Re: [PATCH 2/5] ide: ->ide_dma_clear_irq() -> ->clear_irq()

From: Sergei Shtylyov
Date: Mon Sep 15 2008 - 18:11:41 EST

Hello, I wrote:

* Rename ->ide_dma_clear_irq method to ->clear_irq
and move it from ide_hwif_t to struct ide_port_ops.

* Move ->waiting_for_dma check inside ->clear_irq method.

* Move ->dma_base check inside ->clear_irq method.

* Add ich_port_ops and remove init_hwif_ich() wrapper.

There should be no functional changes caused by this patch.

Good. I think it's worth implementing this method in at least cmd64x.c which actually reads the IDE interrupt latch bits (independent from the DMA interrupt status) in the dma_test_irq() methods but never clears them, so the latches may reflect a non-current state of the IDE interrupt...

I forgot that it does clear them in its dma_end() methods (which I myself have reworked :-).
It seems however that at least for SFF-8038 compatibles, it makes sense to leave it that way since INTRQ might be asserted while BMIDE interrupt bit is not, so the interrupt latch would need clearing even on DMA timeout...

It may also be worth considering turning this method into test-and-clear, so that we can get the actual IDE interrupt state on the chips that implement this...

Probably might add the test_irq() method to be called on !hwif->waiting_for_dma. Cleraing the status at once seems impractical...

Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@xxxxxxxxx>

Acked-by: Sergei Shtylyov <sshtylyov@xxxxxxxxxxxxx>

Not feeling sure about this patch -- ->waiting_for_dma probably should've been left where it was...

MBR, Sergei

To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at
Please read the FAQ at