From 93550f4659d58ae3aeead4c6ad8f5ad9df40b33c Mon Sep 17 00:00:00 2001 From: James Goppert Date: Tue, 29 Nov 2011 13:59:44 -0500 Subject: [PATCH] APO fixes. --- ArduBoat/BoatGeneric.h | 4 ++-- ArduRover/CarStampede.h | 8 ++++---- ArduRover/TankGeneric.h | 4 ++-- apo/PlaneEasystar.h | 4 ++-- apo/QuadArducopter.h | 2 +- libraries/APO/APO_DefaultSetup.h | 9 ++++----- libraries/APO/AP_Autopilot.h | 2 ++ libraries/APO/AP_CommLink.cpp | 14 ++++++++------ libraries/APO/AP_CommLink.h | 14 ++++++++++++-- libraries/APO/AP_Controller.cpp | 2 +- libraries/APO/AP_HardwareAbstractionLayer.h | 21 ++++----------------- 11 files changed, 42 insertions(+), 42 deletions(-) diff --git a/ArduBoat/BoatGeneric.h b/ArduBoat/BoatGeneric.h index b79f2f5634..8289445440 100644 --- a/ArduBoat/BoatGeneric.h +++ b/ArduBoat/BoatGeneric.h @@ -10,7 +10,7 @@ #define BOATGENERIC_H_ // vehicle options -static const apo::vehicle_t vehicle = apo::VEHICLE_BOAT; +static const MAV_TYPE vehicle = UGV_SURFACE_SHIP; static const apo::halMode_t halMode = apo::MODE_LIVE; static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280; static const uint8_t heartBeatTimeout = 3; @@ -31,7 +31,7 @@ static const uint8_t heartBeatTimeout = 3; static const uint32_t debugBaud = 57600; static const uint32_t telemBaud = 57600; static const uint32_t gpsBaud = 38400; -static const uint32_t hilBaud = 57600; +static const uint32_t hilBaud = 115200; // optional sensors static const bool gpsEnabled = false; diff --git a/ArduRover/CarStampede.h b/ArduRover/CarStampede.h index 82dc03b9cd..e84a934d1a 100644 --- a/ArduRover/CarStampede.h +++ b/ArduRover/CarStampede.h @@ -10,9 +10,9 @@ #define CARSTAMPEDE_H_ // vehicle options -static const apo::vehicle_t vehicle = apo::VEHICLE_CAR; -//static const apo::halMode_t halMode = apo::MODE_HIL_CNTL; -static const apo::halMode_t halMode = apo::MODE_LIVE; +static const MAV_TYPE vehicle = UGV_GROUND_ROVER; +static const apo::halMode_t halMode = apo::MODE_HIL_CNTL; +//static const apo::halMode_t halMode = apo::MODE_LIVE; static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280; static const uint8_t heartBeatTimeout = 3; @@ -32,7 +32,7 @@ static const uint8_t heartBeatTimeout = 3; static const uint32_t debugBaud = 57600; static const uint32_t telemBaud = 57600; static const uint32_t gpsBaud = 38400; -static const uint32_t hilBaud = 57600; +static const uint32_t hilBaud = 115200; // optional sensors static const bool gpsEnabled = false; diff --git a/ArduRover/TankGeneric.h b/ArduRover/TankGeneric.h index 106eeca20a..53f025ba04 100644 --- a/ArduRover/TankGeneric.h +++ b/ArduRover/TankGeneric.h @@ -11,7 +11,7 @@ #define TANKGENERIC_H_ // vehicle options -static const apo::vehicle_t vehicle = apo::VEHICLE_TANK; +static const MAV_TYPE vehicle = UGV_GROUND_ROVER; static const apo::halMode_t halMode = apo::MODE_LIVE; static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280; static const uint8_t heartBeatTimeout = 3; @@ -32,7 +32,7 @@ static const uint8_t heartBeatTimeout = 3; static const uint32_t debugBaud = 57600; static const uint32_t telemBaud = 57600; static const uint32_t gpsBaud = 38400; -static const uint32_t hilBaud = 57600; +static const uint32_t hilBaud = 115200; // optional sensors static const bool gpsEnabled = false; diff --git a/apo/PlaneEasystar.h b/apo/PlaneEasystar.h index 54e331f84d..6e1d56ff0f 100644 --- a/apo/PlaneEasystar.h +++ b/apo/PlaneEasystar.h @@ -9,7 +9,7 @@ #define PLANEEASYSTAR_H_ // vehicle options -static const apo::vehicle_t vehicle = apo::VEHICLE_PLANE; +static const MAV_TYPE vehicle = MAV_TYPE_FIXED_WING; static const apo::halMode_t halMode = apo::MODE_LIVE; static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280; static const uint8_t heartBeatTimeout = 3; @@ -30,7 +30,7 @@ static const uint8_t heartBeatTimeout = 3; static const uint32_t debugBaud = 57600; static const uint32_t telemBaud = 57600; static const uint32_t gpsBaud = 38400; -static const uint32_t hilBaud = 57600; +static const uint32_t hilBaud = 115200; // optional sensors static const bool gpsEnabled = false; diff --git a/apo/QuadArducopter.h b/apo/QuadArducopter.h index cda3666c84..387ffd36f1 100644 --- a/apo/QuadArducopter.h +++ b/apo/QuadArducopter.h @@ -9,7 +9,7 @@ #define QUADARDUCOPTER_H_ // vehicle options -static const apo::vehicle_t vehicle = apo::VEHICLE_QUAD; +static const MAV_TYPE vehicle = MAV_QUADROTOR; static const apo::halMode_t halMode = apo::MODE_HIL_CNTL; static const apo::board_t board = apo::BOARD_ARDUPILOTMEGA_1280; static const uint8_t heartBeatTimeout = 0; diff --git a/libraries/APO/APO_DefaultSetup.h b/libraries/APO/APO_DefaultSetup.h index e637d1de4f..d16c1b57f0 100644 --- a/libraries/APO/APO_DefaultSetup.h +++ b/libraries/APO/APO_DefaultSetup.h @@ -30,8 +30,7 @@ void setup() { Serial.begin(debugBaud, 128, 128); // debug // hardware abstraction layer - hal = new AP_HardwareAbstractionLayer( - halMode, board, vehicle, heartBeatTimeout); + hal = new AP_HardwareAbstractionLayer(halMode, board, vehicle); // debug serial hal->debug = &Serial; @@ -150,12 +149,12 @@ void setup() { if (board==BOARD_ARDUPILOTMEGA_2) { Serial2.begin(telemBaud, 128, 128); // gcs - hal->gcs = new COMMLINK_CLASS(&Serial2, navigator, guide, controller, hal); + hal->gcs = new COMMLINK_CLASS(&Serial2, navigator, guide, controller, hal, heartBeatTimeout); } else { Serial3.begin(telemBaud, 128, 128); // gcs - hal->gcs = new COMMLINK_CLASS(&Serial3, navigator, guide, controller, hal); + hal->gcs = new COMMLINK_CLASS(&Serial3, navigator, guide, controller, hal, heartBeatTimeout); } /* @@ -166,7 +165,7 @@ void setup() { Serial1.begin(hilBaud, 128, 128); delay(1000); Serial1.println("starting hil"); - hal->hil = new COMMLINK_CLASS(&Serial1, navigator, guide, controller, hal); + hal->hil = new COMMLINK_CLASS(&Serial1, navigator, guide, controller, hal, heartBeatTimeout); } /* diff --git a/libraries/APO/AP_Autopilot.h b/libraries/APO/AP_Autopilot.h index c508c68d27..a1a6b82adb 100644 --- a/libraries/APO/AP_Autopilot.h +++ b/libraries/APO/AP_Autopilot.h @@ -16,8 +16,10 @@ * ArduPilotOne does not use any global * variables. */ + namespace apo { +// enumerations // forward declarations class AP_Navigator; class AP_Guide; diff --git a/libraries/APO/AP_CommLink.cpp b/libraries/APO/AP_CommLink.cpp index 9ccd483ee2..f0ab7cec4e 100644 --- a/libraries/APO/AP_CommLink.cpp +++ b/libraries/APO/AP_CommLink.cpp @@ -25,14 +25,16 @@ uint8_t MavlinkComm::_nChannels = 0; uint8_t MavlinkComm::_paramNameLengthMax = 13; AP_CommLink::AP_CommLink(FastSerial * link, AP_Navigator * navigator, AP_Guide * guide, - AP_Controller * controller, AP_HardwareAbstractionLayer * hal) : + AP_Controller * controller, AP_HardwareAbstractionLayer * hal, + const uint16_t heartBeatTimeout) : _link(link), _navigator(navigator), _guide(guide), - _controller(controller), _hal(hal) { + _controller(controller), _hal(hal), _heartBeatTimeout(heartBeatTimeout), _lastHeartBeat(0) { } MavlinkComm::MavlinkComm(FastSerial * link, AP_Navigator * nav, AP_Guide * guide, - AP_Controller * controller, AP_HardwareAbstractionLayer * hal) : - AP_CommLink(link, nav, guide, controller, hal), + AP_Controller * controller, AP_HardwareAbstractionLayer * hal, + const uint16_t heartBeatTimeout) : + AP_CommLink(link, nav, guide, controller, hal,heartBeatTimeout), // options _useRelativeAlt(true), @@ -83,7 +85,7 @@ void MavlinkComm::sendMessage(uint8_t id, uint32_t param) { switch (id) { case MAVLINK_MSG_ID_HEARTBEAT: { - mavlink_msg_heartbeat_send(_channel, mavlink_system.type, + mavlink_msg_heartbeat_send(_channel, _hal->getVehicle(), MAV_AUTOPILOT_ARDUPILOTMEGA); break; } @@ -311,7 +313,7 @@ void MavlinkComm::_handleMessage(mavlink_message_t * msg) { case MAVLINK_MSG_ID_HEARTBEAT: { mavlink_heartbeat_t packet; mavlink_msg_heartbeat_decode(msg, &packet); - _hal->lastHeartBeat = micros(); + _lastHeartBeat = micros(); break; } diff --git a/libraries/APO/AP_CommLink.h b/libraries/APO/AP_CommLink.h index 76b4c5e772..0718958e60 100644 --- a/libraries/APO/AP_CommLink.h +++ b/libraries/APO/AP_CommLink.h @@ -46,7 +46,7 @@ class AP_CommLink { public: AP_CommLink(FastSerial * link, AP_Navigator * navigator, AP_Guide * guide, - AP_Controller * controller, AP_HardwareAbstractionLayer * hal); + AP_Controller * controller, AP_HardwareAbstractionLayer * hal, const uint16_t heartBeatTimeout); virtual void send() = 0; virtual void receive() = 0; virtual void sendMessage(uint8_t id, uint32_t param = 0) = 0; @@ -56,18 +56,28 @@ public: virtual void sendParameters() = 0; virtual void requestCmds() = 0; + /// check if heartbeat is lost + bool heartBeatLost() { + if (_heartBeatTimeout == 0) + return false; + else + return ((micros() - _lastHeartBeat) / 1e6) > _heartBeatTimeout; + } + protected: FastSerial * _link; AP_Navigator * _navigator; AP_Guide * _guide; AP_Controller * _controller; AP_HardwareAbstractionLayer * _hal; + uint16_t _heartBeatTimeout; /// vehicle heartbeat timeout, s + uint32_t _lastHeartBeat; /// time of last heartbeat, s }; class MavlinkComm: public AP_CommLink { public: MavlinkComm(FastSerial * link, AP_Navigator * nav, AP_Guide * guide, - AP_Controller * controller, AP_HardwareAbstractionLayer * hal); + AP_Controller * controller, AP_HardwareAbstractionLayer * hal, uint16_t heartBeatTimeout); virtual void send(); void sendMessage(uint8_t id, uint32_t param = 0); diff --git a/libraries/APO/AP_Controller.cpp b/libraries/APO/AP_Controller.cpp index e949d4e0a2..c6d12881e1 100644 --- a/libraries/APO/AP_Controller.cpp +++ b/libraries/APO/AP_Controller.cpp @@ -65,7 +65,7 @@ void AP_Controller::update(const float dt) { // handle emergencies // // check for heartbeat from gcs, if not found go to failsafe - if (_hal->heartBeatLost()) { + if (_hal->gcs->heartBeatLost()) { setMode(MAV_MODE_FAILSAFE); _hal->gcs->sendText(SEVERITY_HIGH, PSTR("configure gcs to send heartbeat")); diff --git a/libraries/APO/AP_HardwareAbstractionLayer.h b/libraries/APO/AP_HardwareAbstractionLayer.h index 4785e975dc..38ff84d548 100644 --- a/libraries/APO/AP_HardwareAbstractionLayer.h +++ b/libraries/APO/AP_HardwareAbstractionLayer.h @@ -36,9 +36,6 @@ enum halMode_t { enum board_t { BOARD_ARDUPILOTMEGA_1280, BOARD_ARDUPILOTMEGA_2560, BOARD_ARDUPILOTMEGA_2 }; -enum vehicle_t { - VEHICLE_CAR, VEHICLE_QUAD, VEHICLE_PLANE, VEHICLE_BOAT, VEHICLE_TANK -}; class AP_HardwareAbstractionLayer { @@ -47,12 +44,10 @@ public: // default ctors on pointers called on pointers here, this // allows NULL to be used as a boolean for if the device was // initialized - AP_HardwareAbstractionLayer(halMode_t mode, board_t board, - vehicle_t vehicle, uint8_t heartBeatTimeout) : + AP_HardwareAbstractionLayer(halMode_t mode, board_t board, MAV_TYPE vehicle) : adc(), gps(), baro(), compass(), rangeFinders(), imu(), batteryMonitor(), radio(), rc(), gcs(), - hil(), debug(), load(), lastHeartBeat(), - _heartBeatTimeout(heartBeatTimeout), _mode(mode), + hil(), debug(), load(), _mode(mode), _board(board), _vehicle(vehicle) { /* @@ -132,7 +127,6 @@ public: * data */ uint8_t load; - uint32_t lastHeartBeat; /** * settings @@ -151,23 +145,16 @@ public: board_t getBoard() { return _board; } - vehicle_t getVehicle() { + MAV_TYPE getVehicle() { return _vehicle; } - bool heartBeatLost() { - if (_heartBeatTimeout == 0) - return false; - else - return ((micros() - lastHeartBeat) / 1e6) > _heartBeatTimeout; - } private: // enumerations - uint8_t _heartBeatTimeout; halMode_t _mode; board_t _board; - vehicle_t _vehicle; + MAV_TYPE _vehicle; }; } // namespace apo