2012-08-27 15:44:50 -03:00
|
|
|
|
|
|
|
#ifndef __AP_HAL_RC_INPUT_H__
|
|
|
|
#define __AP_HAL_RC_INPUT_H__
|
|
|
|
|
|
|
|
#include "AP_HAL_Namespace.h"
|
|
|
|
|
2012-08-27 20:45:10 -03:00
|
|
|
#define RC_INPUT_MIN_PULSEWIDTH 900
|
|
|
|
#define RC_INPUT_MAX_PULSEWIDTH 2100
|
|
|
|
|
2012-08-27 15:44:50 -03:00
|
|
|
class AP_HAL::RCInput {
|
|
|
|
public:
|
2012-08-27 20:45:10 -03:00
|
|
|
/**
|
|
|
|
* Call init from the platform hal instance init, so that both the type of
|
|
|
|
* the RCInput implementation and init argument (e.g. ISRRegistry) are
|
|
|
|
* known to the programmer. (Its too difficult to describe this dependency
|
|
|
|
* in the C++ type system.)
|
|
|
|
*/
|
2015-12-02 11:37:22 -04:00
|
|
|
virtual void init() = 0;
|
2015-06-29 10:19:42 -03:00
|
|
|
virtual void deinit() {};
|
2012-08-27 20:45:10 -03:00
|
|
|
|
|
|
|
/**
|
2015-02-08 18:55:35 -04:00
|
|
|
* Return true if there has been new input since the last read()
|
|
|
|
* call. This call also clears the new_input flag, so once it
|
|
|
|
* returns true it won't return true again until another frame is
|
|
|
|
* received.
|
2012-08-27 20:45:10 -03:00
|
|
|
*/
|
2015-02-08 18:55:35 -04:00
|
|
|
virtual bool new_input() = 0;
|
2014-03-25 00:39:41 -03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the number of valid channels in the last read
|
|
|
|
*/
|
|
|
|
virtual uint8_t num_channels() = 0;
|
2012-08-27 20:45:10 -03:00
|
|
|
|
|
|
|
/* Read a single channel at a time */
|
|
|
|
virtual uint16_t read(uint8_t ch) = 0;
|
|
|
|
|
|
|
|
/* Read an array of channels, return the valid count */
|
|
|
|
virtual uint8_t read(uint16_t* periods, uint8_t len) = 0;
|
2012-12-06 16:45:44 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Overrides: these are really grody and don't belong here but we need
|
|
|
|
* them at the moment to make the port work.
|
|
|
|
* case v of:
|
|
|
|
* v == -1 -> no change to this channel
|
|
|
|
* v == 0 -> do not override this channel
|
|
|
|
* v > 0 -> set v as override.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* set_overrides: array starts at ch 0, for len channels */
|
|
|
|
virtual bool set_overrides(int16_t *overrides, uint8_t len) = 0;
|
|
|
|
/* set_override: set just a specific channel */
|
|
|
|
virtual bool set_override(uint8_t channel, int16_t override) = 0;
|
|
|
|
/* clear_overrides: equivelant to setting all overrides to 0 */
|
|
|
|
virtual void clear_overrides() = 0;
|
|
|
|
|
2015-06-10 03:44:57 -03:00
|
|
|
/* execute receiver bind */
|
|
|
|
virtual bool rc_bind(int dsmMode) { return false; };
|
2012-08-27 15:44:50 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __AP_HAL_RC_INPUT_H__
|
|
|
|
|