These patches synchronize all the in-kernel drivers to use the compatible names generated by the UBoot BSP generator. (at git://git.xilinx.com/gen-mhs-devtree.git)
The patches to make this work are coming shortly: patches 1-2 are provided for context only... They're not ready for mainline. They provide 'raw' boot support and port some initialization code from ARCH=ppc. patches 3-7 are the interesting patches, which I think could be taken for 2.6.25. I've also pushed the working tree up to git.xilinx.com containing these patches. This tree also includes updates for ps2, gpio, etc. The ll_temac currently doesn't work because I haven't gone back and fixed the mechanism by which it finds out about the DMA that it is connected to. If you want output from the boot loader, you'll need something like: linux,stdout-path = "/plb_v34/opb_v20/[EMAIL PROTECTED]"; This seems to work with uartlite, but I wasn't able to get it working with a UART design. Currently, you'll need to add, by hand the following labels: mem_size_cells, on the toplevel #address-cells attribue, e,g. : mem_size_cells: #address-cells = <1>; timebase, on the processors timebase-frequency attribute, e.g. : timebase: timebase-frequency = <11e1a300>; memsize, on the memory's size, e.g.: DDR_256MB_32MX64_rank1_row13_col10_cl2_5: [EMAIL PROTECTED] { device_type = "memory"; reg = < 0 memsize:10000000 >; } ; In addition, if you're using uartlite, you'll have to specify 'console=ttyUL0' as boot args. For reference, below is the device tree for a Virtex2Pro design. Except for the changes noted above, this is entirely automatically generated. Steve / { mem_size_cells: #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,virtex"; model = "testing"; DDR_256MB_32MX64_rank1_row13_col10_cl2_5: [EMAIL PROTECTED] { device_type = "memory"; reg = < 0 memsize:10000000 >; } ; chosen { bootargs = "root=/dev/nfs nfsroot=172.19.221.221:/exports/xup/ydl41 ip=dhcp console=ttyUL0"; } ; cpus { #address-cells = <1>; #cpus = <1>; #size-cells = <0>; PowerPC,[EMAIL PROTECTED] { clock-frequency = <11e1a300>; d-cache-line-size = <20>; d-cache-size = <4000>; device_type = "cpu"; i-cache-line-size = <20>; i-cache-size = <4000>; reg = <0>; timebase: timebase-frequency = <11e1a300>; xlnx,dcr-resync = <0>; xlnx,deterministic-mult = <0>; xlnx,disable-operand-forwarding = <1>; xlnx,mmu-enable = <1>; } ; } ; plb_v34 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,plb-v34-1.02.a"; ranges ; Ethernet_MAC: [EMAIL PROTECTED] { compatible = "xlnx,plb-ethernet-1.01.a"; device_type = "network"; interrupt-parent = <&opb_intc_0>; interrupts = < 2 0 >; local-mac-address = [ 00 00 00 00 00 00 ]; reg = < 80400000 10000 >; xlnx,dev-blk-id = <0>; xlnx,dev-mir-enable = <1>; xlnx,dma-intr-coalesce = <1>; xlnx,dma-present = <1>; xlnx,err-count-exist = <1>; xlnx,fcs-insert-exist = <1>; xlnx,half-duplex-exist = <1>; xlnx,include-dev-pencoder = <1>; xlnx,ipif-fifo-depth = <8000>; xlnx,mac-fifo-depth = <40>; xlnx,mii-exist = <1>; xlnx,miim-clkdvd = <13>; xlnx,pad-insert-exist = <1>; xlnx,reset-present = <1>; xlnx,source-addr-insert-exist = <1>; } ; opb_v20 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,opb-v20-1.10.c"; ranges ; Audio_Codec: [EMAIL PROTECTED] { compatible = "xlnx,opb-ac97-2.00.a"; interrupt-parent = <&opb_intc_0>; interrupts = < 1 0 >; reg = < 7d400000 10000 >; xlnx,intr-level = <1>; xlnx,playback = <1>; xlnx,record = <1>; xlnx,use-bram = <1>; } ; DIPSWs_4Bit: [EMAIL PROTECTED] { compatible = "xlnx,opb-gpio-3.01.b"; reg = < 40020000 10000 >; xlnx,all-inputs = <1>; xlnx,all-inputs-2 = <0>; xlnx,dout-default = <0>; xlnx,dout-default-2 = <0>; xlnx,gpio-width = <4>; xlnx,interrupt-present = <0>; xlnx,is-bidir = <1>; xlnx,is-bidir-2 = <1>; xlnx,is-dual = <0>; xlnx,tri-default = <ffffffff>; xlnx,tri-default-2 = <ffffffff>; xlnx,user-id-code = <3>; } ; LEDs_4Bit: [EMAIL PROTECTED] { compatible = "xlnx,opb-gpio-3.01.b"; reg = < 40000000 10000 >; xlnx,all-inputs = <0>; xlnx,all-inputs-2 = <0>; xlnx,dout-default = <0>; xlnx,dout-default-2 = <0>; xlnx,gpio-width = <4>; xlnx,interrupt-present = <0>; xlnx,is-bidir = <0>; xlnx,is-bidir-2 = <1>; xlnx,is-dual = <0>; xlnx,tri-default = <ffffffff>; xlnx,tri-default-2 = <ffffffff>; xlnx,user-id-code = <3>; } ; PS2_Ports: [EMAIL PROTECTED] { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,compound"; ranges = < 0 7a400000 10000 >; [EMAIL PROTECTED] { compatible = "xlnx,opb-ps2-dual-ref-1.00.a"; interrupt-parent = <&opb_intc_0>; interrupts = < 6 0 >; reg = < 0 40 >; } ; [EMAIL PROTECTED] { compatible = "xlnx,opb-ps2-dual-ref-1.00.a"; interrupt-parent = <&opb_intc_0>; interrupts = < 5 0 >; reg = < 1000 40 >; } ; } ; PushButtons_5Bit: [EMAIL PROTECTED] { compatible = "xlnx,opb-gpio-3.01.b"; reg = < 40040000 10000 >; xlnx,all-inputs = <1>; xlnx,all-inputs-2 = <0>; xlnx,dout-default = <0>; xlnx,dout-default-2 = <0>; xlnx,gpio-width = <5>; xlnx,interrupt-present = <0>; xlnx,is-bidir = <1>; xlnx,is-bidir-2 = <1>; xlnx,is-dual = <0>; xlnx,tri-default = <ffffffff>; xlnx,tri-default-2 = <ffffffff>; xlnx,user-id-code = <3>; } ; RS232_Uart_1: [EMAIL PROTECTED] { compatible = "xlnx,opb-uartlite-1.00.b"; device_type = "serial"; interrupt-parent = <&opb_intc_0>; interrupts = < 4 0 >; port-number = <0>; reg = < 40400000 10000 >; xlnx,baudrate = <2580>; xlnx,clk-freq = <5f5e100>; xlnx,data-bits = <8>; xlnx,odd-parity = <0>; xlnx,use-parity = <0>; } ; SysACE_CompactFlash: [EMAIL PROTECTED] { compatible = "xlnx,opb-sysace-1.00.c"; interrupt-parent = <&opb_intc_0>; interrupts = < 3 0 >; reg = < 41800000 10000 >; xlnx,mem-width = <10>; } ; dcr_v29 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,dcr-v29-1.00.a"; ranges = < 0 40700000 1000 >; VGA_FrameBuffer: [EMAIL PROTECTED] { compatible = "xlnx,plb-tft-cntlr-ref-1.00.a"; reg = < 200 8 >; xlnx,default-tft-base-addr = <7f>; xlnx,dps-init = <1>; xlnx,on-init = <1>; xlnx,pixclk-is-busclk-divby4 = <1>; } ; } ; onewire_0: [EMAIL PROTECTED] { compatible = "xlnx,opb-onewire-1.00.a"; reg = < 7a200000 10000 >; xlnx,add-pullup = "true"; xlnx,checkcrc = "true"; xlnx,clk-div = <f>; } ; opb_hwicap_0: [EMAIL PROTECTED] { compatible = "xlnx,opb-hwicap-1.00.b"; reg = < 41300000 10000 >; } ; opb_intc_0: [EMAIL PROTECTED] { #interrupt-cells = <2>; compatible = "xlnx,opb-intc-1.00.c"; interrupt-controller ; reg = < 41200000 10000 >; xlnx,num-intr-inputs = <7>; } ; opb_timer_0: [EMAIL PROTECTED] { compatible = "xlnx,opb-timer-1.00.b"; interrupt-parent = <&opb_intc_0>; interrupts = < 0 0 >; reg = < 40800000 100 >; xlnx,count-width = <20>; xlnx,gen0-assert = <1>; xlnx,gen1-assert = <1>; xlnx,one-timer-only = <0>; xlnx,trig0-assert = <1>; xlnx,trig1-assert = <1>; } ; } ; } ; } ; _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev