mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 17:38:32 -04:00
efbc7648b1
For certain basic functionality, there aren't much benefit to be able to vary the implementation easily at runtime. So instead of using virtual functions, use regular functions that are "resolved" at link time. The implementation of such functions is provided per board/platform. Examples of functions that fit this include: getting the current time (since boot), panic'ing, getting system information, rebooting. These functions are less likely to benefit from the indirection provided by virtual interfaces. For more complex hardware access APIs the indirection makes more sense and ease the testing (when we have it!). The idea is that instead of calling hal.scheduler->panic("on the streets of london"); now use AP_HAL::panic("on the streets of london"); A less important side-effect is that call-site code gets smaller. Currently the compiler needs to get the hal, get the scheduler pointer, get the right function pointer in the vtable for that scheduler. And the call must include an extra parameter ("this"). Now it will be just a function call, with the address resolved at link time. This patch introduces the first functions that will be in the namespace, further patches will implementations for each board and then switch the call-sites. The extra init() function allow any initial setup needed for the functions to work.
96 lines
2.4 KiB
C++
96 lines
2.4 KiB
C++
|
|
#ifndef __AP_HAL_HAL_H__
|
|
#define __AP_HAL_HAL_H__
|
|
|
|
#include "AP_HAL_Namespace.h"
|
|
|
|
#include "AnalogIn.h"
|
|
#include "GPIO.h"
|
|
#include "RCInput.h"
|
|
#include "RCOutput.h"
|
|
#include "SPIDriver.h"
|
|
#include "Storage.h"
|
|
#include "UARTDriver.h"
|
|
#include "system.h"
|
|
|
|
class AP_HAL::HAL {
|
|
public:
|
|
HAL(AP_HAL::UARTDriver* _uartA, // console
|
|
AP_HAL::UARTDriver* _uartB, // 1st GPS
|
|
AP_HAL::UARTDriver* _uartC, // telem1
|
|
AP_HAL::UARTDriver* _uartD, // telem2
|
|
AP_HAL::UARTDriver* _uartE, // 2nd GPS
|
|
AP_HAL::I2CDriver* _i2c0,
|
|
AP_HAL::I2CDriver* _i2c1,
|
|
AP_HAL::I2CDriver* _i2c2,
|
|
AP_HAL::SPIDeviceManager* _spi,
|
|
AP_HAL::AnalogIn* _analogin,
|
|
AP_HAL::Storage* _storage,
|
|
AP_HAL::UARTDriver* _console,
|
|
AP_HAL::GPIO* _gpio,
|
|
AP_HAL::RCInput* _rcin,
|
|
AP_HAL::RCOutput* _rcout,
|
|
AP_HAL::Scheduler* _scheduler,
|
|
AP_HAL::Util* _util)
|
|
:
|
|
uartA(_uartA),
|
|
uartB(_uartB),
|
|
uartC(_uartC),
|
|
uartD(_uartD),
|
|
uartE(_uartE),
|
|
i2c(_i2c0),
|
|
i2c1(_i2c1),
|
|
i2c2(_i2c2),
|
|
spi(_spi),
|
|
analogin(_analogin),
|
|
storage(_storage),
|
|
console(_console),
|
|
gpio(_gpio),
|
|
rcin(_rcin),
|
|
rcout(_rcout),
|
|
scheduler(_scheduler),
|
|
util(_util)
|
|
{
|
|
AP_HAL::init();
|
|
}
|
|
|
|
struct Callbacks {
|
|
virtual void setup() = 0;
|
|
virtual void loop() = 0;
|
|
};
|
|
|
|
struct FunCallbacks : public Callbacks {
|
|
FunCallbacks(void (*setup_fun)(void), void (*loop_fun)(void));
|
|
|
|
void setup() override { _setup(); }
|
|
void loop() override { _loop(); }
|
|
|
|
private:
|
|
void (*_setup)(void);
|
|
void (*_loop)(void);
|
|
};
|
|
|
|
virtual void run(int argc, char * const argv[], Callbacks* callbacks) const = 0;
|
|
|
|
AP_HAL::UARTDriver* uartA;
|
|
AP_HAL::UARTDriver* uartB;
|
|
AP_HAL::UARTDriver* uartC;
|
|
AP_HAL::UARTDriver* uartD;
|
|
AP_HAL::UARTDriver* uartE;
|
|
AP_HAL::I2CDriver* i2c;
|
|
AP_HAL::I2CDriver* i2c1;
|
|
AP_HAL::I2CDriver* i2c2;
|
|
AP_HAL::SPIDeviceManager* spi;
|
|
AP_HAL::AnalogIn* analogin;
|
|
AP_HAL::Storage* storage;
|
|
AP_HAL::UARTDriver* console;
|
|
AP_HAL::GPIO* gpio;
|
|
AP_HAL::RCInput* rcin;
|
|
AP_HAL::RCOutput* rcout;
|
|
AP_HAL::Scheduler* scheduler;
|
|
AP_HAL::Util* util;
|
|
};
|
|
|
|
#endif // __AP_HAL_HAL_H__
|
|
|