58 lines
1.7 KiB
Makefile
58 lines
1.7 KiB
Makefile
# Mico32 toolchain
|
|
#
|
|
CROSS_COMPILER=lm32-rtems4.11-
|
|
|
|
CC_normal := $(CROSS_COMPILER)gcc
|
|
AR_normal := $(CROSS_COMPILER)ar
|
|
AS_normal := $(CROSS_COMPILER)as
|
|
LD_normal := $(CROSS_COMPILER)ld
|
|
OBJCOPY_normal := $(CROSS_COMPILER)objcopy
|
|
RANLIB_normal := $(CROSS_COMPILER)ranlib
|
|
|
|
CC_quiet = @echo " CC " $@ && $(CROSS_COMPILER)gcc
|
|
AR_quiet = @echo " AR " $@ && $(CROSS_COMPILER)ar
|
|
AS_quiet = @echo " AS " $@ && $(CROSS_COMPILER)as
|
|
LD_quiet = @echo " LD " $@ && $(CROSS_COMPILER)ld
|
|
OBJCOPY_quiet = @echo " OBJCOPY " $@ && $(CROSS_COMPILER)objcopy
|
|
RANLIB_quiet = @echo " RANLIB " $@ && $(CROSS_COMPILER)ranlib
|
|
|
|
ifeq ($(V),1)
|
|
CC = $(CC_normal)
|
|
AR = $(AR_normal)
|
|
AS = $(AS_normal)
|
|
LD = $(LD_normal)
|
|
OBJCOPY = $(OBJCOPY_normal)
|
|
RANLIB = $(RANLIB_normal)
|
|
else
|
|
CC = $(CC_quiet)
|
|
AR = $(AR_quiet)
|
|
AS = $(AS_quiet)
|
|
LD = $(LD_quiet)
|
|
OBJCOPY = $(OBJCOPY_quiet)
|
|
RANLIB = $(RANLIB_quiet)
|
|
endif
|
|
|
|
# Toolchain options
|
|
#
|
|
INCLUDES_NOLIBC ?= -nostdinc -I$(M2DIR)/software/include/base
|
|
INCLUDES = $(INCLUDES_NOLIBC) -I$(M2DIR)/software/include -I$(M2DIR)/tools
|
|
ASFLAGS = $(INCLUDES) -nostdinc
|
|
# later: -Wmissing-prototypes
|
|
CFLAGS = -O9 -Wall -Wstrict-prototypes -Wold-style-definition -Wshadow \
|
|
-mbarrel-shift-enabled -mmultiply-enabled -mdivide-enabled \
|
|
-msign-extend-enabled -fno-builtin -fsigned-char \
|
|
-fsingle-precision-constant $(INCLUDES)
|
|
LDFLAGS = -nostdlib -nodefaultlibs
|
|
|
|
# compile and generate dependencies, based on
|
|
# http://scottmcpeak.com/autodepend/autodepend.html
|
|
|
|
%.o: %.c
|
|
$(CC) -c $(CFLAGS) $*.c -o $*.o
|
|
@$(CC_normal) -MM $(CFLAGS) $*.c > $*.d
|
|
@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
|