mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-06-01 02:55:07 +08:00
Qurt lightweight parameter implementation (#20735)
This commit is contained in:
@@ -3,3 +3,4 @@ CONFIG_BOARD_TOOLCHAIN="qurt"
|
|||||||
CONFIG_MODULES_MUORB_SLPI=y
|
CONFIG_MODULES_MUORB_SLPI=y
|
||||||
CONFIG_SYSTEMCMDS_UORB=y
|
CONFIG_SYSTEMCMDS_UORB=y
|
||||||
CONFIG_ORB_COMMUNICATOR=y
|
CONFIG_ORB_COMMUNICATOR=y
|
||||||
|
CONFIG_SYSTEMCMDS_PARAM=y
|
||||||
|
|||||||
@@ -5,3 +5,4 @@ CONFIG_MODULES_MUORB_APPS=y
|
|||||||
CONFIG_SYSTEMCMDS_PERF=y
|
CONFIG_SYSTEMCMDS_PERF=y
|
||||||
CONFIG_SYSTEMCMDS_UORB=y
|
CONFIG_SYSTEMCMDS_UORB=y
|
||||||
CONFIG_ORB_COMMUNICATOR=y
|
CONFIG_ORB_COMMUNICATOR=y
|
||||||
|
CONFIG_SYSTEMCMDS_PARAM=y
|
||||||
|
|||||||
@@ -48,9 +48,7 @@ function(px4_add_library target)
|
|||||||
# all PX4 libraries have access to parameters and uORB
|
# all PX4 libraries have access to parameters and uORB
|
||||||
# TODO: Exclusion of qurt is temporary until these modules
|
# TODO: Exclusion of qurt is temporary until these modules
|
||||||
# build cleanly.
|
# build cleanly.
|
||||||
if(NOT ${PLATFORM} MATCHES "qurt")
|
add_dependencies(${target} uorb_headers parameters)
|
||||||
add_dependencies(${target} uorb_headers parameters)
|
|
||||||
endif()
|
|
||||||
target_link_libraries(${target} PRIVATE prebuild_targets)
|
target_link_libraries(${target} PRIVATE prebuild_targets)
|
||||||
|
|
||||||
set_property(GLOBAL APPEND PROPERTY PX4_MODULE_PATHS ${CMAKE_CURRENT_SOURCE_DIR})
|
set_property(GLOBAL APPEND PROPERTY PX4_MODULE_PATHS ${CMAKE_CURRENT_SOURCE_DIR})
|
||||||
|
|||||||
@@ -170,9 +170,6 @@ function(px4_add_module)
|
|||||||
if (${PX4_PLATFORM} STREQUAL "nuttx" AND NOT CONFIG_BUILD_FLAT AND KERNEL)
|
if (${PX4_PLATFORM} STREQUAL "nuttx" AND NOT CONFIG_BUILD_FLAT AND KERNEL)
|
||||||
target_link_libraries(${MODULE} PRIVATE kernel_parameters_interface px4_kernel_layer uORB_kernel)
|
target_link_libraries(${MODULE} PRIVATE kernel_parameters_interface px4_kernel_layer uORB_kernel)
|
||||||
set_property(GLOBAL APPEND PROPERTY PX4_KERNEL_MODULE_LIBRARIES ${MODULE})
|
set_property(GLOBAL APPEND PROPERTY PX4_KERNEL_MODULE_LIBRARIES ${MODULE})
|
||||||
elseif(${PX4_PLATFORM} STREQUAL "qurt")
|
|
||||||
target_link_libraries(${MODULE} PRIVATE px4_layer uORB)
|
|
||||||
set_property(GLOBAL APPEND PROPERTY PX4_MODULE_LIBRARIES ${MODULE})
|
|
||||||
else()
|
else()
|
||||||
target_link_libraries(${MODULE} PRIVATE parameters_interface px4_layer uORB)
|
target_link_libraries(${MODULE} PRIVATE parameters_interface px4_layer uORB)
|
||||||
set_property(GLOBAL APPEND PROPERTY PX4_MODULE_LIBRARIES ${MODULE})
|
set_property(GLOBAL APPEND PROPERTY PX4_MODULE_LIBRARIES ${MODULE})
|
||||||
|
|||||||
@@ -100,6 +100,12 @@ typedef struct {
|
|||||||
#define POLLIN (0x01)
|
#define POLLIN (0x01)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(__PX4_QURT)
|
||||||
|
// Qurt has no fsync implementation so need to declare one here
|
||||||
|
// and then define a fake one in the Qurt platform code.
|
||||||
|
void fsync(int fd);
|
||||||
|
#endif
|
||||||
|
|
||||||
__EXPORT int px4_open(const char *path, int flags, ...);
|
__EXPORT int px4_open(const char *path, int flags, ...);
|
||||||
__EXPORT int px4_close(int fd);
|
__EXPORT int px4_close(int fd);
|
||||||
__EXPORT ssize_t px4_read(int fd, void *buffer, size_t buflen);
|
__EXPORT ssize_t px4_read(int fd, void *buffer, size_t buflen);
|
||||||
@@ -114,7 +120,6 @@ __END_DECLS
|
|||||||
#error "No TARGET OS Provided"
|
#error "No TARGET OS Provided"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// The stack size is intended for 32-bit architectures; therefore
|
// The stack size is intended for 32-bit architectures; therefore
|
||||||
// we often run out of stack space when pointers are larger than 4 bytes.
|
// we often run out of stack space when pointers are larger than 4 bytes.
|
||||||
// Double the stack size on posix when we're on a 64-bit architecture.
|
// Double the stack size on posix when we're on a 64-bit architecture.
|
||||||
|
|||||||
@@ -50,8 +50,6 @@ include(qurt_reqs)
|
|||||||
|
|
||||||
include_directories(${HEXAGON_SDK_INCLUDES})
|
include_directories(${HEXAGON_SDK_INCLUDES})
|
||||||
|
|
||||||
set(DISABLE_PARAMS_MODULE_SCOPING TRUE)
|
|
||||||
|
|
||||||
#=============================================================================
|
#=============================================================================
|
||||||
#
|
#
|
||||||
# Defined functions in this file
|
# Defined functions in this file
|
||||||
|
|||||||
@@ -38,6 +38,8 @@
|
|||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#include <visibility.h>
|
#include <visibility.h>
|
||||||
|
#include <inttypes.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
|
|||||||
@@ -35,5 +35,7 @@
|
|||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
long PX4_TICKS_PER_SEC = 1000L;
|
long PX4_TICKS_PER_SEC = 1000L;
|
||||||
|
void fsync(int fd) { return; }
|
||||||
|
uint32_t crc32part(const uint8_t *src, size_t len, uint32_t crc32val) { return 1; }
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|||||||
Reference in New Issue
Block a user