X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=CMakeLists.txt;h=d61a0aee39553e0176fc87bb217297fd8c53394a;hb=refs%2Fheads%2Fupstream;hp=e00d1ed284ecdeab62518612785cb104ab4837ca;hpb=ca08bed617efc86a7765554c14a448b731f97eb3;p=fw%2Fstlink diff --git a/CMakeLists.txt b/CMakeLists.txt index e00d1ed..d61a0ae 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,57 +1,108 @@ +project(stlink C) cmake_minimum_required(VERSION 2.8.7) -project(stlink) +include(CheckCCompilerFlag) find_package(PkgConfig) -pkg_check_modules(libusb REQUIRED libusb-1.0) -pkg_check_modules(gtk gtk+-3.0) - -set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=gnu99 -Wall -Wextra") - -set(HFILES src/stlink-common.h - src/stlink-usb.h - src/stlink-sg.h - src/uglylogging.h - src/mmap.h) - -set(CFILES src/stlink-common.c - src/stlink-usb.c - src/stlink-sg.c - src/uglylogging.c - src/st-info.c) +set(CMAKE_MODULE_PATH "${CMAKE_MODULE_PATH};${CMAKE_SOURCE_DIR}/cmake/modules") -include_directories(${libusb_INCLUDE_DIRS}) -include_directories(src) -include_directories(mingw) +find_package(LibUSB REQUIRED) +pkg_check_modules(gtk gtk+-3.0) -add_library(stlink STATIC - ${HFILES} # header files for ide projects generated by cmake - ${CFILES}) -target_link_libraries(stlink ${libusb_LDFLAGS}) +function(add_cflag_if_supported flag) + string(REPLACE "-" "_" flagclean ${flag}) + string(REPLACE "=" "_" flagclean ${flagclean}) + string(REPLACE "+" "_" flagclean ${flagclean}) + string(REPLACE "," "_" flagclean ${flagclean}) + string(TOUPPER ${flagclean} flagclean) + + check_c_compiler_flag(${flag} C_SUPPORTS${flagclean}) + + if (C_SUPPORTS${flagclean}) + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${flag}" PARENT_SCOPE) + endif() +endfunction() + +add_cflag_if_supported("-std=gnu99") +add_cflag_if_supported("-Wall") +add_cflag_if_supported("-Wextra") +add_cflag_if_supported("-Wshadow") +add_cflag_if_supported("-D_FORTIFY_SOURCE=2") +add_cflag_if_supported("-fstrict-aliasing") +add_cflag_if_supported("-Wformat") +add_cflag_if_supported("-Wformat-security") +add_cflag_if_supported("-Wmaybe-uninitialized") +add_cflag_if_supported("-Wmissing-variable-declarations") +add_cflag_if_supported("-Wshorten-64-to-32") +add_cflag_if_supported("-Wimplicit-function-declaration") +add_cflag_if_supported("-Wredundant-decls") +add_cflag_if_supported("-Wundef") +add_cflag_if_supported("-fPIC") + +if(${CMAKE_BUILD_TYPE} MATCHES "Debug") + include(CTest) + add_cflag_if_supported("-ggdb") + add_cflag_if_supported("-O0") +elseif() + add_cflag_if_supported("-O2") +endif() -add_executable(st-flash flash/main.c) -target_link_libraries(st-flash stlink) +set(STLINK_HEADERS + include/stlink.h + include/stlink/usb.h + include/stlink/sg.h + include/stlink/logging.h + include/stlink/mmap.h + include/stlink/chipid.h + include/stlink/flash_loader.h +) + +set(STLINK_SOURCE + src/chipid.c + src/common.c + src/usb.c + src/sg.c + src/logging.c + src/flash_loader.c +) + +include_directories(${LIBUSB_INCLUDE_DIR}) +include_directories(include) +include_directories(src/mingw) + +add_library(${PROJECT_NAME} STATIC + ${STLINK_HEADERS} # header files for ide projects generated by cmake + ${STLINK_SOURCE}) +target_link_libraries(${PROJECT_NAME} ${LIBUSB_LIBRARY}) + +if (APPLE) + find_library(ObjC objc) + find_library(CoreFoundation CoreFoundation) + find_library(IOKit IOKit) + target_link_libraries(${PROJECT_NAME} ${CoreFoundation} ${IOKit} ${ObjC}) +endif() -add_executable(st-util gdbserver/gdb-remote.c - gdbserver/gdb-remote.h - gdbserver/gdb-server.c - gdbserver/gdb-server.h) -target_link_libraries(st-util stlink) +add_executable(st-flash src/tools/flash.c) +target_link_libraries(st-flash ${PROJECT_NAME}) -add_executable(st-info src/st-info.c) -target_link_libraries(st-info stlink) +add_executable(st-info src/tools/info.c) +target_link_libraries(st-info ${PROJECT_NAME}) -add_executable(st-probe src/st-probe.c) -target_link_libraries(st-probe stlink) +add_executable(st-util src/gdbserver/gdb-remote.c + src/gdbserver/gdb-remote.h + src/gdbserver/gdb-server.c + src/gdbserver/gdb-server.h) +target_link_libraries(st-util ${PROJECT_NAME}) -install(TARGETS stlink st-flash st-util st-info st-probe +install(TARGETS ${PROJECT_NAME} st-flash st-util st-info RUNTIME DESTINATION bin - ARCHIVE DESTINATION lib) + ARCHIVE DESTINATION lib +) if(NOT MINGW) - list(APPEND CFILES src/st-term.c) - add_executable(st-term src/st-term.c) - target_link_libraries(st-term stlink) + list(APPEND STLINK_SOURCE src/tools/term.c) + add_executable(st-term src/tools/term.c) + target_link_libraries(st-term ${PROJECT_NAME}) install(TARGETS st-term RUNTIME DESTINATION bin) @@ -59,8 +110,8 @@ endif() if(gtk_FOUND) include_directories(${gtk_INCLUDE_DIRS}) - set(GUI_SOURCES gui/stlink-gui.c - gui/stlink-gui.h) + set(GUI_SOURCES src/tools/gui/stlink-gui.c + src/tools/gui/stlink-gui.h) add_executable(stlink-gui-local ${GUI_SOURCES}) set_target_properties(stlink-gui-local PROPERTIES @@ -75,7 +126,8 @@ if(gtk_FOUND) install(TARGETS stlink-gui RUNTIME DESTINATION bin) - install(FILES gui/stlink-gui.ui + install(FILES src/tools/gui/stlink-gui.ui DESTINATION ${INSTALLED_UI_DIR}) endif() +add_subdirectory(tests)