// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- /// @file GCS_MAVLink.h /// @brief One size fits all header for MAVLink integration. #pragma once #include #include #include // we have separate helpers disabled to make it possible // to select MAVLink 1.0 in the arduino GUI build #define MAVLINK_SEPARATE_HELPERS #define MAVLINK_SEND_UART_BYTES(chan, buf, len) comm_send_buffer(chan, buf, len) // define our own MAVLINK_MESSAGE_CRC() macro to allow it to be put // into progmem #define MAVLINK_MESSAGE_CRC(msgid) mavlink_get_message_crc(msgid) // allow four telemetry ports #define MAVLINK_COMM_NUM_BUFFERS 4 /* The MAVLink protocol code generator does its own alignment, so alignment cast warnings can be ignored */ #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wcast-align" #include "include/mavlink/v1.0/ardupilotmega/version.h" #define MAVLINK_MAX_PAYLOAD_LEN 255 #include "include/mavlink/v1.0/mavlink_types.h" /// MAVLink stream used for uartA extern AP_HAL::UARTDriver *mavlink_comm_port[MAVLINK_COMM_NUM_BUFFERS]; /// MAVLink system definition extern mavlink_system_t mavlink_system; /// Sanity check MAVLink channel /// /// @param chan Channel to send to static inline bool valid_channel(mavlink_channel_t chan) { #pragma clang diagnostic push #pragma clang diagnostic ignored "-Wtautological-constant-out-of-range-compare" if (chan >= MAVLINK_COMM_NUM_BUFFERS) { return false; } return true; #pragma clang diagnostic pop } /// Send a byte to the nominated MAVLink channel /// /// @param chan Channel to send to /// @param ch Byte to send /// static inline void comm_send_ch(mavlink_channel_t chan, uint8_t ch) { if (!valid_channel(chan)) { return; } mavlink_comm_port[chan]->write(ch); } void comm_send_buffer(mavlink_channel_t chan, const uint8_t *buf, uint8_t len); /// Read a byte from the nominated MAVLink channel /// /// @param chan Channel to receive on /// @returns Byte read /// uint8_t comm_receive_ch(mavlink_channel_t chan); /// Check for available data on the nominated MAVLink channel /// /// @param chan Channel to check /// @returns Number of bytes available uint16_t comm_get_available(mavlink_channel_t chan); /// Check for available transmit space on the nominated MAVLink channel /// /// @param chan Channel to check /// @returns Number of bytes available uint16_t comm_get_txspace(mavlink_channel_t chan); /* return true if the MAVLink parser is idle, so there is no partly parsed MAVLink message being processed */ bool comm_is_idle(mavlink_channel_t chan); #define MAVLINK_USE_CONVENIENCE_FUNCTIONS #include "include/mavlink/v1.0/ardupilotmega/mavlink.h" // return a MAVLink variable type given a AP_Param type uint8_t mav_var_type(enum ap_var_type t); // return CRC byte for a mavlink message ID uint8_t mavlink_get_message_crc(uint8_t msgid); #pragma GCC diagnostic pop