X-Git-Url: https://git.ucc.asn.au/?p=tpg%2Facess2.git;a=blobdiff_plain;f=Usermode%2FApplications%2FMakefile.tpl;h=d72ac6a24cfc32889454b33f6a9933f5c6e68321;hp=a6c8508c4ce379df754d7e9569deb4b04ca230e8;hb=9a9053e91df6e08761e2ce72be350c5c2233153b;hpb=7b64f5e7f00e445a5637e9e3289a1332a14d28e5 diff --git a/Usermode/Applications/Makefile.tpl b/Usermode/Applications/Makefile.tpl index a6c8508c..d72ac6a2 100644 --- a/Usermode/Applications/Makefile.tpl +++ b/Usermode/Applications/Makefile.tpl @@ -3,23 +3,26 @@ # - Application Template Makefile # -CFLAGS += -g -LDFLAGS += -g - -LDFLAGS += -Map $(_OBJPREFIX)Map.txt - -ifneq ($(lastword $(subst -, ,$(basename $(LD)))),ld) - comma=, - LDFLAGS := $(subst -rpath-link ,-Wl$(comma)-rpath-link$(comma),$(LDFLAGS)) - LDFLAGS := $(subst -Map ,-Wl$(comma)-Map$(comma),$(LDFLAGS)) -endif +CFLAGS += -g +CXXFLAGS += -g +LDFLAGS += -g _BIN := $(OUTPUTDIR)$(DIR)/$(BIN) _OBJPREFIX := obj-$(ARCH)/ -_LIBS := $(filter -l%,$(LDFLAGS)) +LDFLAGS += -Map $(_OBJPREFIX)Map.txt + +comma=, +LDFLAGS := $(subst -rpath-link ,-Wl$(comma)-rpath-link$(comma),$(LDFLAGS)) +LDFLAGS := $(subst -Map ,-Wl$(comma)-Map$(comma),$(LDFLAGS)) + +_LIBS := $(filter -l%,$(LIBS)) _LIBS := $(patsubst -l%,$(OUTPUTDIR)Libs/lib%.so,$(_LIBS)) +ifeq ($(ARCHDIR),native) + LDFLAGS := $(patsubst -lc++,-lc++_acess,$(LDFLAGS)) + LIBS := $(patsubst -lc++,-lc++_acess,$(LIBS)) +endif ifeq ($(VERBOSE),) V := @ else @@ -28,6 +31,9 @@ endif OBJ := $(addprefix $(_OBJPREFIX),$(OBJ)) +#LINK_OBJS := $(CRTI) $(CRTBEGIN) $(CRT0) $(OBJ) $(LIBGCC_PATH) $(CRTEND) $(CRTN) +LINK_OBJS := $(OBJ) + DEPFILES := $(OBJ:%.o=%.dep) .PHONY : all clean install @@ -45,10 +51,14 @@ install: $(_BIN) @$(xCP) $(_BIN)_ $(DISTROOT)/$(DIR)/$(BIN) @$(RM) $(_BIN)_ -$(_BIN): $(OUTPUTDIR)Libs/acess.ld $(OUTPUTDIR)Libs/crt0.o $(_LIBS) $(OBJ) +$(_BIN): $(_LIBS) $(LINK_OBJS) $(CRT0) $(CRTI) $(CRTN) @mkdir -p $(dir $(_BIN)) @echo [LD] -o $@ - $V$(LD) -g $(LDFLAGS) -o $@ $(CRTBEGIN) $(OBJ) $(LIBGCC_PATH) $(CRTEND) +ifneq ($(USE_CXX_LINK),) + $V$(CXX) -g $(LDFLAGS) -o $(_BIN) $(LINK_OBJS) $(LIBS) +else + $V$(CC) -g $(LDFLAGS) -o $(_BIN) $(LINK_OBJS) $(LIBS) +endif $V$(DISASM) $(_BIN) > $(_OBJPREFIX)$(BIN).dsm $(_OBJPREFIX)%.o: %.c @@ -56,8 +66,7 @@ $(_OBJPREFIX)%.o: %.c ifneq ($(_OBJPREFIX),) @mkdir -p $(dir $@) endif - $V$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@ - $V$(CC) -M -MP -MT $@ $(CPPFLAGS) $< -o $(_OBJPREFIX)$*.dep + $V$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@ -MQ $@ -MP -MD -MF $(_OBJPREFIX)$*.dep $(_OBJPREFIX)%.o: %.cpp @echo [CXX] -o $@