mavlink_msg_aux_status.h 9.31 KB
Newer Older
James Goppert's avatar
James Goppert committed
1 2 3
// MESSAGE AUX_STATUS PACKING

#define MAVLINK_MSG_ID_AUX_STATUS 142
lm's avatar
lm committed
4 5
#define MAVLINK_MSG_ID_AUX_STATUS_LEN 12
#define MAVLINK_MSG_142_LEN 12
lm's avatar
lm committed
6 7
#define MAVLINK_MSG_ID_AUX_STATUS_KEY 0x7A
#define MAVLINK_MSG_142_KEY 0x7A
James Goppert's avatar
James Goppert committed
8 9 10

typedef struct __mavlink_aux_status_t 
{
lm's avatar
lm committed
11 12 13 14 15 16
	uint16_t load;	///< Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
	uint16_t i2c0_err_count;	///< Number of I2C errors since startup
	uint16_t i2c1_err_count;	///< Number of I2C errors since startup
	uint16_t spi0_err_count;	///< Number of I2C errors since startup
	uint16_t spi1_err_count;	///< Number of I2C errors since startup
	uint16_t uart_total_err_count;	///< Number of I2C errors since startup
James Goppert's avatar
James Goppert committed
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35

} mavlink_aux_status_t;

/**
 * @brief Pack a aux_status 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
 *
 * @param load Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
 * @param i2c0_err_count Number of I2C errors since startup
 * @param i2c1_err_count Number of I2C errors since startup
 * @param spi0_err_count Number of I2C errors since startup
 * @param spi1_err_count Number of I2C errors since startup
 * @param uart_total_err_count Number of I2C errors since startup
 * @return length of the message in bytes (excluding serial stream start sign)
 */
static inline uint16_t mavlink_msg_aux_status_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, uint16_t load, uint16_t i2c0_err_count, uint16_t i2c1_err_count, uint16_t spi0_err_count, uint16_t spi1_err_count, uint16_t uart_total_err_count)
{
lm's avatar
lm committed
36
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
James Goppert's avatar
James Goppert committed
37 38
	msg->msgid = MAVLINK_MSG_ID_AUX_STATUS;

lm's avatar
lm committed
39 40 41 42 43 44
	p->load = load;	// uint16_t:Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
	p->i2c0_err_count = i2c0_err_count;	// uint16_t:Number of I2C errors since startup
	p->i2c1_err_count = i2c1_err_count;	// uint16_t:Number of I2C errors since startup
	p->spi0_err_count = spi0_err_count;	// uint16_t:Number of I2C errors since startup
	p->spi1_err_count = spi1_err_count;	// uint16_t:Number of I2C errors since startup
	p->uart_total_err_count = uart_total_err_count;	// uint16_t:Number of I2C errors since startup
James Goppert's avatar
James Goppert committed
45

lm's avatar
lm committed
46
	return mavlink_finalize_message(msg, system_id, component_id, MAVLINK_MSG_ID_AUX_STATUS_LEN);
James Goppert's avatar
James Goppert committed
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
}

/**
 * @brief Pack a aux_status message
 * @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 was sent over
 * @param msg The MAVLink message to compress the data into
 * @param load Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
 * @param i2c0_err_count Number of I2C errors since startup
 * @param i2c1_err_count Number of I2C errors since startup
 * @param spi0_err_count Number of I2C errors since startup
 * @param spi1_err_count Number of I2C errors since startup
 * @param uart_total_err_count Number of I2C errors since startup
 * @return length of the message in bytes (excluding serial stream start sign)
 */
static inline uint16_t mavlink_msg_aux_status_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan, mavlink_message_t* msg, uint16_t load, uint16_t i2c0_err_count, uint16_t i2c1_err_count, uint16_t spi0_err_count, uint16_t spi1_err_count, uint16_t uart_total_err_count)
{
lm's avatar
lm committed
65
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
James Goppert's avatar
James Goppert committed
66 67
	msg->msgid = MAVLINK_MSG_ID_AUX_STATUS;

lm's avatar
lm committed
68 69 70 71 72 73
	p->load = load;	// uint16_t:Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
	p->i2c0_err_count = i2c0_err_count;	// uint16_t:Number of I2C errors since startup
	p->i2c1_err_count = i2c1_err_count;	// uint16_t:Number of I2C errors since startup
	p->spi0_err_count = spi0_err_count;	// uint16_t:Number of I2C errors since startup
	p->spi1_err_count = spi1_err_count;	// uint16_t:Number of I2C errors since startup
	p->uart_total_err_count = uart_total_err_count;	// uint16_t:Number of I2C errors since startup
James Goppert's avatar
James Goppert committed
74

lm's avatar
lm committed
75
	return mavlink_finalize_message_chan(msg, system_id, component_id, chan, MAVLINK_MSG_ID_AUX_STATUS_LEN);
James Goppert's avatar
James Goppert committed
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
}

/**
 * @brief Encode a aux_status struct into a 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
 * @param aux_status C-struct to read the message contents from
 */
static inline uint16_t mavlink_msg_aux_status_encode(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg, const mavlink_aux_status_t* aux_status)
{
	return mavlink_msg_aux_status_pack(system_id, component_id, msg, aux_status->load, aux_status->i2c0_err_count, aux_status->i2c1_err_count, aux_status->spi0_err_count, aux_status->spi1_err_count, aux_status->uart_total_err_count);
}

lm's avatar
lm committed
91 92

#ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
James Goppert's avatar
James Goppert committed
93 94 95 96 97 98 99 100 101 102 103
/**
 * @brief Send a aux_status message
 * @param chan MAVLink channel to send the message
 *
 * @param load Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
 * @param i2c0_err_count Number of I2C errors since startup
 * @param i2c1_err_count Number of I2C errors since startup
 * @param spi0_err_count Number of I2C errors since startup
 * @param spi1_err_count Number of I2C errors since startup
 * @param uart_total_err_count Number of I2C errors since startup
 */
lm's avatar
lm committed
104 105 106 107 108
static inline void mavlink_msg_aux_status_send(mavlink_channel_t chan, uint16_t load, uint16_t i2c0_err_count, uint16_t i2c1_err_count, uint16_t spi0_err_count, uint16_t spi1_err_count, uint16_t uart_total_err_count)
{
	mavlink_header_t hdr;
	mavlink_aux_status_t payload;

lm's avatar
lm committed
109 110 111 112 113 114 115
	MAVLINK_BUFFER_CHECK_START( chan, MAVLINK_MSG_ID_AUX_STATUS_LEN )
	payload.load = load;	// uint16_t:Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
	payload.i2c0_err_count = i2c0_err_count;	// uint16_t:Number of I2C errors since startup
	payload.i2c1_err_count = i2c1_err_count;	// uint16_t:Number of I2C errors since startup
	payload.spi0_err_count = spi0_err_count;	// uint16_t:Number of I2C errors since startup
	payload.spi1_err_count = spi1_err_count;	// uint16_t:Number of I2C errors since startup
	payload.uart_total_err_count = uart_total_err_count;	// uint16_t:Number of I2C errors since startup
lm's avatar
lm committed
116 117 118 119 120 121 122 123 124 125

	hdr.STX = MAVLINK_STX;
	hdr.len = MAVLINK_MSG_ID_AUX_STATUS_LEN;
	hdr.msgid = MAVLINK_MSG_ID_AUX_STATUS;
	hdr.sysid = mavlink_system.sysid;
	hdr.compid = mavlink_system.compid;
	hdr.seq = mavlink_get_channel_status(chan)->current_tx_seq;
	mavlink_get_channel_status(chan)->current_tx_seq = hdr.seq + 1;
	mavlink_send_mem(chan, (uint8_t *)&hdr.STX, MAVLINK_NUM_HEADER_BYTES );

lm's avatar
lm committed
126 127 128 129 130 131
	crc_init(&hdr.ck);
	crc_calculate_mem((uint8_t *)&hdr.len, &hdr.ck, MAVLINK_CORE_HEADER_LEN);
	crc_calculate_mem((uint8_t *)&payload, &hdr.ck, hdr.len );
	crc_accumulate( 0x7A, &hdr.ck); /// include key in X25 checksum
	mavlink_send_mem(chan, (uint8_t *)&hdr.ck, MAVLINK_NUM_CHECKSUM_BYTES);
	MAVLINK_BUFFER_CHECK_END
James Goppert's avatar
James Goppert committed
132 133 134 135 136 137 138 139 140 141 142 143
}

#endif
// MESSAGE AUX_STATUS UNPACKING

/**
 * @brief Get field load from aux_status message
 *
 * @return Maximum usage in percent of the mainloop time, (0%: 0, 100%: 1000) should be always below 1000
 */
static inline uint16_t mavlink_msg_aux_status_get_load(const mavlink_message_t* msg)
{
lm's avatar
lm committed
144 145
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
	return (uint16_t)(p->load);
James Goppert's avatar
James Goppert committed
146 147 148 149 150 151 152 153 154
}

/**
 * @brief Get field i2c0_err_count from aux_status message
 *
 * @return Number of I2C errors since startup
 */
static inline uint16_t mavlink_msg_aux_status_get_i2c0_err_count(const mavlink_message_t* msg)
{
lm's avatar
lm committed
155 156
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
	return (uint16_t)(p->i2c0_err_count);
James Goppert's avatar
James Goppert committed
157 158 159 160 161 162 163 164 165
}

/**
 * @brief Get field i2c1_err_count from aux_status message
 *
 * @return Number of I2C errors since startup
 */
static inline uint16_t mavlink_msg_aux_status_get_i2c1_err_count(const mavlink_message_t* msg)
{
lm's avatar
lm committed
166 167
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
	return (uint16_t)(p->i2c1_err_count);
James Goppert's avatar
James Goppert committed
168 169 170 171 172 173 174 175 176
}

/**
 * @brief Get field spi0_err_count from aux_status message
 *
 * @return Number of I2C errors since startup
 */
static inline uint16_t mavlink_msg_aux_status_get_spi0_err_count(const mavlink_message_t* msg)
{
lm's avatar
lm committed
177 178
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
	return (uint16_t)(p->spi0_err_count);
James Goppert's avatar
James Goppert committed
179 180 181 182 183 184 185 186 187
}

/**
 * @brief Get field spi1_err_count from aux_status message
 *
 * @return Number of I2C errors since startup
 */
static inline uint16_t mavlink_msg_aux_status_get_spi1_err_count(const mavlink_message_t* msg)
{
lm's avatar
lm committed
188 189
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
	return (uint16_t)(p->spi1_err_count);
James Goppert's avatar
James Goppert committed
190 191 192 193 194 195 196 197 198
}

/**
 * @brief Get field uart_total_err_count from aux_status message
 *
 * @return Number of I2C errors since startup
 */
static inline uint16_t mavlink_msg_aux_status_get_uart_total_err_count(const mavlink_message_t* msg)
{
lm's avatar
lm committed
199 200
	mavlink_aux_status_t *p = (mavlink_aux_status_t *)&msg->payload[0];
	return (uint16_t)(p->uart_total_err_count);
James Goppert's avatar
James Goppert committed
201 202 203 204 205 206 207 208 209 210
}

/**
 * @brief Decode a aux_status message into a struct
 *
 * @param msg The message to decode
 * @param aux_status C-struct to decode the message contents into
 */
static inline void mavlink_msg_aux_status_decode(const mavlink_message_t* msg, mavlink_aux_status_t* aux_status)
{
lm's avatar
lm committed
211
	memcpy( aux_status, msg->payload, sizeof(mavlink_aux_status_t));
James Goppert's avatar
James Goppert committed
212
}