PCI woes with 2.6.37

Gary Thomas gary at mlbassoc.com
Sat Jan 8 10:06:56 EST 2011


I just tried porting my target (MPC8347) from 2.6.28 (remember
that one?) to 2.6.37.  Recently I tried this with 2.6.32 without
a lot of success, so I thought I'd try the latest :-)  The changes
are very simple, pretty much just the addition of my 8347 based
platform DTS.

Sadly, it fails even worse than it did on 2.6.32.

For some reason, although everything seems to report that the
PCI bus is alive, MEM access fails completely.  If I try to
access various PCI devices via their memory space (I only have
memory peripherals so I can't test IO space access), I get
what I assume are BUS timeouts - all 0xFFFFFFFF

My PCI bus is defined in DTS like this:
	pci0: pci at ff008500 {
		cell-index = <1>;
		interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
		interrupt-map = <
				/* IDSEL 0x0B (SIL SATA) */
				 0x5800 0x0 0x0 0x1 &ipic 0x16 8
				 0x5800 0x0 0x0 0x2 &ipic 0x16 8
				 0x5800 0x0 0x0 0x3 &ipic 0x16 8
				 0x5800 0x0 0x0 0x4 &ipic 0x16 8

				/* IDSEL 0x0C (Fujitsu Coral-P) */
				 0x6000 0x0 0x0 0x1 &ipic 0x13 8
				 0x6000 0x0 0x0 0x2 &ipic 0x13 8
				 0x6000 0x0 0x0 0x3 &ipic 0x13 8
				 0x6000 0x0 0x0 0x4 &ipic 0x13 8
                                 >;
		interrupt-parent = <&ipic>;
		interrupts = <0x13 0x8
                               0x14 0x8>;
		bus-range = <0 0>;
		ranges = <0x02000000 0x0 0xC0000000 0xC0000000 0x0 0x20000000
			  0x01000000 0x0 0x00000000 0xB8000000 0x0 0x00100000>;
		clock-frequency = <33333333>;
		#interrupt-cells = <1>;
		#size-cells = <2>;
		#address-cells = <3>;
		reg = <0xff008500 0x100		/* Internal registers */
		       0xff008300 0x8>;         /* Config Space registers */
		compatible = "fsl,mpc8349-pci";
		device_type = "pci";
	};

When I boot, I get these messages indicating that the PCI bus is found,
mapped, scanned, etc:

PCI: Probing PCI hardware
PCI: Scanning PHB /pci at ff008500
PCI: PHB IO resource    = 0000000000000000-00000000000FF FFf [100]
PCI: PHB MEM resource 0 = 00000000c0000000-00000000dFF FFfff [200]
PCI: PHB MEM offset     = 0000000000000000
PCI: PHB IO  offset     = 00000000
     probe mode: 0
PCI:0000:00:0b.0 Resource 0 0000000000001000-0000000000001007 [40101] fixup...
PCI:0000:00:0b.0            0000000000001000-0000000000001007
PCI:0000:00:0b.0 Resource 1 0000000000001008-000000000000100b [40101] fixup...
PCI:0000:00:0b.0            0000000000001008-000000000000100b
PCI:0000:00:0b.0 Resource 2 0000000000001010-0000000000001017 [40101] fixup...
PCI:0000:00:0b.0            0000000000001010-0000000000001017
PCI:0000:00:0b.0 Resource 3 0000000000001018-000000000000101b [40101] fixup...
PCI:0000:00:0b.0            0000000000001018-000000000000101b
PCI:0000:00:0b.0 Resource 4 0000000000001020-000000000000102f [40101] fixup...
PCI:0000:00:0b.0            0000000000001020-000000000000102f
PCI:0000:00:0b.0 Resource 5 0000000000100000-00000000001001ff [40200] fixup...
PCI:0000:00:0b.0            0000000000100000-00000000001001ff
PCI:0000:00:0b.0 Resource 6 0000000000000000-000000000007FF FF [4e200] is unassigned
PCI:0000:00:0c.0 Resource 0 0000000004000000-0000000007FF FFff [40200] fixup...
PCI:0000:00:0c.0            0000000004000000-0000000007FF FFff
PCI: Fixup bus devices 0 (PHB)
PCI: Try to map irq for 0000:00:0b.0...
  Got one, spec 2 cells (0x00000016 0x00000008...) on /soc8349 at ff000000/pic at 700
  Mapped to linux irq 22
PCI: Try to map irq for 0000:00:0c.0...
  Got one, spec 2 cells (0x00000013 0x00000008...) on /soc8349 at ff000000/pic at 700
  Mapped to linux irq 19
PCI: Allocating bus resources for 0000:00...
PCI: PHB (bus 0) bridge rsrc 0: 0000000000000000-00000000000FF FFf [0x100], parent c03b5740 (PCI IO)
PCI: PHB (bus 0) bridge rsrc 1: 00000000c0000000-00000000dFF FFfff [0x200], parent c03b5724 (PCI mem)
PCI: Allocating 0000:00:0b.0: Resource 0: 0000000000001000..0000000000001007 [40101]
PCI: Allocating 0000:00:0b.0: Resource 1: 0000000000001008..000000000000100b [40101]
PCI: Allocating 0000:00:0b.0: Resource 2: 0000000000001010..0000000000001017 [40101]
PCI: Allocating 0000:00:0b.0: Resource 3: 0000000000001018..000000000000101b [40101]
PCI: Allocating 0000:00:0b.0: Resource 4: 0000000000001020..000000000000102f [40101]
PCI: Allocating 0000:00:0b.0: Resource 5: 0000000000100000..00000000001001ff [40200]
PCI: Cannot allocate resource region 5 of device 0000:00:0b.0, will remap
PCI: Allocating 0000:00:0c.0: Resource 0: 0000000004000000..0000000007FF FFff [40200]
PCI: Cannot allocate resource region 0 of device 0000:00:0c.0, will remap
Reserving legacy ranges for domain 0000
Candidate legacy IO: [io  0x0000-0x0fff]
hose mem offset: 0000000000000000
hose mem res: [mem 0xc0000000-0xdFF FFfff]
Local memory hole: [mem 0xc0000000-0xc01FF FFf]
PCI: Assigning unassigned resources...
pci 0000:00:0c.0: BAR 0: assigned [mem 0xc4000000-0xc7FF FFff]
pci 0000:00:0c.0: BAR 0: set to [mem 0xc4000000-0xc7FF FFff] (PCI address [0xc4000000-0xc7FF FFff])
pci 0000:00:0b.0: BAR 6: assigned [mem 0xc0200000-0xc027FF FF pref]
pci 0000:00:0b.0: BAR 5: assigned [mem 0xc0280000-0xc02801ff]
pci 0000:00:0b.0: BAR 5: set to [mem 0xc0280000-0xc02801ff] (PCI address [0xc0280000-0xc02801ff])
   ...
Coral-P FB [1024x768x24] at 0xc4000000..0xc7FF FFff [0xd1100000]
D1100000: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100010: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100020: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100030: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100040: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100050: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100060: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
D1100070: FF FF FF FF FF FF FF FF  FF FF FF FF FF FF FF FF   |................|
  ...
scsi0 : sata_sil
scsi1 : sata_sil
ata1: SATA max UDMA/100 mmio m512 at 0xc0280000 tf 0xc0280080 irq 22
ata2: SATA max UDMA/100 mmio m512 at 0xc0280000 tf 0xc02800c0 irq 22
ata1: failed to resume link (SControl FFFFFFFF)
ata1: SATA link down (SStatus FFFFFFFF SControl FFFFFFFF)
ata2: failed to resume link (SControl FFFFFFFF)
ata2: SATA link down (SStatus FFFFFFFF SControl FFFFFFFF)

Things of note:
   * The 'local memory hole' is a space I have to steal from the PCI
     address space so that the Coral-P gets mapped to something other
     than PCI memory address 0x0 (relative).  This device is dirt stupid
     (previously discussed) and refuses to work at 0x0
   * The dump after the Coral-P FB line is what it sees in it's memory
     space.  It _should_ look something like this:
C4140600: FF FF FF 00 FF FF FF 00  FF FF FF 00 FF FF FF 00  |................|
C4140610: FF FF FF 00 FF FF FF 00  FF FF FF 00 FF FF FF 00  |................|
C4140620: FF FF FF 00 FF FF FF 00  FF FF FF 00 FF FF FF 00  |................|
C4140630: FF FF FF 00 FF FF FF 00  FF FF FF 00 FF FF FF 00  |................|
C4140640: FF FF FF 00 FF FF FF 00  FF FD FF 00 FF FD FF 00  |................|
C4140650: FF FD FF 00 FF FD FF 00  FF FD FF 00 FF FD FF 00  |................|
     Notice how byte 3 of every longword is 0x00?
   * The SATA device driver is failing along similar lines.

Any ideas what I'm doing wrong?  or what I can look at?

Thanks

-- 
------------------------------------------------------------
Gary Thomas                 |  Consulting for the
MLB Associates              |    Embedded world
------------------------------------------------------------


More information about the Linuxppc-dev mailing list