Kiibohd Controller
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

CMakeLists.txt 3.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. ###| CMAKE Kiibohd Controller |###
  2. #
  3. # Jacob Alexander 2011-2014
  4. # Due to this file's usefulness:
  5. #
  6. # Released into the Public Domain
  7. #
  8. ###
  9. #| Windows / Cygwin Compatibility options
  10. set( CMAKE_LEGACY_CYGWIN_WIN32 0 )
  11. set( CMAKE_USE_RELATIVE_PATHS 1 )
  12. ###
  13. # Compiler Family
  14. #
  15. #| Specify the compiler family to use
  16. #| Currently only supports AVR and ARM
  17. #| "avr" # Teensy 1.0
  18. #| "avr" # Teensy 2.0
  19. #| "avr" # Teensy++ 1.0
  20. #| "avr" # Teensy++ 2.0
  21. #| "arm" # Teensy 3.0
  22. #| "arm" # Teensy 3.1
  23. #set( COMPILER_FAMILY "arm" )
  24. set( COMPILER_FAMILY "avr" )
  25. message( STATUS "Compiler Family:" )
  26. message( "${COMPILER_FAMILY}" )
  27. #| Load the compiler family specific configurations
  28. include( ${COMPILER_FAMILY}.cmake )
  29. ###
  30. # Project Description
  31. #
  32. #| Project
  33. project( kiibohd_controller )
  34. #| Target Name (output name)
  35. set( TARGET kiibohd )
  36. #| General Settings
  37. cmake_minimum_required( VERSION 2.8 )
  38. ###
  39. # Source Defines
  40. #
  41. #| Sources (see setup.h for configuring in/away code blocks or other complete modules)
  42. #| XXX Not set here in this project, see setup.cmake
  43. #set( SRCS ./main.c )
  44. #| Instead, include the module source selector
  45. include( setup.cmake )
  46. set( SRCS
  47. main.c
  48. ${COMPILER_SRCS}
  49. ${SCAN_SRCS}
  50. ${MACRO_SRCS}
  51. ${OUTPUT_SRCS}
  52. ${DEBUG_SRCS}
  53. )
  54. #| Directories to include by default
  55. include_directories( ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR} )
  56. ###
  57. # Module Compatibility Check
  58. #
  59. #| Check for whether the set modules are compatible with the specified compiler family
  60. ModuleCompatibility( ${ScanModulePath} ${ScanModuleCompatibility} )
  61. ModuleCompatibility( ${MacroModulePath} ${MacroModuleCompatibility} )
  62. ModuleCompatibility( ${OutputModulePath} ${OutputModuleCompatibility} )
  63. ModuleCompatibility( ${DebugModulePath} ${DebugModuleCompatibility} )
  64. ###
  65. # CMake Module Checking
  66. #
  67. find_package( Git REQUIRED )
  68. ###
  69. # Build Targets
  70. #
  71. #| Create the .ELF file
  72. set( TARGET_ELF ${TARGET}.elf )
  73. add_executable( ${TARGET_ELF} ${SRCS} )
  74. #| .ELF Properties
  75. set_target_properties( ${TARGET_ELF} PROPERTIES
  76. LINK_FLAGS ${LINKER_FLAGS}
  77. SUFFIX "" # XXX Force Windows to keep the .exe off
  78. )
  79. #| Convert the .ELF into a .HEX to load onto the Teensy
  80. set( TARGET_HEX ${TARGET}.hex )
  81. add_custom_command( TARGET ${TARGET_ELF} POST_BUILD
  82. COMMAND ${OBJCOPY} ${HEX_FLAGS} ${TARGET_ELF} ${TARGET_HEX}
  83. COMMENT "Creating load file for Flash: ${TARGET_HEX}"
  84. )
  85. #| Generate the Extended .LSS
  86. set( TARGET_LSS ${TARGET}.lss )
  87. add_custom_command( TARGET ${TARGET_ELF} POST_BUILD
  88. COMMAND ${OBJDUMP} ${LSS_FLAGS} ${TARGET_ELF} > ${TARGET_LSS}
  89. COMMENT "Creating Extended Listing: ${TARGET_LSS}"
  90. )
  91. #| Generate the Symbol Table .SYM
  92. set( TARGET_SYM ${TARGET}.sym )
  93. add_custom_command( TARGET ${TARGET_ELF} POST_BUILD
  94. COMMAND ${NM} -n ${TARGET_ELF} > ${TARGET_SYM}
  95. COMMENT "Creating Symbol Table: ${TARGET_SYM}"
  96. )
  97. ###
  98. # Size Information
  99. #
  100. #| After Changes Size Information
  101. #| TODO Do lookup on Flash and RAM sizes and do % used
  102. add_custom_target( SizeAfter ALL
  103. COMMAND ${SIZE} --target=${FORMAT} ${TARGET_HEX} ${TARGET_ELF}
  104. DEPENDS ${TARGET_ELF}
  105. COMMENT "Size after generation\n\tFlash Usage: data (hex)\n\t RAM Usage: data (elf)"
  106. )
  107. ###
  108. # Setup Loader Script and Program
  109. #
  110. #| Provides the user with the correct teensy-loader-cli command for the built .HEX file
  111. #| Windows
  112. if( CMAKE_SYSTEM_NAME MATCHES "Windows" )
  113. configure_file( LoadFile/winload load NEWLINE_STYLE UNIX )
  114. #| Default
  115. else()
  116. configure_file( LoadFile/load load NEWLINE_STYLE UNIX )
  117. endif()