libata-scsi: ata_task_ioctl should return ATA registers from sense data

User applications using the HDIO_DRIVE_TASK ioctl through libata expect
specific ATA registers to be returned to userspace. Verified that
ata_task_ioctl correctly returns register values to the smartctl
application.

Signed-off-by: David Milburn <dmilburn@redhat.com>
Acked-by: Tejun Heo <htejun@gmail.com>
Cc: Jeff Garzik <jeff@garzik.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Jeff Garzik <jeff@garzik.org>

authored by David Milburn and committed by Jeff Garzik af068bd1 2ca6611b

+46 -7
+46 -7
drivers/ata/libata-scsi.c
··· 273 273 { 274 274 int rc = 0; 275 275 u8 scsi_cmd[MAX_COMMAND_SIZE]; 276 - u8 args[7]; 277 - struct scsi_sense_hdr sshdr; 276 + u8 args[7], *sensebuf = NULL; 277 + int cmd_result; 278 278 279 279 if (arg == NULL) 280 280 return -EINVAL; ··· 282 282 if (copy_from_user(args, arg, sizeof(args))) 283 283 return -EFAULT; 284 284 285 + sensebuf = kzalloc(SCSI_SENSE_BUFFERSIZE, GFP_NOIO); 286 + if (!sensebuf) 287 + return -ENOMEM; 288 + 285 289 memset(scsi_cmd, 0, sizeof(scsi_cmd)); 286 290 scsi_cmd[0] = ATA_16; 287 291 scsi_cmd[1] = (3 << 1); /* Non-data */ 288 - /* scsi_cmd[2] is already 0 -- no off.line, cc, or data xfer */ 292 + scsi_cmd[2] = 0x20; /* cc but no off.line or data xfer */ 289 293 scsi_cmd[4] = args[1]; 290 294 scsi_cmd[6] = args[2]; 291 295 scsi_cmd[8] = args[3]; ··· 299 295 300 296 /* Good values for timeout and retries? Values below 301 297 from scsi_ioctl_send_command() for default case... */ 302 - if (scsi_execute_req(scsidev, scsi_cmd, DMA_NONE, NULL, 0, &sshdr, 303 - (10*HZ), 5)) 304 - rc = -EIO; 298 + cmd_result = scsi_execute(scsidev, scsi_cmd, DMA_NONE, NULL, 0, 299 + sensebuf, (10*HZ), 5, 0); 305 300 306 - /* Need code to retrieve data from check condition? */ 301 + if (driver_byte(cmd_result) == DRIVER_SENSE) {/* sense data available */ 302 + u8 *desc = sensebuf + 8; 303 + cmd_result &= ~(0xFF<<24); /* DRIVER_SENSE is not an error */ 304 + 305 + /* If we set cc then ATA pass-through will cause a 306 + * check condition even if no error. Filter that. */ 307 + if (cmd_result & SAM_STAT_CHECK_CONDITION) { 308 + struct scsi_sense_hdr sshdr; 309 + scsi_normalize_sense(sensebuf, SCSI_SENSE_BUFFERSIZE, 310 + &sshdr); 311 + if (sshdr.sense_key==0 && 312 + sshdr.asc==0 && sshdr.ascq==0) 313 + cmd_result &= ~SAM_STAT_CHECK_CONDITION; 314 + } 315 + 316 + /* Send userspace ATA registers */ 317 + if (sensebuf[0] == 0x72 && /* format is "descriptor" */ 318 + desc[0] == 0x09) {/* code is "ATA Descriptor" */ 319 + args[0] = desc[13]; /* status */ 320 + args[1] = desc[3]; /* error */ 321 + args[2] = desc[5]; /* sector count (0:7) */ 322 + args[3] = desc[7]; /* lbal */ 323 + args[4] = desc[9]; /* lbam */ 324 + args[5] = desc[11]; /* lbah */ 325 + args[6] = desc[12]; /* select */ 326 + if (copy_to_user(arg, args, sizeof(args))) 327 + rc = -EFAULT; 328 + } 329 + } 330 + 331 + if (cmd_result) { 332 + rc = -EIO; 333 + goto error; 334 + } 335 + 336 + error: 337 + kfree(sensebuf); 307 338 return rc; 308 339 } 309 340