Makefile 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. ################################Shimatta Makefile####################################
  2. #CPU: STM32F030
  3. #Compiler: arm-none-eabi
  4. #####################################################################################
  5. #Add Files and Folders below#########################################################
  6. CFILES = main.c syscalls/syscalls.c setup/system_init.c startup/startup_stm32f0xx.c
  7. ASFILES =
  8. INCLUDEPATH = -Iinclude -Iinclude/cmsis
  9. target = project
  10. LIBRARYPATH = -Lstartup
  11. LIBRARIES =
  12. DEFINES = -DSTM32F030x6 -DSTM32F0XX
  13. mapfile = memmap
  14. ##Custom Files###
  15. #TODO
  16. ###################################################################################
  17. CC=arm-none-eabi-gcc
  18. OBJCOPY=arm-none-eabi-objcopy
  19. OBJDUMP=arm-none-eabi-objdump
  20. SIZE=arm-none-eabi-size
  21. LFLAGS = -mlittle-endian -mthumb -mcpu=cortex-m0 -mthumb-interwork
  22. LFLAGS += -mfloat-abi=soft --disable-newlib-supplied-syscalls -nostartfiles
  23. LFLAGS += -Tstartup/stm32f030.ld -Wl,-Map=$(mapfile).map -Wl,--gc-sections -g
  24. CFLAGS = -c -fmessage-length=0 -mlittle-endian -mthumb -mcpu=cortex-m0 -mthumb-interwork
  25. CFLAGS += -mfloat-abi=soft -nostartfiles -Wall -g
  26. ####################################################################################
  27. OBJ = $(CFILES:%.c=%.c.o)
  28. ASOBJ = $(ASFILES:%.S=%.S.o)
  29. default: $(target).elf
  30. binary: $(target).bin $(target).hex
  31. %.bin: %.elf
  32. $(OBJCOPY) -O binary $^ $@
  33. %.hex: %.elf
  34. $(OBJCOPY) -O ihex $^ $@
  35. #Linking
  36. $(target).elf: $(OBJ) $(ASOBJ)
  37. $(CC) $(LFLAGS) $(LIBRARYPATH) -o $@ $^ $(LIBRARIES)
  38. $(SIZE) $@
  39. #Compiling
  40. %.c.o: %.c
  41. $(CC) $(CFLAGS) $(INCLUDEPATH) $(DEFINES) -o $@ $<
  42. %.S.o: %.S
  43. $(CC) $(CFLAGS) $(INCLUDEPATH) $(DEFINES) -o $@ $<
  44. .PHONY: qtproject clean mrproper objcopy disassemble
  45. disassemble: $(target).elf
  46. $(OBJDUMP) -D -s $< > $(target).lss
  47. objcopy: $(target).bin $(target).hex
  48. mrproper:
  49. rm -f $(target).pro
  50. clean:
  51. rm -f $(target).elf $(target).bin $(target).hex $(OBJ) $(ASOBJ) $(mapfile).map $(target).lss
  52. qtproject:
  53. echo -e "TEMPLATE = app\nCONFIG -= console app_bundle qt" > $(target).pro
  54. echo -e "SOURCES += $(CFILES) $(ASFILES)" >> $(target).pro
  55. echo -ne "INCLUDEPATH += " >> $(target).pro
  56. echo "$(INCLUDEPATH)" | sed "s!-I!./!g" >> $(target).pro
  57. echo -ne "HEADERS += " >> $(target).pro
  58. find -name "*.h" | tr "\\n" " " >> $(target).pro
  59. echo -ne "\nDEFINES += " >> $(target).pro
  60. echo "$(DEFINES)" | sed "s/-D//g" >> $(target).pro