Skip to content

Commit c7a8512

Browse files
authored
Cmake fixes for DYNAMIC_ARCH builds and whitespace in path names (#1323)
* prebuild.cmake: Put quotes around path names that may contain whitespace (Copied from alexkaratakis' PR #1295) * kernel/CMakeLists.txt: Fix common_lapack header inclusion and DYNAMIC_ARCH generation of ?neg_tcopy and ?laswp_ncopy files * lapack/CMakeLists.txt: Use correct template for ?laswp_(plus,minus) functions
1 parent db72ad8 commit c7a8512

File tree

3 files changed

+27
-11
lines changed

3 files changed

+27
-11
lines changed

cmake/prebuild.cmake

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -192,7 +192,7 @@ else(NOT CMAKE_CROSSCOMPILING)
192192
if (NOT "${CMAKE_SYSTEM_NAME}" STREQUAL "WindowsStore")
193193
try_compile(GETARCH_RESULT ${GETARCH_DIR}
194194
SOURCES ${GETARCH_SRC}
195-
COMPILE_DEFINITIONS ${EXFLAGS} ${GETARCH_FLAGS} -I${GETARCH_DIR} -I${PROJECT_SOURCE_DIR} -I${PROJECT_BINARY_DIR}
195+
COMPILE_DEFINITIONS ${EXFLAGS} ${GETARCH_FLAGS} -I${GETARCH_DIR} -I"${PROJECT_SOURCE_DIR}" -I"${PROJECT_BINARY_DIR}"
196196
OUTPUT_VARIABLE GETARCH_LOG
197197
COPY_FILE ${PROJECT_BINARY_DIR}/${GETARCH_BIN}
198198
)
@@ -204,8 +204,8 @@ else(NOT CMAKE_CROSSCOMPILING)
204204
message(STATUS "Running getarch")
205205

206206
# use the cmake binary w/ the -E param to run a shell command in a cross-platform way
207-
execute_process(COMMAND ${PROJECT_BINARY_DIR}/${GETARCH_BIN} 0 OUTPUT_VARIABLE GETARCH_MAKE_OUT)
208-
execute_process(COMMAND ${PROJECT_BINARY_DIR}/${GETARCH_BIN} 1 OUTPUT_VARIABLE GETARCH_CONF_OUT)
207+
execute_process(COMMAND "${PROJECT_BINARY_DIR}/${GETARCH_BIN}" 0 OUTPUT_VARIABLE GETARCH_MAKE_OUT)
208+
execute_process(COMMAND "${PROJECT_BINARY_DIR}/${GETARCH_BIN}" 1 OUTPUT_VARIABLE GETARCH_CONF_OUT)
209209

210210
message(STATUS "GETARCH results:\n${GETARCH_MAKE_OUT}")
211211

@@ -220,7 +220,7 @@ else(NOT CMAKE_CROSSCOMPILING)
220220
if (NOT "${CMAKE_SYSTEM_NAME}" STREQUAL "WindowsStore")
221221
try_compile(GETARCH2_RESULT ${GETARCH2_DIR}
222222
SOURCES ${PROJECT_SOURCE_DIR}/getarch_2nd.c
223-
COMPILE_DEFINITIONS ${EXFLAGS} ${GETARCH_FLAGS} ${GETARCH2_FLAGS} -I${GETARCH2_DIR} -I${PROJECT_SOURCE_DIR} -I${PROJECT_BINARY_DIR}
223+
COMPILE_DEFINITIONS ${EXFLAGS} ${GETARCH_FLAGS} ${GETARCH2_FLAGS} -I${GETARCH2_DIR} -I"${PROJECT_SOURCE_DIR}" -I"${PROJECT_BINARY_DIR}"
224224
OUTPUT_VARIABLE GETARCH2_LOG
225225
COPY_FILE ${PROJECT_BINARY_DIR}/${GETARCH2_BIN}
226226
)
@@ -231,8 +231,8 @@ else(NOT CMAKE_CROSSCOMPILING)
231231
endif ()
232232

233233
# use the cmake binary w/ the -E param to run a shell command in a cross-platform way
234-
execute_process(COMMAND ${PROJECT_BINARY_DIR}/${GETARCH2_BIN} 0 OUTPUT_VARIABLE GETARCH2_MAKE_OUT)
235-
execute_process(COMMAND ${PROJECT_BINARY_DIR}/${GETARCH2_BIN} 1 OUTPUT_VARIABLE GETARCH2_CONF_OUT)
234+
execute_process(COMMAND "${PROJECT_BINARY_DIR}/${GETARCH2_BIN}" 0 OUTPUT_VARIABLE GETARCH2_MAKE_OUT)
235+
execute_process(COMMAND "${PROJECT_BINARY_DIR}/${GETARCH2_BIN}" 1 OUTPUT_VARIABLE GETARCH2_CONF_OUT)
236236

237237
# append config data from getarch_2nd to the TARGET file and read in CMake vars
238238
file(APPEND ${TARGET_CONF_TEMP} ${GETARCH2_CONF_OUT})

kernel/CMakeLists.txt

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ function (build_core TARGET_CORE KDIR TSUFFIX KERNEL_DEFINITIONS)
1616
ParseMakefileVars("${KERNELDIR}/KERNEL.${TARGET_CORE}")
1717

1818
set(KERNEL_INTERFACE common_level1.h common_level2.h common_level3.h)
19-
if(NOT ${NO_LAPACK})
19+
if(NOT NO_LAPACK)
2020
set(KERNEL_INTERFACE ${KERNEL_INTERFACE} common_lapack.h)
2121
endif ()
2222

@@ -500,12 +500,21 @@ function (build_core TARGET_CORE KDIR TSUFFIX KERNEL_DEFINITIONS)
500500
set(KERNEL_TSUFFIX_CONTENTS "")
501501
foreach (KERNEL_INTERFACE_H ${KERNEL_INTERFACE})
502502
file(READ ${PROJECT_SOURCE_DIR}/${KERNEL_INTERFACE_H} KERNEL_INTERFACE_H_CONTENTS)
503-
string(REGEX REPLACE "[ ]*\\(" "${TSUFFIX}(" KERNEL_INTERFACE_H_CONTENTS_NEW "${KERNEL_INTERFACE_H_CONTENTS}")
503+
string(REGEX REPLACE " *\\(" "${TSUFFIX}(" KERNEL_INTERFACE_H_CONTENTS_NEW "${KERNEL_INTERFACE_H_CONTENTS}")
504504
set(KERNEL_TSUFFIX_CONTENTS "${KERNEL_TSUFFIX_CONTENTS}\n${KERNEL_INTERFACE_H_CONTENTS_NEW}")
505505
endforeach()
506506
file(WRITE ${SETPARAM_TARGET_DIR}/kernel${TSUFFIX}.tmp "${KERNEL_TSUFFIX_CONTENTS}")
507507
configure_file(${SETPARAM_TARGET_DIR}/kernel${TSUFFIX}.tmp ${SETPARAM_TARGET_DIR}/kernel${TSUFFIX}.h COPYONLY)
508508
file(REMOVE ${SETPARAM_TARGET_DIR}/kernel${TSUFFIX}.tmp)
509+
510+
foreach (float_type ${FLOAT_TYPES})
511+
# a bit of metaprogramming here to pull out the appropriate KERNEL var
512+
string(SUBSTRING ${float_type} 0 1 float_char)
513+
GenerateNamedObjects("generic/neg_tcopy_${${float_char}GEMM_UNROLL_M}.c" "" "neg_tcopy" false "" ${TSUFFIX} false ${float_type})
514+
GenerateNamedObjects("generic/laswp_ncopy_${${float_char}GEMM_UNROLL_N}.c" "" "laswp_ncopy" false "" ${TSUFFIX} false ${float_type})
515+
endforeach ()
516+
517+
509518
endif ()
510519

511520
add_library(kernel${TSUFFIX} OBJECT ${OPENBLAS_SRC})

lapack/CMakeLists.txt

Lines changed: 10 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -42,9 +42,16 @@ set(UNIT_SOURCES2
4242
GenerateNamedObjects("${LAPACK_SOURCES}")
4343
GenerateNamedObjects("${LAPACK_MANGLED_SOURCES}" "" "" false "" "" false 3)
4444

45-
# TODO: laswp needs arch specific code
46-
GenerateNamedObjects("laswp/generic/laswp_k.c" "" "laswp_plus" false "" "" false 3)
47-
GenerateNamedObjects("laswp/generic/laswp_k.c" "MINUS" "laswp_minus" false "" "" false 3)
45+
GenerateNamedObjects("laswp/generic/laswp_k_4.c" "" "laswp_plus" false "" "" false 3)
46+
GenerateNamedObjects("laswp/generic/laswp_k_4.c" "MINUS" "laswp_minus" false "" "" false 3)
47+
48+
# dynamic_arch laswp needs arch specific code ?
49+
#foreach(TARGET_CORE ${DYNAMIC_CORE})
50+
# set(TSUFFIX "_${TARGET_CORE}")
51+
#
52+
#GenerateNamedObjects("laswp/generic/laswp_k_4.c" "" "laswp_plus" false "" ${TSUFFIX} false 3)
53+
#GenerateNamedObjects("laswp/generic/laswp_k_4.c" "MINUS" "laswp_minus" false "" ${TSUFFIX} false 3)
54+
#endforeach ()
4855

4956
if (USE_THREAD)
5057

0 commit comments

Comments
 (0)