diff options
author | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2008-05-10 18:35:55 -0400 |
---|---|---|
committer | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2008-07-14 07:00:18 -0400 |
commit | 3719122a520af2957031859317e74858ab4d3f4b (patch) | |
tree | a9116fbe4e7046f6a5c743390b41381da2699740 | |
parent | ffcaade3109c3a4c0a2c601cf2a44d55b4c3af37 (diff) |
ieee1394: sbp2: fix spindown for PL-3507 and TSB42AA9 firmwares
Reported by Tino Keitel: PL-3507 with firmware from Prolific does not
spin down the disk on START STOP UNIT with power condition = 0 and start
= 0. It does however work with power condition = 2 or 3.
Also found while investigating this: DViCO Momobay CX-1 and FX-3A (TI
TSB42AA9/A based) become unresponsive after START STOP UNIT with power
condition = 0 and start = 0. They stay responsive if power condition is
set when stopping the motor.
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
-rw-r--r-- | drivers/ieee1394/sbp2.c | 20 | ||||
-rw-r--r-- | drivers/ieee1394/sbp2.h | 1 |
2 files changed, 19 insertions, 2 deletions
diff --git a/drivers/ieee1394/sbp2.c b/drivers/ieee1394/sbp2.c index a5ceff287a28..219164da2818 100644 --- a/drivers/ieee1394/sbp2.c +++ b/drivers/ieee1394/sbp2.c | |||
@@ -186,6 +186,11 @@ MODULE_PARM_DESC(exclusive_login, "Exclusive login to sbp2 device " | |||
186 | * - delay inquiry | 186 | * - delay inquiry |
187 | * Wait extra SBP2_INQUIRY_DELAY seconds after login before SCSI inquiry. | 187 | * Wait extra SBP2_INQUIRY_DELAY seconds after login before SCSI inquiry. |
188 | * | 188 | * |
189 | * - power condition | ||
190 | * Set the power condition field in the START STOP UNIT commands sent by | ||
191 | * sd_mod on suspend, resume, and shutdown (if manage_start_stop is on). | ||
192 | * Some disks need this to spin down or to resume properly. | ||
193 | * | ||
189 | * - override internal blacklist | 194 | * - override internal blacklist |
190 | * Instead of adding to the built-in blacklist, use only the workarounds | 195 | * Instead of adding to the built-in blacklist, use only the workarounds |
191 | * specified in the module load parameter. | 196 | * specified in the module load parameter. |
@@ -199,6 +204,8 @@ MODULE_PARM_DESC(workarounds, "Work around device bugs (default = 0" | |||
199 | ", skip mode page 8 = " __stringify(SBP2_WORKAROUND_MODE_SENSE_8) | 204 | ", skip mode page 8 = " __stringify(SBP2_WORKAROUND_MODE_SENSE_8) |
200 | ", fix capacity = " __stringify(SBP2_WORKAROUND_FIX_CAPACITY) | 205 | ", fix capacity = " __stringify(SBP2_WORKAROUND_FIX_CAPACITY) |
201 | ", delay inquiry = " __stringify(SBP2_WORKAROUND_DELAY_INQUIRY) | 206 | ", delay inquiry = " __stringify(SBP2_WORKAROUND_DELAY_INQUIRY) |
207 | ", set power condition in start stop unit = " | ||
208 | __stringify(SBP2_WORKAROUND_POWER_CONDITION) | ||
202 | ", override internal blacklist = " __stringify(SBP2_WORKAROUND_OVERRIDE) | 209 | ", override internal blacklist = " __stringify(SBP2_WORKAROUND_OVERRIDE) |
203 | ", or a combination)"); | 210 | ", or a combination)"); |
204 | 211 | ||
@@ -359,18 +366,25 @@ static const struct { | |||
359 | .firmware_revision = 0x002800, | 366 | .firmware_revision = 0x002800, |
360 | .model_id = 0x001010, | 367 | .model_id = 0x001010, |
361 | .workarounds = SBP2_WORKAROUND_INQUIRY_36 | | 368 | .workarounds = SBP2_WORKAROUND_INQUIRY_36 | |
362 | SBP2_WORKAROUND_MODE_SENSE_8, | 369 | SBP2_WORKAROUND_MODE_SENSE_8 | |
370 | SBP2_WORKAROUND_POWER_CONDITION, | ||
363 | }, | 371 | }, |
364 | /* DViCO Momobay FX-3A with TSB42AA9A bridge */ { | 372 | /* DViCO Momobay FX-3A with TSB42AA9A bridge */ { |
365 | .firmware_revision = 0x002800, | 373 | .firmware_revision = 0x002800, |
366 | .model_id = 0x000000, | 374 | .model_id = 0x000000, |
367 | .workarounds = SBP2_WORKAROUND_DELAY_INQUIRY, | 375 | .workarounds = SBP2_WORKAROUND_DELAY_INQUIRY | |
376 | SBP2_WORKAROUND_POWER_CONDITION, | ||
368 | }, | 377 | }, |
369 | /* Initio bridges, actually only needed for some older ones */ { | 378 | /* Initio bridges, actually only needed for some older ones */ { |
370 | .firmware_revision = 0x000200, | 379 | .firmware_revision = 0x000200, |
371 | .model_id = SBP2_ROM_VALUE_WILDCARD, | 380 | .model_id = SBP2_ROM_VALUE_WILDCARD, |
372 | .workarounds = SBP2_WORKAROUND_INQUIRY_36, | 381 | .workarounds = SBP2_WORKAROUND_INQUIRY_36, |
373 | }, | 382 | }, |
383 | /* PL-3507 bridge with Prolific firmware */ { | ||
384 | .firmware_revision = 0x012800, | ||
385 | .model_id = SBP2_ROM_VALUE_WILDCARD, | ||
386 | .workarounds = SBP2_WORKAROUND_POWER_CONDITION, | ||
387 | }, | ||
374 | /* Symbios bridge */ { | 388 | /* Symbios bridge */ { |
375 | .firmware_revision = 0xa0b800, | 389 | .firmware_revision = 0xa0b800, |
376 | .model_id = SBP2_ROM_VALUE_WILDCARD, | 390 | .model_id = SBP2_ROM_VALUE_WILDCARD, |
@@ -2002,6 +2016,8 @@ static int sbp2scsi_slave_configure(struct scsi_device *sdev) | |||
2002 | sdev->skip_ms_page_8 = 1; | 2016 | sdev->skip_ms_page_8 = 1; |
2003 | if (lu->workarounds & SBP2_WORKAROUND_FIX_CAPACITY) | 2017 | if (lu->workarounds & SBP2_WORKAROUND_FIX_CAPACITY) |
2004 | sdev->fix_capacity = 1; | 2018 | sdev->fix_capacity = 1; |
2019 | if (lu->workarounds & SBP2_WORKAROUND_POWER_CONDITION) | ||
2020 | sdev->start_stop_pwr_cond = 1; | ||
2005 | if (lu->workarounds & SBP2_WORKAROUND_128K_MAX_TRANS) | 2021 | if (lu->workarounds & SBP2_WORKAROUND_128K_MAX_TRANS) |
2006 | blk_queue_max_sectors(sdev->request_queue, 128 * 1024 / 512); | 2022 | blk_queue_max_sectors(sdev->request_queue, 128 * 1024 / 512); |
2007 | return 0; | 2023 | return 0; |
diff --git a/drivers/ieee1394/sbp2.h b/drivers/ieee1394/sbp2.h index 80d8e097b065..875428bc8d29 100644 --- a/drivers/ieee1394/sbp2.h +++ b/drivers/ieee1394/sbp2.h | |||
@@ -345,6 +345,7 @@ enum sbp2lu_state_types { | |||
345 | #define SBP2_WORKAROUND_FIX_CAPACITY 0x8 | 345 | #define SBP2_WORKAROUND_FIX_CAPACITY 0x8 |
346 | #define SBP2_WORKAROUND_DELAY_INQUIRY 0x10 | 346 | #define SBP2_WORKAROUND_DELAY_INQUIRY 0x10 |
347 | #define SBP2_INQUIRY_DELAY 12 | 347 | #define SBP2_INQUIRY_DELAY 12 |
348 | #define SBP2_WORKAROUND_POWER_CONDITION 0x20 | ||
348 | #define SBP2_WORKAROUND_OVERRIDE 0x100 | 349 | #define SBP2_WORKAROUND_OVERRIDE 0x100 |
349 | 350 | ||
350 | #endif /* SBP2_H */ | 351 | #endif /* SBP2_H */ |