Update README
[fw/stlink] / CMakeLists.txt
index cd329bb18e5fb32b4f2d4b027762eceaf0059d3a..d61a0aee39553e0176fc87bb217297fd8c53394a 100644 (file)
@@ -4,7 +4,9 @@ cmake_minimum_required(VERSION 2.8.7)
 include(CheckCCompilerFlag)
 find_package(PkgConfig)
 
-pkg_check_modules(libusb REQUIRED libusb-1.0)
+set(CMAKE_MODULE_PATH "${CMAKE_MODULE_PATH};${CMAKE_SOURCE_DIR}/cmake/modules")
+
+find_package(LibUSB REQUIRED)
 pkg_check_modules(gtk gtk+-3.0)
 
 function(add_cflag_if_supported flag)
@@ -38,44 +40,58 @@ 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")
+       include(CTest)
+       add_cflag_if_supported("-ggdb")
+       add_cflag_if_supported("-O0")
 elseif()
-    add_cflag_if_supported("-O2")
+       add_cflag_if_supported("-O2")
 endif()
 
-set(HFILES src/stlink-common.h
-           src/stlink-usb.h
-           src/stlink-sg.h
-           src/uglylogging.h
-           src/mmap.h)
+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(CFILES src/stlink-common.c
-           src/stlink-usb.c
-           src/stlink-sg.c
-           src/uglylogging.c
-           )
+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_DIRS})
-include_directories(src)
-include_directories(mingw)
+include_directories(${LIBUSB_INCLUDE_DIR})
+include_directories(include)
+include_directories(src/mingw)
 
 add_library(${PROJECT_NAME} STATIC
-            ${HFILES} # header files for ide projects generated by cmake
-            ${CFILES})
-target_link_libraries(${PROJECT_NAME} ${libusb_LDFLAGS})
+            ${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-flash flash/main.c)
+add_executable(st-flash src/tools/flash.c)
 target_link_libraries(st-flash ${PROJECT_NAME})
 
-add_executable(st-info src/st-info.c)
+add_executable(st-info src/tools/info.c)
 target_link_libraries(st-info ${PROJECT_NAME})
 
-add_executable(st-util gdbserver/gdb-remote.c
-                       gdbserver/gdb-remote.h
-                       gdbserver/gdb-server.c
-                       gdbserver/gdb-server.h)
+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 ${PROJECT_NAME} st-flash st-util st-info
@@ -84,8 +100,8 @@ install(TARGETS ${PROJECT_NAME} st-flash st-util st-info
 )
 
 if(NOT MINGW)
-  list(APPEND CFILES src/st-term.c)
-  add_executable(st-term src/st-term.c)
+  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
@@ -94,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
@@ -110,6 +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)