AP_HAL_Linux: remove AP_HAL_Linux_Namespace header

This centralized namespace header encourages centralizing things on
umbrella headers that are a pain to maintain. Force each part of
AP_HAL_Linux to include what is used.

While at it, do some whitespace cleanups and minor changes to adhere to
coding style.
This commit is contained in:
Lucas De Marchi 2016-07-29 16:14:02 -03:00
parent 5edb03d184
commit f36e8d9c05
47 changed files with 260 additions and 155 deletions

View File

@ -24,11 +24,14 @@
#include <AP_HAL_Linux/RCOutput_Bebop.h>
#include <AP_HAL_Linux/RCOutput_Disco.h>
extern const AP_HAL::HAL& hal;
#define BATTERY_CAPACITY (1200U) /* mAh */
#define BATTERY_VOLTAGE_COMPENSATION_LANDED (0.2f)
extern const AP_HAL::HAL &hal;
using namespace Linux;
/* polynomial compensation coefficients */
static const float bat_comp_polynomial_coeffs[5] = {
-1.2471059149657287e-16f,

View File

@ -1,56 +0,0 @@
#pragma once
namespace Linux {
class UARTDriver;
class SPIUARTDriver;
class RPIOUARTDriver;
class I2CDevice;
class I2CDeviceManager;
class SPIDeviceManager;
class SPIDeviceDriver;
class Storage;
class GPIO_BBB;
class GPIO_RPI;
class GPIO_Sysfs;
class Storage;
class DigitalSource;
class DigitalSource_Sysfs;
class PeriodicThread;
class PWM_Sysfs;
class PWM_Sysfs_Bebop;
class PWM_Sysfs_Base;
class RCInput;
class RCInput_PRU;
class RCInput_AioPRU;
class RCInput_RPI;
class RCInput_Raspilot;
class RCInput_Navio2;
class RCInput_ZYNQ;
class RCInput_UART;
class RCInput_UDP;
class RCInput_DSM;
class RCInput_SBUS;
class RCOutput_PRU;
class RCOutput_AioPRU;
class RCOutput_PCA9685;
class RCOutput_Raspilot;
class RCOutput_ZYNQ;
class RCOutput_Bebop;
class RCOutput_Sysfs;
class RCOutput_QFLIGHT;
class RCOutput_Disco;
class Semaphore;
class Scheduler;
class Util;
class UtilRPI;
class ToneAlarm;
class ToneAlarm_Raspilot;
class Thread;
class Heat;
class HeatPwm;
class CameraSensor;
class CameraSensor_Mt9v117;
class VideoIn;
class OpticalFlow_Onboard;
class Flow_PX4;
}

View File

@ -16,7 +16,9 @@
#include "AP_HAL_Linux.h"
class Linux::CameraSensor {
namespace Linux {
class CameraSensor {
public:
CameraSensor(const char *device_path) { _device_path = device_path; }
@ -26,3 +28,5 @@ public:
private:
const char *_device_path;
};
}

View File

@ -16,7 +16,9 @@
#include "AP_HAL_Linux.h"
class Linux::Flow_PX4 {
namespace Linux {
class Flow_PX4 {
public:
Flow_PX4(uint32_t width, uint32_t bytesperline,
uint32_t max_flow_pixel,
@ -35,3 +37,5 @@ private:
uint16_t _pixstep;
uint8_t _num_blocks;
};
}

View File

@ -2,7 +2,9 @@
#include "AP_HAL_Linux.h"
class Linux::DigitalSource : public AP_HAL::DigitalSource {
namespace Linux {
class DigitalSource : public AP_HAL::DigitalSource {
public:
DigitalSource(uint8_t v);
void mode(uint8_t output);
@ -14,6 +16,8 @@ private:
};
}
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_PXF || CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_ERLEBOARD || CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_BBBMINI
#include "GPIO_BBB.h"
#elif CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_NAVIO || \

View File

@ -103,7 +103,9 @@
#define BBB_P9_41 20
#define BBB_P9_42 7
class Linux::GPIO_BBB : public AP_HAL::GPIO {
namespace Linux {
class GPIO_BBB : public AP_HAL::GPIO {
private:
struct GPIO {
volatile uint32_t *base;
@ -131,3 +133,5 @@ public:
/* return true if USB cable is connected */
bool usb_connected(void);
};
}

View File

@ -41,7 +41,9 @@
#define RPI_GPIO_30 30 // Pin 5
#define RPI_GPIO_31 31 // Pin 6
class Linux::GPIO_RPI : public AP_HAL::GPIO {
namespace Linux {
class GPIO_RPI : public AP_HAL::GPIO {
public:
GPIO_RPI();
void init();
@ -65,3 +67,5 @@ public:
private:
volatile uint32_t *_gpio;
};
}

View File

@ -5,8 +5,10 @@
#include "GPIO.h"
class Linux::DigitalSource_Sysfs : public AP_HAL::DigitalSource {
friend class Linux::GPIO_Sysfs;
namespace Linux {
class DigitalSource_Sysfs : public AP_HAL::DigitalSource {
friend class GPIO_Sysfs;
public:
~DigitalSource_Sysfs();
uint8_t read();
@ -23,8 +25,8 @@ private:
/**
* Generic implementation of AP_HAL::GPIO for Linux based boards.
*/
class Linux::GPIO_Sysfs : public AP_HAL::GPIO {
friend class Linux::DigitalSource_Sysfs;
class GPIO_Sysfs : public AP_HAL::GPIO {
friend class DigitalSource_Sysfs;
public:
/* Fill this table with the real pin numbers. */
static const unsigned pin_table[];
@ -76,3 +78,5 @@ protected:
*/
static bool _export_pin(uint8_t vpin);
};
}

View File

@ -2,8 +2,6 @@
#include <AP_HAL/AP_HAL.h>
#include "AP_HAL_Linux_Namespace.h"
class HAL_Linux : public AP_HAL::HAL {
public:
HAL_Linux();

View File

@ -15,8 +15,12 @@
*/
#pragma once
class Linux::Heat {
namespace Linux {
class Heat {
public:
virtual void set_imu_temp(float current) { }
virtual void set_imu_target_temp(int8_t *target) { }
};
}

View File

@ -19,7 +19,9 @@
#include "PWM_Sysfs.h"
#include "Heat.h"
class Linux::HeatPwm : public Linux::Heat {
namespace Linux {
class HeatPwm : public Heat {
public:
HeatPwm(uint8_t pwm_num, float Kp, float Ki,
uint32_t period_ns);
@ -35,3 +37,5 @@ private:
float _sum_error;
int8_t *_target = nullptr;
};
}

View File

@ -22,9 +22,12 @@
#include "AP_HAL_Linux.h"
#include "CameraSensor.h"
#include "Flow_PX4.h"
#include "PWM_Sysfs.h"
#include "VideoIn.h"
class Linux::OpticalFlow_Onboard : public AP_HAL::OpticalFlow {
namespace Linux {
class OpticalFlow_Onboard : public AP_HAL::OpticalFlow {
public:
void init(AP_HAL::OpticalFlow::Gyro_Cb);
bool read(AP_HAL::OpticalFlow::Data_Frame& frame);
@ -59,3 +62,5 @@ private:
AP_HAL::OpticalFlow::Gyro_Cb _get_gyro;
Vector3f _last_gyro_rate;
};
}

View File

@ -5,7 +5,9 @@
#include "AP_HAL_Linux.h"
#include "Util.h"
class Linux::PWM_Sysfs_Base {
namespace Linux {
class PWM_Sysfs_Base {
public:
virtual ~PWM_Sysfs_Base();
@ -51,7 +53,7 @@ private:
char *_period_path = NULL;
};
class Linux::PWM_Sysfs : public Linux::PWM_Sysfs_Base {
class PWM_Sysfs : public PWM_Sysfs_Base {
public:
PWM_Sysfs(uint8_t chip, uint8_t channel);
@ -63,7 +65,7 @@ private:
char *_generate_period_path(uint8_t chip, uint8_t channel);
};
class Linux::PWM_Sysfs_Bebop : public Linux::PWM_Sysfs_Base {
class PWM_Sysfs_Bebop : public PWM_Sysfs_Base {
public:
PWM_Sysfs_Bebop(uint8_t channel);
@ -81,3 +83,5 @@ private:
return PWM_Sysfs::NORMAL;
}
};
}

View File

@ -4,7 +4,9 @@
#define LINUX_RC_INPUT_NUM_CHANNELS 16
class Linux::RCInput : public AP_HAL::RCInput {
namespace Linux {
class RCInput : public AP_HAL::RCInput {
public:
RCInput();
@ -31,8 +33,8 @@ public:
// add some SBUS input bytes, for RCInput over a serial port
void add_sbus_input(const uint8_t *bytes, size_t nbytes);
protected:
void _process_rc_pulse(uint16_t width_s0, uint16_t width_s1);
void _update_periods(uint16_t *periods, uint8_t len);
@ -40,7 +42,7 @@ public:
private:
volatile bool new_rc_input;
uint16_t _pwm_values[LINUX_RC_INPUT_NUM_CHANNELS];
uint16_t _pwm_values[LINUX_RC_INPUT_NUM_CHANNELS];
uint8_t _num_channels;
void _process_ppmsum_pulse(uint16_t width);
@ -83,5 +85,4 @@ public:
} sbus;
};
#include "RCInput_PRU.h"
#include "RCInput_ZYNQ.h"
}

View File

@ -18,16 +18,18 @@
#include "AP_HAL_Linux.h"
#define RCIN_PRUSS_RAM_BASE 0x4a303000
// we use 300 ring buffer entries to guarantee that a full 25 byte
// frame of 12 bits per byte
class Linux::RCInput_AioPRU : public Linux::RCInput
{
namespace Linux {
class RCInput_AioPRU : public RCInput {
public:
void init();
void _timer_tick(void);
private:
private:
static const uint32_t TICK_PER_US = 200;
static const uint32_t NUM_RING_ENTRIES = 300;
// shared ring buffer with the PRU which records pin transitions
@ -41,3 +43,5 @@ public:
};
volatile struct ring_buffer *ring_buffer;
};
}

View File

@ -16,12 +16,15 @@
#pragma once
#include <AP_HAL/AP_HAL.h>
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_QFLIGHT
#include "RCInput.h"
#include "RCInput_DSM.h"
class Linux::RCInput_DSM : public Linux::RCInput
namespace Linux {
class RCInput_DSM : public RCInput
{
public:
void init() override;
@ -32,5 +35,7 @@ private:
const char *device_path;
int32_t fd = -1;
};
#endif // CONFIG_HAL_BOARD_SUBTYPE
}
#endif // CONFIG_HAL_BOARD_SUBTYPE

View File

@ -2,8 +2,10 @@
#include "RCInput.h"
class Linux::RCInput_Navio2 : public Linux::RCInput
{
namespace Linux {
class RCInput_Navio2 : public RCInput {
public:
void init() override;
void _timer_tick(void) override;
@ -18,3 +20,5 @@ private:
int channels[CHANNEL_COUNT];
uint16_t periods[ARRAY_SIZE(channels)] = {0};
};
}

View File

@ -3,6 +3,7 @@
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_PXF || \
CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_ERLEBOARD || \
CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_BBBMINI
#include "RCInput_PRU.h"
#include <errno.h>
#include <fcntl.h>

View File

@ -5,14 +5,15 @@
doing the edge detection of the PPM sum input
*/
#include "AP_HAL_Linux.h"
#include "RCInput.h"
#define RCIN_PRUSS_SHAREDRAM_BASE 0x4a312000
// we use 300 ring buffer entries to guarantee that a full 25 byte
// frame of 12 bits per byte
class Linux::RCInput_PRU : public Linux::RCInput
{
namespace Linux {
class RCInput_PRU : public RCInput {
public:
void init();
void _timer_tick(void);
@ -33,3 +34,5 @@ public:
// time spent in the low state
uint16_t _s0_time;
};
}

View File

@ -22,13 +22,14 @@
#include <queue>
namespace Linux {
enum state_t{
RCIN_RPI_INITIAL_STATE = -1,
RCIN_RPI_ZERO_STATE = 0,
RCIN_RPI_ONE_STATE = 1
};
//Memory table structure
typedef struct {
void **virt_pages;
@ -45,8 +46,8 @@ typedef struct {
class Memory_table {
// Allow RCInput_RPI access to private members of Memory_table
friend class Linux::RCInput_RPI;
friend class RCInput_RPI;
private:
void** _virt_pages;
void** _phys_pages;
@ -73,14 +74,14 @@ public:
};
class Linux::RCInput_RPI : public Linux::RCInput
{
class RCInput_RPI : public RCInput
{
public:
void init();
void _timer_tick(void);
RCInput_RPI();
~RCInput_RPI();
private:
//Physical adresses of peripherals. Are different on different Raspberries.
@ -110,10 +111,10 @@ private:
uint8_t curr_signal;
uint8_t last_signal;
state_t state;
AP_HAL::DigitalSource *enable_pin;
AP_HAL::DigitalSource *enable_pin;
void init_dma_cb(dma_cb_t** cbp, uint32_t mode, uint32_t source, uint32_t dest, uint32_t length, uint32_t stride, uint32_t next_cb);
void* map_peripheral(uint32_t base, uint32_t len);
@ -127,5 +128,6 @@ private:
void set_sigaction();
void set_physical_addresses(int version);
void deinit() override;
};
}

View File

@ -4,15 +4,20 @@
#include "RCInput.h"
#include <AP_HAL/SPIDevice.h>
class Linux::RCInput_Raspilot : public Linux::RCInput
namespace Linux {
class RCInput_Raspilot : public RCInput
{
public:
void init();
private:
uint32_t _last_timer;
AP_HAL::OwnPtr<AP_HAL::SPIDevice> _dev;
void _poll_data(void);
};
}

View File

@ -21,7 +21,9 @@
#include "RCInput.h"
#include "RCInput_SBUS.h"
class Linux::RCInput_SBUS : public Linux::RCInput
namespace Linux {
class RCInput_SBUS : public RCInput
{
public:
void init() override;
@ -32,4 +34,7 @@ private:
const char *device_path = "/dev/uart-sbus";
int32_t fd = -1;
};
}
#endif // CONFIG_HAL_BOARD_SUBTYPE

View File

@ -7,7 +7,9 @@
#define CHANNELS 8
class Linux::RCInput_UART : public Linux::RCInput
namespace Linux {
class RCInput_UART : public RCInput
{
public:
RCInput_UART(const char *path);
@ -25,3 +27,5 @@ private:
uint16_t values[CHANNELS];
} _data;
};
}

View File

@ -6,7 +6,9 @@
#define RCINPUT_UDP_DEF_PORT 777
class Linux::RCInput_UDP : public Linux::RCInput
namespace Linux {
class RCInput_UDP : public RCInput
{
public:
RCInput_UDP();
@ -19,3 +21,5 @@ private:
uint64_t _last_buf_ts;
uint16_t _last_buf_seq;
};
}

View File

@ -1,3 +1,5 @@
#include "RCInput_ZYNQ.h"
#include <errno.h>
#include <fcntl.h>
#include <poll.h>
@ -13,7 +15,6 @@
#include <AP_HAL/AP_HAL.h>
#include "GPIO.h"
#include "RCInput.h"
extern const AP_HAL::HAL& hal;

View File

@ -5,18 +5,19 @@
logic doing the edge detection of the PPM sum input
*/
#include "AP_HAL_Linux.h"
#include "RCInput.h"
// FIXME A puppie dies when you hard code an address
#define RCIN_ZYNQ_PULSE_INPUT_BASE 0x43c10000
class Linux::RCInput_ZYNQ : public Linux::RCInput
{
namespace Linux {
class RCInput_ZYNQ : public RCInput {
public:
void init();
void _timer_tick(void);
private:
private:
static const int TICK_PER_US=100;
static const int TICK_PER_S=100000000;
@ -26,3 +27,5 @@ public:
// time spent in the low state
uint32_t _s0_time;
};
}

View File

@ -16,7 +16,9 @@
#define RCOUT_PRUSS_IRAM_BASE 0x4a338000
#define PWM_CHAN_COUNT 12
class Linux::RCOutput_AioPRU : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_AioPRU : public AP_HAL::RCOutput {
void init();
void set_freq(uint32_t chmask, uint16_t freq_hz);
uint16_t get_freq(uint8_t ch);
@ -40,3 +42,5 @@ private:
volatile struct pwm *pwm;
};
}

View File

@ -3,6 +3,10 @@
#include "AP_HAL_Linux.h"
#include <AP_HAL/I2CDevice.h>
struct bldc_info;
namespace Linux {
enum bebop_bldc_motor {
BEBOP_BLDC_MOTOR_1 = 0,
#if CONFIG_HAL_BOARD_SUBTYPE != HAL_BOARD_SUBTYPE_LINUX_DISCO
@ -49,9 +53,7 @@ public:
uint8_t temperature;
};
struct bldc_info;
class Linux::RCOutput_Bebop : public AP_HAL::RCOutput {
class RCOutput_Bebop : public AP_HAL::RCOutput {
public:
RCOutput_Bebop(AP_HAL::OwnPtr<AP_HAL::I2CDevice> dev);
@ -102,3 +104,5 @@ private:
void _run_rcout();
static void *_control_thread(void *arg);
};
}

View File

@ -4,7 +4,9 @@
#include "RCOutput_Sysfs.h"
#include "RCOutput_Bebop.h"
class Linux::RCOutput_Disco : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_Disco : public AP_HAL::RCOutput {
public:
RCOutput_Disco(AP_HAL::OwnPtr<AP_HAL::I2CDevice> dev);
~RCOutput_Disco() {}
@ -51,5 +53,6 @@ private:
{ sysfs_out, 5 },
{ sysfs_out, 0 },
};
};
}

View File

@ -9,8 +9,10 @@
#define PCA9685_TERTIARY_ADDRESS 0x42
#define PCA9685_QUATENARY_ADDRESS 0x55
class Linux::RCOutput_PCA9685 : public AP_HAL::RCOutput {
public:
namespace Linux {
class RCOutput_PCA9685 : public AP_HAL::RCOutput {
public:
RCOutput_PCA9685(AP_HAL::OwnPtr<AP_HAL::I2CDevice> dev,
bool external_clock,
uint8_t channel_offset,
@ -45,3 +47,5 @@ private:
int16_t _oe_pin_number;
uint16_t _pending_write_mask;
};
}

View File

@ -13,7 +13,9 @@
#define PWM_CMD_CLR 5 /* clr a pwm output explicitly */
#define PWM_CMD_TEST 6 /* various crap */
class Linux::RCOutput_PRU : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_PRU : public AP_HAL::RCOutput {
void init();
void set_freq(uint32_t chmask, uint16_t freq_hz);
uint16_t get_freq(uint8_t ch);
@ -37,3 +39,5 @@ private:
volatile struct pwm_cmd *sharedMem_cmd;
};
}

View File

@ -3,7 +3,10 @@
#include "AP_HAL_Linux.h"
#include <AP_HAL/SPIDevice.h>
class Linux::RCOutput_Raspilot : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_Raspilot : public AP_HAL::RCOutput {
public:
void init();
void set_freq(uint32_t chmask, uint16_t freq_hz);
uint16_t get_freq(uint8_t ch);
@ -16,10 +19,12 @@ class Linux::RCOutput_Raspilot : public AP_HAL::RCOutput {
private:
void reset();
void _update(void);
AP_HAL::OwnPtr<AP_HAL::SPIDevice> _dev;
uint32_t _last_update_timestamp;
uint16_t _frequency;
uint16_t _period_us[8];
};
}

View File

@ -3,7 +3,9 @@
#include "AP_HAL_Linux.h"
#include "PWM_Sysfs.h"
class Linux::RCOutput_Sysfs : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_Sysfs : public AP_HAL::RCOutput {
public:
RCOutput_Sysfs(uint8_t chip, uint8_t channel_base, uint8_t channel_count);
~RCOutput_Sysfs();
@ -28,3 +30,5 @@ private:
const uint8_t _channel_count;
PWM_Sysfs_Base **_pwm_channels;
};
}

View File

@ -11,8 +11,13 @@
#define PWM_CMD_CLR 5 /* clr a pwm output explicitly */
#define PWM_CMD_TEST 6 /* various crap */
#include <AP_HAL/AP_HAL.h>
class Linux::RCOutput_ZYNQ : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_ZYNQ : public AP_HAL::RCOutput {
public:
void init();
void set_freq(uint32_t chmask, uint16_t freq_hz);
uint16_t get_freq(uint8_t ch);
@ -36,3 +41,5 @@ private:
};
volatile struct pwm_cmd *sharedMem_cmd;
};
}

View File

@ -5,7 +5,9 @@
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_QFLIGHT
class Linux::RCOutput_QFLIGHT : public AP_HAL::RCOutput {
namespace Linux {
class RCOutput_QFLIGHT : public AP_HAL::RCOutput {
public:
void init();
void set_freq(uint32_t chmask, uint16_t freq_hz);
@ -19,18 +21,18 @@ public:
private:
const char *device = nullptr;
const uint32_t baudrate = 115200;
const uint32_t baudrate = 115200;
static const uint8_t channel_count = 4;
int32_t fd = -1;
uint16_t enable_mask;
uint16_t period[channel_count];
volatile bool need_write;
void timer_update(void);
void check_rc_in(void);
uint32_t last_read_check_ms;
struct PACKED rcin_frame {
uint8_t magic;
@ -44,4 +46,6 @@ private:
uint8_t nrcin_bytes;
};
}
#endif // CONFIG_HAL_BOARD_SUBTYPE

View File

@ -5,8 +5,9 @@
#include "UARTDriver.h"
#include <AP_HAL/SPIDevice.h>
namespace Linux {
class Linux::RPIOUARTDriver : public Linux::UARTDriver {
class RPIOUARTDriver : public UARTDriver {
public:
RPIOUARTDriver();
@ -37,3 +38,5 @@ private:
bool _need_set_baud;
uint32_t _baudrate;
};
}

View File

@ -4,8 +4,9 @@
#include "UARTDriver.h"
namespace Linux {
class Linux::SPIUARTDriver : public Linux::UARTDriver {
class SPIUARTDriver : public UARTDriver {
public:
SPIUARTDriver();
void begin(uint32_t b, uint16_t rxS, uint16_t txS);
@ -23,3 +24,5 @@ protected:
bool _external;
};
}

View File

@ -10,7 +10,9 @@
#define LINUX_SCHEDULER_MAX_TIMESLICED_PROCS 10
#define LINUX_SCHEDULER_MAX_IO_PROCS 10
class Linux::Scheduler : public AP_HAL::Scheduler {
namespace Linux {
class Scheduler : public AP_HAL::Scheduler {
public:
Scheduler();
@ -109,3 +111,5 @@ private:
Semaphore _timer_semaphore;
Semaphore _io_semaphore;
};
}

View File

@ -6,7 +6,9 @@
#include "AP_HAL_Linux.h"
class Linux::Semaphore : public AP_HAL::Semaphore {
namespace Linux {
class Semaphore : public AP_HAL::Semaphore {
public:
Semaphore() {
pthread_mutex_init(&_lock, NULL);
@ -17,3 +19,5 @@ public:
private:
pthread_mutex_t _lock;
};
}

View File

@ -1,7 +1,6 @@
#pragma once
#include <AP_HAL/AP_HAL.h>
#include "AP_HAL_Linux_Namespace.h"
#define LINUX_STORAGE_SIZE HAL_STORAGE_SIZE
#define LINUX_STORAGE_MAX_WRITE 512
@ -9,7 +8,9 @@
#define LINUX_STORAGE_LINE_SIZE (1<<LINUX_STORAGE_LINE_SHIFT)
#define LINUX_STORAGE_NUM_LINES (LINUX_STORAGE_SIZE/LINUX_STORAGE_LINE_SIZE)
class Linux::Storage : public AP_HAL::Storage
namespace Linux {
class Storage : public AP_HAL::Storage
{
public:
Storage() : _fd(-1),_dirty_mask(0) { }
@ -39,3 +40,5 @@ protected:
uint8_t _buffer[LINUX_STORAGE_SIZE];
volatile uint32_t _dirty_mask;
};
}

View File

@ -23,8 +23,6 @@
#include <AP_HAL/utility/functor.h>
#include "AP_HAL_Linux_Namespace.h"
namespace Linux {
/*

View File

@ -1,7 +1,6 @@
#pragma once
#include <AP_HAL/AP_HAL.h>
#include "AP_HAL_Linux_Namespace.h"
#define OCTAVE_OFFSET 0
@ -109,7 +108,9 @@
#define TONE_NUMBER_OF_TUNES 11
class Linux::ToneAlarm{
namespace Linux {
class ToneAlarm {
public:
ToneAlarm();
void set_tune(uint8_t tone);
@ -141,3 +142,5 @@ private:
int32_t duty_fd;
int32_t run_fd;
};
}

View File

@ -4,7 +4,9 @@
#include "ToneAlarm.h"
class Linux::ToneAlarm_Raspilot : public Linux::ToneAlarm {
namespace Linux {
class ToneAlarm_Raspilot : public ToneAlarm {
public:
ToneAlarm_Raspilot();
bool init() override;
@ -18,3 +20,5 @@ private:
volatile uint32_t *_pwm;
volatile uint32_t *_clk;
};
}

View File

@ -5,7 +5,9 @@
#include "AP_HAL_Linux.h"
#include "SerialDevice.h"
class Linux::UARTDriver : public AP_HAL::UARTDriver {
namespace Linux {
class UARTDriver : public AP_HAL::UARTDriver {
public:
UARTDriver(bool default_console);
@ -54,14 +56,14 @@ private:
uint16_t _base_port;
char *_ip;
char *_flag;
bool _connected; // true if a client has connected
bool _connected; // true if a client has connected
bool _packetise; // true if writes should try to be on mavlink boundaries
void _allocate_buffers(uint16_t rxS, uint16_t txS);
void _deallocate_buffers();
AP_HAL::OwnPtr<SerialDevice> _parseDevicePath(const char *arg);
uint64_t _last_write_time;
uint64_t _last_write_time;
protected:
const char *device_path;
@ -85,3 +87,5 @@ protected:
virtual int _read_fd(uint8_t *buf, uint16_t n);
};
}

View File

@ -3,11 +3,13 @@
#include <AP_Common/AP_Common.h>
#include <AP_HAL/AP_HAL.h>
#include "AP_HAL_Linux_Namespace.h"
#include "Heat.h"
#include "Perf.h"
#include "ToneAlarm.h"
#include "Semaphores.h"
namespace Linux {
enum hw_type {
UTIL_HARDWARE_RPI1 = 0,
UTIL_HARDWARE_RPI2,
@ -17,7 +19,7 @@ enum hw_type {
UTIL_NUM_HARDWARES,
};
class Linux::Util : public AP_HAL::Util {
class Util : public AP_HAL::Util {
public:
static Util *from(AP_HAL::Util *util) {
return static_cast<Util*>(util);
@ -39,7 +41,7 @@ public:
/*
set system clock in UTC microseconds
*/
void set_system_clock(uint64_t time_utc_usec);
void set_system_clock(uint64_t time_utc_usec);
const char* get_custom_log_directory() { return custom_log_directory; }
const char* get_custom_terrain_directory() { return custom_terrain_directory; }
@ -87,20 +89,22 @@ public:
}
// create a new semaphore
AP_HAL::Semaphore *new_semaphore(void) override { return new Linux::Semaphore; }
AP_HAL::Semaphore *new_semaphore(void) override { return new Semaphore; }
int get_hw_arm32();
private:
#if CONFIG_HAL_BOARD_SUBTYPE == HAL_BOARD_SUBTYPE_LINUX_RASPILOT
static Linux::ToneAlarm_Raspilot _toneAlarm;
static ToneAlarm_Raspilot _toneAlarm;
#else
static Linux::ToneAlarm _toneAlarm;
static ToneAlarm _toneAlarm;
#endif
Linux::Heat *_heat;
Heat *_heat;
int saved_argc;
char* const *saved_argv;
const char* custom_log_directory = NULL;
const char* custom_terrain_directory = NULL;
static const char *_hw_names[UTIL_NUM_HARDWARES];
};
}

View File

@ -2,7 +2,9 @@
#include "Util.h"
class Linux::UtilRPI : public Linux::Util {
namespace Linux {
class UtilRPI : public Util {
public:
UtilRPI();
@ -20,3 +22,5 @@ protected:
private:
int _rpi_version = 0;
};
}

View File

@ -18,12 +18,14 @@
#include <linux/videodev2.h>
#include <vector>
namespace Linux {
struct buffer {
unsigned int size;
void *mem;
};
class Linux::VideoIn {
class VideoIn {
public:
/* This structure implements the fields of the v4l2_pix_format struct
* that are considered useful for an optical flow application along
@ -80,3 +82,5 @@ private:
uint32_t _sizeimage;
uint32_t _memtype = V4L2_MEMORY_MMAP;
};
}