diff options
author | Vegard Storheil Eriksen <zyp@jvnv.net> | 2012-08-07 16:50:46 +0200 |
---|---|---|
committer | Vegard Storheil Eriksen <zyp@jvnv.net> | 2012-08-07 16:50:46 +0200 |
commit | e586c178073b9a0fee90d5fc8e795d266ebd7b7d (patch) | |
tree | ca9a9c40bab37d5af440c80833755223e2bdd946 /build_rules |
Initial import.
Most sources are split off from suzumebachi project revision 2fc77d2 as is with some path changes. New build rules introduced.
Diffstat (limited to 'build_rules')
-rw-r--r-- | build_rules | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/build_rules b/build_rules new file mode 100644 index 0000000..0040cd7 --- /dev/null +++ b/build_rules @@ -0,0 +1,80 @@ +laks_dir = Dir('.') +ld_dir = Dir('ld_scripts') +main_sconscript = File('SConscript') + +def select_arm(env, family): + env.SetDefault( + TOOLCHAIN = 'arm-none-eabi-', + ) + + env.Replace( + CC = '${TOOLCHAIN}gcc', + CXX = '${TOOLCHAIN}g++', + AS = '${TOOLCHAIN}gcc', + LINK = '${TOOLCHAIN}gcc', + AR = '${TOOLCHAIN}ar', + RANLIB = '${TOOLCHAIN}ranlib', + + CCFLAGS = '-O2 -Wall -ggdb -mcpu=${CPU_FAMILY} -mthumb -ffunction-sections', + CXXFLAGS = '-fno-exceptions -fno-rtti -Wno-pmf-conversions', + ASFLAGS = '-c -x assembler-with-cpp -mcpu=${CPU_FAMILY} -mthumb', + LINKFLAGS = '-Wall -mcpu=${CPU_FAMILY} -mthumb -mhard-float -nostartfiles -Wl,-T${LINK_SCRIPT}', # -Wl,--gc-sections + + CPPPATH = [laks_dir], + LIBPATH = [ld_dir], + + LIB_SOURCES = [], + + CPU_FAMILY = family, + ) + + if family == 'cortex-m4': + env.Append(CCFLAGS = ' -mhard-float') + +def select_stm32(env, variant): + family = variant[5:9] + pin_count = variant[9] + flash = variant[10] + + if family == 'f103': + select_arm(env, 'cortex-m3') + env.Append(CPPDEFINES = ['STM32F1']) + + env['LINK_SCRIPT'] = { + '8': 'stm32_f1_8.ld', + 'b': 'stm32_f1_b.ld', + }[flash] + + elif family in ('f405', 'f407'): + select_arm(env, 'cortex-m4') + env.Append(CPPDEFINES = ['STM32F4']) + + env['LINK_SCRIPT'] = { + 'e': 'stm32_f4_e.ld', + 'g': 'stm32_f4_g.ld', + }[flash] + + else: + print 'Unknown stm32 family: %s' % mcu + Exit(1) + +def SelectMCU(env, mcu): + mcu = mcu.lower() + + if mcu.startswith('stm32'): + select_stm32(env, mcu) + + else: + print 'Unknown MCU: %s' % mcu + Exit(1) + + SConscript(main_sconscript, exports = 'env') + +AddMethod(Environment, SelectMCU) + +def Firmware(env, target, sources): + firmware = env.Program(target, [sources, env['LIB_SOURCES']]) + #env.Depends(firmware, env['LINK_SCRIPT']) # TODO + return firmware + +AddMethod(Environment, Firmware) |