Subject: Re: booting Efika with ppc-oea-renovation
To: Tim Rightnour <root@garbled.net>
From: Frank Wille <frank@phoenix.owl.de>
List: port-ofppc
Date: 07/09/2007 22:30:49
Tim Rightnour wrote:
> In ofwoea_map_space it tries to do a find_ranges() call for
> RANGE_TYPE_ISA. It then looks to see if the range and cur values are zero,
> and if either are, it should exit out. I'd throw some printfs in the
> find_ranges call and try to figure out why it's not failing on the efika,
> which has no ISA.
Ok. ofwoea_map_space() returns with -1 and doesn't detect any ISA.
But the crash is caused by doing bus_map_space() in map_isa_ioregs() for the
genppc_isa_io_space_tag without the function-pointers of this structure being
ever initialized by bus_space_init(). Therefore, crash while jumping to 0!
>> - ofwpci is not detected (SmartFirmware shows: /pci@80000000)
>
> Yeah.. I don't have a dump of the pci node itself for the efika. Could you
> cd to /pci and do a .properties for me there? It would help a bunch. The
> match routine just probably needs some fiddling.
I wonder how this match routine ever worked for other systems. The problem
is in ofwpci.c, where you access a property named "device-type", but correct
would have been "device_type".
After fixing that the PCI bus is recognized and mapped, but then a crash of
OFW follows in genofw_setup_pciintr_map() while calling
OF_getprop(parent, "#interrupt-cells", &pcells, sizeof(pcells)
with a parent-node of 0.
Refering to my previous mail, the properties of "pci" were:
#address-cells 0x3 (3)
#size-cells 0x2 (2)
clock-frequency 0x3EF1480 (66000000)
ranges [0x30 bytes]
[000] 01000000 00000000 00000000 F8000000
[010] 00000000 00010000 02000000 00000000
[020] 80000000 80000000 00000000 40000000
reg 80000000:40000000
#interrupt-cells 0x1 (1)
interrupt-map-mask [0x10 bytes]
[000] 00000000 00000000 00000000 00000007
bus-range 0:1
interrupt-map [0x20 bytes]
[000] 00008000 00000000 00000000 00000001
[010] 07C57D30 00000000 00000000 00000003
...which means that "adress-cells + interrupt-cells + 1" would access a zero
entry at interrupt-map[5].
I have no idea which is the right one, though...
--
_ Frank Wille (frank@phoenix.owl.de)
_ // http://sun.hasenbraten.de/~frank/
\X/ Phx @ #AmigaGer