Update README
[fw/stlink] / CMakeLists.txt
index e00d1ed284ecdeab62518612785cb104ab4837ca..d61a0aee39553e0176fc87bb217297fd8c53394a 100644 (file)
+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)