The page provides tips on debugging initialization and boot up issues with the following devices:
- AM64x
- AM243x
- AM62x/AM625SIP
- AM62Ax
- AM62Px
If this page doesn't address your issue, please submit a ticket at http://e2e.ti.com . This page will continually be updated with new information
Section 1: No Console Output
If you do have console output, skip to Section 2
Check MCU_RESETSTAT and RESETSTAT signals. These are status signals that identify if the device is still in reset. Signals should go high and stay high when the device out of reset. If either of them stay low after power ramp, the device is still in reset. If device remains in reset, check power sequencing a voltage rails according to the device datasheet (section Power Supply Sequencing and Recommended Operating Conditions in the datasheet)
After MCU_RESETSTAT and RESETSTAT goes high, the ROM executes and attempts to boot from the primary boot source.
- Check to ensure the BOOTMODE signals are set correctly for your boot source. Check voltage levels on all BOOTMODE signals
- Check to see if there is activity on the interface of the primary boot source. For example:
- if you are booting from SD Card, see if MMC1_CLK toggles.
- if you are booting from OSPI, check for OSPI0_CLK toggle or OSPI0_CSN0 goes low.
- if you are booting from UART, check UART0_TXD for activity
If there is no activity on the primary boot source, check all power supplies on the board for proper voltage levels, especially with the devices that are your boot sources. Check to make sure your power up sequencing is correct, and all power supplies are valid and stable after RESETSTATz goes high.
If there is activity on the primary boot source, then that indicates the ROM is attempting to boot, but is failing. You may also see that the ROM eventually attempts to boot from the secondary boot source (ie, you see 'CCCCC' if secondary boot source is UART, or USB enumerates if secondary boot source is USB DFU). Check to make sure your power up sequencing is correct, and all power supplies are valid and stable after RESETSTATz goes high. Also ensure the boot media is not in reset (maybe a separate signal is holding it in reset) while the ROM is attempting to access it.
Try performing a warm reset on your board if possible. If the board boots as expected after a warm reset, but does not after a power up, then that may indicate a power sequencing issue, or possibly the boot media peripheral is not 'ready' immediately after power up. Check interface signals and supplies after RESETSTATz.
If you can boot from the secondary boot source, try to read register MAIN_DEVSTAT_BOOTMODE (address 0x43000030) either using a debugger or from console prompt. This register indicates the bootmode that was latched by the device. The device may be inadvertently latching a different bootmode than what is expected from the bootmode pins. Confirm this bootmode register is latching the correct value (Refer to the Initialization Chapter in the TRM, Section Boot Mode Pins)
Section 2: Hang during DDR initialization
The console output may hang in u-boot like below. If your console output has more lines or does not hang at this point, skip to Section 3
U-Boot SPL 2023.04-dirty (Apr 03 2024 - 16:03:41 -0500)
SYSFW ABI: 3.1 (firmware rev 0x0009 '9.1.8--v09.01.08 (Kool Koala)')
SPL initial stack usage: 13384 bytes
This typically means the DDR configuration is incorrect. If your design uses a different DDR device from the EVMs (or even if it is the same), you need to use the DDR Register Configuration Tool to generate a header file for your board using one of the following links (depending on the device you are using):
- AM64x: https://dev.ti.com/sysconfig/?product=Processor_DDR_Config&device=AM64x
- AM62x: https://dev.ti.com/sysconfig/?product=Processor_DDR_Config&device=AM62x
- AM62Ax: https://dev.ti.com/sysconfig/?product=Processor_DDR_Config&device=AM62Ax
- AM62Px: https://dev.ti.com/sysconfig/?product=Processor_DDR_Config&device=AM62Px
Check the README in the tool for further instructions on how to use the tool. This also has guidance on where to place the header file output to rebuild it into your code.
Also check the links in Section 3 for further assistance in customizing the DDR configuration for your board
Adding debug statements to u-boot
To help debug the DDR configuration, add the following to include debug statements in the UART console output:
#define DEBUG
to the very top (above all #include) of drivers/ram/k3-ddrss/k3_ddrss.c
A successful boot with DEBUG messages and LPDDR4 memory will look something like this:
U-Boot SPL 2023.04-dirty (Apr 03 2024 - 16:48:03 -0500)
SYSFW ABI: 3.1 (firmware rev 0x0009 '9.1.8--v09.01.08 (Kool Koala)')
k3_ddrss_probe(dev=43c34cdc)
k3_ddrss_ofdata_to_priv(dev=43c34cdc)
k3_ddrss memorycontroller@f300000: ddr freq0 not populated, using bypass frequency.
k3_ddrss_power_on(ddrss=43c3a640)
k3_ddrss memorycontroller@f300000: vtt-supply not found.
k3_lpddr4_probe: PASS
k3_lpddr4_init: PASS
--->>> LPDDR4 Initialization is in progress ... <<<---
k3_lpddr4_freq_update: received freq change req: req type = 1, req no. = 0, instance = 0
k3_lpddr4_freq_update: received freq change req: req type = 0, req no. = 1, instance = 0
k3_lpddr4_freq_update: received freq change req: req type = 1, req no. = 2, instance = 0
k3_lpddr4_freq_update: received freq change req: req type = 2, req no. = 3, instance = 0
k3_lpddr4_freq_update: received freq change req: req type = 1, req no. = 4, instance = 0
k3_lpddr4_freq_update: received freq change req: req type = 2, req no. = 5, instance = 0
k3_lpddr4_start: Post start PASS
SPL initial stack usage: 13384 bytes
Trying to boot from MMC2
<boot log continues...>
Getting DDR register dump after initialization
git apply -v 0001-regdump-patch-files.patch
A boot with DEBUG messages and register dump patch implemented will look like this:
k3_lpddr4_start: Post start PASS
Begin DDR Register Dump
0x0f308000 0x10460b01 //DDRSS_CTL_0_DATA
0x0f308004 0x5d1af3c3 //DDRSS_CTL_1_DATA
0x0f308008 0x0171a610 //DDRSS_CTL_2_DATA
<many more registers>
0x0f30d5ec 0x00018011 //DDRSS_PHY_1403_DATA_F2
0x0f30d5f0 0x0089ff00 //DDRSS_PHY_1404_DATA_F2
0x0f30d5f4 0x20040004 //DDRSS_PHY_1405_DATA_F2
End of DDR Register Dump
SPL initial stack usage: 13384 bytes
Trying to boot from MMC2
Hardware checks:
Validate the custom board design meets all of the device power, clock, and reset requirements. These are the three most fundamental things needed for the device to operate properly.
- VDDS_DDR = VDDS_DDR_C = 1.2V
- VDDA_PLL1 = 1.8V (AM64x/AM243)
- VDDA_PLL0 = 1.8V (AM62x)
- VDDA_DDR_PLL0 = VDD_CORE = 0.75 or 0.85V (AM62 AMC package only)
Memory voltage rails:
- VTT = 0.6V
- DDR_VREFCA = 0.6V
- DDR_VPP = 2.5V
For LPDDR4 designs:
Processor voltage rails:
- VDDS_DDR = VDDS_DDR_C = 1.1V
- VDDA_PLL1 = 1.8V (AM64x/AM243)
- VDDA_PLL0 = 1.8V (AM62x)
- VDDA_PLL4 = 1.8V (AM62Ax)
- VDDA_PLL3 = 1.8V (AM62Px)
- VDDA_DDR_PLL0 = VDD_CORE = 0.75 or 0.85V (AM62 AMC package, AM62Ax, AM62Px)
Memory voltage rails:
- VDDQ = VDD2 = 1.1V
- VDD1 = 1.8V
Clocks
- probe DDR_CK to see if it is the expected frequency
Resets
DDR4:
- ensure DDR_RESETn signal is low throughout power ramp and transitions high (1.2V) only once, at least 200us after power ramp completes
- ensure DDR_CKE transitions high- (1.2V) at least 500us after DDR_RESETn transitions high
LPDDR4:
- ensure DDR_RESETn signal is low throughout power ramp and transitions high (1.1V) only once, at least 200us after power ramp completes
- ensure DDR_CKE transitions high (1.1V) at least 2ms after DDR_RESET transitions high
Section 3: Debugging Software failures during boot
Consult some of the software documentation for Linux board port
- Go to https://dev.ti.com/tirex/explore/
- Expand 'Arm-based processors'
- Expand 'Training'
- Choose 'AM6*** Academy' for the device and SDK version you are using
- Expand 'Linux'
- Select 'Porting Linux to Custom Hardware' and follow the guidance on the subsequent pages
If you are using MCU+ SDK, consult the online documentation for MCU+:
-
go to the Documentation link in your device's MCU+ SDK page.
-
In the left hand tabs, choose SOC Peripheral Drivers->DDR->Creating your own DDR config file for DDR4 designs (or Creating your own LPDDR config file for LPDDR4 designs)
Some other links that can possibly help: