2019-04-06 15:08:09 +02:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2019-01-18 16:47:05 +01:00
|
|
|
file(MAKE_DIRECTORY ${PROJECT_BINARY_DIR}/include/generated)
|
|
|
|
|
2017-10-27 15:43:34 +02:00
|
|
|
# Zephyr code can configure itself based on a KConfig'uration with the
|
|
|
|
# header file autoconf.h. There exists an analogous file
|
2018-10-09 16:03:29 +02:00
|
|
|
# generated_dts_board_unfixed.h that allows configuration based on information
|
2017-10-27 15:43:34 +02:00
|
|
|
# encoded in DTS.
|
|
|
|
#
|
|
|
|
# Here we call on dtc, the gcc preprocessor, and
|
|
|
|
# scripts/dts/extract_dts_includes.py to generate this header file at
|
|
|
|
# CMake configure-time.
|
|
|
|
#
|
|
|
|
# See ~/zephyr/doc/dts
|
2019-03-14 13:06:40 +01:00
|
|
|
set(GENERATED_DTS_BOARD_UNFIXED_H ${PROJECT_BINARY_DIR}/include/generated/generated_dts_board_unfixed.h)
|
|
|
|
set(GENERATED_DTS_BOARD_CONF ${PROJECT_BINARY_DIR}/include/generated/generated_dts_board.conf)
|
2019-08-28 16:30:23 +02:00
|
|
|
set(DTS_POST_CPP ${PROJECT_BINARY_DIR}/${BOARD}.dts.pre.tmp)
|
2019-03-14 13:06:40 +01:00
|
|
|
|
2018-09-27 17:15:24 +02:00
|
|
|
set_ifndef(DTS_SOURCE ${BOARD_DIR}/${BOARD}.dts)
|
2018-06-14 20:21:18 +02:00
|
|
|
set_ifndef(DTS_COMMON_OVERLAYS ${ZEPHYR_BASE}/dts/common/common.dts)
|
2019-03-14 13:06:40 +01:00
|
|
|
|
|
|
|
# 'DTS_ROOT' is a list of directories where a directory tree with DT
|
2019-07-04 16:48:53 +02:00
|
|
|
# files may be found. It always includes the application directory,
|
|
|
|
# the board directory, and ${ZEPHYR_BASE}.
|
2019-03-14 13:06:40 +01:00
|
|
|
list(APPEND
|
|
|
|
DTS_ROOT
|
|
|
|
${APPLICATION_SOURCE_DIR}
|
2019-07-04 16:48:53 +02:00
|
|
|
${BOARD_DIR}
|
2019-03-14 13:06:40 +01:00
|
|
|
${ZEPHYR_BASE}
|
|
|
|
)
|
2017-10-27 15:43:34 +02:00
|
|
|
|
2018-04-18 09:31:02 +02:00
|
|
|
set(dts_files
|
|
|
|
${DTS_SOURCE}
|
|
|
|
${DTS_COMMON_OVERLAYS}
|
2019-01-14 16:11:15 +01:00
|
|
|
${shield_dts_files}
|
2018-04-18 09:31:02 +02:00
|
|
|
)
|
2018-03-15 17:21:35 +01:00
|
|
|
|
2019-01-18 16:47:05 +01:00
|
|
|
# TODO: What to do about non-posix platforms where NOT CONFIG_HAS_DTS (xtensa)?
|
|
|
|
# Drop support for NOT CONFIG_HAS_DTS perhaps?
|
|
|
|
if(EXISTS ${DTS_SOURCE})
|
|
|
|
set(SUPPORTS_DTS 1)
|
|
|
|
else()
|
|
|
|
set(SUPPORTS_DTS 0)
|
|
|
|
endif()
|
2017-10-27 15:43:34 +02:00
|
|
|
|
2019-01-18 16:47:05 +01:00
|
|
|
if(SUPPORTS_DTS)
|
2018-01-31 18:00:49 +01:00
|
|
|
if(DTC_OVERLAY_FILE)
|
|
|
|
# Convert from space-separated files into file list
|
|
|
|
string(REPLACE " " ";" DTC_OVERLAY_FILE_AS_LIST ${DTC_OVERLAY_FILE})
|
2018-04-18 09:31:02 +02:00
|
|
|
list(APPEND
|
|
|
|
dts_files
|
|
|
|
${DTC_OVERLAY_FILE_AS_LIST}
|
|
|
|
)
|
2017-10-27 15:43:34 +02:00
|
|
|
endif()
|
|
|
|
|
2018-11-13 16:50:25 +01:00
|
|
|
set(i 0)
|
2018-01-31 18:00:49 +01:00
|
|
|
unset(DTC_INCLUDE_FLAG_FOR_DTS)
|
|
|
|
foreach(dts_file ${dts_files})
|
|
|
|
list(APPEND DTC_INCLUDE_FLAG_FOR_DTS
|
|
|
|
-include ${dts_file})
|
2018-11-13 16:50:25 +01:00
|
|
|
|
2018-12-19 10:40:57 +01:00
|
|
|
if(i EQUAL 0)
|
|
|
|
message(STATUS "Loading ${dts_file} as base")
|
|
|
|
else()
|
|
|
|
message(STATUS "Overlaying ${dts_file}")
|
|
|
|
endif()
|
2018-11-13 16:50:25 +01:00
|
|
|
|
2019-01-24 16:12:18 +01:00
|
|
|
# Ensure that changes to 'dts_file's cause CMake to be re-run
|
|
|
|
set_property(DIRECTORY APPEND PROPERTY
|
|
|
|
CMAKE_CONFIGURE_DEPENDS
|
|
|
|
${dts_file}
|
|
|
|
)
|
|
|
|
|
2018-12-19 10:40:57 +01:00
|
|
|
math(EXPR i "${i}+1")
|
2018-01-31 18:00:49 +01:00
|
|
|
endforeach()
|
2017-10-27 15:43:34 +02:00
|
|
|
|
2019-03-14 13:06:40 +01:00
|
|
|
foreach(dts_root ${DTS_ROOT})
|
|
|
|
foreach(dts_root_path
|
|
|
|
include
|
|
|
|
dts/common
|
|
|
|
dts/${ARCH}
|
|
|
|
dts
|
|
|
|
)
|
|
|
|
set(full_path ${dts_root}/${dts_root_path})
|
|
|
|
if(EXISTS ${full_path})
|
|
|
|
list(APPEND
|
|
|
|
DTS_ROOT_SYSTEM_INCLUDE_DIRS
|
|
|
|
-isystem ${full_path}
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
foreach(dts_root ${DTS_ROOT})
|
|
|
|
set(full_path ${dts_root}/dts/bindings)
|
|
|
|
if(EXISTS ${full_path})
|
|
|
|
list(APPEND
|
|
|
|
DTS_ROOT_BINDINGS
|
|
|
|
${full_path}
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
|
2017-10-27 15:43:34 +02:00
|
|
|
# TODO: Cut down on CMake configuration time by avoiding
|
2018-10-09 16:03:29 +02:00
|
|
|
# regeneration of generated_dts_board_unfixed.h on every configure. How
|
2017-10-27 15:43:34 +02:00
|
|
|
# challenging is this? What are the dts dependencies? We run the
|
|
|
|
# preprocessor, and it seems to be including all kinds of
|
|
|
|
# directories with who-knows how many header files.
|
|
|
|
|
|
|
|
# Run the C preprocessor on an empty C source file that has one or
|
|
|
|
# more DTS source files -include'd into it to create the
|
|
|
|
# intermediary file *.dts.pre.tmp
|
|
|
|
execute_process(
|
|
|
|
COMMAND ${CMAKE_C_COMPILER}
|
|
|
|
-x assembler-with-cpp
|
|
|
|
-nostdinc
|
2019-03-14 13:06:40 +01:00
|
|
|
${DTS_ROOT_SYSTEM_INCLUDE_DIRS}
|
2018-01-31 18:00:49 +01:00
|
|
|
${DTC_INCLUDE_FLAG_FOR_DTS} # include the DTS source and overlays
|
2018-11-01 17:45:54 +01:00
|
|
|
${NOSYSDEF_CFLAG}
|
|
|
|
-D__DTS__
|
2017-10-27 15:43:34 +02:00
|
|
|
-P
|
2018-01-11 15:46:44 +01:00
|
|
|
-E ${ZEPHYR_BASE}/misc/empty_file.c
|
2018-02-26 17:52:29 +01:00
|
|
|
-o ${BOARD}.dts.pre.tmp
|
2017-10-27 15:43:34 +02:00
|
|
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
|
|
RESULT_VARIABLE ret
|
|
|
|
)
|
|
|
|
if(NOT "${ret}" STREQUAL "0")
|
|
|
|
message(FATAL_ERROR "command failed with return code: ${ret}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Run the DTC on *.dts.pre.tmp to create the intermediary file *.dts_compiled
|
2019-01-18 21:10:04 +01:00
|
|
|
|
|
|
|
set(DTC_WARN_UNIT_ADDR_IF_ENABLED "")
|
|
|
|
check_dtc_flag("-Wunique_unit_address_if_enabled" check)
|
|
|
|
if (check)
|
|
|
|
set(DTC_WARN_UNIT_ADDR_IF_ENABLED "-Wunique_unit_address_if_enabled")
|
|
|
|
endif()
|
2019-01-24 16:46:08 +01:00
|
|
|
set(DTC_NO_WARN_UNIT_ADDR "")
|
|
|
|
check_dtc_flag("-Wno-unique_unit_address" check)
|
|
|
|
if (check)
|
|
|
|
set(DTC_NO_WARN_UNIT_ADDR "-Wno-unique_unit_address")
|
|
|
|
endif()
|
2017-10-27 15:43:34 +02:00
|
|
|
execute_process(
|
|
|
|
COMMAND ${DTC}
|
|
|
|
-O dts
|
2018-02-26 17:52:29 +01:00
|
|
|
-o ${BOARD}.dts_compiled
|
2017-10-27 15:43:34 +02:00
|
|
|
-b 0
|
2018-10-03 09:13:06 +02:00
|
|
|
-E unit_address_vs_reg
|
2019-01-24 16:46:08 +01:00
|
|
|
${DTC_NO_WARN_UNIT_ADDR}
|
2019-01-18 21:10:04 +01:00
|
|
|
${DTC_WARN_UNIT_ADDR_IF_ENABLED}
|
2018-10-03 10:39:43 +02:00
|
|
|
${EXTRA_DTC_FLAGS} # User settable
|
2018-02-26 17:52:29 +01:00
|
|
|
${BOARD}.dts.pre.tmp
|
2017-10-27 15:43:34 +02:00
|
|
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
|
|
RESULT_VARIABLE ret
|
|
|
|
)
|
|
|
|
if(NOT "${ret}" STREQUAL "0")
|
|
|
|
message(FATAL_ERROR "command failed with return code: ${ret}")
|
|
|
|
endif()
|
|
|
|
|
2018-12-17 20:09:47 +01:00
|
|
|
#
|
|
|
|
# Run gen_defines.py to create a .conf file and a header file
|
|
|
|
#
|
|
|
|
|
|
|
|
set(CMD_NEW_EXTRACT ${PYTHON_EXECUTABLE} ${ZEPHYR_BASE}/scripts/dts/gen_defines.py
|
|
|
|
--dts ${BOARD}.dts.pre.tmp
|
|
|
|
--bindings-dir ${DTS_ROOT_BINDINGS}
|
|
|
|
--conf-out ${GENERATED_DTS_BOARD_CONF}
|
|
|
|
--header-out ${GENERATED_DTS_BOARD_UNFIXED_H}
|
|
|
|
)
|
|
|
|
|
|
|
|
execute_process(
|
|
|
|
COMMAND ${CMD_NEW_EXTRACT}
|
|
|
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
|
|
RESULT_VARIABLE ret
|
|
|
|
)
|
|
|
|
if(NOT "${ret}" STREQUAL "0")
|
|
|
|
message(FATAL_ERROR "new extractor failed with return code: ${ret}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
#
|
|
|
|
# Run extract_dts_includes.py (the older DT/binding parser) to generate some
|
|
|
|
# legacy identifiers (via --deprecated-only). This will go away later.
|
|
|
|
#
|
|
|
|
|
2018-06-14 20:21:18 +02:00
|
|
|
set(CMD_EXTRACT_DTS_INCLUDES ${PYTHON_EXECUTABLE} ${ZEPHYR_BASE}/scripts/dts/extract_dts_includes.py
|
2018-12-17 20:09:47 +01:00
|
|
|
--deprecated-only
|
2018-02-26 17:52:29 +01:00
|
|
|
--dts ${BOARD}.dts_compiled
|
2019-03-14 13:06:40 +01:00
|
|
|
--yaml ${DTS_ROOT_BINDINGS}
|
2018-12-17 20:09:47 +01:00
|
|
|
--include ${GENERATED_DTS_BOARD_UNFIXED_H}.deprecated
|
2018-10-31 19:19:54 +01:00
|
|
|
--old-alias-names
|
2017-10-27 15:43:34 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
execute_process(
|
2018-03-07 11:15:00 +01:00
|
|
|
COMMAND ${CMD_EXTRACT_DTS_INCLUDES}
|
2017-10-27 15:43:34 +02:00
|
|
|
WORKING_DIRECTORY ${PROJECT_BINARY_DIR}
|
|
|
|
RESULT_VARIABLE ret
|
|
|
|
)
|
|
|
|
if(NOT "${ret}" STREQUAL "0")
|
|
|
|
message(FATAL_ERROR "command failed with return code: ${ret}")
|
|
|
|
endif()
|
|
|
|
|
2018-12-12 15:35:28 +01:00
|
|
|
import_kconfig(DT_ ${GENERATED_DTS_BOARD_CONF})
|
2017-10-27 15:43:34 +02:00
|
|
|
|
|
|
|
else()
|
2018-10-09 16:03:29 +02:00
|
|
|
file(WRITE ${GENERATED_DTS_BOARD_UNFIXED_H} "/* WARNING. THIS FILE IS AUTO-GENERATED. DO NOT MODIFY! */")
|
2018-12-17 20:09:47 +01:00
|
|
|
file(WRITE ${GENERATED_DTS_BOARD_UNFIXED_H}.deprecated "/* WARNING. THIS FILE IS AUTO-GENERATED. DO NOT MODIFY! */")
|
2019-01-18 16:47:05 +01:00
|
|
|
endif(SUPPORTS_DTS)
|