You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
148 lines
4.4 KiB
148 lines
4.4 KiB
/* |
|
* UAVCAN data structure definition for libcanard. |
|
* |
|
* Autogenerated, do not edit. |
|
* |
|
* Source file: E:\000_MyProjects\UAVCAN\libcanard_zrzk\dsdl_compiler\pyuavcan\uavcan\dsdl_files\uavcan\CoarseOrientation.uavcan |
|
*/ |
|
#include "node_coarse_orientation.h" |
|
#include "canard.h" |
|
|
|
#ifndef CANARD_INTERNAL_SATURATE |
|
#define CANARD_INTERNAL_SATURATE(x, max) ( ((x) > max) ? max : ( (-(x) > max) ? (-max) : (x) ) ); |
|
#endif |
|
|
|
#ifndef CANARD_INTERNAL_SATURATE_UNSIGNED |
|
#define CANARD_INTERNAL_SATURATE_UNSIGNED(x, max) ( ((x) >= max) ? max : (x) ); |
|
#endif |
|
|
|
#if defined(__GNUC__) |
|
# define CANARD_MAYBE_UNUSED(x) x __attribute__((unused)) |
|
#else |
|
# define CANARD_MAYBE_UNUSED(x) x |
|
#endif |
|
|
|
/** |
|
* @brief uavcan_CoarseOrientation_encode_internal |
|
* @param source : pointer to source data struct |
|
* @param msg_buf: pointer to msg storage |
|
* @param offset: bit offset to msg storage |
|
* @param root_item: for detecting if TAO should be used |
|
* @retval returns offset |
|
*/ |
|
uint32_t uavcan_CoarseOrientation_encode_internal(uavcan_coarse_orientation_t* source, |
|
void* msg_buf, |
|
uint32_t offset, |
|
uint8_t CANARD_MAYBE_UNUSED(root_item)) |
|
{ |
|
uint32_t c = 0; |
|
|
|
// Static array (fixed_axis_roll_pitch_yaw) |
|
for (c = 0; c < 3; c++) |
|
{ |
|
canardEncodeScalar(msg_buf, offset, 5, (void*)(source->fixed_axis_roll_pitch_yaw + c)); // 15 |
|
offset += 5; |
|
} |
|
|
|
source->orientation_defined = CANARD_INTERNAL_SATURATE_UNSIGNED(source->orientation_defined, 1) |
|
canardEncodeScalar(msg_buf, offset, 1, (void*)&source->orientation_defined); // 1 |
|
offset += 1; |
|
|
|
return offset; |
|
} |
|
|
|
/** |
|
* @brief uavcan_CoarseOrientation_encode |
|
* @param source : Pointer to source data struct |
|
* @param msg_buf: Pointer to msg storage |
|
* @retval returns message length as bytes |
|
*/ |
|
uint32_t uavcan_CoarseOrientation_encode(uavcan_coarse_orientation_t* source, void* msg_buf) |
|
{ |
|
uint32_t offset = 0; |
|
|
|
offset = uavcan_CoarseOrientation_encode_internal(source, msg_buf, offset, 1); |
|
|
|
return (offset + 7 ) / 8; |
|
} |
|
|
|
/** |
|
* @brief uavcan_CoarseOrientation_decode_internal |
|
* @param transfer: Pointer to CanardRxTransfer transfer |
|
* @param payload_len: Payload message length |
|
* @param dest: Pointer to destination struct |
|
* @param dyn_arr_buf: NULL or Pointer to memory storage to be used for dynamic arrays |
|
* uavcan_coarse_orientation_t dyn memory will point to dyn_arr_buf memory. |
|
* NULL will ignore dynamic arrays decoding. |
|
* @param offset: Call with 0, bit offset to msg storage |
|
* @retval offset or ERROR value if < 0 |
|
*/ |
|
int32_t uavcan_CoarseOrientation_decode_internal( |
|
const CanardRxTransfer* transfer, |
|
uint16_t CANARD_MAYBE_UNUSED(payload_len), |
|
uavcan_coarse_orientation_t* dest, |
|
uint8_t** CANARD_MAYBE_UNUSED(dyn_arr_buf), |
|
int32_t offset) |
|
{ |
|
int32_t ret = 0; |
|
uint32_t c = 0; |
|
|
|
// Static array (fixed_axis_roll_pitch_yaw) |
|
for (c = 0; c < 3; c++) |
|
{ |
|
ret = canardDecodeScalar(transfer, (uint32_t)offset, 5, true, (void*)(dest->fixed_axis_roll_pitch_yaw + c)); |
|
if (ret != 5) |
|
{ |
|
goto uavcan_CoarseOrientation_error_exit; |
|
} |
|
offset += 5; |
|
} |
|
|
|
ret = canardDecodeScalar(transfer, (uint32_t)offset, 1, false, (void*)&dest->orientation_defined); |
|
if (ret != 1) |
|
{ |
|
goto uavcan_CoarseOrientation_error_exit; |
|
} |
|
offset += 1; |
|
return offset; |
|
|
|
uavcan_CoarseOrientation_error_exit: |
|
if (ret < 0) |
|
{ |
|
return ret; |
|
} |
|
else |
|
{ |
|
return -CANARD_ERROR_INTERNAL; |
|
} |
|
} |
|
|
|
/** |
|
* @brief uavcan_CoarseOrientation_decode |
|
* @param transfer: Pointer to CanardRxTransfer transfer |
|
* @param payload_len: Payload message length |
|
* @param dest: Pointer to destination struct |
|
* @param dyn_arr_buf: NULL or Pointer to memory storage to be used for dynamic arrays |
|
* uavcan_coarse_orientation_t dyn memory will point to dyn_arr_buf memory. |
|
* NULL will ignore dynamic arrays decoding. |
|
* @retval offset or ERROR value if < 0 |
|
*/ |
|
int32_t uavcan_CoarseOrientation_decode(const CanardRxTransfer* transfer, |
|
uint16_t payload_len, |
|
uavcan_coarse_orientation_t* dest, |
|
uint8_t** dyn_arr_buf) |
|
{ |
|
const int32_t offset = 0; |
|
int32_t ret = 0; |
|
|
|
// Clear the destination struct |
|
for (uint32_t c = 0; c < sizeof(uavcan_coarse_orientation_t); c++) |
|
{ |
|
((uint8_t*)dest)[c] = 0x00; |
|
} |
|
|
|
ret = uavcan_CoarseOrientation_decode_internal(transfer, payload_len, dest, dyn_arr_buf, offset); |
|
|
|
return ret; |
|
} |
|
|
|
|