1import os 2 3# core to be use 4#USE_CORE = 'CORE_M0' 5USE_CORE = 'CORE_M4' 6 7# toolchains options 8ARCH='arm' 9 10if USE_CORE == 'CORE_M4': 11 CPU = 'cortex-m4' 12else: 13 CPU = 'cortex-m0' 14 15CROSS_TOOL='keil' 16 17 18# get setting from environment. 19if os.getenv('RTT_CC'): 20 CROSS_TOOL = os.getenv('RTT_CC') 21 22# cross_tool provides the cross compiler 23# EXEC_PATH is the compiler execute path, for example, CodeSourcery, Keil MDK, IAR 24if CROSS_TOOL == 'gcc': 25 PLATFORM = 'gcc' 26 EXEC_PATH = r'C:/Program Files/CodeSourcery/arm-none-eabi/bin' 27elif CROSS_TOOL == 'keil': 28 PLATFORM = 'armcc' 29 EXEC_PATH = r'D:/Keil' 30elif CROSS_TOOL == 'iar': 31 PLATFORM = 'iccarm' 32 EXEC_PATH = r'C:/Program Files/IAR Systems/Embedded Workbench 6.0' 33 34if os.getenv('RTT_EXEC_PATH'): 35 EXEC_PATH = os.getenv('RTT_EXEC_PATH') 36 37# 38BUILD = 'debug' 39 40if PLATFORM == 'gcc': 41 # toolchains 42 PREFIX = 'arm-none-eabi-' 43 CC = PREFIX + 'gcc' 44 AS = PREFIX + 'gcc' 45 AR = PREFIX + 'ar' 46 LINK = PREFIX + 'gcc' 47 TARGET_EXT = 'elf' 48 SIZE = PREFIX + 'size' 49 OBJDUMP = PREFIX + 'objdump' 50 OBJCPY = PREFIX + 'objcopy' 51 DEVICE = ' -mcpu=' + CPU + ' -mthumb -ffunction-sections -fdata-sections -Wall' 52 if USE_CORE == 'CORE_M4': 53 DEVICE += ' -mfpu=fpv4-sp-d16 -mfloat-abi=softfp' 54 CFLAGS = DEVICE 55 AFLAGS = ' -c' + DEVICE + ' -x assembler-with-cpp -Wa,-mimplicit-it=thumb ' 56 LFLAGS = DEVICE + ' -Wl,--gc-sections,-Map=rtthread-lpc43xx.map,-cref,-u,Reset_Handler -T rtthread-lpc43xx.ld' 57 58 CPATH = '' 59 LPATH = '' 60 61 CFLAGS += ' -gdwarf-2' 62 AFLAGS += ' -gdwarf-2' 63 if BUILD == 'debug': 64 CFLAGS += ' -O0' 65 else: 66 CFLAGS += ' -O2' 67 68 POST_ACTION = OBJCPY + ' -O binary $TARGET rtthread.bin\n' + SIZE + ' $TARGET \n' 69 70elif PLATFORM == 'armcc': 71 # toolchains 72 CC = 'armcc' 73 AS = 'armasm' 74 AR = 'armar' 75 LINK = 'armlink' 76 TARGET_EXT = 'axf' 77 78 DEVICE = ' --device DARMSTM' 79 CFLAGS = DEVICE + ' --apcs=interwork ' 80 AFLAGS = DEVICE 81 LFLAGS = DEVICE + ' --info sizes --info totals --info unused --info veneers --list rtthread-lpc43xx.map --scatter rtthread-lpc43xx_spifi.sct' 82 83 CFLAGS += ' -I' + EXEC_PATH + '/ARM/RV31/INC' 84 LFLAGS += ' --libpath ' + EXEC_PATH + '/ARM/RV31/LIB' 85 86 EXEC_PATH += '/arm/bin40/' 87 88 if BUILD == 'debug': 89 CFLAGS += ' -g -O0' 90 AFLAGS += ' -g' 91 else: 92 CFLAGS += ' -O2' 93 94 POST_ACTION = 'fromelf --bin $TARGET --output rtthread.bin \nfromelf -z $TARGET' 95 96elif PLATFORM == 'iccarm': 97 # toolchains 98 CC = 'iccarm' 99 AS = 'iasmarm' 100 AR = 'iarchive' 101 LINK = 'ilinkarm' 102 TARGET_EXT = 'out' 103 104 CFLAGS = ' --diag_suppress Pa050' 105 CFLAGS += ' --no_cse' 106 CFLAGS += ' --no_unroll' 107 CFLAGS += ' --no_inline' 108 CFLAGS += ' --no_code_motion' 109 CFLAGS += ' --no_tbaa' 110 CFLAGS += ' --no_clustering' 111 CFLAGS += ' --no_scheduling' 112 CFLAGS += ' --debug' 113 CFLAGS += ' --endian=little' 114 if USE_CORE == 'CORE_M4': 115 CFLAGS += ' --cpu=Cortex-M4' 116 CFLAGS += ' --fpu=None' 117 else: 118 CFLAGS += ' --cpu=Cortex-M0' 119 CFLAGS += ' -e' 120 CFLAGS += ' --dlib_config "' + EXEC_PATH + '/arm/INC/c/DLib_Config_Normal.h"' 121 CFLAGS += ' -Ol' 122 CFLAGS += ' --use_c++_inline' 123 124 AFLAGS = '' 125 AFLAGS += ' -s+' 126 AFLAGS += ' -w+' 127 AFLAGS += ' -r' 128 if USE_CORE == 'CORE_M4': 129 AFLAGS += ' --cpu Cortex-M4' 130 AFLAGS += ' --fpu None' 131 else: 132 AFLAGS += ' --cpu Cortex-M0' 133 134 LFLAGS = ' --config lpc43xx_flash.icf' 135 LFLAGS += ' --redirect _Printf=_PrintfTiny' 136 LFLAGS += ' --redirect _Scanf=_ScanfSmall' 137 LFLAGS += ' --entry __iar_program_start' 138 139 EXEC_PATH = EXEC_PATH + '/arm/bin/' 140 POST_ACTION = '' 141