|
@@ -788,12 +788,11 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive)
|
|
|
{
|
|
|
idefloppy_floppy_t *floppy = drive->driver_data;
|
|
|
ide_hwif_t *hwif = drive->hwif;
|
|
|
- atapi_ireason_t ireason;
|
|
|
idefloppy_pc_t *pc = floppy->pc;
|
|
|
struct request *rq = pc->rq;
|
|
|
unsigned int temp;
|
|
|
u16 bcount;
|
|
|
- u8 stat;
|
|
|
+ u8 stat, ireason;
|
|
|
|
|
|
debug_log(KERN_INFO "ide-floppy: Reached %s interrupt handler\n",
|
|
|
__FUNCTION__);
|
|
@@ -852,18 +851,18 @@ static ide_startstop_t idefloppy_pc_intr (ide_drive_t *drive)
|
|
|
bcount = (hwif->INB(IDE_BCOUNTH_REG) << 8) |
|
|
|
hwif->INB(IDE_BCOUNTL_REG);
|
|
|
/* on this interrupt */
|
|
|
- ireason.all = HWIF(drive)->INB(IDE_IREASON_REG);
|
|
|
+ ireason = hwif->INB(IDE_IREASON_REG);
|
|
|
|
|
|
- if (ireason.b.cod) {
|
|
|
+ if (ireason & CD) {
|
|
|
printk(KERN_ERR "ide-floppy: CoD != 0 in idefloppy_pc_intr\n");
|
|
|
return ide_do_reset(drive);
|
|
|
}
|
|
|
- if (ireason.b.io == test_bit(PC_WRITING, &pc->flags)) {
|
|
|
+ if (((ireason & IO) == IO) == test_bit(PC_WRITING, &pc->flags)) {
|
|
|
/* Hopefully, we will never get here */
|
|
|
printk(KERN_ERR "ide-floppy: We wanted to %s, ",
|
|
|
- ireason.b.io ? "Write":"Read");
|
|
|
+ (ireason & IO) ? "Write" : "Read");
|
|
|
printk(KERN_ERR "but the floppy wants us to %s !\n",
|
|
|
- ireason.b.io ? "Read":"Write");
|
|
|
+ (ireason & IO) ? "Read" : "Write");
|
|
|
return ide_do_reset(drive);
|
|
|
}
|
|
|
if (!test_bit(PC_WRITING, &pc->flags)) {
|
|
@@ -920,15 +919,15 @@ static ide_startstop_t idefloppy_transfer_pc (ide_drive_t *drive)
|
|
|
{
|
|
|
ide_startstop_t startstop;
|
|
|
idefloppy_floppy_t *floppy = drive->driver_data;
|
|
|
- atapi_ireason_t ireason;
|
|
|
+ u8 ireason;
|
|
|
|
|
|
if (ide_wait_stat(&startstop, drive, DRQ_STAT, BUSY_STAT, WAIT_READY)) {
|
|
|
printk(KERN_ERR "ide-floppy: Strange, packet command "
|
|
|
"initiated yet DRQ isn't asserted\n");
|
|
|
return startstop;
|
|
|
}
|
|
|
- ireason.all = HWIF(drive)->INB(IDE_IREASON_REG);
|
|
|
- if (!ireason.b.cod || ireason.b.io) {
|
|
|
+ ireason = drive->hwif->INB(IDE_IREASON_REG);
|
|
|
+ if ((ireason & CD) == 0 || (ireason & IO)) {
|
|
|
printk(KERN_ERR "ide-floppy: (IO,CoD) != (0,1) while "
|
|
|
"issuing a packet command\n");
|
|
|
return ide_do_reset(drive);
|
|
@@ -968,15 +967,15 @@ static ide_startstop_t idefloppy_transfer_pc1 (ide_drive_t *drive)
|
|
|
{
|
|
|
idefloppy_floppy_t *floppy = drive->driver_data;
|
|
|
ide_startstop_t startstop;
|
|
|
- atapi_ireason_t ireason;
|
|
|
+ u8 ireason;
|
|
|
|
|
|
if (ide_wait_stat(&startstop, drive, DRQ_STAT, BUSY_STAT, WAIT_READY)) {
|
|
|
printk(KERN_ERR "ide-floppy: Strange, packet command "
|
|
|
"initiated yet DRQ isn't asserted\n");
|
|
|
return startstop;
|
|
|
}
|
|
|
- ireason.all = HWIF(drive)->INB(IDE_IREASON_REG);
|
|
|
- if (!ireason.b.cod || ireason.b.io) {
|
|
|
+ ireason = drive->hwif->INB(IDE_IREASON_REG);
|
|
|
+ if ((ireason & CD) == 0 || (ireason & IO)) {
|
|
|
printk(KERN_ERR "ide-floppy: (IO,CoD) != (0,1) "
|
|
|
"while issuing a packet command\n");
|
|
|
return ide_do_reset(drive);
|