Subversion Repositories Projects

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1702 - 1
// MESSAGE AUTH_KEY PACKING
2
 
3
#define MAVLINK_MSG_ID_AUTH_KEY 7
4
 
5
typedef struct __mavlink_auth_key_t
6
{
7
 char key[32]; ///< key
8
} mavlink_auth_key_t;
9
 
10
#define MAVLINK_MSG_ID_AUTH_KEY_LEN 32
11
#define MAVLINK_MSG_ID_7_LEN 32
12
 
13
#define MAVLINK_MSG_AUTH_KEY_FIELD_KEY_LEN 32
14
 
15
#define MAVLINK_MESSAGE_INFO_AUTH_KEY { \
16
        "AUTH_KEY", \
17
        1, \
18
        {  { "key", NULL, MAVLINK_TYPE_CHAR, 32, 0, offsetof(mavlink_auth_key_t, key) }, \
19
         } \
20
}
21
 
22
 
23
/**
24
 * @brief Pack a auth_key message
25
 * @param system_id ID of this system
26
 * @param component_id ID of this component (e.g. 200 for IMU)
27
 * @param msg The MAVLink message to compress the data into
28
 *
29
 * @param key key
30
 * @return length of the message in bytes (excluding serial stream start sign)
31
 */
32
static inline uint16_t mavlink_msg_auth_key_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
33
                                                       const char *key)
34
{
35
#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
36
        char buf[32];
37
 
38
        _mav_put_char_array(buf, 0, key, 32);
39
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, 32);
40
#else
41
        mavlink_auth_key_t packet;
42
 
43
        mav_array_memcpy(packet.key, key, sizeof(char)*32);
44
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, 32);
45
#endif
46
 
47
        msg->msgid = MAVLINK_MSG_ID_AUTH_KEY;
48
        return mavlink_finalize_message(msg, system_id, component_id, 32);
49
}
50
 
51
/**
52
 * @brief Pack a auth_key message on a channel
53
 * @param system_id ID of this system
54
 * @param component_id ID of this component (e.g. 200 for IMU)
55
 * @param chan The MAVLink channel this message was sent over
56
 * @param msg The MAVLink message to compress the data into
57
 * @param key key
58
 * @return length of the message in bytes (excluding serial stream start sign)
59
 */
60
static inline uint16_t mavlink_msg_auth_key_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
61
                                                           mavlink_message_t* msg,
62
                                                           const char *key)
63
{
64
#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
65
        char buf[32];
66
 
67
        _mav_put_char_array(buf, 0, key, 32);
68
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, 32);
69
#else
70
        mavlink_auth_key_t packet;
71
 
72
        mav_array_memcpy(packet.key, key, sizeof(char)*32);
73
        memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, 32);
74
#endif
75
 
76
        msg->msgid = MAVLINK_MSG_ID_AUTH_KEY;
77
        return mavlink_finalize_message_chan(msg, system_id, component_id, chan, 32);
78
}
79
 
80
/**
81
 * @brief Encode a auth_key struct into a message
82
 *
83
 * @param system_id ID of this system
84
 * @param component_id ID of this component (e.g. 200 for IMU)
85
 * @param msg The MAVLink message to compress the data into
86
 * @param auth_key C-struct to read the message contents from
87
 */
88
static inline uint16_t mavlink_msg_auth_key_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_auth_key_t* auth_key)
89
{
90
        return mavlink_msg_auth_key_pack(system_id, component_id, msg, auth_key->key);
91
}
92
 
93
/**
94
 * @brief Send a auth_key message
95
 * @param chan MAVLink channel to send the message
96
 *
97
 * @param key key
98
 */
99
#ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
100
 
101
static inline void mavlink_msg_auth_key_send(mavlink_channel_t chan, const char *key)
102
{
103
#if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
104
        char buf[32];
105
 
106
        _mav_put_char_array(buf, 0, key, 32);
107
        _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AUTH_KEY, buf, 32);
108
#else
109
        mavlink_auth_key_t packet;
110
 
111
        mav_array_memcpy(packet.key, key, sizeof(char)*32);
112
        _mav_finalize_message_chan_send(chan, MAVLINK_MSG_ID_AUTH_KEY, (const char *)&packet, 32);
113
#endif
114
}
115
 
116
#endif
117
 
118
// MESSAGE AUTH_KEY UNPACKING
119
 
120
 
121
/**
122
 * @brief Get field key from auth_key message
123
 *
124
 * @return key
125
 */
126
static inline uint16_t mavlink_msg_auth_key_get_key(const mavlink_message_t* msg, char *key)
127
{
128
        return _MAV_RETURN_char_array(msg, key, 32,  0);
129
}
130
 
131
/**
132
 * @brief Decode a auth_key message into a struct
133
 *
134
 * @param msg The message to decode
135
 * @param auth_key C-struct to decode the message contents into
136
 */
137
static inline void mavlink_msg_auth_key_decode(const mavlink_message_t* msg, mavlink_auth_key_t* auth_key)
138
{
139
#if MAVLINK_NEED_BYTE_SWAP
140
        mavlink_msg_auth_key_get_key(msg, auth_key->key);
141
#else
142
        memcpy(auth_key, _MAV_PAYLOAD(msg), 32);
143
#endif
144
}