diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/ata.h | 12 | ||||
-rw-r--r-- | include/linux/libata.h | 24 |
2 files changed, 22 insertions, 14 deletions
diff --git a/include/linux/ata.h b/include/linux/ata.h index 312a2c0c64e6..206d859083ea 100644 --- a/include/linux/ata.h +++ b/include/linux/ata.h | |||
@@ -199,6 +199,7 @@ enum { | |||
199 | ATA_TFLAG_WRITE = (1 << 3), /* data dir: host->dev==1 (write) */ | 199 | ATA_TFLAG_WRITE = (1 << 3), /* data dir: host->dev==1 (write) */ |
200 | ATA_TFLAG_LBA = (1 << 4), /* enable LBA */ | 200 | ATA_TFLAG_LBA = (1 << 4), /* enable LBA */ |
201 | ATA_TFLAG_FUA = (1 << 5), /* enable FUA */ | 201 | ATA_TFLAG_FUA = (1 << 5), /* enable FUA */ |
202 | ATA_TFLAG_POLLING = (1 << 6), /* set nIEN to 1 and use polling */ | ||
202 | }; | 203 | }; |
203 | 204 | ||
204 | enum ata_tf_protocols { | 205 | enum ata_tf_protocols { |
@@ -272,6 +273,8 @@ struct ata_taskfile { | |||
272 | ((u64) (id)[(n) + 1] << 16) | \ | 273 | ((u64) (id)[(n) + 1] << 16) | \ |
273 | ((u64) (id)[(n) + 0]) ) | 274 | ((u64) (id)[(n) + 0]) ) |
274 | 275 | ||
276 | #define ata_id_cdb_intr(id) (((id)[0] & 0x60) == 0x20) | ||
277 | |||
275 | static inline unsigned int ata_id_major_version(const u16 *id) | 278 | static inline unsigned int ata_id_major_version(const u16 *id) |
276 | { | 279 | { |
277 | unsigned int mver; | 280 | unsigned int mver; |
@@ -311,6 +314,15 @@ static inline int is_atapi_taskfile(const struct ata_taskfile *tf) | |||
311 | (tf->protocol == ATA_PROT_ATAPI_DMA); | 314 | (tf->protocol == ATA_PROT_ATAPI_DMA); |
312 | } | 315 | } |
313 | 316 | ||
317 | static inline int is_multi_taskfile(struct ata_taskfile *tf) | ||
318 | { | ||
319 | return (tf->command == ATA_CMD_READ_MULTI) || | ||
320 | (tf->command == ATA_CMD_WRITE_MULTI) || | ||
321 | (tf->command == ATA_CMD_READ_MULTI_EXT) || | ||
322 | (tf->command == ATA_CMD_WRITE_MULTI_EXT) || | ||
323 | (tf->command == ATA_CMD_WRITE_MULTI_FUA_EXT); | ||
324 | } | ||
325 | |||
314 | static inline int ata_ok(u8 status) | 326 | static inline int ata_ok(u8 status) |
315 | { | 327 | { |
316 | return ((status & (ATA_BUSY | ATA_DRDY | ATA_DF | ATA_DRQ | ATA_ERR)) | 328 | return ((status & (ATA_BUSY | ATA_DRDY | ATA_DF | ATA_DRQ | ATA_ERR)) |
diff --git a/include/linux/libata.h b/include/linux/libata.h index d35b1e3bb7e0..bf86ee474533 100644 --- a/include/linux/libata.h +++ b/include/linux/libata.h | |||
@@ -122,6 +122,7 @@ enum { | |||
122 | /* struct ata_device stuff */ | 122 | /* struct ata_device stuff */ |
123 | ATA_DFLAG_LBA = (1 << 0), /* device supports LBA */ | 123 | ATA_DFLAG_LBA = (1 << 0), /* device supports LBA */ |
124 | ATA_DFLAG_LBA48 = (1 << 1), /* device supports LBA48 */ | 124 | ATA_DFLAG_LBA48 = (1 << 1), /* device supports LBA48 */ |
125 | ATA_DFLAG_CDB_INTR = (1 << 2), /* device asserts INTRQ when ready for CDB */ | ||
125 | ATA_DFLAG_CFG_MASK = (1 << 8) - 1, | 126 | ATA_DFLAG_CFG_MASK = (1 << 8) - 1, |
126 | 127 | ||
127 | ATA_DFLAG_PIO = (1 << 8), /* device currently in PIO mode */ | 128 | ATA_DFLAG_PIO = (1 << 8), /* device currently in PIO mode */ |
@@ -145,9 +146,9 @@ enum { | |||
145 | ATA_FLAG_PIO_DMA = (1 << 7), /* PIO cmds via DMA */ | 146 | ATA_FLAG_PIO_DMA = (1 << 7), /* PIO cmds via DMA */ |
146 | ATA_FLAG_PIO_LBA48 = (1 << 8), /* Host DMA engine is LBA28 only */ | 147 | ATA_FLAG_PIO_LBA48 = (1 << 8), /* Host DMA engine is LBA28 only */ |
147 | ATA_FLAG_IRQ_MASK = (1 << 9), /* Mask IRQ in PIO xfers */ | 148 | ATA_FLAG_IRQ_MASK = (1 << 9), /* Mask IRQ in PIO xfers */ |
149 | ATA_FLAG_PIO_POLLING = (1 << 10), /* use polling PIO if LLD | ||
150 | * doesn't handle PIO interrupts */ | ||
148 | 151 | ||
149 | ATA_FLAG_NOINTR = (1 << 16), /* FIXME: Remove this once | ||
150 | * proper HSM is in place. */ | ||
151 | ATA_FLAG_DEBUGMSG = (1 << 17), | 152 | ATA_FLAG_DEBUGMSG = (1 << 17), |
152 | ATA_FLAG_FLUSH_PORT_TASK = (1 << 18), /* flush port task */ | 153 | ATA_FLAG_FLUSH_PORT_TASK = (1 << 18), /* flush port task */ |
153 | 154 | ||
@@ -168,11 +169,8 @@ enum { | |||
168 | ATA_HOST_SIMPLEX = (1 << 0), /* Host is simplex, one DMA channel per host_set only */ | 169 | ATA_HOST_SIMPLEX = (1 << 0), /* Host is simplex, one DMA channel per host_set only */ |
169 | 170 | ||
170 | /* various lengths of time */ | 171 | /* various lengths of time */ |
171 | ATA_TMOUT_PIO = 30 * HZ, | ||
172 | ATA_TMOUT_BOOT = 30 * HZ, /* heuristic */ | 172 | ATA_TMOUT_BOOT = 30 * HZ, /* heuristic */ |
173 | ATA_TMOUT_BOOT_QUICK = 7 * HZ, /* heuristic */ | 173 | ATA_TMOUT_BOOT_QUICK = 7 * HZ, /* heuristic */ |
174 | ATA_TMOUT_CDB = 30 * HZ, | ||
175 | ATA_TMOUT_CDB_QUICK = 5 * HZ, | ||
176 | ATA_TMOUT_INTERNAL = 30 * HZ, | 174 | ATA_TMOUT_INTERNAL = 30 * HZ, |
177 | ATA_TMOUT_INTERNAL_QUICK = 5 * HZ, | 175 | ATA_TMOUT_INTERNAL_QUICK = 5 * HZ, |
178 | 176 | ||
@@ -221,14 +219,13 @@ enum { | |||
221 | }; | 219 | }; |
222 | 220 | ||
223 | enum hsm_task_states { | 221 | enum hsm_task_states { |
224 | HSM_ST_UNKNOWN, | 222 | HSM_ST_UNKNOWN, /* state unknown */ |
225 | HSM_ST_IDLE, | 223 | HSM_ST_IDLE, /* no command on going */ |
226 | HSM_ST_POLL, | 224 | HSM_ST, /* (waiting the device to) transfer data */ |
227 | HSM_ST_TMOUT, | 225 | HSM_ST_LAST, /* (waiting the device to) complete command */ |
228 | HSM_ST, | 226 | HSM_ST_ERR, /* error */ |
229 | HSM_ST_LAST, | 227 | HSM_ST_FIRST, /* (waiting the device to) |
230 | HSM_ST_LAST_POLL, | 228 | write CDB or first data block */ |
231 | HSM_ST_ERR, | ||
232 | }; | 229 | }; |
233 | 230 | ||
234 | enum ata_completion_errors { | 231 | enum ata_completion_errors { |
@@ -419,7 +416,6 @@ struct ata_port { | |||
419 | struct work_struct port_task; | 416 | struct work_struct port_task; |
420 | 417 | ||
421 | unsigned int hsm_task_state; | 418 | unsigned int hsm_task_state; |
422 | unsigned long pio_task_timeout; | ||
423 | 419 | ||
424 | u32 msg_enable; | 420 | u32 msg_enable; |
425 | struct list_head eh_done_q; | 421 | struct list_head eh_done_q; |