Hi. We're trying to port 2.6.24-rc7 to a board. Right now wr're battling with the device tree and PCI.
Our board is somewhat loosely based on a 8266ADS/pq2fads board We have a PCI interrupt mux in a fpga. We have a disk controller and a pci bridge on the primary side, and four TI dsp's on the secondary side. All the interrupts are hardwired to the int mux in our FPGA. THe PCI code does not seem happy: Mount-cache hash table entries: 512 net_namespace: 64 bytes NET: Registered protocol family 16 PCI: Probing PCI hardware irq_create_mapping called for NULL host, hwirq=0 ------------[ cut here ]------------ Badness at arch/powerpc/kernel/irq.c:661 NIP: c0006048 LR: c0006048 CTR: 00000000 REGS: ef821d40 TRAP: 0700 Not tainted (2.6.24-rc7-gdcbd768b-dirty) MSR: 00029032 <EE,ME,IR,DR> CR: 24022022 XER: 00000000 TASK = ef812000[1] 'swapper' THREAD: ef820000 GPR00: c0006048 ef821df0 ef812000 00000034 00000001 00000001 00000000 c0306c30 GPR08: 00000000 00000000 00000000 c02f0000 24022082 10019684 0ffce000 0040092c GPR16: 00000001 ffffffff ef821f60 c02d0000 c02d0000 c02d0000 0071f3a0 00000001 GPR24: 00000000 00000000 c030e000 ef818100 00000001 00000000 ef818114 00000000 NIP [c0006048] irq_create_mapping+0xa8/0x100 LR [c0006048] irq_create_mapping+0xa8/0x100 Call Trace: [ef821df0] [c0006048] irq_create_mapping+0xa8/0x100 (unreliable) [ef821e10] [c001225c] pci_read_irq_line+0x84/0xfc [ef821e60] [c00117c8] pcibios_fixup_bus+0xe8/0x24c [ef821e90] [c013b784] pci_scan_child_bus+0x78/0x118 [ef821eb0] [c013bb24] pci_scan_bridge+0x300/0x42c [ef821ef0] [c013b7d4] pci_scan_child_bus+0xc8/0x118 [ef821f10] [c013beb4] pci_scan_bus_parented+0x20/0x3c [ef821f20] [c02ba754] pcibios_init+0x68/0x250 [ef821f50] [c02b68ac] kernel_init+0x108/0x2e0 [ef821ff0] [c00100d8] kernel_thread+0x44/0x60 here is our device tree: /* * Device Tree for the ApMax board with an MPC8280 chip. * * Copyright 2007 Freescale Semiconductor Inc. * Copyright 2008 Innovative Systems, LLC * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. */ / { model = "pq2fads"; compatible = "fsl,pq2fads"; #address-cells = <1>; #size-cells = <1>; cpus { #address-cells = <1>; #size-cells = <0>; [EMAIL PROTECTED] { device_type = "cpu"; reg = <0>; d-cache-line-size = <d#32>; i-cache-line-size = <d#32>; d-cache-size = <d#16384>; i-cache-size = <d#16384>; timebase-frequency = <0>; clock-frequency = <0>; }; }; memory { device_type = "memory"; reg = <0 0>; }; [EMAIL PROTECTED] { compatible = "fsl,mpc8280-localbus", "fsl,pq2-localbus"; // Change to our own apmax-localbus #address-cells = <2>; #size-cells = <1>; reg = <f0010100 60>; // <CS 0 BaseAddress length> <<---- look ranges = <0 0 ff800000 00800000 // CPU1 8MB Flash 5 0 f8100000 00008000 // FPGA registers 6 0 f8800000 00200000 // ARM FIFO in FPGA 8 0 f9000000 00800000 // CPU2 8MB Flash 9 0 f8400000 00020000>; // CPU1 128K SRAM [EMAIL PROTECTED],0 { compatible = "jedec-flash"; reg = <0 0 800000>; bank-width = <2>; device-width = <2>; }; PCI_INT: [EMAIL PROTECTED],10 { #interrupt-cells = <1>; interrupt-controller; reg = <5 10 4>; // Chip select, offset, length compatible = "apmax-pciintmux"; interrupt-parent = <&PIC>; interrupts = <19 8>; // IRQ7, interrupt#25 }; }; [EMAIL PROTECTED] { device_type = "pci"; reg = <f0010800 10c f00101ac 8 f00101c4 8>; compatible = "fsl,mpc8280-pci", "fsl,pq2-pci"; #interrupt-cells = <1>; #size-cells = <2>; #address-cells = <3>; clock-frequency = <d#49766400>; // For our board. interrupt-map-mask = <f800 0 0 7>; // Anded with the interrupt-map values interrupt-map = < /* IDSEL 0x11 */ 00008800 0 0 1 &PCI_INT 5>; // 3 first numbers pci device specifier are: (buss << 16 | id_sel << 11) 0 0 // buss = 0, id_sel = 11 // Next number is interrupt 1-4 mapped A-D (interrupt A for us) // Last two numbers are host interrupt specifier (external interrupt 5) interrupt-parent = <&PIC>; interrupts = <12 8>; // Mem type 0 Bus Add Loc. Add 0 Length <<--- Remember the mem type is little endian ranges = <42000000 0 90000000 90000000 0 08000000 // Pre-fetch memory 02000000 0 80000000 80000000 0 10000000 // Normal Memory 01000000 0 98000000 98000000 0 00010000>; // I/O [EMAIL PROTECTED] { interrupt-map-mask = <0f800 0 0 7>; interrupt-map = < /* IDSEL 0x10 */ 00008000 0 0 1 &PCI_INT 1 /* IDSEL 0x11 */ 00008800 0 0 1 &PCI_INT 2 /* IDSEL 0x12 */ 00009000 0 0 1 &PCI_INT 3 /* IDSEL 0x13 */ 00009800 0 0 1 &PCI_INT 4>; }; }; [EMAIL PROTECTED] { #address-cells = <1>; #size-cells = <1>; device_type = "soc"; compatible = "fsl,mpc8280", "fsl,pq2-soc"; ranges = <00000000 f0000000 00053000>; // Temporary -- will go away once kernel uses ranges for get_immrbase(). reg = <f0000000 00053000>; [EMAIL PROTECTED] { #address-cells = <1>; #size-cells = <1>; #interrupt-cells = <2>; compatible = "fsl,mpc8280-cpm", "fsl,cpm2"; reg = <119c0 30>; ranges; [EMAIL PROTECTED] { #address-cells = <1>; #size-cells = <1>; ranges = <0 0 10000>; [EMAIL PROTECTED] { compatible = "fsl,cpm-muram-data"; reg = <80 1f80 9800 800>; }; }; [EMAIL PROTECTED] { compatible = "fsl,mpc8280-brg", "fsl,cpm2-brg", "fsl,cpm-brg"; reg = <119f0 10 115f0 10>; }; [EMAIL PROTECTED] { device_type = "serial"; compatible = "fsl,mpc8280-smc-uart", "fsl,cpm2-smc-uart"; reg = <11a80 10 0 40>; // <base_address length parameter_ram_address length> interrupts = <4 8>; // Interrupt from table 4.3 of mpc8280rm, interrupt is level or edge interrupt-parent = <&PIC>; fsl,cpm-brg = <7>; fsl,cpm-command = <1d000000>; // Page and Sub-block code of the CPCR }; [EMAIL PROTECTED] { device_type = "network"; compatible = "fsl,mpc8280-fcc-enet", "fsl,cpm2-fcc-enet"; reg = <11320 20 8500 100 113b0 1>; interrupts = <21 8>; interrupt-parent = <&PIC>; phy-handle = <&PHY0>; linux,network-index = <0>; fsl,cpm-command = <16200300>; }; [EMAIL PROTECTED] { device_type = "network"; compatible = "fsl,mpc8280-fcc-enet", "fsl,cpm2-fcc-enet"; reg = <11340 20 8600 100 113d0 1>; interrupts = <22 8>; interrupt-parent = <&PIC>; phy-handle = <&PHY1>; linux,network-index = <1>; fsl,cpm-command = <1a400300>; local-mac-address = [00 e0 0c 00 79 01]; }; [EMAIL PROTECTED] { device_type = "mdio"; compatible = "fsl,pq2fads-mdio-bitbang", "fsl,mpc8280-mdio-bitbang", "fsl,cpm2-mdio-bitbang"; #address-cells = <1>; #size-cells = <0>; reg = <10d40 14>; fsl,mdio-pin = <9>; fsl,mdc-pin = <a>; PHY0: [EMAIL PROTECTED] { interrupt-parent = <&PIC>; interrupts = <19 2>; reg = <0>; device_type = "ethernet-phy"; }; PHY1: [EMAIL PROTECTED] { interrupt-parent = <&PIC>; interrupts = <19 2>; reg = <3>; device_type = "ethernet-phy"; }; }; }; PIC: [EMAIL PROTECTED] { #interrupt-cells = <2>; interrupt-controller; reg = <10c00 80>; compatible = "fsl,mpc8280-pic", "fsl,cpm2-pic"; }; }; chosen { linux,stdout-path = "/soc/cpm/[EMAIL PROTECTED]"; }; }; _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev