Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/Makefile.common

    r664af708 re8c5c11  
    4040#   BINARY         (/) binary output name (like appname)
    4141#   LIBRARY        (/) library output name (like libname)
     42#
    4243#   EXTRA_OUTPUT       additional output targets
    4344#   EXTRA_CLEAN        additional cleanup targets
     45#
     46# Optionally, for a binary:
     47#   STATIC_NEEDED      set to 'y' for init binaries, will build statically
     48#                      linked version
     49#   STATIC_ONLY        set to 'y' if binary cannot be linked dynamically
     50#                      (e.g. uses thread-local variables)
     51#
     52# Optionally, for a libary:
     53#   SLIBRARY           Name with full version, e.g. libfoo.so.0.0
     54#   LSONAME            Soname / name with short version, e.g. libfoo.so.0
    4455#
    4556# (x) required variables
     
    7384endif
    7485
     86ifeq ($(CONFIG_BUILD_SHARED_LIBS), y)
     87        ifneq ($(SLIBRARY),)
     88                LARCHIVE = $(LIBRARY).la
     89                LOUTPUT = $(SLIBRARY)
     90                EXTRA_OUTPUT += $(LOUTPUT).disasm $(LIBRARY).so $(LSONAME)
     91                EXTRA_CLEAN += $(LOUTPUT).map $(LOUTPUT).ldisasm \
     92                    $(LIBC_PREFIX)/shared/arch/$(UARCH)/_lib.ld \
     93                    $(LIBRARY).so $(LSONAME)
     94        endif
     95endif
     96
    7597DEPEND = Makefile.depend
    7698DEPEND_PREV = $(DEPEND).prev
     
    90112LIBNET_PREFIX = $(LIB_PREFIX)/net
    91113
     114ifeq ($(STATIC_NEEDED),y)
     115        STATIC_BUILD = y
     116else
     117        ifeq ($(STATIC_ONLY),y)
     118                STATIC_BUILD = y
     119        else
     120                ifeq ($(CONFIG_USE_SHARED_LIBS), y)
     121                        STATIC_BUILD = n
     122                else
     123                        STATIC_BUILD = y
     124                endif
     125        endif
     126endif
     127
     128ifeq ($(STATIC_BUILD), y)
    92129BASE_LIBS = $(LIBC_PREFIX)/libc.a $(LIBSOFTINT_PREFIX)/libsoftint.a
    93 
    94130LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link.ld
     131else
     132BASE_LIBS = $(LIBC_PREFIX)/libc.so0 $(LIBSOFTINT_PREFIX)/libsofti.so0
     133LFLAGS = -Bdynamic
     134LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link-dlexe.ld
     135endif
    95136
    96137ifeq ($(CONFIG_OPTIMIZE_FOR_SIZE),y)
     
    102143.PHONY: all clean
    103144
    104 all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(EXTRA_OUTPUT)
     145all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(LOUTPUT) $(EXTRA_OUTPUT)
    105146        -[ -f $(DEPEND) ] && cp -a $(DEPEND) $(DEPEND_PREV)
    106147
    107148clean:
    108         rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN)
     149        rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(LARCHIVE) $(LOUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN)
    109150        find . -name '*.o' -follow -exec rm \{\} \;
     151        find . -name '*.lo' -follow -exec rm \{\} \;
    110152
    111153GCC_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
     
    113155        -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
    114156        -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \
    115         -Werror-implicit-function-declaration -Wwrite-strings \
     157        -std=gnu99 -Werror-implicit-function-declaration -Wwrite-strings \
    116158        -pipe -g -D__$(ENDIANESS)__
    117159
     
    130172        -pipe -g -arch $(CLANG_ARCH) -D__$(ENDIANESS)__
    131173
     174LIB_CFLAGS = $(CFLAGS) -fPIC -D__IN_SHARED_LIBC__
     175LIB_LFLAGS = $(LFLAGS) -shared -soname $(LSONAME) --whole-archive
     176
    132177ifeq ($(CONFIG_DEBUG),y)
    133178        GCC_CFLAGS += -Werror
     
    175220
    176221OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
     222LOBJECTS := $(addsuffix .lo,$(basename $(SOURCES)))
    177223
    178224ifneq ($(BINARY),)
     
    185231
    186232$(BINARY): $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS)
    187         $(LD) -N $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS)
     233        $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS)
    188234ifeq ($(CONFIG_STRIP_BINARIES),y)
    189235        $(STRIP) $(BINARY)
    190236endif
     237endif
     238
     239ifneq ($(SLIBRARY),)
     240%.disasm: $(LOUTPUT)
     241ifeq ($(CONFIG_LINE_DEBUG),y)
     242        $(OBJDUMP) -d -S $< > $@
     243else
     244        $(OBJDUMP) -d $< > $@
     245endif
     246
     247$(LOUTPUT): $(LARCHIVE) $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld
     248        $(LD) -T $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld $(LIB_LFLAGS) $(LARCHIVE) -o $@ -Map $(LOUTPUT).map
     249
     250$(LIBRARY).so:
     251        ln -s $(SLIBRARY) $@
     252
     253$(LSONAME):
     254        ln -s $(SLIBRARY) $@
    191255endif
    192256
     
    196260endif
    197261
     262ifneq ($(SLIBRARY),)
     263%.la: $(LOBJECTS)
     264        $(AR) rc $@ $(LOBJECTS)
     265endif
     266
    198267%.o: %.S $(DEPEND)
    199268        $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@
     
    210279%.o: %.c $(DEPEND)
    211280        $(CC) $(DEFS) $(CFLAGS) -c $< -o $@
     281ifeq ($(PRECHECK),y)
     282        $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS)
     283endif
     284
     285%.lo: %.S $(DEPEND)
     286        $(CC) $(DEFS) $(LIB_CFLAGS) -D__ASM__ -c $< -o $@
     287ifeq ($(PRECHECK),y)
     288        $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(CFLAGS) -D__ASM__
     289endif
     290
     291%.lo: %.s $(DEPEND)
     292        $(AS) $(AFLAGS) -o $@ $<
     293ifeq ($(PRECHECK),y)
     294        $(JOBFILE) $(JOB) $< $@ as asm
     295endif
     296
     297%.lo: %.c $(DEPEND)
     298        $(CC) $(DEFS) $(LIB_CFLAGS) -c $< -o $@
    212299ifeq ($(PRECHECK),y)
    213300        $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS)
     
    223310$(OUTPUT): $(OBJECTS)
    224311
     312$(LARCHIVE): $(LOBJECTS)
Note: See TracChangeset for help on using the changeset viewer.