X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Usermode%2FLibraries%2Fld-acess.so_src%2FMakefile;h=78aac4bd7f7b548463a0c141719526357c3b374b;hb=d8d31a4ec9a28eb8de493146ce75e8238e8e13b1;hp=d0b49a44067fd255c61a74b65d31b31650f54e4e;hpb=5c46f86c5a8ceaa63a1a9919cf1f4d2889c6c233;p=tpg%2Facess2.git diff --git a/Usermode/Libraries/ld-acess.so_src/Makefile b/Usermode/Libraries/ld-acess.so_src/Makefile index d0b49a44..78aac4bd 100644 --- a/Usermode/Libraries/ld-acess.so_src/Makefile +++ b/Usermode/Libraries/ld-acess.so_src/Makefile @@ -1,37 +1,57 @@ -# Acess Dynamic Linker (ELF) Version 1 -# LD-ACESS.SO -# Makefile - --include ../Makefile.cfg - -COBJ = main.o lib.o loadlib.o elf.o pe.o -AOBJ = helpers.ao -BIN = ../ld-acess.so - -CFLAGS = -Wall -fno-builtin -fleading-underscore -fno-stack-protector -ASFLAGS = -felf -LDFLAGS = -T link.ld -Map map.txt -Bstatic - - -.PHONY: all clean - -all: $(BIN) - -clean: - $(RM) $(BIN) $(AOBJ) $(COBJ) ld-acess.dmp ld-acess.dsm link.txt map.txt - -$(BIN): $(AOBJ) $(COBJ) - @echo --- $(LD) -shared -o $@ - @$(LD) $(LDFLAGS) -o $(BIN) $(AOBJ) $(COBJ) > link.txt - $(OBJDUMP) -x $(BIN) > ld-acess.dmp - $(OBJDUMP) -d $(BIN) > ld-acess.dsm - $(xCP) $(BIN) $(DISTROOT)/Libs/ - -$(COBJ): %.o: %.c - @echo $(CC) -o $@ - @$(CC) $(CFLAGS) -o $@ -c $< - -$(AOBJ): %.ao: %.asm - @echo $(AS) -o $@ - @$(AS) $(ASFLAGS) -o $@ $< - +# Acess Dynamic Linker (ELF) Version 1 +# LD-ACESS.SO +# Makefile + +-include ../Makefile.cfg + +OBJ := main.o lib.o loadlib.o export.o elf.o pe.o +OBJ += arch/$(ARCHDIR).ao_ +BIN = ld-acess.so +EXTRABIN := libld-acess.so +EXTRACLEAN = $(_OBJPREFIX)_stublib.o +INCFILES := sys/sys.h + +#CPPFLAGS += -D DISABLE_ELF64 +CFLAGS = -g -Wall -fno-builtin -fno-stack-protector -fPIC -std=c99 -ffreestanding +# -fno-leading-underscore +CFLAGS += $(CPPFLAGS) +LDFLAGS = -ffreestanding -nostdlib -g -Wl,-T,arch/$(ARCHDIR).ld -Map map.txt --export-dynamic -x +LIBS := $(LIBGCC_PATH) + +ifeq ($(ARCH),native) +XBIN := $(addprefix $(OUTPUTDIR)Libs/,$(EXTRABIN)) +$(XBIN): obj-$(ARCH)/_stublib.o +all: $(XBIN) +CFLAGS += -ffreestanding +LDFLAGS := +BIN := +OBJ := +endif + +include ../Makefile.tpl + +# create libld-acess.so +$(_XBIN): $(_OBJPREFIX)_stublib.o + @echo [LD] -o -shared libld-acess.so + $(LD) -shared -o $@ $< +# @$(LD) $(LDFLAGS) -o $@ $(OBJ) + + +# Override .ao to look in the object prefix for the source +$(_OBJPREFIX)arch/$(ARCHDIR).ao_: $(_OBJPREFIX)arch/$(ARCHDIR).$(ASSUFFIX) + @echo [AS] -o $@ + @mkdir -p $(dir $@) + @$(AS) $(ASFLAGS) -o $@ $< + +#.PRECIOUS: $(OBJ:%.ao=%.asm) + +# Preprocessing objects if needed +$(_OBJPREFIX)arch/$(ARCHDIR).$(ASSUFFIX): arch/$(ARCHDIR).$(ASSUFFIX).h arch/syscalls.s.h + @echo [CPP] -o $@ + @mkdir -p $(dir $@) + @$(CPP) $(CPPFLAGS) -P -D__ASSEMBLER__ $< -o $@ + +$(_OBJPREFIX)arch/$(ARCHDIR).$(ASSUFFIX): $(ACESSDIR)/KernelLand/Kernel/include/syscalls.h + +$(_OBJPREFIX)_stublib.o: arch/syscalls.s.h +