Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/Makefile.common

    ra60afd0 r78a9e5ef  
    4040#   BINARY         (/) binary output name (like appname)
    4141#   LIBRARY        (/) library output name (like libname)
    42 #
    4342#   EXTRA_OUTPUT       additional output targets
    4443#   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
    5544#
    5645# (x) required variables
     
    8473endif
    8574
    86 ifeq ($(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
    95 endif
    96 
    9775DEPEND = Makefile.depend
    9876DEPEND_PREV = $(DEPEND).prev
     
    10886LIBCLUI_PREFIX = $(LIB_PREFIX)/clui
    10987
    110 
    111 LIBUSB_PREFIX = $(LIB_PREFIX)/usb
    112 LIBUSBHOST_PREFIX = $(LIB_PREFIX)/usbhost
    113 LIBUSBDEV_PREFIX = $(LIB_PREFIX)/usbdev
    114 LIBUSBHID_PREFIX = $(LIB_PREFIX)/usbhid
    115 LIBUSBVIRT_PREFIX = $(LIB_PREFIX)/usbvirt
    11688LIBDRV_PREFIX = $(LIB_PREFIX)/drv
    11789LIBPACKET_PREFIX = $(LIB_PREFIX)/packet
    11890LIBNET_PREFIX = $(LIB_PREFIX)/net
    11991
    120 ifeq ($(STATIC_NEEDED),y)
    121         STATIC_BUILD = y
    122 else
    123         ifeq ($(STATIC_ONLY),y)
    124                 STATIC_BUILD = y
    125         else
    126                 ifeq ($(CONFIG_USE_SHARED_LIBS), y)
    127                         STATIC_BUILD = n
    128                 else
    129                         STATIC_BUILD = y
    130                 endif
    131         endif
    132 endif
    133 # Build static whenever we use libusb because that library uses
    134 # thread local variables
    135 ifneq ($(findstring usb, $(LIBS)),)
    136         STATIC_BUILD = y
    137 endif
    138 
    139 ifeq ($(STATIC_BUILD), y)
    14092BASE_LIBS = $(LIBC_PREFIX)/libc.a $(LIBSOFTINT_PREFIX)/libsoftint.a
     93
    14194LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link.ld
    142 else
    143 BASE_LIBS = $(LIBC_PREFIX)/libc.so0 $(LIBSOFTINT_PREFIX)/libsofti.so0
    144 LFLAGS = -Bdynamic
    145 LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link-dlexe.ld
    146 endif
    14795
    14896ifeq ($(CONFIG_OPTIMIZE_FOR_SIZE),y)
     
    154102.PHONY: all clean
    155103
    156 all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(LOUTPUT) $(EXTRA_OUTPUT)
     104all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(EXTRA_OUTPUT)
    157105        -[ -f $(DEPEND) ] && cp -a $(DEPEND) $(DEPEND_PREV)
    158106
    159107clean:
    160         rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(LARCHIVE) $(LOUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN)
     108        rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN)
    161109        find . -name '*.o' -follow -exec rm \{\} \;
    162         find . -name '*.lo' -follow -exec rm \{\} \;
    163110
    164111GCC_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \
     
    166113        -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
    167114        -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \
    168         -std=gnu99 -Werror-implicit-function-declaration -Wwrite-strings \
     115        -Werror-implicit-function-declaration -Wwrite-strings \
    169116        -pipe -g -D__$(ENDIANESS)__
    170117
     
    183130        -pipe -g -arch $(CLANG_ARCH) -D__$(ENDIANESS)__
    184131
    185 LIB_CFLAGS = $(CFLAGS) -fPIC -D__IN_SHARED_LIBC__
    186 LIB_LFLAGS = $(LFLAGS) -shared -soname $(LSONAME) --whole-archive
    187 
    188132ifeq ($(CONFIG_DEBUG),y)
    189133        GCC_CFLAGS += -Werror
     
    191135endif
    192136
    193 ifeq ($(CONFIG_LINE_DEBUG),y)
    194         GCC_CFLAGS += -g
    195         ICC_CFLAGS += -g
    196         SUNCC_CFLAGS += -g
    197         CLANG_CFLAGS += -g
    198 endif
    199 
    200137## Setup platform configuration
    201138#
     
    231168
    232169OBJECTS := $(addsuffix .o,$(basename $(SOURCES)))
    233 LOBJECTS := $(addsuffix .lo,$(basename $(SOURCES)))
    234170
    235171ifneq ($(BINARY),)
     
    242178
    243179$(BINARY): $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS)
    244         $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS)
     180        $(LD) -N $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS)
    245181ifeq ($(CONFIG_STRIP_BINARIES),y)
    246182        $(STRIP) $(BINARY)
    247183endif
    248 endif
    249 
    250 ifneq ($(SLIBRARY),)
    251 %.disasm: $(LOUTPUT)
    252 ifeq ($(CONFIG_LINE_DEBUG),y)
    253         $(OBJDUMP) -d -S $< > $@
    254 else
    255         $(OBJDUMP) -d $< > $@
    256 endif
    257 
    258 $(LOUTPUT): $(LARCHIVE) $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld
    259         $(LD) -T $(LIBC_PREFIX)/arch/$(UARCH)/_link-shlib.ld $(LIB_LFLAGS) $(LARCHIVE) -o $@ -Map $(LOUTPUT).map
    260 
    261 $(LIBRARY).so:
    262         ln -s $(SLIBRARY) $@
    263 
    264 $(LSONAME):
    265         ln -s $(SLIBRARY) $@
    266184endif
    267185
     
    269187%.a: $(OBJECTS)
    270188        $(AR) rc $@ $(OBJECTS)
    271 endif
    272 
    273 ifneq ($(SLIBRARY),)
    274 %.la: $(LOBJECTS)
    275         $(AR) rc $@ $(LOBJECTS)
    276189endif
    277190
     
    294207endif
    295208
    296 %.lo: %.S $(DEPEND)
    297         $(CC) $(DEFS) $(LIB_CFLAGS) -D__ASM__ -c $< -o $@
    298 ifeq ($(PRECHECK),y)
    299         $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(CFLAGS) -D__ASM__
    300 endif
    301 
    302 %.lo: %.s $(DEPEND)
    303         $(AS) $(AFLAGS) -o $@ $<
    304 ifeq ($(PRECHECK),y)
    305         $(JOBFILE) $(JOB) $< $@ as asm
    306 endif
    307 
    308 %.lo: %.c $(DEPEND)
    309         $(CC) $(DEFS) $(LIB_CFLAGS) -c $< -o $@
    310 ifeq ($(PRECHECK),y)
    311         $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS)
    312 endif
    313 
    314209$(DEPEND): $(PRE_DEPEND)
    315210        makedepend -f - -- $(DEPEND_DEFS) $(CFLAGS) -- $(SOURCES) > $@ 2> /dev/null
    316211        -[ -f $(DEPEND_PREV) ] && diff -q $(DEPEND_PREV) $@ && mv -f $(DEPEND_PREV) $@
    317 
    318 ##
    319 # This explicit dependecy of the output binary on the object files seems to be
    320 # necessary to prevent parallel build failures (GNU make bug #26893 ???).
    321 $(OUTPUT): $(OBJECTS)
    322 
    323 $(LARCHIVE): $(LOBJECTS)
Note: See TracChangeset for help on using the changeset viewer.