Hi all !
I was wondering if anyone can give me some insight on the IDE driver
regarding 48 bit LBA addressing. I would like to know:
1. What is different in 48 bit lba implementation as opposed to 28
bit LBA ? What extra steps are needed in order to perform 48 bit lba
for DMA and PIO modes ? This is what I know so far:
- the READ/WRITE commands have to be replaced with their _EXT
counterparts for 48 bit lba; also the sector # and the lba low/mid/high
registers have to be written twice with the appropriate values
- I noticed that there are extra steps required for 48 bit lba dma
transfers but I don't fully understand them
2. Why do we need to perform extra steps with the promise chips when
using 48 bit lba ?
3. Where can I get a spec for the promise chips ?
4. Given the following code from ide_dmaproc(...) function from
ide-dma.c I would appreciate any explanation (or pointers to sources
that explain it).
----------
unsigned long high_16 = pci_resource_start(hwif->pci_dev, 4);
byte clock =inb(high_16+0x11);
unsigned long atapi_port =high_16+ 0x20 + (hwif->channel ? 0x04 :
0x00);
----------
- what is 'high_16' ? is it the base address for the promise chip ?
- what is the '0x11' offset from 'high_16' ? is that the offset to
the udma ctl register ? Why do we need to read this register and
how is this register used ?
- what is the 'atapi_port' used for ?
- I would very much appreciate any explanation on the following code:
-----------
case ide_dma_begin:
/* Note that this is done *after* the cmd has
* been issued to the drive, as per the BM-IDE spec. */
/* Enable ATAPI UDMA port for 48bit data on PDC20267 */
if (lba48 && hwif->pci_devid.vid==PCI_VENDOR_ID_PROMISE &&
(hwif->pci_devid.did == PCI_DEVICE_ID_PROMISE_20267 ||
hwif->pci_devid.did == PCI_DEVICE_ID_PROMISE_20265 ||
hwif->pci_devid.did == PCI_DEVICE_ID_PROMISE_20262))
{
outb(clock|(hwif->channel ? 0x08:0x02), high_16 + 0x11);
word_count=(rq->nr_sectors << 8);
word_count=reading ? word_count | 0x05000000 : word_count |
0x06000000;
outl(word_count, atapi_port);
}
outb(inb(dma_base)|1, dma_base); /* start DMA */
return 0;
case ide_dma_end: /* returns 1 on error, 0 otherwise */
drive->waiting_for_dma = 0;
outb(inb(dma_base)&~1, dma_base); /* stop DMA */
/* Disable ATAPI UDMA port for 48bit data on PDC20267 */
if (lba48 && hwif->pci_devid.vid==PCI_VENDOR_ID_PROMISE &&
(hwif->pci_devid.did == PCI_DEVICE_ID_PROMISE_20267 ||
hwif->pci_devid.did == PCI_DEVICE_ID_PROMISE_20265 ||
hwif->pci_devid.did == PCI_DEVICE_ID_PROMISE_20262))
{
outl(0, atapi_port);
clock=inb(high_16+0x11);
outb(clock & ~(hwif->channel ? 0x08:0x02), high_16+0x11);
}
dma_stat = inb(dma_base+2); /* get DMA status */
outb(dma_stat|6, dma_base+2); /* clear the INTR & ERROR bits */
ide_destroy_dmatable(drive); /* purge DMA mappings */
return (dma_stat & 7) != 4 ? (0x10 | dma_stat) : 0; /* verify good DMA
status */
--------------
Thanks in advance,
remus
__________________________________________________
Do you Yahoo!?
Yahoo! Mail Plus - Powerful. Affordable. Sign up now.
http://mailplus.yahoo.com
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
This archive was generated by hypermail 2b29 : Wed Jan 15 2003 - 22:00:48 EST