-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
147 lines (128 loc) · 4.58 KB
/
CMakeLists.txt
File metadata and controls
147 lines (128 loc) · 4.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
cmake_minimum_required(VERSION 3.10)
project(bmp-conv C)
# === C standard & compiler flags ===
set(CMAKE_C_STANDARD 99)
set(CMAKE_C_STANDARD_REQUIRED ON)
add_compile_options(-Wall -Wpedantic -Wextra)
add_compile_options(
"$<$<CONFIG:Debug>:-O0;-g3;-ggdb>"
"$<$<CONFIG:Release>:-O3>"
)
add_compile_definitions(
LOG_USE_COLOR
_POSIX_C_SOURCE=200809L
"$<$<NOT:$<CONFIG:Debug>>:NDEBUG>"
"$<$<CONFIG:Debug>:DEBUG_MODE>"
)
include_directories(. src)
option(ENABLE_MPI "Enable MPI backend" ON)
option(ENABLE_OPENCL "Enable OpenCL backend" ON)
find_package(MPI COMPONENTS C QUIET)
find_package(OpenCL QUIET)
# === Sources ===
set(SRCS_COMMON
src/bmp-conv.c
src/utils/args-parse.c
src/utils/filters.c
src/utils/threads-general.c
src/utils/utils.c
src/utils/cli.c
src/backend/compute-backend.c
src/backend/cpu/cpu-backend.c
src/backend/cpu/st/st-exec.c
src/backend/cpu/mt/mt-compute.c
src/backend/cpu/mt/mt-exec.c
src/backend/cpu/qmt/qmt-exec.c
src/backend/cpu/qmt/utils/qmt-queue.c
src/backend/cpu/qmt/qmt-threads.c
src/backend/gpu/gpu-backend.c
src/backend/gpu/core/mw-exec.c
src/backend/gpu/utils/utils.c
logger/log.c
libbmp/libbmp.c
)
set(SRCS_MPI_ONLY
src/backend/cpu/mpi/mpi-exec.c
src/backend/cpu/mpi/utils/utils.c
src/backend/cpu/mpi/comm/phases.c
src/backend/cpu/mpi/comm/rank0-proc.c
src/backend/cpu/mpi/comm/data-transfer.c
src/backend/cpu/mpi/compute/filter-comp.c
)
set(SRCS_OPENCL_ONLY
src/backend/gpu/gpu-backend.c
src/backend/gpu/core/mw-exec.c
src/backend/gpu/utils/utils.c
)
set(SRCS
${SRCS_COMMON}
)
add_executable(bmp-conv ${SRCS_COMMON})
if(ENABLE_MPI AND MPI_C_FOUND)
target_sources(bmp-conv PRIVATE ${SRCS_MPI_ONLY})
target_compile_definitions(bmp-conv PRIVATE USE_MPI)
target_link_libraries(bmp-conv PRIVATE m MPI::MPI_C)
endif()
if(ENABLE_OPENCL AND OpenCL_FOUND)
target_sources(bmp-conv PRIVATE ${SRCS_OPENCL_ONLY})
target_compile_definitions(bmp-conv PRIVATE USE_OPENCL)
target_link_libraries(bmp-conv PRIVATE m ${OpenCL_LIBRARY})
target_include_directories(bmp-conv PRIVATE ${OpenCL_INCLUDE_DIRS})
endif()
# === Runtime arguments ===
set(INPUT_TF "image2.bmp" CACHE STRING "Input file")
set(FILTER_TYPE "mb" CACHE STRING "Filter type")
set(THREAD_NUM 2 CACHE STRING "Number of threads")
set(COMPUTE_MODE "by_row" CACHE STRING "Compute mode")
set(BLOCK_SIZE 5 CACHE STRING "Block size")
set(OUTPUT_FILE "" CACHE STRING "Output file")
set(LOG 1 CACHE STRING "Enable logging")
set(RWW_MIX "1,1,1" CACHE STRING "Queue RWW mix")
set(MPI_NP 2 CACHE STRING "MPI number of processes")
set(QUEUE_MEM 500 CACHE STRING "Queue memory")
set(QUEUE_CAP 20 CACHE STRING "Queue capacity")
set(VALGRIND_PREFIX "" CACHE STRING "Valgrind prefix (if any)")
# === Helper function to prepend Valgrind ===
function(add_valgrind_prefix CMD)
if(VALGRIND_PREFIX AND NOT VALGRIND_PREFIX STREQUAL "")
set(${CMD} "${VALGRIND_PREFIX} ${${CMD}}" PARENT_SCOPE)
endif()
endfunction()
# === Run targets ===
add_custom_target(run
COMMAND $<TARGET_FILE:bmp-conv>
${INPUT_TF} --filter=${FILTER_TYPE} --threadnum=${THREAD_NUM} --mode=${COMPUTE_MODE} --block=${BLOCK_SIZE} --output=${OUTPUT_FILE} --log=${LOG}
DEPENDS bmp-conv
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
COMMENT "Running bmp-conv..."
)
add_custom_target(run-q-mode
COMMAND $<TARGET_FILE:bmp-conv>
-queue-mode ${INPUT_TF} --mode=${COMPUTE_MODE} --filter=${FILTER_TYPE} --block=${BLOCK_SIZE} --rww=${RWW_MIX} --queue-size=${QUEUE_CAP} --queue-mem=${QUEUE_MEM}
DEPENDS bmp-conv
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
COMMENT "Running Queue Mode..."
)
add_custom_target(run-mac-e-cores
COMMAND taskpolicy -c background $<TARGET_FILE:bmp-conv>
${INPUT_TF} --filter=${FILTER_TYPE} --threadnum=${THREAD_NUM} --mode=${COMPUTE_MODE} --block=${BLOCK_SIZE} --output=${OUTPUT_FILE} --log=${LOG}
DEPENDS bmp-conv
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
COMMENT "Running on macOS E-cores..."
)
add_custom_target(run-mac-p-cores
COMMAND $<TARGET_FILE:bmp-conv>
${INPUT_TF} --filter=${FILTER_TYPE} --threadnum=${THREAD_NUM} --mode=${COMPUTE_MODE} --block=${BLOCK_SIZE} --output=${OUTPUT_FILE} --log=${LOG}
DEPENDS bmp-conv
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
COMMENT "Running on macOS P-cores..."
)
if(MPI_FOUND)
add_custom_target(run-mpi-mode
COMMAND mpirun -np ${MPI_NP} $<TARGET_FILE:bmp-conv>
-cpu -mpi ${INPUT_TF} --filter=${FILTER_TYPE} --mode=${COMPUTE_MODE} --block=${BLOCK_SIZE} --log=${LOG}
DEPENDS bmp-conv
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
COMMENT "Running MPI version..."
)
endif()