CMakeLists.txt 63 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729
  1. # SPDX-License-Identifier: Apache-2.0
  2. # *DOCUMENTATION*
  3. #
  4. # Note that this is *NOT* the top-level CMakeLists.txt. That's in the
  5. # application. See the Application Development Primer documentation
  6. # for details.
  7. #
  8. # To see a list of typical targets execute "make usage"
  9. # More info can be located in ./README.rst
  10. # Comments in this file are targeted only to the developer, do not
  11. # expect to learn how to build the kernel reading this file.
  12. if(NOT DEFINED ZEPHYR_BINARY_DIR)
  13. message(FATAL_ERROR "A user error has occurred.
  14. cmake was invoked with '${CMAKE_CURRENT_LIST_DIR}' specified as the source directory,
  15. but it must be invoked with an application source directory,
  16. such as '${CMAKE_CURRENT_LIST_DIR}/samples/hello_world'.
  17. Debug variables:
  18. CMAKE_CACHEFILE_DIR: ${CMAKE_CACHEFILE_DIR}
  19. ")
  20. endif()
  21. # See https://gitlab.kitware.com/cmake/cmake/issues/16228
  22. # and https://cmake.org/pipermail/cmake/2019-May/thread.html#69496
  23. if(NOT ZEPHYR_BASE STREQUAL CMAKE_CURRENT_SOURCE_DIR)
  24. message(WARNING "ZEPHYR_BASE doesn't match CMAKE_CURRENT_SOURCE_DIR
  25. ZEPHYR_BASE = ${ZEPHYR_BASE}
  26. PWD = $ENV{PWD}
  27. CMAKE_CURRENT_SOURCE_DIR = ${CMAKE_CURRENT_SOURCE_DIR}
  28. You may be using a mix of symbolic links and real paths which causes \
  29. subtle and hard to debug CMake issues.")
  30. endif()
  31. # For Zephyr more specifically this breaks (at least)
  32. # -fmacro-prefix-map=${ZEPHYR_BASE}=
  33. # Verify that the toolchain can compile a dummy file, if it is not we
  34. # won't be able to test for compatibility with certain C flags.
  35. zephyr_check_compiler_flag(C "" toolchain_is_ok)
  36. assert(toolchain_is_ok "The toolchain is unable to build a dummy C file. See CMakeError.log.")
  37. # In some cases the "final" things are not used at all and "_prebuilt"
  38. # is the last station. See "logical_target_for_zephyr_elf" below for
  39. # details.
  40. set(CMAKE_EXECUTABLE_SUFFIX .elf)
  41. set(ZEPHYR_PREBUILT_EXECUTABLE zephyr_prebuilt)
  42. set(ZEPHYR_FINAL_EXECUTABLE zephyr_final)
  43. # Set some phony targets to collect dependencies
  44. set(OFFSETS_H_TARGET offsets_h)
  45. set(SYSCALL_LIST_H_TARGET syscall_list_h_target)
  46. set(DRIVER_VALIDATION_H_TARGET driver_validation_h_target)
  47. set(KOBJ_TYPES_H_TARGET kobj_types_h_target)
  48. set(PARSE_SYSCALLS_TARGET parse_syscalls_target)
  49. define_property(GLOBAL PROPERTY PROPERTY_OUTPUT_FORMAT BRIEF_DOCS " " FULL_DOCS " ")
  50. set_property( GLOBAL PROPERTY PROPERTY_OUTPUT_FORMAT elf32-little${ARCH}) # BFD format
  51. # "zephyr_interface" is a source-less library that encapsulates all the global
  52. # compiler options needed by all source files. All zephyr libraries,
  53. # including the library named "zephyr" link with this library to
  54. # obtain these flags.
  55. # https://cmake.org/cmake/help/latest/manual/cmake-buildsystem.7.html#interface-libraries
  56. add_library(zephyr_interface INTERFACE)
  57. # "zephyr" is a catch-all CMake library for source files that can be
  58. # built purely with the include paths, defines, and other compiler
  59. # flags that come with zephyr_interface.
  60. zephyr_library_named(zephyr)
  61. zephyr_include_directories(
  62. include
  63. ${PROJECT_BINARY_DIR}/include/generated
  64. ${USERINCLUDE}
  65. ${STDINCLUDE}
  66. )
  67. include(${ZEPHYR_BASE}/cmake/linker_script/${ARCH}/linker.cmake OPTIONAL)
  68. # Don't add non-existing include directories, it creates noise and
  69. # warnings in some tooling
  70. foreach(optional_include_dir
  71. ${SOC_DIR}/${ARCH}/${SOC_PATH}
  72. ${SOC_DIR}/${ARCH}/${SOC_PATH}/include
  73. ${SOC_DIR}/${ARCH}/${SOC_FAMILY}/include
  74. ${SOC_DIR}/${ARCH}/${SOC_FAMILY}/common/include
  75. )
  76. if(EXISTS ${optional_include_dir})
  77. zephyr_include_directories(${optional_include_dir})
  78. endif()
  79. endforeach()
  80. zephyr_compile_definitions(
  81. KERNEL
  82. __ZEPHYR__=1
  83. )
  84. # Ensure that include/toolchain.h includes toolchain/other.h for all off-tree toolchains
  85. if(TOOLCHAIN_USE_CUSTOM)
  86. zephyr_compile_definitions(__TOOLCHAIN_CUSTOM__)
  87. endif()
  88. # @Intent: Set compiler flags to enable buffer overflow checks in libc functions
  89. # @config in CONFIG_NO_OPTIMIZATIONS optional : Optimizations may affect security
  90. zephyr_compile_definitions($<TARGET_PROPERTY:compiler,security_fortify> )
  91. # @Intent: Set compiler flags to detect general stack overflows across all functions
  92. if(CONFIG_STACK_CANARIES)
  93. # zephyr_compile_options($<TARGET_PROPERTY:compiler,security_canaries>)
  94. endif()
  95. if(BUILD_VERSION)
  96. zephyr_compile_definitions(
  97. BUILD_VERSION=${BUILD_VERSION}
  98. )
  99. endif()
  100. # @Intent: Obtain compiler optimizations flags and store in variables
  101. # @details:
  102. # Kconfig.zephyr "Optimization level" is a kconfig choice, ensuring
  103. # only *one* of CONFIG_{NO,DEBUG,SPEED,SIZE}_OPTIMIZATIONS is set.
  104. # Refer to Kconfig.zephyr for selection logic and description of these choices.
  105. # toolchain_cc_optimize_*() macros must provide the mapping from these kconfigs
  106. # to compiler flags. Each macro will store the flags in a CMake variable, whose
  107. # name is passed as argument (somewhat like by reference).
  108. #
  109. # If the user wants to tweak the optimizations, there are two ways:
  110. # 1) Using EXTRA_CFLAGS which is applied regardless of kconfig choice, or
  111. # 2) Rely on override support being implemented by your toolchain_cc_optimize_*()
  112. #
  113. get_property(OPTIMIZE_FOR_NO_OPTIMIZATIONS_FLAG TARGET compiler PROPERTY no_optimization)
  114. get_property(OPTIMIZE_FOR_DEBUG_FLAG TARGET compiler PROPERTY optimization_debug)
  115. get_property(OPTIMIZE_FOR_SPEED_FLAG TARGET compiler PROPERTY optimization_speed)
  116. get_property(OPTIMIZE_FOR_SIZE_FLAG TARGET compiler PROPERTY optimization_size)
  117. # From kconfig choice, pick the actual OPTIMIZATION_FLAG to use.
  118. # Kconfig choice ensures only one of these CONFIG_*_OPTIMIZATIONS is set.
  119. if(CONFIG_NO_OPTIMIZATIONS)
  120. set(OPTIMIZATION_FLAG ${OPTIMIZE_FOR_NO_OPTIMIZATIONS_FLAG})
  121. elseif(CONFIG_DEBUG_OPTIMIZATIONS)
  122. set(OPTIMIZATION_FLAG ${OPTIMIZE_FOR_DEBUG_FLAG})
  123. elseif(CONFIG_SPEED_OPTIMIZATIONS)
  124. set(OPTIMIZATION_FLAG ${OPTIMIZE_FOR_SPEED_FLAG})
  125. elseif(CONFIG_SIZE_OPTIMIZATIONS)
  126. set(OPTIMIZATION_FLAG ${OPTIMIZE_FOR_SIZE_FLAG}) # Default in kconfig
  127. else()
  128. assert(0 "Unreachable code. Expected optimization level to have been chosen. See Kconfig.zephyr")
  129. endif()
  130. if(NOT CONFIG_ARCH_IS_SET)
  131. message(WARNING "\
  132. None of the CONFIG_<arch> (e.g. CONFIG_X86) symbols are set. \
  133. Select one of them from the SOC_SERIES_* symbol or, lacking that, from the \
  134. SOC_* symbol.")
  135. endif()
  136. # Apply the final optimization flag(s)
  137. zephyr_compile_options(${OPTIMIZATION_FLAG})
  138. # @Intent: Obtain compiler specific flags related to C++ that are not influenced by kconfig
  139. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,required>>)
  140. # @Intent: Obtain compiler specific flags for compiling under different ISO standards of C++
  141. if(CONFIG_CPLUSPLUS)
  142. # From kconfig choice, pick a single dialect.
  143. # Kconfig choice ensures only one of these CONFIG_STD_CPP* is set.
  144. if(CONFIG_STD_CPP98)
  145. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp98>)
  146. elseif(CONFIG_STD_CPP11)
  147. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp11>) # Default in kconfig
  148. elseif(CONFIG_STD_CPP14)
  149. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp14>)
  150. elseif(CONFIG_STD_CPP17)
  151. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp17>)
  152. elseif(CONFIG_STD_CPP2A)
  153. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp2a>)
  154. elseif(CONFIG_STD_CPP20)
  155. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp20>)
  156. elseif(CONFIG_STD_CPP2B)
  157. set(STD_CPP_DIALECT_FLAGS $<TARGET_PROPERTY:compiler-cpp,dialect_cpp2b>)
  158. else()
  159. assert(0 "Unreachable code. Expected C++ standard to have been chosen. See Kconfig.zephyr.")
  160. endif()
  161. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:${STD_CPP_DIALECT_FLAGS}>)
  162. endif()
  163. if(NOT CONFIG_EXCEPTIONS)
  164. # @Intent: Obtain compiler specific flags related to C++ Exceptions
  165. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,no_exceptions>>)
  166. endif()
  167. if(NOT CONFIG_RTTI)
  168. # @Intent: Obtain compiler specific flags related to C++ Run Time Type Information
  169. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,no_rtti>>)
  170. endif()
  171. if(CONFIG_MISRA_SANE)
  172. # @Intent: Obtain toolchain compiler flags relating to MISRA.
  173. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_error_misra_sane>>)
  174. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_error_misra_sane>>)
  175. endif()
  176. # This is intend to be temporary. Once we have fixed the violations that
  177. # prevents build Zephyr, these flags shall be part of the default flags.
  178. if(CONFIG_CODING_GUIDELINE_CHECK)
  179. # @Intent: Obtain toolchain compiler flags relating to coding guideline
  180. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_error_coding_guideline>>)
  181. endif()
  182. # @Intent: Set compiler specific macro inclusion of AUTOCONF_H
  183. zephyr_compile_options("SHELL: $<TARGET_PROPERTY:compiler,imacros> ${AUTOCONF_H}")
  184. # @Intent: Set compiler specific flag for bare metal freestanding option
  185. zephyr_compile_options($<TARGET_PROPERTY:compiler,freestanding>)
  186. # @Intent: Set compiler specific flag for tentative definitions, no-common
  187. zephyr_compile_options($<TARGET_PROPERTY:compiler,no_common>)
  188. # @Intent: Set compiler specific flag for production of debug information
  189. zephyr_compile_options($<TARGET_PROPERTY:compiler,debug>)
  190. if(CONFIG_COMPILER_COLOR_DIAGNOSTICS)
  191. # @Intent: Set compiler specific flag for diagnostic messages
  192. zephyr_compile_options($<TARGET_PROPERTY:compiler,diagnostic>)
  193. endif()
  194. zephyr_compile_options(
  195. ${TOOLCHAIN_C_FLAGS}
  196. )
  197. # @Intent: Obtain compiler specific flags related to assembly
  198. # ToDo: Remember to get feedback from Oticon on this, as they might use the `ASM_BASE_FLAG` since this is done this way.
  199. zephyr_compile_options($<$<COMPILE_LANGUAGE:ASM>:$<TARGET_PROPERTY:asm,required>>)
  200. # @Intent: Enforce standard integer type correspondance to match Zephyr usage.
  201. # (must be after compiler specific flags)
  202. if(NOT CONFIG_ARCH_POSIX)
  203. # `zephyr_stdint.h` is not included for the POSIX (native) arch because it
  204. # compiles with the host toolchain/headers and there can be conflicts if we
  205. # arbitrarily redefine our own type system (see #37718).
  206. zephyr_compile_options("SHELL: $<TARGET_PROPERTY:compiler,imacros> ${ZEPHYR_BASE}/include/toolchain/zephyr_stdint.h")
  207. endif()
  208. # Common toolchain-agnostic assembly flags
  209. zephyr_compile_options(
  210. $<$<COMPILE_LANGUAGE:ASM>:-D_ASMLANGUAGE>
  211. )
  212. # @Intent: Set fundamental linker specific flags
  213. toolchain_ld_base()
  214. toolchain_ld_force_undefined_symbols(
  215. _OffsetAbsSyms
  216. _ConfigAbsSyms
  217. )
  218. if(NOT CONFIG_NATIVE_APPLICATION)
  219. # @Intent: Set linker specific flags for bare metal target
  220. toolchain_ld_baremetal()
  221. endif()
  222. if(CONFIG_LIB_CPLUSPLUS)
  223. # @Intent: Set linker specific flags for C++
  224. toolchain_ld_cpp()
  225. endif()
  226. # @Intent: Add the basic toolchain warning flags
  227. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_base>>)
  228. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_base>>)
  229. # ==========================================================================
  230. #
  231. # cmake -DW=... settings
  232. #
  233. # W=1 - warnings that may be relevant and does not occur too often
  234. # W=2 - warnings that occur quite often but may still be relevant
  235. # W=3 - the more obscure warnings, can most likely be ignored
  236. # ==========================================================================
  237. # @Intent: Add cmake -DW toolchain supported warnings, if any
  238. if(W MATCHES "1")
  239. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_dw_1>>)
  240. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_dw_1>>)
  241. endif()
  242. if(W MATCHES "2")
  243. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_dw_2>>)
  244. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_dw_2>>)
  245. endif()
  246. if(W MATCHES "3")
  247. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_dw_3>>)
  248. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_dw_3>>)
  249. endif()
  250. # @Intent: Add extended, more specific, toolchain warning flags
  251. zephyr_compile_options($<TARGET_PROPERTY:compiler,warning_extended>)
  252. # @Intent: Trigger an error when a declaration does not specify a type
  253. #zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_error_implicit_int>>)
  254. #zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_error_implicit_int>>)
  255. # @Intent: Any warning will trigger an error when compilation occurs
  256. zephyr_compile_options($<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,warning_error_all>>)
  257. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,warning_error_all>>)
  258. # Allow the user to inject options when calling cmake, e.g.
  259. # 'cmake -DEXTRA_CFLAGS="-Werror -Wno-deprecated-declarations" ..'
  260. include(cmake/extra_flags.cmake)
  261. zephyr_cc_option(-fno-asynchronous-unwind-tables)
  262. zephyr_cc_option(-fno-pie)
  263. zephyr_cc_option(-fno-pic)
  264. zephyr_cc_option(-fno-strict-overflow)
  265. if(CONFIG_THREAD_LOCAL_STORAGE)
  266. # Only support local exec TLS model at this point.
  267. zephyr_cc_option(-ftls-model=local-exec)
  268. endif()
  269. if(CONFIG_OVERRIDE_FRAME_POINTER_DEFAULT)
  270. if(CONFIG_OMIT_FRAME_POINTER)
  271. zephyr_cc_option(-fomit-frame-pointer)
  272. else()
  273. zephyr_cc_option(-fno-omit-frame-pointer)
  274. endif()
  275. endif()
  276. separate_arguments(COMPILER_OPT_AS_LIST UNIX_COMMAND ${CONFIG_COMPILER_OPT})
  277. zephyr_compile_options(${COMPILER_OPT_AS_LIST})
  278. # TODO: Include arch compiler options at this point.
  279. if(NOT CMAKE_C_COMPILER_ID STREQUAL "Clang")
  280. # GCC assumed
  281. zephyr_cc_option(-fno-reorder-functions)
  282. if(NOT ${ZEPHYR_TOOLCHAIN_VARIANT} STREQUAL "xcc")
  283. zephyr_cc_option(-fno-defer-pop)
  284. endif()
  285. endif()
  286. zephyr_cc_option_ifdef(CONFIG_STACK_USAGE -fstack-usage)
  287. # If the compiler supports it, strip the ${ZEPHYR_BASE} prefix from the
  288. # __FILE__ macro used in __ASSERT*, in the
  289. # .noinit."/home/joe/zephyr/fu/bar.c" section names and in any
  290. # application code. This saves some memory, stops leaking user locations
  291. # in binaries, makes failure logs more deterministic and most
  292. # importantly makes builds more deterministic
  293. # If several match then the last one wins. This matters for instances
  294. # like tests/ and samples/: they're inside all of them! Then let's
  295. # strip as little as possible.
  296. zephyr_cc_option(-fmacro-prefix-map=${CMAKE_SOURCE_DIR}=CMAKE_SOURCE_DIR)
  297. zephyr_cc_option(-fmacro-prefix-map=${ZEPHYR_BASE}=ZEPHYR_BASE)
  298. if(WEST_TOPDIR)
  299. zephyr_cc_option(-fmacro-prefix-map=${WEST_TOPDIR}=WEST_TOPDIR)
  300. endif()
  301. # TODO: Archiver arguments
  302. # ar_option(D)
  303. # Declare MPU userspace dependencies before the linker scripts to make
  304. # sure the order of dependencies are met
  305. if(CONFIG_USERSPACE)
  306. add_custom_target(app_smem)
  307. set(APP_SMEM_ALIGNED_DEP app_smem_aligned_linker)
  308. set(APP_SMEM_UNALIGNED_DEP app_smem_unaligned_linker)
  309. endif()
  310. if(CONFIG_USERSPACE)
  311. set(KOBJECT_LINKER_DEP kobject_linker)
  312. endif()
  313. get_property(TOPT GLOBAL PROPERTY TOPT)
  314. set_ifndef( TOPT -Wl,-T) # clang doesn't pick -T for some reason and complains,
  315. # while -Wl,-T works for both, gcc and clang
  316. if(CONFIG_HAVE_CUSTOM_LINKER_SCRIPT)
  317. set(LINKER_SCRIPT ${APPLICATION_SOURCE_DIR}/${CONFIG_CUSTOM_LINKER_SCRIPT})
  318. if(NOT EXISTS ${LINKER_SCRIPT})
  319. set(LINKER_SCRIPT ${CONFIG_CUSTOM_LINKER_SCRIPT})
  320. assert_exists(CONFIG_CUSTOM_LINKER_SCRIPT)
  321. endif()
  322. else()
  323. # Try a board specific linker file
  324. set(LINKER_SCRIPT ${BOARD_DIR}/linker.ld)
  325. if(NOT EXISTS ${LINKER_SCRIPT})
  326. # If not available, try an SoC specific linker file
  327. set(LINKER_SCRIPT ${SOC_DIR}/${ARCH}/${SOC_PATH}/linker.ld)
  328. endif()
  329. endif()
  330. if(NOT EXISTS ${LINKER_SCRIPT})
  331. message(FATAL_ERROR "Could not find linker script: '${LINKER_SCRIPT}'. Corrupted configuration?")
  332. endif()
  333. configure_file(version.h.in ${PROJECT_BINARY_DIR}/include/generated/version.h)
  334. # Error-out when the deprecated naming convention is found (until
  335. # after 1.14.0 has been released)
  336. foreach(path
  337. ${BOARD_DIR}/dts.fixup
  338. ${PROJECT_SOURCE_DIR}/soc/${ARCH}/${SOC_PATH}/dts.fixup
  339. ${APPLICATION_SOURCE_DIR}/dts.fixup
  340. )
  341. if(EXISTS ${path})
  342. message(FATAL_ERROR
  343. "A deprecated filename has been detected. Porting is required."
  344. "The file '${path}' exists, but it should be named dts_fixup.h instead."
  345. "See https://github.com/zephyrproject-rtos/zephyr/pull/10352 for more details"
  346. )
  347. endif()
  348. endforeach()
  349. set_ifndef( DTS_BOARD_FIXUP_FILE ${BOARD_DIR}/dts_fixup.h)
  350. set_ifndef( DTS_SOC_FIXUP_FILE ${SOC_DIR}/${ARCH}/${SOC_PATH}/dts_fixup.h)
  351. set( DTS_APP_FIXUP_FILE ${APPLICATION_SOURCE_DIR}/dts_fixup.h)
  352. set_ifndef(DTS_CAT_OF_FIXUP_FILES ${ZEPHYR_BINARY_DIR}/include/generated/devicetree_fixups.h)
  353. # Concatenate the fixups into a single header file for easy
  354. # #include'ing
  355. file(WRITE ${DTS_CAT_OF_FIXUP_FILES} "/* May only be included by devicetree.h */\n\n")
  356. set(DISCOVERED_FIXUP_FILES)
  357. foreach(fixup_file
  358. ${DTS_BOARD_FIXUP_FILE}
  359. ${DTS_SOC_FIXUP_FILE}
  360. ${DTS_APP_FIXUP_FILE}
  361. ${shield_dts_fixups}
  362. )
  363. if(EXISTS ${fixup_file})
  364. file(READ ${fixup_file} contents)
  365. file(APPEND ${DTS_CAT_OF_FIXUP_FILES} "${contents}")
  366. string(APPEND DISCOVERED_FIXUP_FILES "- ${fixup_file}\n")
  367. endif()
  368. endforeach()
  369. if (DISCOVERED_FIXUP_FILES)
  370. message(WARNING "One or more dts_fixup.h files detected:\n${DISCOVERED_FIXUP_FILES}Use of these files is deprecated; use the devicetree.h API instead.")
  371. endif()
  372. # Unfortunately, the order in which CMakeLists.txt code is processed
  373. # matters so we need to be careful about how we order the processing
  374. # of subdirectories. One example is "Compiler flags added late in the
  375. # build are not exported to external build systems #5605"; when we
  376. # integrate with an external build system we read out all compiler
  377. # flags when the external project is created. So an external project
  378. # defined in subsys or ext will not get global flags added by drivers/
  379. # or tests/ as the subdirectories are ordered now.
  380. #
  381. # Another example of when the order matters is the reading and writing
  382. # of global properties such as ZEPHYR_LIBS or
  383. # GENERATED_KERNEL_OBJECT_FILES.
  384. #
  385. # Arch is placed early because it defines important compiler flags
  386. # that must be exported to external build systems defined in
  387. # e.g. subsys/.
  388. add_subdirectory(arch)
  389. add_subdirectory(lib)
  390. # We use include instead of add_subdirectory to avoid creating a new directory scope.
  391. # This is because source file properties are directory scoped, including the GENERATED
  392. # property which is set implicitly for custom command outputs
  393. include(misc/generated/CMakeLists.txt)
  394. if(EXISTS ${SOC_DIR}/${ARCH}/CMakeLists.txt)
  395. add_subdirectory(${SOC_DIR}/${ARCH} soc/${ARCH})
  396. else()
  397. add_subdirectory(${SOC_DIR}/${ARCH}/${SOC_PATH} soc/${ARCH}/${SOC_PATH})
  398. endif()
  399. add_subdirectory(boards)
  400. add_subdirectory(subsys)
  401. add_subdirectory(drivers)
  402. # Include zephyr modules generated CMake file.
  403. foreach(module_name ${ZEPHYR_MODULE_NAMES})
  404. # Note the second, binary_dir parameter requires the added
  405. # subdirectory to have its own, local cmake target(s). If not then
  406. # this binary_dir is created but stays empty. Object files land in
  407. # the main binary dir instead.
  408. # https://cmake.org/pipermail/cmake/2019-June/069547.html
  409. zephyr_string(SANITIZE TOUPPER MODULE_NAME_UPPER ${module_name})
  410. if(NOT ${ZEPHYR_${MODULE_NAME_UPPER}_CMAKE_DIR} STREQUAL "")
  411. set(ZEPHYR_CURRENT_MODULE_DIR ${ZEPHYR_${MODULE_NAME_UPPER}_MODULE_DIR})
  412. set(ZEPHYR_CURRENT_CMAKE_DIR ${ZEPHYR_${MODULE_NAME_UPPER}_CMAKE_DIR})
  413. add_subdirectory(${ZEPHYR_CURRENT_CMAKE_DIR} ${CMAKE_BINARY_DIR}/modules/${module_name})
  414. endif()
  415. endforeach()
  416. # Done processing modules, clear ZEPHYR_CURRENT_MODULE_DIR and ZEPHYR_CURRENT_CMAKE_DIR.
  417. set(ZEPHYR_CURRENT_MODULE_DIR)
  418. set(ZEPHYR_CURRENT_CMAKE_DIR)
  419. set(syscall_list_h ${CMAKE_CURRENT_BINARY_DIR}/include/generated/syscall_list.h)
  420. set(syscalls_json ${CMAKE_CURRENT_BINARY_DIR}/misc/generated/syscalls.json)
  421. set(struct_tags_json ${CMAKE_CURRENT_BINARY_DIR}/misc/generated/struct_tags.json)
  422. # The syscalls subdirs txt file is constructed by python containing a list of folders to use for
  423. # dependency handling, including empty folders.
  424. # Windows: The list is used to specify DIRECTORY list with CMAKE_CONFIGURE_DEPENDS attribute.
  425. # Other OS: The list will update whenever a file is added/removed/modified and ensure a re-build.
  426. set(syscalls_subdirs_txt ${CMAKE_CURRENT_BINARY_DIR}/misc/generated/syscalls_subdirs.txt)
  427. # As syscalls_subdirs_txt is updated whenever a file is modified, this file can not be used for
  428. # monitoring of added / removed folders. A trigger file is thus used for correct dependency
  429. # handling. The trigger file will update when a folder is added / removed.
  430. set(syscalls_subdirs_trigger ${CMAKE_CURRENT_BINARY_DIR}/misc/generated/syscalls_subdirs.trigger)
  431. if(NOT (${CMAKE_HOST_SYSTEM_NAME} STREQUAL Windows))
  432. set(syscalls_links --create-links ${CMAKE_CURRENT_BINARY_DIR}/misc/generated/syscalls_links)
  433. endif()
  434. # When running CMake it must be ensured that all dependencies are correctly acquired.
  435. execute_process(
  436. COMMAND
  437. ${PYTHON_EXECUTABLE}
  438. ${ZEPHYR_BASE}/scripts/subfolder_list.py
  439. --directory ${ZEPHYR_BASE}/include # Walk this directory
  440. --out-file ${syscalls_subdirs_txt} # Write file with discovered folder
  441. --trigger ${syscalls_subdirs_trigger} # Trigger file that is used for json generation
  442. ${syscalls_links} # If defined, create symlinks for dependencies
  443. )
  444. file(STRINGS ${syscalls_subdirs_txt} PARSE_SYSCALLS_PATHS_DEPENDS ENCODING UTF-8)
  445. if(${CMAKE_HOST_SYSTEM_NAME} STREQUAL Windows)
  446. # On windows only adding/removing files or folders will be reflected in depends.
  447. # Hence adding a file requires CMake to re-run to add this file to the file list.
  448. set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS ${PARSE_SYSCALLS_PATHS_DEPENDS})
  449. # Also On Windows each header file must be monitored as file modifications are not reflected
  450. # on directory level.
  451. file(GLOB_RECURSE PARSE_SYSCALLS_HEADER_DEPENDS ${ZEPHYR_BASE}/include/*.h)
  452. else()
  453. # The syscall parsing depends on the folders in order to detect add/removed/modified files.
  454. # When a folder is removed, CMake will try to find a target that creates that dependency.
  455. # This command sets up the target for CMake to find.
  456. # Without this code, CMake will fail with the following error:
  457. # <folder> needed by '<target>', missing and no known rule to make it
  458. # when a folder is removed.
  459. add_custom_command(OUTPUT ${PARSE_SYSCALLS_PATHS_DEPENDS}
  460. COMMAND ${CMAKE_COMMAND} -E echo ""
  461. COMMENT "Preparing syscall dependency handling"
  462. )
  463. add_custom_command(
  464. OUTPUT
  465. ${syscalls_subdirs_trigger}
  466. COMMAND
  467. ${PYTHON_EXECUTABLE}
  468. ${ZEPHYR_BASE}/scripts/subfolder_list.py
  469. --directory ${ZEPHYR_BASE}/include # Walk this directory
  470. --out-file ${syscalls_subdirs_txt} # Write file with discovered folder
  471. --trigger ${syscalls_subdirs_trigger} # Trigger file that is used for json generation
  472. ${syscalls_links} # If defined, create symlinks for dependencies
  473. DEPENDS ${PARSE_SYSCALLS_PATHS_DEPENDS}
  474. )
  475. # Ensure subdir file always exists when specifying CMake dependency.
  476. if(NOT EXISTS ${syscalls_subdirs_txt})
  477. file(WRITE ${syscalls_subdirs_txt} "")
  478. endif()
  479. # On other OS'es, modifying a file is reflected on the folder timestamp and hence detected
  480. # when using depend on directory level.
  481. # Thus CMake only needs to re-run when sub-directories are added / removed, which is indicated
  482. # using a trigger file.
  483. set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS ${syscalls_subdirs_txt})
  484. endif()
  485. # syscall declarations are searched for in the SYSCALL_INCLUDE_DIRS
  486. if(CONFIG_APPLICATION_DEFINED_SYSCALL)
  487. list(APPEND SYSCALL_INCLUDE_DIRS ${APPLICATION_SOURCE_DIR})
  488. endif()
  489. if(CONFIG_ZTEST)
  490. list(APPEND SYSCALL_INCLUDE_DIRS ${ZEPHYR_BASE}/subsys/testsuite/ztest/include)
  491. endif()
  492. foreach(d ${SYSCALL_INCLUDE_DIRS})
  493. list(APPEND parse_syscalls_include_args
  494. --include ${d}
  495. )
  496. endforeach()
  497. add_custom_command(
  498. OUTPUT
  499. ${syscalls_json}
  500. ${struct_tags_json}
  501. COMMAND
  502. ${PYTHON_EXECUTABLE}
  503. ${ZEPHYR_BASE}/scripts/parse_syscalls.py
  504. --include ${ZEPHYR_BASE}/include # Read files from this dir
  505. --include ${ZEPHYR_BASE}/drivers # For net sockets
  506. --include ${ZEPHYR_BASE}/subsys/net # More net sockets
  507. ${parse_syscalls_include_args} # Read files from these dirs also
  508. --json-file ${syscalls_json} # Write this file
  509. --tag-struct-file ${struct_tags_json} # Write subsystem list to this file
  510. DEPENDS ${syscalls_subdirs_trigger} ${PARSE_SYSCALLS_HEADER_DEPENDS}
  511. )
  512. add_custom_target(${SYSCALL_LIST_H_TARGET} DEPENDS ${syscall_list_h})
  513. set_property(TARGET ${SYSCALL_LIST_H_TARGET}
  514. APPEND PROPERTY
  515. ADDITIONAL_CLEAN_FILES
  516. ${CMAKE_CURRENT_BINARY_DIR}/include/generated/syscalls
  517. )
  518. add_custom_target(${PARSE_SYSCALLS_TARGET}
  519. DEPENDS
  520. ${syscalls_json}
  521. ${struct_tags_json}
  522. )
  523. # 64-bit systems do not require special handling of 64-bit system call
  524. # parameters or return values, indicate this to the system call boilerplate
  525. # generation script.
  526. if(CONFIG_64BIT)
  527. set(SYSCALL_LONG_REGISTERS_ARG --long-registers)
  528. endif()
  529. if(CONFIG_TIMEOUT_64BIT)
  530. set(SYSCALL_SPLIT_TIMEOUT_ARG --split-type k_timeout_t)
  531. endif()
  532. add_custom_command(OUTPUT include/generated/syscall_dispatch.c ${syscall_list_h}
  533. # Also, some files are written to include/generated/syscalls/
  534. COMMAND
  535. ${PYTHON_EXECUTABLE}
  536. ${ZEPHYR_BASE}/scripts/gen_syscalls.py
  537. --json-file ${syscalls_json} # Read this file
  538. --base-output include/generated/syscalls # Write to this dir
  539. --syscall-dispatch include/generated/syscall_dispatch.c # Write this file
  540. --syscall-list ${syscall_list_h}
  541. ${SYSCALL_LONG_REGISTERS_ARG}
  542. ${SYSCALL_SPLIT_TIMEOUT_ARG}
  543. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  544. DEPENDS ${PARSE_SYSCALLS_TARGET}
  545. )
  546. # This is passed into all calls to the gen_kobject_list.py script.
  547. set(gen_kobject_list_include_args --include ${struct_tags_json})
  548. set(DRV_VALIDATION ${PROJECT_BINARY_DIR}/include/generated/driver-validation.h)
  549. add_custom_command(
  550. OUTPUT ${DRV_VALIDATION}
  551. COMMAND
  552. ${PYTHON_EXECUTABLE}
  553. ${ZEPHYR_BASE}/scripts/gen_kobject_list.py
  554. --validation-output ${DRV_VALIDATION}
  555. ${gen_kobject_list_include_args}
  556. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  557. DEPENDS
  558. ${ZEPHYR_BASE}/scripts/gen_kobject_list.py
  559. ${PARSE_SYSCALLS_TARGET}
  560. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  561. )
  562. add_custom_target(${DRIVER_VALIDATION_H_TARGET} DEPENDS ${DRV_VALIDATION})
  563. include(${ZEPHYR_BASE}/cmake/kobj.cmake)
  564. gen_kobj(KOBJ_INCLUDE_PATH)
  565. # Add a pseudo-target that is up-to-date when all generated headers
  566. # are up-to-date.
  567. add_custom_target(zephyr_generated_headers)
  568. add_dependencies(zephyr_generated_headers
  569. offsets_h
  570. )
  571. # Generate offsets.c.obj from offsets.c
  572. # Generate offsets.h from offsets.c.obj
  573. set(OFFSETS_LIB offsets)
  574. set(OFFSETS_C_PATH ${ARCH_DIR}/${ARCH}/core/offsets/offsets.c)
  575. set(OFFSETS_H_PATH ${PROJECT_BINARY_DIR}/include/generated/offsets.h)
  576. add_library( ${OFFSETS_LIB} OBJECT ${OFFSETS_C_PATH})
  577. target_include_directories(${OFFSETS_LIB} PRIVATE
  578. kernel/include
  579. ${ARCH_DIR}/${ARCH}/include
  580. )
  581. target_link_libraries(${OFFSETS_LIB} zephyr_interface)
  582. add_dependencies(zephyr_interface
  583. ${SYSCALL_LIST_H_TARGET}
  584. ${DRIVER_VALIDATION_H_TARGET}
  585. ${KOBJ_TYPES_H_TARGET}
  586. )
  587. add_custom_command(
  588. OUTPUT ${OFFSETS_H_PATH}
  589. COMMAND ${PYTHON_EXECUTABLE} ${ZEPHYR_BASE}/scripts/gen_offset_header.py
  590. -i $<TARGET_OBJECTS:${OFFSETS_LIB}>
  591. -o ${OFFSETS_H_PATH}
  592. DEPENDS
  593. ${OFFSETS_LIB}
  594. $<TARGET_OBJECTS:${OFFSETS_LIB}>
  595. )
  596. add_custom_target(${OFFSETS_H_TARGET} DEPENDS ${OFFSETS_H_PATH})
  597. zephyr_get_include_directories_for_lang(C ZEPHYR_INCLUDES)
  598. add_subdirectory(kernel)
  599. # Add framework
  600. add_subdirectory(framework)
  601. # Read list content
  602. get_property(ZEPHYR_LIBS_PROPERTY GLOBAL PROPERTY ZEPHYR_LIBS)
  603. foreach(zephyr_lib ${ZEPHYR_LIBS_PROPERTY})
  604. get_property(lib_type TARGET ${zephyr_lib} PROPERTY TYPE)
  605. # To prevent CMake failure when a driver is enabled, for example: REGULATOR=y
  606. # we disable any Zephyr libraries without sources and adds the `empty_file.c`.
  607. if(${lib_type} STREQUAL STATIC_LIBRARY
  608. AND NOT ${zephyr_lib} STREQUAL app
  609. )
  610. get_property(source_list TARGET ${zephyr_lib} PROPERTY SOURCES)
  611. get_property(lib_imported TARGET ${zephyr_lib} PROPERTY IMPORTED)
  612. if(NOT source_list
  613. AND NOT ${lib_imported}
  614. )
  615. get_property(allow_empty TARGET ${zephyr_lib} PROPERTY ALLOW_EMPTY)
  616. if(NOT "${allow_empty}")
  617. message(WARNING
  618. "No SOURCES given to Zephyr library: ${zephyr_lib}\nExcluding target from build."
  619. )
  620. endif()
  621. target_sources(${zephyr_lib} PRIVATE ${ZEPHYR_BASE}/misc/empty_file.c)
  622. set_property(TARGET ${zephyr_lib} PROPERTY EXCLUDE_FROM_ALL TRUE)
  623. list(REMOVE_ITEM ZEPHYR_LIBS_PROPERTY ${zephyr_lib})
  624. continue()
  625. endif()
  626. endif()
  627. # TODO: Could this become an INTERFACE property of zephyr_interface?
  628. add_dependencies(${zephyr_lib} zephyr_generated_headers)
  629. endforeach()
  630. get_property(OUTPUT_FORMAT GLOBAL PROPERTY PROPERTY_OUTPUT_FORMAT)
  631. if (CONFIG_CODE_DATA_RELOCATION)
  632. set(CODE_RELOCATION_DEP code_relocation_source_lib)
  633. endif() # CONFIG_CODE_DATA_RELOCATION
  634. # Give the linker script targets all of the include directories so
  635. # that cmake can successfully find the linker scripts' header
  636. # dependencies.
  637. zephyr_get_include_directories_for_lang(C
  638. ZEPHYR_INCLUDE_DIRS
  639. STRIP_PREFIX # Don't use a -I prefix
  640. )
  641. if(CONFIG_GEN_ISR_TABLES)
  642. if(CONFIG_GEN_SW_ISR_TABLE)
  643. list(APPEND GEN_ISR_TABLE_EXTRA_ARG --sw-isr-table)
  644. endif()
  645. if(CONFIG_GEN_IRQ_VECTOR_TABLE)
  646. list(APPEND GEN_ISR_TABLE_EXTRA_ARG --vector-table)
  647. endif()
  648. # isr_tables.c is generated from ${ZEPHYR_PREBUILT_EXECUTABLE} by
  649. # gen_isr_tables.py
  650. add_custom_command(
  651. OUTPUT isr_tables.c isrList.bin
  652. COMMAND $<TARGET_PROPERTY:bintools,elfconvert_command>
  653. $<TARGET_PROPERTY:bintools,elfconvert_flag>
  654. $<TARGET_PROPERTY:bintools,elfconvert_flag_intarget>${OUTPUT_FORMAT}
  655. $<TARGET_PROPERTY:bintools,elfconvert_flag_outtarget>binary
  656. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_only>.intList
  657. $<TARGET_PROPERTY:bintools,elfconvert_flag_infile>$<TARGET_FILE:${ZEPHYR_PREBUILT_EXECUTABLE}>
  658. $<TARGET_PROPERTY:bintools,elfconvert_flag_outfile>isrList.bin
  659. $<TARGET_PROPERTY:bintools,elfconvert_flag_final>
  660. COMMAND ${PYTHON_EXECUTABLE}
  661. ${ZEPHYR_BASE}/arch/common/gen_isr_tables.py
  662. --output-source isr_tables.c
  663. --kernel $<TARGET_FILE:${ZEPHYR_PREBUILT_EXECUTABLE}>
  664. --intlist isrList.bin
  665. $<$<BOOL:${CONFIG_BIG_ENDIAN}>:--big-endian>
  666. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--debug>
  667. ${GEN_ISR_TABLE_EXTRA_ARG}
  668. DEPENDS ${ZEPHYR_PREBUILT_EXECUTABLE}
  669. COMMAND_EXPAND_LISTS
  670. )
  671. set_property(GLOBAL APPEND PROPERTY GENERATED_KERNEL_SOURCE_FILES isr_tables.c)
  672. endif()
  673. if(CONFIG_KALLSYMS)
  674. set(KALLSYMS_PARAM --fbin=ksym.bin)
  675. if(CONFIG_KALLSYMS_NO_NAME)
  676. set(KALLSYMS_PARAM --no_symbols_name)
  677. endif()
  678. if(CMAKE_HOST_SYSTEM_NAME MATCHES "Windows")
  679. MESSAGE(STATUS "operation system is Windows")
  680. set(KALLSYMS_APP ${ZEPHYR_BASE}/scripts/kallsyms_win.exe)
  681. else()
  682. MESSAGE(STATUS "operation system is linux ")
  683. set(KALLSYMS_APP ${ZEPHYR_BASE}/scripts/kallsyms)
  684. endif()
  685. add_custom_command(
  686. OUTPUT ksyms.S
  687. POST_BUILD
  688. COMMAND ${CMAKE_NM}
  689. -n
  690. ${ZEPHYR_PREBUILT_EXECUTABLE}.elf
  691. > k_syms.map
  692. COMMAND ${KALLSYMS_APP}
  693. ${KALLSYMS_PARAM}
  694. < k_syms.map
  695. > ksyms.S
  696. DEPENDS ${ZEPHYR_PREBUILT_EXECUTABLE}
  697. COMMAND_EXPAND_LISTS
  698. )
  699. add_custom_target(output_ksyms DEPENDS ksyms.S)
  700. set_property(GLOBAL APPEND PROPERTY GENERATED_KERNEL_SOURCE_FILES ksyms.S)
  701. endif()
  702. # if(CONFIG_HAS_DTS)
  703. # # dev_handles.c is generated from ${ZEPHYR_PREBUILT_EXECUTABLE} by
  704. # # gen_handles.py
  705. # add_custom_command(
  706. # OUTPUT dev_handles.c
  707. # COMMAND
  708. # ${PYTHON_EXECUTABLE}
  709. # ${ZEPHYR_BASE}/scripts/gen_handles.py
  710. # --output-source dev_handles.c
  711. # --kernel $<TARGET_FILE:${ZEPHYR_PREBUILT_EXECUTABLE}>
  712. # --zephyr-base ${ZEPHYR_BASE}
  713. # --start-symbol "$<TARGET_PROPERTY:linker,devices_start_symbol>"
  714. # DEPENDS ${ZEPHYR_PREBUILT_EXECUTABLE}
  715. # )
  716. # set_property(GLOBAL APPEND PROPERTY GENERATED_KERNEL_SOURCE_FILES dev_handles.c)
  717. # endif()
  718. if(CONFIG_CODE_DATA_RELOCATION)
  719. # @Intent: Linker script to relocate .text, data and .bss sections
  720. toolchain_ld_relocation()
  721. endif()
  722. if(CONFIG_USERSPACE)
  723. zephyr_get_compile_options_for_lang_as_string(C compiler_flags_priv)
  724. string(REPLACE "$<TARGET_PROPERTY:compiler,coverage>" ""
  725. NO_COVERAGE_FLAGS "${compiler_flags_priv}"
  726. )
  727. get_property(include_dir_in_interface TARGET zephyr_interface
  728. PROPERTY INTERFACE_INCLUDE_DIRECTORIES)
  729. get_property(sys_include_dir_in_interface TARGET zephyr_interface
  730. PROPERTY INTERFACE_SYSTEM_INCLUDE_DIRECTORIES)
  731. get_property(compile_definitions_interface TARGET zephyr_interface
  732. PROPERTY INTERFACE_COMPILE_DEFINITIONS)
  733. set(GEN_KOBJ_LIST ${ZEPHYR_BASE}/scripts/gen_kobject_list.py)
  734. set(PROCESS_GPERF ${ZEPHYR_BASE}/scripts/process_gperf.py)
  735. set(KOBJECT_HASH_LIST kobject_hash.gperf)
  736. set(KOBJECT_HASH_OUTPUT_SRC_PRE kobject_hash_preprocessed.c)
  737. set(KOBJECT_HASH_OUTPUT_SRC kobject_hash.c)
  738. set(KOBJECT_HASH_OUTPUT_OBJ kobject_hash.c.obj)
  739. set(KOBJECT_HASH_OUTPUT_OBJ_RENAMED kobject_hash_renamed.o)
  740. # Essentially what we are doing here is extracting some information
  741. # out of the nearly finished elf file, generating the source code
  742. # for a hash table based on that information, and then compiling and
  743. # linking the hash table back into a now even more nearly finished
  744. # elf file. More information in gen_kobject_list.py --help.
  745. # Use the script GEN_KOBJ_LIST to scan the kernel binary's
  746. # (${ZEPHYR_PREBUILT_EXECUTABLE}) DWARF information to produce a table of kernel
  747. # objects (KOBJECT_HASH_LIST) which we will then pass to gperf
  748. add_custom_command(
  749. OUTPUT ${KOBJECT_HASH_LIST}
  750. COMMAND
  751. ${PYTHON_EXECUTABLE}
  752. ${GEN_KOBJ_LIST}
  753. --kernel $<TARGET_FILE:${ZEPHYR_PREBUILT_EXECUTABLE}>
  754. --gperf-output ${KOBJECT_HASH_LIST}
  755. ${gen_kobject_list_include_args}
  756. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  757. DEPENDS
  758. ${ZEPHYR_PREBUILT_EXECUTABLE}
  759. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  760. )
  761. add_custom_target(
  762. kobj_hash_list
  763. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_LIST}
  764. )
  765. # Use gperf to generate C code (KOBJECT_HASH_OUTPUT_SRC_PRE) which implements a
  766. # perfect hashtable based on KOBJECT_HASH_LIST
  767. add_custom_command(
  768. OUTPUT ${KOBJECT_HASH_OUTPUT_SRC_PRE}
  769. COMMAND
  770. ${GPERF}
  771. --output-file ${KOBJECT_HASH_OUTPUT_SRC_PRE}
  772. --multiple-iterations 10
  773. ${KOBJECT_HASH_LIST}
  774. DEPENDS kobj_hash_list ${KOBJECT_HASH_LIST}
  775. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  776. )
  777. add_custom_target(
  778. kobj_hash_output_src_pre
  779. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_OUTPUT_SRC_PRE}
  780. )
  781. # For our purposes the code/data generated by gperf is not optimal.
  782. #
  783. # The script PROCESS_GPERF creates a new c file KOBJECT_HASH_OUTPUT_SRC based on
  784. # KOBJECT_HASH_OUTPUT_SRC_PRE to greatly reduce the amount of code/data generated
  785. # since we know we are always working with pointer values
  786. add_custom_command(
  787. OUTPUT ${KOBJECT_HASH_OUTPUT_SRC}
  788. COMMAND
  789. ${PYTHON_EXECUTABLE}
  790. ${PROCESS_GPERF}
  791. -i ${KOBJECT_HASH_OUTPUT_SRC_PRE}
  792. -o ${KOBJECT_HASH_OUTPUT_SRC}
  793. -p "struct z_object"
  794. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  795. DEPENDS kobj_hash_output_src_pre ${KOBJECT_HASH_OUTPUT_SRC_PRE}
  796. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  797. )
  798. add_custom_target(
  799. kobj_hash_output_src
  800. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_OUTPUT_SRC}
  801. )
  802. # We need precise control of where generated text/data ends up in the final
  803. # kernel image. Disable function/data sections and use objcopy to move
  804. # generated data into special section names
  805. add_library(
  806. kobj_hash_output_lib
  807. STATIC ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_OUTPUT_SRC}
  808. )
  809. set_source_files_properties(${KOBJECT_HASH_OUTPUT_SRC}
  810. PROPERTIES COMPILE_FLAGS
  811. "${NO_COVERAGE_FLAGS} -fno-function-sections -fno-data-sections")
  812. set_source_files_properties(${KOBJECT_HASH_OUTPUT_SRC}
  813. PROPERTIES COMPILE_DEFINITIONS "${compile_definitions_interface}")
  814. # Turn off -ffunction-sections, etc.
  815. # NB: Using a library instead of target_compile_options(kobj_hash_output_lib
  816. # [...]) because a library's options have precedence
  817. add_library(kobj_hash_output_lib_interface INTERFACE)
  818. target_link_libraries(kobj_hash_output_lib kobj_hash_output_lib_interface)
  819. foreach(incl ${include_dir_in_interface})
  820. target_include_directories(kobj_hash_output_lib_interface INTERFACE ${incl})
  821. endforeach()
  822. foreach(incl ${sys_include_dir_in_interface})
  823. target_include_directories(kobj_hash_output_lib_interface SYSTEM INTERFACE ${incl})
  824. endforeach()
  825. set(
  826. KOBJECT_HASH_OUTPUT_OBJ_PATH
  827. ${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/kobj_hash_output_lib.dir/${KOBJECT_HASH_OUTPUT_OBJ}
  828. )
  829. add_custom_command(
  830. OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_OUTPUT_OBJ_RENAMED}
  831. COMMAND $<TARGET_PROPERTY:bintools,elfconvert_command>
  832. $<TARGET_PROPERTY:bintools,elfconvert_flag>
  833. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_rename>.data=.kobject_data.data
  834. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_rename>.sdata=.kobject_data.sdata
  835. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_rename>.text=.kobject_data.text
  836. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_rename>.rodata=.kobject_data.rodata
  837. $<TARGET_PROPERTY:bintools,elfconvert_flag_infile>${KOBJECT_HASH_OUTPUT_OBJ_PATH}
  838. $<TARGET_PROPERTY:bintools,elfconvert_flag_outfile>${KOBJECT_HASH_OUTPUT_OBJ_RENAMED}
  839. $<TARGET_PROPERTY:bintools,elfconvert_flag_final>
  840. DEPENDS kobj_hash_output_lib
  841. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  842. COMMAND_EXPAND_LISTS
  843. )
  844. add_custom_target(
  845. kobj_hash_output_obj_renamed
  846. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_OUTPUT_OBJ_RENAMED}
  847. )
  848. add_library(kobj_hash_output_obj_renamed_lib STATIC IMPORTED GLOBAL)
  849. set_property(
  850. TARGET kobj_hash_output_obj_renamed_lib
  851. PROPERTY
  852. IMPORTED_LOCATION ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_HASH_OUTPUT_OBJ_RENAMED}
  853. )
  854. add_dependencies(
  855. kobj_hash_output_obj_renamed_lib
  856. kobj_hash_output_obj_renamed
  857. )
  858. set_property(
  859. GLOBAL APPEND PROPERTY
  860. GENERATED_KERNEL_OBJECT_FILES kobj_hash_output_obj_renamed_lib
  861. )
  862. endif()
  863. # Read global variables into local variables
  864. get_property(GKOF GLOBAL PROPERTY GENERATED_KERNEL_OBJECT_FILES)
  865. get_property(GKSF GLOBAL PROPERTY GENERATED_KERNEL_SOURCE_FILES)
  866. get_property(CSTD GLOBAL PROPERTY CSTD)
  867. set_ifndef(CSTD c99)
  868. # @Intent: Obtain compiler specific flag for specifying the c standard
  869. zephyr_compile_options(
  870. $<$<COMPILE_LANGUAGE:C>:$<TARGET_PROPERTY:compiler,cstd>${CSTD}>
  871. )
  872. # @Intent: Configure linker scripts, i.e. generate linker scripts with variables substituted
  873. toolchain_ld_configure_files()
  874. if(CONFIG_USERSPACE)
  875. set(APP_SMEM_ALIGNED_LD "${PROJECT_BINARY_DIR}/include/generated/app_smem_aligned.ld")
  876. set(APP_SMEM_UNALIGNED_LD "${PROJECT_BINARY_DIR}/include/generated/app_smem_unaligned.ld")
  877. if(CONFIG_LINKER_USE_PINNED_SECTION)
  878. set(APP_SMEM_PINNED_ALIGNED_LD
  879. "${PROJECT_BINARY_DIR}/include/generated/app_smem_pinned_aligned.ld")
  880. set(APP_SMEM_PINNED_UNALIGNED_LD
  881. "${PROJECT_BINARY_DIR}/include/generated/app_smem_pinned_unaligned.ld")
  882. if(NOT CONFIG_LINKER_GENERIC_SECTIONS_PRESENT_AT_BOOT)
  883. # The libc partition may hold symbols that are required during boot process,
  884. # for example, stack guard (if enabled). So the libc partition must be pinned
  885. # if not sections are in physical memory at boot, as the paging mechanism is
  886. # only initialized post-kernel.
  887. set_property(TARGET app_smem APPEND PROPERTY pinned_partitions "z_libc_partition")
  888. endif()
  889. get_property(APP_SMEM_PINNED_PARTITION_LIST TARGET app_smem PROPERTY pinned_partitions)
  890. if(APP_SMEM_PINNED_PARTITION_LIST)
  891. list(JOIN APP_SMEM_PINNED_PARTITION_LIST "," APP_SMEM_PINNED_PARTITION_LIST_ARG_CSL)
  892. set(APP_SMEM_PINNED_PARTITION_LIST_ARG "--pinpartitions=${APP_SMEM_PINNED_PARTITION_LIST_ARG_CSL}")
  893. endif()
  894. endif()
  895. set(OBJ_FILE_DIR "${PROJECT_BINARY_DIR}/../")
  896. add_custom_target(
  897. ${APP_SMEM_ALIGNED_DEP}
  898. DEPENDS
  899. ${APP_SMEM_ALIGNED_LD}
  900. ${APP_SMEM_PINNED_ALIGNED_LD}
  901. )
  902. add_custom_target(
  903. ${APP_SMEM_UNALIGNED_DEP}
  904. DEPENDS
  905. ${APP_SMEM_UNALIGNED_LD}
  906. ${APP_SMEM_PINNED_UNALIGNED_LD}
  907. )
  908. if(CONFIG_NEWLIB_LIBC)
  909. set(NEWLIB_PART -l libc.a z_libc_partition)
  910. endif()
  911. if(CONFIG_NEWLIB_LIBC_NANO)
  912. set(NEWLIB_PART -l libc_nano.a z_libc_partition)
  913. endif()
  914. add_custom_command(
  915. OUTPUT ${APP_SMEM_UNALIGNED_LD} ${APP_SMEM_PINNED_UNALIGNED_LD}
  916. COMMAND ${PYTHON_EXECUTABLE}
  917. ${ZEPHYR_BASE}/scripts/gen_app_partitions.py
  918. -d ${OBJ_FILE_DIR}
  919. -o ${APP_SMEM_UNALIGNED_LD}
  920. $<$<BOOL:${APP_SMEM_PINNED_UNALIGNED_LD}>:--pinoutput=${APP_SMEM_PINNED_UNALIGNED_LD}>
  921. ${APP_SMEM_PINNED_PARTITION_LIST_ARG}
  922. ${NEWLIB_PART}
  923. $<TARGET_PROPERTY:zephyr_property_target,COMPILE_OPTIONS>
  924. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  925. DEPENDS
  926. kernel
  927. ${ZEPHYR_LIBS_PROPERTY}
  928. WORKING_DIRECTORY ${PROJECT_BINARY_DIR}/
  929. COMMAND_EXPAND_LISTS
  930. COMMENT "Generating app_smem_unaligned linker section"
  931. )
  932. configure_linker_script(
  933. linker_app_smem_unaligned.cmd
  934. "-DLINKER_APP_SMEM_UNALIGNED"
  935. ${CODE_RELOCATION_DEP}
  936. ${APP_SMEM_UNALIGNED_DEP}
  937. ${APP_SMEM_UNALIGNED_LD}
  938. ${APP_SMEM_PINNED_UNALIGNED_LD}
  939. zephyr_generated_headers
  940. )
  941. add_custom_target(
  942. linker_app_smem_unaligned_script
  943. DEPENDS
  944. linker_app_smem_unaligned.cmd
  945. )
  946. set_property(TARGET
  947. linker_app_smem_unaligned_script
  948. PROPERTY INCLUDE_DIRECTORIES
  949. ${ZEPHYR_INCLUDE_DIRS}
  950. )
  951. set(APP_SMEM_UNALIGNED_LIB app_smem_unaligned_output_obj_renamed_lib)
  952. add_executable( app_smem_unaligned_prebuilt misc/empty_file.c)
  953. toolchain_ld_link_elf(
  954. TARGET_ELF app_smem_unaligned_prebuilt
  955. OUTPUT_MAP ${PROJECT_BINARY_DIR}/app_smem_unaligned_prebuilt.map
  956. LIBRARIES_PRE_SCRIPT ""
  957. LINKER_SCRIPT ${PROJECT_BINARY_DIR}/linker_app_smem_unaligned.cmd
  958. LIBRARIES_POST_SCRIPT ""
  959. DEPENDENCIES ${CODE_RELOCATION_DEP}
  960. )
  961. target_byproducts(TARGET app_smem_unaligned_prebuilt
  962. BYPRODUCTS ${PROJECT_BINARY_DIR}/app_smem_unaligned_prebuilt.map
  963. )
  964. set_property(TARGET app_smem_unaligned_prebuilt PROPERTY LINK_DEPENDS ${PROJECT_BINARY_DIR}/linker_app_smem_unaligned.cmd)
  965. add_dependencies( app_smem_unaligned_prebuilt linker_app_smem_unaligned_script ${OFFSETS_LIB})
  966. add_custom_command(
  967. OUTPUT ${APP_SMEM_ALIGNED_LD} ${APP_SMEM_PINNED_ALIGNED_LD}
  968. COMMAND ${PYTHON_EXECUTABLE}
  969. ${ZEPHYR_BASE}/scripts/gen_app_partitions.py
  970. -e $<TARGET_FILE:app_smem_unaligned_prebuilt>
  971. -o ${APP_SMEM_ALIGNED_LD}
  972. $<$<BOOL:${APP_SMEM_PINNED_ALIGNED_LD}>:--pinoutput=${APP_SMEM_PINNED_ALIGNED_LD}>
  973. ${APP_SMEM_PINNED_PARTITION_LIST_ARG}
  974. ${NEWLIB_PART}
  975. $<TARGET_PROPERTY:zephyr_property_target,COMPILE_OPTIONS>
  976. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  977. DEPENDS
  978. kernel
  979. ${ZEPHYR_LIBS_PROPERTY}
  980. app_smem_unaligned_prebuilt
  981. WORKING_DIRECTORY ${PROJECT_BINARY_DIR}/
  982. COMMAND_EXPAND_LISTS
  983. COMMENT "Generating app_smem_aligned linker section"
  984. )
  985. endif()
  986. if(CONFIG_USERSPACE)
  987. # This CONFIG_USERSPACE block is to create place holders to reserve space
  988. # for the gperf generated structures for zephyr_prebuilt.elf.
  989. # These place holders are there so that the placement of kobjects would be
  990. # the same between linking zephyr_prebuilt.elf and zephyr.elf, as
  991. # the gperf hash table is hashed on the addresses of kobjects.
  992. # The placeholders are generated from app_smem_unaligned_prebuilt.elf.
  993. set(KOBJECT_PREBUILT_HASH_LIST kobject_prebuilt_hash.gperf)
  994. set(KOBJECT_PREBUILT_HASH_OUTPUT_SRC_PRE kobject_prebuilt_hash_preprocessed.c)
  995. set(KOBJECT_PREBUILT_HASH_OUTPUT_SRC kobject_prebuilt_hash.c)
  996. set(KOBJECT_PREBUILT_HASH_OUTPUT_OBJ kobject_prebuilt_hash.c.obj)
  997. add_custom_command(
  998. OUTPUT ${KOBJECT_PREBUILT_HASH_LIST}
  999. COMMAND
  1000. ${PYTHON_EXECUTABLE}
  1001. ${GEN_KOBJ_LIST}
  1002. --kernel $<TARGET_FILE:app_smem_unaligned_prebuilt>
  1003. --gperf-output ${KOBJECT_PREBUILT_HASH_LIST}
  1004. ${gen_kobject_list_include_args}
  1005. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  1006. DEPENDS
  1007. app_smem_unaligned_prebuilt
  1008. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  1009. )
  1010. add_custom_target(
  1011. kobj_prebuilt_hash_list
  1012. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_PREBUILT_HASH_LIST}
  1013. )
  1014. add_custom_command(
  1015. OUTPUT ${KOBJECT_PREBUILT_HASH_OUTPUT_SRC_PRE}
  1016. COMMAND
  1017. ${GPERF}
  1018. --output-file ${KOBJECT_PREBUILT_HASH_OUTPUT_SRC_PRE}
  1019. --multiple-iterations 10
  1020. ${KOBJECT_PREBUILT_HASH_LIST}
  1021. DEPENDS kobj_prebuilt_hash_list ${KOBJECT_PREBUILT_HASH_LIST}
  1022. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  1023. )
  1024. add_custom_target(
  1025. kobj_prebuilt_hash_output_src_pre
  1026. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_PREBUILT_HASH_OUTPUT_SRC_PRE}
  1027. )
  1028. add_custom_command(
  1029. OUTPUT ${KOBJECT_PREBUILT_HASH_OUTPUT_SRC}
  1030. COMMAND
  1031. ${PYTHON_EXECUTABLE}
  1032. ${PROCESS_GPERF}
  1033. -i ${KOBJECT_PREBUILT_HASH_OUTPUT_SRC_PRE}
  1034. -o ${KOBJECT_PREBUILT_HASH_OUTPUT_SRC}
  1035. -p "struct z_object"
  1036. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  1037. DEPENDS kobj_prebuilt_hash_output_src_pre ${KOBJECT_PREBUILT_HASH_OUTPUT_SRC_PRE}
  1038. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  1039. )
  1040. add_custom_target(
  1041. kobj_prebuilt_hash_output_src
  1042. DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_PREBUILT_HASH_OUTPUT_SRC}
  1043. )
  1044. add_library(
  1045. kobj_prebuilt_hash_output_lib
  1046. STATIC ${CMAKE_CURRENT_BINARY_DIR}/${KOBJECT_PREBUILT_HASH_OUTPUT_SRC}
  1047. )
  1048. set_source_files_properties(${KOBJECT_PREBUILT_HASH_OUTPUT_SRC}
  1049. PROPERTIES COMPILE_FLAGS
  1050. "${NO_COVERAGE_FLAGS} -fno-function-sections -fno-data-sections")
  1051. set_source_files_properties(${KOBJECT_PREBUILT_HASH_OUTPUT_SRC}
  1052. PROPERTIES COMPILE_DEFINITIONS "${compile_definitions_interface}")
  1053. add_library(kobj_prebuilt_hash_output_lib_interface INTERFACE)
  1054. target_link_libraries(
  1055. kobj_prebuilt_hash_output_lib
  1056. kobj_prebuilt_hash_output_lib_interface
  1057. )
  1058. foreach(incl ${include_dir_in_interface})
  1059. target_include_directories(
  1060. kobj_prebuilt_hash_output_lib_interface
  1061. INTERFACE ${incl}
  1062. )
  1063. endforeach()
  1064. foreach(incl ${sys_include_dir_in_interface})
  1065. target_include_directories(
  1066. kobj_prebuilt_hash_output_lib_interface
  1067. SYSTEM INTERFACE ${incl}
  1068. )
  1069. endforeach()
  1070. set(
  1071. KOBJECT_PREBUILT_HASH_OUTPUT_OBJ_PATH
  1072. ${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/kobj_prebuilt_hash_output_lib.dir/${KOBJECT_PREBUILT_HASH_OUTPUT_OBJ}
  1073. )
  1074. set(KOBJECT_LINKER_HEADER_DATA "${PROJECT_BINARY_DIR}/include/generated/linker-kobject-prebuilt-data.h")
  1075. add_custom_command(
  1076. OUTPUT ${KOBJECT_LINKER_HEADER_DATA}
  1077. COMMAND
  1078. ${PYTHON_EXECUTABLE}
  1079. ${ZEPHYR_BASE}/scripts/gen_kobject_placeholders.py
  1080. --object ${KOBJECT_PREBUILT_HASH_OUTPUT_OBJ_PATH}
  1081. --outdir ${PROJECT_BINARY_DIR}/include/generated
  1082. --datapct ${CONFIG_KOBJECT_DATA_AREA_RESERVE_EXTRA_PERCENT}
  1083. --rodata ${CONFIG_KOBJECT_RODATA_AREA_EXTRA_BYTES}
  1084. $<$<BOOL:${CMAKE_VERBOSE_MAKEFILE}>:--verbose>
  1085. DEPENDS
  1086. kobj_prebuilt_hash_output_lib
  1087. ${KOBJECT_PREBUILT_HASH_OUTPUT_OBJ_PATH}
  1088. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  1089. )
  1090. add_custom_target(
  1091. ${KOBJECT_LINKER_DEP}
  1092. DEPENDS
  1093. ${KOBJECT_LINKER_HEADER_DATA}
  1094. )
  1095. endif()
  1096. configure_linker_script(
  1097. linker_zephyr_prebuilt.cmd
  1098. "-DLINKER_ZEPHYR_PREBUILT"
  1099. ${APP_SMEM_ALIGNED_DEP}
  1100. ${KOBJECT_LINKER_DEP}
  1101. ${CODE_RELOCATION_DEP}
  1102. zephyr_generated_headers
  1103. )
  1104. add_custom_target(
  1105. linker_zephyr_prebuilt_script_target
  1106. DEPENDS
  1107. linker_zephyr_prebuilt.cmd
  1108. )
  1109. set_property(TARGET
  1110. linker_zephyr_prebuilt_script_target
  1111. PROPERTY INCLUDE_DIRECTORIES
  1112. ${ZEPHYR_INCLUDE_DIRS}
  1113. )
  1114. # FIXME: Is there any way to get rid of empty_file.c?
  1115. add_executable( ${ZEPHYR_PREBUILT_EXECUTABLE} misc/empty_file.c)
  1116. toolchain_ld_link_elf(
  1117. TARGET_ELF ${ZEPHYR_PREBUILT_EXECUTABLE}
  1118. OUTPUT_MAP ${PROJECT_BINARY_DIR}/${ZEPHYR_PREBUILT_EXECUTABLE}.map
  1119. LIBRARIES_PRE_SCRIPT ""
  1120. LINKER_SCRIPT ${PROJECT_BINARY_DIR}/linker_zephyr_prebuilt.cmd
  1121. DEPENDENCIES ${CODE_RELOCATION_DEP}
  1122. )
  1123. target_byproducts(TARGET ${ZEPHYR_PREBUILT_EXECUTABLE}
  1124. BYPRODUCTS ${PROJECT_BINARY_DIR}/${ZEPHYR_PREBUILT_EXECUTABLE}.map
  1125. )
  1126. set_property(TARGET
  1127. ${ZEPHYR_PREBUILT_EXECUTABLE}
  1128. PROPERTY LINK_DEPENDS ${PROJECT_BINARY_DIR}/linker_zephyr_prebuilt.cmd
  1129. )
  1130. add_dependencies(
  1131. ${ZEPHYR_PREBUILT_EXECUTABLE}
  1132. linker_zephyr_prebuilt_script_target
  1133. ${OFFSETS_LIB}
  1134. )
  1135. set(generated_kernel_files ${GKSF} ${GKOF})
  1136. if(NOT generated_kernel_files)
  1137. # Use the prebuilt elf as the final elf since we don't have a
  1138. # generation stage.
  1139. set(logical_target_for_zephyr_elf ${ZEPHYR_PREBUILT_EXECUTABLE})
  1140. else()
  1141. # The final linker pass uses the same source linker script of the
  1142. # previous passes, but this time with a different output
  1143. # file and preprocessed with the define LINKER_ZEPHYR_FINAL.
  1144. #
  1145. # LINKER_PASS2 is deprecated but being kept to avoid breaking
  1146. # external projects. It will be removed in the future.
  1147. configure_linker_script(
  1148. linker.cmd
  1149. "-DLINKER_ZEPHYR_FINAL;-DLINKER_PASS2"
  1150. ${CODE_RELOCATION_DEP}
  1151. ${ZEPHYR_PREBUILT_EXECUTABLE}
  1152. zephyr_generated_headers
  1153. )
  1154. add_custom_target(
  1155. linker_zephyr_final_script_target
  1156. DEPENDS
  1157. linker.cmd
  1158. )
  1159. set_property(TARGET
  1160. linker_zephyr_final_script_target
  1161. PROPERTY INCLUDE_DIRECTORIES
  1162. ${ZEPHYR_INCLUDE_DIRS}
  1163. )
  1164. add_executable( ${ZEPHYR_FINAL_EXECUTABLE} misc/empty_file.c ${GKSF})
  1165. toolchain_ld_link_elf(
  1166. TARGET_ELF ${ZEPHYR_FINAL_EXECUTABLE}
  1167. OUTPUT_MAP ${PROJECT_BINARY_DIR}/${ZEPHYR_FINAL_EXECUTABLE}.map
  1168. LIBRARIES_PRE_SCRIPT ${GKOF}
  1169. LINKER_SCRIPT ${PROJECT_BINARY_DIR}/linker.cmd
  1170. LIBRARIES_POST_SCRIPT ""
  1171. DEPENDENCIES ${CODE_RELOCATION_DEP}
  1172. )
  1173. set_property(TARGET ${ZEPHYR_FINAL_EXECUTABLE} PROPERTY LINK_DEPENDS ${PROJECT_BINARY_DIR}/linker.cmd)
  1174. add_dependencies( ${ZEPHYR_FINAL_EXECUTABLE} linker_zephyr_final_script_target)
  1175. # Use the pass2 elf as the final elf
  1176. set(logical_target_for_zephyr_elf ${ZEPHYR_FINAL_EXECUTABLE})
  1177. endif()
  1178. # Export the variable to the application's scope to allow the
  1179. # application to know what the name of the final elf target is.
  1180. set(logical_target_for_zephyr_elf ${logical_target_for_zephyr_elf} PARENT_SCOPE)
  1181. # Override the base name of the last, "logical" .elf output (and last .map) so:
  1182. # 1. it doesn't depend on the number of passes above and the
  1183. # post_build_commands below can always find it no matter which is it;
  1184. # 2. it can be defined in Kconfig
  1185. set_target_properties(${logical_target_for_zephyr_elf} PROPERTIES OUTPUT_NAME ${KERNEL_NAME})
  1186. set(post_build_commands "")
  1187. set(post_build_byproducts "")
  1188. list(APPEND
  1189. post_build_commands
  1190. COMMAND
  1191. ${CMAKE_COMMAND} -E rename ${logical_target_for_zephyr_elf}.map ${KERNEL_MAP_NAME}
  1192. )
  1193. list(APPEND post_build_byproducts ${KERNEL_MAP_NAME})
  1194. if(NOT CONFIG_BUILD_NO_GAP_FILL)
  1195. # Use ';' as separator to get proper space in resulting command.
  1196. set(GAP_FILL "$<TARGET_PROPERTY:bintools,elfconvert_flag_gapfill>0xff")
  1197. endif()
  1198. if(CONFIG_OUTPUT_PRINT_MEMORY_USAGE)
  1199. target_link_libraries(${logical_target_for_zephyr_elf} $<TARGET_PROPERTY:linker,memusage>)
  1200. get_property(memusage_build_command TARGET bintools PROPERTY memusage_command)
  1201. if(memusage_build_command)
  1202. # Note: The use of generator expressions allows downstream extensions to add/change the post build.
  1203. # Unfortunately, the BYPRODUCTS does not allow for generator expression, so question is if we
  1204. # should remove the downstream ability from start.
  1205. # Or fix the output name, by the use of `get_property`
  1206. list(APPEND
  1207. post_build_commands
  1208. COMMAND $<TARGET_PROPERTY:bintools,memusage_command>
  1209. $<TARGET_PROPERTY:bintools,memusage_flag>
  1210. $<TARGET_PROPERTY:bintools,memusage_infile>${KERNEL_ELF_NAME}
  1211. )
  1212. # For now, the byproduct can only be supported upstream on byproducts name,
  1213. # cause byproduct does not support generator expressions
  1214. get_property(memusage_byproducts TARGET bintools PROPERTY memusage_byproducts)
  1215. list(APPEND
  1216. post_build_byproducts
  1217. ${memusage_byproducts}
  1218. )
  1219. endif()
  1220. endif()
  1221. if(CONFIG_BUILD_OUTPUT_HEX OR BOARD_FLASH_RUNNER STREQUAL openocd)
  1222. get_property(elfconvert_formats TARGET bintools PROPERTY elfconvert_formats)
  1223. if(ihex IN_LIST elfconvert_formats)
  1224. list(APPEND
  1225. post_build_commands
  1226. COMMAND $<TARGET_PROPERTY:bintools,elfconvert_command>
  1227. $<TARGET_PROPERTY:bintools,elfconvert_flag>
  1228. ${GAP_FILL}
  1229. $<TARGET_PROPERTY:bintools,elfconvert_flag_outtarget>ihex
  1230. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_remove>.comment
  1231. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_remove>COMMON
  1232. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_remove>.eh_frame
  1233. $<TARGET_PROPERTY:bintools,elfconvert_flag_infile>${KERNEL_ELF_NAME}
  1234. $<TARGET_PROPERTY:bintools,elfconvert_flag_outfile>${KERNEL_HEX_NAME}
  1235. $<TARGET_PROPERTY:bintools,elfconvert_flag_final>
  1236. )
  1237. list(APPEND
  1238. post_build_byproducts
  1239. ${KERNEL_HEX_NAME}
  1240. # ${out_hex_byprod} # Is this needed ?
  1241. )
  1242. endif()
  1243. endif()
  1244. if(CONFIG_BUILD_OUTPUT_BIN)
  1245. get_property(elfconvert_formats TARGET bintools PROPERTY elfconvert_formats)
  1246. if(binary IN_LIST elfconvert_formats)
  1247. list(APPEND
  1248. post_build_commands
  1249. COMMAND $<TARGET_PROPERTY:bintools,elfconvert_command>
  1250. $<TARGET_PROPERTY:bintools,elfconvert_flag>
  1251. ${GAP_FILL}
  1252. $<TARGET_PROPERTY:bintools,elfconvert_flag_outtarget>binary
  1253. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_remove>.comment
  1254. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_remove>COMMON
  1255. $<TARGET_PROPERTY:bintools,elfconvert_flag_section_remove>.eh_frame
  1256. $<TARGET_PROPERTY:bintools,elfconvert_flag_infile>${KERNEL_ELF_NAME}
  1257. $<TARGET_PROPERTY:bintools,elfconvert_flag_outfile>${KERNEL_BIN_NAME}
  1258. $<TARGET_PROPERTY:bintools,elfconvert_flag_final>
  1259. )
  1260. list(APPEND
  1261. post_build_byproducts
  1262. ${KERNEL_BIN_NAME}
  1263. # ${out_hex_byprod} # Is this needed ?
  1264. )
  1265. endif()
  1266. endif()
  1267. if(CONFIG_BUILD_OUTPUT_BIN AND CONFIG_BUILD_OUTPUT_UF2)
  1268. list(APPEND
  1269. post_build_commands
  1270. COMMAND ${PYTHON_EXECUTABLE} ${ZEPHYR_BASE}/scripts/uf2conv.py
  1271. -c
  1272. -f ${CONFIG_BUILD_OUTPUT_UF2_FAMILY_ID}
  1273. -b ${CONFIG_FLASH_LOAD_OFFSET}
  1274. -o ${KERNEL_UF2_NAME}
  1275. ${KERNEL_BIN_NAME}
  1276. )
  1277. list(APPEND
  1278. post_build_byproducts
  1279. ${KERNEL_UF2_NAME}
  1280. )
  1281. endif()
  1282. # Cleanup intermediate files
  1283. if(CONFIG_CLEANUP_INTERMEDIATE_FILES)
  1284. list(APPEND
  1285. post_build_commands
  1286. COMMAND
  1287. # This file can be very large in some cases, delete it as we do not need it.
  1288. ${CMAKE_COMMAND} -E remove ${ZEPHYR_PREBUILT_EXECUTABLE}.elf
  1289. )
  1290. endif()
  1291. if(CONFIG_BUILD_OUTPUT_S19)
  1292. get_property(elfconvert_formats TARGET bintools PROPERTY elfconvert_formats)
  1293. if(srec IN_LIST elfconvert_formats)
  1294. # Should we print a warning if case the tools does not support converting to s19 ?
  1295. list(APPEND
  1296. post_build_commands
  1297. COMMAND $<TARGET_PROPERTY:bintools,elfconvert_command>
  1298. $<TARGET_PROPERTY:bintools,elfconvert_flag>
  1299. ${GAP_FILL}
  1300. $<TARGET_PROPERTY:bintools,elfconvert_flag_outtarget>srec
  1301. $<TARGET_PROPERTY:bintools,elfconvert_flag_srec_len>1
  1302. $<TARGET_PROPERTY:bintools,elfconvert_flag_infile>${KERNEL_ELF_NAME}
  1303. $<TARGET_PROPERTY:bintools,elfconvert_flag_outfile>${KERNEL_S19_NAME}
  1304. $<TARGET_PROPERTY:bintools,elfconvert_flag_final>
  1305. )
  1306. list(APPEND
  1307. post_build_byproducts
  1308. ${KERNEL_S19_NAME}
  1309. # ${out_S19_byprod} # Is this needed ?
  1310. )
  1311. endif()
  1312. endif()
  1313. if(CONFIG_OUTPUT_DISASSEMBLY)
  1314. if(CONFIG_OUTPUT_DISASSEMBLE_ALL)
  1315. set(disassembly_type "$<TARGET_PROPERTY:bintools,disassembly_flag_all>")
  1316. else()
  1317. set(disassembly_type "$<TARGET_PROPERTY:bintools,disassembly_flag_inline_source>")
  1318. endif()
  1319. list(APPEND
  1320. post_build_commands
  1321. COMMAND $<TARGET_PROPERTY:bintools,disassembly_command>
  1322. $<TARGET_PROPERTY:bintools,disassembly_flag>
  1323. ${disassembly_type}
  1324. $<TARGET_PROPERTY:bintools,disassembly_flag_infile>${KERNEL_ELF_NAME}
  1325. $<TARGET_PROPERTY:bintools,disassembly_flag_outfile>${KERNEL_LST_NAME}
  1326. $<TARGET_PROPERTY:bintools,disassembly_flag_final>
  1327. )
  1328. list(APPEND
  1329. post_build_byproducts
  1330. ${KERNEL_LST_NAME}
  1331. # ${out_disassembly_byprod} # Needed ??
  1332. )
  1333. endif()
  1334. if(CONFIG_OUTPUT_STAT)
  1335. # zephyr_post_build(TOOLS bintools COMMAND readelf FLAGS headers INFILE file OUTFILE outfile)
  1336. list(APPEND
  1337. post_build_commands
  1338. COMMAND $<TARGET_PROPERTY:bintools,readelf_command>
  1339. $<TARGET_PROPERTY:bintools,readelf_flag>
  1340. $<TARGET_PROPERTY:bintools,readelf_flag_headers>
  1341. $<TARGET_PROPERTY:bintools,readelf_flag_infile>${KERNEL_ELF_NAME}
  1342. $<TARGET_PROPERTY:bintools,readelf_flag_outfile>${KERNEL_STAT_NAME}
  1343. $<TARGET_PROPERTY:bintools,readelf_flag_final>
  1344. )
  1345. list(APPEND
  1346. post_build_byproducts
  1347. ${KERNEL_STAT_NAME}
  1348. )
  1349. endif()
  1350. if(CONFIG_BUILD_OUTPUT_STRIPPED)
  1351. list(APPEND
  1352. post_build_commands
  1353. COMMAND $<TARGET_PROPERTY:bintools,strip_command>
  1354. $<TARGET_PROPERTY:bintools,strip_flag>
  1355. $<TARGET_PROPERTY:bintools,strip_flag_all>
  1356. $<TARGET_PROPERTY:bintools,strip_flag_infile>${KERNEL_ELF_NAME}
  1357. $<TARGET_PROPERTY:bintools,strip_flag_outfile>${KERNEL_STRIP_NAME}
  1358. $<TARGET_PROPERTY:bintools,strip_flag_final>
  1359. )
  1360. list(APPEND
  1361. post_build_byproducts
  1362. ${KERNEL_STRIP_NAME}
  1363. )
  1364. endif()
  1365. if(CONFIG_BUILD_OUTPUT_EXE)
  1366. list(APPEND
  1367. post_build_commands
  1368. COMMAND
  1369. ${CMAKE_COMMAND} -E copy ${KERNEL_ELF_NAME} ${KERNEL_EXE_NAME}
  1370. )
  1371. list(APPEND
  1372. post_build_byproducts
  1373. ${KERNEL_EXE_NAME}
  1374. )
  1375. endif()
  1376. # Generate and use MCUboot related artifacts as needed.
  1377. if(CONFIG_BOOTLOADER_MCUBOOT)
  1378. include(${CMAKE_CURRENT_LIST_DIR}/cmake/mcuboot.cmake)
  1379. endif()
  1380. get_property(extra_post_build_commands
  1381. GLOBAL PROPERTY
  1382. extra_post_build_commands
  1383. )
  1384. list(APPEND
  1385. post_build_commands
  1386. ${extra_post_build_commands}
  1387. )
  1388. get_property(extra_post_build_byproducts
  1389. GLOBAL PROPERTY
  1390. extra_post_build_byproducts
  1391. )
  1392. list(APPEND
  1393. post_build_byproducts
  1394. ${extra_post_build_byproducts}
  1395. )
  1396. if(CONFIG_LOG_DICTIONARY_SUPPORT)
  1397. set(LOG_DICT_DB_NAME ${PROJECT_BINARY_DIR}/log_dictionary.json)
  1398. list(APPEND
  1399. post_build_commands
  1400. COMMAND
  1401. ${PYTHON_EXECUTABLE}
  1402. ${ZEPHYR_BASE}/scripts/logging/dictionary/database_gen.py
  1403. ${KERNEL_ELF_NAME}
  1404. ${LOG_DICT_DB_NAME}
  1405. --build ${BUILD_VERSION}
  1406. )
  1407. list(APPEND
  1408. post_build_byproducts
  1409. ${LOG_DICT_DB_NAME}
  1410. )
  1411. endif()
  1412. # Add post_build_commands to post-process the final .elf file produced by
  1413. # either the ZEPHYR_PREBUILT_EXECUTABLE or the KERNEL_ELF executable
  1414. # targets above.
  1415. add_custom_command(
  1416. TARGET ${logical_target_for_zephyr_elf}
  1417. POST_BUILD
  1418. ${post_build_commands}
  1419. BYPRODUCTS
  1420. ${post_build_byproducts}
  1421. COMMENT "Generating files from ${KERNEL_ELF_NAME} for board: ${BOARD}"
  1422. COMMAND_EXPAND_LISTS
  1423. # NB: COMMENT only works for some CMake-Generators
  1424. )
  1425. # To populate with hex files to merge, do the following:
  1426. # set_property(GLOBAL APPEND PROPERTY HEX_FILES_TO_MERGE ${my_local_list})
  1427. # Note that the zephyr.hex file will not be included automatically.
  1428. get_property(HEX_FILES_TO_MERGE GLOBAL PROPERTY HEX_FILES_TO_MERGE)
  1429. if(HEX_FILES_TO_MERGE)
  1430. # Merge in out-of-tree hex files.
  1431. set(MERGED_HEX_NAME merged.hex)
  1432. add_custom_command(
  1433. OUTPUT ${MERGED_HEX_NAME}
  1434. COMMAND
  1435. ${PYTHON_EXECUTABLE}
  1436. ${ZEPHYR_BASE}/scripts/mergehex.py
  1437. -o ${MERGED_HEX_NAME}
  1438. ${HEX_FILES_TO_MERGE}
  1439. DEPENDS ${HEX_FILES_TO_MERGE} ${logical_target_for_zephyr_elf}
  1440. )
  1441. add_custom_target(mergehex ALL DEPENDS ${MERGED_HEX_NAME})
  1442. list(APPEND RUNNERS_DEPS mergehex)
  1443. message(VERBOSE "Merging hex files: ${HEX_FILES_TO_MERGE}")
  1444. endif()
  1445. if(EMU_PLATFORM)
  1446. include(${ZEPHYR_BASE}/cmake/emu/${EMU_PLATFORM}.cmake)
  1447. else()
  1448. add_custom_target(run
  1449. COMMAND
  1450. ${CMAKE_COMMAND} -E echo
  1451. "==================================================="
  1452. "Emulation/Simulation not supported with this board."
  1453. "==================================================="
  1454. )
  1455. endif()
  1456. add_subdirectory(cmake/flash)
  1457. add_subdirectory(cmake/usage)
  1458. add_subdirectory(cmake/reports)
  1459. if(NOT CONFIG_TEST)
  1460. if(CONFIG_ASSERT AND (NOT CONFIG_FORCE_NO_ASSERT))
  1461. message(WARNING "__ASSERT() statements are globally ENABLED")
  1462. endif()
  1463. endif()
  1464. if(CONFIG_BOARD_DEPRECATED_RELEASE)
  1465. message(WARNING "
  1466. WARNING: The board '${BOARD}' is deprecated and will be
  1467. removed in version ${CONFIG_BOARD_DEPRECATED_RELEASE}"
  1468. )
  1469. endif()
  1470. if(CONFIG_SOC_DEPRECATED_RELEASE)
  1471. message(WARNING "
  1472. WARNING: The SoC '${SOC_NAME}' is deprecated and will be
  1473. removed in version ${CONFIG_SOC_DEPRECATED_RELEASE}"
  1474. )
  1475. endif()
  1476. # In CMake projects, 'CMAKE_BUILD_TYPE' usually determines the
  1477. # optimization flag, but in Zephyr it is determined through
  1478. # Kconfig. Here we give a warning when there is a mismatch between the
  1479. # two in case the user is not aware of this.
  1480. set(build_types None Debug Release RelWithDebInfo MinSizeRel)
  1481. if((CMAKE_BUILD_TYPE IN_LIST build_types) AND (NOT NO_BUILD_TYPE_WARNING))
  1482. string(TOUPPER ${CMAKE_BUILD_TYPE} CMAKE_BUILD_TYPE_uppercase)
  1483. if(NOT (${OPTIMIZATION_FLAG} IN_LIST CMAKE_C_FLAGS_${CMAKE_BUILD_TYPE_uppercase}))
  1484. message(WARNING "
  1485. The CMake build type was set to '${CMAKE_BUILD_TYPE}', but the optimization flag was set to '${OPTIMIZATION_FLAG}'.
  1486. This may be intentional and the warning can be turned off by setting the CMake variable 'NO_BUILD_TYPE_WARNING'"
  1487. )
  1488. endif()
  1489. endif()
  1490. # @Intent: Set compiler specific flags for standard C/C++ includes
  1491. # Done at the very end, so any other system includes which may
  1492. # be added by Zephyr components were first in list.
  1493. # Note, the compile flags are moved, but the system include is still present here.
  1494. zephyr_compile_options($<TARGET_PROPERTY:compiler,nostdinc>)
  1495. target_include_directories(zephyr_interface SYSTEM INTERFACE $<TARGET_PROPERTY:compiler,nostdinc_include>)
  1496. if(NOT CONFIG_LIB_CPLUSPLUS)
  1497. zephyr_compile_options($<$<COMPILE_LANGUAGE:CXX>:$<TARGET_PROPERTY:compiler-cpp,nostdincxx>>)
  1498. endif()
  1499. # Finally export all build flags from Zephyr
  1500. add_subdirectory_ifdef(
  1501. CONFIG_MAKEFILE_EXPORTS
  1502. cmake/makefile_exports
  1503. )