2007-05-15 08:09:45 +00:00
|
|
|
# $Id: Makefile.msp430,v 1.17 2007/05/15 08:09:45 adamdunkels Exp $
|
2006-06-17 22:41:10 +00:00
|
|
|
|
2006-10-09 09:15:48 +00:00
|
|
|
ifdef nodeid
|
|
|
|
CFLAGS += -DNODEID=$(nodeid)
|
|
|
|
endif
|
|
|
|
|
2006-06-17 22:41:10 +00:00
|
|
|
.SUFFIXES:
|
|
|
|
|
|
|
|
### Define the CPU directory
|
|
|
|
CONTIKI_CPU=$(CONTIKI)/cpu/msp430
|
|
|
|
|
|
|
|
### Define the source files we have in the MSP430 port
|
|
|
|
|
2007-05-13 08:41:11 +00:00
|
|
|
CONTIKI_CPU_DIRS = . dev
|
|
|
|
|
2006-12-19 09:22:25 +00:00
|
|
|
MSP430 = msp430.c flash.c clock.c leds.c leds-arch.c \
|
2007-04-03 19:05:13 +00:00
|
|
|
watchdog.c lpm.c mtarch.c uart1.c rtimer-arch.c
|
2006-06-17 22:41:10 +00:00
|
|
|
UIPDRIVERS = me.c me_tabs.c slip.c crc16.c
|
|
|
|
#UIPDRIVERS = me.c me_tabs.c crc16.c ppp/ahdlc.c ppp/ipcp.c ppp/lcp.c ppp/pap.c ppp/ppp.c ppp/ppp_process.c
|
|
|
|
SYSAPPS = codeprop-tmp.c
|
|
|
|
APPDIRS += $(CONTIKI)/apps/codeprop
|
2006-12-18 11:45:47 +00:00
|
|
|
#ELFLOADER = loader-arch.c elfloader.c elfloader-msp430.c symtab.c
|
2006-12-18 15:17:47 +00:00
|
|
|
ELFLOADER = elfloader.c elfloader-msp430.c symtab.c
|
2006-06-17 22:41:10 +00:00
|
|
|
TARGETLIBS = random.c serial.c
|
|
|
|
|
|
|
|
CONTIKI_TARGET_SOURCEFILES += $(MSP430) \
|
|
|
|
$(SYSAPPS) $(ELFLOADER) \
|
|
|
|
$(TARGETLIBS) $(UIPDRIVERS)
|
|
|
|
|
|
|
|
CONTIKI_SOURCEFILES += $(CONTIKI_TARGET_SOURCEFILES)
|
|
|
|
|
|
|
|
|
|
|
|
### Compiler definitions
|
|
|
|
CC = msp430-gcc
|
2007-01-24 16:11:48 +00:00
|
|
|
LD = msp430-gcc
|
2006-06-17 22:41:10 +00:00
|
|
|
AS = msp430-as
|
|
|
|
AR = msp430-ar
|
2007-03-22 23:57:33 +00:00
|
|
|
NM = msp430-nm
|
2006-06-17 22:41:10 +00:00
|
|
|
OBJCOPY = msp430-objcopy
|
|
|
|
STRIP = msp430-strip
|
|
|
|
BSL = msp430-bsl
|
|
|
|
CFLAGSNO = -I. -I$(CONTIKI)/core -I$(CONTIKI_CPU) \
|
|
|
|
-I$(CONTIKI)/platform/$(TARGET) \
|
|
|
|
${addprefix -I,$(APPDIRS)} \
|
2007-05-15 08:09:45 +00:00
|
|
|
-DWITH_ASCII \
|
2006-06-17 22:41:10 +00:00
|
|
|
-Wall -mmcu=$(MCU) -g
|
|
|
|
CFLAGS += $(CFLAGSNO) -Os
|
2006-06-22 14:24:49 +00:00
|
|
|
LDFLAGS += -mmcu=$(MCU) -Wl,-Map=contiki-$(TARGET).map
|
2006-06-17 22:41:10 +00:00
|
|
|
|
|
|
|
PROJECT_OBJECTFILES += ${addprefix $(OBJECTDIR)/,$(CONTIKI_TARGET_MAIN:.c=.o)}
|
|
|
|
|
|
|
|
### Compilation rules
|
|
|
|
|
|
|
|
%-stripped.o: %.c
|
|
|
|
$(CC) $(CFLAGS) -c $< -o $@
|
|
|
|
$(STRIP) --strip-unneeded -g -x $@
|
|
|
|
|
|
|
|
%.cm: %.co
|
|
|
|
$(LD) -i -r --unresolved-symbols=ignore-in-object-files -mmsp430x149 -o $@ $^
|
|
|
|
$(STRIP) --strip-unneeded -g -x $@
|
|
|
|
|
|
|
|
%-stripped.o: %.o
|
|
|
|
$(STRIP) --strip-unneeded -g -x -o $@ $<
|
|
|
|
|
|
|
|
%.o: ${CONTIKI_TARGET}/loader/%.S
|
|
|
|
$(AS) -o $(notdir $(<:.S=.o)) $<
|
|
|
|
|
|
|
|
%.firmware: %.co $(PROJECT_OBJECTFILES) contiki-$(TARGET).a
|
|
|
|
$(CC) $(LDFLAGS) $(CFLAGS) -o $@ $(filter-out %.a,$^) $(filter %.a,$^)
|
|
|
|
|
|
|
|
%.ihex: %.firmware
|
|
|
|
$(OBJCOPY) $^ -O ihex $@
|
|
|
|
|
|
|
|
core-labels.o: core.firmware
|
|
|
|
${CONTIKI}/tools/msp430-make-labels core.firmware > core-labels.S
|
|
|
|
$(AS) -o $@ core-labels.S
|
|
|
|
# cp core-labels.o app/
|
|
|
|
|
|
|
|
core-globals.o: core.firmware
|
|
|
|
${CONTIKI}/tools/msp430-make-globals core.firmware > core-globals.S
|
|
|
|
$(AS) -o $@ core-globals.S
|
|
|
|
|
|
|
|
loader-init.o: ${CONTIKI_TARGET}/loader/loader-init.S
|
|
|
|
$(AS) -o $(notdir $(<:.S=.o)) $<
|
|
|
|
# cp loader-init.o build-app/
|
|
|
|
|
2006-12-19 09:22:25 +00:00
|
|
|
.PHONY: symbols.c symbols.h
|
|
|
|
ifdef CORE
|
2007-01-24 16:11:48 +00:00
|
|
|
symbols.c:
|
|
|
|
# @${CONTIKI}/tools/msp430-make-symbols $(CORE)
|
|
|
|
$(NM) $(CORE) | awk -f ../../tools/mknmlist > symbols.c
|
2006-12-19 09:22:25 +00:00
|
|
|
else
|
|
|
|
symbols.c symbols.h:
|
|
|
|
@${CONTIKI}/tools/make-empty-symbols
|
|
|
|
endif
|