Merge branch 'mueller/master' into mueller/restructuring

This commit is contained in:
Robin Müller 2021-07-15 18:55:52 +02:00
commit 8db0ca861a
62 changed files with 102 additions and 115 deletions

View File

@ -86,6 +86,7 @@ message(STATUS "Compiling FSFW for the ${OS_FSFW_NAME} operating system.")
add_subdirectory(src) add_subdirectory(src)
add_subdirectory(tests) add_subdirectory(tests)
add_subdirectory(hal)
add_subdirectory(contrib) add_subdirectory(contrib)
# The project CMakeLists file has to set the FSFW_CONFIG_PATH and add it. # The project CMakeLists file has to set the FSFW_CONFIG_PATH and add it.

View File

@ -5,35 +5,19 @@ find_library(LIB_FSFW_NAME fsfw REQUIRED)
option(FSFW_HAL_ADD_LINUX "Add the Linux HAL to the sources. Required gpiod library" OFF) option(FSFW_HAL_ADD_LINUX "Add the Linux HAL to the sources. Required gpiod library" OFF)
option(FSFW_HAL_ADD_RASPBERRY_PI "Add Raspberry Pi specific code to the sources" OFF) option(FSFW_HAL_ADD_RASPBERRY_PI "Add Raspberry Pi specific code to the sources" OFF)
option(FSFW_HAL_ADD_STM32H7 "Add the STM32H7 HAL to the sources" OFF) option(FSFW_HAL_ADD_STM32H7 "Add the STM32H7 HAL to the sources" OFF)
option(FSFW_HAL_WARNING_SHADOW_LOCAL_GCC "Enable -Wshadow=local warning in GCC" ON) option(FSFW_HAL_WARNING_SHADOW_LOCAL_GCC "Enable -Wshadow=local warning in GCC" ON)
set(LIB_FSFW_HAL_NAME fsfw_hal) 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})
@ -50,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
View 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
View 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()

View File

@ -0,0 +1 @@
add_subdirectory(gpio)

View File

@ -1,3 +1,3 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
GpioCookie.cpp GpioCookie.cpp
) )

View File

@ -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() {

View File

@ -1,3 +1,3 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
GyroL3GD20Handler.cpp GyroL3GD20Handler.cpp
) )

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@ -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_) :

View File

@ -1,3 +1,3 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
GpioRPi.cpp GpioRPi.cpp
) )

View File

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

View File

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

View File

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

View File

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

View File

@ -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"

View File

@ -1,4 +1,4 @@
#include "UartCookie.h" #include "fsfw/hal/linux/uart/UartCookie.h"
#include <fsfw/serviceinterface/ServiceInterface.h> #include <fsfw/serviceinterface/ServiceInterface.h>

View File

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

View File

@ -1,3 +1,3 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
GyroL3GD20H.cpp GyroL3GD20H.cpp
) )

View File

@ -1,3 +1,3 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
gpio.cpp gpio.cpp
) )

View File

@ -1,2 +1,2 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
) )

View File

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

View File

@ -1,2 +1,2 @@
target_sources(${LIB_FSFW_HAL_NAME} PRIVATE target_sources(${LIB_FSFW_NAME} PRIVATE
) )

View File

@ -79,7 +79,9 @@ public:
static void setCreateDirectoryCommand(CommandMessage* message, static void setCreateDirectoryCommand(CommandMessage* message,
store_address_t storeId); store_address_t storeId);
static void setDeleteDirectoryCommand(CommandMessage* message, static void setDeleteDirectoryCommand(CommandMessage* message,
store_address_t storeId); store_address_t storeId, bool deleteRecursively);
static store_address_t getDeleteDirectoryCommand(const CommandMessage* message,
bool& deleteRecursively);
static void setSuccessReply(CommandMessage* message); static void setSuccessReply(CommandMessage* message);
static void setFailureReply(CommandMessage* message, static void setFailureReply(CommandMessage* message,

View File

@ -36,9 +36,8 @@ public:
//! [EXPORT] : P1: Sequence number missing //! [EXPORT] : P1: Sequence number missing
static constexpr ReturnValue_t SEQUENCE_PACKET_MISSING_READ = MAKE_RETURN_CODE(16); static constexpr ReturnValue_t SEQUENCE_PACKET_MISSING_READ = MAKE_RETURN_CODE(16);
virtual ~HasFileSystemIF() {} virtual ~HasFileSystemIF() {}
/** /**
* Function to get the MessageQueueId_t of the implementing object * Function to get the MessageQueueId_t of the implementing object
* @return MessageQueueId_t of the object * @return MessageQueueId_t of the object
@ -46,7 +45,7 @@ public:
virtual MessageQueueId_t getCommandQueue() const = 0; virtual MessageQueueId_t getCommandQueue() const = 0;
/** /**
* Generic function to append to file. * @brief Generic function to append to file.
* @param dirname Directory of the file * @param dirname Directory of the file
* @param filename The filename of the file * @param filename The filename of the file
* @param data The data to write to the file * @param data The data to write to the file
@ -63,12 +62,12 @@ public:
uint16_t packetNumber, void* args = nullptr) = 0; uint16_t packetNumber, void* args = nullptr) = 0;
/** /**
* Generic function to create a new file. * @brief Generic function to create a new file.
* @param repositoryPath * @param repositoryPath
* @param filename * @param filename
* @param data * @param data
* @param size * @param size
* @param args Any other arguments which an implementation might require. * @param args Any other arguments which an implementation might require
* @return * @return
*/ */
virtual ReturnValue_t createFile(const char* repositoryPath, virtual ReturnValue_t createFile(const char* repositoryPath,
@ -76,14 +75,30 @@ public:
size_t size = 0, void* args = nullptr) = 0; size_t size = 0, void* args = nullptr) = 0;
/** /**
* Generic function to delete a file. * @brief Generic function to delete a file.
* @param repositoryPath * @param repositoryPath
* @param filename * @param filename
* @param args * @param args Any other arguments which an implementation might require
* @return * @return
*/ */
virtual ReturnValue_t deleteFile(const char* repositoryPath, virtual ReturnValue_t deleteFile(const char* repositoryPath,
const char* filename, void* args = nullptr) = 0; const char* filename, void* args = nullptr) = 0;
/**
* @brief Generic function to create a directory
* @param repositoryPath
* @param args Any other arguments which an implementation might require
* @return
*/
virtual ReturnValue_t createDirectory(const char* repositoryPath, void* args = nullptr) = 0;
/**
* @brief Generic function to remove a directory
* @param repositoryPath
* @param args Any other arguments which an implementation might require
*/
virtual ReturnValue_t removeDirectory(const char* repositoryPath,
bool deleteRecurively = false, void* args = nullptr) = 0;
}; };

View File

@ -1,15 +0,0 @@
CXXSRC += $(wildcard $(CURRENTPATH)/ipc/*.cpp)
CXXSRC += $(wildcard $(CURRENTPATH)/objects/*.cpp)
CXXSRC += $(wildcard $(CURRENTPATH)/pollingsequence/*.cpp)
CXXSRC += $(wildcard $(CURRENTPATH)/events/*.cpp)
CXXSRC += $(wildcard $(CURRENTPATH)/tmtc/*.cpp)
CXXSRC += $(wildcard $(CURRENTPATH)/devices/*.cpp)
INCLUDES += $(CURRENTPATH)
INCLUDES += $(CURRENTPATH)/objects
INCLUDES += $(CURRENTPATH)/returnvalues
INCLUDES += $(CURRENTPATH)/tmtc
INCLUDES += $(CURRENTPATH)/events
INCLUDES += $(CURRENTPATH)/devices
INCLUDES += $(CURRENTPATH)/pollingsequence
INCLUDES += $(CURRENTPATH)/ipc

View File

@ -34,8 +34,9 @@ void GenericFileSystemMessage::setReportFileAttributesReply(CommandMessage *mess
} }
void GenericFileSystemMessage::setDeleteDirectoryCommand(CommandMessage* message, void GenericFileSystemMessage::setDeleteDirectoryCommand(CommandMessage* message,
store_address_t storeId) { store_address_t storeId, bool deleteRecursively) {
message->setCommand(CMD_DELETE_DIRECTORY); message->setCommand(CMD_DELETE_DIRECTORY);
message->setParameter(deleteRecursively);
message->setParameter2(storeId.raw); message->setParameter2(storeId.raw);
} }
@ -133,6 +134,12 @@ bool GenericFileSystemMessage::getReadReply(const CommandMessage *message,
return message->getParameter(); return message->getParameter();
} }
store_address_t GenericFileSystemMessage::getDeleteDirectoryCommand(const CommandMessage *message,
bool &deleteRecursively) {
deleteRecursively = message->getParameter();
return getStoreId(message);
}
ReturnValue_t GenericFileSystemMessage::clear(CommandMessage* message) { ReturnValue_t GenericFileSystemMessage::clear(CommandMessage* message) {
switch(message->getCommand()) { switch(message->getCommand()) {
case(CMD_CREATE_FILE): case(CMD_CREATE_FILE):

View File

@ -1,9 +1,8 @@
target_sources(${LIB_FSFW_NAME} target_sources(${LIB_FSFW_NAME} PRIVATE
PRIVATE CCSDSTime.cpp
CCSDSTime.cpp Countdown.cpp
Countdown.cpp Stopwatch.cpp
Stopwatch.cpp TimeMessage.cpp
TimeMessage.cpp TimeStamper.cpp
TimeStamper.cpp ClockCommon.cpp
ClockCommon.cpp
) )