PCI enlightenment follow-up
acurtis at directvinternet.com
acurtis at directvinternet.com
Thu Aug 8 02:03:53 EST 2002
> > ======= Board specs ========
> > Host phys: 0x40000000 - 0x47ffffff =>
> > PCI I/O space 0x00000000 - 0x07ffffff
> >
> > Host phys: 0x48000000 - 0x4fffffff =>
> > PCI Memory space 0x00000000 - 0x07ffffff
> >
> > PCI phys: 0x40000000 - 0x47ffffff =>
> > Host Memory 0x00000000 - 0x07ffffff
> >
> > Host Memory:
> > phys: 0x00000000
> > virt: 0xc0000000
> > size: 0x08000000
> >
> > PCI BAR: (only 1 bus)
> > Memory: 0x00000000
> > I/O: 0x00000000
> >
> > ========== Boot Messages ===========
> > /* SCSI controller resource allocation is fine */
> > PCI:00:0f.0: Resource 0: 47ffff00-47ffffff (f=101)
> > PCI:00:0f.0: Resource 1: 4ffffc00-4fffffff (f=200)
> > PCI:00:0f.0: Resource 2: 4fffc000-4fffdfff (f=200)
>
> OK, obviously, the pci_dev resource regions get set up with the
> necessary offset to get to the right address on the PCI bus.
Yes, but I am beginning to suspect that this is where the problem is. If the
I/O addresses should not be translated because the in/out() functions
automagically add the offset, then perhaps the I/O regions should not be
fixed?
> > /* ==== sym53c8xx version 1 output ==== */
> > sym53c8xx: at PCI bus 0, device 15, function 0
> > sym53c8xx: 0x07fffc00 = pci_get_base_address(base)
> > sym53c8xx: 0x07ffc000 = pci_get_base_address(base_2)
>
> sym should _not_ play with these bus-view addresses. Have a look at the
> driver where it gets these from.
These are coming directly from the BAR addresses of the device. PCI
configuration space macros. Good addresses for a PCI master to use.
> > sym53c8xx: setting PCI_COMMAND_PARITY...(fix-up)
> > sym53c8xx: 53c895a detected
> > sym53c895a-0: rev 0x1 on pci bus 0 device 15 function 0 irq 19
> > sym53c8xx: device->slot.base = 0x07fffc00
> > sym53c8xx: device->slot.base_2 = 0x07ffc000
>
> Should contain the offset from host to PCI bus. With these addresses,
> there's no way to access the SCSI card from the driver.
These only need to be offset if you are accessing an external resource.
These values are just fine if you are a PCI bus master, which the SCSI chip
is, and you want to access your own memory.
> > sym53c895a-0: ID 7, Fast-40, Parity Checking
> > /* vtobus() mapping looks ok */
> > sym53c8xx: 0x404ba000 = vtobus(0xc04ba000)
> > sym53c8xx: 0x404bd800 = vtobus(0xc04bd800)
>
> Where do these come from? Is that DMA memory?
vtobus() == virt_to_bus()
PCI_TO_SYS_DRAM = 0x40000000
SYS_DRAM_VIRT = 0xc0000000
This translation looks fine.
> > sym53c8xx: ncr_script_copy_and_bind(src 0xc04f7ce0, dst 0xc04be054)
> > sym53c8xx: ncr_script_copy_and_bind(src 0xc04f7ce0, dst 0xc04be054)
> > sym53c8xx: 0xf0ccff07 = cpu_to_scr(0x07ffccf0)
> ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
> Nope, reversed address. That will not work. Don't touch the address,
> touch the data if necessary. What needs to be swapped is data going
> _over_ the little-endian PCI bus. Addreses don't go _over_ the bus, they
> address resources _on_ the bus.
The SCSI controller is a PCI bus master and script processing engine. The
scripts are retrieved from system memory. The snoop script, for instance, is
constructed by the PPC in system memory and then points the SCSI controller
at it for processing. If you assume that the SCSI contoller is
little-endian, then any addresses need to be byte swapped by the PPC before
the scripts engine can use them. This looks like a SCSI memory location. If
all these assumptions are correct, then this code looks fine too.
** Sent via the linuxppc-dev mail list. See http://lists.linuxppc.org/
More information about the Linuxppc-dev
mailing list