aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-01-25 16:17:17 -0500
committerBartlomiej Zolnierkiewicz <bzolnier@gmail.com>2008-01-25 16:17:17 -0500
commitd32444771b154c3ec37ebf6439004653560c2411 (patch)
tree953c1a943c6e0fa44898f5ba5ca1c45e65c2ae1c
parentf6e29e35cc0f9facf2eb0b0454f9b09021b5aa6f (diff)
ide: fix registers loading order in ide_dump_ata_status()
Fix registers loading order in ide_dump_ata_status()/ide_read_24(). Load registers in this order: * IDE_SECTOR_REG * IDE_LCYL_REG * IDE_HCYL_REG * IDE_SELECT_REG It shouldn't affect anything (just a usual paranoia to separate changes which change the way in which hardware is accessed from code cleanups). Acked-by: Sergei Shtylyov <sshtylyov@ru.mvista.com> Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
-rw-r--r--drivers/ide/ide-iops.c4
-rw-r--r--drivers/ide/ide-lib.c23
2 files changed, 16 insertions, 11 deletions
diff --git a/drivers/ide/ide-iops.c b/drivers/ide/ide-iops.c
index 106454211cb8..38d6b15d6c47 100644
--- a/drivers/ide/ide-iops.c
+++ b/drivers/ide/ide-iops.c
@@ -160,9 +160,9 @@ EXPORT_SYMBOL(default_hwif_mmiops);
160 160
161u32 ide_read_24 (ide_drive_t *drive) 161u32 ide_read_24 (ide_drive_t *drive)
162{ 162{
163 u8 hcyl = HWIF(drive)->INB(IDE_HCYL_REG);
164 u8 lcyl = HWIF(drive)->INB(IDE_LCYL_REG);
165 u8 sect = HWIF(drive)->INB(IDE_SECTOR_REG); 163 u8 sect = HWIF(drive)->INB(IDE_SECTOR_REG);
164 u8 lcyl = HWIF(drive)->INB(IDE_LCYL_REG);
165 u8 hcyl = HWIF(drive)->INB(IDE_HCYL_REG);
166 return (hcyl<<16)|(lcyl<<8)|sect; 166 return (hcyl<<16)|(lcyl<<8)|sect;
167} 167}
168 168
diff --git a/drivers/ide/ide-lib.c b/drivers/ide/ide-lib.c
index 562f5efae9c6..001085845a79 100644
--- a/drivers/ide/ide-lib.c
+++ b/drivers/ide/ide-lib.c
@@ -524,19 +524,24 @@ static u8 ide_dump_ata_status(ide_drive_t *drive, const char *msg, u8 stat)
524 (unsigned long long) sectors, 524 (unsigned long long) sectors,
525 high, low); 525 high, low);
526 } else { 526 } else {
527 u8 cur = hwif->INB(IDE_SELECT_REG); 527 u8 sector, lcyl, hcyl, cur;
528
529 sector = hwif->INB(IDE_SECTOR_REG);
530 lcyl = hwif->INB(IDE_LCYL_REG);
531 hcyl = hwif->INB(IDE_HCYL_REG);
532 cur = hwif->INB(IDE_SELECT_REG);
533
528 if (cur & 0x40) { /* using LBA? */ 534 if (cur & 0x40) { /* using LBA? */
529 printk(", LBAsect=%ld", (unsigned long) 535 printk(", LBAsect=%ld", (unsigned long)
530 ((cur&0xf)<<24) 536 ((cur & 0xf) << 24) |
531 |(hwif->INB(IDE_HCYL_REG)<<16) 537 (hcyl << 16) |
532 |(hwif->INB(IDE_LCYL_REG)<<8) 538 (lcyl << 8) |
533 | hwif->INB(IDE_SECTOR_REG)); 539 sector);
534 } else { 540 } else {
535 printk(", CHS=%d/%d/%d", 541 printk(", CHS=%d/%d/%d",
536 (hwif->INB(IDE_HCYL_REG)<<8) + 542 (hcyl << 8) + lcyl,
537 hwif->INB(IDE_LCYL_REG), 543 cur & 0xf,
538 cur & 0xf, 544 sector);
539 hwif->INB(IDE_SECTOR_REG));
540 } 545 }
541 } 546 }
542 if (HWGROUP(drive) && HWGROUP(drive)->rq) 547 if (HWGROUP(drive) && HWGROUP(drive)->rq)