What software tools are available to help me debug boot? Topic is solved

If you have a simple question and just want an answer.
User avatar
infiniteimprobability
Verified
XCore Legend
Posts: 1135
Joined: Thu May 27, 2010 10:08 am

What software tools are available to help me debug boot?

Post by infiniteimprobability »

My xcore isn't booting - how can I get further information about where it has failed?

Engineer at XMOS
View Solution
User avatar
infiniteimprobability
Verified
XCore Legend
Posts: 1135
Joined: Thu May 27, 2010 10:08 am

Post by infiniteimprobability »

The xcore (XS1 - L, U and A series) boots in 3 stages:

1)Executes internal boot ROM (first stage bootloader) to load the second stage boot loader from SPI flash, OTP or link (if multi-chip). If booting from flash, SPI runs quite slowly (depends on mode/clock but a few of MHz typically - the divider is set to /20)

2) Executes second stage boot loader to setup links, PLL etc. and load the application (from flash or link if multi-chip). SPI runs quicker (according to boot pins/crystal and --jtag-speed setting used in xflash, which sets the divider. Run

Code: Select all

xrun --help
for more)

3) Resets (on PLL configure to user application settings in .xn file) and runs application from RAM

If it is stuck before running the app, then you can use:

Code: Select all

xrun --dumpstate
to find out where the processor is and what happened. The key registers to look at are PC, and SPC/ET/ED if an exception has occurred. Note these addresses are for  all XS1 - L, U and A series devices as they share the same boot ROM.

If it has stopped in the ROM (first stage boot loader) it is likely to be at one of the following addresses:

Address Description
- 0xffffc070    Boot mode JTAG (waiting for program to be loaded over JTAG)
- 0xffffc0a6    Boot mode channels (waiting for boot image)
- 0xffffc300    Exception handler - see below
 
If the PC is in RAM (0x10000 - 0x20000) then you are in your application. If the PC is at 0xfffc300but the SPC is in RAM, the ROM has successfully loaded and jumped to the next bootloader / user application but this has raised an exception before setting up its own exception handler.
 
Debugging exceptions
Look at the saved PC (where was it before exception raised), ET (exception type) and ED (exception data).
- Boot from SPI. Contents of SPC, ET, ED:
- 0xffffc218, 0x5 (ET_LOAD STORE), 0x20000. SPI Image size is bigger than memory (RAM). Image size in words can be computed using 0x4000 + r5. The last word received is in r6.
- 0xffffc232, 0x5 (ET_ECALL), 0. Boot from SPI CRC failure.
 
- Boot from channel. Contents of SPC, ET, ED:
- 0xffffc0b8, 0x5 (ET_LOAD_STORE), 0x20000 Boot from channel image size is bigger than memory. Image size in words can be computed using 0x4000 + r2. The last word received is in r1.
- 0xffffc0a6 or 0xffffc0aa or 0xffffc0c0 or 0xffffc0c8, 0x4 (ET_ILLEGAL_RESOURCE), 0x2. Invalid boot from channel image format (unexpected or missing control token).
- 0xffffc0d4, 0x8 (ET_ECALL), 0 .Boot from channel CRC failure
0xffffc112 0x4 (ET_ILLEGAL_RESOURCE) 0x2 Race condition where bootable image is received before all links have been enabled (see bug 14028), suggests xflash hasn't used a long enough delay.
Engineer at XMOS
User avatar
Thomas
Experienced Member
Posts: 66
Joined: Fri Feb 05, 2010 12:34 pm

Post by Thomas »

There is another place in the Boot ROM where an exception can be raised:
In the routine _BootModeOTPLoopEntry when the tile is trying to boot from OTP but the OTP content is empty or corrupted
0xffffc174: (ET_CALL) OTP CRC Check failed
User avatar
Thomas
Experienced Member
Posts: 66
Joined: Fri Feb 05, 2010 12:34 pm

Post by Thomas »

Here is the information for xCORE-200 about debugging boot problems using the output of

Code: Select all

xrun --dumpstate <your .xe file>
If the PC is in RAM (0x10000 - 0x50000) then that tile is running your application. If the PC is at 0xfffc300 but the SPC is in RAM, the ROM has successfully loaded and jumped to the next bootloader / user application but this has raised an exception before setting up its own exception handler.
If the PC starts with 0xfff that means the tile is executing from boot ROM.

Addresses where boot ROM can hang:
- 0xfff004c8 Boot mode JTAG (waiting for program to be loaded over JTAG)
- 0xfff00518 Boot mode channels (waiting for boot image)
- 0xffffc300 Exception handler - see below

Debugging exceptions:
When an exception was raised, have a look at the section ***** Registers ***** in the dumpstate.
Find the values for SPC (saved PC where of the instruction that raised the exception), ET (exception type) and ED (exception data).

Boot from SPI.
- 0xfff0065c, 0x5 (ET_LOAD STORE), 0x50000. SPI Image size is bigger than memory (RAM).
- 0xfff005ce, 0x8 (ET_ECALL), 0. Boot from SPI CRC failure.

Boot from channel.
- 0xfff00528, 0x5 (ET_LOAD_STORE), 0x50000 Boot from channel image size is bigger than memory.
- 0xfff00518 or 0xfff0051c or 0xfff0052e, 0x4 (ET_ILLEGAL_RESOURCE), 0x2. Invalid boot from channel image format (unexpected or missing control token).
- 0xfff00540, 0x8 (ET_ECALL), 0. Boot from channel CRC failure

Boot from OTP:
- 0xfff004b4, 0x8 (ET_ECALL), 0, Boot from OTP CRC failure