-
Notifications
You must be signed in to change notification settings - Fork 439
/
CMakeLists.txt
337 lines (285 loc) · 8.14 KB
/
CMakeLists.txt
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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
cmake_minimum_required (VERSION 3.0)
project (pe-sieve)
option(PESIEVE_BUILD_TESTING "Enable testing for PE-sieve" OFF)
option(PESIEVE_AS_DLL "Build PE-sieve as a DLL" OFF)
option(PESIEVE_AS_STATIC_LIB "Build PE-Sieve as a static library" OFF)
include_directories (
include
)
if (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
option(LINK_STATICALLY "Link PE-Sieve with static versions of linked libraries" ON)
add_compile_options(
-fpermissive
)
add_compile_definitions(
_WIN32_WINNT=1536 # 0x600 aka Windows Vista required
)
if(LINK_STATICALLY)
add_link_options(
-static
-static-libgcc
-static-libstdc
)
endif()
endif()
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /MT")
# modules:
set ( M_PARSER "libpeconv/libpeconv" )
set ( M_SIGFIND "sig_finder/sig_finder" )
# modules paths:
set ( PECONV_DIR "${PROJECT_SOURCE_DIR}/${M_PARSER}" CACHE PATH "PEConv main path")
set ( SIGFIND_DIR "${PROJECT_SOURCE_DIR}/${M_SIGFIND}" CACHE PATH "SigFinder main path")
# modules headers:
include_directories ( ${PECONV_DIR}/include )
include_directories ( ${SIGFIND_DIR}/include )
# libs
add_subdirectory (${M_PARSER})
set ( PECONV_LIB $<TARGET_FILE:libpeconv> CACHE PATH "PEConvLib library path" )
add_subdirectory(${M_SIGFIND})
set ( SIGFIND_LIB $<TARGET_FILE:sig_finder> CACHE PATH "SigFinder library path" )
if( NOT PESIEVE_AS_STATIC_LIB AND NOT PESIEVE_AS_DLL)
set ( M_PARAMKIT_LIB "paramkit" )
set (PARAMKIT_DIR "${CMAKE_SOURCE_DIR}/${M_PARAMKIT_LIB}/${M_PARAMKIT_LIB}" CACHE PATH "ParamKit main path" )
# modules headers:
include_directories ( ${PARAMKIT_DIR}/include )
# libs
add_subdirectory ( ${PARAMKIT_DIR} )
set ( PARAMKIT_LIB $<TARGET_FILE:paramkit> CACHE PATH "ParamKit library path" )
endif()
set (scanners_srcs
scanners/mapping_scanner.cpp
scanners/headers_scanner.cpp
scanners/code_scanner.cpp
scanners/workingset_scanner.cpp
scanners/artefact_scanner.cpp
scanners/iat_scanner.cpp
scanners/scanner.cpp
scanners/module_data.cpp
scanners/module_cache.cpp
scanners/mempage_data.cpp
scanners/patch_list.cpp
scanners/patch_analyzer.cpp
scanners/scan_report.cpp
scanners/scanned_modules.cpp
scanners/hook_targets_resolver.cpp
scanners/thread_scanner.cpp
)
set (scanners_hdrs
scanners/process_feature_scanner.h
scanners/mapping_scanner.h
scanners/headers_scanner.h
scanners/code_scanner.h
scanners/module_scanner.h
scanners/workingset_scanner.h
scanners/artefact_scanner.h
scanners/iat_scanner.h
scanners/scanner.h
scanners/module_scan_report.h
scanners/scan_report.h
scanners/module_cache.h
scanners/module_data.h
scanners/mempage_data.h
scanners/pe_section.h
scanners/patch_list.h
scanners/patch_analyzer.h
scanners/scanned_modules.h
scanners/hook_targets_resolver.h
scanners/thread_scanner.h
scanners/process_details.h
)
set (imprec_hdrs
postprocessors/imp_rec/imp_reconstructor.h
postprocessors/imp_rec/iat_block.h
postprocessors/imp_rec/iat_finder.h
postprocessors/imp_rec/import_table_finder.h
)
set (postprocessors_hdrs
postprocessors/report_formatter.h
postprocessors/results_dumper.h
postprocessors/dump_report.h
postprocessors/pe_buffer.h
postprocessors/pe_reconstructor.h
)
set (imprec_srcs
postprocessors/imp_rec/imp_reconstructor.cpp
postprocessors/imp_rec/iat_block.cpp
postprocessors/imp_rec/import_table_finder.cpp
)
set (postprocessors_srcs
postprocessors/report_formatter.cpp
postprocessors/results_dumper.cpp
postprocessors/dump_report.cpp
postprocessors/pe_buffer.cpp
postprocessors/pe_reconstructor.cpp
)
set (stats_srcs
stats/stats_analyzer.cpp
)
set (stats_hdrs
stats/entropy.h
stats/stats.h
stats/entropy_stats.h
stats/multi_stats.h
stats/stats_util.h
stats/stats_analyzer.h
stats/std_dev_calc.h
)
set (utils_srcs
utils/format_util.cpp
utils/process_util.cpp
utils/threads_util.cpp
utils/process_privilege.cpp
utils/process_minidump.cpp
utils/path_util.cpp
utils/path_converter.cpp
utils/workingset_enum.cpp
utils/modules_enum.cpp
utils/artefacts_util.cpp
utils/process_reflection.cpp
utils/console_color.cpp
utils/strings_util.cpp
utils/syscall_extractor.cpp
)
set (utils_hdrs
utils/format_util.h
utils/path_util.h
utils/path_converter.h
utils/process_util.h
utils/threads_util.h
utils/process_privilege.h
utils/process_minidump.h
utils/workingset_enum.h
utils/modules_enum.h
utils/artefacts_util.h
utils/process_reflection.h
utils/console_color.h
utils/strings_util.h
utils/byte_buffer.h
utils/code_patterns.h
utils/custom_mutex.h
utils/custom_buffer.h
utils/process_symbols.h
utils/syscall_extractor.h
)
set (params_info_hdrs
params_info/pe_sieve_params_info.h
params_info/params_dump.h
)
set (params_info_srcs
params_info/pe_sieve_params_info.cpp
params_info/params_dump.cpp
)
set (srcs
pe_sieve.cpp
color_scheme.h
${params_info_srcs}
${scanners_srcs}
${postprocessors_srcs}
${imprec_srcs}
${utils_srcs}
${stats_srcs}
)
set (hdrs
pe_sieve.h
pe_sieve_report.h
include/pe_sieve_types.h
${params_info_hdrs}
${scanners_hdrs}
${postprocessors_hdrs}
${imprec_hdrs}
${utils_hdrs}
${stats_hdrs}
)
set (rsrc
resources.h
pe_sieve_ver_short.h
pe_sieve_res.rc
)
# set filters in Visual Studio project:
SOURCE_GROUP("Source Files\\scanners" FILES ${scanners_srcs} )
SOURCE_GROUP("Header Files\\scanners" FILES ${scanners_hdrs} )
SOURCE_GROUP("Source Files\\utils" FILES ${utils_srcs} )
SOURCE_GROUP("Header Files\\utils" FILES ${utils_hdrs} )
SOURCE_GROUP("Source Files\\stats" FILES ${stats_srcs} )
SOURCE_GROUP("Header Files\\stats" FILES ${stats_hdrs} )
SOURCE_GROUP("Source Files\\params_info" FILES ${params_info_srcs} )
SOURCE_GROUP("Header Files\\params_info" FILES ${params_info_hdrs} )
SOURCE_GROUP("Source Files\\postprocessors" FILES ${postprocessors_srcs} )
SOURCE_GROUP("Header Files\\postprocessors" FILES ${postprocessors_hdrs} )
SOURCE_GROUP("Source Files\\postprocessors\\imp_rec" FILES ${imprec_srcs} )
SOURCE_GROUP("Header Files\\postprocessors\\imp_rec" FILES ${imprec_hdrs} )
include(GNUInstallDirs)
set (library_export_hdrs
include/pe_sieve_types.h
include/pe_sieve_api.h
include/pe_sieve_return_codes.h
)
if(PESIEVE_AS_STATIC_LIB)
set(LIBRARY_TYPE STATIC)
# Install libpeconv as well since with static libraries a user has to link against both
set(PECONV_LIB_INSTALL ON CACHE INTERNAL "")
elseif(PESIEVE_AS_DLL)
set(LIBRARY_TYPE SHARED)
endif()
if (PESIEVE_AS_DLL AND PESIEVE_AS_STATIC_LIB)
message(FATAL_ERROR "Choose either PESIEVE_AS_STATIC_LIB or PESIEVE_AS_DLL (or none of them, to build as an EXE)")
endif()
# Choose to build the library or EXE
if(PESIEVE_AS_STATIC_LIB OR PESIEVE_AS_DLL)
set (lib_srcs
pe_sieve_api.cpp
${srcs}
)
if (PESIEVE_AS_DLL)
set (lib_srcs
dll_main.cpp
main.def
${lib_srcs}
)
endif()
add_library ( ${PROJECT_NAME} ${LIBRARY_TYPE} ${library_export_hdrs} ${hdrs} ${lib_srcs} ${rsrc} )
set_source_files_properties(main.def PROPERTIES HEADER_FILE_ONLY TRUE)
target_compile_definitions(${PROJECT_NAME} PUBLIC PESIEVE_${LIBRARY_TYPE}_LIB)
INSTALL(FILES ${library_export_hdrs}
DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
)
set_source_files_properties(main.def PROPERTIES HEADER_FILE_ONLY TRUE)
else()
add_executable ( ${PROJECT_NAME} ${hdrs} ${srcs} ${rsrc} pe_sieve_res_icon.rc main.cpp params.h )
endif()
set (used_libs
${PECONV_LIB}
${SIGFIND_LIB}
psapi.lib
ntdll.lib
shlwapi
imagehlp
)
# dependencies
add_dependencies( ${PROJECT_NAME} libpeconv sig_finder )
if(PESIEVE_AS_STATIC_LIB OR PESIEVE_AS_DLL)
include(GNUInstallDirs)
install(TARGETS ${PROJECT_NAME}
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
)
target_link_libraries ( ${PROJECT_NAME} ${used_libs} )
else()
# add Paramkit only if build as an exe
# dependencies
add_dependencies(${PROJECT_NAME} paramkit )
target_link_libraries ( ${PROJECT_NAME} ${used_libs} ${PARAMKIT_LIB} )
endif()
if (NOT PESIEVE_AS_STATIC_LIB)
install(TARGETS ${PROJECT_NAME}
DESTINATION ${CMAKE_INSTALL_PREFIX} COMPONENT ${PROJECT_NAME}
)
# Setup testing
if(PESIEVE_BUILD_TESTING)
enable_testing()
# 0) does the application run
add_test (TestRuns ${CMAKE_INSTALL_PREFIX}/pe-sieve -?)
set_tests_properties(TestRuns PROPERTIES PASS_REGULAR_EXPRESSION "Version:")
endif()
endif()