# 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$(MMDIR)/software/include/base INCLUDES = $(INCLUDES_NOLIBC) -I$(MMDIR)/software/include -I$(MMDIR)/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