mcu_selection.mk 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. ifneq ($(findstring STM32F303, $(MCU)),)
  2. ## chip/board settings
  3. # - the next two should match the directories in
  4. # <chibios>/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES)
  5. MCU_FAMILY ?= STM32
  6. MCU_SERIES ?= STM32F3xx
  7. # Linker script to use
  8. # - it should exist either in <chibios>/os/common/ports/ARMCMx/compilers/GCC/ld/
  9. # or <this_dir>/ld/
  10. MCU_LDSCRIPT ?= STM32F303xC
  11. # Startup code to use
  12. # - it should exist in <chibios>/os/common/startup/ARMCMx/compilers/GCC/mk/
  13. MCU_STARTUP ?= stm32f3xx
  14. # Board: it should exist either in <chibios>/os/hal/boards/
  15. # or <this_dir>/boards
  16. BOARD ?= GENERIC_STM32_F303XC
  17. # Cortex version
  18. MCU = cortex-m4
  19. # ARM version, CORTEX-M0/M1 are 6, CORTEX-M3/M4/M7 are 7
  20. ARMV ?= 7
  21. USE_FPU = yes
  22. # Vector table for application
  23. # 0x00000000-0x00001000 area is occupied by bootlaoder.*/
  24. # The CORTEX_VTOR... is needed only for MCHCK/Infinity KB
  25. # OPT_DEFS = -DCORTEX_VTOR_INIT=0x08005000
  26. # Options to pass to dfu-util when flashing
  27. DFU_ARGS ?= -d 0483:df11 -a 0 -s 0x08000000:leave
  28. endif
  29. ifneq (,$(filter $(MCU),atmega32u4 at90usb1286))
  30. # Processor frequency.
  31. # This will define a symbol, F_CPU, in all source code files equal to the
  32. # processor frequency in Hz. You can then use this symbol in your source code to
  33. # calculate timings. Do NOT tack on a 'UL' at the end, this will be done
  34. # automatically to create a 32-bit value in your source code.
  35. #
  36. # This will be an integer division of F_USB below, as it is sourced by
  37. # F_USB after it has run through any CPU prescalers. Note that this value
  38. # does not *change* the processor frequency - it should merely be updated to
  39. # reflect the processor speed set externally so that the code can use accurate
  40. # software delays.
  41. F_CPU ?= 16000000
  42. # LUFA specific
  43. #
  44. # Target architecture (see library "Board Types" documentation).
  45. ARCH ?= AVR8
  46. # Input clock frequency.
  47. # This will define a symbol, F_USB, in all source code files equal to the
  48. # input clock frequency (before any prescaling is performed) in Hz. This value may
  49. # differ from F_CPU if prescaling is used on the latter, and is required as the
  50. # raw input clock is fed directly to the PLL sections of the AVR for high speed
  51. # clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'
  52. # at the end, this will be done automatically to create a 32-bit value in your
  53. # source code.
  54. #
  55. # If no clock division is performed on the input clock inside the AVR (via the
  56. # CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
  57. F_USB ?= $(F_CPU)
  58. endif