mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
18a64d17d3
this fixes a bug caused by GPIO_INPUT and GPIO_OUTPUT already being defined in NuttX, which caused pinMode() not to setup pins for output when requested
46 lines
1.2 KiB
C++
46 lines
1.2 KiB
C++
|
|
#ifndef __AP_HAL_GPIO_H__
|
|
#define __AP_HAL_GPIO_H__
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "AP_HAL_Namespace.h"
|
|
|
|
#define HAL_GPIO_INPUT 0
|
|
#define HAL_GPIO_OUTPUT 1
|
|
#define HAL_GPIO_INTERRUPT_LOW 0
|
|
#define HAL_GPIO_INTERRUPT_HIGH 1
|
|
#define HAL_GPIO_INTERRUPT_FALLING 2
|
|
#define HAL_GPIO_INTERRUPT_RISING 3
|
|
|
|
class AP_HAL::DigitalSource {
|
|
public:
|
|
virtual void mode(uint8_t output) = 0;
|
|
virtual uint8_t read() = 0;
|
|
virtual void write(uint8_t value) = 0;
|
|
virtual void toggle() = 0;
|
|
};
|
|
|
|
class AP_HAL::GPIO {
|
|
public:
|
|
GPIO() {}
|
|
virtual void init() = 0;
|
|
virtual void pinMode(uint8_t pin, uint8_t output) = 0;
|
|
virtual uint8_t read(uint8_t pin) = 0;
|
|
virtual void write(uint8_t pin, uint8_t value) = 0;
|
|
virtual void toggle(uint8_t pin) = 0;
|
|
virtual int8_t analogPinToDigitalPin(uint8_t pin) = 0;
|
|
|
|
/* Alternative interface: */
|
|
virtual AP_HAL::DigitalSource* channel(uint16_t n) = 0;
|
|
|
|
/* Interrupt interface: */
|
|
virtual bool attach_interrupt(uint8_t interrupt_num, AP_HAL::Proc p,
|
|
uint8_t mode) = 0;
|
|
|
|
/* return true if USB cable is connected */
|
|
virtual bool usb_connected(void) = 0;
|
|
};
|
|
|
|
#endif // __AP_HAL_GPIO_H__
|