Makefile 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. #----------------------------------------------------------------------------
  2. # On command line:
  3. #
  4. # make all = Make software.
  5. #
  6. # make clean = Clean out built project files.
  7. #
  8. # make coff = Convert ELF to AVR COFF.
  9. #
  10. # make extcoff = Convert ELF to AVR Extended COFF.
  11. #
  12. # make program = Download the hex file to the device.
  13. # Please customize your programmer settings(PROGRAM_CMD)
  14. #
  15. # make teensy = Download the hex file to the device, using teensy_loader_cli.
  16. # (must have teensy_loader_cli installed).
  17. #
  18. # make dfu = Download the hex file to the device, using dfu-programmer (must
  19. # have dfu-programmer installed).
  20. #
  21. # make flip = Download the hex file to the device, using Atmel FLIP (must
  22. # have Atmel FLIP installed).
  23. #
  24. # make dfu-ee = Download the eeprom file to the device, using dfu-programmer
  25. # (must have dfu-programmer installed).
  26. #
  27. # make flip-ee = Download the eeprom file to the device, using Atmel FLIP
  28. # (must have Atmel FLIP installed).
  29. #
  30. # make debug = Start either simulavr or avarice as specified for debugging,
  31. # with avr-gdb or avr-insight as the front end for debugging.
  32. #
  33. # make filename.s = Just compile filename.c into the assembler code only.
  34. #
  35. # make filename.i = Create a preprocessed source file for use in submitting
  36. # bug reports to the GCC project.
  37. #
  38. # To rebuild project do "make clean" then "make all".
  39. #----------------------------------------------------------------------------
  40. # Target file name (without extension).
  41. TARGET = planck
  42. # Directory common source filess exist
  43. TOP_DIR = ../..
  44. TMK_DIR = ../../tmk_core
  45. # Directory keyboard dependent files exist
  46. TARGET_DIR = .
  47. # # project specific files
  48. SRC = planck.c \
  49. backlight.c
  50. ifdef keymap
  51. KEYMAP = $(keymap)
  52. endif
  53. ifdef KEYMAP
  54. ifneq ("$(wildcard keymaps/$(KEYMAP).c)","")
  55. KEYMAP_FILE = keymaps/$(KEYMAP).c
  56. else
  57. ifneq ("$(wildcard keymaps/$(KEYMAP)/keymap.c)","")
  58. KEYMAP_FILE = keymaps/$(KEYMAP)/keymap.c
  59. else
  60. $(error Keymap file does not exist)
  61. endif
  62. endif
  63. else
  64. ifneq ("$(wildcard keymaps/default.c)","")
  65. KEYMAP_FILE = keymaps/default.c
  66. else
  67. KEYMAP_FILE = keymaps/default/keymap.c
  68. endif
  69. endif
  70. SRC := $(KEYMAP_FILE) $(SRC)
  71. CONFIG_H = config.h
  72. # MCU name
  73. #MCU = at90usb1287
  74. MCU = atmega32u4
  75. # Processor frequency.
  76. # This will define a symbol, F_CPU, in all source code files equal to the
  77. # processor frequency in Hz. You can then use this symbol in your source code to
  78. # calculate timings. Do NOT tack on a 'UL' at the end, this will be done
  79. # automatically to create a 32-bit value in your source code.
  80. #
  81. # This will be an integer division of F_USB below, as it is sourced by
  82. # F_USB after it has run through any CPU prescalers. Note that this value
  83. # does not *change* the processor frequency - it should merely be updated to
  84. # reflect the processor speed set externally so that the code can use accurate
  85. # software delays.
  86. F_CPU = 16000000
  87. #
  88. # LUFA specific
  89. #
  90. # Target architecture (see library "Board Types" documentation).
  91. ARCH = AVR8
  92. # Input clock frequency.
  93. # This will define a symbol, F_USB, in all source code files equal to the
  94. # input clock frequency (before any prescaling is performed) in Hz. This value may
  95. # differ from F_CPU if prescaling is used on the latter, and is required as the
  96. # raw input clock is fed directly to the PLL sections of the AVR for high speed
  97. # clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'
  98. # at the end, this will be done automatically to create a 32-bit value in your
  99. # source code.
  100. #
  101. # If no clock division is performed on the input clock inside the AVR (via the
  102. # CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
  103. F_USB = $(F_CPU)
  104. # Interrupt driven control endpoint task(+60)
  105. OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT
  106. # Boot Section Size in *bytes*
  107. # Teensy halfKay 512
  108. # Teensy++ halfKay 1024
  109. # Atmel DFU loader 4096
  110. # LUFA bootloader 4096
  111. # USBaspLoader 2048
  112. OPT_DEFS += -DBOOTLOADER_SIZE=4096
  113. # Build Options
  114. # comment out to disable the options.
  115. #
  116. BOOTMAGIC_ENABLE = yes # Virtual DIP switch configuration(+1000)
  117. MOUSEKEY_ENABLE = yes # Mouse keys(+4700)
  118. EXTRAKEY_ENABLE = yes # Audio control and System control(+450)
  119. CONSOLE_ENABLE = yes # Console for debug(+400)
  120. COMMAND_ENABLE = yes # Commands for debug and configuration
  121. # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
  122. # SLEEP_LED_ENABLE = yes # Breathing sleep LED during USB suspend
  123. # NKRO_ENABLE = yes # USB Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
  124. BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality
  125. # MIDI_ENABLE = YES # MIDI controls
  126. # UNICODE_ENABLE = YES # Unicode
  127. # BLUETOOTH_ENABLE = yes # Enable Bluetooth with the Adafruit EZ-Key HID
  128. # Optimize size but this may cause error "relocation truncated to fit"
  129. #EXTRALDFLAGS = -Wl,--relax
  130. # Search Path
  131. VPATH += $(TARGET_DIR)
  132. VPATH += $(TOP_DIR)
  133. VPATH += $(TMK_DIR)
  134. include $(TOP_DIR)/quantum/quantum.mk