diff options
Diffstat (limited to 'include/linux/libata.h')
-rw-r--r-- | include/linux/libata.h | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/include/linux/libata.h b/include/linux/libata.h index 0d61357604d5..b248cb020f87 100644 --- a/include/linux/libata.h +++ b/include/linux/libata.h | |||
@@ -123,6 +123,7 @@ enum { | |||
123 | ATA_DFLAG_LBA48 = (1 << 0), /* device supports LBA48 */ | 123 | ATA_DFLAG_LBA48 = (1 << 0), /* device supports LBA48 */ |
124 | ATA_DFLAG_PIO = (1 << 1), /* device currently in PIO mode */ | 124 | ATA_DFLAG_PIO = (1 << 1), /* device currently in PIO mode */ |
125 | ATA_DFLAG_LBA = (1 << 2), /* device supports LBA */ | 125 | ATA_DFLAG_LBA = (1 << 2), /* device supports LBA */ |
126 | ATA_DFLAG_CDB_INTR = (1 << 3), /* device asserts INTRQ when ready for CDB */ | ||
126 | 127 | ||
127 | ATA_DEV_UNKNOWN = 0, /* unknown device */ | 128 | ATA_DEV_UNKNOWN = 0, /* unknown device */ |
128 | ATA_DEV_ATA = 1, /* ATA device */ | 129 | ATA_DEV_ATA = 1, /* ATA device */ |
@@ -141,8 +142,8 @@ enum { | |||
141 | ATA_FLAG_MMIO = (1 << 6), /* use MMIO, not PIO */ | 142 | ATA_FLAG_MMIO = (1 << 6), /* use MMIO, not PIO */ |
142 | ATA_FLAG_SATA_RESET = (1 << 7), /* (obsolete) use COMRESET */ | 143 | ATA_FLAG_SATA_RESET = (1 << 7), /* (obsolete) use COMRESET */ |
143 | ATA_FLAG_PIO_DMA = (1 << 8), /* PIO cmds via DMA */ | 144 | ATA_FLAG_PIO_DMA = (1 << 8), /* PIO cmds via DMA */ |
144 | ATA_FLAG_NOINTR = (1 << 9), /* FIXME: Remove this once | 145 | ATA_FLAG_PIO_POLLING = (1 << 9), /* use polling PIO if LLD |
145 | * proper HSM is in place. */ | 146 | * doesn't handle PIO interrupts */ |
146 | ATA_FLAG_DEBUGMSG = (1 << 10), | 147 | ATA_FLAG_DEBUGMSG = (1 << 10), |
147 | ATA_FLAG_NO_ATAPI = (1 << 11), /* No ATAPI support */ | 148 | ATA_FLAG_NO_ATAPI = (1 << 11), /* No ATAPI support */ |
148 | 149 | ||
@@ -164,11 +165,8 @@ enum { | |||
164 | ATA_HOST_SIMPLEX = (1 << 0), /* Host is simplex, one DMA channel per host_set only */ | 165 | ATA_HOST_SIMPLEX = (1 << 0), /* Host is simplex, one DMA channel per host_set only */ |
165 | 166 | ||
166 | /* various lengths of time */ | 167 | /* various lengths of time */ |
167 | ATA_TMOUT_PIO = 30 * HZ, | ||
168 | ATA_TMOUT_BOOT = 30 * HZ, /* heuristic */ | 168 | ATA_TMOUT_BOOT = 30 * HZ, /* heuristic */ |
169 | ATA_TMOUT_BOOT_QUICK = 7 * HZ, /* heuristic */ | 169 | ATA_TMOUT_BOOT_QUICK = 7 * HZ, /* heuristic */ |
170 | ATA_TMOUT_CDB = 30 * HZ, | ||
171 | ATA_TMOUT_CDB_QUICK = 5 * HZ, | ||
172 | ATA_TMOUT_INTERNAL = 30 * HZ, | 170 | ATA_TMOUT_INTERNAL = 30 * HZ, |
173 | ATA_TMOUT_INTERNAL_QUICK = 5 * HZ, | 171 | ATA_TMOUT_INTERNAL_QUICK = 5 * HZ, |
174 | 172 | ||
@@ -214,14 +212,13 @@ enum { | |||
214 | }; | 212 | }; |
215 | 213 | ||
216 | enum hsm_task_states { | 214 | enum hsm_task_states { |
217 | HSM_ST_UNKNOWN, | 215 | HSM_ST_UNKNOWN, /* state unknown */ |
218 | HSM_ST_IDLE, | 216 | HSM_ST_IDLE, /* no command on going */ |
219 | HSM_ST_POLL, | 217 | HSM_ST, /* (waiting the device to) transfer data */ |
220 | HSM_ST_TMOUT, | 218 | HSM_ST_LAST, /* (waiting the device to) complete command */ |
221 | HSM_ST, | 219 | HSM_ST_ERR, /* error */ |
222 | HSM_ST_LAST, | 220 | HSM_ST_FIRST, /* (waiting the device to) |
223 | HSM_ST_LAST_POLL, | 221 | write CDB or first data block */ |
224 | HSM_ST_ERR, | ||
225 | }; | 222 | }; |
226 | 223 | ||
227 | enum ata_completion_errors { | 224 | enum ata_completion_errors { |
@@ -411,7 +408,6 @@ struct ata_port { | |||
411 | struct work_struct port_task; | 408 | struct work_struct port_task; |
412 | 409 | ||
413 | unsigned int hsm_task_state; | 410 | unsigned int hsm_task_state; |
414 | unsigned long pio_task_timeout; | ||
415 | 411 | ||
416 | u32 msg_enable; | 412 | u32 msg_enable; |
417 | struct list_head eh_done_q; | 413 | struct list_head eh_done_q; |