/* * UAVCAN data structure definition for libcanard. * * Autogenerated, do not edit. * * Source file: D:\data\libcanard-master\dsdl_compiler\dsdl_define\uavcan\equipment\actuator\Statusinfo.uavcan */ #ifndef __UAVCAN_EQUIPMENT_ACTUATOR_STATUSINFO #define __UAVCAN_EQUIPMENT_ACTUATOR_STATUSINFO #include #include "canard.h" #ifdef __cplusplus extern "C" { #endif /******************************* Source text ********************************** # # Generic actuator feedback, if available. # Unknown fields should be set to NAN. # uint16 actuator_id # # Whether the units are linear or angular depends on the actuator type (refer to the Command data type). # float16 position # meter or radian float16 force # Newton or Newton metre float16 speed # meter per second or radian per second ******************************************************************************/ /********************* DSDL signature source definition *********************** uavcan.equipment.actuator.Statusinfo saturated uint16 actuator_id saturated float16 position saturated float16 force saturated float16 speed ******************************************************************************/ #define UAVCAN_EQUIPMENT_ACTUATOR_STATUSINFO_NAME "uavcan.equipment.actuator.Statusinfo" #define UAVCAN_EQUIPMENT_ACTUATOR_STATUSINFO_SIGNATURE (0x7EF30CB8A0D3B490ULL) #define UAVCAN_EQUIPMENT_ACTUATOR_STATUSINFO_MAX_SIZE ((64 + 7)/8) // Constants typedef struct { // FieldTypes uint16_t actuator_id; // bit len 16 float position; // float16 Saturate float force; // float16 Saturate float speed; // float16 Saturate } uavcan_equipment_actuator_Statusinfo; static inline uint32_t uavcan_equipment_actuator_Statusinfo_encode(uavcan_equipment_actuator_Statusinfo* source, void* msg_buf, bool tao_enabled); static inline int32_t uavcan_equipment_actuator_Statusinfo_decode(const CanardRxTransfer* transfer, uint16_t payload_len, uavcan_equipment_actuator_Statusinfo* dest, uint8_t** dyn_arr_buf, bool tao_enabled); static inline uint32_t uavcan_equipment_actuator_Statusinfo_encode_internal(uavcan_equipment_actuator_Statusinfo* source, void* msg_buf, uint32_t offset, uint8_t root_item, bool tao_enabled); static inline int32_t uavcan_equipment_actuator_Statusinfo_decode_internal(const CanardRxTransfer* transfer, uint16_t payload_len, uavcan_equipment_actuator_Statusinfo* dest, uint8_t** dyn_arr_buf, int32_t offset, bool tao_enabled); /* * UAVCAN data structure definition for libcanard. * * Autogenerated, do not edit. * * Source file: D:\data\libcanard-master\dsdl_compiler\dsdl_define\uavcan\equipment\actuator\Statusinfo.uavcan */ #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_equipment_actuator_Statusinfo_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_equipment_actuator_Statusinfo_encode_internal(uavcan_equipment_actuator_Statusinfo* source, void* msg_buf, uint32_t offset, uint8_t CANARD_MAYBE_UNUSED(root_item), bool tao_enabled) { #ifndef CANARD_USE_FLOAT16_CAST uint16_t tmp_float = 0; #else CANARD_USE_FLOAT16_CAST tmp_float = 0; #endif canardEncodeScalar(msg_buf, offset, 16, (void*)&source->actuator_id); // 65535 offset += 16; // float16 special handling #ifndef CANARD_USE_FLOAT16_CAST tmp_float = canardConvertNativeFloatToFloat16(source->position); #else tmp_float = (CANARD_USE_FLOAT16_CAST)source->position; #endif canardEncodeScalar(msg_buf, offset, 16, (void*)&tmp_float); // 32767 offset += 16; // float16 special handling #ifndef CANARD_USE_FLOAT16_CAST tmp_float = canardConvertNativeFloatToFloat16(source->force); #else tmp_float = (CANARD_USE_FLOAT16_CAST)source->force; #endif canardEncodeScalar(msg_buf, offset, 16, (void*)&tmp_float); // 32767 offset += 16; // float16 special handling #ifndef CANARD_USE_FLOAT16_CAST tmp_float = canardConvertNativeFloatToFloat16(source->speed); #else tmp_float = (CANARD_USE_FLOAT16_CAST)source->speed; #endif canardEncodeScalar(msg_buf, offset, 16, (void*)&tmp_float); // 32767 offset += 16; return offset; } /** * @brief uavcan_equipment_actuator_Statusinfo_encode * @param source : Pointer to source data struct * @param msg_buf: Pointer to msg storage * @retval returns message length as bytes */ uint32_t uavcan_equipment_actuator_Statusinfo_encode(uavcan_equipment_actuator_Statusinfo* source, void* msg_buf, bool tao_enabled) { uint32_t offset = 0; offset = uavcan_equipment_actuator_Statusinfo_encode_internal(source, msg_buf, offset, 1, tao_enabled); return (offset + 7 ) / 8; } /** * @brief uavcan_equipment_actuator_Statusinfo_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_equipment_actuator_Statusinfo 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_equipment_actuator_Statusinfo_decode_internal( const CanardRxTransfer* transfer, uint16_t CANARD_MAYBE_UNUSED(payload_len), uavcan_equipment_actuator_Statusinfo* dest, uint8_t** CANARD_MAYBE_UNUSED(dyn_arr_buf), int32_t offset, bool tao_enabled) { int32_t ret = 0; #ifndef CANARD_USE_FLOAT16_CAST uint16_t tmp_float = 0; #else CANARD_USE_FLOAT16_CAST tmp_float = 0; #endif ret = canardDecodeScalar(transfer, (uint32_t)offset, 16, false, (void*)&dest->actuator_id); if (ret != 16) { goto uavcan_equipment_actuator_Statusinfo_error_exit; } offset += 16; // float16 special handling ret = canardDecodeScalar(transfer, (uint32_t)offset, 16, false, (void*)&tmp_float); if (ret != 16) { goto uavcan_equipment_actuator_Statusinfo_error_exit; } #ifndef CANARD_USE_FLOAT16_CAST dest->position = canardConvertFloat16ToNativeFloat(tmp_float); #else dest->position = (float)tmp_float; #endif offset += 16; // float16 special handling ret = canardDecodeScalar(transfer, (uint32_t)offset, 16, false, (void*)&tmp_float); if (ret != 16) { goto uavcan_equipment_actuator_Statusinfo_error_exit; } #ifndef CANARD_USE_FLOAT16_CAST dest->force = canardConvertFloat16ToNativeFloat(tmp_float); #else dest->force = (float)tmp_float; #endif offset += 16; // float16 special handling ret = canardDecodeScalar(transfer, (uint32_t)offset, 16, false, (void*)&tmp_float); if (ret != 16) { goto uavcan_equipment_actuator_Statusinfo_error_exit; } #ifndef CANARD_USE_FLOAT16_CAST dest->speed = canardConvertFloat16ToNativeFloat(tmp_float); #else dest->speed = (float)tmp_float; #endif offset += 16; return offset; uavcan_equipment_actuator_Statusinfo_error_exit: if (ret < 0) { return ret; } else { return -CANARD_ERROR_INTERNAL; } } /** * @brief uavcan_equipment_actuator_Statusinfo_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_equipment_actuator_Statusinfo 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_equipment_actuator_Statusinfo_decode(const CanardRxTransfer* transfer, uint16_t payload_len, uavcan_equipment_actuator_Statusinfo* dest, uint8_t** dyn_arr_buf, bool tao_enabled) { const int32_t offset = 0; int32_t ret = 0; // Clear the destination struct for (uint32_t c = 0; c < sizeof(uavcan_equipment_actuator_Statusinfo); c++) { ((uint8_t*)dest)[c] = 0x00; } ret = uavcan_equipment_actuator_Statusinfo_decode_internal(transfer, payload_len, dest, dyn_arr_buf, offset, tao_enabled); return ret; } #ifdef __cplusplus } // extern "C" #endif #endif // __UAVCAN_EQUIPMENT_ACTUATOR_STATUSINFO