software/common: add LTO enable flag and cleanup.
authorFlorent Kermarrec <florent@enjoy-digital.fr>
Wed, 4 Mar 2020 07:11:21 +0000 (08:11 +0100)
committerFlorent Kermarrec <florent@enjoy-digital.fr>
Wed, 4 Mar 2020 07:11:21 +0000 (08:11 +0100)
litex/soc/software/common.mak

index cc2511a43068036db4912c94f962fb8a6aad4888..58cf2ad864a2434bb86e4a1b2d5107ca1c309f3d 100644 (file)
@@ -7,14 +7,20 @@ endif
 RM ?= rm -f
 PYTHON ?= python3
 
-ifeq ($(CLANG),1)
+ifneq ($(CPU), lm32)
+LTO = 0
+else
+LTO = 1
+endif
+
+ifeq ($(CLANG), 1)
 CC_normal      := clang -target $(TRIPLE) -integrated-as
 CX_normal      := clang++ -target $(TRIPLE) -integrated-as
 else
 CC_normal      := $(TARGET_PREFIX)gcc -std=gnu99
 CX_normal      := $(TARGET_PREFIX)g++
 endif
-ifneq ($(CPU), lm32)
+ifneq ($(LTO), 1)
 AR_normal      := $(TARGET_PREFIX)gcc-ar
 else
 AR_normal      := $(TARGET_PREFIX)ar
@@ -28,7 +34,7 @@ AR_quiet      = @echo " AR      " $@ && $(AR_normal)
 LD_quiet      = @echo " LD      " $@ && $(LD_normal)
 OBJCOPY_quiet = @echo " OBJCOPY " $@ && $(OBJCOPY_normal)
 
-ifeq ($(V),1)
+ifeq ($(V), 1)
        CC = $(CC_normal)
        CX = $(CX_normal)
        AR = $(AR_normal)
@@ -49,14 +55,15 @@ DEPFLAGS += -MD -MP
 
 # Toolchain options
 #
-INCLUDES = -I$(SOC_DIRECTORY)/software/include/base -I$(SOC_DIRECTORY)/software/include -I$(SOC_DIRECTORY)/common -I$(BUILDINC_DIRECTORY)
-COMMONFLAGS = $(DEPFLAGS) -Os $(CPUFLAGS) -g3 -fomit-frame-pointer -Wall -fno-builtin -nostdinc $(INCLUDES) -ffunction-sections -fdata-sections -nostartfiles -nostdlib -nodefaultlibs
-ifneq ($(CPU), lm32)
+INCLUDES    = -I$(SOC_DIRECTORY)/software/include/base -I$(SOC_DIRECTORY)/software/include -I$(SOC_DIRECTORY)/common -I$(BUILDINC_DIRECTORY)
+COMMONFLAGS = $(DEPFLAGS) -Os $(CPUFLAGS) -g3 -fomit-frame-pointer -Wall -fno-builtin -nostdinc $(INCLUDES)
+COMMONFLAGS += -ffunction-sections -fdata-sections -nostartfiles -nostdlib -nodefaultlibs
+ifneq ($(LTO), 1)
 COMMONFLAGS += -flto -fuse-linker-plugin
 endif
-CFLAGS = $(COMMONFLAGS) -fexceptions -Wstrict-prototypes -Wold-style-definition -Wmissing-prototypes
+CFLAGS   = $(COMMONFLAGS) -fexceptions -Wstrict-prototypes -Wold-style-definition -Wmissing-prototypes
 CXXFLAGS = $(COMMONFLAGS) -std=c++11 -I$(SOC_DIRECTORY)/software/include/basec++ -fexceptions -fno-rtti -ffreestanding
-LDFLAGS = -nostdlib -nodefaultlibs -Os $(CPUFLAGS) -L$(BUILDINC_DIRECTORY)
+LDFLAGS  = -nostdlib -nodefaultlibs -Os $(CPUFLAGS) -L$(BUILDINC_DIRECTORY)
 
 define compilexx
 $(CX) -c $(CXXFLAGS) $(1) $< -o $@