mirror of
https://github.com/drasko/codezero.git
synced 2026-02-26 08:43:13 +01:00
Got the tasks linking.
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -3,3 +3,4 @@ build
|
|||||||
.sconsign.dblite
|
.sconsign.dblite
|
||||||
*.pyc
|
*.pyc
|
||||||
config.log
|
config.log
|
||||||
|
crt0.o
|
||||||
|
|||||||
43
SConstruct
43
SConstruct
@@ -169,7 +169,7 @@ else :
|
|||||||
|
|
||||||
Alias('kernel', startAxf)
|
Alias('kernel', startAxf)
|
||||||
|
|
||||||
########## Build the tasks ########################
|
########## Build the task libraries ########################
|
||||||
|
|
||||||
taskSupportLibraryEnvironment = baseEnvironment.Clone(
|
taskSupportLibraryEnvironment = baseEnvironment.Clone(
|
||||||
CC = 'arm-none-linux-gnueabi-gcc',
|
CC = 'arm-none-linux-gnueabi-gcc',
|
||||||
@@ -188,22 +188,51 @@ else :
|
|||||||
Depends(taskLibraries, taskSupportLibraryEnvironment['configFiles'])
|
Depends(taskLibraries, taskSupportLibraryEnvironment['configFiles'])
|
||||||
|
|
||||||
Alias ('tasklibs', taskLibraries)
|
Alias ('tasklibs', taskLibraries)
|
||||||
|
|
||||||
|
########## Build the tasks ########################
|
||||||
|
|
||||||
|
def buildTask(programName, sources, environment, previousImage, extraCppPath=None):
|
||||||
|
e = environment.Clone()
|
||||||
|
e.Append(LINKFLAGS=['-Ttasks/' + programName + '/include/linker.lds'])
|
||||||
|
e.Append(LIBPATH=['#build/tasks/' + programName, '#build/lib/c/userspace/crt/sys-userspace/arch-arm'])
|
||||||
|
if extraCppPath: e.Append(CPPPATH=extraCppPath)
|
||||||
|
objects = e.StaticObject(sources)
|
||||||
|
Depends(objects, e['configFiles'])
|
||||||
|
program = e.Program(programName, objects + ['#' + e['crt0'][0].name])
|
||||||
|
physicalBaseLinkerScript = Command('include/physical_base.lds', previousImage, 'tools/pyelf/readelf.py --first-free-page ' + previousImage[0].path + ' >> $TARGET')
|
||||||
|
Depends(program, [physicalBaseLinkerScript, e['crt0']])
|
||||||
|
return program
|
||||||
|
|
||||||
tasksEnvironment = baseEnvironment.Clone(
|
tasksEnvironment = baseEnvironment.Clone(
|
||||||
CC = 'arm-none-linux-gnueabi-gcc',
|
CC = 'arm-none-linux-gnueabi-gcc',
|
||||||
CCFLAGS = ['-g', '-nostdlib', '-ffreestanding', '-std=gnu99', '-Wall', '-Werror'],
|
CCFLAGS = ['-g', '-nostdlib', '-ffreestanding', '-std=gnu99', '-Wall', '-Werror'],
|
||||||
LINKFLAGS = ['-nostdlib'],
|
LINKFLAGS = ['-nostdlib'],
|
||||||
ASFLAGS = ['-D__ASSEMBLY__'],
|
ASFLAGS = ['-D__ASSEMBLY__'],
|
||||||
LIBS = taskLibraries + ['gcc', libs['userspace']],
|
LIBS = [libs['userspace']] + taskLibraries + ['gcc', libs['userspace']], #### TODO: Why have the userspace C library twice?
|
||||||
PROGSUFFIX = '.axf',
|
PROGSUFFIX = '.axf',
|
||||||
CPPDEFINES = ['__USERSPACE__'],
|
CPPDEFINES = ['__USERSPACE__'],
|
||||||
CPPPATH = ['#' + buildDirectory, '#' + buildDirectory + '/l4', '#' + includeDirectory, 'include', '#tasks/libl4/include', '#tasks/libmem', '#tasks/libposix/include'],
|
CPPPATH = ['#' + buildDirectory, '#' + buildDirectory + '/l4', '#' + includeDirectory, 'include', '#tasks/libl4/include', '#tasks/libmem', '#tasks/libposix/include'],
|
||||||
kernel = startAxf)
|
buildTask = buildTask)
|
||||||
|
|
||||||
|
####
|
||||||
|
#### TODO: Why doe the linker require crt0.o to be in the current directory and named as such. Is it
|
||||||
|
#### because of the text in the linker script?
|
||||||
|
####
|
||||||
|
|
||||||
|
userspaceRuntime = Command(crts['userspace'][0].name, crts['userspace'][0], 'ln -s $SOURCE.path $TARGET')
|
||||||
|
|
||||||
|
execfile('tasks/taskOrder.py')
|
||||||
|
imageOrderData = [(taskName, []) for taskName in taskOrder]
|
||||||
|
imageOrderData[0][1].append(startAxf)
|
||||||
tasks = []
|
tasks = []
|
||||||
for task in [f.name for f in Glob('tasks/*') if f.name not in taskLibraryNames + ['bootdesc']]:
|
for i in range(len(imageOrderData)):
|
||||||
tasks.append(SConscript('tasks/' + task + '/SConscript', variant_dir = buildDirectory + '/tasks/' + task, duplicate = 0, exports = {'environment': tasksEnvironment}))
|
taskName = imageOrderData[i][0]
|
||||||
|
dependency = imageOrderData[i][1]
|
||||||
|
program = SConscript('tasks/' + taskName + '/SConscript', variant_dir = buildDirectory + '/tasks/' + taskName, duplicate = 0, exports = {'environment': tasksEnvironment, 'previousImage': dependency[0]})
|
||||||
|
Depends(program, userspaceRuntime)
|
||||||
|
tasks.append(program)
|
||||||
|
if i < len(imageOrderData) - 1:
|
||||||
|
imageOrderData[i+1][1].append(program)
|
||||||
Depends(tasks, tasksEnvironment['configFiles'])
|
Depends(tasks, tasksEnvironment['configFiles'])
|
||||||
|
|
||||||
Alias ('tasks', tasks)
|
Alias ('tasks', tasks)
|
||||||
|
|||||||
@@ -17,16 +17,8 @@
|
|||||||
#
|
#
|
||||||
# Author: Russel Winder
|
# Author: Russel Winder
|
||||||
|
|
||||||
Import('environment')
|
Import('environment', 'previousImage')
|
||||||
|
|
||||||
e = environment.Clone()
|
program = environment['buildTask']('fs0', Glob('*.c') + [Glob(directory + '/*.c') for directory in [ 'src', 'src/lib', 'src/lib/elf', 'src/memfs']], environment, previousImage)
|
||||||
e.Append(LINKFLAGS = ['-Ttasks/fs0/include/linker.lds'])
|
|
||||||
e.Append(LIBPATH=['#build/tasks/fs0', '#build/lib/c/userspace/crt/sys-userspace/arch-arm'])
|
|
||||||
|
|
||||||
objects = e.StaticObject(Glob('*.c') + [Glob(directory + '/*.c') for directory in [ 'src', 'src/lib', 'src/memfs']])
|
|
||||||
Depends(objects, e['configFiles'])
|
|
||||||
program = e.Program('fs0', objects)
|
|
||||||
physicalBaseLinkerScript = Command('include/physical_base.lds', e['kernel'], 'tools/pyelf/readelf.py --first-free-page ' + e['kernel'][0].path + ' >> $TARGET')
|
|
||||||
Depends(program, [physicalBaseLinkerScript, e['crt0']])
|
|
||||||
|
|
||||||
Return('program')
|
Return('program')
|
||||||
|
|||||||
@@ -17,16 +17,8 @@
|
|||||||
#
|
#
|
||||||
# Author: Russel Winder
|
# Author: Russel Winder
|
||||||
|
|
||||||
Import('environment')
|
Import('environment', 'previousImage')
|
||||||
|
|
||||||
e = environment.Clone()
|
program = environment['buildTask']('mm0', Glob('*.c') + [Glob(directory + '/*.c') for directory in [ 'src', 'src/lib', 'src/lib/elf', 'src/arch-' + environment['ARCH']]], environment, previousImage)
|
||||||
e.Append(LINKFLAGS=['-Ttasks/mm0/include/linker.lds'])
|
|
||||||
e.Append(LIBPATH=['#build/tasks/mm0', '#build/lib/c/userspace/crt/sys-userspace/arch-arm'])
|
|
||||||
|
|
||||||
objects = e.StaticObject(Glob('*.c') + Glob('src/*.c') + Glob('src/lib/*.c') + Glob('src/arch/*.c'))
|
|
||||||
Depends(objects, e['configFiles'])
|
|
||||||
program = e.Program('mm0', objects)
|
|
||||||
physicalBaseLinkerScript = Command('include/physical_base.lds', e['kernel'], 'tools/pyelf/readelf.py --first-free-page ' + e['kernel'][0].path + ' >> $TARGET')
|
|
||||||
Depends(program, [physicalBaseLinkerScript, e['crt0']])
|
|
||||||
|
|
||||||
Return('program')
|
Return('program')
|
||||||
|
|||||||
22
tasks/taskOrder.py
Normal file
22
tasks/taskOrder.py
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
# -*- mode: python; coding: utf-8; -*-
|
||||||
|
|
||||||
|
# Codezero -- a microkernel for embedded systems.
|
||||||
|
#
|
||||||
|
# Copyright © 2009 B Labs Ltd
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify it under the terms of the GNU
|
||||||
|
# General Public License as published by the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
|
||||||
|
# the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
||||||
|
# License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License along with this program. If not, see
|
||||||
|
# <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
# Author: Russel Winder
|
||||||
|
|
||||||
|
# A sequence determining the order of tasks in the packing.
|
||||||
|
|
||||||
|
taskOrder = ('mm0', 'fs0', 'test0')
|
||||||
@@ -17,16 +17,8 @@
|
|||||||
#
|
#
|
||||||
# Author: Russel Winder
|
# Author: Russel Winder
|
||||||
|
|
||||||
Import('environment')
|
Import('environment', 'previousImage')
|
||||||
|
|
||||||
e = environment.Clone()
|
program = environment['buildTask']('test0', Glob('*.c') + Glob('src/*.c'), environment, previousImage, ['#tasks/libposix/include/posix'])
|
||||||
e.Append(LINKFLAGS = ['-Ttasks/test0/include/linker.lds'])
|
|
||||||
e.Append(LIBPATH=['#build/tasks/test0', '#build/lib/c/userspace/crt/sys-userspace/arch-arm'])
|
|
||||||
|
|
||||||
objects = e.StaticObject(Glob('*.c') + Glob('src/*.c'))
|
|
||||||
Depends(objects, e['configFiles'])
|
|
||||||
program = e.Program('test0', objects)
|
|
||||||
physicalBaseLinkerScript = Command('include/physical_base.lds', e['kernel'], 'tools/pyelf/readelf.py --first-free-page ' + e['kernel'][0].path + ' >> $TARGET')
|
|
||||||
Depends(program, [physicalBaseLinkerScript, e['crt0']])
|
|
||||||
|
|
||||||
Return('program')
|
Return('program')
|
||||||
|
|||||||
Reference in New Issue
Block a user