56 lines
1.1 KiB
Makefile
56 lines
1.1 KiB
Makefile
LINKERSCRIPT = $(MC1322X)/mc1322x.lds
|
|
LIBMC1322X = $(MC1322X)/libmc1322x
|
|
|
|
include $(MC1322X)/config.mk
|
|
|
|
include $(MC1322X)/board/Makefile.board
|
|
|
|
include $(MC1322X)/libmc1322x/Makefile.lib
|
|
|
|
# default start and isr
|
|
ifndef START
|
|
START = $(MC1322X)/src/start.o
|
|
endif
|
|
ifndef ISR
|
|
ISR = $(MC1322X)/src/isr.o
|
|
endif
|
|
|
|
ARCH = arm
|
|
CPU = arm7tdmi-s
|
|
export ARCH CPU VENDOR
|
|
|
|
.SECONDARY:
|
|
|
|
$(START): $(START:.o=.s)
|
|
$(CC) $(AFLAGS) -c -o $@ $<
|
|
|
|
$(ISR): $(ISR:.o=.c)
|
|
$(CC) $(CFLAGS) $(ARM_FLAGS) $< -c -o $@
|
|
|
|
%_$(BOARD).elf: %.elf
|
|
mv $< $@
|
|
|
|
%.elf: $(START) $(ISR) $(OBJDIR)/%.o $(LINKERSCRIPT) board
|
|
$(LD) $(LDFLAGS) $(AOBJS) \
|
|
--start-group $(PLATFORM_LIBS) --end-group \
|
|
$(filter %.o %.a,$+) -o $@
|
|
|
|
$(OBJDIR)/%.s: %.S
|
|
$(CPP) $(AFLAGS) -o $@ $<
|
|
$(OBJDIR)/%.o: %.S
|
|
$(CC) $(AFLAGS) -c -o $@ $<
|
|
$(OBJDIR)/%.o: %.c
|
|
$(CC) $(CFLAGS) $(THUMB_FLAGS) -c -o $@ $<
|
|
|
|
|
|
clean:
|
|
find $(MC1322X) -type f \
|
|
\( -name 'core' -o -name '*.bak' -o -name '*~' \
|
|
-o -name '*.o' -o -name '*.a' -o -name '*.obj' -o -name '*.elf' -o -name '*.s' -o -name '*.map' \) -print \
|
|
| xargs rm -f
|
|
rm -fr *.*~
|
|
|
|
clobber \
|
|
mrproper \
|
|
distclean: clean
|