#--------------------------------------------------------------------------- # Project: NitroSDK - tools - makelcf # File: ARM9-TS-C.lcf.template # # Copyright 2003-2008 Nintendo. All rights reserved. # # These coded instructions, statements, and computer programs contain # proprietary information of Nintendo of America Inc. and/or Nintendo # Company Ltd., and are protected by Federal copyright law. They may # not be disclosed to third parties or copied or duplicated in any form, # in whole or in part, without the prior written consent of Nintendo. # # $Log: ARM9-TS-C.lcf.template,v $ # Revision 1.20 2006/07/20 07:29:12 kitase_hirotake # Added the description explaining the version section # # Revision 1.19 2006/07/18 11:11:01 yasu # There is an error in the way check.xTCM gets the OVERLAY region size in the TCM region overflow check. Because it is not currently clear how to accurately calculate this, the addition of the OVERLAY region was cut out. # # # # Revision 1.18 2006/05/10 03:19:47 yasu # Added support for the CodeWarrior 2.x overlay expansion # # Revision 1.17 2006/04/07 04:45:03 kitase_hirotake # Added .itcm.bss/.dtcm.bss # # Revision 1.16 2006/03/30 00:31:29 yasu # Revised NUMBER_OVERLAYS to NUMBER.OVERLAYS # # Revision 1.15 2006/03/29 13:19:14 yasu # NUMBER_OVERLAYS revised to NUMBER.OVERLAYS # # Revision 1.14 2005/11/24 01:16:47 yada # Changed start address of mainEX arena from 0x2400000 to 0x23e0000 # # Revision 1.13 2005/09/02 04:14:22 yasu # Old symbols were redefined so they can be used even under SDK2.2 # # Revision 1.12 2005/08/31 09:34:57 yasu # Corrected a problem where code would not function normally when using section names such as section_BSS # # Revision 1.11 2005/08/26 11:22:16 yasu # Overlay support for ITCM/DTCM # # Revision 1.10 2005/06/20 12:29:20 yasu # Changed Surffix to Suffix # # Revision 1.9 2005/06/14 09:03:42 yada # Fix specific to negative value of SDK_STACKSIZE # # Revision 1.8 2005/04/13 12:52:22 terui # Changed SDK_AUTOLOAD.DTCM.START 0x027c0000 to 0x027e0000 # # Revision 1.7 2005/03/25 12:54:59 yasu # Added the .version section # # Revision 1.6 2005/01/14 03:35:32 yasu # Support sinit # # Revision 1.5 2004/11/05 04:23:32 yasu # Added OverlayTable digest # # Revision 1.4 2004/10/03 02:00:56 yasu # Output component file list for compstatic tool # # Revision 1.3 2004/09/09 11:49:20 yasu # Added support for compstatic in default # # Revision 1.2 2004/09/09 03:15:45 yasu # Fixed typo # # Revision 1.1 2004/09/01 07:49:39 yasu # Added support for NITRO_COMPRESS # # $NoKeywords: $ #--------------------------------------------------------------------------- MEMORY { (RWX) : ORIGIN = , LENGTH = 0x0 > (RWX) : ORIGIN = , LENGTH = 0x0 >> binary.AUTOLOAD_INFO (RWX) : ORIGIN = 0, LENGTH = 0x0 >> binary.STATIC_FOOTER (RWX) : ORIGIN = 0, LENGTH = 0x0 >> (RW) : ORIGIN = AFTER(), LENGTH = 0x0 > (RW) : ORIGIN = AFTER(), LENGTH = 0x0 > (RWXO): ORIGIN = , LENGTH = 0x0 > dummy.MAIN_EX (RW) : ORIGIN = 0x023e0000, LENGTH = 0x0 arena.MAIN (RW) : ORIGIN = AFTER(,), LENGTH = 0x0 arena.MAIN_EX (RW) : ORIGIN = AFTER(dummy.MAIN_EX,), LENGTH = 0x0 arena.ITCM (RW) : ORIGIN = AFTER(ITCM,), LENGTH = 0x0 arena.DTCM (RW) : ORIGIN = AFTER(DTCM,), LENGTH = 0x0 binary.MODULE_FILES (RW) : ORIGIN = 0x0, LENGTH = 0x0 > component.files check.ITCM (RWX) : ORIGIN = 0x0, LENGTH = 0x08000 > itcm.check check.DTCM (RW) : ORIGIN = 0x0, LENGTH = 0x04000 > dtcm.check } FORCE_ACTIVE { SVC_SoftReset } KEEP_SECTION { .sinit } SECTIONS { ############################ STATIC ################################# .: { ALIGNALL(4); . = ALIGN(32); # Fit to cache line SEARCH_SYMBOL ; # # TEXT BLOCK: READ ONLY # SDK_STATIC_START =.; SDK_STATIC_TEXT_START =.; #:::::::::: text/rodata libsyscall.a (.text) crt0.o (.text) crt0.o (.rodata) # # Added .version section. # The information included in this section will be needed for Lotcheck purposes. Be sure to leave it in this position. # # * (.version) OBJECT(NitroMain,*) . = ALIGN(4); * (.exception) . = ALIGN(4); SDK_STATIC_ETABLE_START =.; EXCEPTION SDK_STATIC_ETABLE_END =.; . = ALIGN(4); . = ALIGN(4); . = ALIGN(4); SDK_STATIC_SINIT_START =.; #:::::::::: ctor WRITEW 0; #:::::::::: ctor SDK_STATIC_SINIT_END =.; #:::::::::: text/rodata . = ALIGN(32); SDK_STATIC_TEXT_END =.; # # DATA BLOCK: READ WRITE # SDK_STATIC_DATA_START =.; #:::::::::: Data . = ALIGN(4); . = ALIGN(4); SDK_OVERLAYTABLE_DIGEST =.; . = . + 20; SDK_OVERLAYTABLE_DIGEST_END =.; SDK_OVERLAY_DIGEST =.; . = . + * 20; SDK_OVERLAY_DIGEST_END =.; #:::::::::: Data . = ALIGN(32); SDK_STATIC_DATA_END =.; SDK_STATIC_END =.; SDK_STATIC_TEXT_SIZE = SDK_STATIC_TEXT_END - SDK_STATIC_TEXT_START; SDK_STATIC_DATA_SIZE = SDK_STATIC_DATA_END - SDK_STATIC_DATA_START; SDK_STATIC_SIZE = SDK_STATIC_END - SDK_STATIC_START; __sinit__ = SDK_STATIC_SINIT_START; # For static initializer __exception_table_start__ = SDK_STATIC_ETABLE_START; # For exception table __exception_table_end__ = SDK_STATIC_ETABLE_END; # For exception table } > ..bss: { ALIGNALL(4); . = ALIGN(32); SEARCH_SYMBOL ; # # BSS BLOCK # SDK_STATIC_BSS_START =.; #:::::::::: bss . = ALIGN(4); . = ALIGN(4); #:::::::::: bss . = ALIGN(32); SDK_STATIC_BSS_END = .; SDK_STATIC_BSS_SIZE = SDK_STATIC_BSS_END - SDK_STATIC_BSS_START; } >> ############################ AUTOLOADS ############################## SDK_AUTOLOAD.ITCM.START = 0x01ff8000; SDK_AUTOLOAD.ITCM.END = SDK_AUTOLOAD.ITCM.START; SDK_AUTOLOAD.ITCM.BSS_END = SDK_AUTOLOAD.ITCM.START; SDK_AUTOLOAD.ITCM.SIZE = 0; SDK_AUTOLOAD.ITCM.BSS_SIZE = 0; SDK_AUTOLOAD.DTCM.START = 0x027e0000; SDK_AUTOLOAD.DTCM.END = SDK_AUTOLOAD.DTCM.START; SDK_AUTOLOAD.DTCM.BSS_END = SDK_AUTOLOAD.DTCM.START; SDK_AUTOLOAD.DTCM.SIZE = 0; SDK_AUTOLOAD.DTCM.BSS_SIZE = 0; SDK_AUTOLOAD_START = SDK_STATIC_END; SDK_AUTOLOAD_SIZE = 0; SDK_AUTOLOAD_NUMBER = ; .: { ALIGNALL(4); . = ALIGN(32); SEARCH_SYMBOL ; # # TEXT BLOCK: READ ONLY # SDK_AUTOLOAD__ID =; SDK_AUTOLOAD..ID =; SDK_AUTOLOAD..START =.; SDK_AUTOLOAD..TEXT_START =.; #:::::::::: text/rodata . = ALIGN(4); . = ALIGN(4); . = ALIGN(4); #:::::::::: text/rodata SDK_AUTOLOAD..TEXT_END =.; # # DATA BLOCK: READ WRITE BLOCK # SDK_AUTOLOAD..DATA_START =.; #:::::::::: Data . = ALIGN(4); . = ALIGN(4); . = ALIGN(4); #:::::::::: Data . = ALIGN(32); SDK_AUTOLOAD..DATA_END =.; SDK_AUTOLOAD..END =.; SDK_AUTOLOAD..TEXT_SIZE = SDK_AUTOLOAD..TEXT_END - SDK_AUTOLOAD..TEXT_START; SDK_AUTOLOAD..DATA_SIZE = SDK_AUTOLOAD..DATA_END - SDK_AUTOLOAD..DATA_START; SDK_AUTOLOAD..SIZE = SDK_AUTOLOAD..END - SDK_AUTOLOAD..START; SDK_AUTOLOAD_SIZE = SDK_AUTOLOAD_SIZE + SDK_AUTOLOAD..SIZE; } > ..bss: { ALIGNALL(4); . = ALIGN(32); SEARCH_SYMBOL ; # # BSS BLOCK # SDK_AUTOLOAD..BSS_START = .; #:::::::::: bss . = ALIGN(4); . = ALIGN(4); . = ALIGN(4); . = ALIGN(4); #:::::::::: bss . = ALIGN(32); SDK_AUTOLOAD..BSS_END = .; SDK_AUTOLOAD..BSS_SIZE = SDK_AUTOLOAD..BSS_END - SDK_AUTOLOAD..BSS_START; } >> SDK_AUTOLOAD_ITCM_START = SDK_AUTOLOAD.ITCM.START; SDK_AUTOLOAD_ITCM_END = SDK_AUTOLOAD.ITCM.END; SDK_AUTOLOAD_ITCM_BSS_END = SDK_AUTOLOAD.ITCM.BSS_END; SDK_AUTOLOAD_ITCM_SIZE = SDK_AUTOLOAD.ITCM.SIZE; SDK_AUTOLOAD_ITCM_BSS_SIZE = SDK_AUTOLOAD.ITCM.BSS_SIZE; SDK_AUTOLOAD_DTCM_START = SDK_AUTOLOAD.DTCM.START; SDK_AUTOLOAD_DTCM_END = SDK_AUTOLOAD.DTCM.END; SDK_AUTOLOAD_DTCM_BSS_END = SDK_AUTOLOAD.DTCM.BSS_END; SDK_AUTOLOAD_DTCM_SIZE = SDK_AUTOLOAD.DTCM.SIZE; SDK_AUTOLOAD_DTCM_BSS_SIZE = SDK_AUTOLOAD.DTCM.BSS_SIZE; ############################ AUTOLOAD_INFO ########################## .binary.AUTOLOAD_INFO: { WRITEW ADDR(.); WRITEW SDK_AUTOLOAD..SIZE; WRITEW SDK_AUTOLOAD..BSS_SIZE; } > binary.AUTOLOAD_INFO SDK_AUTOLOAD_LIST = SDK_AUTOLOAD_START + SDK_AUTOLOAD_SIZE; SDK_AUTOLOAD_LIST_END = SDK_AUTOLOAD_START + SDK_AUTOLOAD_SIZE + SIZEOF(.binary.AUTOLOAD_INFO); SDK_AUTOLOAD_SIZE = SDK_AUTOLOAD_SIZE + SIZEOF(.binary.AUTOLOAD_INFO); ############################ STATIC_FOOTER ########################## .binary.STATIC_FOOTER: { WRITEW 0xdec00621; # LE(0x2106C0DE) = NITRO CODE WRITEW _start_ModuleParams - ADDR(.); WRITEW SDK_OVERLAY_DIGEST - ADDR(.); } > binary.STATIC_FOOTER ############################ OVERLAYS ############################### SDK_OVERLAY_NUMBER = ; .: { ALIGNALL(4); . = ALIGN(32); SEARCH_SYMBOL ; # # TEXT BLOCK: READ ONLY # SDK_OVERLAY__ID =; ### SEGMENT OVERLAY ID SDK_OVERLAY..ID =; SDK_OVERLAY..START =.; SDK_OVERLAY..TEXT_START =.; #:::::::::: text/rodata . = ALIGN(4); . = ALIGN(4); . = ALIGN(4); SDK_OVERLAY..SINIT_START =.; #:::::::::: ctor WRITEW 0; #:::::::::: ctor SDK_OVERLAY..SINIT_END =.; #:::::::::: text/rodata . = ALIGN(32); SDK_OVERLAY..TEXT_END =.; # # DATA BLOCK: READ WRITE # SDK_OVERLAY..DATA_START =.; #:::::::::: Data . = ALIGN(4); . = ALIGN(4); #:::::::::: Data . = ALIGN(32); SDK_OVERLAY..DATA_END =.; SDK_OVERLAY..END =.; SDK_OVERLAY..TEXT_SIZE = SDK_OVERLAY..TEXT_END - SDK_OVERLAY..TEXT_START; SDK_OVERLAY..DATA_SIZE = SDK_OVERLAY..DATA_END - SDK_OVERLAY..DATA_START; SDK_OVERLAY..SIZE = SDK_OVERLAY..END - SDK_OVERLAY..START; } > ..bss: { ALIGNALL(4); . = ALIGN(32); SEARCH_SYMBOL ; # # BSS BLOCK # SDK_OVERLAY..BSS_START = .; #:::::::::: bss . = ALIGN(4); . = ALIGN(4); #:::::::::: bss . = ALIGN(32); SDK_OVERLAY..BSS_END = .; SDK_OVERLAY..BSS_SIZE = SDK_OVERLAY..BSS_END - SDK_OVERLAY..BSS_START; } >> ############################ MAIN EX ################################## # MAIN EX Area .dummy.MAIN_EX: { . = ALIGN(32); } > dummy.MAIN_EX ############################ ARENA ################################## .arena.MAIN: { . = ALIGN(32); SDK_SECTION_ARENA_START =.; } > arena.MAIN .arena.MAIN_EX: { . = ALIGN(32); SDK_SECTION_ARENA_EX_START =.; } > arena.MAIN_EX .arena.ITCM: { . = ALIGN(32); SDK_SECTION_ARENA_ITCM_START =.; } > arena.ITCM .arena.DTCM: { . = ALIGN(32); SDK_SECTION_ARENA_DTCM_START =.; } > arena.DTCM ############################ OVERLAYDEFS ############################ .: { ### module information WRITEW ADDR(.); # Load address WRITEW _start; # Entry address WRITEW SDK_STATIC_SIZE + SDK_AUTOLOAD_SIZE; # Size of module WRITEW _start_AutoloadDoneCallback; # Callback autoload done ### overlay filename WRITES (""); # Overlay } > ############################ OVERLAYTABLE ########################### .: { # Overlay WRITEW ; # Overlay ID WRITEW ADDR(.); # Load address WRITEW SDK_OVERLAY..SIZE; # Size of module WRITEW SDK_OVERLAY..BSS_SIZE; # Size of bss WRITEW SDK_OVERLAY..SINIT_START; # Start address of static init WRITEW SDK_OVERLAY..SINIT_END; # End address of static init WRITEW ; # ROM file ID WRITEW 0; # Reserved } > ############################ OTHERS ################################# SDK_MAIN_ARENA_LO = SDK_SECTION_ARENA_START; SDK_IRQ_STACKSIZE = ; # Allocated in DTCM SDK_SYS_STACKSIZE = ; # When 0 means all remains of DTCM # Module filelist .binary.MODULE_FILES: { WRITES (""); WRITES (""); WRITES (""); } > binary.MODULE_FILES # ITCM/DTCM size checker => check AUTOLOAD_ITCM/DTCM .check.ITCM: { . = . + SDK_AUTOLOAD_ITCM_SIZE + SDK_AUTOLOAD_ITCM_BSS_SIZE; } > check.ITCM SDK_SYS_STACKSIZE_SIGN = (SDK_SYS_STACKSIZE < 0x80000000) * 2 - 1; .check.DTCM: { . = . + SDK_AUTOLOAD_DTCM_SIZE + SDK_AUTOLOAD_DTCM_BSS_SIZE; . = . + SDK_IRQ_STACKSIZE + SDK_SYS_STACKSIZE * SDK_SYS_STACKSIZE_SIGN; } > check.DTCM }