Re: Linux on Virtex board with ARCH=powerpc
From: Peter Mendham <hidden>
Date: 2008-06-27 15:07:00
Hi John,
With regard to CONFIG_PPC_UDBG... we have a patch ready that I need to apply to the Git tree and I'll expedite that.
Great, thanks.
With the console and UART Lite, the only thing I could think of is making sure you have a dev entry for the UART Lite.
I do. I used the major and minor numbers from the driver source.
I'm assuming all the boot messages about the console, "enabled", look the same as the 550 as I have seen that give hints to problems sometimes.
I'm not really getting anything illuminating. I turned debugging messages on and I see the following: Console: colour dummy device 80x25 console [ttyUL0] enabled <snip> Serial: 8250/16550 driver $Revision: 1.90 $ 4 ports, IRQ sharing disabled uartlite: calling uart_register_driver() uartlite: calling of_register_platform_driver() uartlite 800f0000.serial: ulite_of_probe(c7846800, c019713c) ulite console: port=c01aef38; port->mapbase=800f0003 800f0000.serial: ttyUL0 at MMIO 0x800f0003 (irq = 0) is a uartlite uartlite: calling platform_driver_register() The only thing that I notice is that the "console [x] enabled" line comes way before the uartlite driver registers, whereas on the 16550 version it's straight afterwards. Does that matter? Thanks, -- Peter
Thanks, John -----Original Message----- From: Peter Mendham [mailto:petermendham@computing.dundee.ac.uk] Sent: Friday, June 27, 2008 6:31 AM To: John Linn Cc: linuxppc-embedded@ozlabs.org Subject: Re: Linux on Virtex board with ARCH=powerpc Hi John, Yes, with regard to the non-functional sysace, I was being an idiot: I had a small hw problem which now that I have fixed it, the kernel now reports that my drive is mounted. I now have a new and rather bizarre problem, which maybe you or someone else has met before. I have a simple FPGA design with memory, a sysace and a uart16550 on an ML405 (I've put my hardware to one side for the moment). It works just fine. If I swap the uart16550 for a uartlite (remaking the kernel with the correct device tree) I see all the boot messages and the kernel seems to start OK, the root partition is mounted but then I see nothing from /sbin/init. This is the same root fs that I was using with the uart16550 example I just mentioned. So it's a known good root fs, but it doesn't appear to be able to output to /dev/console when I have a uartlite instead of a uart16550. I have selected console support for uartlite. Any ideas? Incidentally, the uart16550 solution did not work until I removed CONFIG_PPC_UDBG_16550 - the kernel was getting stuck in udbg_550_putc indefinitely. Thanks, -- Peter John Linn wrote:quoted
Hi Peter, I think you'll get a baseline quicker this way and then you can go on other less known paths after that. In my experience, this message happens when there is no compact flashinquoted
the slot of the board. I have the system ace device as /dev/xsa2 in my notes, but I have only used it much. Sorry it's not one of my primary test cases at thispointquoted
in time. Thanks, John -----Original Message----- From: Peter Mendham [mailto:petermendham@computing.dundee.ac.uk] Sent: Thursday, June 26, 2008 7:24 AM To: John Linn Cc: linuxppc-embedded@ozlabs.org Subject: Re: Linux on Virtex board with ARCH=powerpc Hi John, OK, I've given in and I'm using the xilinx git code now :) It nowshowsquoted
some signs of life, thanks, but the sysace driver is not happy. Myrootquoted
fs is on cf and I'm not using initrd. The driver loads then getsstuck,quoted
repeatedly saying: xsysace 80030000.sysace: kicking stalled fsm; state=2 task=0 iter=1dc=0quoted
I notice from the driver source that state 2 is the driver attemptingtoquoted
acquire the mpu lock. I have tried the standard xilinx sysaceselftestquoted
code which just acquires and frees the lock (which is fine) so the hardware should be OK (I hope). I have the sysace hooked up to an irqquoted
(the only one), I have no idea whether the dts is correct but it seemsquoted
to compare favourably with the ml405 one; mine says (the important bits): intc: interrupt-controller@80010000 { #interrupt-cells = <2>; compatible = "xlnx,xps-intc-1.00.a"; interrupt-controller ; reg = < 80010000 10000 >; xlnx,num-intr-inputs = <1>; } ; sysace: sysace@80030000 { compatible = "xlnx,xps-sysace-1.00.a"; interrupt-parent = <&intc>; interrupts = < 0 2 >; reg = < 80030000 10000 >; xlnx,family = "virtex4"; xlnx,mem-width = <10>; } ; Do you have any ideas? Thanks, -- Peter John Linn wrote:quoted
Hi Peter, To some extent I think you're trying to re-invent the wheel here, butIquoted
understand why. Ideally, you would be able to pull from the mainline kernel to build this, but Xilinx hasn't got our code into the mainline. We areworkingquoted
on it more proactively now. So, in the meantime, it would be easier for you to pull from theXilinxquoted
git tree as we have solved the problems you are solving I believe. Git://git.xilinx.com/linux-2.6-xlnx or http://git.xilinx.com/... We supply the device tree files and kernel configurations for theML405quoted
and ML507 boards to help get started. Thanks and sorry for the inconvenience, John -----Original Message----- From: Peter Mendham [mailto:petermendham@computing.dundee.ac.uk] Sent: Wednesday, June 25, 2008 10:18 AM To: John Linn Cc: linuxppc-embedded@ozlabs.org Subject: Re: Linux on Virtex board with ARCH=powerpc OK, this is all new to me, so please bear with me if I've made amajorquoted
quoted
quoted
mistake. I ran the kernel until it didn't give me anymore output andquoted
quoted
then told xmd to "stop", mrd from any location gave me exactly thesamequoted
32-bit word of garbage. I then reset the processor and mrd wouldgivequoted
quoted
quoted
me what looked like reasonable values. I found the __log_buf symbolinquoted
the System.map file (0xc024a108) and tried mrd on what I assume isthequoted
quoted
quoted
corresponding physical address of 0x0024a108. I get the following: <6>Using Xilinx Virtex machine description <5>Linux version 2.6.26-rc6 (peter@eris) (gcc version 4.2.4) #9PREEMPTquoted
Wed Jun 25 16:27:33 BST 2008 <7>Entering add_active_range(0, 0, 131072) 0 entries of 256 used <7>Top of RAM: 0x20000000, Total RAM: 0x20000000 <7>Memory hole size: 0MB <4>Zone PFN ranges: <4> DMA 0 -> 131072 <4> Normal 131072 -> 131072 <4>Movable zone start PFN for each node <4>early_node_map[1] active PFN ranges <4> 0: 0 -> 131072 <7>On node 0 totalpages: 131072 <7> DMA zone: 1024 pages used for memmap <7> DMA zone: 0 pages reserved <7> DMA zone: 130048 pages, LIFO batch:31 <7> Normal zone: 0 pages used for memmap <7> Movable zone: 0 pages used for memmap <4>Built 1 zonelists in Zone order, mobility grouping on. Totalpages:quoted
130048 <5>Kernel command line: console=ttyUL0 root=/dev/xsa2 rw <6>Xilinx intc at 0xFDFFF000C025CFFC mapped to 0x0000025d <4>PID hash table entries: 2048 (order: 11, 8192 bytes) xmd tells me that the processor stopped at 0xc000fe50, and subsequentquoted
quoted
"con" and "stop" sequences do no move this on (it reports the sameeachquoted
time). Below is a choice excerpt of my System.map: c000fdc4 t src_error c000fddc t dst_error c000fdf4 T __div64_32 c000fe94 T cacheable_memzero c000ff38 T memset So I guess that means it's in __div64_32? Any ideas? Thanks in advance, -- Peter John Linn wrote:quoted
Sounds like the bootstrap loader has loaded the kernel and passedoffquoted
quoted
quoted
execution to it, but there's no console working on the kernel. You can confirm that since you have a probe as you can dump the __log_buf by getting the address of it using objdump on the elfimage.quoted
quoted
It's a pain to convert to readable form, but can help to see thatthingsquoted
are indeed running. Stop the processor, then do the memory readcommand,quoted
mrd, in xmd. For the console to work with UART Lite, CONFIG_OF must be on in the kernel configuration, I would check that. The file, arch/powerpc/boot/virtex.c, has the startup code for the virtex specific processing. It checks to make sure there iscompatiblequoted
hardware based on the device tree. If your device tree doesn'tmatchquoted
quoted
quoted
that hardware you could have a problem. I have not found thepowerupquoted
quoted
quoted
ofquoted
the kernel to be very informative if the device tree is wrong. I pasted in our ML405 device tree below to allow you to compare toit.quoted
quoted
Hope that helps, John /* * (C) Copyright 2007 Michal Simek * * Michal SIMEK [off-list ref] * * 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. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * CAUTION: This file is automatically generated by libgen. * Version: Xilinx EDK 10.1.1 EDK_K_SP1.1 */ / { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,virtex"; model = "testing"; DDR_SDRAM: memory@0 { device_type = "memory"; reg = < 0 8000000 >; } ; chosen { bootargs = "console=ttyS0 ip=on root=/dev/ram"; linux,stdout-path = "/plb@0/serial@83e00000"; } ; cpus { #address-cells = <1>; #cpus = <1>; #size-cells = <0>; ppc405_0: cpu@0 { clock-frequency = <11e1a300>; compatible = "PowerPC,405", "ibm,ppc405"; d-cache-line-size = <20>; d-cache-size = <4000>; device_type = "cpu"; i-cache-line-size = <20>; i-cache-size = <4000>; model = "PowerPC,405"; reg = <0>; timebase-frequency = <11e1a300>; xlnx,apu-control = <de00>; xlnx,apu-udi-1 = <a18983>; xlnx,apu-udi-2 = <a38983>; xlnx,apu-udi-3 = <a589c3>; xlnx,apu-udi-4 = <a789c3>; xlnx,apu-udi-5 = <a98c03>; xlnx,apu-udi-6 = <ab8c03>; xlnx,apu-udi-7 = <ad8c43>; xlnx,apu-udi-8 = <af8c43>; xlnx,deterministic-mult = <0>; xlnx,disable-operand-forwarding = <1>; xlnx,fastest-plb-clock = "DPLB0"; xlnx,generate-plb-timespecs = <1>; xlnx,mmu-enable = <1>; xlnx,pvr-high = <0>; xlnx,pvr-low = <0>; } ; } ; plb: plb@0 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,plb-v46-1.02.a"; ranges ; IIC_EEPROM: i2c@81600000 { compatible = "xlnx,xps-iic-2.00.a"; interrupt-parent = <&xps_intc_0>; interrupts = < 4 2 >; reg = < 81600000 10000 >; xlnx,clk-freq = <5f5e100>; xlnx,family = "virtex4"; xlnx,gpo-width = <1>; xlnx,iic-freq = <186a0>; xlnx,scl-inertial-delay = <0>; xlnx,sda-inertial-delay = <0>; xlnx,ten-bit-adr = <0>; } ; LEDs_4Bit: gpio@81400000 { compatible = "xlnx,xps-gpio-1.00.a"; interrupt-parent = <&xps_intc_0>; interrupts = < 5 2 >; reg = < 81400000 10000 >; xlnx,all-inputs = <0>; xlnx,all-inputs-2 = <0>; xlnx,dout-default = <0>; xlnx,dout-default-2 = <0>; xlnx,family = "virtex4"; xlnx,gpio-width = <4>; xlnx,interrupt-present = <1>; xlnx,is-bidir = <1>; xlnx,is-bidir-2 = <1>; xlnx,is-dual = <0>; xlnx,tri-default = <ffffffff>; xlnx,tri-default-2 = <ffffffff>; } ; RS232_Uart: serial@83e00000 { compatible = "ns16550"; device_type = "serial"; interrupt-parent = <&xps_intc_0>; interrupts = < 6 2 >; reg = < 83e00000 10000 >; reg-offset = <3>; reg-shift = <2>; clock-frequency = <05f5e100>; xlnx,family = "virtex4"; xlnx,has-external-rclk = <0>; xlnx,has-external-xin = <0>; xlnx,is-a-16550 = <1>; } ; SysACE_CompactFlash: sysace@83600000 { compatible = "xlnx,xps-sysace-1.00.a"; interrupt-parent = <&xps_intc_0>; interrupts = < 3 2 >; reg = < 83600000 10000 >; xlnx,family = "virtex4"; xlnx,mem-width = <10>; } ; TriMode_MAC_GMII: xps-ll-temac@81c00000 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,compound"; ethernet@81c00000 { compatible = "xlnx,xps-ll-temac-1.01.a"; device_type = "network"; interrupt-parent = <&xps_intc_0>; interrupts = < 2 2 >; llink-connected = <&PIM2>; local-mac-address = [ 02 00 00 00 00 01 ]; reg = < 81c00000 40 >; xlnx,bus2core-clk-ratio = <1>; xlnx,phy-type = <1>; xlnx,phyaddr = <1>; xlnx,rxcsum = <0>; xlnx,rxfifo = <1000>; xlnx,temac-type = <1>; xlnx,txcsum = <0>; xlnx,txfifo = <1000>; } ; } ; mpmc@0 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,mpmc-4.00.a"; PIM2: sdma@84600100 { compatible = "xlnx,ll-dma-1.00.a"; interrupt-parent = <&xps_intc_0>; interrupts = < 1 2 0 2 >; reg = < 84600100 80 >; } ; } ; xps_bram_if_cntlr_1: xps-bram-if-cntlr@ffffe000 { compatible = "xlnx,xps-bram-if-cntlr-1.00.a"; reg = < ffffe000 2000 >; xlnx,family = "virtex4"; } ; xps_intc_0: interrupt-controller@81800000 { #interrupt-cells = <2>; compatible = "xlnx,xps-intc-1.00.a"; interrupt-controller ; reg = < 81800000 10000 >; xlnx,num-intr-inputs = <7>; } ; } ; ppc405_0_dplb1: plb@1 { #address-cells = <1>; #size-cells = <1>; compatible = "xlnx,plb-v46-1.02.a"; ranges ; } ; } ; -----Original Message----- From: Peter Mendham [mailto:petermendham@computing.dundee.ac.uk] Sent: Tuesday, June 24, 2008 1:21 PM To: John Linn Cc: linuxppc-embedded@ozlabs.org Subject: Re: Linux on Virtex board with ARCH=powerpc Hi John, Thanks for your reply, that's really helpful. I'm actually usingthequoted
quoted
quoted
quoted
quoted
mainline kernel, rather than the one from the xilinx git tree, butyourquoted
information has really moved me on. My first problem was that the Xilinx utility (from the git tree) for device tree dts generationdidn'tquoted
insert a "linux,stdout-path" node under "chosen". I spotted thatthequoted
quoted
quoted
quoted
quoted
ml403 example had this, so after adding it I got early console messages. Everything now grinds to a halt after I get the message"flatquoted
tree at 0x40ad60" which is just before it calls the kernel, so Iassumequoted
it's that call that is killing it. I have "console=ttyUL0" for my uartlite, so I should be getting messages, shouldn't I? Do you knowquoted
quoted
quoted
where the next execution point is? Maybe I could find out whereit'squoted
quoted
quoted
quoted
quoted
getting stuck. I haven't managed to generate an ACE file, I'm just loading thekernelquoted
quoted
quoted
image from xmd ATM, genace won't play ball for me, it complainsaboutquoted
quoted
quoted
quoted
quoted
-board user not being valid, it won't even run on the examplescopiedquoted
quoted
quoted
quoted
quoted
directly from the user manual. Anyway, I think genace is a bit OT,andquoted
I can manage with xmd for now. Thanks, -- Peter John Linn wrote:quoted
Hi Peter, I'm not up on what can be done with the simple image you refer toinquoted
quoted
quoted
quoted
1.quoted
I'm sure I should be, but there's a lot to learn. With regards to 2, the elf image, zImage (without the elfextension),quoted
quoted
quoted
isquoted
located in arch/powerpc/boot. You can make a SystemACE file from that elf image just as you didinquoted
quoted
quoted
quoted
arch/ppc. We have a default device tree file, ml405.dts, in the arch/powerpc/boot/dts directory for our ml405 board. The kernel configuration has a config, DEVICE_TREE, that specifies the name ofthequoted
device tree file. I normally compile the device tree into thekernelquoted
quoted
quoted
quoted
which is the default build, make ARCH=powerpc zImage. That imagedoesquoted
quoted
quoted
not require a boot loader. I inserted the text below from a document that I have aboutbuildingquoted
quoted
quoted
quoted
thequoted
arch/ppc and arch/powerpc kernels. Hope that helps, John Notation The phrase "<ppc or powerpc>" is used throughput the text and meansthatquoted
one or the other, "ppc" or "powerpc" is to be typed depending onthequoted
quoted
quoted
quoted
architecture you are building. Commands that are used in a bash shell are preceded by ">". Getting Ready To Build the Kernel This assumes you installed the ELDK tools and assumes you'll beusingquoted
quoted
quoted
aquoted
bash shell.quoted
bash export CROSS_COMPILE=ppc_4xx-Setting Up the Kernel Tree If you have previously built this kernel for another architecture,ppcquoted
quoted
or powerpc, then the tree needs to be setup correctly for the new architecture. Assuming you have not previously built it, this doesnotquoted
need to be done.quoted
make ARCH=<ppc or powerpc> mrproperConfiguring the Kernel The kernel should be configured to run on the ML405 or ML507 boardfromquoted
Xilinx.quoted
make ARCH=<ppc or powerpc> ml405_defconfigorquoted
make ARCH=<ppc or powerpc> ml507_defconfigBuilding the Kernel The following command will build the Linux kernel assuming you areinquoted
quoted
quoted
the root directory of the kernel. The root directory of the kernelfromquoted
the Xilinx Git tree is linux-2.6-xlnx. An elf file, zImage.elf, is created in the arch/ppc/boot/images directory for ppc architecture.Anquoted
quoted
elf file, zImage, is created in the the arch/powerpc/boot directoryforquoted
the powerpc architecture.quoted
make ARCH=<ppc or powerpc> zImageBuilding the Kernel With Ramdisk A ram disk image, a file named *.gz, must be placed into the arch/ppc/boot/images or arch/powerpc/boot directory, depending onthequoted
quoted
quoted
architecture, prior to building the kernel.quoted
make ARCH=<ppc or powerpc> zImage.initrdAn elf file, zImage.initrd.elf, is created in arch/ppc/boot/images directory for the ppc architecture. An elf file file,zImage.initrd,quoted
quoted
quoted
quoted
isquoted
created in arch/powerpc/boot directory for the powerpcarchitecture.quoted
quoted
quoted
quoted
Generating An Ace File The elf file generated for the kernel and the bit stream can becombinedquoted
to create an ACE file for compact flash. The following assumes abashquoted
quoted
shell where XMD is accessible and a xilinx probe attached to theboardquoted
quoted
for which you are generating an ace file.quoted
xmd -tcl genace.tcl -jprog -target ppc_hw -hw <bit file name> -elf<elfquoted
quoted
file name> -board <ml405 or ml507> -ace <desired ace file name> -----Original Message----- From: linuxppc-embedded-bounces+john.linn=xilinx.com@ozlabs.org [mailto:linuxppc-embedded-bounces+john.linn=xilinx.com@ozlabs.org]Onquoted
quoted
quoted
Behalf Of Peter Mendham Sent: Tuesday, June 24, 2008 3:02 AM To: linuxppc-embedded@ozlabs.org Subject: Linux on Virtex board with ARCH=powerpc Dear all, I'm trying to boot a 2.6.26-rc6 kernel on a custom Virtex 4 board.Iquoted
quoted
quoted
quoted
quoted
have used the Xilinx utility to generate a device tree and now wanttoquoted
quoted
quoted
generate an image for throwing onto CF for use with a SystemACE(justquoted
quoted
quoted
quoted
quoted
like on the the ML3/4xx boards). I don't want to use a bootloader(Iquoted
quoted
quoted
quoted
quoted
don't really need one). I saw something on this list aboutsimpleImage,quoted
"simple" sounded good to me so I thought I'd try that (or did I misinterpret what this is for?). I also don't want the image to betooquoted
big, I always used to use a zImage under ARCH=ppc. So, twoquestions,quoted
quoted
quoted
quoted
quoted
which hopefully are easy ones: 1. I did what Grant said in a post to this list about simpleImage,andquoted
quoted
quoted
dumped my dts into arch/powerpc/boot/dts and I called it system.dts(forquoted
now). I then tried to do make simpleImage.system which ran right through to final link then moaned about a missingsimpleboot-system.quoted
quoted
quoted
quoted
quoted
quoted
Where is this supposed to come from? What am I doing wrong? Inaivelyquoted
tried copying simpleboot.o to simpleboot-system.o and the errorwentquoted
quoted
quoted
quoted
quoted
quoted
quoted
away. Hmm. 2. I need an ELF to give to my SystemACE file generator. This usedtoquoted
quoted
quoted
pop up in arch/ppc/boot/images and be called zImage.elf, which madequoted
quoted
quoted
quoted
sense to me. What's the deal now with powerpc? What should I beusing?quoted
Finally, can anyone give me a heads-up on any gotchas with what I'mquoted
quoted
quoted
quoted
trying to do. As you can tell, I don't entirely know what I'mdoing,quoted
quoted
quoted
soquoted
any pointers would be gratefully received. Thanks, -- Peter The University of Dundee is a Scottish Registered Charity, No.SC015096.quoted
_______________________________________________ Linuxppc-embedded mailing list Linuxppc-embedded@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-embedded This email and any attachments are intended for the sole use of thenamed recipient(s) and contain(s) confidential information that maybequoted
quoted
proprietary, privileged or copyrighted under applicable law. If youarequoted
not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.quoted
The University of Dundee is a Scottish Registered Charity, No.SC015096.quoted
This email and any attachments are intended for the sole use of thenamed recipient(s) and contain(s) confidential information that maybequoted
quoted
proprietary, privileged or copyrighted under applicable law. If youarequoted
not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.quoted
The University of Dundee is a Scottish Registered Charity, No.SC015096.quoted
This email and any attachments are intended for the sole use of thenamed recipient(s) and contain(s) confidential information that may be proprietary, privileged or copyrighted under applicable law. If youarequoted
not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.quoted
The University of Dundee is a Scottish Registered Charity, No.SC015096.quoted
This email and any attachments are intended for the sole use of thenamed recipient(s) and contain(s) confidential information that may be proprietary, privileged or copyrighted under applicable law. If you are not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.quoted
The University of Dundee is a Scottish Registered Charity, No. SC015096. This email and any attachments are intended for the sole use of the named recipient(s) and contain(s) confidential information that may be proprietary, privileged or copyrighted under applicable law. If you are not the intended recipient, do not read, copy, or forward this email message or any attachments. Delete this email message and any attachments immediately.
The University of Dundee is a Scottish Registered Charity, No. SC015096.