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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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. # Build Targets
  66. #
  67. #| Create the .ELF file
  68. set( TARGET_ELF ${TARGET}.elf )
  69. add_executable( ${TARGET_ELF} ${SRCS} )
  70. #| .ELF Properties
  71. set_target_properties( ${TARGET_ELF} PROPERTIES
  72. LINK_FLAGS ${LINKER_FLAGS}
  73. SUFFIX "" # XXX Force Windows to keep the .exe off
  74. )
  75. #| Convert the .ELF into a .HEX to load onto the Teensy
  76. set( TARGET_HEX ${TARGET}.hex )
  77. add_custom_command( TARGET ${TARGET_ELF} POST_BUILD
  78. COMMAND ${OBJCOPY} ${HEX_FLAGS} ${TARGET_ELF} ${TARGET_HEX}
  79. COMMENT "Creating load file for Flash: ${TARGET_HEX}"
  80. )
  81. #| Generate the Extended .LSS
  82. set( TARGET_LSS ${TARGET}.lss )
  83. add_custom_command( TARGET ${TARGET_ELF} POST_BUILD
  84. COMMAND ${OBJDUMP} ${LSS_FLAGS} ${TARGET_ELF} > ${TARGET_LSS}
  85. COMMENT "Creating Extended Listing: ${TARGET_LSS}"
  86. )
  87. #| Generate the Symbol Table .SYM
  88. set( TARGET_SYM ${TARGET}.sym )
  89. add_custom_command( TARGET ${TARGET_ELF} POST_BUILD
  90. COMMAND ${NM} -n ${TARGET_ELF} > ${TARGET_SYM}
  91. COMMENT "Creating Symbol Table: ${TARGET_SYM}"
  92. )
  93. ###
  94. # Size Information
  95. #
  96. #| After Changes Size Information
  97. #| TODO Do lookup on Flash and RAM sizes and do % used
  98. add_custom_target( SizeAfter ALL ${SIZE} --target=${FORMAT} ${TARGET_HEX} ${TARGET_ELF}
  99. DEPENDS ${TARGET_ELF}
  100. COMMENT "Size after generation\n\tFlash Usage: data (hex)\n\t RAM Usage: data (elf)"
  101. )
  102. ###
  103. # Setup Loader Script
  104. #
  105. #| Provides the user with the correct teensy-loader-cli command for the built .HEX file
  106. #| teensy-loader-cli must be in the user's path
  107. if( ${CMAKE_SYSTEM_NAME} MATCHES "Linux" OR ${CMAKE_SYSTEM_NAME} MATCHES "Darwin" )
  108. configure_file( LoadFile/bash load )
  109. endif()
  110. #| TODO Windows
  111. if( ${CMAKE_SYSTEM_NAME} MATCHES "Windows" )
  112. configure_file( LoadFile/bash load )
  113. endif()