X-Git-Url: http://git.code-monkey.de/?p=gps-watch.git;a=blobdiff_plain;f=SConscript.target;h=539db881882e4ba961f3a18a7b20b9c005d28f61;hp=b42eecef5f6166c51d73698c4abfe52e89e679db;hb=3d88ea26c53e1bc22caf250b8d7d8998c186e19a;hpb=cab249f22d64f9faefac6baebb700d12a111de2f diff --git a/SConscript.target b/SConscript.target index b42eece..539db88 100644 --- a/SConscript.target +++ b/SConscript.target @@ -1,3 +1,4 @@ +import subprocess import os Import('env') @@ -33,80 +34,74 @@ env.Append(LINKFLAGS = [ '-nostartfiles', ]) +libgcc_path = \ + subprocess.check_output('{} -print-libgcc-file-name'.format(env['CC']), + shell=True).strip().decode('utf-8') + env.Append(RUSTCFLAGS = [ '-C', 'opt-level=s', + '-C', 'link-arg={}'.format(libgcc_path), '--target=thumbv6m-none-eabi', '-L', '$LIBPATH', + '-l', 'common', ]) env.Append(LINKFLAGS = [ '-Wl,--gc-sections' ]) -SConscript('SConscript.libcommon', exports='env', duplicate=0) +SConscript('SConscript.libcommon.c', exports='env', duplicate=0) +SConscript('SConscript.libcommon.rs', exports='env', duplicate=0) -libbootloader_source_files = [ +bootloader_source_files = [ 'src/bootloader/main.rs', # Must be listed first (see below). 'src/bootloader/bootloader.rs', 'src/bootloader/flash.rs', ] -start_o = env.Object('src/bootloader/start.c') - for s in ['intermediate', 'final']: - libbootloader_env = env.Clone() + bootloader_env = env.Clone() - libbootloader_env.Append(RUSTCFLAGS = [ + bootloader_env.Append(RUSTCFLAGS = [ + '-C', 'link-arg=-Tsrc/bootloader/bootloader-{}.ld'.format(s), '--cfg', 'bootloader_type=\\"{}\\"'.format(s) ]) - libbootloader = libbootloader_env.Rustc('libbootloader-{}.a'.format(s), - libbootloader_source_files[0]) - - for f in libbootloader_source_files: - Depends(libbootloader, f) - - Depends(libbootloader, 'libcommon.rlib') - Depends(libbootloader, 'libcommon.a') - - bootloader_env = env.Clone() + bootloader_elf = \ + bootloader_env.Rustc('gps-watch-bootloader-{}.elf'.format(s), + bootloader_source_files[0]) - bootloader_env.Append(LINKFLAGS = [ - '-Tsrc/bootloader/bootloader-{}.ld'.format(s), - ]) + for f in bootloader_source_files: + Depends(bootloader_elf, f) - bootloader_elf = \ - bootloader_env.Program('gps-watch-bootloader-{}.elf'.format(s), - start_o, LIBS = ['bootloader-{}'.format(s), 'common']) + Depends(bootloader_elf, 'libcommon.rlib') + Depends(bootloader_elf, 'libcommon.a') bootloader_bin = bootloader_env.Objcopy(bootloader_elf) Default(bootloader_bin) -libapplication_source_files = [ +application_source_files = [ 'src/application/main.rs', # Must be listed first (see below). + 'src/application/button.rs', + 'src/application/uart0.rs', ] -libapplication = env.Rustc('libapplication.a', libapplication_source_files[0]) - -for f in libapplication_source_files: - Depends(libapplication, f) - -Depends(libapplication, 'libcommon.rlib') -Depends(libapplication, 'libcommon.a') - -start_o = env.Object('src/application/start.c') - application_env = env.Clone() -application_env.Append(LINKFLAGS = [ - '-Tsrc/application/application.ld' +application_env.Append(RUSTCFLAGS = [ + '-C', 'link-arg=-Tsrc/application/application.ld', ]) -application_elf = application_env.Program('gps-watch-application.elf', - start_o, - LIBS = ['application', 'common']) +application_elf = application_env.Rustc('gps-watch-application.elf', + application_source_files[0]) + +for f in application_source_files: + Depends(application_elf, f) + +Depends(application_elf, 'libcommon.rlib') +Depends(application_elf, 'libcommon.a') application_bin = application_env.Objcopy(application_elf)