mirror of
https://github.com/genodelabs/genode.git
synced 2025-02-12 14:05:25 +00:00
Merge base libraries into a single library
This patch simplifies the way of how Genode's base libraries are organized. Originally, the base API was implemented in the form of many small libraries such as 'thread', 'env', 'server', etc. Most of them used to consist of only a small number of files. Because those libraries are incorporated in any build, the checking of their inter-dependencies made the build process more verbose than desired. Also, the number of libraries and their roles (core only, non-core only, shared by both core and non-core) were not easy to capture. Hereby, the base libraries have been reduced to the following few libraries: - startup.mk contains the startup code for normal Genode processes. On some platform, core is able to use the library as well. - base-common.mk contains the parts of the base library that are identical by core and non-core processes. - base.mk contains the complete base API implementation for non-core processes Consequently, the 'LIBS' declaration in 'target.mk' files becomes simpler as well. In the most simple case, only the 'base' library must be mentioned. Fixes #18
This commit is contained in:
parent
4c3d49459b
commit
fae63f4fa9
@ -1,9 +0,0 @@
|
||||
LIBS = cxx lock l4
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
INC_DIR += $(REP_DIR)/src/platform
|
||||
INC_DIR += $(BASE_DIR)/src/platform
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
vpath crt0.s $(BASE_DIR)/src/platform/arm
|
||||
vpath _main.cc $(dir $(call select_from_repositories,src/platform/_main.cc))
|
32
base-codezero/lib/mk/base-common.mk
Normal file
32
base-codezero/lib/mk/base-common.mk
Normal file
@ -0,0 +1,32 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += cxx l4 startup
|
||||
|
||||
SRC_CC += cap_copy.cc
|
||||
SRC_CC += ipc/ipc.cc ipc/pager.cc ipc/ipc_marshal_cap.cc
|
||||
SRC_CC += pager/pager.cc
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc server/common.cc
|
||||
SRC_CC += thread/thread.cc thread/thread_bootstrap_empty.cc
|
||||
SRC_CC += env/utcb.cc
|
||||
SRC_CC += lock/cmpxchg.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
vpath cap_copy.cc $(BASE_DIR)/src/platform
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
||||
vpath %.cc $(REP_DIR)/src/base
|
12
base-codezero/lib/mk/base.mk
Normal file
12
base-codezero/lib/mk/base.mk
Normal file
@ -0,0 +1,12 @@
|
||||
SRC_CC += console/log_console.cc
|
||||
SRC_CC += env/env.cc env/context_area.cc env/reload_parent_cap.cc
|
||||
SRC_CC += thread/thread_start.cc
|
||||
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
LIBS += base-common
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
||||
|
@ -1,13 +0,0 @@
|
||||
#
|
||||
# Additional symbols we need to keep when using the arm-none-linux-gnueabi
|
||||
# tool chain
|
||||
#
|
||||
KEEP_SYMBOLS += __aeabi_ldivmod __aeabi_uldivmod __dynamic_cast
|
||||
KEEP_SYMBOLS += _ZN10__cxxabiv121__vmi_class_type_infoD0Ev
|
||||
|
||||
#
|
||||
# Override sources of the base repository with our changed version
|
||||
#
|
||||
vpath exception.cc $(REP_DIR)/src/base/cxx
|
||||
|
||||
include $(BASE_DIR)/lib/mk/cxx.mk
|
@ -1,6 +0,0 @@
|
||||
include $(BASE_DIR)/lib/mk/env.mk
|
||||
|
||||
SRC_CC += utcb.cc
|
||||
|
||||
vpath utcb.cc $(REP_DIR)/src/base/env
|
||||
vpath env.cc $(BASE_DIR)/src/base/env
|
@ -1,6 +0,0 @@
|
||||
SRC_CC = ipc.cc pager.cc ipc_marshal_cap.cc
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
LIBS = cap_copy
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base/ipc
|
||||
vpath ipc_marshal_cap.cc $(BASE_DIR)/src/base/ipc
|
@ -1,7 +0,0 @@
|
||||
SRC_CC = lock.cc cmpxchg.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
|
||||
vpath lock.cc $(BASE_DIR)/src/base/lock
|
||||
vpath cmpxchg.cc $(REP_DIR)/src/base/lock
|
@ -1,4 +0,0 @@
|
||||
SRC_CC = pager.cc
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
vpath pager.cc $(REP_DIR)/src/base/pager
|
@ -1,5 +1,4 @@
|
||||
SRC_CC = core_printf.cc
|
||||
LIBS = cxx console
|
||||
INC_DIR += $(REP_DIR)/src/base/console/pl011
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
|
5
base-codezero/lib/mk/startup.mk
Normal file
5
base-codezero/lib/mk/startup.mk
Normal file
@ -0,0 +1,5 @@
|
||||
include $(BASE_DIR)/lib/mk/startup.inc
|
||||
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
vpath crt0.s $(BASE_DIR)/src/platform/arm
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = thread.cc thread_start.cc thread_bootstrap.cc
|
||||
INC_DIR += $(REP_DIR)/include/codezero/dummies
|
||||
|
||||
vpath thread_start.cc $(REP_DIR)/src/base/thread
|
||||
vpath %.cc $(BASE_DIR)/src/base/thread
|
@ -34,11 +34,6 @@ INC_DIR += $(CODEZERO_ABS_DIR)/include
|
||||
INC_DIR += $(CODEZERO_ABS_DIR)/conts/userlibs/libl4/include
|
||||
INC_DIR += $(CODEZERO_ABS_DIR)/conts/userlibs/libdev/uart/include
|
||||
|
||||
#
|
||||
# Codezero-specific startup code
|
||||
#
|
||||
PRG_LIBS += startup
|
||||
|
||||
#
|
||||
# Allow programs to test for the Codezero kernel
|
||||
#
|
||||
|
@ -1,10 +1,8 @@
|
||||
TARGET = core
|
||||
LIBS = cxx ipc heap core_printf child pager lock \
|
||||
raw_signal raw_server
|
||||
|
||||
GEN_CORE_DIR = $(BASE_DIR)/src/core
|
||||
|
||||
SRC_CC = \
|
||||
SRC_CC += \
|
||||
main.cc \
|
||||
ram_session_component.cc \
|
||||
ram_session_support.cc \
|
||||
@ -14,9 +12,7 @@ SRC_CC = \
|
||||
pd_session_component.cc \
|
||||
io_mem_session_component.cc \
|
||||
io_mem_session_support.cc \
|
||||
thread.cc \
|
||||
thread_start.cc \
|
||||
thread_bootstrap.cc \
|
||||
platform_thread.cc \
|
||||
platform_pd.cc \
|
||||
platform_services.cc \
|
||||
@ -30,10 +26,11 @@ SRC_CC = \
|
||||
core_rm_session.cc \
|
||||
core_mem_alloc.cc \
|
||||
dump_alloc.cc \
|
||||
context_area.cc \
|
||||
utcb.cc
|
||||
context_area.cc
|
||||
|
||||
INC_DIR = $(REP_DIR)/src/core/include \
|
||||
LIBS += core_printf base-common
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/core/include \
|
||||
$(GEN_CORE_DIR)/include \
|
||||
$(REP_DIR)/include/codezero/dummies
|
||||
|
||||
@ -53,6 +50,3 @@ vpath core_mem_alloc.cc $(GEN_CORE_DIR)
|
||||
vpath dump_alloc.cc $(GEN_CORE_DIR)
|
||||
vpath context_area.cc $(GEN_CORE_DIR)
|
||||
vpath %.cc $(REP_DIR)/src/core
|
||||
vpath thread_bootstrap.cc $(BASE_DIR)/src/base/thread
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath utcb.cc $(REP_DIR)/src/base/env
|
||||
|
6
base-fiasco/lib/mk/arm/platform.mk
Normal file
6
base-fiasco/lib/mk/arm/platform.mk
Normal file
@ -0,0 +1,6 @@
|
||||
#
|
||||
# Configuration for L4 build system (for kernel-bindings, sigma0, bootstrap).
|
||||
#
|
||||
L4_CONFIG = $(REP_DIR)/config/l4env-config.x86
|
||||
|
||||
include $(REP_DIR)/lib/mk/platform.inc
|
@ -1,8 +0,0 @@
|
||||
REQUIRES = fiasco arm
|
||||
LIBS = cxx lock
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
INC_DIR += $(REP_DIR)/src/platform
|
||||
|
||||
vpath crt0.s $(REP_DIR)/src/platform/arm
|
||||
vpath _main.cc $(dir $(call select_from_repositories,src/platform/_main.cc))
|
29
base-fiasco/lib/mk/base-common.mk
Normal file
29
base-fiasco/lib/mk/base-common.mk
Normal file
@ -0,0 +1,29 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += cxx startup
|
||||
|
||||
SRC_CC += cap_copy.cc
|
||||
SRC_CC += ipc/ipc.cc ipc/pager.cc ipc/ipc_marshal_cap.cc
|
||||
SRC_CC += pager/pager.cc
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc server/common.cc
|
||||
SRC_CC += thread/thread.cc thread/thread_bootstrap_empty.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
|
||||
vpath cap_copy.cc $(BASE_DIR)/src/platform
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
16
base-fiasco/lib/mk/base.mk
Normal file
16
base-fiasco/lib/mk/base.mk
Normal file
@ -0,0 +1,16 @@
|
||||
#
|
||||
# \brief Portions of base library that are exclusive to non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += base-common
|
||||
|
||||
SRC_CC += console/log_console.cc
|
||||
SRC_CC += env/env.cc env/context_area.cc env/reload_parent_cap.cc
|
||||
SRC_CC += thread/thread_start.cc
|
||||
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = core_printf.cc
|
||||
LIBS = cxx console
|
||||
INC_DIR += $(REP_DIR)/src/base/console
|
||||
|
||||
vpath core_printf.cc $(BASE_DIR)/src/base/console
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = ipc.cc pager.cc ipc_marshal_cap.cc
|
||||
LIBS = cap_copy
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base/ipc
|
||||
vpath ipc_marshal_cap.cc $(BASE_DIR)/src/base/ipc
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = lock.cc
|
||||
|
||||
vpath lock.cc $(REP_DIR)/src/base/lock
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = pager.cc
|
||||
|
||||
vpath pager.cc $(REP_DIR)/src/base/pager
|
@ -1,8 +0,0 @@
|
||||
REQUIRES = fiasco x86
|
||||
LIBS = cxx lock
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
INC_DIR += $(BASE_DIR)/src/platform $(REP_DIR)/src/platform
|
||||
|
||||
vpath crt0.s $(dir $(call select_from_repositories,src/platform/x86_32/crt0.s))
|
||||
vpath _main.cc $(dir $(call select_from_repositories,src/platform/_main.cc))
|
@ -13,19 +13,12 @@
|
||||
L4_BUILD_DIR ?= $(BUILD_BASE_DIR)/l4
|
||||
L4_SRC_DIR ?= $(REP_DIR)/contrib/fiasco/snapshot
|
||||
|
||||
|
||||
#
|
||||
# L4/sys headers
|
||||
#
|
||||
L4_INC_DIR += $(L4_BUILD_DIR)/include \
|
||||
$(L4_BUILD_DIR)/include/l4v2
|
||||
|
||||
#
|
||||
# Startup code to be used when building a program
|
||||
#
|
||||
STARTUP_LIB ?= startup
|
||||
PRG_LIBS += $(STARTUP_LIB)
|
||||
|
||||
clean_contrib:
|
||||
$(VERBOSE)rm -rf $(BUILD_BASE_DIR)/l4
|
||||
|
||||
|
@ -1,10 +1,8 @@
|
||||
TARGET = core
|
||||
REQUIRES = fiasco
|
||||
LIBS = cxx ipc heap core_printf child pager lock raw_signal raw_server
|
||||
|
||||
GEN_CORE_DIR = $(BASE_DIR)/src/core
|
||||
|
||||
SRC_CC = main.cc \
|
||||
SRC_CC += main.cc \
|
||||
multiboot_info.cc \
|
||||
ram_session_component.cc \
|
||||
ram_session_support.cc \
|
||||
@ -14,9 +12,7 @@ SRC_CC = main.cc \
|
||||
pd_session_component.cc \
|
||||
io_mem_session_component.cc \
|
||||
io_mem_session_support.cc \
|
||||
thread.cc \
|
||||
thread_start.cc \
|
||||
thread_bootstrap.cc \
|
||||
platform_thread.cc \
|
||||
platform_pd.cc \
|
||||
platform_services.cc \
|
||||
@ -29,10 +25,14 @@ SRC_CC = main.cc \
|
||||
signal_session_component.cc \
|
||||
signal_source_component.cc \
|
||||
dump_alloc.cc \
|
||||
context_area.cc
|
||||
context_area.cc \
|
||||
core_printf.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/core/include \
|
||||
$(GEN_CORE_DIR)/include
|
||||
$(GEN_CORE_DIR)/include \
|
||||
$(REP_DIR)/src/base/console
|
||||
|
||||
LIBS += base-common
|
||||
|
||||
vpath main.cc $(GEN_CORE_DIR)
|
||||
vpath multiboot_info.cc $(GEN_CORE_DIR)
|
||||
@ -48,6 +48,5 @@ vpath signal_source_component.cc $(GEN_CORE_DIR)
|
||||
vpath dataspace_component.cc $(GEN_CORE_DIR)
|
||||
vpath dump_alloc.cc $(GEN_CORE_DIR)
|
||||
vpath context_area.cc $(GEN_CORE_DIR)
|
||||
vpath thread_bootstrap.cc $(BASE_DIR)/src/base/thread
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath core_printf.cc $(BASE_DIR)/src/base/console
|
||||
vpath %.cc $(REP_DIR)/src/core
|
||||
|
3
base-foc/lib/mk/arm/base-common.mk
Normal file
3
base-foc/lib/mk/arm/base-common.mk
Normal file
@ -0,0 +1,3 @@
|
||||
include $(REP_DIR)/lib/mk/base-common.inc
|
||||
|
||||
SRC_CC += ipc/arm/pager.cc ipc/arm/pager_exception.cc
|
@ -1,4 +0,0 @@
|
||||
SRC_CC = arm/pager_exception.cc arm/pager.cc
|
||||
|
||||
include $(REP_DIR)/lib/mk/ipc.inc
|
||||
|
@ -1,8 +0,0 @@
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
LIBS += cxx lock
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/platform $(BASE_DIR)/src/platform
|
||||
|
||||
vpath crt0.s $(BASE_DIR)/src/platform/arm
|
||||
vpath _main.cc $(BASE_DIR)/src/platform
|
28
base-foc/lib/mk/base-common.inc
Normal file
28
base-foc/lib/mk/base-common.inc
Normal file
@ -0,0 +1,28 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += cxx syscall startup
|
||||
|
||||
SRC_CC += ipc/ipc.cc ipc/pager.cc
|
||||
SRC_CC += pager/pager.cc
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += env/spin_lock.cc env/cap_map.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc server/common.cc
|
||||
SRC_CC += thread/thread.cc thread/thread_bootstrap.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock $(BASE_DIR)/src/base/lock
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
17
base-foc/lib/mk/base.mk
Normal file
17
base-foc/lib/mk/base.mk
Normal file
@ -0,0 +1,17 @@
|
||||
#
|
||||
# \brief Portions of base library that are exclusive to non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += base-common
|
||||
|
||||
SRC_CC += console/log_console.cc
|
||||
SRC_CC += env/env.cc env/context_area.cc env/reload_parent_cap.cc \
|
||||
env/cap_map_remove.cc env/cap_alloc.cc
|
||||
SRC_CC += thread/thread_start.cc
|
||||
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = core_printf.cc
|
||||
LIBS = cxx console
|
||||
INC_DIR += $(REP_DIR)/src/base/console
|
||||
|
||||
vpath core_printf.cc $(BASE_DIR)/src/base/console
|
@ -1,13 +0,0 @@
|
||||
SRC_CC = env.cc context_area.cc cap_map.cc cap_alloc.cc \
|
||||
reload_parent_cap.cc spin_lock.cc cap_map_remove.cc
|
||||
LIBS = ipc heap log_console lock
|
||||
INC_DIR += $(REP_DIR)/src/base/lock $(BASE_DIR)/src/base/lock
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
|
||||
vpath env.cc $(BASE_DIR)/src/base/env
|
||||
vpath context_area.cc $(BASE_DIR)/src/base/env
|
||||
vpath cap_map.cc $(REP_DIR)/src/base/env
|
||||
vpath cap_map_remove.cc $(REP_DIR)/src/base/env
|
||||
vpath cap_alloc.cc $(REP_DIR)/src/base/env
|
||||
vpath spin_lock.cc $(REP_DIR)/src/base/env
|
||||
vpath reload_parent_cap.cc $(BASE_DIR)/src/base/env
|
@ -1,5 +0,0 @@
|
||||
LIBS = syscalls
|
||||
SRC_CC += ipc.cc pager.cc
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base/ipc
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = lock.cc
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
#INC_DIR += $(REP_DIR)/src/platform
|
||||
|
||||
vpath lock.cc $(BASE_DIR)/src/base/lock
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = pager.cc
|
||||
|
||||
vpath pager.cc $(REP_DIR)/src/base/pager
|
@ -1,4 +0,0 @@
|
||||
SRC_CC = server.cc common.cc
|
||||
|
||||
vpath server.cc $(REP_DIR)/src/base/server
|
||||
vpath common.cc $(BASE_DIR)/src/base/server
|
@ -1,3 +0,0 @@
|
||||
LIBS = thread
|
||||
|
||||
include $(REP_DIR)/lib/mk/raw_server.mk
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = thread.cc thread_start.cc thread_bootstrap.cc
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base/thread
|
3
base-foc/lib/mk/x86_32/base-common.mk
Normal file
3
base-foc/lib/mk/x86_32/base-common.mk
Normal file
@ -0,0 +1,3 @@
|
||||
include $(REP_DIR)/lib/mk/base-common.inc
|
||||
|
||||
SRC_CC += ipc/x86_32/pager.cc ipc/x86/pager_exception.cc
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = x86/pager_exception.cc x86_32/pager.cc
|
||||
|
||||
include $(REP_DIR)/lib/mk/ipc.inc
|
@ -1,8 +0,0 @@
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
LIBS += cxx lock
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/platform $(BASE_DIR)/src/platform
|
||||
|
||||
vpath crt0.s $(BASE_DIR)/src/platform/x86_32
|
||||
vpath _main.cc $(BASE_DIR)/src/platform
|
3
base-foc/lib/mk/x86_64/base-common.mk
Normal file
3
base-foc/lib/mk/x86_64/base-common.mk
Normal file
@ -0,0 +1,3 @@
|
||||
include $(REP_DIR)/lib/mk/base-common.inc
|
||||
|
||||
SRC_CC += ipc/x86_64/pager.cc ipc/x86/pager_exception.cc
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = x86/pager_exception.cc x86_64/pager.cc
|
||||
|
||||
include $(REP_DIR)/lib/mk/ipc.inc
|
@ -1,8 +0,0 @@
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
LIBS += cxx lock
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/platform $(BASE_DIR)/src/platform
|
||||
|
||||
vpath crt0.s $(BASE_DIR)/src/platform/x86_64
|
||||
vpath _main.cc $(BASE_DIR)/src/platform
|
@ -30,12 +30,6 @@ CC_OPT += -fPIC
|
||||
#
|
||||
CC_OPT += -DL4SYS_USE_UTCB_WRAP=1
|
||||
|
||||
#
|
||||
# Startup code to be used when building a program
|
||||
#
|
||||
STARTUP_LIB ?= startup
|
||||
PRG_LIBS += $(STARTUP_LIB)
|
||||
|
||||
all:
|
||||
|
||||
#
|
||||
|
@ -1,13 +1,13 @@
|
||||
TARGET = core
|
||||
REQUIRES = foc
|
||||
LIBS = cxx ipc heap core_printf child pager lock raw_signal raw_server
|
||||
|
||||
LD_TEXT_ADDR = 0x500000
|
||||
|
||||
GEN_CORE_DIR = $(BASE_DIR)/src/core
|
||||
|
||||
SRC_CC = cap_map.cc \
|
||||
cap_session_component.cc \
|
||||
LIBS += base-common
|
||||
|
||||
SRC_CC = cap_session_component.cc \
|
||||
context_area.cc \
|
||||
cpu_session_component.cc \
|
||||
cpu_session_extension.cc \
|
||||
@ -31,15 +31,14 @@ SRC_CC = cap_map.cc \
|
||||
rom_session_component.cc \
|
||||
signal_session_component.cc \
|
||||
signal_source_component.cc \
|
||||
spin_lock.cc \
|
||||
thread.cc \
|
||||
thread_bootstrap.cc \
|
||||
thread_start.cc
|
||||
thread_start.cc \
|
||||
core_printf.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/core/include \
|
||||
$(GEN_CORE_DIR)/include \
|
||||
$(REP_DIR)/src/base/lock \
|
||||
$(BASE_DIR)/src/base/lock
|
||||
$(BASE_DIR)/src/base/lock \
|
||||
$(REP_DIR)/src/base/console
|
||||
|
||||
vpath context_area.cc $(GEN_CORE_DIR)
|
||||
vpath cpu_session_component.cc $(GEN_CORE_DIR)
|
||||
@ -54,8 +53,5 @@ vpath ram_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath rm_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath rom_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath signal_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath cap_map.cc $(REP_DIR)/src/base/env
|
||||
vpath spin_lock.cc $(REP_DIR)/src/base/env
|
||||
vpath thread.cc $(REP_DIR)/src/base/thread
|
||||
vpath thread_bootstrap.cc $(REP_DIR)/src/base/thread
|
||||
vpath core_printf.cc $(BASE_DIR)/src/base/console
|
||||
vpath %.cc $(REP_DIR)/src/core
|
||||
|
@ -1,10 +1,11 @@
|
||||
include $(PRG_DIR)/../target.inc
|
||||
|
||||
REQUIRES += x86
|
||||
|
||||
SRC_CC += io_port_session_component.cc \
|
||||
x86/platform_x86.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/core/include/x86
|
||||
|
||||
vpath io_port_session_component.cc $(GEN_CORE_DIR)/x86
|
||||
vpath platform_services.cc $(GEN_CORE_DIR)/x86
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
REQUIRES = foc
|
||||
TARGET = test-cap_integrity
|
||||
SRC_CC = main.cc
|
||||
LIBS = env
|
||||
LIBS = base
|
||||
|
31
base-host/lib/mk/base-common.mk
Normal file
31
base-host/lib/mk/base-common.mk
Normal file
@ -0,0 +1,31 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += cxx
|
||||
|
||||
SRC_CC += cap_copy.cc
|
||||
SRC_CC += ipc/ipc.cc ipc/ipc_marshal_cap.cc
|
||||
SRC_CC += pager/pager.cc
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc server/common.cc
|
||||
SRC_CC += thread/thread.cc thread/thread_bootstrap_empty.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
INC_DIR += $(BASE_DIR)/src/platform $(REP_DIR)/src/platform
|
||||
|
||||
vpath cap_copy.cc $(BASE_DIR)/src/platform
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
|
@ -1 +0,0 @@
|
||||
LIBS = printf_stdio console
|
4
base-host/lib/mk/cxx.mk
Normal file
4
base-host/lib/mk/cxx.mk
Normal file
@ -0,0 +1,4 @@
|
||||
SRC_CC += new_delete.cc
|
||||
|
||||
vpath %.cc $(BASE_DIR)/src/base/cxx
|
||||
|
@ -1,7 +0,0 @@
|
||||
SRC_CC = env.cc parent.cc context_area.cc
|
||||
LIBS = ipc heap lock log_console
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
|
||||
vpath env.cc $(BASE_DIR)/src/base/env
|
||||
vpath context_area.cc $(BASE_DIR)/src/base/env
|
||||
vpath parent.cc $(REP_DIR)/src/base/env
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = ipc.cc ipc_marshal_cap.cc
|
||||
LIBS = cap_copy
|
||||
|
||||
vpath ipc.cc $(REP_DIR)/src/base/ipc
|
||||
vpath ipc_marshal_cap.cc $(BASE_DIR)/src/base/ipc
|
@ -1,4 +0,0 @@
|
||||
SRC_CC = lock.cc
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
|
||||
vpath lock.cc $(BASE_DIR)/src/base/lock
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = pager.cc
|
||||
|
||||
vpath pager.cc $(REP_DIR)/src/base/pager
|
@ -1,3 +0,0 @@
|
||||
SRC_CC = printf_stdio.cc
|
||||
|
||||
vpath printf_stdio.cc $(REP_DIR)/src/lib/printf_stdio
|
@ -1,6 +1,5 @@
|
||||
TARGET = core
|
||||
LIBS = cxx ipc heap core_printf child pager lock \
|
||||
raw_signal raw_server
|
||||
LIBS = base-common
|
||||
|
||||
GEN_CORE_DIR = $(BASE_DIR)/src/core
|
||||
|
||||
@ -14,9 +13,7 @@ SRC_CC = \
|
||||
pd_session_component.cc \
|
||||
io_mem_session_component.cc \
|
||||
io_mem_session_support.cc \
|
||||
thread.cc \
|
||||
thread_host.cc \
|
||||
thread_bootstrap.cc \
|
||||
platform_thread.cc \
|
||||
platform_pd.cc \
|
||||
platform.cc \
|
||||
@ -28,7 +25,8 @@ SRC_CC = \
|
||||
signal_session_component.cc \
|
||||
signal_source_component.cc \
|
||||
core_rm_session.cc \
|
||||
context_area.cc
|
||||
context_area.cc \
|
||||
printf_stdio.cc
|
||||
|
||||
INC_DIR = $(REP_DIR)/src/core/include \
|
||||
$(GEN_CORE_DIR)/include
|
||||
@ -45,7 +43,6 @@ vpath signal_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath signal_source_component.cc $(GEN_CORE_DIR)
|
||||
vpath dataspace_component.cc $(GEN_CORE_DIR)
|
||||
vpath platform_services.cc $(GEN_CORE_DIR)
|
||||
vpath printf_stdio.cc $(REP_DIR)/src/lib/printf_stdio
|
||||
vpath %.cc $(REP_DIR)/src/core
|
||||
vpath thread_bootstrap.cc $(BASE_DIR)/src/base/thread
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
|
||||
|
@ -1,22 +0,0 @@
|
||||
#
|
||||
# \brief Essential platform specific sources for common programs
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# add libraries
|
||||
LIBS += cxx lock
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += _main.cc
|
||||
|
||||
# add assembly sources
|
||||
SRC_S += crt0.s syscall.cc
|
||||
|
||||
# add include paths
|
||||
INC_DIR += $(REP_DIR)/src/platform $(BASE_DIR)/src/platform
|
||||
|
||||
# declare source paths
|
||||
vpath crt0.s $(REP_DIR)/src/platform
|
||||
vpath _main.cc $(BASE_DIR)/src/platform
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
26
base-hw/lib/mk/base-common.mk
Normal file
26
base-hw/lib/mk/base-common.mk
Normal file
@ -0,0 +1,26 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += cxx syscall
|
||||
|
||||
SRC_CC += ipc.cc ipc/ipc_marshal_cap
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc server/common.cc
|
||||
SRC_CC += thread/thread_bootstrap_empty.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock $(BASE_DIR)/src/base/lock
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
16
base-hw/lib/mk/base.mk
Normal file
16
base-hw/lib/mk/base.mk
Normal file
@ -0,0 +1,16 @@
|
||||
#
|
||||
# \brief Portions of base library that are exclusive to non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += base-common startup
|
||||
|
||||
SRC_CC += console/log_console.cc
|
||||
SRC_CC += env/env.cc env/context_area.cc env/reload_parent_cap.cc
|
||||
SRC_CC += thread/thread.cc thread_support.cc
|
||||
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
@ -1,12 +0,0 @@
|
||||
#
|
||||
# \brief Interprocess communication
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# add library dependencies
|
||||
LIBS += thread
|
||||
|
||||
# include implied libraries
|
||||
include $(REP_DIR)/lib/mk/raw_ipc.mk
|
||||
|
@ -1,15 +0,0 @@
|
||||
#
|
||||
# \brief Synchronisation through locks
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += lock.cc
|
||||
|
||||
# add include paths
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
|
||||
# declare source paths
|
||||
vpath lock.cc $(BASE_DIR)/src/base/lock
|
||||
|
@ -1,12 +0,0 @@
|
||||
#
|
||||
# \brief Genode pager threads
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += pager.cc
|
||||
|
||||
# declare source paths
|
||||
vpath pager.cc $(REP_DIR)/src/base
|
||||
|
@ -1,13 +0,0 @@
|
||||
#
|
||||
# \brief Inter-process communication without thread implementations
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# add C++ source files
|
||||
SRC_CC += ipc.cc ipc_marshal_cap.cc
|
||||
|
||||
# declare source paths
|
||||
vpath ipc.cc $(REP_DIR)/src/base
|
||||
vpath ipc_marshal_cap.cc $(BASE_DIR)/src/base/ipc
|
||||
|
@ -1,15 +0,0 @@
|
||||
#
|
||||
# \brief Submit and receive asynchronous events
|
||||
# \author Martin Stein
|
||||
# \date 2012-05-07
|
||||
#
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += signal.cc
|
||||
|
||||
# add library dependencies
|
||||
LIBS += slab
|
||||
|
||||
# declare source paths
|
||||
vpath signal.cc $(REP_DIR)/src/base/signal
|
||||
|
@ -1,9 +0,0 @@
|
||||
#
|
||||
# \brief Shortcut for raw-signal lib to ensure Genode compliance
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# include implied libraries
|
||||
include $(REP_DIR)/lib/mk/raw_signal.mk
|
||||
|
3
base-hw/lib/mk/syscall.mk
Normal file
3
base-hw/lib/mk/syscall.mk
Normal file
@ -0,0 +1,3 @@
|
||||
SRC_CC = syscall.cc
|
||||
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
@ -1,14 +0,0 @@
|
||||
#
|
||||
# \brief Implementation of the Genode thread-API
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += thread.cc thread_bootstrap.cc thread_support.cc
|
||||
|
||||
# declare source paths
|
||||
vpath thread_support.cc $(REP_DIR)/src/base/
|
||||
vpath thread_bootstrap.cc $(BASE_DIR)/src/base/thread/
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread/
|
||||
|
@ -1,10 +0,0 @@
|
||||
#
|
||||
# \brief Build config for targets with hw spec
|
||||
# \author Martin Stein
|
||||
# \date 2012-04-16
|
||||
#
|
||||
|
||||
# use the default startup lib if not set already
|
||||
STARTUP_LIB ?= startup
|
||||
PRG_LIBS += $(STARTUP_LIB)
|
||||
|
@ -12,8 +12,7 @@ INC_DIR += $(REP_DIR)/src/core/imx31
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += platform_services.cc \
|
||||
platform_support.cc \
|
||||
syscall.cc
|
||||
platform_support.cc
|
||||
|
||||
# add assembly sources
|
||||
SRC_S += mode_transition.s \
|
||||
@ -24,7 +23,6 @@ SRC_S += mode_transition.s \
|
||||
vpath platform_services.cc $(BASE_DIR)/src/core
|
||||
vpath platform_support.cc $(REP_DIR)/src/core/imx31
|
||||
vpath mode_transition.s $(REP_DIR)/src/core/arm_v6
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
||||
vpath crt0.s $(REP_DIR)/src/core/arm
|
||||
|
||||
#
|
||||
|
@ -13,8 +13,7 @@ INC_DIR += $(REP_DIR)/src/core/imx53
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += platform_services.cc \
|
||||
platform_support.cc \
|
||||
syscall.cc
|
||||
platform_support.cc
|
||||
|
||||
# add assembly sources
|
||||
SRC_S += mode_transition.s \
|
||||
@ -25,7 +24,6 @@ SRC_S += mode_transition.s \
|
||||
vpath platform_services.cc $(BASE_DIR)/src/core
|
||||
vpath platform_support.cc $(REP_DIR)/src/core/imx53
|
||||
vpath mode_transition.s $(REP_DIR)/src/core/arm_v7
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
||||
vpath crt0.s $(REP_DIR)/src/core/arm
|
||||
|
||||
#
|
||||
|
@ -13,8 +13,7 @@ INC_DIR += $(REP_DIR)/src/core/panda
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += platform_services.cc \
|
||||
platform_support.cc \
|
||||
syscall.cc
|
||||
platform_support.cc
|
||||
|
||||
# add assembly sources
|
||||
SRC_S += mode_transition.s \
|
||||
@ -25,7 +24,6 @@ SRC_S += mode_transition.s \
|
||||
vpath platform_support.cc $(REP_DIR)/src/core/panda
|
||||
vpath platform_services.cc $(BASE_DIR)/src/core
|
||||
vpath mode_transition.s $(REP_DIR)/src/core/arm_v7
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
||||
vpath crt0.s $(REP_DIR)/src/core/arm
|
||||
|
||||
#
|
||||
|
@ -13,8 +13,7 @@ INC_DIR += $(REP_DIR)/src/core/pbxa9
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += platform_services.cc \
|
||||
platform_support.cc \
|
||||
syscall.cc
|
||||
platform_support.cc
|
||||
|
||||
# add assembly sources
|
||||
SRC_S += mode_transition.s \
|
||||
@ -25,7 +24,6 @@ SRC_S += mode_transition.s \
|
||||
vpath platform_services.cc $(BASE_DIR)/src/core
|
||||
vpath platform_support.cc $(REP_DIR)/src/core/pbxa9
|
||||
vpath mode_transition.s $(REP_DIR)/src/core/arm_v7
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
||||
vpath crt0.s $(REP_DIR)/src/core/arm
|
||||
|
||||
#
|
||||
|
@ -10,21 +10,8 @@ TARGET = core
|
||||
# set entry point of core's first thread
|
||||
CC_OPT += -DCORE_MAIN=_main
|
||||
|
||||
# core brings its own startup code
|
||||
STARTUP_LIB =
|
||||
|
||||
# add library dependencies
|
||||
LIBS += cxx \
|
||||
raw_ipc \
|
||||
heap \
|
||||
child \
|
||||
process \
|
||||
pager \
|
||||
lock \
|
||||
console \
|
||||
signal \
|
||||
raw_server \
|
||||
syscall
|
||||
LIBS += base-common
|
||||
|
||||
# add include paths
|
||||
INC_DIR += $(REP_DIR)/src/core \
|
||||
@ -36,8 +23,7 @@ INC_DIR += $(REP_DIR)/src/core \
|
||||
$(BASE_DIR)/src/platform
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += _main.cc \
|
||||
console.cc \
|
||||
SRC_CC += console.cc \
|
||||
cpu_session_component.cc \
|
||||
cpu_session_support.cc \
|
||||
dataspace_component.cc \
|
||||
@ -59,7 +45,9 @@ SRC_CC += _main.cc \
|
||||
kernel.cc \
|
||||
rm_session_support.cc \
|
||||
kernel_support.cc \
|
||||
trustzone.cc
|
||||
trustzone.cc \
|
||||
pager.cc \
|
||||
_main.cc
|
||||
|
||||
# declare file locations
|
||||
vpath _main.cc $(BASE_DIR)/src/platform
|
||||
@ -74,5 +62,7 @@ vpath rm_session_component.cc $(BASE_DIR)/src/core
|
||||
vpath rom_session_component.cc $(BASE_DIR)/src/core
|
||||
vpath dump_alloc.cc $(BASE_DIR)/src/core
|
||||
vpath console.cc $(REP_DIR)/src/base
|
||||
vpath pager.cc $(REP_DIR)/src/base
|
||||
vpath _main.cc $(BASE_DIR)/src/platform
|
||||
vpath % $(REP_DIR)/src/core
|
||||
|
||||
|
@ -10,8 +10,7 @@ INC_DIR += $(REP_DIR)/src/core/vea9x4
|
||||
|
||||
# add C++ sources
|
||||
SRC_CC += platform_services.cc \
|
||||
platform_support.cc \
|
||||
syscall.cc
|
||||
platform_support.cc
|
||||
|
||||
# add assembly sources
|
||||
SRC_S += crt0.s \
|
||||
@ -31,7 +30,6 @@ endif
|
||||
|
||||
# declare source paths
|
||||
vpath mode_transition.s $(REP_DIR)/src/core/arm_v7
|
||||
vpath syscall.cc $(REP_DIR)/src/base/arm
|
||||
vpath crt0.s $(REP_DIR)/src/core/arm
|
||||
|
||||
# include less specific target parts
|
||||
|
29
base-linux/lib/mk/base-common.mk
Normal file
29
base-linux/lib/mk/base-common.mk
Normal file
@ -0,0 +1,29 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += syscall
|
||||
|
||||
SRC_CC += ipc/ipc.cc
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += env/rm_session_mmap.cc env/debug.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc server/common.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock $(BASE_DIR)/src/base/lock
|
||||
INC_DIR += $(REP_DIR)/src/base/ipc
|
||||
INC_DIR += $(REP_DIR)/src/base/env
|
||||
INC_DIR += $(REP_DIR)/src/platform $(BASE_DIR)/src/platform
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
18
base-linux/lib/mk/base.inc
Normal file
18
base-linux/lib/mk/base.inc
Normal file
@ -0,0 +1,18 @@
|
||||
#
|
||||
# \brief Portions of base library that are exclusive to non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
# The content of this file is used for both native Genode as well as hybrid
|
||||
# Linux/Genode programs. Hence, it must be void of any thread-related code.
|
||||
#
|
||||
|
||||
LIBS += base-common syscall
|
||||
|
||||
SRC_CC += console/log_console.cc
|
||||
SRC_CC += env/env.cc env/platform_env.cc env/context_area.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/env
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = core_printf.cc
|
||||
LIBS = cxx console syscall
|
||||
INC_DIR += $(REP_DIR)/src/base/console
|
||||
|
||||
vpath core_printf.cc $(BASE_DIR)/src/base/console
|
@ -1,7 +0,0 @@
|
||||
SRC_CC = env.cc rm_session_mmap.cc platform_env.cc debug.cc context_area.cc
|
||||
LIBS = ipc heap log_console lock syscall
|
||||
INC_DIR += $(REP_DIR)/src/base/env
|
||||
|
||||
vpath env.cc $(BASE_DIR)/src/base/env
|
||||
vpath context_area.cc $(BASE_DIR)/src/base/env
|
||||
vpath %.cc $(REP_DIR)/src/base/env
|
@ -1,6 +0,0 @@
|
||||
REQUIRES = linux
|
||||
SRC_CC = ipc.cc
|
||||
LIBS = syscall cap_copy
|
||||
INC_DIR += $(REP_DIR)/src/base/ipc
|
||||
|
||||
vpath ipc.cc $(REP_DIR)/src/base/ipc
|
@ -1,5 +0,0 @@
|
||||
SRC_CC = lock.cc
|
||||
LIBS = syscall
|
||||
INC_DIR += $(REP_DIR)/src/base/lock
|
||||
|
||||
vpath lock.cc $(BASE_DIR)/src/base/lock
|
@ -1,5 +1,10 @@
|
||||
SRC_CC = lx_hybrid.cc new_delete.cc
|
||||
LIBS += syscall env
|
||||
SRC_CC += lx_hybrid.cc new_delete.cc
|
||||
|
||||
vpath new_delete.cc $(BASE_DIR)/src/base/cxx
|
||||
vpath lx_hybrid.cc $(REP_DIR)/src/platform
|
||||
|
||||
# add parts of the base library that are shared with core
|
||||
LIBS += base-common
|
||||
|
||||
# non-core parts of the base library (except for the startup code)
|
||||
include $(REP_DIR)/lib/mk/base.inc
|
||||
|
@ -1,13 +0,0 @@
|
||||
SRC_CC = process.cc
|
||||
LIBS = syscall
|
||||
|
||||
#
|
||||
# The Linux version of the process library does not use Genode's ELF loader for
|
||||
# loading executables but the 'execve' system call. However, for supporting
|
||||
# dynamically linked executables, we have to take the decision of whether to load
|
||||
# the dynamic linker or a static executable based on information provided by
|
||||
# the ELF program header. We use the ELF library to obtain this information.
|
||||
#
|
||||
LIBS += elf
|
||||
|
||||
vpath process.cc $(REP_DIR)/src/base/process
|
@ -1,6 +0,0 @@
|
||||
REQUIRES = linux
|
||||
SRC_CC = thread.cc thread_linux.cc
|
||||
LIBS = syscall
|
||||
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath thread_linux.cc $(REP_DIR)/src/base/thread
|
8
base-linux/lib/mk/x86_32/base.mk
Normal file
8
base-linux/lib/mk/x86_32/base.mk
Normal file
@ -0,0 +1,8 @@
|
||||
include $(REP_DIR)/lib/mk/base.inc
|
||||
|
||||
LIBS += startup cxx
|
||||
|
||||
SRC_CC += thread.cc thread_linux.cc
|
||||
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath thread_linux.cc $(REP_DIR)/src/base/thread
|
@ -1,8 +1,5 @@
|
||||
REQUIRES = linux x86
|
||||
LIBS = cxx lock syscall
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
INC_DIR += $(BASE_DIR)/src/platform
|
||||
LIBS += syscall
|
||||
|
||||
vpath crt0.s $(REP_DIR)/src/platform/x86_32
|
||||
vpath _main.cc $(dir $(call select_from_repositories,src/platform/_main.cc))
|
||||
include $(BASE_DIR)/lib/mk/startup.inc
|
||||
|
||||
vpath crt0.s $(REP_DIR)/src/platform/x86_32
|
||||
|
8
base-linux/lib/mk/x86_64/base.mk
Normal file
8
base-linux/lib/mk/x86_64/base.mk
Normal file
@ -0,0 +1,8 @@
|
||||
include $(REP_DIR)/lib/mk/base.inc
|
||||
|
||||
LIBS += startup
|
||||
|
||||
SRC_CC += thread.cc thread_linux.cc
|
||||
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath thread_linux.cc $(REP_DIR)/src/base/thread
|
@ -1,8 +1,5 @@
|
||||
REQUIRES = linux x86
|
||||
LIBS = cxx lock syscall
|
||||
SRC_S = crt0.s
|
||||
SRC_CC = _main.cc
|
||||
INC_DIR += $(BASE_DIR)/src/platform
|
||||
LIBS += syscall
|
||||
|
||||
vpath crt0.s $(REP_DIR)/src/platform/x86_64
|
||||
vpath _main.cc $(dir $(call select_from_repositories,src/platform/_main.cc))
|
||||
include $(BASE_DIR)/lib/mk/startup.inc
|
||||
|
||||
vpath crt0.s $(REP_DIR)/src/platform/x86_64
|
||||
|
@ -8,7 +8,6 @@
|
||||
# the program under Linux to prevent clashes with vdso.
|
||||
#
|
||||
ifneq ($(USE_HOST_LD_SCRIPT),yes)
|
||||
PRG_LIBS += startup
|
||||
LD_TEXT_ADDR ?= 0x01000000
|
||||
LD_SCRIPT_STATIC = $(call select_from_repositories,src/platform/genode.ld) \
|
||||
$(call select_from_repositories,src/platform/context_area.nostdlib.ld)
|
||||
|
@ -1,6 +1,6 @@
|
||||
TARGET = core
|
||||
REQUIRES = linux
|
||||
LIBS = cxx ipc heap core_printf child lock raw_server syscall raw_signal
|
||||
LIBS = cxx base-common syscall startup
|
||||
|
||||
GEN_CORE_DIR = $(BASE_DIR)/src/core
|
||||
|
||||
@ -18,17 +18,17 @@ SRC_CC = main.cc \
|
||||
io_mem_session_component.cc \
|
||||
signal_session_component.cc \
|
||||
signal_source_component.cc \
|
||||
thread.cc \
|
||||
thread_linux.cc \
|
||||
context_area.cc \
|
||||
debug.cc \
|
||||
rm_session_mmap.cc
|
||||
core_printf.cc \
|
||||
thread.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/core/include \
|
||||
$(GEN_CORE_DIR)/include \
|
||||
$(REP_DIR)/src/platform \
|
||||
$(REP_DIR)/src/base/ipc \
|
||||
$(REP_DIR)/src/base/env
|
||||
$(REP_DIR)/src/base/env \
|
||||
$(REP_DIR)/src/base/console
|
||||
|
||||
HOST_INC_DIR += /usr/include
|
||||
|
||||
@ -43,12 +43,11 @@ LD_SCRIPT_STATIC = $(LD_SCRIPT_DEFAULT) \
|
||||
endif
|
||||
|
||||
vpath main.cc $(GEN_CORE_DIR)
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath ram_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath cpu_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath platform_services.cc $(GEN_CORE_DIR)
|
||||
vpath signal_session_component.cc $(GEN_CORE_DIR)
|
||||
vpath signal_source_component.cc $(GEN_CORE_DIR)
|
||||
vpath debug.cc $(REP_DIR)/src/base/env
|
||||
vpath rm_session_mmap.cc $(REP_DIR)/src/base/env
|
||||
vpath core_printf.cc $(BASE_DIR)/src/base/console
|
||||
vpath thread.cc $(BASE_DIR)/src/base/thread
|
||||
vpath %.cc $(PRG_DIR)
|
||||
|
@ -1,6 +1,6 @@
|
||||
TARGET = test-lx_hybrid_ctors
|
||||
SRC_CC = main.cc
|
||||
LIBS = env lx_hybrid
|
||||
LIBS = lx_hybrid
|
||||
|
||||
TESTLIB_SO = libtestlib.so
|
||||
TESTLIB_SRC_CC = testlib.cc
|
||||
|
@ -1,3 +1,3 @@
|
||||
TARGET = test-lx_hybrid_errno
|
||||
SRC_CC = main.c
|
||||
LIBS = env cxx thread lx_hybrid
|
||||
LIBS = lx_hybrid
|
||||
|
@ -1,3 +1,3 @@
|
||||
TARGET = test-lx_hybrid_exception
|
||||
SRC_CC = main.cc
|
||||
LIBS = env lx_hybrid
|
||||
LIBS = lx_hybrid
|
||||
|
@ -1,3 +1,3 @@
|
||||
TARGET = test-lx_hybrid_pthread_ipc
|
||||
SRC_CC = main.c
|
||||
LIBS = env cxx thread lx_hybrid
|
||||
LIBS = lx_hybrid
|
||||
|
@ -1,3 +1,3 @@
|
||||
TARGET = test-rm_session_mmap
|
||||
LIBS = cxx env
|
||||
LIBS = base
|
||||
SRC_CC = main.cc
|
||||
|
@ -1,3 +1,3 @@
|
||||
TARGET = hello
|
||||
SRC_CC = main.cc
|
||||
LIBS = cxx env thread
|
||||
LIBS = base
|
||||
|
26
base-nova/lib/mk/base-common.inc
Normal file
26
base-nova/lib/mk/base-common.inc
Normal file
@ -0,0 +1,26 @@
|
||||
#
|
||||
# \brief Portions of base library shared by core and non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += cxx startup
|
||||
|
||||
SRC_CC += ipc/ipc.cc ipc/pager.cc
|
||||
SRC_CC += avl_tree/avl_tree.cc
|
||||
SRC_CC += allocator/slab.cc
|
||||
SRC_CC += allocator/allocator_avl.cc
|
||||
SRC_CC += heap/heap.cc heap/sliced_heap.cc
|
||||
SRC_CC += console/console.cc
|
||||
SRC_CC += child/child.cc
|
||||
SRC_CC += process/process.cc
|
||||
SRC_CC += elf/elf_binary.cc
|
||||
SRC_CC += lock/lock.cc
|
||||
SRC_CC += signal/signal.cc
|
||||
SRC_CC += server/server.cc
|
||||
SRC_CC += thread/thread.cc thread/thread_context.cc
|
||||
|
||||
INC_DIR += $(REP_DIR)/src/base/lock $(BASE_DIR)/src/base/lock
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
17
base-nova/lib/mk/base.mk
Normal file
17
base-nova/lib/mk/base.mk
Normal file
@ -0,0 +1,17 @@
|
||||
#
|
||||
# \brief Portions of base library that are exclusive to non-core processes
|
||||
# \author Norman Feske
|
||||
# \date 2013-02-14
|
||||
#
|
||||
|
||||
LIBS += base-common
|
||||
|
||||
SRC_CC += console/log_console.cc
|
||||
SRC_CC += env/env.cc env/cap_sel_alloc.cc env/main_thread.cc \
|
||||
env/context_area.cc env/reload_parent_cap
|
||||
SRC_CC += thread/thread_nova.cc
|
||||
|
||||
INC_DIR += $(BASE_DIR)/src/base/env
|
||||
|
||||
vpath %.cc $(REP_DIR)/src/base
|
||||
vpath %.cc $(BASE_DIR)/src/base
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user