diff --git a/SConstruct b/SConstruct index 06c6d2f..e780cbf 100644 --- a/SConstruct +++ b/SConstruct @@ -71,7 +71,8 @@ else : configItems[item[0].strip ( )] = ( item[1].strip ( ) == 'y' ) return configItems - baseEnvironment = Environment ( tools = [ 'gnulink' , 'gcc' , 'gas' , 'ar' ] ) + baseEnvironment = Environment ( tools = [ 'gnulink' , 'gcc' , 'gas' , 'ar' ] , + configFiles = ( '#' + cml2CompileRulesFile , '#' + cml2ConfigPropertiesFile , '#' + cml2ConfigHeaderFile ) ) kernelSConscriptPaths = [ 'generic' , 'api' , 'lib' ] @@ -109,7 +110,7 @@ else : baseEnvironment = configuration.Finish ( ) libraryEnvironment = baseEnvironment.Clone ( - CC = 'arm-none-linux-gnueabi-gcc', + CC = 'arm-none-linux-gnueabi-gcc' , CCFLAGS = [ '-g' , '-nostdinc' , '-nostdlib' , '-ffreestanding' ] , LINKFLAGS = [ '-nostdlib' ] , ENV = { 'PATH' : os.environ['PATH'] } , @@ -120,9 +121,10 @@ else : libs = { } crts = { } for variant in [ 'baremetal' , 'userspace' ] : - ( libs[variant] , crts[variant] ) = SConscript ( 'libs/c/SConscript' , variant_dir = buildDirectory + '/lib/c/' + variant , duplicate = 0 , exports = { 'environment' : libraryEnvironment , 'variant' : variant } ) + ( libs[variant] , crts[variant] ) = SConscript ( 'libs/c/SConscript' , variant_dir = buildDirectory + '/' + arch + '/lib/c/' + variant , duplicate = 0 , exports = { 'environment' : libraryEnvironment , 'variant' : variant } ) + Depends ( ( libs[variant] , crts[variant] ) , ( cml2CompileRulesFile , cml2ConfigPropertiesFile , cml2ConfigHeaderFile ) ) - libelf = SConscript ( 'libs/elf/SConscript' , variant_dir = buildDirectory + '/lib/elf' , duplicate = 0 , exports = { 'environment' : libraryEnvironment } ) + libelf = SConscript ( 'libs/elf/SConscript' , variant_dir = buildDirectory + '/' + arch + '/lib/elf' , duplicate = 0 , exports = { 'environment' : libraryEnvironment } ) kernelEnvironment = baseEnvironment.Clone ( CC = 'arm-none-eabi-gcc' , @@ -139,7 +141,7 @@ else : kernelComponents = [ ] for scriptPath in [ 'src/' + path for path in kernelSConscriptPaths ] : - kernelComponents.append ( SConscript ( scriptPath + '/SConscript' , variant_dir = buildDirectory + '/' + scriptPath , duplicate = 0 , exports = { 'environment' : kernelEnvironment } ) ) + kernelComponents.append ( SConscript ( scriptPath + '/SConscript' , variant_dir = buildDirectory + '/' + arch + '/' + scriptPath , duplicate = 0 , exports = { 'environment' : kernelEnvironment } ) ) startAxf = kernelEnvironment.Program ( buildDirectory + '/start.axf' , kernelComponents ) @@ -153,7 +155,7 @@ else : tasks = [ ] for task in [ item for item in os.listdir ( 'tasks' ) if os.path.isdir ( 'tasks/' + item ) and os.path.exists ( 'tasks/' + item + '/SConscript' )] : - tasks.append ( SConscript ( 'tasks/' + task + '/SConscript' , variant_dir = buildDirectory + '/tasks/' + task , duplicate = 0 , exports = { 'environment' : tasksEnvironment } ) ) + tasks.append ( SConscript ( 'tasks/' + task + '/SConscript' , variant_dir = buildDirectory + '/' + arch + '/tasks/' + task , duplicate = 0 , exports = { 'environment' : tasksEnvironment } ) ) Default ( crts.values ( ) + libs.values ( ) + [ libelf , startAxf ] + tasks ) diff --git a/libs/c/SConscript b/libs/c/SConscript index 03c7b20..68fea00 100644 --- a/libs/c/SConscript +++ b/libs/c/SConscript @@ -27,9 +27,15 @@ source = \ Glob ( 'src/arch-' + environment['ARCH'] + '/*.c' ) + \ Glob ( 'src/arch-' + environment['ARCH'] + '/*.S' ) +e = environment.Clone ( ) +e.Append ( CPPPATH = [ 'include' , 'include/sys-' + variant + '/arch-' + environment['ARCH'] ] ) + +objects = e.StaticObject ( source ) +Depends ( objects , e['configFiles'] ) + result = ( - environment.StaticLibrary ( 'c-' + variant , source , CPPPATH = [ 'include' , 'include/sys-' + variant + '/arch-' + environment['ARCH'] ] ) , - environment.StaticObject ( 'crt/sys-' + variant + '/arch-' + environment['ARCH'] + '/crt0.S' ) + e.StaticLibrary ( 'c-' + variant , objects ) , + e.StaticObject ( 'crt/sys-' + variant + '/arch-' + e['ARCH'] + '/crt0.S' ) ) Return ( 'result' ) diff --git a/libs/elf/SConscript b/libs/elf/SConscript index e241bef..eef6426 100644 --- a/libs/elf/SConscript +++ b/libs/elf/SConscript @@ -22,6 +22,9 @@ Import ( 'environment' ) e = environment.Clone ( ) e.Append ( CPPPATH = [ 'include' , '#libs/c/include' , '#libs/c/include/arch/' + e['ARCH'] ] ) -result = e.StaticLibrary ( 'elf' , Glob ( 'src/*.c' ) ) +objects = e.StaticObject ( Glob ( 'src/*.c' ) ) +Depends ( objects , e['configFiles'] ) + +result = e.StaticLibrary ( 'elf' , objects ) Return ( 'result' )