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.

TMS320F28379D: Linker file memory range errors

Part Number: TMS320F28379D
Other Parts Discussed in Thread: C2000WARE

Hello,

I am using the following empty project inside C2000Ware_3_04_00_00.

C:\C2000Ware_3_04_00_00\driverlib\f2837xd\examples\dual\empty_projects

After I wrote some code in the project, I started getting the following errors.

I added the "RAMGS0 | RAMGS1 | RAMGS2 | RAMGS3" sections to the project because of insufficient RAM.

The "2837xD_RAM_lnk_cpu1.cmd" file of my project is attached.

/cfs-file/__key/communityserver-discussions-components-files/171/2837xD_5F00_RAM_5F00_lnk_5F00_cpu1.rar

How can we solve this error?

Thanks,

Sinan.

  • Hi Sinan,

    You can combine consecutive memories to form  larger emmory blocks so that tlarges sections can be fit in.

    For example : 

    /* RAMLS4 : origin = 0x00A000, length = 0x000800 */
    /* RAMLS5 : origin = 0x00A800, length = 0x000800 */
    RAMLS4_5 : origin = 0x00A000, length = 0x001000

    Regards,

    Veena

  • Hi, Veena:

    For example : 

    /* RAMLS4 : origin = 0x00A000, length = 0x000800 */
    /* RAMLS5 : origin = 0x00A800, length = 0x000800 */
    RAMLS4_5 : origin = 0x00A000, length = 0x001000

    I did as you stated, but the problem is not solved.

    I added RAMLS4_5 to the .text section of the linker file. Also, I set the "--gen_" settings in the image below to "on".

    My "2837xD_FLASH_lnk_cpu1.cmd" file is as follows:

    Fullscreen
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    MEMORY
    {
    PAGE 0 :
    /* BEGIN is used for the "boot to SARAM" bootloader mode */
    BEGIN : origin = 0x000000, length = 0x000002
    RAMM0 : origin = 0x000123, length = 0x0002DD
    RAMD0 : origin = 0x00B000, length = 0x000800
    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
    RESET : origin = 0x3FFFC0, length = 0x000002
    PAGE 1 :
    BOOT_RSVD : origin = 0x000002, length = 0x000121 /* Part of M0, BOOT rom will use this for stack */
    RAMM1 : origin = 0x000400, length = 0x0003F8 /* on-chip RAM block M1 */
    // RAMM1_RSVD : origin = 0x0007F8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
    RAMD1 : origin = 0x00B800, length = 0x000800
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Regards,
    Sinan.

  • Hi,

    Please take a note on the error message. It says the .text is of size 0x1de7 and the individual memory blocks are of size 0x800. To fit in a section of size 0x1de7, you need to combine 4 consecutive memories

    Regards,

    Veena

  • Hi,

    I combined RAMLS2, RAMLS3, RAMLS4 and RAMLS5 memory partitions. But again it didn't.

    Fullscreen
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    MEMORY
    {
    PAGE 0 :
    /* BEGIN is used for the "boot to SARAM" bootloader mode */
    BEGIN : origin = 0x000000, length = 0x000002
    RAMM0 : origin = 0x000123, length = 0x0002DD
    RAMD0 : origin = 0x00B000, length = 0x000800
    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
    RESET : origin = 0x3FFFC0, length = 0x000002
    PAGE 1 :
    BOOT_RSVD : origin = 0x000002, length = 0x000121 /* Part of M0, BOOT rom will use this for stack */
    RAMM1 : origin = 0x000400, length = 0x0003F8 /* on-chip RAM block M1 */
    // RAMM1_RSVD : origin = 0x0007F8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
    RAMD1 : origin = 0x00B800, length = 0x000800
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    Thanks,
    Sinan.

  • Hi Sinan,

    As mentioned in the error message there is no RAMLS2_3_4_5 in page 0. Please add the RAMLS2_3_4_5 definition under Page 0

    Regards,

    Veena

  • Hi, Veena:

    I added the "RAMGS0 | RAMGS1 | RAMGS2 | RAMGS3" sections to the project because of insufficient RAM.

    Couldn't I have just added new RAM partition instead of combining RAM blocks?

    for example:

    Fullscreen
    1
    .text : >> RAMD0 | RAMLS0 | RAMLS1 | RAMLS2 | RAMLS3 | RAMLS4 | RAMGS0 | RAMGS1 | RAMGS2 | RAMGS3, PAGE = 0
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

    It didn't happen when I did it.

    Thanks,
    Sinan.

  • Hi Sinan,

    This works if the linker is able to split the .text section to smaller subsections. By default, the sections can be split at file level. If you have gen_func_subsections turned on, compiler treats each function as separate subsection. But if a single function itself is bigger than the size of a single memory block, linker cannot split this further and allocate across memory blocks. hence you need to combine memory blocks to form larger blocks.

    In your case if you move the RAMLS2_3_4_5  definition under Page 0, the issue should get resolved, I believe.

    In fact, it is not required to split the memories as PAGE 0 and PAGE 1. you can keep all the memory blocks in PAGE0 itself. This was required for some of the older devices to divide program and data memory. It is not mandatory for this device

    Regards,

    Veena

  • Hi, Veena:

    My problem solved. I am thankful to you.

    I will close this post case later.

    Thank you very much for your feedbacks.

    Thanks also to TI E2E for the quick support as usual.

    Have a great day and keep safe at all times.

    Sinan,
    Thanks and best regards.