hal integration done
This commit is contained in:
parent
243cf42dc4
commit
e2da68795b
@ -12,26 +12,12 @@ set(LIB_FSFW_HAL_NAME fsfw_hal)
|
|||||||
set(LINUX_HAL_PATH_NAME linux)
|
set(LINUX_HAL_PATH_NAME linux)
|
||||||
set(STM32H7_PATH_NAME stm32h7)
|
set(STM32H7_PATH_NAME stm32h7)
|
||||||
|
|
||||||
add_library(${LIB_FSFW_HAL_NAME})
|
|
||||||
|
|
||||||
if(NOT LIB_FSFW_NAME)
|
if(NOT LIB_FSFW_NAME)
|
||||||
message(ERROR "LIB_FSFW_NAME needs to be set as a linkable target")
|
message(ERROR "LIB_FSFW_NAME needs to be set as a linkable target")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_subdirectory(devicehandlers)
|
add_subdirectory(src)
|
||||||
add_subdirectory(common)
|
add_subdirectory(inc)
|
||||||
|
|
||||||
if(FSFW_HAL_ADD_LINUX)
|
|
||||||
add_subdirectory(${LINUX_HAL_PATH_NAME})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(FSFW_HAL_ADD_STM32H7)
|
|
||||||
add_subdirectory(${STM32H7_PATH_NAME})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
target_link_libraries(${LIB_FSFW_HAL_NAME} PRIVATE
|
|
||||||
${LIB_FSFW_NAME}
|
|
||||||
)
|
|
||||||
|
|
||||||
foreach(INCLUDE_PATH ${FSFW_HAL_ADDITIONAL_INC_PATHS})
|
foreach(INCLUDE_PATH ${FSFW_HAL_ADDITIONAL_INC_PATHS})
|
||||||
if(IS_ABSOLUTE ${INCLUDE_PATH})
|
if(IS_ABSOLUTE ${INCLUDE_PATH})
|
||||||
@ -48,40 +34,15 @@ foreach(INCLUDE_PATH ${FSFW_HAL_ADDITIONAL_INC_PATHS})
|
|||||||
list(APPEND FSFW_HAL_ADD_INC_PATHS_ABS ${CURR_ABS_INC_PATH})
|
list(APPEND FSFW_HAL_ADD_INC_PATHS_ABS ${CURR_ABS_INC_PATH})
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
target_include_directories(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_include_directories(${LIB_FSFW_NAME} PRIVATE
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
${FSFW_HAL_ADD_INC_PATHS_ABS}
|
${FSFW_HAL_ADD_INC_PATHS_ABS}
|
||||||
)
|
)
|
||||||
|
|
||||||
target_compile_definitions(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_compile_definitions(${LIB_FSFW_NAME} PRIVATE
|
||||||
${FSFW_HAL_DEFINES}
|
${FSFW_HAL_DEFINES}
|
||||||
)
|
)
|
||||||
|
|
||||||
target_link_libraries(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_link_libraries(${LIB_FSFW_NAME} PRIVATE
|
||||||
${FSFW_HAL_LINK_LIBS}
|
${FSFW_HAL_LINK_LIBS}
|
||||||
)
|
)
|
||||||
|
|
||||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
|
|
||||||
if(NOT DEFINED FSFW_WARNING_FLAGS)
|
|
||||||
set(FSFW_WARNING_FLAGS
|
|
||||||
-Wall
|
|
||||||
-Wextra
|
|
||||||
-Wimplicit-fallthrough=1
|
|
||||||
-Wno-unused-parameter
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
target_compile_options(${LIB_FSFW_NAME} PRIVATE
|
|
||||||
"-ffunction-sections"
|
|
||||||
"-fdata-sections"
|
|
||||||
)
|
|
||||||
|
|
||||||
target_link_options(${LIB_FSFW_NAME} PRIVATE
|
|
||||||
"Wl,--gc-sections"
|
|
||||||
)
|
|
||||||
|
|
||||||
if(FSFW_HAL_WARNING_SHADOW_LOCAL_GCC)
|
|
||||||
list(APPEND WARNING_FLAGS "-Wshadow=local")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
endif()
|
|
||||||
|
7
hal/inc/CMakeLists.txt
Normal file
7
hal/inc/CMakeLists.txt
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
target_include_directories(${LIB_FSFW_NAME} PRIVATE
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
)
|
||||||
|
|
||||||
|
target_include_directories(${LIB_FSFW_NAME} INTERFACE
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
)
|
10
hal/src/CMakeLists.txt
Normal file
10
hal/src/CMakeLists.txt
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
add_subdirectory(devicehandlers)
|
||||||
|
add_subdirectory(common)
|
||||||
|
|
||||||
|
if(FSFW_HAL_ADD_LINUX)
|
||||||
|
add_subdirectory(${LINUX_HAL_PATH_NAME})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(FSFW_HAL_ADD_STM32H7)
|
||||||
|
add_subdirectory(${STM32H7_PATH_NAME})
|
||||||
|
endif()
|
1
hal/src/common/CMakeLists.txt
Normal file
1
hal/src/common/CMakeLists.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
add_subdirectory(gpio)
|
@ -1,3 +1,3 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
GpioCookie.cpp
|
GpioCookie.cpp
|
||||||
)
|
)
|
@ -1,4 +1,4 @@
|
|||||||
#include "GpioCookie.h"
|
#include "fsfw/hal/common/gpio/GpioCookie.h"
|
||||||
#include "fsfw/serviceinterface/ServiceInterface.h"
|
#include "fsfw/serviceinterface/ServiceInterface.h"
|
||||||
|
|
||||||
GpioCookie::GpioCookie() {
|
GpioCookie::GpioCookie() {
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
GyroL3GD20Handler.cpp
|
GyroL3GD20Handler.cpp
|
||||||
)
|
)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#include "GyroL3GD20Handler.h"
|
#include "fsfw/hal/devicehandlers/GyroL3GD20Handler.h"
|
||||||
|
|
||||||
#include <fsfw/datapool/PoolReadGuard.h>
|
#include "fsfw/datapool/PoolReadGuard.h"
|
||||||
|
|
||||||
GyroHandlerL3GD20H::GyroHandlerL3GD20H(object_id_t objectId, object_id_t deviceCommunication,
|
GyroHandlerL3GD20H::GyroHandlerL3GD20H(object_id_t objectId, object_id_t deviceCommunication,
|
||||||
CookieIF *comCookie):
|
CookieIF *comCookie):
|
||||||
|
@ -2,7 +2,7 @@ if(FSFW_HAL_ADD_RASPBERRY_PI)
|
|||||||
add_subdirectory(rpi)
|
add_subdirectory(rpi)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
UnixFileGuard.cpp
|
UnixFileGuard.cpp
|
||||||
utility.cpp
|
utility.cpp
|
||||||
)
|
)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include "UnixFileGuard.h"
|
#include "fsfw/hal/linux/UnixFileGuard.h"
|
||||||
|
|
||||||
UnixFileGuard::UnixFileGuard(std::string device, int* fileDescriptor, int flags,
|
UnixFileGuard::UnixFileGuard(std::string device, int* fileDescriptor, int flags,
|
||||||
std::string diagnosticPrefix):
|
std::string diagnosticPrefix):
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
LinuxLibgpioIF.cpp
|
LinuxLibgpioIF.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -7,6 +7,6 @@ target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
|||||||
# to install the package before syncing the sysroot to your host computer.
|
# to install the package before syncing the sysroot to your host computer.
|
||||||
find_library(LIB_GPIO gpiod REQUIRED)
|
find_library(LIB_GPIO gpiod REQUIRED)
|
||||||
|
|
||||||
target_link_libraries(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_link_libraries(${LIB_FSFW_NAME} PRIVATE
|
||||||
${LIB_GPIO}
|
${LIB_GPIO}
|
||||||
)
|
)
|
@ -1,6 +1,6 @@
|
|||||||
#include "LinuxLibgpioIF.h"
|
#include "fsfw/hal/linux/gpio/LinuxLibgpioIF.h"
|
||||||
#include <common/gpio/gpioDefinitions.h>
|
#include "fsfw/hal/common/gpio/gpioDefinitions.h"
|
||||||
#include <common/gpio/GpioCookie.h>
|
#include "fsfw/hal/common/gpio/GpioCookie.h"
|
||||||
|
|
||||||
#include <fsfw/serviceinterface/ServiceInterface.h>
|
#include <fsfw/serviceinterface/ServiceInterface.h>
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PUBLIC
|
target_sources(${LIB_FSFW_NAME} PUBLIC
|
||||||
I2cComIF.cpp
|
I2cComIF.cpp
|
||||||
I2cCookie.cpp
|
I2cCookie.cpp
|
||||||
)
|
)
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
#include "I2cComIF.h"
|
#include "fsfw/hal/linux/i2c/I2cComIF.h"
|
||||||
#include "../utility.h"
|
#include "fsfw/hal/linux/utility.h"
|
||||||
#include "../UnixFileGuard.h"
|
#include "fsfw/hal/linux/UnixFileGuard.h"
|
||||||
|
|
||||||
#include <fsfw/serviceinterface/ServiceInterface.h>
|
#include "fsfw/serviceinterface/ServiceInterface.h"
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include "I2cCookie.h"
|
#include "fsfw/hal/linux/i2c/I2cCookie.h"
|
||||||
|
|
||||||
I2cCookie::I2cCookie(address_t i2cAddress_, size_t maxReplyLen_,
|
I2cCookie::I2cCookie(address_t i2cAddress_, size_t maxReplyLen_,
|
||||||
std::string deviceFile_) :
|
std::string deviceFile_) :
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
GpioRPi.cpp
|
GpioRPi.cpp
|
||||||
)
|
)
|
@ -1,6 +1,7 @@
|
|||||||
#include "GpioRPi.h"
|
#include "fsfw/FSFW.h"
|
||||||
#include "../../common/gpio/GpioCookie.h"
|
|
||||||
#include <FSFWConfig.h>
|
#include "fsfw/hal/linux/rpi/GpioRPi.h"
|
||||||
|
#include "fsfw/hal/common/gpio/GpioCookie.h"
|
||||||
|
|
||||||
#include <fsfw/serviceinterface/ServiceInterface.h>
|
#include <fsfw/serviceinterface/ServiceInterface.h>
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PUBLIC
|
target_sources(${LIB_FSFW_NAME} PUBLIC
|
||||||
SpiComIF.cpp
|
SpiComIF.cpp
|
||||||
SpiCookie.cpp
|
SpiCookie.cpp
|
||||||
)
|
)
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
#include "SpiComIF.h"
|
#include "fsfw/FSFW.h"
|
||||||
#include "SpiCookie.h"
|
#include "fsfw/hal/linux/spi/SpiComIF.h"
|
||||||
#include "../utility.h"
|
#include "fsfw/hal/linux/spi/SpiCookie.h"
|
||||||
#include "../UnixFileGuard.h"
|
#include "fsfw/hal/linux/utility.h"
|
||||||
#include "FSFWConfig.h"
|
#include "fsfw/hal/linux/UnixFileGuard.h"
|
||||||
|
|
||||||
#include <fsfw/ipc/MutexFactory.h>
|
#include <fsfw/ipc/MutexFactory.h>
|
||||||
#include <fsfw/globalfunctions/arrayprinter.h>
|
#include <fsfw/globalfunctions/arrayprinter.h>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include "SpiCookie.h"
|
#include "fsfw/hal/linux/spi/SpiCookie.h"
|
||||||
|
|
||||||
SpiCookie::SpiCookie(address_t spiAddress, gpioId_t chipSelect, std::string spiDev,
|
SpiCookie::SpiCookie(address_t spiAddress, gpioId_t chipSelect, std::string spiDev,
|
||||||
const size_t maxSize, spi::SpiModes spiMode, uint32_t spiSpeed):
|
const size_t maxSize, spi::SpiModes spiMode, uint32_t spiSpeed):
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include "UartComIF.h"
|
#include "fsfw/hal/linux/uart/UartComIF.h"
|
||||||
#include "OBSWConfig.h"
|
#include "OBSWConfig.h"
|
||||||
|
|
||||||
#include "fsfw/serviceinterface/ServiceInterface.h"
|
#include "fsfw/serviceinterface/ServiceInterface.h"
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#include "UartCookie.h"
|
#include "fsfw/hal/linux/uart/UartCookie.h"
|
||||||
|
|
||||||
#include <fsfw/serviceinterface/ServiceInterface.h>
|
#include <fsfw/serviceinterface/ServiceInterface.h>
|
||||||
|
|
||||||
|
@ -2,6 +2,6 @@ add_subdirectory(spi)
|
|||||||
add_subdirectory(gpio)
|
add_subdirectory(gpio)
|
||||||
add_subdirectory(devicetest)
|
add_subdirectory(devicetest)
|
||||||
|
|
||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
dma.cpp
|
dma.cpp
|
||||||
)
|
)
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
GyroL3GD20H.cpp
|
GyroL3GD20H.cpp
|
||||||
)
|
)
|
@ -1,3 +1,3 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
gpio.cpp
|
gpio.cpp
|
||||||
)
|
)
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
)
|
)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
spiCore.cpp
|
spiCore.cpp
|
||||||
spiDefinitions.cpp
|
spiDefinitions.cpp
|
||||||
spiInterrupts.cpp
|
spiInterrupts.cpp
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE
|
target_sources(${LIB_FSFW_NAME} PRIVATE
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user