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.6KB

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