#include <AP_HAL/utility/sparse-endian.h> #include <AP_InternalError/AP_InternalError.h> #include "msp.h" #include "msp_sbuf.h" #include <string.h> #if HAL_MSP_ENABLED uint8_t* MSP::sbuf_ptr(sbuf_t *buf) { return buf->ptr; } uint16_t MSP::sbuf_bytes_remaining(const sbuf_t *buf) { return buf->end - buf->ptr; } bool MSP::sbuf_check_bounds(const sbuf_t *buf, const uint8_t len) { if (sbuf_bytes_remaining(buf) < len) { INTERNAL_ERROR(AP_InternalError::error_t::flow_of_control); return false; } return true; } void MSP::sbuf_switch_to_reader(sbuf_t *buf, uint8_t *base) { buf->end = buf->ptr; buf->ptr = base; } void MSP::sbuf_write_u8(sbuf_t *dst, uint8_t val) { if (!sbuf_check_bounds(dst, 1)) { return; } *dst->ptr++ = val; } void MSP::sbuf_write_u16(sbuf_t *dst, uint16_t val) { if (!sbuf_check_bounds(dst, 2)) { return; } put_le16_ptr(dst->ptr, val); dst->ptr += 2; } void MSP::sbuf_write_u32(sbuf_t *dst, uint32_t val) { if (!sbuf_check_bounds(dst, 4)) { return; } put_le32_ptr(dst->ptr, val); dst->ptr += 4; } void MSP::sbuf_write_data(sbuf_t *dst, const void *data, int len) { if (!sbuf_check_bounds(dst, len)) { return; } memcpy(dst->ptr, data, len); dst->ptr += len; } #endif //HAL_MSP_ENABLED