This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

[参考译文] TMS320F28388D:复位后无符号、程序失败

Guru**** 2609285 points
Other Parts Discussed in Thread: TMS320F28388D

请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

https://e2e.ti.com/support/microcontrollers/c2000-microcontrollers-group/c2000/f/c2000-microcontrollers-forum/1034086/tms320f28388d-no-symbols-after-reset-program-fails

器件型号:TMS320F28388D

大家好、

在正常复位(按 TMS320F28388D 控制卡上的 S1)或下电上电后、我当前无法使代码正常工作。

当我通过 CCS (RAM 或闪存)重新加载程序时、一切工作正常。 正常复位后、程序将不再工作(RAM 或闪存)。 在下电上电后、它将不会运行(仅闪存)

当我在复位后连接调试器时、或者如果我在复位期间保持连接、我可以看到一些变量是随机变化的。 这让我想、有些代码正在运行、但不知怎么说、执行会分支到内存中的随机位置、而不是我的写入代码。 我不知道应该如何调试这个问题,因为执行永远不会到达 main()。

这种行为的原因可能是什么? 为什么在通过 CCS /在任何复位后加载程序时、引导过程不同?

谢谢、此致、

Marcel Kummer。

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    尊敬的 Marcel:

    这里有几个要检查的地方-

    1. 引导模式引脚设置-请确保引导模式设置为闪存引导。 否则、当未连接到 CCS 时、程序将不会运行到闪存。  
    2. 连接 CCS 后、器件会在任何复位后根据仿真启动进行引导、因此您需要设置正确的仿真启动。 使用 CCS、程序入口点在加载代码后被 CCS 强制执行、因此在加载代码后它可以正常工作、但在您发出复位命令时不能正常工作。 有关仿真启动的详细信息、请参阅器件 TRM。
    3. CMD 文件-请检查 RAM 中没有加载任何内容、因为加电后 RAM 内容会被清除。

    此致、

    Vivek Singh

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    您好、Vivek、

    在连接到 CCS 时复位对我来说并不重要。 我只想让代码独立于 CCS 运行。

    我现在将 S2开关的两个引脚都设置为关闭。 在 SPRUIL8B 中、声明这应该是引导至闪存选项。 但复位后、应用程序仍不会引导至闪存(CCS 未连接)。

    我还检查了闪存 cmd 文件、但找不到错误地放置在 RAM 中而不是闪存中的任何内存。 为了确保、您能验证一下吗? (也许我理解了一个部分错误、并在那里犯了错误)。


    MEMORY
    {
       /* BEGIN is used for the "boot to Flash" bootloader mode   */
       BEGIN            : origin = 0x080000, length = 0x000002
       BOOT_RSVD        : origin = 0x000002, length = 0x0001AE     /* Part of M0, BOOT rom will use this for stack */
       RAMM0            : origin = 0x0001B0, length = 0x000250
       RAMM1            : origin = 0x000400, length = 0x000400     /* on-chip RAM block M1 */
       RAMD0            : origin = 0x00C000, length = 0x000800
       RAMD1            : origin = 0x00C800, length = 0x000800
       RAMLS0_to_LS7    : origin = 0x008000, length = 0x004000
    /*   RAMLS0           : origin = 0x008000, length = 0x000800 */
    /*   RAMLS1           : origin = 0x008800, length = 0x000800 */
    /*   RAMLS2           : origin = 0x009000, length = 0x000800 */
    /*   RAMLS3           : origin = 0x009800, length = 0x000800 */
    /*   RAMLS4           : origin = 0x00A000, length = 0x000800 */
    /*   RAMLS5           : origin = 0x00A800, length = 0x000800 */
    /*   RAMLS6           : origin = 0x00B000, length = 0x000800 */
    /*   RAMLS7           : origin = 0x00B800, length = 0x000800 */
       RAMGS0           : origin = 0x00D000, length = 0x001000
       RAMGS1           : origin = 0x00E000, length = 0x001000
       RAMGS2           : origin = 0x00F000, length = 0x001000
       RAMGS3           : origin = 0x010000, length = 0x001000
       RAMGS4           : origin = 0x011000, length = 0x001000
       RAMGS5           : origin = 0x012000, length = 0x001000
       RAMGS6           : origin = 0x013000, length = 0x001000
       RAMGS7           : origin = 0x014000, length = 0x001000
       RAMGS8           : origin = 0x015000, length = 0x001000
       RAMGS9           : origin = 0x016000, length = 0x001000
       RAMGS10          : origin = 0x017000, length = 0x001000
       RAMGS11          : origin = 0x018000, length = 0x001000
       RAMGS12          : origin = 0x019000, length = 0x001000
       RAMGS13          : origin = 0x01A000, length = 0x001000
       RAMGS14          : origin = 0x01B000, length = 0x001000
       RAMGS15          : origin = 0x01C000, length = 0x001000
    
       /* Flash sectors */
       FLASH0           : origin = 0x080002, length = 0x001FFE  /* on-chip Flash */
       FLASH1           : origin = 0x082000, length = 0x002000  /* on-chip Flash */
       FLASH2           : origin = 0x084000, length = 0x002000  /* on-chip Flash */
       FLASH3           : origin = 0x086000, length = 0x002000  /* on-chip Flash */
       FLASH4           : origin = 0x088000, length = 0x008000  /* on-chip Flash */
       FLASH5           : origin = 0x090000, length = 0x008000  /* on-chip Flash */
       FLASH6           : origin = 0x098000, length = 0x008000  /* on-chip Flash */
       FLASH7           : origin = 0x0A0000, length = 0x008000  /* on-chip Flash */
       FLASH8           : origin = 0x0A8000, length = 0x008000  /* on-chip Flash */
       FLASH9           : origin = 0x0B0000, length = 0x008000  /* on-chip Flash */
       FLASH10          : origin = 0x0B8000, length = 0x002000  /* on-chip Flash */
       FLASH11          : origin = 0x0BA000, length = 0x002000  /* on-chip Flash */
       FLASH12          : origin = 0x0BC000, length = 0x002000  /* on-chip Flash */
       FLASH13          : origin = 0x0BE000, length = 0x002000  /* on-chip Flash */
       
       CPU1TOCPU2RAM    : origin = 0x03A000, length = 0x000800
       CPU2TOCPU1RAM    : origin = 0x03B000, length = 0x000800
    
       CPUTOCMRAM0      : origin = 0x039000, length = 0x000200
       CPUTOCMRAM0_ECAT : origin = 0x039200, length = 0x000200
       CPUTOCMRAM1      : origin = 0x039400, length = 0x000400
    
       CMTOCPURAM0      : origin = 0x038000, length = 0x000200
       CMTOCPURAM0_ECAT : origin = 0x038200, length = 0x000200
       CMTOCPURAM1      : origin = 0x038400, length = 0x000400
    
       CANA_MSG_RAM     : origin = 0x049000, length = 0x000800
       CANB_MSG_RAM     : origin = 0x04B000, length = 0x000800
       RESET            : origin = 0x3FFFC0, length = 0x000002
    }
    
    SECTIONS
    {
       codestart           : > BEGIN, ALIGN(4)
       .text               : >> FLASH1 | FLASH2 | FLASH3 | FLASH4, ALIGN(4)
       .cinit              : > FLASH1 | FLASH2 | FLASH3, ALIGN(4)
       .switch             : > FLASH1, ALIGN(4)
       .reset              : > RESET, TYPE = DSECT /* not used, */
       .stack              : > RAMGS0
    
    #if defined(__TI_EABI__)
       .init_array      : > FLASH1, ALIGN(4)
       .bss             : > RAMLS0_to_LS7
       .bss:output      : > RAMLS0_to_LS7
       .bss:cio         : > RAMLS0_to_LS7
       .data            : > RAMLS0_to_LS7
       .sysmem          : > RAMLS0_to_LS7
       /* Initalized sections go in Flash */
       .const           : > FLASH5, ALIGN(4)
    #else
       .pinit           : > FLASH1, ALIGN(4)
       .ebss            : > RAMLS0_to_LS7
       .esysmem         : > RAMLS0_to_LS7
       .cio             : > RAMLS0_to_LS7
       /* Initalized sections go in Flash */
       .econst          : >> FLASH4 | FLASH5, ALIGN(4)
    #endif
    
       ramgs0 : > RAMGS0, type=NOINIT
       ramgs1 : > RAMGS1, type=NOINIT
       
       MSGRAM_CPU1_TO_CPU2 : > CPU1TOCPU2RAM, type=NOINIT
       MSGRAM_CPU2_TO_CPU1 : > CPU2TOCPU1RAM, type=NOINIT
    
       MSGRAM_CPU_TO_CM    : > CPUTOCMRAM0, type=NOINIT
       MSGRAM_CPU1_TO_CM_ECAT : > CPUTOCMRAM0_ECAT, type=NOINIT
    
       MSGRAM_CM_TO_CPU    : > CMTOCPURAM0, type=NOINIT
       MSGRAM_CM_TO_CPU1_ECAT : > CMTOCPURAM0_ECAT, type=NOINIT
    
       /* The following section definition are for SDFM examples */
       Filter_RegsFile  : > RAMGS0
       Filter1_RegsFile : > RAMGS1, fill=0x1111
       Filter2_RegsFile : > RAMGS2, fill=0x2222
       Filter3_RegsFile : > RAMGS3, fill=0x3333
       Filter4_RegsFile : > RAMGS4, fill=0x4444
       Difference_RegsFile : >RAMGS5, fill=0x3333
    
       #if defined(__TI_EABI__)
           .TI.ramfunc : {} LOAD = FLASH3,
                            RUN = RAMLS0_to_LS7,
                            LOAD_START(RamfuncsLoadStart),
                            LOAD_SIZE(RamfuncsLoadSize),
                            LOAD_END(RamfuncsLoadEnd),
                            RUN_START(RamfuncsRunStart),
                            RUN_SIZE(RamfuncsRunSize),
                            RUN_END(RamfuncsRunEnd),
                            ALIGN(4)
       #else
           .TI.ramfunc : {} LOAD = FLASH3,
                            RUN = RAMLS0_to_LS7,
                            LOAD_START(_RamfuncsLoadStart),
                            LOAD_SIZE(_RamfuncsLoadSize),
                            LOAD_END(_RamfuncsLoadEnd),
                            RUN_START(_RamfuncsRunStart),
                            RUN_SIZE(_RamfuncsRunSize),
                            RUN_END(_RamfuncsRunEnd),
                            ALIGN(4)
       #endif
    
    }
    
    /*
    //===========================================================================
    // End of file.
    //===========================================================================
    */
    


    谢谢、此致、

    Marcel。

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    尊敬的 Marcel:

    对我来说、cmd 文件看起来很好。 连接到 CCS 后、您是否可以按照以下步骤操作并查看其是否正常工作-

    • 从 CCS 复位问题
    • 在存储器观察窗口中、在地址0xD00写入0x5AFF
    • 点击"Run"

    看看这是否运行您的应用程序。 否则、您可以暂停 CPU 并调试代码。

    此致、

    Vivek Singh

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    您好、Vivek、

    我今天回来上班、给我的电路板加电、惊喜的是、它启动了应用。

    我现在尝试了一些操作、可以发现、在我使用 CSS 加载应用程序后、启动所有内核、停止调试(这意味着断开 CCS)使用控制卡上的按钮 S1进行正常复位失败。

    但在下电上电后、应用程序启动正确、然后 S1复位也正常。

    我假设 CCS 在 RAM 中进行一些设置、以阻止应用程序启动。 在下电上电后、将 RAM 归零、从而使应用程序再次正确启动。

    我对此感到高兴。 目前、我在连接 CCS 时不需要复位即可工作。

    谢谢、此致、

    Marcel。