mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 22:48:29 -04:00
dcbbc86f34
fixes #12273
132 lines
3.3 KiB
C
132 lines
3.3 KiB
C
/*
|
|
structures for telemetry packets
|
|
This header is common to ArduPilot AP_Radio and STM8 TX code
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
enum telem_type {
|
|
TELEM_STATUS= 0, // a telem_status packet
|
|
TELEM_PLAY = 1, // play a tune
|
|
TELEM_FW = 2, // update new firmware
|
|
};
|
|
|
|
// flags in telem_status structure
|
|
#define TELEM_FLAG_GPS_OK (1U<<0)
|
|
#define TELEM_FLAG_ARM_OK (1U<<1)
|
|
#define TELEM_FLAG_BATT_OK (1U<<2)
|
|
#define TELEM_FLAG_ARMED (1U<<4)
|
|
#define TELEM_FLAG_POS_OK (1U<<5)
|
|
#define TELEM_FLAG_VIDEO (1U<<6)
|
|
#define TELEM_FLAG_HYBRID (1U<<7)
|
|
|
|
struct PACKED telem_status {
|
|
uint8_t pps; // packets per second received
|
|
uint8_t rssi; // lowpass rssi
|
|
uint8_t flags; // TELEM_FLAG_*
|
|
uint8_t flight_mode; // flight mode (with profile number in high bit)
|
|
uint8_t wifi_chan; // wifi channel number on Sonix
|
|
uint8_t tx_max; // max TX power
|
|
uint8_t note_adjust; // buzzer tone adjustment
|
|
};
|
|
|
|
// write to new firmware. This is also used to play a tune
|
|
struct PACKED telem_firmware {
|
|
uint8_t seq;
|
|
uint8_t len;
|
|
uint16_t offset;
|
|
uint8_t data[4];
|
|
};
|
|
|
|
/*
|
|
telemetry packet from RX to TX for cypress
|
|
*/
|
|
struct PACKED telem_packet_cypress {
|
|
uint8_t crc; // simple CRC
|
|
enum telem_type type;
|
|
union {
|
|
uint8_t pkt[14];
|
|
struct telem_status status;
|
|
struct telem_firmware fw;
|
|
} payload;
|
|
};
|
|
|
|
/*
|
|
cc2500 specific protocol structures
|
|
*/
|
|
struct PACKED telem_status_cc2500 {
|
|
uint8_t pps; // packets per second received
|
|
uint8_t rssi; // lowpass rssi
|
|
uint8_t flags; // TELEM_FLAG_*
|
|
uint8_t flight_mode; // flight mode (with profile number in high bit)
|
|
uint8_t wifi_chan; // wifi channel number on Sonix
|
|
uint8_t tx_max; // max TX power
|
|
uint8_t note_adjust; // buzzer tone adjustment
|
|
uint8_t rxid[2]; // 16 bit ID for cc2500 to prevent double binds
|
|
};
|
|
|
|
/*
|
|
telemetry packet from RX to TX for cc2500
|
|
*/
|
|
struct PACKED telem_packet_cc2500 {
|
|
uint8_t length;
|
|
uint8_t type;
|
|
uint8_t txid[2];
|
|
union {
|
|
uint8_t pkt[9];
|
|
struct telem_status_cc2500 status;
|
|
struct telem_firmware fw;
|
|
} payload;
|
|
};
|
|
|
|
/*
|
|
autobind packet from TX to RX for cc2500
|
|
*/
|
|
struct PACKED autobind_packet_cc2500 {
|
|
uint8_t length;
|
|
uint8_t magic1; // 0xC5
|
|
uint8_t magic2; // 0xA2
|
|
uint8_t txid[2];
|
|
uint8_t txid_inverse[2];
|
|
uint8_t wifi_chan;
|
|
uint8_t pad[3]; // pad to 13 bytes for fixed packet length
|
|
uint8_t crc[2];
|
|
};
|
|
|
|
/*
|
|
packet type - controls data field. We have 4 bits, giving 16 possible
|
|
data field types
|
|
*/
|
|
enum packet_type {
|
|
PKTYPE_VOLTAGE = 0,
|
|
PKTYPE_YEAR = 1,
|
|
PKTYPE_MONTH = 2,
|
|
PKTYPE_DAY = 3,
|
|
PKTYPE_TELEM_RSSI = 4,
|
|
PKTYPE_TELEM_PPS = 5,
|
|
PKTYPE_BL_VERSION = 6,
|
|
PKTYPE_FW_ACK = 7,
|
|
PKTYPE_RXID1 = 8,
|
|
PKTYPE_RXID2 = 9,
|
|
PKTYPE_NUM_TYPES = 10 // used for modulus
|
|
};
|
|
|
|
/*
|
|
skyrocket specific packet from TX to RX for cc2500
|
|
*/
|
|
struct PACKED srt_packet {
|
|
uint8_t length; // required for cc2500 FIFO
|
|
uint8_t txid[2];
|
|
uint8_t version:4; // protocol version
|
|
uint8_t pkt_type:4; // packet type
|
|
uint8_t chan1;
|
|
uint8_t chan2;
|
|
uint8_t chan3;
|
|
uint8_t chan4;
|
|
uint8_t chan_high;
|
|
uint8_t data; // data according to pkt_type
|
|
uint8_t buttons; // see channels.h
|
|
uint8_t channr;
|
|
uint8_t chanskip;
|
|
};
|