User Tools

Site Tools


blog:2020-07-20_stm32_.icf_file_note



2020-07-20 STM32 .icf File Note

  • STM32 IAR .icf File is the device configuration file
  • It descriptes the flash and sram size specification
  • Refer the specification of the chip:

The Chip Specification

Chip Code Flash/RAM Siza ROM Start ROM End RAM Start RAM End
G 1024K/96K 0x08000000 0x080FFFFF 0x20000000 0x20017FFF
F 768K/96K 0x08000000 0x080BFFFF 0x20000000 0x20017FFF
E 512K/64K 0x08000000 0x0807FFFF 0x20000000 0x2000FFFF
D 384K/64K 0x08000000 0x0805FFFF 0x20000000 0x2000FFFF
C 256K/48K 0x08000000 0x0803FFFF 0x20000000 0x2000BFFF
B 128K/20K 0x08000000 0x0801FFFF 0x20000000 0x20004FFF
8 64K/20K 0x08000000 0x0800FFFF 0x20000000 0x20004FFF
6 32K/10K 0x08000000 0x08007FFF 0x20000000 0x20002FFF
4 16K/6K 0x08000000 0x08003FFF 0x20000000 0x200017FF

The .ICF File of xC (Ex: STM32F103RCT6)

  • /*###ICF### Section handled by ICF editor, don't touch! ****/
    /*-Editor annotation file-*/
    /* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
    /*-Specials-*/
    define symbol __ICFEDIT_intvec_start__ = 0x08000000;
    /*-Memory Regions-*/
    define symbol __ICFEDIT_region_ROM_start__   = 0x08000000 ;
    define symbol __ICFEDIT_region_ROM_end__     = 0x0803FFFF;
    define symbol __ICFEDIT_region_RAM_start__   = 0x20000000;
    define symbol __ICFEDIT_region_RAM_end__     = 0x2000BFFF;
    /*-Sizes-*/
    define symbol __ICFEDIT_size_cstack__   = 0x400;
    define symbol __ICFEDIT_size_heap__     = 0x200;
    /**** End of ICF editor section. ###ICF###*/
    
    
    define memory mem with size = 4G;
    define region ROM_region   = mem:[from __ICFEDIT_region_ROM_start__   to __ICFEDIT_region_ROM_end__];
    define region RAM_region   = mem:[from __ICFEDIT_region_RAM_start__   to __ICFEDIT_region_RAM_end__];
    
    define block CSTACK    with alignment = 8, size = __ICFEDIT_size_cstack__   { };
    define block HEAP      with alignment = 8, size = __ICFEDIT_size_heap__     { };
    
    initialize by copy { readwrite };
    do not initialize  { section .noinit };
    
    place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
    
    place in ROM_region   { readonly };
    place in RAM_region   { readwrite,
                            block CSTACK, block HEAP };
    

TAGS

  • 3 person(s) visited this page until now.

blog/2020-07-20_stm32_.icf_file_note.txt · Last modified: 2020/07/20 17:04 (external edit)