2014-05-14 04:24:56 -04:00
|
|
|
include $(MSCDIR)/software/include/generated/cpu.mak
|
2015-07-25 20:28:37 -04:00
|
|
|
TARGET_PREFIX=$(TRIPLE)-
|
2012-02-03 06:08:17 -05:00
|
|
|
|
2013-05-10 16:30:28 -04:00
|
|
|
RM ?= rm -f
|
|
|
|
|
2015-07-26 09:06:48 -04:00
|
|
|
ifeq ($(CLANG),1)
|
2015-07-28 04:51:28 -04:00
|
|
|
CC_normal := clang -target $(TRIPLE) -integrated-as
|
|
|
|
CX_normal := clang++ -target $(TRIPLE) -integrated-as
|
2015-07-26 03:00:58 -04:00
|
|
|
else
|
|
|
|
CC_normal := $(TARGET_PREFIX)gcc
|
|
|
|
CX_normal := $(TARGET_PREFIX)g++
|
|
|
|
endif
|
2015-07-25 20:28:37 -04:00
|
|
|
AR_normal := $(TARGET_PREFIX)ar
|
|
|
|
LD_normal := $(TARGET_PREFIX)ld
|
2013-02-16 17:41:42 -05:00
|
|
|
OBJCOPY_normal := $(TARGET_PREFIX)objcopy
|
2012-02-03 06:08:17 -05:00
|
|
|
|
2015-07-25 20:28:37 -04:00
|
|
|
CC_quiet = @echo " CC " $@ && $(CC_normal)
|
|
|
|
CX_quiet = @echo " CX " $@ && $(CX_normal)
|
|
|
|
AR_quiet = @echo " AR " $@ && $(AR_normal)
|
|
|
|
LD_quiet = @echo " LD " $@ && $(LD_normal)
|
|
|
|
OBJCOPY_quiet = @echo " OBJCOPY " $@ && $(OBJCOPY_normal)
|
2012-02-03 06:08:17 -05:00
|
|
|
|
2015-05-02 12:42:33 -04:00
|
|
|
MSC_GIT_ID := $(shell cd $(MSCDIR) && python3 -c "from misoclib.cpu.identifier import get_id; print(hex(get_id()), end='')")
|
2013-11-09 10:38:44 -05:00
|
|
|
|
2012-02-03 06:08:17 -05:00
|
|
|
ifeq ($(V),1)
|
2013-01-10 11:20:31 -05:00
|
|
|
CC = $(CC_normal)
|
2013-03-24 11:11:53 -04:00
|
|
|
CX = $(CX_normal)
|
2013-01-10 11:20:31 -05:00
|
|
|
AR = $(AR_normal)
|
|
|
|
LD = $(LD_normal)
|
|
|
|
OBJCOPY = $(OBJCOPY_normal)
|
2012-02-03 06:08:17 -05:00
|
|
|
else
|
2013-01-10 11:20:31 -05:00
|
|
|
CC = $(CC_quiet)
|
2013-03-24 11:11:53 -04:00
|
|
|
CX = $(CX_quiet)
|
2013-01-10 11:20:31 -05:00
|
|
|
AR = $(AR_quiet)
|
|
|
|
LD = $(LD_quiet)
|
|
|
|
OBJCOPY = $(OBJCOPY_quiet)
|
2012-02-03 06:08:17 -05:00
|
|
|
endif
|
|
|
|
|
|
|
|
# Toolchain options
|
|
|
|
#
|
2013-11-09 09:27:32 -05:00
|
|
|
INCLUDES = -I$(MSCDIR)/software/include/base -I$(MSCDIR)/software/include -I$(MSCDIR)/common
|
2015-07-28 04:51:28 -04:00
|
|
|
COMMONFLAGS = -Os $(CPUFLAGS) -fomit-frame-pointer -Wall -fno-builtin -nostdinc -DMSC_GIT_ID=$(MSC_GIT_ID) $(INCLUDES)
|
2015-07-25 20:30:21 -04:00
|
|
|
CFLAGS = $(COMMONFLAGS) -fexceptions -Wstrict-prototypes -Wold-style-definition -Wmissing-prototypes
|
2015-07-26 05:49:02 -04:00
|
|
|
CXXFLAGS = $(COMMONFLAGS) -std=c++11 -I$(MSCDIR)/software/include/basec++ -fexceptions -fno-rtti -ffreestanding
|
2013-11-24 13:50:17 -05:00
|
|
|
LDFLAGS = -nostdlib -nodefaultlibs -L$(MSCDIR)/software/include
|
2012-02-03 06:25:55 -05:00
|
|
|
|
|
|
|
# compile and generate dependencies, based on
|
|
|
|
# http://scottmcpeak.com/autodepend/autodepend.html
|
|
|
|
|
2013-03-24 11:11:53 -04:00
|
|
|
define compilexx-dep
|
2013-05-19 06:41:40 -04:00
|
|
|
$(CX) -c $(CXXFLAGS) $(1) $< -o $*.o
|
|
|
|
@$(CX_normal) -MM $(CXXFLAGS) $(1) $< > $*.d
|
2013-03-24 11:11:53 -04:00
|
|
|
@mv -f $*.d $*.d.tmp
|
|
|
|
@sed -e 's|.*:|$*.o:|' < $*.d.tmp > $*.d
|
|
|
|
@sed -e 's/.*://' -e 's/\\$$//' < $*.d.tmp | fmt -1 | \
|
|
|
|
sed -e 's/^ *//' -e 's/$$/:/' >> $*.d
|
|
|
|
@rm -f $*.d.tmp
|
|
|
|
endef
|
|
|
|
|
2013-01-10 11:20:31 -05:00
|
|
|
define compile-dep
|
2013-05-19 06:41:40 -04:00
|
|
|
$(CC) -c $(CFLAGS) $(1) $< -o $*.o
|
|
|
|
@$(CC_normal) -MM $(CFLAGS) $(1) $< > $*.d
|
2012-05-31 14:17:33 -04:00
|
|
|
@mv -f $*.d $*.d.tmp
|
|
|
|
@sed -e 's|.*:|$*.o:|' < $*.d.tmp > $*.d
|
|
|
|
@sed -e 's/.*://' -e 's/\\$$//' < $*.d.tmp | fmt -1 | \
|
|
|
|
sed -e 's/^ *//' -e 's/$$/:/' >> $*.d
|
|
|
|
@rm -f $*.d.tmp
|
2013-01-10 11:20:31 -05:00
|
|
|
endef
|
|
|
|
|
|
|
|
define assemble
|
2014-05-14 04:24:56 -04:00
|
|
|
$(CC) -c $(CFLAGS) -o $*.o $<
|
2012-05-31 14:17:33 -04:00
|
|
|
endef
|