diff options
author | Martin K. Petersen <martin.petersen@oracle.com> | 2014-01-03 18:19:26 -0500 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2014-03-27 11:26:33 -0400 |
commit | b2bff6ceb61a9a21294f04057d30c9bb4910a88f (patch) | |
tree | ae92ba064ed276ef34d560aad344b64044590159 | |
parent | 89d9a567952baec13e26ada3e438f1b642d66b6e (diff) |
[SCSI] sd: Quiesce mode sense error messages
Messages about discovered disk properties are only printed once unless
they are found to have changed. Errors encountered during mode sense,
however, are printed every time we revalidate.
Quiesce mode sense errors so they are only printed during the first
scan.
[jejb: checkpatch fixes]
Bugzilla: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=733565
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
-rw-r--r-- | drivers/scsi/sd.c | 38 | ||||
-rw-r--r-- | drivers/scsi/sd.h | 6 |
2 files changed, 28 insertions, 16 deletions
diff --git a/drivers/scsi/sd.c b/drivers/scsi/sd.c index 36d1a23f14be..89e6c04ac595 100644 --- a/drivers/scsi/sd.c +++ b/drivers/scsi/sd.c | |||
@@ -2281,7 +2281,7 @@ sd_read_write_protect_flag(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2281 | 2281 | ||
2282 | set_disk_ro(sdkp->disk, 0); | 2282 | set_disk_ro(sdkp->disk, 0); |
2283 | if (sdp->skip_ms_page_3f) { | 2283 | if (sdp->skip_ms_page_3f) { |
2284 | sd_printk(KERN_NOTICE, sdkp, "Assuming Write Enabled\n"); | 2284 | sd_first_printk(KERN_NOTICE, sdkp, "Assuming Write Enabled\n"); |
2285 | return; | 2285 | return; |
2286 | } | 2286 | } |
2287 | 2287 | ||
@@ -2313,7 +2313,7 @@ sd_read_write_protect_flag(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2313 | } | 2313 | } |
2314 | 2314 | ||
2315 | if (!scsi_status_is_good(res)) { | 2315 | if (!scsi_status_is_good(res)) { |
2316 | sd_printk(KERN_WARNING, sdkp, | 2316 | sd_first_printk(KERN_WARNING, sdkp, |
2317 | "Test WP failed, assume Write Enabled\n"); | 2317 | "Test WP failed, assume Write Enabled\n"); |
2318 | } else { | 2318 | } else { |
2319 | sdkp->write_prot = ((data.device_specific & 0x80) != 0); | 2319 | sdkp->write_prot = ((data.device_specific & 0x80) != 0); |
@@ -2381,7 +2381,8 @@ sd_read_cache_type(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2381 | if (!data.header_length) { | 2381 | if (!data.header_length) { |
2382 | modepage = 6; | 2382 | modepage = 6; |
2383 | first_len = 0; | 2383 | first_len = 0; |
2384 | sd_printk(KERN_ERR, sdkp, "Missing header in MODE_SENSE response\n"); | 2384 | sd_first_printk(KERN_ERR, sdkp, |
2385 | "Missing header in MODE_SENSE response\n"); | ||
2385 | } | 2386 | } |
2386 | 2387 | ||
2387 | /* that went OK, now ask for the proper length */ | 2388 | /* that went OK, now ask for the proper length */ |
@@ -2394,7 +2395,7 @@ sd_read_cache_type(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2394 | if (len < 3) | 2395 | if (len < 3) |
2395 | goto bad_sense; | 2396 | goto bad_sense; |
2396 | else if (len > SD_BUF_SIZE) { | 2397 | else if (len > SD_BUF_SIZE) { |
2397 | sd_printk(KERN_NOTICE, sdkp, "Truncating mode parameter " | 2398 | sd_first_printk(KERN_NOTICE, sdkp, "Truncating mode parameter " |
2398 | "data from %d to %d bytes\n", len, SD_BUF_SIZE); | 2399 | "data from %d to %d bytes\n", len, SD_BUF_SIZE); |
2399 | len = SD_BUF_SIZE; | 2400 | len = SD_BUF_SIZE; |
2400 | } | 2401 | } |
@@ -2417,8 +2418,9 @@ sd_read_cache_type(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2417 | /* We're interested only in the first 3 bytes. | 2418 | /* We're interested only in the first 3 bytes. |
2418 | */ | 2419 | */ |
2419 | if (len - offset <= 2) { | 2420 | if (len - offset <= 2) { |
2420 | sd_printk(KERN_ERR, sdkp, "Incomplete " | 2421 | sd_first_printk(KERN_ERR, sdkp, |
2421 | "mode parameter data\n"); | 2422 | "Incomplete mode parameter " |
2423 | "data\n"); | ||
2422 | goto defaults; | 2424 | goto defaults; |
2423 | } else { | 2425 | } else { |
2424 | modepage = page_code; | 2426 | modepage = page_code; |
@@ -2432,14 +2434,15 @@ sd_read_cache_type(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2432 | else if (!spf && len - offset > 1) | 2434 | else if (!spf && len - offset > 1) |
2433 | offset += 2 + buffer[offset+1]; | 2435 | offset += 2 + buffer[offset+1]; |
2434 | else { | 2436 | else { |
2435 | sd_printk(KERN_ERR, sdkp, "Incomplete " | 2437 | sd_first_printk(KERN_ERR, sdkp, |
2436 | "mode parameter data\n"); | 2438 | "Incomplete mode " |
2439 | "parameter data\n"); | ||
2437 | goto defaults; | 2440 | goto defaults; |
2438 | } | 2441 | } |
2439 | } | 2442 | } |
2440 | } | 2443 | } |
2441 | 2444 | ||
2442 | sd_printk(KERN_ERR, sdkp, "No Caching mode page found\n"); | 2445 | sd_first_printk(KERN_ERR, sdkp, "No Caching mode page found\n"); |
2443 | goto defaults; | 2446 | goto defaults; |
2444 | 2447 | ||
2445 | Page_found: | 2448 | Page_found: |
@@ -2453,7 +2456,7 @@ sd_read_cache_type(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2453 | 2456 | ||
2454 | sdkp->DPOFUA = (data.device_specific & 0x10) != 0; | 2457 | sdkp->DPOFUA = (data.device_specific & 0x10) != 0; |
2455 | if (sdkp->DPOFUA && !sdkp->device->use_10_for_rw) { | 2458 | if (sdkp->DPOFUA && !sdkp->device->use_10_for_rw) { |
2456 | sd_printk(KERN_NOTICE, sdkp, | 2459 | sd_first_printk(KERN_NOTICE, sdkp, |
2457 | "Uses READ/WRITE(6), disabling FUA\n"); | 2460 | "Uses READ/WRITE(6), disabling FUA\n"); |
2458 | sdkp->DPOFUA = 0; | 2461 | sdkp->DPOFUA = 0; |
2459 | } | 2462 | } |
@@ -2475,16 +2478,19 @@ bad_sense: | |||
2475 | sshdr.sense_key == ILLEGAL_REQUEST && | 2478 | sshdr.sense_key == ILLEGAL_REQUEST && |
2476 | sshdr.asc == 0x24 && sshdr.ascq == 0x0) | 2479 | sshdr.asc == 0x24 && sshdr.ascq == 0x0) |
2477 | /* Invalid field in CDB */ | 2480 | /* Invalid field in CDB */ |
2478 | sd_printk(KERN_NOTICE, sdkp, "Cache data unavailable\n"); | 2481 | sd_first_printk(KERN_NOTICE, sdkp, "Cache data unavailable\n"); |
2479 | else | 2482 | else |
2480 | sd_printk(KERN_ERR, sdkp, "Asking for cache data failed\n"); | 2483 | sd_first_printk(KERN_ERR, sdkp, |
2484 | "Asking for cache data failed\n"); | ||
2481 | 2485 | ||
2482 | defaults: | 2486 | defaults: |
2483 | if (sdp->wce_default_on) { | 2487 | if (sdp->wce_default_on) { |
2484 | sd_printk(KERN_NOTICE, sdkp, "Assuming drive cache: write back\n"); | 2488 | sd_first_printk(KERN_NOTICE, sdkp, |
2489 | "Assuming drive cache: write back\n"); | ||
2485 | sdkp->WCE = 1; | 2490 | sdkp->WCE = 1; |
2486 | } else { | 2491 | } else { |
2487 | sd_printk(KERN_ERR, sdkp, "Assuming drive cache: write through\n"); | 2492 | sd_first_printk(KERN_ERR, sdkp, |
2493 | "Assuming drive cache: write through\n"); | ||
2488 | sdkp->WCE = 0; | 2494 | sdkp->WCE = 0; |
2489 | } | 2495 | } |
2490 | sdkp->RCD = 0; | 2496 | sdkp->RCD = 0; |
@@ -2513,7 +2519,7 @@ static void sd_read_app_tag_own(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2513 | 2519 | ||
2514 | if (!scsi_status_is_good(res) || !data.header_length || | 2520 | if (!scsi_status_is_good(res) || !data.header_length || |
2515 | data.length < 6) { | 2521 | data.length < 6) { |
2516 | sd_printk(KERN_WARNING, sdkp, | 2522 | sd_first_printk(KERN_WARNING, sdkp, |
2517 | "getting Control mode page failed, assume no ATO\n"); | 2523 | "getting Control mode page failed, assume no ATO\n"); |
2518 | 2524 | ||
2519 | if (scsi_sense_valid(&sshdr)) | 2525 | if (scsi_sense_valid(&sshdr)) |
@@ -2525,7 +2531,7 @@ static void sd_read_app_tag_own(struct scsi_disk *sdkp, unsigned char *buffer) | |||
2525 | offset = data.header_length + data.block_descriptor_length; | 2531 | offset = data.header_length + data.block_descriptor_length; |
2526 | 2532 | ||
2527 | if ((buffer[offset] & 0x3f) != 0x0a) { | 2533 | if ((buffer[offset] & 0x3f) != 0x0a) { |
2528 | sd_printk(KERN_ERR, sdkp, "ATO Got wrong page\n"); | 2534 | sd_first_printk(KERN_ERR, sdkp, "ATO Got wrong page\n"); |
2529 | return; | 2535 | return; |
2530 | } | 2536 | } |
2531 | 2537 | ||
diff --git a/drivers/scsi/sd.h b/drivers/scsi/sd.h index 26895ff247c5..620871efbf0a 100644 --- a/drivers/scsi/sd.h +++ b/drivers/scsi/sd.h | |||
@@ -104,6 +104,12 @@ static inline struct scsi_disk *scsi_disk(struct gendisk *disk) | |||
104 | (sdsk)->disk->disk_name, ##a) : \ | 104 | (sdsk)->disk->disk_name, ##a) : \ |
105 | sdev_printk(prefix, (sdsk)->device, fmt, ##a) | 105 | sdev_printk(prefix, (sdsk)->device, fmt, ##a) |
106 | 106 | ||
107 | #define sd_first_printk(prefix, sdsk, fmt, a...) \ | ||
108 | do { \ | ||
109 | if ((sdkp)->first_scan) \ | ||
110 | sd_printk(prefix, sdsk, fmt, ##a); \ | ||
111 | } while (0) | ||
112 | |||
107 | static inline int scsi_medium_access_command(struct scsi_cmnd *scmd) | 113 | static inline int scsi_medium_access_command(struct scsi_cmnd *scmd) |
108 | { | 114 | { |
109 | switch (scmd->cmnd[0]) { | 115 | switch (scmd->cmnd[0]) { |