rp2: Add support for USER_C_MODULES to CMake build system.
The parts that are generic are added to py/ so they can be used by other ports that use CMake. py/usermod.cmake: * Creates a usermod target to hang user C/CXX modules from. * Gathers sources from user C/CXX modules and libs for QSTR scan. ports/rp2/CMakeLists.txt: * Includes py/usermod.cmake. * Links the resulting usermod library to the MicroPython target. py/mkrules.cmake: Add cxxflags to qstr.i.last custom command for CXX modules: * MICROPY_CPP_FLAGS so CXX modules will find includes. * -DNO_QSTR to fix fatal error missing "genhdr/qstrdefs.generated.h". Usage: The rp2 port can be linked against user C modules by running: make USER_C_MODULES=/path/to/module/micropython.cmake CMake will print a list of included modules. Co-authored-by: Graham Sanderson <graham.sanderson@raspberrypi.org> Co-authored-by: Michael O'Cleirigh <michael.ocleirigh@rivulet.ca> Signed-off-by: Phil Howard <phil@pimoroni.com>
This commit is contained in:
parent
ccc388f157
commit
0cf12dd59c
@ -27,6 +27,8 @@ project(${MICROPY_TARGET})
|
|||||||
|
|
||||||
pico_sdk_init()
|
pico_sdk_init()
|
||||||
|
|
||||||
|
include(${MICROPY_DIR}/py/usermod.cmake)
|
||||||
|
|
||||||
add_executable(${MICROPY_TARGET})
|
add_executable(${MICROPY_TARGET})
|
||||||
|
|
||||||
set(MICROPY_QSTRDEFS_PORT
|
set(MICROPY_QSTRDEFS_PORT
|
||||||
@ -80,6 +82,7 @@ set(MICROPY_SOURCE_PORT
|
|||||||
set(MICROPY_SOURCE_QSTR
|
set(MICROPY_SOURCE_QSTR
|
||||||
${MICROPY_SOURCE_PY}
|
${MICROPY_SOURCE_PY}
|
||||||
${MICROPY_SOURCE_EXTMOD}
|
${MICROPY_SOURCE_EXTMOD}
|
||||||
|
${MICROPY_SOURCE_USERMOD}
|
||||||
${MICROPY_DIR}/lib/utils/mpirq.c
|
${MICROPY_DIR}/lib/utils/mpirq.c
|
||||||
${MICROPY_DIR}/lib/utils/sys_stdio_mphal.c
|
${MICROPY_DIR}/lib/utils/sys_stdio_mphal.c
|
||||||
${PROJECT_SOURCE_DIR}/machine_adc.c
|
${PROJECT_SOURCE_DIR}/machine_adc.c
|
||||||
@ -142,7 +145,10 @@ target_sources(${MICROPY_TARGET} PRIVATE
|
|||||||
${MICROPY_SOURCE_PORT}
|
${MICROPY_SOURCE_PORT}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_link_libraries(${MICROPY_TARGET} usermod)
|
||||||
|
|
||||||
target_include_directories(${MICROPY_TARGET} PRIVATE
|
target_include_directories(${MICROPY_TARGET} PRIVATE
|
||||||
|
${MICROPY_INC_USERMOD}
|
||||||
"${PROJECT_SOURCE_DIR}"
|
"${PROJECT_SOURCE_DIR}"
|
||||||
"${MICROPY_DIR}"
|
"${MICROPY_DIR}"
|
||||||
"${CMAKE_BINARY_DIR}"
|
"${CMAKE_BINARY_DIR}"
|
||||||
|
@ -6,8 +6,14 @@ BUILD = build
|
|||||||
|
|
||||||
$(VERBOSE)MAKESILENT = -s
|
$(VERBOSE)MAKESILENT = -s
|
||||||
|
|
||||||
|
CMAKE_ARGS =
|
||||||
|
|
||||||
|
ifdef USER_C_MODULES
|
||||||
|
CMAKE_ARGS += -DUSER_C_MODULES=${USER_C_MODULES}
|
||||||
|
endif
|
||||||
|
|
||||||
all:
|
all:
|
||||||
[ -d $(BUILD) ] || cmake -S . -B $(BUILD) -DPICO_BUILD_DOCS=0
|
[ -d $(BUILD) ] || cmake -S . -B $(BUILD) -DPICO_BUILD_DOCS=0 ${CMAKE_ARGS}
|
||||||
$(MAKE) $(MAKESILENT) -C $(BUILD)
|
$(MAKE) $(MAKESILENT) -C $(BUILD)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
|
@ -69,7 +69,7 @@ add_custom_command(
|
|||||||
# it was last run, but it looks like it's not possible to specify that with cmake.
|
# it was last run, but it looks like it's not possible to specify that with cmake.
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${MICROPY_QSTRDEFS_LAST}
|
OUTPUT ${MICROPY_QSTRDEFS_LAST}
|
||||||
COMMAND ${Python3_EXECUTABLE} ${MICROPY_PY_DIR}/makeqstrdefs.py pp ${CMAKE_C_COMPILER} -E output ${MICROPY_GENHDR_DIR}/qstr.i.last cflags ${MICROPY_CPP_FLAGS} -DNO_QSTR sources ${MICROPY_SOURCE_QSTR}
|
COMMAND ${Python3_EXECUTABLE} ${MICROPY_PY_DIR}/makeqstrdefs.py pp ${CMAKE_C_COMPILER} -E output ${MICROPY_GENHDR_DIR}/qstr.i.last cflags ${MICROPY_CPP_FLAGS} -DNO_QSTR cxxflags ${MICROPY_CPP_FLAGS} -DNO_QSTR sources ${MICROPY_SOURCE_QSTR}
|
||||||
DEPENDS ${MICROPY_MODULEDEFS}
|
DEPENDS ${MICROPY_MODULEDEFS}
|
||||||
${MICROPY_SOURCE_QSTR}
|
${MICROPY_SOURCE_QSTR}
|
||||||
VERBATIM
|
VERBATIM
|
||||||
|
52
py/usermod.cmake
Normal file
52
py/usermod.cmake
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
# Create a target for all user modules to link against.
|
||||||
|
add_library(usermod INTERFACE)
|
||||||
|
|
||||||
|
function(usermod_gather_sources SOURCES_VARNAME INCLUDE_DIRECTORIES_VARNAME INCLUDED_VARNAME LIB)
|
||||||
|
if (NOT ${LIB} IN_LIST ${INCLUDED_VARNAME})
|
||||||
|
list(APPEND ${INCLUDED_VARNAME} ${LIB})
|
||||||
|
|
||||||
|
# Gather library sources
|
||||||
|
get_target_property(lib_sources ${LIB} INTERFACE_SOURCES)
|
||||||
|
if (lib_sources)
|
||||||
|
list(APPEND ${SOURCES_VARNAME} ${lib_sources})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Gather library includes
|
||||||
|
get_target_property(lib_include_directories ${LIB} INTERFACE_INCLUDE_DIRECTORIES)
|
||||||
|
if (lib_include_directories)
|
||||||
|
list(APPEND ${INCLUDE_DIRECTORIES_VARNAME} ${lib_include_directories})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Recurse linked libraries
|
||||||
|
get_target_property(trans_depend ${LIB} INTERFACE_LINK_LIBRARIES)
|
||||||
|
if (trans_depend)
|
||||||
|
foreach(SUB_LIB ${trans_depend})
|
||||||
|
usermod_gather_sources(
|
||||||
|
${SOURCES_VARNAME}
|
||||||
|
${INCLUDE_DIRECTORIES_VARNAME}
|
||||||
|
${INCLUDED_VARNAME}
|
||||||
|
${SUB_LIB})
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(${SOURCES_VARNAME} ${${SOURCES_VARNAME}} PARENT_SCOPE)
|
||||||
|
set(${INCLUDE_DIRECTORIES_VARNAME} ${${INCLUDE_DIRECTORIES_VARNAME}} PARENT_SCOPE)
|
||||||
|
set(${INCLUDED_VARNAME} ${${INCLUDED_VARNAME}} PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
# Include CMake files for user modules.
|
||||||
|
if (USER_C_MODULES)
|
||||||
|
foreach(USER_C_MODULE_PATH ${USER_C_MODULES})
|
||||||
|
message("Including User C Module(s) from ${USER_C_MODULE_PATH}")
|
||||||
|
include(${USER_C_MODULE_PATH})
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Recursively gather sources for QSTR scanning - doesn't support generator expressions.
|
||||||
|
usermod_gather_sources(MICROPY_SOURCE_USERMOD MICROPY_INC_USERMOD found_modules usermod)
|
||||||
|
|
||||||
|
# Report found modules.
|
||||||
|
list(REMOVE_ITEM found_modules "usermod")
|
||||||
|
list(JOIN found_modules ", " found_modules)
|
||||||
|
message("Found User C Module(s): ${found_modules}")
|
Loading…
Reference in New Issue
Block a user