Makefile 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. ##############################################################################
  2. BUILD = build
  3. BIN = free_dap_m484_nobl
  4. ##############################################################################
  5. .PHONY: all directory clean size
  6. CC = arm-none-eabi-gcc
  7. OBJCOPY = arm-none-eabi-objcopy
  8. SIZE = arm-none-eabi-size
  9. ifeq ($(OS), Windows_NT)
  10. MKDIR = gmkdir
  11. else
  12. MKDIR = mkdir
  13. endif
  14. CFLAGS += -W -Wall --std=gnu11 -Os
  15. CFLAGS += -fno-diagnostics-show-caret
  16. CFLAGS += -fdata-sections -ffunction-sections
  17. CFLAGS += -funsigned-char -funsigned-bitfields
  18. CFLAGS += -mcpu=cortex-m4 -mthumb
  19. CFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16
  20. CFLAGS += -MD -MP -MT $(BUILD)/$(*F).o -MF $(BUILD)/$(@F).d
  21. LDFLAGS += -mcpu=cortex-m4 -mthumb
  22. LDFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16
  23. LDFLAGS += -Wl,--gc-sections
  24. LDFLAGS += -Wl,--script=../linker/m484.ld
  25. INCLUDES += \
  26. -I../include \
  27. -I../usb \
  28. -I../../.. \
  29. -I..
  30. SRCS += \
  31. ../main.c \
  32. ../uart.c \
  33. ../../../dap.c \
  34. ../startup_m480.c \
  35. ../usb/usb_m484.c \
  36. ../usb/usb_std.c \
  37. ../usb/usb_cdc.c \
  38. ../usb/usb_hid.c \
  39. ../usb/usb_winusb.c \
  40. ../usb_descriptors.c \
  41. DEFINES += \
  42. -DDONT_USE_CMSIS_INIT \
  43. CFLAGS += $(INCLUDES) $(DEFINES)
  44. OBJS = $(addprefix $(BUILD)/, $(notdir %/$(subst .c,.o, $(SRCS))))
  45. all: directory $(BUILD)/$(BIN).elf $(BUILD)/$(BIN).hex $(BUILD)/$(BIN).bin size
  46. $(BUILD)/$(BIN).elf: $(OBJS)
  47. @echo LD $@
  48. @$(CC) $(LDFLAGS) $(OBJS) $(LIBS) -o $@
  49. $(BUILD)/$(BIN).hex: $(BUILD)/$(BIN).elf
  50. @echo OBJCOPY $@
  51. @$(OBJCOPY) -O ihex $^ $@
  52. $(BUILD)/$(BIN).bin: $(BUILD)/$(BIN).elf
  53. @echo OBJCOPY $@
  54. @$(OBJCOPY) -O binary $^ $@
  55. %.o:
  56. @echo CC $@
  57. @$(CC) $(CFLAGS) $(filter %/$(subst .o,.c,$(notdir $@)), $(SRCS)) -c -o $@
  58. directory:
  59. @$(MKDIR) -p $(BUILD)
  60. size: $(BUILD)/$(BIN).elf
  61. @echo size:
  62. @$(SIZE) -t $^
  63. clean:
  64. @echo clean
  65. @-rm -rf $(BUILD)
  66. -include $(wildcard $(BUILD)/*.d)