2024-08-19 16:16:39 +08:00
# pragma once
2023-05-26 20:01:10 +08:00
// MESSAGE PARAM_REQUEST_READ PACKING
# define MAVLINK_MSG_ID_PARAM_REQUEST_READ 20
2024-08-19 16:16:39 +08:00
MAVPACKED (
typedef struct __mavlink_param_request_read_t {
int16_t param_index ; /*< Parameter index. Send -1 to use the param ID field as identifier (else the param id will be ignored)*/
uint8_t target_system ; /*< System ID*/
uint8_t target_component ; /*< Component ID*/
char param_id [ 16 ] ; /*< Onboard parameter id, terminated by NULL if the length is less than 16 human-readable chars and WITHOUT null termination (NULL) byte if the length is exactly 16 chars - applications have to provide 16+1 bytes storage if the ID is stored as string*/
} ) mavlink_param_request_read_t ;
2023-05-26 20:01:10 +08:00
# define MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN 20
2024-08-19 16:16:39 +08:00
# define MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN 20
2023-05-26 20:01:10 +08:00
# define MAVLINK_MSG_ID_20_LEN 20
2024-08-19 16:16:39 +08:00
# define MAVLINK_MSG_ID_20_MIN_LEN 20
# define MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC 214
# define MAVLINK_MSG_ID_20_CRC 214
2023-05-26 20:01:10 +08:00
# define MAVLINK_MSG_PARAM_REQUEST_READ_FIELD_PARAM_ID_LEN 16
2024-08-19 16:16:39 +08:00
# if MAVLINK_COMMAND_24BIT
2023-05-26 20:01:10 +08:00
# define MAVLINK_MESSAGE_INFO_PARAM_REQUEST_READ { \
2024-08-19 16:16:39 +08:00
20 , \
" PARAM_REQUEST_READ " , \
4 , \
{ { " target_system " , NULL , MAVLINK_TYPE_UINT8_T , 0 , 2 , offsetof ( mavlink_param_request_read_t , target_system ) } , \
2023-05-26 20:01:10 +08:00
{ " target_component " , NULL , MAVLINK_TYPE_UINT8_T , 0 , 3 , offsetof ( mavlink_param_request_read_t , target_component ) } , \
{ " param_id " , NULL , MAVLINK_TYPE_CHAR , 16 , 4 , offsetof ( mavlink_param_request_read_t , param_id ) } , \
2024-08-19 16:16:39 +08:00
{ " param_index " , NULL , MAVLINK_TYPE_INT16_T , 0 , 0 , offsetof ( mavlink_param_request_read_t , param_index ) } , \
2023-05-26 20:01:10 +08:00
} \
}
2024-08-19 16:16:39 +08:00
# else
# define MAVLINK_MESSAGE_INFO_PARAM_REQUEST_READ { \
" PARAM_REQUEST_READ " , \
4 , \
{ { " target_system " , NULL , MAVLINK_TYPE_UINT8_T , 0 , 2 , offsetof ( mavlink_param_request_read_t , target_system ) } , \
{ " target_component " , NULL , MAVLINK_TYPE_UINT8_T , 0 , 3 , offsetof ( mavlink_param_request_read_t , target_component ) } , \
{ " param_id " , NULL , MAVLINK_TYPE_CHAR , 16 , 4 , offsetof ( mavlink_param_request_read_t , param_id ) } , \
{ " param_index " , NULL , MAVLINK_TYPE_INT16_T , 0 , 0 , offsetof ( mavlink_param_request_read_t , param_index ) } , \
} \
}
# endif
2023-05-26 20:01:10 +08:00
/**
* @ brief Pack a param_request_read message
* @ param system_id ID of this system
* @ param component_id ID of this component ( e . g . 200 for IMU )
* @ param msg The MAVLink message to compress the data into
*
2024-08-19 16:16:39 +08:00
* @ param target_system System ID
* @ param target_component Component ID
* @ param param_id Onboard parameter id , terminated by NULL if the length is less than 16 human - readable chars and WITHOUT null termination ( NULL ) byte if the length is exactly 16 chars - applications have to provide 16 + 1 bytes storage if the ID is stored as string
* @ param param_index Parameter index . Send - 1 to use the param ID field as identifier ( else the param id will be ignored )
2023-05-26 20:01:10 +08:00
* @ return length of the message in bytes ( excluding serial stream start sign )
*/
static inline uint16_t mavlink_msg_param_request_read_pack ( uint8_t system_id , uint8_t component_id , mavlink_message_t * msg ,
2024-08-19 16:16:39 +08:00
uint8_t target_system , uint8_t target_component , const char * param_id , int16_t param_index )
2023-05-26 20:01:10 +08:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2024-08-19 16:16:39 +08:00
char buf [ MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ] ;
_mav_put_int16_t ( buf , 0 , param_index ) ;
_mav_put_uint8_t ( buf , 2 , target_system ) ;
_mav_put_uint8_t ( buf , 3 , target_component ) ;
_mav_put_char_array ( buf , 4 , param_id , 16 ) ;
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , buf , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ) ;
2023-05-26 20:01:10 +08:00
# else
2024-08-19 16:16:39 +08:00
mavlink_param_request_read_t packet ;
packet . param_index = param_index ;
packet . target_system = target_system ;
packet . target_component = target_component ;
mav_array_memcpy ( packet . param_id , param_id , sizeof ( char ) * 16 ) ;
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , & packet , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ) ;
2023-05-26 20:01:10 +08:00
# endif
2024-08-19 16:16:39 +08:00
msg - > msgid = MAVLINK_MSG_ID_PARAM_REQUEST_READ ;
return mavlink_finalize_message ( msg , system_id , component_id , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
2023-05-26 20:01:10 +08:00
}
/**
* @ brief Pack a param_request_read message on a channel
* @ param system_id ID of this system
* @ param component_id ID of this component ( e . g . 200 for IMU )
2024-08-19 16:16:39 +08:00
* @ param chan The MAVLink channel this message will be sent over
2023-05-26 20:01:10 +08:00
* @ param msg The MAVLink message to compress the data into
2024-08-19 16:16:39 +08:00
* @ param target_system System ID
* @ param target_component Component ID
* @ param param_id Onboard parameter id , terminated by NULL if the length is less than 16 human - readable chars and WITHOUT null termination ( NULL ) byte if the length is exactly 16 chars - applications have to provide 16 + 1 bytes storage if the ID is stored as string
* @ param param_index Parameter index . Send - 1 to use the param ID field as identifier ( else the param id will be ignored )
2023-05-26 20:01:10 +08:00
* @ return length of the message in bytes ( excluding serial stream start sign )
*/
static inline uint16_t mavlink_msg_param_request_read_pack_chan ( uint8_t system_id , uint8_t component_id , uint8_t chan ,
2024-08-19 16:16:39 +08:00
mavlink_message_t * msg ,
uint8_t target_system , uint8_t target_component , const char * param_id , int16_t param_index )
2023-05-26 20:01:10 +08:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2024-08-19 16:16:39 +08:00
char buf [ MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ] ;
_mav_put_int16_t ( buf , 0 , param_index ) ;
_mav_put_uint8_t ( buf , 2 , target_system ) ;
_mav_put_uint8_t ( buf , 3 , target_component ) ;
_mav_put_char_array ( buf , 4 , param_id , 16 ) ;
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , buf , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ) ;
2023-05-26 20:01:10 +08:00
# else
2024-08-19 16:16:39 +08:00
mavlink_param_request_read_t packet ;
packet . param_index = param_index ;
packet . target_system = target_system ;
packet . target_component = target_component ;
mav_array_memcpy ( packet . param_id , param_id , sizeof ( char ) * 16 ) ;
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , & packet , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ) ;
2023-05-26 20:01:10 +08:00
# endif
2024-08-19 16:16:39 +08:00
msg - > msgid = MAVLINK_MSG_ID_PARAM_REQUEST_READ ;
return mavlink_finalize_message_chan ( msg , system_id , component_id , chan , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
2023-05-26 20:01:10 +08:00
}
/**
2024-08-19 16:16:39 +08:00
* @ brief Encode a param_request_read struct
2023-05-26 20:01:10 +08:00
*
* @ param system_id ID of this system
* @ param component_id ID of this component ( e . g . 200 for IMU )
* @ param msg The MAVLink message to compress the data into
* @ param param_request_read C - struct to read the message contents from
*/
static inline uint16_t mavlink_msg_param_request_read_encode ( uint8_t system_id , uint8_t component_id , mavlink_message_t * msg , const mavlink_param_request_read_t * param_request_read )
{
2024-08-19 16:16:39 +08:00
return mavlink_msg_param_request_read_pack ( system_id , component_id , msg , param_request_read - > target_system , param_request_read - > target_component , param_request_read - > param_id , param_request_read - > param_index ) ;
}
/**
* @ brief Encode a param_request_read struct on a channel
*
* @ param system_id ID of this system
* @ param component_id ID of this component ( e . g . 200 for IMU )
* @ param chan The MAVLink channel this message will be sent over
* @ param msg The MAVLink message to compress the data into
* @ param param_request_read C - struct to read the message contents from
*/
static inline uint16_t mavlink_msg_param_request_read_encode_chan ( uint8_t system_id , uint8_t component_id , uint8_t chan , mavlink_message_t * msg , const mavlink_param_request_read_t * param_request_read )
{
return mavlink_msg_param_request_read_pack_chan ( system_id , component_id , chan , msg , param_request_read - > target_system , param_request_read - > target_component , param_request_read - > param_id , param_request_read - > param_index ) ;
2023-05-26 20:01:10 +08:00
}
/**
* @ brief Send a param_request_read message
* @ param chan MAVLink channel to send the message
*
2024-08-19 16:16:39 +08:00
* @ param target_system System ID
* @ param target_component Component ID
* @ param param_id Onboard parameter id , terminated by NULL if the length is less than 16 human - readable chars and WITHOUT null termination ( NULL ) byte if the length is exactly 16 chars - applications have to provide 16 + 1 bytes storage if the ID is stored as string
* @ param param_index Parameter index . Send - 1 to use the param ID field as identifier ( else the param id will be ignored )
2023-05-26 20:01:10 +08:00
*/
# ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
static inline void mavlink_msg_param_request_read_send ( mavlink_channel_t chan , uint8_t target_system , uint8_t target_component , const char * param_id , int16_t param_index )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2024-08-19 16:16:39 +08:00
char buf [ MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ] ;
_mav_put_int16_t ( buf , 0 , param_index ) ;
_mav_put_uint8_t ( buf , 2 , target_system ) ;
_mav_put_uint8_t ( buf , 3 , target_component ) ;
_mav_put_char_array ( buf , 4 , param_id , 16 ) ;
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_PARAM_REQUEST_READ , buf , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
2023-05-26 20:01:10 +08:00
# else
2024-08-19 16:16:39 +08:00
mavlink_param_request_read_t packet ;
packet . param_index = param_index ;
packet . target_system = target_system ;
packet . target_component = target_component ;
mav_array_memcpy ( packet . param_id , param_id , sizeof ( char ) * 16 ) ;
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_PARAM_REQUEST_READ , ( const char * ) & packet , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
2023-05-26 20:01:10 +08:00
# endif
}
2024-08-19 16:16:39 +08:00
/**
* @ brief Send a param_request_read message
* @ param chan MAVLink channel to send the message
* @ param struct The MAVLink struct to serialize
*/
static inline void mavlink_msg_param_request_read_send_struct ( mavlink_channel_t chan , const mavlink_param_request_read_t * param_request_read )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
mavlink_msg_param_request_read_send ( chan , param_request_read - > target_system , param_request_read - > target_component , param_request_read - > param_id , param_request_read - > param_index ) ;
# else
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_PARAM_REQUEST_READ , ( const char * ) param_request_read , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
# endif
}
# if MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN <= MAVLINK_MAX_PAYLOAD_LEN
/*
This varient of _send ( ) can be used to save stack space by re - using
memory from the receive buffer . The caller provides a
mavlink_message_t which is the size of a full mavlink message . This
is usually the receive buffer for the channel , and allows a reply to an
incoming message with minimum stack space usage .
*/
static inline void mavlink_msg_param_request_read_send_buf ( mavlink_message_t * msgbuf , mavlink_channel_t chan , uint8_t target_system , uint8_t target_component , const char * param_id , int16_t param_index )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
char * buf = ( char * ) msgbuf ;
_mav_put_int16_t ( buf , 0 , param_index ) ;
_mav_put_uint8_t ( buf , 2 , target_system ) ;
_mav_put_uint8_t ( buf , 3 , target_component ) ;
_mav_put_char_array ( buf , 4 , param_id , 16 ) ;
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_PARAM_REQUEST_READ , buf , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
# else
mavlink_param_request_read_t * packet = ( mavlink_param_request_read_t * ) msgbuf ;
packet - > param_index = param_index ;
packet - > target_system = target_system ;
packet - > target_component = target_component ;
mav_array_memcpy ( packet - > param_id , param_id , sizeof ( char ) * 16 ) ;
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_PARAM_REQUEST_READ , ( const char * ) packet , MAVLINK_MSG_ID_PARAM_REQUEST_READ_MIN_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN , MAVLINK_MSG_ID_PARAM_REQUEST_READ_CRC ) ;
# endif
}
# endif
2023-05-26 20:01:10 +08:00
# endif
// MESSAGE PARAM_REQUEST_READ UNPACKING
/**
* @ brief Get field target_system from param_request_read message
*
2024-08-19 16:16:39 +08:00
* @ return System ID
2023-05-26 20:01:10 +08:00
*/
static inline uint8_t mavlink_msg_param_request_read_get_target_system ( const mavlink_message_t * msg )
{
2024-08-19 16:16:39 +08:00
return _MAV_RETURN_uint8_t ( msg , 2 ) ;
2023-05-26 20:01:10 +08:00
}
/**
* @ brief Get field target_component from param_request_read message
*
2024-08-19 16:16:39 +08:00
* @ return Component ID
2023-05-26 20:01:10 +08:00
*/
static inline uint8_t mavlink_msg_param_request_read_get_target_component ( const mavlink_message_t * msg )
{
2024-08-19 16:16:39 +08:00
return _MAV_RETURN_uint8_t ( msg , 3 ) ;
2023-05-26 20:01:10 +08:00
}
/**
* @ brief Get field param_id from param_request_read message
*
2024-08-19 16:16:39 +08:00
* @ return Onboard parameter id , terminated by NULL if the length is less than 16 human - readable chars and WITHOUT null termination ( NULL ) byte if the length is exactly 16 chars - applications have to provide 16 + 1 bytes storage if the ID is stored as string
2023-05-26 20:01:10 +08:00
*/
static inline uint16_t mavlink_msg_param_request_read_get_param_id ( const mavlink_message_t * msg , char * param_id )
{
2024-08-19 16:16:39 +08:00
return _MAV_RETURN_char_array ( msg , param_id , 16 , 4 ) ;
2023-05-26 20:01:10 +08:00
}
/**
* @ brief Get field param_index from param_request_read message
*
2024-08-19 16:16:39 +08:00
* @ return Parameter index . Send - 1 to use the param ID field as identifier ( else the param id will be ignored )
2023-05-26 20:01:10 +08:00
*/
static inline int16_t mavlink_msg_param_request_read_get_param_index ( const mavlink_message_t * msg )
{
2024-08-19 16:16:39 +08:00
return _MAV_RETURN_int16_t ( msg , 0 ) ;
2023-05-26 20:01:10 +08:00
}
/**
* @ brief Decode a param_request_read message into a struct
*
* @ param msg The message to decode
* @ param param_request_read C - struct to decode the message contents into
*/
static inline void mavlink_msg_param_request_read_decode ( const mavlink_message_t * msg , mavlink_param_request_read_t * param_request_read )
{
2024-08-19 16:16:39 +08:00
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
param_request_read - > param_index = mavlink_msg_param_request_read_get_param_index ( msg ) ;
param_request_read - > target_system = mavlink_msg_param_request_read_get_target_system ( msg ) ;
param_request_read - > target_component = mavlink_msg_param_request_read_get_target_component ( msg ) ;
mavlink_msg_param_request_read_get_param_id ( msg , param_request_read - > param_id ) ;
2023-05-26 20:01:10 +08:00
# else
2024-08-19 16:16:39 +08:00
uint8_t len = msg - > len < MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ? msg - > len : MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ;
memset ( param_request_read , 0 , MAVLINK_MSG_ID_PARAM_REQUEST_READ_LEN ) ;
memcpy ( param_request_read , _MAV_PAYLOAD ( msg ) , len ) ;
2023-05-26 20:01:10 +08:00
# endif
}