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)
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
)
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
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
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)