Initial commit
This commit is contained in:
75
dev-utility/BuildKernelModule.cmake
Normal file
75
dev-utility/BuildKernelModule.cmake
Normal file
@@ -0,0 +1,75 @@
|
||||
function(module_objects module_name input_files output_string)
|
||||
foreach(module_file ${input_files})
|
||||
string(REGEX MATCH "^.*[oc]$" match_file ${module_file})
|
||||
if(NOT ${match_file})
|
||||
file(RELATIVE_PATH rel_file "${PROJECT_SOURCE_DIR}" ${module_file} )
|
||||
string(REPLACE ".c" ".o" module_object ${rel_file})
|
||||
list(APPEND module_objects "${module_name}-objs += ${module_object}")
|
||||
endif()
|
||||
endforeach()
|
||||
string(REPLACE ";" "\n" module_objects_string "${module_objects}")
|
||||
set(${output_string} ${module_objects_string} PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
function(module_include_directories input_dirs output_string)
|
||||
foreach(include_dir ${input_dirs})
|
||||
get_filename_component(abs_path ${include_dir} REALPATH)
|
||||
list(APPEND module_includes "ccflags-y += -I${abs_path}")
|
||||
include_directories(${abs_path})
|
||||
endforeach()
|
||||
string(REPLACE ";" "\n" module_includes_string "${module_includes}")
|
||||
set(${output_string} ${module_includes_string} PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
function(module_add_definitions input_definitions output_string)
|
||||
foreach(input_definition ${input_definitions})
|
||||
add_definitions(${input_definition})
|
||||
list(APPEND module_definitions "ccflags-y += ${input_definition}")
|
||||
endforeach()
|
||||
string(REPLACE ";" "\n" module_definitions_string "${module_definitions}")
|
||||
set(${output_string} ${module_definitions_string} PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
function(module_kbuild module_name module_files module_include_dirs module_defs output_string)
|
||||
module_objects("${module_name}" "${module_files}" kobjects_string)
|
||||
module_include_directories("${module_include_dirs}" kincludes_string)
|
||||
module_add_definitions("${module_defs}" kdefintions_string)
|
||||
set(${output_string}
|
||||
"${module_name}-m += ${module_name}.o
|
||||
${kobjects_string}
|
||||
|
||||
${kincludes_string}
|
||||
|
||||
${kdefintions_string}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
function(add_module module_name module_files module_include_dirs module_defs kernel_dir)
|
||||
set(module_build_path "${PROJECT_BINARY_DIR}/${module_name}")
|
||||
module_kbuild("${module_name}" "${module_files}" "${module_include_dirs}" "${module_include_dirs}" Kbuild_string)
|
||||
file(WRITE "${module_build_path}/Kbuild" ${Kbuild_string})
|
||||
|
||||
foreach(copy_file ${module_files})
|
||||
file(RELATIVE_PATH rel_copy_file "${PROJECT_SOURCE_DIR}" ${copy_file} )
|
||||
list(APPEND cmd_list "cp --parents ${copy_file} ${module_build_path}")
|
||||
endforeach()
|
||||
string(REPLACE ";" "\n" cmd_list_string "${cmd_list}")
|
||||
file(WRITE "${module_build_path}/cp.sh" "#!/bin/bash\n${cmd_list_string}")
|
||||
file(COPY "${module_build_path}/cp.sh"
|
||||
DESTINATION "${module_build_path}/.tmp"
|
||||
FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
|
||||
file(REMOVE "${module_build_path}/cp.sh")
|
||||
|
||||
ADD_CUSTOM_COMMAND(
|
||||
OUTPUT ${module_name}.built
|
||||
COMMAND "${module_build_path}/.tmp/cp.sh"
|
||||
COMMAND ${CMAKE_MAKE_PROGRAM} -C ${kernel_dir} M=${module_build_path} modules KBUILD_EXTRA_SYMBOLS=${module_build_path}/Module.symvers
|
||||
COMMAND cmake -E touch ${module_name}.built
|
||||
COMMENT "Kernel make modules ${module_name}:\n${Kbuild_string}\n"
|
||||
DEPENDS ${PROJECT_SOURCE_DIR}/CMakeLists.txt ${module_files} ${module_include_dirs}
|
||||
VERBATIM)
|
||||
|
||||
ADD_CUSTOM_TARGET("${module_name}" ALL
|
||||
DEPENDS ${PROJECT_BINARY_DIR}/${module_name}.built
|
||||
SOURCES ${module_files}
|
||||
COMMENT "Building Kernel Module ${module_name}")
|
||||
endfunction()
|
||||
Reference in New Issue
Block a user