#include "GPIO.h" using namespace HALSITL; extern const AP_HAL::HAL& hal; #define SITL_WOW_ALTITUDE 0.01 void GPIO::init() {} void GPIO::pinMode(uint8_t pin, uint8_t output) {} uint8_t GPIO::read(uint8_t pin) { if (!_sitlState->_sitl) { return 0; } // weight on wheels pin support if (pin == _sitlState->_sitl->wow_pin.get()) { return _sitlState->_sitl->state.altitude < SITL_WOW_ALTITUDE ? 1 : 0; } uint16_t mask = static_cast(_sitlState->_sitl->pin_mask.get()); return static_cast((mask & (1U << pin)) ? 1 : 0); } void GPIO::write(uint8_t pin, uint8_t value) { if (!_sitlState->_sitl) { return; } uint16_t mask = static_cast(_sitlState->_sitl->pin_mask.get()); uint16_t new_mask = mask; if (pin == _sitlState->_sitl->wow_pin.get()) { return; } if (value) { new_mask |= (1U << pin); } else { new_mask &= ~(1U << pin); } if (mask != new_mask) { _sitlState->_sitl->pin_mask.set_and_notify(new_mask); } } void GPIO::toggle(uint8_t pin) { write(pin, !read(pin)); } /* Alternative interface: */ AP_HAL::DigitalSource* GPIO::channel(uint16_t n) { if (n < 16) { // (ie. sizeof(pin_mask)*8) return new DigitalSource(static_cast(n)); } else { return nullptr; } } bool GPIO::usb_connected(void) { return false; } DigitalSource::DigitalSource(uint8_t pin) : _pin(pin) {} void DigitalSource::mode(uint8_t output) {} uint8_t DigitalSource::read() { return hal.gpio->read(_pin); } void DigitalSource::write(uint8_t value) { value = static_cast(value ? 1 : 0); return hal.gpio->write(_pin, value); } void DigitalSource::toggle() { return hal.gpio->write(_pin, !hal.gpio->read(_pin)); }