mirror of
https://github.com/RfidResearchGroup/proxmark3.git
synced 2024-09-20 15:26:13 +08:00
cmake tuning
This commit is contained in:
parent
de4ae57b21
commit
e79537ba46
|
@ -63,18 +63,23 @@ if (NOT SKIPPYTHON EQUAL 1)
|
||||||
pkg_search_module(PYTHON3EMBED QUIET python3-embed)
|
pkg_search_module(PYTHON3EMBED QUIET python3-embed)
|
||||||
endif (NOT SKIPPYTHON EQUAL 1)
|
endif (NOT SKIPPYTHON EQUAL 1)
|
||||||
|
|
||||||
# If build on android cross, we need to init source and build.
|
# If cross-compiled, we need to init source and build.
|
||||||
if (ANDROID)
|
if (CMAKE_TOOLCHAIN_FILE)
|
||||||
set(CFLAGS_EXTERNAL_LIB "CFLAGS=--target=${CMAKE_C_COMPILER_TARGET} -w")
|
set(CFLAGS_EXTERNAL_LIB "CFLAGS=--target=${CMAKE_C_COMPILER_TARGET} -w")
|
||||||
|
set(EMBED_READLINE ON)
|
||||||
|
set(EMBED_BZIP2 ON)
|
||||||
|
endif (CMAKE_TOOLCHAIN_FILE)
|
||||||
|
|
||||||
|
if (EMBED_READLINE OR EMBED_BZIP2)
|
||||||
include(ExternalProject)
|
include(ExternalProject)
|
||||||
endif (ANDROID)
|
endif (EMBED_READLINE OR EMBED_BZIP2)
|
||||||
|
|
||||||
if (NOT SKIPREADLINE EQUAL 1)
|
if (NOT SKIPREADLINE EQUAL 1)
|
||||||
if (APPLE)
|
if (APPLE)
|
||||||
find_path(READLINE_INCLUDE_DIRS readline/readline.h /usr/local/opt/readline/include /opt/local/include /opt/include /usr/local/include /usr/include NO_DEFAULT_PATH)
|
find_path(READLINE_INCLUDE_DIRS readline/readline.h /usr/local/opt/readline/include /opt/local/include /opt/include /usr/local/include /usr/include NO_DEFAULT_PATH)
|
||||||
find_library(READLINE_LIBRARIES readline /usr/local/opt/readline/lib /opt/local/lib /opt/lib /usr/local/lib /usr/lib NO_DEFAULT_PATH)
|
find_library(READLINE_LIBRARIES readline /usr/local/opt/readline/lib /opt/local/lib /opt/lib /usr/local/lib /usr/lib NO_DEFAULT_PATH)
|
||||||
endif (APPLE)
|
endif (APPLE)
|
||||||
if (ANDROID)
|
if (EMBED_READLINE)
|
||||||
ExternalProject_Add(ncurses
|
ExternalProject_Add(ncurses
|
||||||
URL http://ftp.gnu.org/pub/gnu/ncurses/ncurses-6.0.tar.gz
|
URL http://ftp.gnu.org/pub/gnu/ncurses/ncurses-6.0.tar.gz
|
||||||
PREFIX deps/ncurses
|
PREFIX deps/ncurses
|
||||||
|
@ -100,10 +105,10 @@ if (NOT SKIPREADLINE EQUAL 1)
|
||||||
ExternalProject_Add_StepTargets(readline configure build install)
|
ExternalProject_Add_StepTargets(readline configure build install)
|
||||||
set(READLINE_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/deps/readline/src/)
|
set(READLINE_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/deps/readline/src/)
|
||||||
set(READLINE_LIBRARIES ${CMAKE_CURRENT_BINARY_DIR}/deps/readline/src/readline/libreadline.a ${CMAKE_CURRENT_BINARY_DIR}/deps/ncurses/src/ncurses/lib/libtinfo.a)
|
set(READLINE_LIBRARIES ${CMAKE_CURRENT_BINARY_DIR}/deps/readline/src/readline/libreadline.a ${CMAKE_CURRENT_BINARY_DIR}/deps/ncurses/src/ncurses/lib/libtinfo.a)
|
||||||
else (ANDROID)
|
else (EMBED_READLINE)
|
||||||
find_path(READLINE_INCLUDE_DIRS readline/readline.h)
|
find_path(READLINE_INCLUDE_DIRS readline/readline.h)
|
||||||
find_library(READLINE_LIBRARIES readline)
|
find_library(READLINE_LIBRARIES readline)
|
||||||
endif (ANDROID)
|
endif (EMBED_READLINE)
|
||||||
if (READLINE_INCLUDE_DIRS AND READLINE_LIBRARIES)
|
if (READLINE_INCLUDE_DIRS AND READLINE_LIBRARIES)
|
||||||
set(READLINE_FOUND ON)
|
set(READLINE_FOUND ON)
|
||||||
endif (READLINE_INCLUDE_DIRS AND READLINE_LIBRARIES)
|
endif (READLINE_INCLUDE_DIRS AND READLINE_LIBRARIES)
|
||||||
|
@ -122,7 +127,7 @@ if (NOT SKIPJANSSONSYSTEM EQUAL 1)
|
||||||
endif (JANSSON_INCLUDE_DIRS AND JANSSON_LIBRARIES)
|
endif (JANSSON_INCLUDE_DIRS AND JANSSON_LIBRARIES)
|
||||||
endif (NOT SKIPJANSSONSYSTEM EQUAL 1)
|
endif (NOT SKIPJANSSONSYSTEM EQUAL 1)
|
||||||
|
|
||||||
if(ANDROID)
|
if(EMBED_BZIP2)
|
||||||
set(BZIP2_BUILD_DIR ${CMAKE_CURRENT_BINARY_DIR}/deps/bzip2/src/bzip2)
|
set(BZIP2_BUILD_DIR ${CMAKE_CURRENT_BINARY_DIR}/deps/bzip2/src/bzip2)
|
||||||
ExternalProject_Add(bzip2
|
ExternalProject_Add(bzip2
|
||||||
GIT_REPOSITORY https://android.googlesource.com/platform/external/bzip2
|
GIT_REPOSITORY https://android.googlesource.com/platform/external/bzip2
|
||||||
|
@ -139,9 +144,9 @@ if(ANDROID)
|
||||||
set(BZIP2_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/deps/bzip2/src/bzip2)
|
set(BZIP2_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/deps/bzip2/src/bzip2)
|
||||||
set(BZIP2_LIBRARIES ${CMAKE_CURRENT_BINARY_DIR}/deps/bzip2/src/bzip2/libbz2.a)
|
set(BZIP2_LIBRARIES ${CMAKE_CURRENT_BINARY_DIR}/deps/bzip2/src/bzip2/libbz2.a)
|
||||||
set(BZIP2_FOUND ON)
|
set(BZIP2_FOUND ON)
|
||||||
else()
|
else(EMBED_BZIP2)
|
||||||
find_package (BZip2 REQUIRED)
|
find_package (BZip2 REQUIRED)
|
||||||
endif(ANDROID)
|
endif(EMBED_BZIP2)
|
||||||
|
|
||||||
if (NOT SKIPWHEREAMISYSTEM EQUAL 1)
|
if (NOT SKIPWHEREAMISYSTEM EQUAL 1)
|
||||||
find_path(WHEREAMI_INCLUDE_DIRS whereami.h)
|
find_path(WHEREAMI_INCLUDE_DIRS whereami.h)
|
||||||
|
@ -393,6 +398,12 @@ else (SKIPBT EQUAL 1)
|
||||||
endif (BLUEZ_FOUND)
|
endif (BLUEZ_FOUND)
|
||||||
endif(SKIPBT EQUAL 1)
|
endif(SKIPBT EQUAL 1)
|
||||||
|
|
||||||
|
if (EMBED_BZIP2)
|
||||||
|
message("Bzip2 library: embedded")
|
||||||
|
else (EMBED_BZIP2)
|
||||||
|
message("Bzip2 library: system library found")
|
||||||
|
endif (EMBED_BZIP2)
|
||||||
|
|
||||||
if (SKIPJANSSONSYSTEM EQUAL 1)
|
if (SKIPJANSSONSYSTEM EQUAL 1)
|
||||||
message("Jansson library: local library forced")
|
message("Jansson library: local library forced")
|
||||||
else (SKIPJANSSONSYSTEM EQUAL 1)
|
else (SKIPJANSSONSYSTEM EQUAL 1)
|
||||||
|
@ -419,7 +430,11 @@ if (SKIPREADLINE EQUAL 1)
|
||||||
message("Readline library: skipped")
|
message("Readline library: skipped")
|
||||||
else (SKIPREADLINE EQUAL 1)
|
else (SKIPREADLINE EQUAL 1)
|
||||||
if (READLINE_FOUND)
|
if (READLINE_FOUND)
|
||||||
message("Readline library: enabled")
|
if (EMBED_READLINE)
|
||||||
|
message("Readline library: embedded")
|
||||||
|
else (EMBED_READLINE)
|
||||||
|
message("Readline library: system library found")
|
||||||
|
endif (EMBED_READLINE)
|
||||||
else (READLINE_FOUND)
|
else (READLINE_FOUND)
|
||||||
message("Readline library: Readline not found, disabled")
|
message("Readline library: Readline not found, disabled")
|
||||||
endif (READLINE_FOUND)
|
endif (READLINE_FOUND)
|
||||||
|
@ -443,12 +458,14 @@ add_executable(proxmark3
|
||||||
)
|
)
|
||||||
|
|
||||||
target_compile_options(proxmark3 PUBLIC -Wall -Werror -O3)
|
target_compile_options(proxmark3 PUBLIC -Wall -Werror -O3)
|
||||||
if (ANDROID)
|
if (EMBED_READLINE)
|
||||||
if (NOT SKIPREADLINE EQUAL 1)
|
if (NOT SKIPREADLINE EQUAL 1)
|
||||||
add_dependencies(proxmark3 ncurses readline)
|
add_dependencies(proxmark3 ncurses readline)
|
||||||
endif (NOT SKIPREADLINE EQUAL 1)
|
endif (NOT SKIPREADLINE EQUAL 1)
|
||||||
|
endif (EMBED_READLINE)
|
||||||
|
if (EMBED_BZIP2)
|
||||||
add_dependencies(proxmark3 bzip2)
|
add_dependencies(proxmark3 bzip2)
|
||||||
endif (ANDROID)
|
endif (EMBED_BZIP2)
|
||||||
|
|
||||||
if (MINGW)
|
if (MINGW)
|
||||||
# Mingw uses by default Microsoft printf, we want the GNU printf (e.g. for %z)
|
# Mingw uses by default Microsoft printf, we want the GNU printf (e.g. for %z)
|
||||||
|
|
|
@ -26,7 +26,7 @@ At the moment both are maintained because they don't perfectly overlap yet.
|
||||||
| bluez detection | pc | pkg_search_module | |
|
| bluez detection | pc | pkg_search_module | |
|
||||||
| `SKIPBT` | yes | yes | |
|
| `SKIPBT` | yes | yes | |
|
||||||
| dep bzip2 | sys | sys | |
|
| dep bzip2 | sys | sys | |
|
||||||
| bzip2 detection | **none** | find_package, Android:gitclone | |
|
| bzip2 detection | **none** | find_package, Cross:gitclone | |
|
||||||
| dep cliparser | in_deps | in_deps | |
|
| dep cliparser | in_deps | in_deps | |
|
||||||
| dep hardnested | in_deps | in_deps | |
|
| dep hardnested | in_deps | in_deps | |
|
||||||
| hardn arch autodetect | `uname -m` =? 86 or amd64; `$(CC) -E -mavx512f`? +AVX512` | `CMAKE_SYSTEM_PROCESSOR` =? x86 or x86_64 or i686 or AMD64 (1) | (1) currently it always includes AVX512 on Intel arch |
|
| hardn arch autodetect | `uname -m` =? 86 or amd64; `$(CC) -E -mavx512f`? +AVX512` | `CMAKE_SYSTEM_PROCESSOR` =? x86 or x86_64 or i686 or AMD64 (1) | (1) currently it always includes AVX512 on Intel arch |
|
||||||
|
@ -53,7 +53,7 @@ At the moment both are maintained because they don't perfectly overlap yet.
|
||||||
| Qt detection | pc(qt5)/pc(qt4)/`QTDIR`(1) (2) | find_package(qt5) (3) | (1) if `QTDIR`: hardcode path (2) OSX: pkg-config hook for Brew (3) OSX: add search path|
|
| Qt detection | pc(qt5)/pc(qt4)/`QTDIR`(1) (2) | find_package(qt5) (3) | (1) if `QTDIR`: hardcode path (2) OSX: pkg-config hook for Brew (3) OSX: add search path|
|
||||||
| `SKIPQT` | yes | yes | |
|
| `SKIPQT` | yes | yes | |
|
||||||
| dep readline | sys | sys | |
|
| dep readline | sys | sys | |
|
||||||
| readline detection | **none** (1) | find*(2), Android:getzip | (1) OSX: hardcoded path (2) additional paths for OSX |
|
| readline detection | **none** (1) | find*(2), Cross:getzip | (1) OSX: hardcoded path (2) additional paths for OSX |
|
||||||
| `SKIPREADLINE` | yes | yes | CLI not fully functional without Readline |
|
| `SKIPREADLINE` | yes | yes | CLI not fully functional without Readline |
|
||||||
| dep reveng | in_deps | in_deps | |
|
| dep reveng | in_deps | in_deps | |
|
||||||
| `SKIPREVENGTEST` | yes(1) | **no**(2) | (1) e.g. if cross-compilation (2) tests aren't compiled/ran with cmake |
|
| `SKIPREVENGTEST` | yes(1) | **no**(2) | (1) e.g. if cross-compilation (2) tests aren't compiled/ran with cmake |
|
||||||
|
|
Loading…
Reference in a new issue