X-Git-Url: https://git.rohieb.name/hackover2013-badge-firmware.git/blobdiff_plain/700dfdd70ef5746bc0becaf93e77017e00f5b3b1..adf69ed4aa95d022041388b89a40ecdeb401c4fd:/Makefile

diff --git a/Makefile b/Makefile
index 2151859..97eda7a 100644
--- a/Makefile
+++ b/Makefile
@@ -11,9 +11,7 @@ SRAM = 8K
 # For USB HID support the LPC134x reserves 384 bytes from the sram,
 # if you don't want to use the USB features, just use 0 here.
 SRAM_USB = 384
-
-VPATH = 
-OBJS = main.o
+#SRAM_USB = 0
 
 ##########################################################################
 # Debug settings
@@ -27,135 +25,247 @@ DEBUGBUILD = FALSE
 # IDE Flags (Keeps various IDEs happy)
 ##########################################################################
 
-OPTDEFINES = -D __NEWLIB__
-
+OPTDEFINES = -D__NEWLIB__
+#OPTDEFINES += -DR0KET
+#OPTDEFINES += -DUSBONLY
 ##########################################################################
 # Project-specific files 
 ##########################################################################
 
-VPATH += project
-OBJS += commands.o
-
-VPATH += project/commands
-OBJS += cmd_chibi_addr.o cmd_chibi_tx.o
-OBJS += cmd_i2ceeprom_read.o cmd_i2ceeprom_write.o cmd_lm75b_gettemp.o
-OBJS += cmd_reset.o cmd_sd_dir.o cmd_sysinfo.o cmd_uart.o 
-OBJS += cmd_roundedcorner.o cmd_pwm.o
-
-VPATH += project/commands/drawing
-OBJS += cmd_backlight.o cmd_bmp.o cmd_button.o cmd_calibrate.o
-OBJS += cmd_circle.o cmd_clear.o cmd_line.o cmd_orientation.o
-OBJS += cmd_pixel.o cmd_progress.o cmd_rectangle.o cmd_text.o
-OBJS += cmd_textw.o cmd_tsthreshhold.o cmd_tswait.o cmd_triangle.o
+SRCS = \
+  badge/fahrplan.c \
+  badge/backlight.c \
+  badge/init.c \
+  badge/main.c \
+  badge/jumpnrun/collision.c \
+  badge/jumpnrun/enemies.c \
+  badge/jumpnrun/game_state.c \
+  badge/jumpnrun/items.c \
+  badge/jumpnrun/jumpnrun.c \
+  badge/jumpnrun/level_load.c \
+  badge/jumpnrun/player.c \
+  badge/jumpnrun/render.c \
+  badge/jumpnrun/shots.c \
+  badge/jumpnrun/starter.c \
+  badge/jumpnrun/stats.c \
+  badge/jumpnrun/tiles.c \
+  badge/ui/browser.c \
+  badge/ui/display.c \
+  badge/ui/event.c \
+  badge/ui/font.c \
+  badge/ui/menu.c \
+  badge/ui/sprite.c \
+  badge/ui/vanity.c
+
+SRCS += \
+  dataflash/iobase.c \
+  dataflash/diskio.c \
+  dataflash/at45db041d.c
+
+SRCS += \
+  funk/nrf24l01p.c
+
+SRCS += \
+  project/commands.c
+
+SRCS += \
+  project/commands/cmd_chibi_addr.c \
+  project/commands/cmd_chibi_tx.c \
+  project/commands/cmd_i2ceeprom_read.c \
+  project/commands/cmd_i2ceeprom_write.c \
+  project/commands/cmd_lm75b_gettemp.c \
+  project/commands/cmd_reset.c \
+  project/commands/cmd_sd_dir.c \
+  project/commands/cmd_sysinfo.c \
+  project/commands/cmd_uart.c \
+  project/commands/cmd_pwm.c
+
+SRCS += \
+  project/commands/drawing/cmd_backlight.c \
+  project/commands/drawing/cmd_bmp.c \
+  project/commands/drawing/cmd_button.c \
+  project/commands/drawing/cmd_calibrate.c \
+  project/commands/drawing/cmd_circle.c \
+  project/commands/drawing/cmd_clear.c \
+  project/commands/drawing/cmd_line.c \
+  project/commands/drawing/cmd_orientation.c \
+  project/commands/drawing/cmd_pixel.c \
+  project/commands/drawing/cmd_progress.c \
+  project/commands/drawing/cmd_rectangle.c \
+  project/commands/drawing/cmd_roundedcorner.c \
+  project/commands/drawing/cmd_text.c \
+  project/commands/drawing/cmd_textw.c \
+  project/commands/drawing/cmd_tsthreshhold.c \
+  project/commands/drawing/cmd_tswait.c \
+  project/commands/drawing/cmd_triangle.c
 
 ##########################################################################
 # Optional driver files 
 ##########################################################################
 
 # Chibi Light-Weight Wireless Stack (AT86RF212)
-VPATH += drivers/rf/chibi
-OBJS += chb.o chb_buf.o chb_drvr.o chb_eeprom.o chb_spi.o
+SRCS += \
+  drivers/rf/chibi/chb.c \
+  drivers/rf/chibi/chb_buf.c \
+  drivers/rf/chibi/chb_drvr.c \
+  drivers/rf/chibi/chb_eeprom.c \
+  drivers/rf/chibi/chb_spi.c
 
 # 4K EEPROM
-VPATH += drivers/storage/eeprom drivers/storage/eeprom/mcp24aa
-OBJS += eeprom.o mcp24aa.o
+SRCS += \
+  drivers/storage/eeprom/eeprom.c \
+  drivers/storage/eeprom/mcp24aa/mcp24aa.c
 
 # LM75B temperature sensor
-VPATH += drivers/sensors/lm75b
-OBJS += lm75b.o
+SRCS += \
+  drivers/sensors/lm75b/lm75b.c
 
 # ISL12022M RTC
-VPATH += drivers/rtc/isl12022m
-OBJS += isl12022m.o
+SRCS += \
+  drivers/rtc/isl12022m/isl12022m.c
 
 # TFT LCD support
-VPATH += drivers/displays/tft drivers/displays/tft/hw 
-OBJS += drawing.o touchscreen.o colors.o theme.o bmp.o
+SRCS += \
+  drivers/displays/tft/drawing.c \
+  drivers/displays/tft/touchscreen.c \
+  drivers/displays/tft/colors.c \
+  drivers/displays/tft/theme.c \
+  drivers/displays/tft/bmp.c
 
 # GUI Controls
-VPATH += drivers/displays/tft/controls
-OBJS += button.o hsbchart.o huechart.o label.o
-OBJS += labelcentered.o progressbar.o
+SRCS += \
+  drivers/displays/tft/controls/button.c \
+  drivers/displays/tft/controls/hsbchart.c \
+  drivers/displays/tft/controls/huechart.c \
+  drivers/displays/tft/controls/label.c \
+  drivers/displays/tft/controls/labelcentered.c \
+  drivers/displays/tft/controls/progressbar.c
 
 # Bitmap (non-AA) fonts
-VPATH += drivers/displays/tft/fonts
-OBJS += fonts.o 
-OBJS += dejavusans9.o dejavusansbold9.o dejavusanscondensed9.o
-OBJS += dejavusansmono8.o dejavusansmonobold8.o
-OBJS += verdana9.o verdana14.o verdanabold14.o 
+SRCS += \
+  drivers/displays/tft/fonts.c \
+  drivers/displays/tft/fonts/dejavusans9.c \
+  drivers/displays/tft/fonts/dejavusansbold9.c \
+  drivers/displays/tft/fonts/dejavusanscondensed9.c \
+  drivers/displays/tft/fonts/dejavusansmono8.c \
+  drivers/displays/tft/fonts/dejavusansmonobold8.c \
+  drivers/displays/tft/fonts/verdana9.c \
+  drivers/displays/tft/fonts/verdana14.c \
+  drivers/displays/tft/fonts/verdanabold14.c
 
 # Anti-aliased fonts
-VPATH += drivers/displays/tft/aafonts/aa2 drivers/displays/tft/aafonts/aa4
-OBJS += aafonts.o 
-OBJS += DejaVuSansCondensed14_AA2.o DejaVuSansCondensedBold14_AA2.o
-OBJS += DejaVuSansMono10_AA2.o DejaVuSansMono13_AA2.o DejaVuSansMono14_AA2.o
+SRCS += \
+  drivers/displays/tft/aafonts.c \
+  drivers/displays/tft/aafonts/aa2/DejaVuSansCondensed14_AA2.c \
+  drivers/displays/tft/aafonts/aa2/DejaVuSansCondensedBold14_AA2.c \
+  drivers/displays/tft/aafonts/aa2/DejaVuSansMono10_AA2.c \
+  drivers/displays/tft/aafonts/aa2/DejaVuSansMono13_AA2.c \
+  drivers/displays/tft/aafonts/aa2/DejaVuSansMono14_AA2.c
 
 # LCD Driver (Only one can be included at a time!)
-# OBJS += hx8340b.o
-OBJS += ILI9328.o
-# OBJS += ILI9325.o
-# OBJS += ssd1331.o
-# OBJS += ssd1351.o
-# OBJS += st7735.o
-# OBJS += st7783.o
+# SRCS += drivers/displays/tft/hw/hx8340b.c
+# SRCS += drivers/displays/tft/hw/hx8347d.c
+# SRCS += drivers/displays/tft/hw/ILI9328.c
+# SRCS += drivers/displays/tft/hw/ILI9325.c
+# SRCS += drivers/displays/tft/hw/ssd1331.c
+# SRCS += drivers/displays/tft/hw/ssd1351.c
+# SRCS += drivers/displays/tft/hw/st7735.c
+# SRCS += drivers/displays/tft/hw/st7783.c
 
 # Bitmap/Monochrome LCD support (ST7565, SSD1306, etc.)
-VPATH += drivers/displays
-VPATH += drivers/displays/bitmap/sharpmem
-VPATH += drivers/displays/bitmap/st7565
-VPATH += drivers/displays/bitmap/ssd1306
-OBJS += smallfonts.o sharpmem.o st7565.o ssd1306.o
+SRCS += \
+  drivers/displays/smallfonts.c \
+  drivers/displays/bitmap/sharpmem/sharpmem.c \
+  drivers/displays/bitmap/st7565/st7565.c \
+  drivers/displays/bitmap/ssd1306/ssd1306.c
 
 #Character Displays (VFD text displays, etc.)
-VPATH += drivers/displays/character/samsung_20T202DA2JA
-OBJS += samsung_20T202DA2JA.o
+SRCS += \
+  drivers/displays/character/samsung_20T202DA2JA/samsung_20T202DA2JA.c
 
 # ChaN FatFS and SD card support
-VPATH += drivers/fatfs
-OBJS += ff.o mmc.o
+SRCS += \
+  drivers/fatfs/ff.c 
+# drivers/fatfs/mmc.c
 
 # Motors
-VPATH += drivers/motor/stepper
-OBJS += stepper.o
+SRCS += \
+  drivers/motor/stepper/stepper.c
 
 # RSA Encryption/Descryption
-VPATH += drivers/rsa
-OBJS += rsa.o
+SRCS += \
+  drivers/rsa/rsa.c
 
 # DAC
-VPATH += drivers/dac/mcp4725 drivers/dac/mcp4901
-OBJS += mcp4725.o mcp4901.o
+SRCS += \
+  drivers/dac/mcp4725/mcp4725.c \
+  drivers/dac/mcp4901/mcp4901.c
 
 # RFID/NFC
-VPATH += drivers/rf/pn532 drivers/rf/pn532/helpers
-OBJS += pn532.o pn532_bus_i2c.o pn532_bus_uart.o
-OBJS += pn532_mifare_classic.o pn532_mifare_ultralight.o
+SRCS += \
+  drivers/rf/pn532/pn532.c \
+  drivers/rf/pn532/pn532_bus_i2c.c \
+  drivers/rf/pn532/pn532_bus_uart.c \
+  drivers/rf/pn532/helpers/pn532_mifare_classic.c \
+  drivers/rf/pn532/helpers/pn532_mifare_ultralight.c
 
 # TAOS Light Sensors
-VPATH += drivers/sensors/tcs3414 drivers/sensors/tsl2561
-OBJS += tcs3414.o tsl2561.o
+SRCS += \
+  drivers/sensors/tcs3414/tcs3414.c \
+  drivers/sensors/tsl2561/tsl2561.c
 
 # SPI Flash
-VPATH += drivers/storage/spiflash/w25q16bv
-OBJS += w25q16bv.o
+SRCS += \
+  drivers/storage/spiflash/w25q16bv/w25q16bv.c
 
 # FM Radio
-VPATH += drivers/audio/tea5767
-OBJS += tea5767.o
+SRCS += \
+  drivers/audio/tea5767/tea5767.c
+
+# IN219 Current Sensor
+SRCS += \
+  drivers/sensors/ina219/ina219.c
+
+# MPL115A2 Barometric Pressure Sensor
+SRCS += \
+  drivers/sensors/mpl115a2/mpl115a2.c
+
+# ADS1015 12-bit ADC
+SRCS += \
+  drivers/adc/ads1015/ads1015.c
 
 ##########################################################################
 # Library files 
 ##########################################################################
 
-VPATH += core core/adc core/cmd core/cpu core/gpio core/i2c core/pmu
-VPATH += core/ssp core/systick core/timer16 core/timer32 core/uart
-VPATH += core/usbhid-rom core/wdt core/usbcdc core/pwm core/iap
-VPATH += core/libc
-OBJS += stdio.o string.o
-OBJS += adc.o cpu.o cmd.o gpio.o i2c.o pmu.o ssp.o systick.o timer16.o
-OBJS += timer32.o uart.o uart_buf.o usbconfig.o usbhid.o
-OBJS += wdt.o cdcuser.o cdc_buf.o usbcore.o usbdesc.o usbhw.o usbuser.o 
-OBJS += sysinit.o pwm.o iap.o
+SRCS += \
+  core/adc/adc.c \
+  core/cmd/cmd.c \
+  core/cpu/cpu.c \
+  core/gpio/gpio.c \
+  core/iap/iap.c \
+  core/libc/stdio.c \
+  core/libc/string.c \
+  core/pmu/pmu.c \
+  core/pwm/pwm.c \
+  core/ssp/ssp.c \
+  core/systick/systick.c \
+  core/timer16/timer16.c \
+  core/timer32/timer32.c \
+  core/usbcdc/cdc_buf.c \
+  core/usbcdc/cdcuser.c \
+  core/usbcdc/usbcore.c \
+  core/usbcdc/usbdesc.c \
+  core/usbcdc/usbhw.c \
+  core/usbcdc/usbuser.c \
+  core/usbhid-rom/usbconfig.c \
+  core/usbhid-rom/usbhid.c \
+  core/usbhid-rom/usbmsc.c \
+  core/wdt/wdt.c
+
+#  core/i2c/i2c.c
+#  core/uart/uart_buf.c
+#  core/uart/uart.c
 
 ##########################################################################
 # GNU GCC compiler prefix and location
@@ -169,6 +279,8 @@ SIZE = $(CROSS_COMPILE)size
 OBJCOPY = $(CROSS_COMPILE)objcopy
 OBJDUMP = $(CROSS_COMPILE)objdump
 OUTFILE = firmware
+
+CC_FOR_BUILD = gcc
 LPCRC = ./lpcrc
 
 ##########################################################################
@@ -192,17 +304,22 @@ else
 endif
 
 CPU_TYPE = cortex-$(CORTEX_TYPE)
-VPATH += lpc1xxx
-OBJS += $(TARGET)_handlers.o LPC1xxx_startup.o
+
+SRCS += \
+  lpc1xxx/$(TARGET)_handlers.c \
+  lpc1xxx/LPC1xxx_startup.c
+
+OBJS = $(SRCS:%.c=%.o)
+DEPS = $(SRCS:%.c=%.dep)
 
 ##########################################################################
 # Compiler settings, parameters and flags
 ##########################################################################
 ifeq (TRUE,$(DEBUGBUILD))
-  CFLAGS  = -c -g -O0 $(INCLUDE_PATHS) -Wall -mthumb -ffunction-sections -fdata-sections -fmessage-length=0 -mcpu=$(CPU_TYPE) -DTARGET=$(TARGET) -fno-builtin $(OPTDEFINES)
+  CFLAGS  = -c -g -O0 $(INCLUDE_PATHS) -Wall -mthumb -ffunction-sections -fdata-sections -fmessage-length=0 -mcpu=$(CPU_TYPE) -DTARGET=$(TARGET) -fno-builtin $(OPTDEFINES) -std=c99
   ASFLAGS = -c -g -O0 $(INCLUDE_PATHS) -Wall -mthumb -ffunction-sections -fdata-sections -fmessage-length=0 -mcpu=$(CPU_TYPE) -D__ASSEMBLY__ -x assembler-with-cpp
 else
-  CFLAGS  = -c -g -Os $(INCLUDE_PATHS) -Wall -mthumb -ffunction-sections -fdata-sections -fmessage-length=0 -mcpu=$(CPU_TYPE) -DTARGET=$(TARGET) -fno-builtin $(OPTDEFINES)
+  CFLAGS  = -c -g -Os $(INCLUDE_PATHS) -Wall -mthumb -ffunction-sections -fdata-sections -fmessage-length=0 -mcpu=$(CPU_TYPE) -DTARGET=$(TARGET) -fno-builtin $(OPTDEFINES) -std=c99
   ASFLAGS = -c -g -Os $(INCLUDE_PATHS) -Wall -mthumb -ffunction-sections -fdata-sections -fmessage-length=0 -mcpu=$(CPU_TYPE) -D__ASSEMBLY__ -x assembler-with-cpp
 endif
 
@@ -210,30 +327,55 @@ LDFLAGS = -nostartfiles -mthumb -mcpu=$(CPU_TYPE) -Wl,--gc-sections
 LDLIBS  = -lm
 OCFLAGS = --strip-unneeded
 
-all: firmware
+all: dep size $(OUTFILE).bin $(OUTFILE).hex
 
-%.o : %.c
-	$(CC) $(CFLAGS) -o $@ $<
+dep: $(DEPS)
 
-%.o : %.s
-	$(AS) $(ASFLAGS) -o $@ $<
+$(DEPS) : %.dep : %.c
+	$(CC) $(CPPFLAGS) $(CFLAGS) -MM $< -MT $@ -MT $(@:%.dep=%.o) -MF $@
 
-firmware: $(OBJS) $(SYS_OBJS)
+sinclude $(DEPS)
+
+$(LD_TEMP): 
 	-@echo "MEMORY" > $(LD_TEMP)
 	-@echo "{" >> $(LD_TEMP)
 	-@echo "  flash(rx): ORIGIN = 0x00000000, LENGTH = $(FLASH)" >> $(LD_TEMP)
 	-@echo "  sram(rwx): ORIGIN = 0x10000000+$(SRAM_USB), LENGTH = $(SRAM)-$(SRAM_USB)" >> $(LD_TEMP)
 	-@echo "}" >> $(LD_TEMP)
 	-@echo "INCLUDE $(LD_SCRIPT)" >> $(LD_TEMP)
+
+$(OUTFILE).elf: $(OBJS) $(LD_TEMP)
 	$(LD) $(LDFLAGS) -T $(LD_TEMP) -o $(OUTFILE).elf $(OBJS) $(LDLIBS)
-	-@echo ""
-	$(SIZE) $(OUTFILE).elf
-	-@echo ""
-	$(OBJCOPY) $(OCFLAGS) -O binary $(OUTFILE).elf $(OUTFILE).bin
+
+$(OUTFILE).bin: $(OUTFILE).elf $(LPCRC)
 	$(OBJCOPY) $(OCFLAGS) -O binary $(OUTFILE).elf $(OUTFILE).bin
+	$(LPCRC) $(OUTFILE).bin
+
+$(OUTFILE).hex: $(OUTFILE).elf
 	$(OBJCOPY) $(OCFLAGS) -O ihex $(OUTFILE).elf $(OUTFILE).hex
-	-@echo ""
-	$(LPCRC) firmware.bin
+
+size: $(OUTFILE).elf
+	$(SIZE) $(OUTFILE).elf
 
 clean:
 	rm -f $(OBJS) $(LD_TEMP) $(OUTFILE).elf $(OUTFILE).bin $(OUTFILE).hex
+
+distclean: clean
+	rm -f $(DEPS) $(LPCRC)
+
+.PHONY: all dep size clean distclean
+
+CFLAGS_FOR_BUILD = -Wall -Wextra -std=c99 -O0 -g
+
+LPCRC_SRCS = tools/lpcrc/lpcrc.c
+LPCRC_OBJS = $(LPCRC_SRCS:%.c=%.o)
+LPCRC_DEPS = $(LPCRC_SRCS:%.c=%.dep)
+
+$(LPCRC_DEPS) : %.dep : %.c
+	$(CC_FOR_BUILD) $(CPPFLAGS_FOR_BUILD) $(CFLAGS_FOR_BUILD) -MM $< -MT $@ -MT $(@:%.dep=%.o) -MF $@
+
+$(LPCRC_OBJS): %.o : %.c
+	$(CC_FOR_BUILD) $(CPPFLAGS_FOR_BUILD) $(CFLAGS_FOR_BUILD) -o $@ -c $<
+
+$(LPCRC):  $(LPCRC_OBJS)
+	$(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) $(LDFLAGS_FOR_BUILD) -o $@ $+ $(LDLIBS_FOR_BUILD)