diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-04-22 11:43:59 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-04-22 11:43:59 -0400 |
| commit | c81eddb0e3728661d1585fbc564449c94165cc36 (patch) | |
| tree | bd7dbc09bec4c1c90552718d48fb7f30b94e0265 | |
| parent | a28ca3f3244dfe05d16c67f2c0636ce6bf2b4e0a (diff) | |
| parent | 76ef964c78797f9baed7c2f9a58f696e86d8a048 (diff) | |
Merge branch 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6
* 'for-linus' of git://git390.marist.edu/pub/scm/linux-2.6:
[S390] zcore: Fix reipl device detection
[S390] vdso: use ntp adjusted clock multiplier
[S390] cio: use exception-save stsch
[S390] add hook to reenable mss after hibernation
[S390] cio: allow enable_facility from outside init functions
[S390] dasd: fix endless loop in erp
| -rw-r--r-- | arch/s390/include/asm/vdso.h | 1 | ||||
| -rw-r--r-- | arch/s390/kernel/asm-offsets.c | 1 | ||||
| -rw-r--r-- | arch/s390/kernel/swsusp_asm64.S | 3 | ||||
| -rw-r--r-- | arch/s390/kernel/time.c | 1 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/clock_gettime.S | 12 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/gettimeofday.S | 6 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso64/clock_gettime.S | 4 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso64/gettimeofday.S | 2 | ||||
| -rw-r--r-- | drivers/s390/block/dasd.c | 3 | ||||
| -rw-r--r-- | drivers/s390/block/dasd_3990_erp.c | 7 | ||||
| -rw-r--r-- | drivers/s390/char/zcore.c | 6 | ||||
| -rw-r--r-- | drivers/s390/cio/chsc.c | 29 | ||||
| -rw-r--r-- | drivers/s390/cio/chsc_sch.c | 2 | ||||
| -rw-r--r-- | drivers/s390/cio/cio.c | 18 | ||||
| -rw-r--r-- | drivers/s390/cio/css.c | 16 | ||||
| -rw-r--r-- | drivers/s390/cio/device_fsm.c | 2 |
16 files changed, 60 insertions, 53 deletions
diff --git a/arch/s390/include/asm/vdso.h b/arch/s390/include/asm/vdso.h index 4a76d9480cce..533f35751aeb 100644 --- a/arch/s390/include/asm/vdso.h +++ b/arch/s390/include/asm/vdso.h | |||
| @@ -29,6 +29,7 @@ struct vdso_data { | |||
| 29 | __u32 tz_minuteswest; /* Minutes west of Greenwich 0x30 */ | 29 | __u32 tz_minuteswest; /* Minutes west of Greenwich 0x30 */ |
| 30 | __u32 tz_dsttime; /* Type of dst correction 0x34 */ | 30 | __u32 tz_dsttime; /* Type of dst correction 0x34 */ |
| 31 | __u32 ectg_available; | 31 | __u32 ectg_available; |
| 32 | __u32 ntp_mult; /* NTP adjusted multiplier 0x3C */ | ||
| 32 | }; | 33 | }; |
| 33 | 34 | ||
| 34 | struct vdso_per_cpu_data { | 35 | struct vdso_per_cpu_data { |
diff --git a/arch/s390/kernel/asm-offsets.c b/arch/s390/kernel/asm-offsets.c index 08db736dded0..a09408952ed0 100644 --- a/arch/s390/kernel/asm-offsets.c +++ b/arch/s390/kernel/asm-offsets.c | |||
| @@ -61,6 +61,7 @@ int main(void) | |||
| 61 | DEFINE(__VDSO_WTOM_NSEC, offsetof(struct vdso_data, wtom_clock_nsec)); | 61 | DEFINE(__VDSO_WTOM_NSEC, offsetof(struct vdso_data, wtom_clock_nsec)); |
| 62 | DEFINE(__VDSO_TIMEZONE, offsetof(struct vdso_data, tz_minuteswest)); | 62 | DEFINE(__VDSO_TIMEZONE, offsetof(struct vdso_data, tz_minuteswest)); |
| 63 | DEFINE(__VDSO_ECTG_OK, offsetof(struct vdso_data, ectg_available)); | 63 | DEFINE(__VDSO_ECTG_OK, offsetof(struct vdso_data, ectg_available)); |
| 64 | DEFINE(__VDSO_NTP_MULT, offsetof(struct vdso_data, ntp_mult)); | ||
| 64 | DEFINE(__VDSO_ECTG_BASE, offsetof(struct vdso_per_cpu_data, ectg_timer_base)); | 65 | DEFINE(__VDSO_ECTG_BASE, offsetof(struct vdso_per_cpu_data, ectg_timer_base)); |
| 65 | DEFINE(__VDSO_ECTG_USER, offsetof(struct vdso_per_cpu_data, ectg_user_time)); | 66 | DEFINE(__VDSO_ECTG_USER, offsetof(struct vdso_per_cpu_data, ectg_user_time)); |
| 66 | /* constants used by the vdso */ | 67 | /* constants used by the vdso */ |
diff --git a/arch/s390/kernel/swsusp_asm64.S b/arch/s390/kernel/swsusp_asm64.S index b354427e03b7..c56d3f56d020 100644 --- a/arch/s390/kernel/swsusp_asm64.S +++ b/arch/s390/kernel/swsusp_asm64.S | |||
| @@ -256,6 +256,9 @@ restore_registers: | |||
| 256 | lghi %r2,0 | 256 | lghi %r2,0 |
| 257 | brasl %r14,arch_set_page_states | 257 | brasl %r14,arch_set_page_states |
| 258 | 258 | ||
| 259 | /* Reinitialize the channel subsystem */ | ||
| 260 | brasl %r14,channel_subsystem_reinit | ||
| 261 | |||
| 259 | /* Return 0 */ | 262 | /* Return 0 */ |
| 260 | lmg %r6,%r15,STACK_FRAME_OVERHEAD + __SF_GPRS(%r15) | 263 | lmg %r6,%r15,STACK_FRAME_OVERHEAD + __SF_GPRS(%r15) |
| 261 | lghi %r2,0 | 264 | lghi %r2,0 |
diff --git a/arch/s390/kernel/time.c b/arch/s390/kernel/time.c index fba6dec156bf..d906bf19c14a 100644 --- a/arch/s390/kernel/time.c +++ b/arch/s390/kernel/time.c | |||
| @@ -221,6 +221,7 @@ void update_vsyscall(struct timespec *wall_time, struct clocksource *clock, | |||
| 221 | vdso_data->xtime_clock_nsec = wall_time->tv_nsec; | 221 | vdso_data->xtime_clock_nsec = wall_time->tv_nsec; |
| 222 | vdso_data->wtom_clock_sec = wall_to_monotonic.tv_sec; | 222 | vdso_data->wtom_clock_sec = wall_to_monotonic.tv_sec; |
| 223 | vdso_data->wtom_clock_nsec = wall_to_monotonic.tv_nsec; | 223 | vdso_data->wtom_clock_nsec = wall_to_monotonic.tv_nsec; |
| 224 | vdso_data->ntp_mult = mult; | ||
| 224 | smp_wmb(); | 225 | smp_wmb(); |
| 225 | ++vdso_data->tb_update_count; | 226 | ++vdso_data->tb_update_count; |
| 226 | } | 227 | } |
diff --git a/arch/s390/kernel/vdso32/clock_gettime.S b/arch/s390/kernel/vdso32/clock_gettime.S index 4a98909a8310..969643954273 100644 --- a/arch/s390/kernel/vdso32/clock_gettime.S +++ b/arch/s390/kernel/vdso32/clock_gettime.S | |||
| @@ -38,13 +38,13 @@ __kernel_clock_gettime: | |||
| 38 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) | 38 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) |
| 39 | brc 3,2f | 39 | brc 3,2f |
| 40 | ahi %r0,-1 | 40 | ahi %r0,-1 |
| 41 | 2: mhi %r0,1000 /* cyc2ns(clock,cycle_delta) */ | 41 | 2: ms %r0,__VDSO_NTP_MULT(%r5) /* cyc2ns(clock,cycle_delta) */ |
| 42 | lr %r2,%r0 | 42 | lr %r2,%r0 |
| 43 | lhi %r0,1000 | 43 | l %r0,__VDSO_NTP_MULT(%r5) |
| 44 | ltr %r1,%r1 | 44 | ltr %r1,%r1 |
| 45 | mr %r0,%r0 | 45 | mr %r0,%r0 |
| 46 | jnm 3f | 46 | jnm 3f |
| 47 | ahi %r0,1000 | 47 | a %r0,__VDSO_NTP_MULT(%r5) |
| 48 | 3: alr %r0,%r2 | 48 | 3: alr %r0,%r2 |
| 49 | srdl %r0,12 | 49 | srdl %r0,12 |
| 50 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | 50 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ |
| @@ -86,13 +86,13 @@ __kernel_clock_gettime: | |||
| 86 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) | 86 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) |
| 87 | brc 3,12f | 87 | brc 3,12f |
| 88 | ahi %r0,-1 | 88 | ahi %r0,-1 |
| 89 | 12: mhi %r0,1000 /* cyc2ns(clock,cycle_delta) */ | 89 | 12: ms %r0,__VDSO_NTP_MULT(%r5) /* cyc2ns(clock,cycle_delta) */ |
| 90 | lr %r2,%r0 | 90 | lr %r2,%r0 |
| 91 | lhi %r0,1000 | 91 | l %r0,__VDSO_NTP_MULT(%r5) |
| 92 | ltr %r1,%r1 | 92 | ltr %r1,%r1 |
| 93 | mr %r0,%r0 | 93 | mr %r0,%r0 |
| 94 | jnm 13f | 94 | jnm 13f |
| 95 | ahi %r0,1000 | 95 | a %r0,__VDSO_NTP_MULT(%r5) |
| 96 | 13: alr %r0,%r2 | 96 | 13: alr %r0,%r2 |
| 97 | srdl %r0,12 | 97 | srdl %r0,12 |
| 98 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | 98 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ |
diff --git a/arch/s390/kernel/vdso32/gettimeofday.S b/arch/s390/kernel/vdso32/gettimeofday.S index ad8acfc949fb..2d3633175e3b 100644 --- a/arch/s390/kernel/vdso32/gettimeofday.S +++ b/arch/s390/kernel/vdso32/gettimeofday.S | |||
| @@ -35,13 +35,13 @@ __kernel_gettimeofday: | |||
| 35 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) | 35 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) |
| 36 | brc 3,3f | 36 | brc 3,3f |
| 37 | ahi %r0,-1 | 37 | ahi %r0,-1 |
| 38 | 3: mhi %r0,1000 /* cyc2ns(clock,cycle_delta) */ | 38 | 3: ms %r0,__VDSO_NTP_MULT(%r5) /* cyc2ns(clock,cycle_delta) */ |
| 39 | st %r0,24(%r15) | 39 | st %r0,24(%r15) |
| 40 | lhi %r0,1000 | 40 | l %r0,__VDSO_NTP_MULT(%r5) |
| 41 | ltr %r1,%r1 | 41 | ltr %r1,%r1 |
| 42 | mr %r0,%r0 | 42 | mr %r0,%r0 |
| 43 | jnm 4f | 43 | jnm 4f |
| 44 | ahi %r0,1000 | 44 | a %r0,__VDSO_NTP_MULT(%r5) |
| 45 | 4: al %r0,24(%r15) | 45 | 4: al %r0,24(%r15) |
| 46 | srdl %r0,12 | 46 | srdl %r0,12 |
| 47 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | 47 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ |
diff --git a/arch/s390/kernel/vdso64/clock_gettime.S b/arch/s390/kernel/vdso64/clock_gettime.S index 49106c6e6f88..f40467884a03 100644 --- a/arch/s390/kernel/vdso64/clock_gettime.S +++ b/arch/s390/kernel/vdso64/clock_gettime.S | |||
| @@ -36,7 +36,7 @@ __kernel_clock_gettime: | |||
| 36 | stck 48(%r15) /* Store TOD clock */ | 36 | stck 48(%r15) /* Store TOD clock */ |
| 37 | lg %r1,48(%r15) | 37 | lg %r1,48(%r15) |
| 38 | sg %r1,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ | 38 | sg %r1,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ |
| 39 | mghi %r1,1000 | 39 | msgf %r1,__VDSO_NTP_MULT(%r5) /* * NTP adjustment */ |
| 40 | srlg %r1,%r1,12 /* cyc2ns(clock,cycle_delta) */ | 40 | srlg %r1,%r1,12 /* cyc2ns(clock,cycle_delta) */ |
| 41 | alg %r1,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | 41 | alg %r1,__VDSO_XTIME_NSEC(%r5) /* + xtime */ |
| 42 | lg %r0,__VDSO_XTIME_SEC(%r5) | 42 | lg %r0,__VDSO_XTIME_SEC(%r5) |
| @@ -64,7 +64,7 @@ __kernel_clock_gettime: | |||
| 64 | stck 48(%r15) /* Store TOD clock */ | 64 | stck 48(%r15) /* Store TOD clock */ |
| 65 | lg %r1,48(%r15) | 65 | lg %r1,48(%r15) |
| 66 | sg %r1,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ | 66 | sg %r1,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ |
| 67 | mghi %r1,1000 | 67 | msgf %r1,__VDSO_NTP_MULT(%r5) /* * NTP adjustment */ |
| 68 | srlg %r1,%r1,12 /* cyc2ns(clock,cycle_delta) */ | 68 | srlg %r1,%r1,12 /* cyc2ns(clock,cycle_delta) */ |
| 69 | alg %r1,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | 69 | alg %r1,__VDSO_XTIME_NSEC(%r5) /* + xtime */ |
| 70 | lg %r0,__VDSO_XTIME_SEC(%r5) | 70 | lg %r0,__VDSO_XTIME_SEC(%r5) |
diff --git a/arch/s390/kernel/vdso64/gettimeofday.S b/arch/s390/kernel/vdso64/gettimeofday.S index f873e75634e1..36ee674722ec 100644 --- a/arch/s390/kernel/vdso64/gettimeofday.S +++ b/arch/s390/kernel/vdso64/gettimeofday.S | |||
| @@ -31,7 +31,7 @@ __kernel_gettimeofday: | |||
| 31 | stck 48(%r15) /* Store TOD clock */ | 31 | stck 48(%r15) /* Store TOD clock */ |
| 32 | lg %r1,48(%r15) | 32 | lg %r1,48(%r15) |
| 33 | sg %r1,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ | 33 | sg %r1,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ |
| 34 | mghi %r1,1000 | 34 | msgf %r1,__VDSO_NTP_MULT(%r5) /* * NTP adjustment */ |
| 35 | srlg %r1,%r1,12 /* cyc2ns(clock,cycle_delta) */ | 35 | srlg %r1,%r1,12 /* cyc2ns(clock,cycle_delta) */ |
| 36 | alg %r1,__VDSO_XTIME_NSEC(%r5) /* + xtime.tv_nsec */ | 36 | alg %r1,__VDSO_XTIME_NSEC(%r5) /* + xtime.tv_nsec */ |
| 37 | lg %r0,__VDSO_XTIME_SEC(%r5) /* xtime.tv_sec */ | 37 | lg %r0,__VDSO_XTIME_SEC(%r5) /* xtime.tv_sec */ |
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c index bbea90baf98f..acf222f91f5a 100644 --- a/drivers/s390/block/dasd.c +++ b/drivers/s390/block/dasd.c | |||
| @@ -1899,7 +1899,8 @@ restart: | |||
| 1899 | /* Process requests that may be recovered */ | 1899 | /* Process requests that may be recovered */ |
| 1900 | if (cqr->status == DASD_CQR_NEED_ERP) { | 1900 | if (cqr->status == DASD_CQR_NEED_ERP) { |
| 1901 | erp_fn = base->discipline->erp_action(cqr); | 1901 | erp_fn = base->discipline->erp_action(cqr); |
| 1902 | erp_fn(cqr); | 1902 | if (IS_ERR(erp_fn(cqr))) |
| 1903 | continue; | ||
| 1903 | goto restart; | 1904 | goto restart; |
| 1904 | } | 1905 | } |
| 1905 | 1906 | ||
diff --git a/drivers/s390/block/dasd_3990_erp.c b/drivers/s390/block/dasd_3990_erp.c index 6927e751ce3e..6632649dd6aa 100644 --- a/drivers/s390/block/dasd_3990_erp.c +++ b/drivers/s390/block/dasd_3990_erp.c | |||
| @@ -2309,7 +2309,7 @@ static struct dasd_ccw_req *dasd_3990_erp_add_erp(struct dasd_ccw_req *cqr) | |||
| 2309 | cqr->retries); | 2309 | cqr->retries); |
| 2310 | dasd_block_set_timer(device->block, (HZ << 3)); | 2310 | dasd_block_set_timer(device->block, (HZ << 3)); |
| 2311 | } | 2311 | } |
| 2312 | return cqr; | 2312 | return erp; |
| 2313 | } | 2313 | } |
| 2314 | 2314 | ||
| 2315 | ccw = cqr->cpaddr; | 2315 | ccw = cqr->cpaddr; |
| @@ -2372,6 +2372,9 @@ dasd_3990_erp_additional_erp(struct dasd_ccw_req * cqr) | |||
| 2372 | /* add erp and initialize with default TIC */ | 2372 | /* add erp and initialize with default TIC */ |
| 2373 | erp = dasd_3990_erp_add_erp(cqr); | 2373 | erp = dasd_3990_erp_add_erp(cqr); |
| 2374 | 2374 | ||
| 2375 | if (IS_ERR(erp)) | ||
| 2376 | return erp; | ||
| 2377 | |||
| 2375 | /* inspect sense, determine specific ERP if possible */ | 2378 | /* inspect sense, determine specific ERP if possible */ |
| 2376 | if (erp != cqr) { | 2379 | if (erp != cqr) { |
| 2377 | 2380 | ||
| @@ -2711,6 +2714,8 @@ dasd_3990_erp_action(struct dasd_ccw_req * cqr) | |||
| 2711 | if (erp == NULL) { | 2714 | if (erp == NULL) { |
| 2712 | /* no matching erp found - set up erp */ | 2715 | /* no matching erp found - set up erp */ |
| 2713 | erp = dasd_3990_erp_additional_erp(cqr); | 2716 | erp = dasd_3990_erp_additional_erp(cqr); |
| 2717 | if (IS_ERR(erp)) | ||
| 2718 | return erp; | ||
| 2714 | } else { | 2719 | } else { |
| 2715 | /* matching erp found - set all leading erp's to DONE */ | 2720 | /* matching erp found - set all leading erp's to DONE */ |
| 2716 | erp = dasd_3990_erp_handle_match_erp(cqr, erp); | 2721 | erp = dasd_3990_erp_handle_match_erp(cqr, erp); |
diff --git a/drivers/s390/char/zcore.c b/drivers/s390/char/zcore.c index 18daf16aa357..7217966f7d31 100644 --- a/drivers/s390/char/zcore.c +++ b/drivers/s390/char/zcore.c | |||
| @@ -638,11 +638,7 @@ static int __init zcore_reipl_init(void) | |||
| 638 | rc = memcpy_hsa_kernel(ipl_block, ipib_info.ipib, PAGE_SIZE); | 638 | rc = memcpy_hsa_kernel(ipl_block, ipib_info.ipib, PAGE_SIZE); |
| 639 | else | 639 | else |
| 640 | rc = memcpy_real(ipl_block, (void *) ipib_info.ipib, PAGE_SIZE); | 640 | rc = memcpy_real(ipl_block, (void *) ipib_info.ipib, PAGE_SIZE); |
| 641 | if (rc) { | 641 | if (rc || csum_partial(ipl_block, ipl_block->hdr.len, 0) != |
| 642 | free_page((unsigned long) ipl_block); | ||
| 643 | return rc; | ||
| 644 | } | ||
| 645 | if (csum_partial(ipl_block, ipl_block->hdr.len, 0) != | ||
| 646 | ipib_info.checksum) { | 642 | ipib_info.checksum) { |
| 647 | TRACE("Checksum does not match\n"); | 643 | TRACE("Checksum does not match\n"); |
| 648 | free_page((unsigned long) ipl_block); | 644 | free_page((unsigned long) ipl_block); |
diff --git a/drivers/s390/cio/chsc.c b/drivers/s390/cio/chsc.c index 4038f5b4f144..ce7cb87479fe 100644 --- a/drivers/s390/cio/chsc.c +++ b/drivers/s390/cio/chsc.c | |||
| @@ -29,6 +29,7 @@ | |||
| 29 | #include "chsc.h" | 29 | #include "chsc.h" |
| 30 | 30 | ||
| 31 | static void *sei_page; | 31 | static void *sei_page; |
| 32 | static DEFINE_SPINLOCK(sda_lock); | ||
| 32 | 33 | ||
| 33 | /** | 34 | /** |
| 34 | * chsc_error_from_response() - convert a chsc response to an error | 35 | * chsc_error_from_response() - convert a chsc response to an error |
| @@ -832,11 +833,10 @@ void __init chsc_free_sei_area(void) | |||
| 832 | kfree(sei_page); | 833 | kfree(sei_page); |
| 833 | } | 834 | } |
| 834 | 835 | ||
| 835 | int __init | 836 | int chsc_enable_facility(int operation_code) |
| 836 | chsc_enable_facility(int operation_code) | ||
| 837 | { | 837 | { |
| 838 | int ret; | 838 | int ret; |
| 839 | struct { | 839 | static struct { |
| 840 | struct chsc_header request; | 840 | struct chsc_header request; |
| 841 | u8 reserved1:4; | 841 | u8 reserved1:4; |
| 842 | u8 format:4; | 842 | u8 format:4; |
| @@ -849,33 +849,32 @@ chsc_enable_facility(int operation_code) | |||
| 849 | u32 reserved5:4; | 849 | u32 reserved5:4; |
| 850 | u32 format2:4; | 850 | u32 format2:4; |
| 851 | u32 reserved6:24; | 851 | u32 reserved6:24; |
| 852 | } __attribute__ ((packed)) *sda_area; | 852 | } __attribute__ ((packed, aligned(4096))) sda_area; |
| 853 | 853 | ||
| 854 | sda_area = (void *)get_zeroed_page(GFP_KERNEL|GFP_DMA); | 854 | spin_lock(&sda_lock); |
| 855 | if (!sda_area) | 855 | memset(&sda_area, 0, sizeof(sda_area)); |
| 856 | return -ENOMEM; | 856 | sda_area.request.length = 0x0400; |
| 857 | sda_area->request.length = 0x0400; | 857 | sda_area.request.code = 0x0031; |
| 858 | sda_area->request.code = 0x0031; | 858 | sda_area.operation_code = operation_code; |
| 859 | sda_area->operation_code = operation_code; | ||
| 860 | 859 | ||
| 861 | ret = chsc(sda_area); | 860 | ret = chsc(&sda_area); |
| 862 | if (ret > 0) { | 861 | if (ret > 0) { |
| 863 | ret = (ret == 3) ? -ENODEV : -EBUSY; | 862 | ret = (ret == 3) ? -ENODEV : -EBUSY; |
| 864 | goto out; | 863 | goto out; |
| 865 | } | 864 | } |
| 866 | 865 | ||
| 867 | switch (sda_area->response.code) { | 866 | switch (sda_area.response.code) { |
| 868 | case 0x0101: | 867 | case 0x0101: |
| 869 | ret = -EOPNOTSUPP; | 868 | ret = -EOPNOTSUPP; |
| 870 | break; | 869 | break; |
| 871 | default: | 870 | default: |
| 872 | ret = chsc_error_from_response(sda_area->response.code); | 871 | ret = chsc_error_from_response(sda_area.response.code); |
| 873 | } | 872 | } |
| 874 | if (ret != 0) | 873 | if (ret != 0) |
| 875 | CIO_CRW_EVENT(2, "chsc: sda (oc=%x) failed (rc=%04x)\n", | 874 | CIO_CRW_EVENT(2, "chsc: sda (oc=%x) failed (rc=%04x)\n", |
| 876 | operation_code, sda_area->response.code); | 875 | operation_code, sda_area.response.code); |
| 877 | out: | 876 | out: |
| 878 | free_page((unsigned long)sda_area); | 877 | spin_unlock(&sda_lock); |
| 879 | return ret; | 878 | return ret; |
| 880 | } | 879 | } |
| 881 | 880 | ||
diff --git a/drivers/s390/cio/chsc_sch.c b/drivers/s390/cio/chsc_sch.c index 404f630c27ca..3b6f4adc5094 100644 --- a/drivers/s390/cio/chsc_sch.c +++ b/drivers/s390/cio/chsc_sch.c | |||
| @@ -124,7 +124,7 @@ static int chsc_subchannel_prepare(struct subchannel *sch) | |||
| 124 | * since we don't have a way to clear the subchannel and | 124 | * since we don't have a way to clear the subchannel and |
| 125 | * cannot disable it with a request running. | 125 | * cannot disable it with a request running. |
| 126 | */ | 126 | */ |
| 127 | cc = stsch(sch->schid, &schib); | 127 | cc = stsch_err(sch->schid, &schib); |
| 128 | if (!cc && scsw_stctl(&schib.scsw)) | 128 | if (!cc && scsw_stctl(&schib.scsw)) |
| 129 | return -EAGAIN; | 129 | return -EAGAIN; |
| 130 | return 0; | 130 | return 0; |
diff --git a/drivers/s390/cio/cio.c b/drivers/s390/cio/cio.c index f736cdcf08ad..5feea1a371e1 100644 --- a/drivers/s390/cio/cio.c +++ b/drivers/s390/cio/cio.c | |||
| @@ -361,7 +361,7 @@ int cio_commit_config(struct subchannel *sch) | |||
| 361 | struct schib schib; | 361 | struct schib schib; |
| 362 | int ccode, retry, ret = 0; | 362 | int ccode, retry, ret = 0; |
| 363 | 363 | ||
| 364 | if (stsch(sch->schid, &schib) || !css_sch_is_valid(&schib)) | 364 | if (stsch_err(sch->schid, &schib) || !css_sch_is_valid(&schib)) |
| 365 | return -ENODEV; | 365 | return -ENODEV; |
| 366 | 366 | ||
| 367 | for (retry = 0; retry < 5; retry++) { | 367 | for (retry = 0; retry < 5; retry++) { |
| @@ -372,7 +372,7 @@ int cio_commit_config(struct subchannel *sch) | |||
| 372 | return ccode; | 372 | return ccode; |
| 373 | switch (ccode) { | 373 | switch (ccode) { |
| 374 | case 0: /* successful */ | 374 | case 0: /* successful */ |
| 375 | if (stsch(sch->schid, &schib) || | 375 | if (stsch_err(sch->schid, &schib) || |
| 376 | !css_sch_is_valid(&schib)) | 376 | !css_sch_is_valid(&schib)) |
| 377 | return -ENODEV; | 377 | return -ENODEV; |
| 378 | if (cio_check_config(sch, &schib)) { | 378 | if (cio_check_config(sch, &schib)) { |
| @@ -404,7 +404,7 @@ int cio_update_schib(struct subchannel *sch) | |||
| 404 | { | 404 | { |
| 405 | struct schib schib; | 405 | struct schib schib; |
| 406 | 406 | ||
| 407 | if (stsch(sch->schid, &schib) || !css_sch_is_valid(&schib)) | 407 | if (stsch_err(sch->schid, &schib) || !css_sch_is_valid(&schib)) |
| 408 | return -ENODEV; | 408 | return -ENODEV; |
| 409 | 409 | ||
| 410 | memcpy(&sch->schib, &schib, sizeof(schib)); | 410 | memcpy(&sch->schib, &schib, sizeof(schib)); |
| @@ -771,7 +771,7 @@ cio_get_console_sch_no(void) | |||
| 771 | if (console_irq != -1) { | 771 | if (console_irq != -1) { |
| 772 | /* VM provided us with the irq number of the console. */ | 772 | /* VM provided us with the irq number of the console. */ |
| 773 | schid.sch_no = console_irq; | 773 | schid.sch_no = console_irq; |
| 774 | if (stsch(schid, &console_subchannel.schib) != 0 || | 774 | if (stsch_err(schid, &console_subchannel.schib) != 0 || |
| 775 | (console_subchannel.schib.pmcw.st != SUBCHANNEL_TYPE_IO) || | 775 | (console_subchannel.schib.pmcw.st != SUBCHANNEL_TYPE_IO) || |
| 776 | !console_subchannel.schib.pmcw.dnv) | 776 | !console_subchannel.schib.pmcw.dnv) |
| 777 | return -1; | 777 | return -1; |
| @@ -863,10 +863,10 @@ __disable_subchannel_easy(struct subchannel_id schid, struct schib *schib) | |||
| 863 | cc = 0; | 863 | cc = 0; |
| 864 | for (retry=0;retry<3;retry++) { | 864 | for (retry=0;retry<3;retry++) { |
| 865 | schib->pmcw.ena = 0; | 865 | schib->pmcw.ena = 0; |
| 866 | cc = msch(schid, schib); | 866 | cc = msch_err(schid, schib); |
| 867 | if (cc) | 867 | if (cc) |
| 868 | return (cc==3?-ENODEV:-EBUSY); | 868 | return (cc==3?-ENODEV:-EBUSY); |
| 869 | if (stsch(schid, schib) || !css_sch_is_valid(schib)) | 869 | if (stsch_err(schid, schib) || !css_sch_is_valid(schib)) |
| 870 | return -ENODEV; | 870 | return -ENODEV; |
| 871 | if (!schib->pmcw.ena) | 871 | if (!schib->pmcw.ena) |
| 872 | return 0; | 872 | return 0; |
| @@ -913,7 +913,7 @@ static int stsch_reset(struct subchannel_id schid, struct schib *addr) | |||
| 913 | 913 | ||
| 914 | pgm_check_occured = 0; | 914 | pgm_check_occured = 0; |
| 915 | s390_base_pgm_handler_fn = cio_reset_pgm_check_handler; | 915 | s390_base_pgm_handler_fn = cio_reset_pgm_check_handler; |
| 916 | rc = stsch(schid, addr); | 916 | rc = stsch_err(schid, addr); |
| 917 | s390_base_pgm_handler_fn = NULL; | 917 | s390_base_pgm_handler_fn = NULL; |
| 918 | 918 | ||
| 919 | /* The program check handler could have changed pgm_check_occured. */ | 919 | /* The program check handler could have changed pgm_check_occured. */ |
| @@ -950,7 +950,7 @@ static int __shutdown_subchannel_easy(struct subchannel_id schid, void *data) | |||
| 950 | /* No default clear strategy */ | 950 | /* No default clear strategy */ |
| 951 | break; | 951 | break; |
| 952 | } | 952 | } |
| 953 | stsch(schid, &schib); | 953 | stsch_err(schid, &schib); |
| 954 | __disable_subchannel_easy(schid, &schib); | 954 | __disable_subchannel_easy(schid, &schib); |
| 955 | } | 955 | } |
| 956 | out: | 956 | out: |
| @@ -1086,7 +1086,7 @@ int __init cio_get_iplinfo(struct cio_iplinfo *iplinfo) | |||
| 1086 | schid = *(struct subchannel_id *)&S390_lowcore.subchannel_id; | 1086 | schid = *(struct subchannel_id *)&S390_lowcore.subchannel_id; |
| 1087 | if (!schid.one) | 1087 | if (!schid.one) |
| 1088 | return -ENODEV; | 1088 | return -ENODEV; |
| 1089 | if (stsch(schid, &schib)) | 1089 | if (stsch_err(schid, &schib)) |
| 1090 | return -ENODEV; | 1090 | return -ENODEV; |
| 1091 | if (schib.pmcw.st != SUBCHANNEL_TYPE_IO) | 1091 | if (schib.pmcw.st != SUBCHANNEL_TYPE_IO) |
| 1092 | return -ENODEV; | 1092 | return -ENODEV; |
diff --git a/drivers/s390/cio/css.c b/drivers/s390/cio/css.c index 2769da54f2b9..511649115bd7 100644 --- a/drivers/s390/cio/css.c +++ b/drivers/s390/cio/css.c | |||
| @@ -870,15 +870,10 @@ static int __init css_bus_init(void) | |||
| 870 | 870 | ||
| 871 | /* Try to enable MSS. */ | 871 | /* Try to enable MSS. */ |
| 872 | ret = chsc_enable_facility(CHSC_SDA_OC_MSS); | 872 | ret = chsc_enable_facility(CHSC_SDA_OC_MSS); |
| 873 | switch (ret) { | 873 | if (ret) |
| 874 | case 0: /* Success. */ | ||
| 875 | max_ssid = __MAX_SSID; | ||
| 876 | break; | ||
| 877 | case -ENOMEM: | ||
| 878 | goto out; | ||
| 879 | default: | ||
| 880 | max_ssid = 0; | 874 | max_ssid = 0; |
| 881 | } | 875 | else /* Success. */ |
| 876 | max_ssid = __MAX_SSID; | ||
| 882 | 877 | ||
| 883 | ret = slow_subchannel_init(); | 878 | ret = slow_subchannel_init(); |
| 884 | if (ret) | 879 | if (ret) |
| @@ -1048,6 +1043,11 @@ static int __init channel_subsystem_init_sync(void) | |||
| 1048 | } | 1043 | } |
| 1049 | subsys_initcall_sync(channel_subsystem_init_sync); | 1044 | subsys_initcall_sync(channel_subsystem_init_sync); |
| 1050 | 1045 | ||
| 1046 | void channel_subsystem_reinit(void) | ||
| 1047 | { | ||
| 1048 | chsc_enable_facility(CHSC_SDA_OC_MSS); | ||
| 1049 | } | ||
| 1050 | |||
| 1051 | #ifdef CONFIG_PROC_FS | 1051 | #ifdef CONFIG_PROC_FS |
| 1052 | static ssize_t cio_settle_write(struct file *file, const char __user *buf, | 1052 | static ssize_t cio_settle_write(struct file *file, const char __user *buf, |
| 1053 | size_t count, loff_t *ppos) | 1053 | size_t count, loff_t *ppos) |
diff --git a/drivers/s390/cio/device_fsm.c b/drivers/s390/cio/device_fsm.c index c56ab94612f9..c9b852647f01 100644 --- a/drivers/s390/cio/device_fsm.c +++ b/drivers/s390/cio/device_fsm.c | |||
| @@ -45,7 +45,7 @@ static void ccw_timeout_log(struct ccw_device *cdev) | |||
| 45 | sch = to_subchannel(cdev->dev.parent); | 45 | sch = to_subchannel(cdev->dev.parent); |
| 46 | private = to_io_private(sch); | 46 | private = to_io_private(sch); |
| 47 | orb = &private->orb; | 47 | orb = &private->orb; |
| 48 | cc = stsch(sch->schid, &schib); | 48 | cc = stsch_err(sch->schid, &schib); |
| 49 | 49 | ||
| 50 | printk(KERN_WARNING "cio: ccw device timeout occurred at %llx, " | 50 | printk(KERN_WARNING "cio: ccw device timeout occurred at %llx, " |
| 51 | "device information:\n", get_clock()); | 51 | "device information:\n", get_clock()); |
