diff options
Diffstat (limited to 'drivers/ide/cmd64x.c')
-rw-r--r-- | drivers/ide/cmd64x.c | 69 |
1 files changed, 12 insertions, 57 deletions
diff --git a/drivers/ide/cmd64x.c b/drivers/ide/cmd64x.c index 9f5cde7a731a..fd904e923a9f 100644 --- a/drivers/ide/cmd64x.c +++ b/drivers/ide/cmd64x.c | |||
@@ -254,53 +254,34 @@ static void cmd64x_clear_irq(ide_drive_t *drive) | |||
254 | (void) pci_write_config_byte(dev, irq_reg, irq_stat | irq_mask); | 254 | (void) pci_write_config_byte(dev, irq_reg, irq_stat | irq_mask); |
255 | } | 255 | } |
256 | 256 | ||
257 | static int cmd648_dma_test_irq(ide_drive_t *drive) | 257 | static int cmd648_test_irq(ide_hwif_t *hwif) |
258 | { | 258 | { |
259 | ide_hwif_t *hwif = drive->hwif; | 259 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
260 | unsigned long base = hwif->dma_base - (hwif->channel * 8); | 260 | unsigned long base = pci_resource_start(dev, 4); |
261 | u8 irq_mask = hwif->channel ? MRDMODE_INTR_CH1 : | 261 | u8 irq_mask = hwif->channel ? MRDMODE_INTR_CH1 : |
262 | MRDMODE_INTR_CH0; | 262 | MRDMODE_INTR_CH0; |
263 | u8 dma_stat = inb(hwif->dma_base + ATA_DMA_STATUS); | ||
264 | u8 mrdmode = inb(base + 1); | 263 | u8 mrdmode = inb(base + 1); |
265 | 264 | ||
266 | #ifdef DEBUG | 265 | pr_debug("%s: mrdmode: 0x%02x irq_mask: 0x%02x\n", |
267 | printk("%s: dma_stat: 0x%02x mrdmode: 0x%02x irq_mask: 0x%02x\n", | 266 | hwif->name, mrdmode, irq_mask); |
268 | drive->name, dma_stat, mrdmode, irq_mask); | ||
269 | #endif | ||
270 | if (!(mrdmode & irq_mask)) | ||
271 | return 0; | ||
272 | 267 | ||
273 | /* return 1 if INTR asserted */ | 268 | return (mrdmode & irq_mask) ? 1 : 0; |
274 | if (dma_stat & 4) | ||
275 | return 1; | ||
276 | |||
277 | return 0; | ||
278 | } | 269 | } |
279 | 270 | ||
280 | static int cmd64x_dma_test_irq(ide_drive_t *drive) | 271 | static int cmd64x_test_irq(ide_hwif_t *hwif) |
281 | { | 272 | { |
282 | ide_hwif_t *hwif = drive->hwif; | ||
283 | struct pci_dev *dev = to_pci_dev(hwif->dev); | 273 | struct pci_dev *dev = to_pci_dev(hwif->dev); |
284 | int irq_reg = hwif->channel ? ARTTIM23 : CFR; | 274 | int irq_reg = hwif->channel ? ARTTIM23 : CFR; |
285 | u8 irq_mask = hwif->channel ? ARTTIM23_INTR_CH1 : | 275 | u8 irq_mask = hwif->channel ? ARTTIM23_INTR_CH1 : |
286 | CFR_INTR_CH0; | 276 | CFR_INTR_CH0; |
287 | u8 dma_stat = inb(hwif->dma_base + ATA_DMA_STATUS); | ||
288 | u8 irq_stat = 0; | 277 | u8 irq_stat = 0; |
289 | 278 | ||
290 | (void) pci_read_config_byte(dev, irq_reg, &irq_stat); | 279 | (void) pci_read_config_byte(dev, irq_reg, &irq_stat); |
291 | 280 | ||
292 | #ifdef DEBUG | 281 | pr_debug("%s: irq_stat: 0x%02x irq_mask: 0x%02x\n", |
293 | printk("%s: dma_stat: 0x%02x irq_stat: 0x%02x irq_mask: 0x%02x\n", | 282 | hwif->name, irq_stat, irq_mask); |
294 | drive->name, dma_stat, irq_stat, irq_mask); | ||
295 | #endif | ||
296 | if (!(irq_stat & irq_mask)) | ||
297 | return 0; | ||
298 | |||
299 | /* return 1 if INTR asserted */ | ||
300 | if (dma_stat & 4) | ||
301 | return 1; | ||
302 | 283 | ||
303 | return 0; | 284 | return (irq_stat & irq_mask) ? 1 : 0; |
304 | } | 285 | } |
305 | 286 | ||
306 | /* | 287 | /* |
@@ -366,6 +347,7 @@ static const struct ide_port_ops cmd64x_port_ops = { | |||
366 | .set_pio_mode = cmd64x_set_pio_mode, | 347 | .set_pio_mode = cmd64x_set_pio_mode, |
367 | .set_dma_mode = cmd64x_set_dma_mode, | 348 | .set_dma_mode = cmd64x_set_dma_mode, |
368 | .clear_irq = cmd64x_clear_irq, | 349 | .clear_irq = cmd64x_clear_irq, |
350 | .test_irq = cmd64x_test_irq, | ||
369 | .cable_detect = cmd64x_cable_detect, | 351 | .cable_detect = cmd64x_cable_detect, |
370 | }; | 352 | }; |
371 | 353 | ||
@@ -373,20 +355,10 @@ static const struct ide_port_ops cmd648_port_ops = { | |||
373 | .set_pio_mode = cmd64x_set_pio_mode, | 355 | .set_pio_mode = cmd64x_set_pio_mode, |
374 | .set_dma_mode = cmd64x_set_dma_mode, | 356 | .set_dma_mode = cmd64x_set_dma_mode, |
375 | .clear_irq = cmd648_clear_irq, | 357 | .clear_irq = cmd648_clear_irq, |
358 | .test_irq = cmd648_test_irq, | ||
376 | .cable_detect = cmd64x_cable_detect, | 359 | .cable_detect = cmd64x_cable_detect, |
377 | }; | 360 | }; |
378 | 361 | ||
379 | static const struct ide_dma_ops cmd64x_dma_ops = { | ||
380 | .dma_host_set = ide_dma_host_set, | ||
381 | .dma_setup = ide_dma_setup, | ||
382 | .dma_start = ide_dma_start, | ||
383 | .dma_end = ide_dma_end, | ||
384 | .dma_test_irq = cmd64x_dma_test_irq, | ||
385 | .dma_lost_irq = ide_dma_lost_irq, | ||
386 | .dma_timer_expiry = ide_dma_sff_timer_expiry, | ||
387 | .dma_sff_read_status = ide_dma_sff_read_status, | ||
388 | }; | ||
389 | |||
390 | static const struct ide_dma_ops cmd646_rev1_dma_ops = { | 362 | static const struct ide_dma_ops cmd646_rev1_dma_ops = { |
391 | .dma_host_set = ide_dma_host_set, | 363 | .dma_host_set = ide_dma_host_set, |
392 | .dma_setup = ide_dma_setup, | 364 | .dma_setup = ide_dma_setup, |
@@ -398,24 +370,12 @@ static const struct ide_dma_ops cmd646_rev1_dma_ops = { | |||
398 | .dma_sff_read_status = ide_dma_sff_read_status, | 370 | .dma_sff_read_status = ide_dma_sff_read_status, |
399 | }; | 371 | }; |
400 | 372 | ||
401 | static const struct ide_dma_ops cmd648_dma_ops = { | ||
402 | .dma_host_set = ide_dma_host_set, | ||
403 | .dma_setup = ide_dma_setup, | ||
404 | .dma_start = ide_dma_start, | ||
405 | .dma_end = ide_dma_end, | ||
406 | .dma_test_irq = cmd648_dma_test_irq, | ||
407 | .dma_lost_irq = ide_dma_lost_irq, | ||
408 | .dma_timer_expiry = ide_dma_sff_timer_expiry, | ||
409 | .dma_sff_read_status = ide_dma_sff_read_status, | ||
410 | }; | ||
411 | |||
412 | static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | 373 | static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { |
413 | { /* 0: CMD643 */ | 374 | { /* 0: CMD643 */ |
414 | .name = DRV_NAME, | 375 | .name = DRV_NAME, |
415 | .init_chipset = init_chipset_cmd64x, | 376 | .init_chipset = init_chipset_cmd64x, |
416 | .enablebits = {{0x00,0x00,0x00}, {0x51,0x08,0x08}}, | 377 | .enablebits = {{0x00,0x00,0x00}, {0x51,0x08,0x08}}, |
417 | .port_ops = &cmd64x_port_ops, | 378 | .port_ops = &cmd64x_port_ops, |
418 | .dma_ops = &cmd64x_dma_ops, | ||
419 | .host_flags = IDE_HFLAG_CLEAR_SIMPLEX | | 379 | .host_flags = IDE_HFLAG_CLEAR_SIMPLEX | |
420 | IDE_HFLAG_ABUSE_PREFETCH, | 380 | IDE_HFLAG_ABUSE_PREFETCH, |
421 | .pio_mask = ATA_PIO5, | 381 | .pio_mask = ATA_PIO5, |
@@ -427,7 +387,6 @@ static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | |||
427 | .init_chipset = init_chipset_cmd64x, | 387 | .init_chipset = init_chipset_cmd64x, |
428 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, | 388 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, |
429 | .port_ops = &cmd648_port_ops, | 389 | .port_ops = &cmd648_port_ops, |
430 | .dma_ops = &cmd648_dma_ops, | ||
431 | .host_flags = IDE_HFLAG_SERIALIZE | | 390 | .host_flags = IDE_HFLAG_SERIALIZE | |
432 | IDE_HFLAG_ABUSE_PREFETCH, | 391 | IDE_HFLAG_ABUSE_PREFETCH, |
433 | .pio_mask = ATA_PIO5, | 392 | .pio_mask = ATA_PIO5, |
@@ -439,7 +398,6 @@ static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | |||
439 | .init_chipset = init_chipset_cmd64x, | 398 | .init_chipset = init_chipset_cmd64x, |
440 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, | 399 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, |
441 | .port_ops = &cmd648_port_ops, | 400 | .port_ops = &cmd648_port_ops, |
442 | .dma_ops = &cmd648_dma_ops, | ||
443 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, | 401 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, |
444 | .pio_mask = ATA_PIO5, | 402 | .pio_mask = ATA_PIO5, |
445 | .mwdma_mask = ATA_MWDMA2, | 403 | .mwdma_mask = ATA_MWDMA2, |
@@ -450,7 +408,6 @@ static const struct ide_port_info cmd64x_chipsets[] __devinitdata = { | |||
450 | .init_chipset = init_chipset_cmd64x, | 408 | .init_chipset = init_chipset_cmd64x, |
451 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, | 409 | .enablebits = {{0x51,0x04,0x04}, {0x51,0x08,0x08}}, |
452 | .port_ops = &cmd648_port_ops, | 410 | .port_ops = &cmd648_port_ops, |
453 | .dma_ops = &cmd648_dma_ops, | ||
454 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, | 411 | .host_flags = IDE_HFLAG_ABUSE_PREFETCH, |
455 | .pio_mask = ATA_PIO5, | 412 | .pio_mask = ATA_PIO5, |
456 | .mwdma_mask = ATA_MWDMA2, | 413 | .mwdma_mask = ATA_MWDMA2, |
@@ -490,8 +447,6 @@ static int __devinit cmd64x_init_one(struct pci_dev *dev, const struct pci_devic | |||
490 | d.port_ops = &cmd64x_port_ops; | 447 | d.port_ops = &cmd64x_port_ops; |
491 | if (dev->revision == 1) | 448 | if (dev->revision == 1) |
492 | d.dma_ops = &cmd646_rev1_dma_ops; | 449 | d.dma_ops = &cmd646_rev1_dma_ops; |
493 | else | ||
494 | d.dma_ops = &cmd64x_dma_ops; | ||
495 | } | 450 | } |
496 | } | 451 | } |
497 | } | 452 | } |