Make out and dev output paths more explicit
This commit is contained in:
parent
c6c7870a29
commit
af9b91e94c
29
Tuprules.tup
29
Tuprules.tup
|
@ -2,6 +2,8 @@
|
|||
|
||||
OUT_DIR=$(TUP_CWD)/out
|
||||
DEV_DIR = $(TUP_CWD)/dev
|
||||
DEV_LIB_DIR = $(DEV_DIR)/lib
|
||||
|
||||
|
||||
ifeq (@(TUP_ARCH),i386)
|
||||
X86 = y
|
||||
|
@ -23,29 +25,29 @@ endif
|
|||
|
||||
GENODE_DIR = $(TUP_CWD)
|
||||
|
||||
!prg = | $(GENODE_DIR)/<lib> $(DEV_DIR)/<lib> $(GENODE_DIR)/<pkg-config> \
|
||||
!prg = | $(DEV_DIR)/<lib> $(DEV_DIR)/<pkg-config> \
|
||||
|> ^o LD %o^ \
|
||||
$(LD) $(LD_MARCH) $(LDFLAGS) \
|
||||
-L$(LIB_DIR) \
|
||||
-L$(DEV_LIB_DIR) \
|
||||
`$(PKG_CONFIG) --libs $(LIBS) genode-prg` \
|
||||
%f \
|
||||
$(LIBGCC) \
|
||||
-o %o \
|
||||
|> %d
|
||||
|
||||
!lib = | $(GENODE_DIR)/<lib> $(DEV_DIR)/<lib> $(GENODE_DIR)/<pkg-config> |> ^o LD %o^ $(LD) $(LD_MARCH) %f $(LDFLAGS) `$(PKG_CONFIG) --libs genode-lib $(LIBS)` -L$(LIB_DIR) -o %o |> %d.lib.so
|
||||
!lib = | $(DEV_DIR)/<lib> $(DEV_DIR)/<pkg-config> |> ^o LD %o^ $(LD) $(LD_MARCH) %f $(LDFLAGS) `$(PKG_CONFIG) --libs genode-lib $(LIBS)` -L$(DEV_LIB_DIR) -o %o |> %d.lib.so
|
||||
|
||||
!collect_bin = |> ^ COLLECT %b^ \
|
||||
$STRIP -o %o %f \
|
||||
|> $(OUT_DIR)/bin/%b $(OUT_DIR)/<bin>
|
||||
|
||||
!collect_shared = |> ^ COLLECT %b^ \
|
||||
$STRIP -o %o %f \
|
||||
cp %f %o \
|
||||
|> $(OUT_DIR)/lib/%b $(OUT_DIR)/<lib>
|
||||
|
||||
!collect_static = |> ^ COLLECT %b^ \
|
||||
cp %f %o \
|
||||
|> $(DEV_DIR)/lib/%b \
|
||||
|> $(DEV_LIB_DIR)/%b \
|
||||
$(DEV_DIR)/<lib> \
|
||||
|
||||
export CC
|
||||
|
@ -65,8 +67,6 @@ CXXFLAGS += -Wno-undefined-bool-conversion -Wno-unknown-attributes -Wsystem-head
|
|||
|
||||
LIBGCC = `$(CC) $(CC_MARCH) -print-libgcc-file-name`
|
||||
|
||||
LIB_DIR = $(DEV_DIR)/lib
|
||||
|
||||
export PKG_CONFIG_PATH
|
||||
PKG_CONFIG_DIR = $(DEV_DIR)/lib/pkgconfig
|
||||
PKG_CONFIG = PKG_CONFIG_PATH=$(PKG_CONFIG_DIR):$PKG_CONFIG_PATH pkg-config
|
||||
|
@ -80,15 +80,15 @@ else
|
|||
OLEVEL = -O2
|
||||
endif
|
||||
|
||||
!ir = | $(GENODE_DIR)/<pkg-config> |> clang $(OLEVEL) $(CXXFLAGS) $(CXXFLAGS_%e) $(CXXFLAGS_%f) `$(PKG_CONFIG) --cflags $(LIBS)` $(CPPFLAGS) -S -emit-llvm %f |> %B.ll
|
||||
!ir = | $(DEV_DIR)/<pkg-config> |> clang $(OLEVEL) $(CXXFLAGS) $(CXXFLAGS_%e) $(CXXFLAGS_%f) `$(PKG_CONFIG) --cflags $(LIBS)` $(CPPFLAGS) -S -emit-llvm %f |> %B.ll
|
||||
|
||||
!asm = |> ^ CC %b^ @(CC_WRAPPER) $(CC) $(OLEVEL) $(CFLAGS) $(CFLAGS_%e) $(CFLAGS_%f) -D__ASSEMBLY__ $(CPPFLAGS) -c %f -o %o |> %B.o
|
||||
|
||||
!cc = | $(GENODE_DIR)/<pkg-config> |> ^o CC %f^ @(CC_WRAPPER) $(CC) $(OLEVEL) $(CFLAGS) $(CFLAGS_%e) $(CFLAGS_%f) $(CPPFLAGS) `$(PKG_CONFIG) --cflags $(LIBS) $(LIBS_CFLAGS)` -c -fPIC %f -o %o |> %B.o
|
||||
!cc = | $(DEV_DIR)/<pkg-config> |> ^o CC %f^ @(CC_WRAPPER) $(CC) $(OLEVEL) $(CFLAGS) $(CFLAGS_%e) $(CFLAGS_%f) $(CPPFLAGS) `$(PKG_CONFIG) --cflags $(LIBS) $(LIBS_CFLAGS)` -c -fPIC %f -o %o |> %B.o
|
||||
|
||||
!cxx = | $(GENODE_DIR)/<pkg-config> |> ^o CXX %b^ @(CC_WRAPPER) $(CXX) $(OLEVEL) $(CXXFLAGS) $(CXXFLAGS_%e) $(CXXFLAGS_%f) $(CPPFLAGS) `$(PKG_CONFIG) --cflags $(LIBS)` -c -fPIC %f -o %o |> %B.o
|
||||
!cxx = | $(DEV_DIR)/<pkg-config> |> ^o CXX %b^ @(CC_WRAPPER) $(CXX) $(OLEVEL) $(CXXFLAGS) $(CXXFLAGS_%e) $(CXXFLAGS_%f) $(CPPFLAGS) `$(PKG_CONFIG) --cflags $(LIBS)` -c -fPIC %f -o %o |> %B.o
|
||||
|
||||
!ld = | $(GENODE_DIR)/<lib> $(GENODE_DIR)/<pkg-config> |> ^o LD %o^ $(LD) $(LDFLAGS) `$(PKG_CONFIG) --libs $(LIBS)` --whole-archive --start-group %f --no-whole-archive --end-group -o %o |>
|
||||
!ld = | $(DEV_DIR)/<lib> $(DEV_DIR)/<pkg-config> |> ^o LD %o^ $(LD) $(LDFLAGS) `$(PKG_CONFIG) --libs $(LIBS)` --whole-archive --start-group %f --no-whole-archive --end-group -o %o |>
|
||||
|
||||
export STRIP
|
||||
!strip = |> $STRIP -o %o %f |>
|
||||
|
@ -106,18 +106,17 @@ export AR
|
|||
|
||||
GIT_VERSION = `git describe || echo @(VERSION)`
|
||||
|
||||
SED_PKGCONFIG_FLAGS += -e "s|@DEPOT_VERSION@|$(GIT_VERSION)|"
|
||||
SED_PKGCONFIG_FLAGS += -e "s|@VERSION@|$(GIT_VERSION)|"
|
||||
|
||||
!sed_pkgconfig_file = |> ^o SED %B^ \
|
||||
sed $(SED_PKGCONFIG_FLAGS) $(SED_FLAGS) < %f > %o; \
|
||||
pkg-config --validate %o; \
|
||||
|> $(PKG_CONFIG_DIR)/%B $(GENODE_DIR)/<pkg-config>
|
||||
|> $(PKG_CONFIG_DIR)/%B $(DEV_DIR)/<pkg-config>
|
||||
|
||||
!sed_pkgconfig_flags = |> ^o SED %d.pc^ \
|
||||
sed $(SED_PKGCONFIG_FLAGS) $(SED_FLAGS) > %o; \
|
||||
pkg-config --validate %o; \
|
||||
|> $(PKG_CONFIG_DIR)/%d.pc $(GENODE_DIR)/<pkg-config>
|
||||
|> $(PKG_CONFIG_DIR)/%d.pc $(DEV_DIR)/<pkg-config>
|
||||
|
||||
!emit_lib_pkg_config = |> ^ emit %d.a pkg-config^ \
|
||||
echo Name: %d >> %o; \
|
||||
|
@ -125,4 +124,4 @@ SED_PKGCONFIG_FLAGS += -e "s|@VERSION@|$(GIT_VERSION)|"
|
|||
echo Version: $(GIT_VERSION) >> %o; \
|
||||
echo Libs: -l:%d.a >> %o; \
|
||||
pkg-config --validate %o; \
|
||||
|> $(PKG_CONFIG_DIR)/%d.pc $(GENODE_DIR)/<pkg-config>
|
||||
|> $(PKG_CONFIG_DIR)/%d.pc $(DEV_DIR)/<pkg-config>
|
||||
|
|
|
@ -25,7 +25,7 @@ endif
|
|||
-T &(LD_SCRIPT_SO) \
|
||||
tmp.o; \
|
||||
rm tmp.o; \
|
||||
|> $(DEV_DIR)/lib/%B.lib.so $(GENODE_DIR)/<lib>
|
||||
|> $(DEV_LIB_DIR)/%B.lib.so $(DEV_DIR)/<lib>
|
||||
|
||||
BASE_DIR = $(GENODE_DIR)/repos/base
|
||||
&BASE_DIR = base
|
||||
|
|
|
@ -34,21 +34,20 @@ CXXFLAGS_$(GEN_CORE_DIR)/version.cc += -DGENODE_VERSION=\"`git describe`\"
|
|||
|
||||
: foreach $(SRC_CC) |> !cxx |> {obj}
|
||||
|
||||
LDFLAGS += \
|
||||
-gc-sections \
|
||||
-z max-page-size=0x1000 \
|
||||
-nostdlib \
|
||||
-Ttext=0x01000000 \
|
||||
-T$(BASE_DIR)/src/ld/genode.ld \
|
||||
-T$(REP_DIR)/src/ld/stack_area.ld \
|
||||
LDFLAGS += -gc-sections
|
||||
LDFLAGS += -z max-page-size=0x1000
|
||||
LDFLAGS += -nostdlib
|
||||
LDFLAGS += -Ttext=0x01000000
|
||||
LDFLAGS += -T$(BASE_DIR)/src/ld/genode.ld
|
||||
LDFLAGS += -T$(REP_DIR)/src/ld/stack_area.ld
|
||||
|
||||
LDFLAGS += -L$(LIB_DIR) `$(PKG_CONFIG) --libs cxx-baremetal`
|
||||
LDFLAGS += -L$(DEV_LIB_DIR) `$(PKG_CONFIG) --libs cxx-baremetal`
|
||||
|
||||
: {obj} | \
|
||||
$(DEV_DIR)/<lib> \
|
||||
$(GENODE_DIR)/<pkg-config> \
|
||||
$(REP_DIR)/<startup> \
|
||||
$(DEV_DIR)/<pkg-config> \
|
||||
$(REP_DIR)/<base-common> \
|
||||
$(REP_DIR)/<startup> \
|
||||
$(REP_DIR)/<syscall> \
|
||||
|> !ld %<base-common> %<startup> %<syscall> \
|
||||
|> core-linux $(REP_DIR)/<core> {bin}
|
||||
|
|
|
@ -37,12 +37,12 @@ BASE_LIBS += \
|
|||
|
||||
BASE_PKGS += alarm cxx ldso-startup startup timeout
|
||||
|
||||
LDFLAGS += -L$(LIB_DIR) `$(PKG_CONFIG) --static --libs $(BASE_PKGS)`
|
||||
LDFLAGS += -L$(DEV_LIB_DIR) `$(PKG_CONFIG) --static --libs $(BASE_PKGS)`
|
||||
|
||||
: $(BASE_LIBS) {obj} | \
|
||||
symbol.map \
|
||||
$(DEV_DIR)/<lib> \
|
||||
$(GENODE_DIR)/<pkg-config> \
|
||||
$(DEV_DIR)/<pkg-config> \
|
||||
$(REP_DIR)/<base-common> \
|
||||
$(REP_DIR)/<syscall> \
|
||||
|> \
|
||||
|
|
|
@ -45,11 +45,11 @@ CXXFLAGS_$(GEN_CORE_DIR)/version.cc += -DGENODE_VERSION=\"`git describe`\"
|
|||
|
||||
: foreach $(SRC_CC) |> !cxx |> {obj}
|
||||
|
||||
LDFLAGS += -L$(LIB_DIR) `$(PKG_CONFIG) --libs cxx-baremetal`
|
||||
LDFLAGS += -L$(DEV_LIB_DIR) `$(PKG_CONFIG) --libs cxx-baremetal`
|
||||
|
||||
: {obj} | \
|
||||
$(DEV_DIR)/<lib> \
|
||||
$(GENODE_DIR)/<pkg-config> \
|
||||
$(DEV_DIR)/<pkg-config> \
|
||||
$(BASE_DIR)/<base-libs> \
|
||||
$(REP_DIR)/<startup> \
|
||||
$(REP_DIR)/<base-common> \
|
||||
|
|
|
@ -35,11 +35,14 @@ LDFLAGS += -T$(BASE_DIR)/src/ld/genode_rel.ld
|
|||
|
||||
BASE_LIBS += $(REP_DIR)/src/lib/base/base-nova.lib.a
|
||||
|
||||
BASE_PKGS += alarm cxx-baremetal ldso-startup timeout
|
||||
LDFLAGS += -L$(DEV_LIB_DIR) `$(PKG_CONFIG) --static --libs $(BASE_PKGS)`
|
||||
|
||||
LDFLAGS += `$(PKG_CONFIG) --static --libs $(BASE_PKGS)` -L $(LIB_DIR)
|
||||
|
||||
: $(BASE_LIBS) {obj} | symbol.map $(REP_DIR)/<startup> $(REP_DIR)/<base-common> $(GENODE_DIR)/<pkg-config> $(DEV_DIR)/<lib> \
|
||||
: {obj} | \
|
||||
$(DEV_DIR)/<lib> \
|
||||
$(DEV_DIR)/<pkg-config> \
|
||||
$(REP_DIR)/<base-common> \
|
||||
$(REP_DIR)/<startup> \
|
||||
symbol.map \
|
||||
|> \
|
||||
$(LD) -o %o \
|
||||
$(LD_MARCH) $(LDFLAGS) \
|
||||
|
|
|
@ -8,7 +8,6 @@ SED_FLAGS += -e "s|@includedir@|`nix-store --add $(REP_DIR)/include`|"
|
|||
SED_FLAGS += -e "s|@lddir@|`nix-store --add $(REP_DIR)/src/ld`|"
|
||||
endif
|
||||
|
||||
|
||||
SED_FLAGS += -e "s|@toolchainincludedir@|`$(CC) $(CC_MARCH) -print-file-name=include`|"
|
||||
SED_FLAGS += -e "s|@libgcc@||"
|
||||
|
||||
|
@ -19,4 +18,3 @@ SED_FLAGS += -e "s|@ar@|$(AR)|"
|
|||
SED_FLAGS += -e "s|@ranlib@|$(RANLIB)|"
|
||||
|
||||
: foreach *.pc.in |> !sed_pkgconfig_file |>
|
||||
: |> ln -s genode-base.pc %o |> $(PKG_CONFIG_DIR)/base.pc $(GENODE_DIR)/<pkg-config>
|
||||
|
|
|
@ -2,4 +2,4 @@ Name: ld
|
|||
Description: Genode dynamic loader
|
||||
URL: https://genode.org/
|
||||
Version: @VERSION@
|
||||
Libs: -l:ld.lib.so -l:ldso-startup.a
|
||||
Libs: -l:ld.lib.so
|
||||
|
|
|
@ -1 +1 @@
|
|||
LIBS += base
|
||||
LIBS += genode-base
|
||||
|
|
Loading…
Reference in New Issue