Native Mode ATA query
Posted: Thu Jun 16, 2011 6:19 pm
Hi, looking for someone who may have experienced similar issue and overcome it!!
Have a long mode OS booting up, SMP, IO APIC, got basic GUI classes and everything's great in vmware. On real hardware I cannot get the native mode ATA controller to fire an interrupt unless I poll for DRQ (using alt. status reg) and then read the status register twice asserts the interrupt. Not great obviously!
Even IDENTIFY isn't firing an interrupt until two reads from the status register after. As far as I can see im following guidelines set out by ATA specs, read lots of material and varying versions of the specs and forums/articles all over the place.
I can only assume it's the native mode ATA controller and something I'm missing. I have got correct ports from PCI configuration space and the IRQ assign by BIOS is 15. Which as I say ,is correctly routed as I get the isr to fire by doing two status reads from the status reg after sending the command.
At a complete loss and praying someone has solved this before!!
Thanks
Have a long mode OS booting up, SMP, IO APIC, got basic GUI classes and everything's great in vmware. On real hardware I cannot get the native mode ATA controller to fire an interrupt unless I poll for DRQ (using alt. status reg) and then read the status register twice asserts the interrupt. Not great obviously!
Even IDENTIFY isn't firing an interrupt until two reads from the status register after. As far as I can see im following guidelines set out by ATA specs, read lots of material and varying versions of the specs and forums/articles all over the place.
I can only assume it's the native mode ATA controller and something I'm missing. I have got correct ports from PCI configuration space and the IRQ assign by BIOS is 15. Which as I say ,is correctly routed as I get the isr to fire by doing two status reads from the status reg after sending the command.
At a complete loss and praying someone has solved this before!!
Thanks