MavlinkOrbSubscription API reworked

This commit is contained in:
Anton Babushkin 2014-06-11 14:00:44 +02:00
parent fb4bcf87ba
commit 342e08977a
6 changed files with 251 additions and 140 deletions

View File

@ -40,21 +40,17 @@
#include "mavlink_commands.h"
MavlinkCommandsStream::MavlinkCommandsStream(Mavlink *mavlink, mavlink_channel_t channel) : _channel(channel)
MavlinkCommandsStream::MavlinkCommandsStream(Mavlink *mavlink, mavlink_channel_t channel) : _channel(channel), _cmd_time(0)
{
_cmd_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_command));
}
MavlinkCommandsStream::~MavlinkCommandsStream()
{
}
void
MavlinkCommandsStream::update(const hrt_abstime t)
{
struct vehicle_command_s cmd;
if (_cmd_sub->update(t, &cmd)) {
if (_cmd_sub->update(&_cmd_time, &cmd)) {
/* only send commands for other systems/components */
if (cmd.target_system != mavlink_system.sysid || cmd.target_component != mavlink_system.compid) {
mavlink_msg_command_long_send(_channel,

View File

@ -55,10 +55,10 @@ private:
MavlinkOrbSubscription *_cmd_sub;
struct vehicle_command_s *_cmd;
mavlink_channel_t _channel;
uint64_t _cmd_time;
public:
MavlinkCommandsStream(Mavlink *mavlink, mavlink_channel_t channel);
~MavlinkCommandsStream();
void update(const hrt_abstime t);
};

View File

@ -1900,10 +1900,12 @@ Mavlink::task_main(int argc, char *argv[])
_task_running = true;
MavlinkOrbSubscription *param_sub = add_orb_subscription(ORB_ID(parameter_update));
uint64_t param_time = 0;
MavlinkOrbSubscription *status_sub = add_orb_subscription(ORB_ID(vehicle_status));
uint64_t status_time = 0;
struct vehicle_status_s status;
status_sub->update(0, &status);
status_sub->update(&status_time, &status);
MavlinkCommandsStream commands_stream(this, _channel);
@ -1960,12 +1962,12 @@ Mavlink::task_main(int argc, char *argv[])
hrt_abstime t = hrt_absolute_time();
if (param_sub->update(t, nullptr)) {
if (param_sub->update(&param_time, nullptr)) {
/* parameters updated */
mavlink_update_system();
}
if (status_sub->update(t, &status)) {
if (status_sub->update(&status_time, &status)) {
/* switch HIL mode if required */
set_hil_enabled(status.hil_state == HIL_STATE_ON);
}

View File

@ -195,9 +195,6 @@ void get_mavlink_mode_state(struct vehicle_status_s *status, struct position_set
class MavlinkStreamHeartbeat : public MavlinkStream
{
public:
~MavlinkStreamHeartbeat() {};
const char *get_name() const
{
return MavlinkStreamHeartbeat::get_name_static();
@ -216,12 +213,8 @@ public:
private:
MavlinkOrbSubscription *status_sub;
MavlinkOrbSubscription *pos_sp_triplet_sub;
protected:
explicit MavlinkStreamHeartbeat() {};
void subscribe(Mavlink *mavlink)
{
status_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_status));
@ -233,21 +226,19 @@ protected:
struct vehicle_status_s status;
struct position_setpoint_triplet_s pos_sp_triplet;
(void)status_sub->update(t, &status);
(void)pos_sp_triplet_sub->update(t, &pos_sp_triplet);
uint8_t mavlink_state = 0;
uint8_t mavlink_base_mode = 0;
uint32_t mavlink_custom_mode = 0;
get_mavlink_mode_state(&status, &pos_sp_triplet, &mavlink_state, &mavlink_base_mode, &mavlink_custom_mode);
mavlink_msg_heartbeat_send(_channel,
mavlink_system.type,
MAV_AUTOPILOT_PX4,
mavlink_base_mode,
mavlink_custom_mode,
mavlink_state);
if (status_sub->update(&status) && pos_sp_triplet_sub->update(&pos_sp_triplet)) {
uint8_t mavlink_state = 0;
uint8_t mavlink_base_mode = 0;
uint32_t mavlink_custom_mode = 0;
get_mavlink_mode_state(&status, &pos_sp_triplet, &mavlink_state, &mavlink_base_mode, &mavlink_custom_mode);
mavlink_msg_heartbeat_send(_channel,
mavlink_system.type,
MAV_AUTOPILOT_PX4,
mavlink_base_mode,
mavlink_custom_mode,
mavlink_state);
}
}
};
@ -255,8 +246,6 @@ protected:
class MavlinkStreamSysStatus : public MavlinkStream
{
public:
~MavlinkStreamSysStatus() {};
const char *get_name() const
{
return MavlinkStreamSysStatus::get_name_static();
@ -274,11 +263,8 @@ public:
private:
MavlinkOrbSubscription *status_sub;
struct vehicle_status_s *status;
protected:
explicit MavlinkStreamSysStatus() {};
void subscribe(Mavlink *mavlink)
{
status_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_status));
@ -287,21 +273,23 @@ protected:
void send(const hrt_abstime t)
{
struct vehicle_status_s status;
(void)status_sub->update(t, &status);
mavlink_msg_sys_status_send(_channel,
status.onboard_control_sensors_present,
status.onboard_control_sensors_enabled,
status.onboard_control_sensors_health,
status.load * 1000.0f,
status.battery_voltage * 1000.0f,
status.battery_current * 100.0f,
status.battery_remaining * 100.0f,
status.drop_rate_comm,
status.errors_comm,
status.errors_count1,
status.errors_count2,
status.errors_count3,
status.errors_count4);
if (status_sub->update(&status)) {
mavlink_msg_sys_status_send(_channel,
status.onboard_control_sensors_present,
status.onboard_control_sensors_enabled,
status.onboard_control_sensors_health,
status.load * 1000.0f,
status.battery_voltage * 1000.0f,
status.battery_current * 100.0f,
status.battery_remaining * 100.0f,
status.drop_rate_comm,
status.errors_comm,
status.errors_count1,
status.errors_count2,
status.errors_count3,
status.errors_count4);
}
}
};
@ -309,8 +297,6 @@ protected:
class MavlinkStreamHighresIMU : public MavlinkStream
{
public:
~MavlinkStreamHighresIMU() {};
const char *get_name() const
{
return MavlinkStreamHighresIMU::get_name_static();
@ -328,6 +314,7 @@ public:
private:
MavlinkOrbSubscription *sensor_sub;
uint64_t sensor_time;
uint64_t accel_timestamp;
uint64_t gyro_timestamp;
@ -335,9 +322,13 @@ private:
uint64_t baro_timestamp;
protected:
explicit MavlinkStreamHighresIMU() : MavlinkStream(), accel_timestamp(0), gyro_timestamp(0), mag_timestamp(0), baro_timestamp(0)
{
}
explicit MavlinkStreamHighresIMU() : MavlinkStream(),
sensor_time(0),
accel_timestamp(0),
gyro_timestamp(0),
mag_timestamp(0),
baro_timestamp(0)
{}
void subscribe(Mavlink *mavlink)
{
@ -347,7 +338,8 @@ protected:
void send(const hrt_abstime t)
{
struct sensor_combined_s sensor;
if (sensor_sub->update(t, &sensor)) {
if (sensor_sub->update(&sensor_time, &sensor)) {
uint16_t fields_updated = 0;
if (accel_timestamp != sensor.accelerometer_timestamp) {
@ -407,9 +399,13 @@ public:
private:
MavlinkOrbSubscription *att_sub;
struct vehicle_attitude_s *att;
uint64_t att_time;
protected:
explicit MavlinkStreamAttitude() : MavlinkStream(),
att_time(0)
{}
void subscribe(Mavlink *mavlink)
{
att_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_attitude));
@ -419,7 +415,7 @@ protected:
{
struct vehicle_attitude_s att;
if (att_sub->update(t, &att)) {
if (att_sub->update(&att_time, &att)) {
mavlink_msg_attitude_send(_channel,
att.timestamp / 1000,
att.roll, att.pitch, att.yaw,
@ -449,8 +445,13 @@ public:
private:
MavlinkOrbSubscription *att_sub;
uint64_t att_time;
protected:
explicit MavlinkStreamAttitudeQuaternion() : MavlinkStream(),
att_time(0)
{}
void subscribe(Mavlink *mavlink)
{
att_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_attitude));
@ -460,7 +461,7 @@ protected:
{
struct vehicle_attitude_s att;
if (att_sub->update(t, &att)) {
if (att_sub->update(&att_time, &att)) {
mavlink_msg_attitude_quaternion_send(_channel,
att.timestamp / 1000,
att.q[0],
@ -496,21 +497,29 @@ public:
private:
MavlinkOrbSubscription *att_sub;
struct vehicle_attitude_s *att;
uint64_t att_time;
MavlinkOrbSubscription *pos_sub;
struct vehicle_global_position_s *pos;
uint64_t pos_time;
MavlinkOrbSubscription *armed_sub;
struct actuator_armed_s *armed;
uint64_t armed_time;
MavlinkOrbSubscription *act_sub;
struct actuator_controls_s *act;
uint64_t act_time;
MavlinkOrbSubscription *airspeed_sub;
struct airspeed_s *airspeed;
uint64_t airspeed_time;
protected:
explicit MavlinkStreamVFRHUD() : MavlinkStream(),
att_time(0),
pos_time(0),
armed_time(0),
act_time(0),
airspeed_time(0)
{}
void subscribe(Mavlink *mavlink)
{
att_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_attitude));
@ -528,11 +537,11 @@ protected:
struct actuator_controls_s act;
struct airspeed_s airspeed;
bool updated = att_sub->update(t, &att);
updated |= pos_sub->update(t, &pos);
updated |= armed_sub->update(t, &armed);
updated |= act_sub->update(t, &act);
updated |= airspeed_sub->update(t, &airspeed);
bool updated = att_sub->update(&att_time, &att);
updated |= pos_sub->update(&pos_time, &pos);
updated |= armed_sub->update(&armed_time, &armed);
updated |= act_sub->update(&act_time, &act);
updated |= airspeed_sub->update(&airspeed_time, &airspeed);
if (updated) {
float groundspeed = sqrtf(pos.vel_n * pos.vel_n + pos.vel_e * pos.vel_e);
@ -571,9 +580,13 @@ public:
private:
MavlinkOrbSubscription *gps_sub;
struct vehicle_gps_position_s *gps;
uint64_t gps_time;
protected:
explicit MavlinkStreamGPSRawInt() : MavlinkStream(),
gps_time(0)
{}
void subscribe(Mavlink *mavlink)
{
gps_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_gps_position));
@ -583,7 +596,7 @@ protected:
{
struct vehicle_gps_position_s gps;
if (gps_sub->update(t, &gps)) {
if (gps_sub->update(&gps_time, &gps)) {
mavlink_msg_gps_raw_int_send(_channel,
gps.timestamp_position,
gps.fix_type,
@ -620,9 +633,17 @@ public:
private:
MavlinkOrbSubscription *pos_sub;
uint64_t pos_time;
MavlinkOrbSubscription *home_sub;
uint64_t home_time;
protected:
explicit MavlinkStreamGlobalPositionInt() : MavlinkStream(),
pos_time(0),
home_time(0)
{}
void subscribe(Mavlink *mavlink)
{
pos_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_global_position));
@ -634,8 +655,8 @@ protected:
struct vehicle_global_position_s pos;
struct home_position_s home;
bool updated = pos_sub->update(t, &pos);
updated |= home_sub->update(t, &home);
bool updated = pos_sub->update(&pos_time, &pos);
updated |= home_sub->update(&home_time, &home);
if (updated) {
mavlink_msg_global_position_int_send(_channel,
@ -673,8 +694,13 @@ public:
private:
MavlinkOrbSubscription *pos_sub;
uint64_t pos_time;
protected:
explicit MavlinkStreamLocalPositionNED() : MavlinkStream(),
pos_time(0)
{}
void subscribe(Mavlink *mavlink)
{
pos_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_local_position));
@ -684,7 +710,7 @@ protected:
{
struct vehicle_local_position_s pos;
if (pos_sub->update(t, &pos)) {
if (pos_sub->update(&pos_time, &pos)) {
mavlink_msg_local_position_ned_send(_channel,
pos.timestamp / 1000,
pos.x,
@ -719,8 +745,13 @@ public:
private:
MavlinkOrbSubscription *pos_sub;
uint64_t pos_time;
protected:
explicit MavlinkStreamViconPositionEstimate() : MavlinkStream(),
pos_time(0)
{}
void subscribe(Mavlink *mavlink)
{
pos_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_vicon_position));
@ -730,7 +761,7 @@ protected:
{
struct vehicle_vicon_position_s pos;
if (pos_sub->update(t, &pos)) {
if (pos_sub->update(&pos_time, &pos)) {
mavlink_msg_vicon_position_estimate_send(_channel,
pos.timestamp / 1000,
pos.x,
@ -777,38 +808,29 @@ protected:
* the GCS does pick it up at one point */
if (home_sub->is_published()) {
struct home_position_s home;
home_sub->update(t, &home);
mavlink_msg_gps_global_origin_send(_channel,
(int32_t)(home.lat * 1e7),
(int32_t)(home.lon * 1e7),
(int32_t)(home.alt) * 1000.0f);
if (home_sub->update(&home)) {
mavlink_msg_gps_global_origin_send(_channel,
(int32_t)(home.lat * 1e7),
(int32_t)(home.lon * 1e7),
(int32_t)(home.alt) * 1000.0f);
}
}
}
};
template <int N>
class MavlinkStreamServoOutputRaw : public MavlinkStream
{
public:
MavlinkStreamServoOutputRaw() : MavlinkStream()
{
_instance = _n++;
}
const char *get_name() const
{
return get_name_static_int(_instance);
return MavlinkStreamServoOutputRaw<N>::get_name_static();
}
static const char *get_name_static()
{
return get_name_static_int(_n);
}
static const char *get_name_static_int(unsigned n)
{
switch (n) {
switch (N) {
case 0:
return "SERVO_OUTPUT_RAW_0";
@ -825,17 +847,18 @@ public:
static MavlinkStream *new_instance()
{
return new MavlinkStreamServoOutputRaw();
return new MavlinkStreamServoOutputRaw<N>();
}
static unsigned _n;
private:
MavlinkOrbSubscription *_act_sub;
unsigned _instance;
MavlinkOrbSubscription *act_sub;
uint64_t act_time;
protected:
explicit MavlinkStreamServoOutputRaw() : MavlinkStream(),
act_time(0)
{}
void subscribe(Mavlink *mavlink)
{
orb_id_t act_topics[] = {
@ -845,17 +868,17 @@ protected:
ORB_ID(actuator_outputs_3)
};
_act_sub = mavlink->add_orb_subscription(act_topics[_instance]);
act_sub = mavlink->add_orb_subscription(act_topics[N]);
}
void send(const hrt_abstime t)
{
struct actuator_outputs_s act;
if (_act_sub->update(t, &act)) {
if (act_sub->update(&act_time, &act)) {
mavlink_msg_servo_output_raw_send(_channel,
act.timestamp / 1000,
_instance,
N,
act.output[0],
act.output[1],
act.output[2],
@ -889,10 +912,21 @@ public:
private:
MavlinkOrbSubscription *status_sub;
uint64_t status_time;
MavlinkOrbSubscription *pos_sp_triplet_sub;
uint64_t pos_sp_triplet_time;
MavlinkOrbSubscription *act_sub;
uint64_t act_time;
protected:
explicit MavlinkStreamHILControls() : MavlinkStream(),
status_time(0),
pos_sp_triplet_time(0),
act_time(0)
{}
void subscribe(Mavlink *mavlink)
{
status_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_status));
@ -906,9 +940,9 @@ protected:
struct position_setpoint_triplet_s pos_sp_triplet;
struct actuator_outputs_s act;
bool updated = act_sub->update(t, &act);
(void)pos_sp_triplet_sub->update(t, &pos_sp_triplet);
(void)status_sub->update(t, &status);
bool updated = act_sub->update(&act_time, &act);
updated |= pos_sp_triplet_sub->update(&pos_sp_triplet_time, &pos_sp_triplet);
updated |= status_sub->update(&status_time, &status);
if (updated && (status.arming_state == ARMING_STATE_ARMED)) {
/* translate the current syste state to mavlink state and mode */
@ -1015,8 +1049,13 @@ public:
private:
MavlinkOrbSubscription *pos_sp_triplet_sub;
uint64_t pos_sp_triplet_time;
protected:
explicit MavlinkStreamGlobalPositionSetpointInt() : MavlinkStream(),
pos_sp_triplet_time(0)
{}
void subscribe(Mavlink *mavlink)
{
pos_sp_triplet_sub = mavlink->add_orb_subscription(ORB_ID(position_setpoint_triplet));
@ -1025,7 +1064,8 @@ protected:
void send(const hrt_abstime t)
{
struct position_setpoint_triplet_s pos_sp_triplet;
if (pos_sp_triplet_sub->update(t, &pos_sp_triplet)) {
if (pos_sp_triplet_sub->update(&pos_sp_triplet_time, &pos_sp_triplet)) {
mavlink_msg_global_position_setpoint_int_send(_channel,
MAV_FRAME_GLOBAL,
(int32_t)(pos_sp_triplet.current.lat * 1e7),
@ -1057,8 +1097,13 @@ public:
private:
MavlinkOrbSubscription *pos_sp_sub;
uint64_t pos_sp_time;
protected:
explicit MavlinkStreamLocalPositionSetpoint() : MavlinkStream(),
pos_sp_time(0)
{}
void subscribe(Mavlink *mavlink)
{
pos_sp_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_local_position_setpoint));
@ -1067,7 +1112,8 @@ protected:
void send(const hrt_abstime t)
{
struct vehicle_local_position_setpoint_s pos_sp;
if (pos_sp_sub->update(t, &pos_sp)) {
if (pos_sp_sub->update(&pos_sp_time, &pos_sp)) {
mavlink_msg_local_position_setpoint_send(_channel,
MAV_FRAME_LOCAL_NED,
pos_sp.x,
@ -1099,8 +1145,13 @@ public:
private:
MavlinkOrbSubscription *att_sp_sub;
uint64_t att_sp_time;
protected:
explicit MavlinkStreamRollPitchYawThrustSetpoint() : MavlinkStream(),
att_sp_time(0)
{}
void subscribe(Mavlink *mavlink)
{
att_sp_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_attitude_setpoint));
@ -1109,7 +1160,8 @@ protected:
void send(const hrt_abstime t)
{
struct vehicle_attitude_setpoint_s att_sp;
if (att_sp_sub->update(t, &att_sp)) {
if (att_sp_sub->update(&att_sp_time, &att_sp)) {
mavlink_msg_roll_pitch_yaw_thrust_setpoint_send(_channel,
att_sp.timestamp / 1000,
att_sp.roll_body,
@ -1141,8 +1193,13 @@ public:
private:
MavlinkOrbSubscription *att_rates_sp_sub;
uint64_t att_rates_sp_time;
protected:
explicit MavlinkStreamRollPitchYawRatesThrustSetpoint() : MavlinkStream(),
att_rates_sp_time(0)
{}
void subscribe(Mavlink *mavlink)
{
att_rates_sp_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_rates_setpoint));
@ -1151,7 +1208,8 @@ protected:
void send(const hrt_abstime t)
{
struct vehicle_rates_setpoint_s att_rates_sp;
if (att_rates_sp_sub->update(t, &att_rates_sp)) {
if (att_rates_sp_sub->update(&att_rates_sp_time, &att_rates_sp)) {
mavlink_msg_roll_pitch_yaw_rates_thrust_setpoint_send(_channel,
att_rates_sp.timestamp / 1000,
att_rates_sp.roll,
@ -1183,8 +1241,13 @@ public:
private:
MavlinkOrbSubscription *rc_sub;
uint64_t rc_time;
protected:
explicit MavlinkStreamRCChannelsRaw() : MavlinkStream(),
rc_time(0)
{}
void subscribe(Mavlink *mavlink)
{
rc_sub = mavlink->add_orb_subscription(ORB_ID(input_rc));
@ -1194,7 +1257,7 @@ protected:
{
struct rc_input_values rc;
if (rc_sub->update(t, &rc)) {
if (rc_sub->update(&rc_time, &rc)) {
const unsigned port_width = 8;
// Deprecated message (but still needed for compatibility!)
@ -1262,8 +1325,13 @@ public:
private:
MavlinkOrbSubscription *manual_sub;
uint64_t manual_time;
protected:
explicit MavlinkStreamManualControl() : MavlinkStream(),
manual_time(0)
{}
void subscribe(Mavlink *mavlink)
{
manual_sub = mavlink->add_orb_subscription(ORB_ID(manual_control_setpoint));
@ -1273,7 +1341,7 @@ protected:
{
struct manual_control_setpoint_s manual;
if (manual_sub->update(t, &manual)) {
if (manual_sub->update(&manual_time, &manual)) {
mavlink_msg_manual_control_send(_channel,
mavlink_system.sysid,
manual.x * 1000,
@ -1306,8 +1374,13 @@ public:
private:
MavlinkOrbSubscription *flow_sub;
uint64_t flow_time;
protected:
explicit MavlinkStreamOpticalFlow() : MavlinkStream(),
flow_time(0)
{}
void subscribe(Mavlink *mavlink)
{
flow_sub = mavlink->add_orb_subscription(ORB_ID(optical_flow));
@ -1317,7 +1390,7 @@ protected:
{
struct optical_flow_s flow;
if (flow_sub->update(t, &flow)) {
if (flow_sub->update(&flow_time, &flow)) {
mavlink_msg_optical_flow_send(_channel,
flow.timestamp,
flow.sensor_id,
@ -1349,8 +1422,13 @@ public:
private:
MavlinkOrbSubscription *att_ctrl_sub;
uint64_t att_ctrl_time;
protected:
explicit MavlinkStreamAttitudeControls() : MavlinkStream(),
att_ctrl_time(0)
{}
void subscribe(Mavlink *mavlink)
{
att_ctrl_sub = mavlink->add_orb_subscription(ORB_ID_VEHICLE_ATTITUDE_CONTROLS);
@ -1360,7 +1438,7 @@ protected:
{
struct actuator_controls_s att_ctrl;
if (att_ctrl_sub->update(t, &att_ctrl)) {
if (att_ctrl_sub->update(&att_ctrl_time, &att_ctrl)) {
/* send, add spaces so that string buffer is at least 10 chars long */
mavlink_msg_named_value_float_send(_channel,
att_ctrl.timestamp / 1000,
@ -1402,8 +1480,13 @@ public:
private:
MavlinkOrbSubscription *debug_sub;
uint64_t debug_time;
protected:
explicit MavlinkStreamNamedValueFloat() : MavlinkStream(),
debug_time(0)
{}
void subscribe(Mavlink *mavlink)
{
debug_sub = mavlink->add_orb_subscription(ORB_ID(debug_key_value));
@ -1413,7 +1496,7 @@ protected:
{
struct debug_key_value_s debug;
if (debug_sub->update(t, &debug)) {
if (debug_sub->update(&debug_time, &debug)) {
/* enforce null termination */
debug.key[sizeof(debug.key) - 1] = '\0';
@ -1455,7 +1538,7 @@ protected:
void send(const hrt_abstime t)
{
struct vehicle_status_s status;
(void)status_sub->update(t, &status);
(void)status_sub->update(&status);
if (status.arming_state == ARMING_STATE_ARMED
|| status.arming_state == ARMING_STATE_ARMED_ERROR) {
@ -1490,8 +1573,13 @@ public:
private:
MavlinkOrbSubscription *range_sub;
uint64_t range_time;
protected:
explicit MavlinkStreamDistanceSensor() : MavlinkStream(),
range_time(0)
{}
void subscribe(Mavlink *mavlink)
{
range_sub = mavlink->add_orb_subscription(ORB_ID(sensor_range_finder));
@ -1501,7 +1589,7 @@ protected:
{
struct range_finder_report range;
if (range_sub->update(t, &range)) {
if (range_sub->update(&range_time, &range)) {
uint8_t type;
@ -1521,7 +1609,6 @@ protected:
}
};
unsigned MavlinkStreamServoOutputRaw::_n = 0;
StreamListItem *streams_list[] = {
new StreamListItem(&MavlinkStreamHeartbeat::new_instance, &MavlinkStreamHeartbeat::get_name_static),
@ -1534,10 +1621,10 @@ StreamListItem *streams_list[] = {
new StreamListItem(&MavlinkStreamGlobalPositionInt::new_instance, &MavlinkStreamGlobalPositionInt::get_name_static),
new StreamListItem(&MavlinkStreamLocalPositionNED::new_instance, &MavlinkStreamLocalPositionNED::get_name_static),
new StreamListItem(&MavlinkStreamGPSGlobalOrigin::new_instance, &MavlinkStreamGPSGlobalOrigin::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw::new_instance, &MavlinkStreamServoOutputRaw::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw::new_instance, &MavlinkStreamServoOutputRaw::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw::new_instance, &MavlinkStreamServoOutputRaw::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw::new_instance, &MavlinkStreamServoOutputRaw::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw<0>::new_instance, &MavlinkStreamServoOutputRaw<0>::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw<1>::new_instance, &MavlinkStreamServoOutputRaw<1>::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw<2>::new_instance, &MavlinkStreamServoOutputRaw<2>::get_name_static),
new StreamListItem(&MavlinkStreamServoOutputRaw<3>::new_instance, &MavlinkStreamServoOutputRaw<3>::get_name_static),
new StreamListItem(&MavlinkStreamHILControls::new_instance, &MavlinkStreamHILControls::get_name_static),
new StreamListItem(&MavlinkStreamGlobalPositionSetpointInt::new_instance, &MavlinkStreamGlobalPositionSetpointInt::get_name_static),
new StreamListItem(&MavlinkStreamLocalPositionSetpoint::new_instance, &MavlinkStreamLocalPositionSetpoint::get_name_static),

View File

@ -50,7 +50,6 @@ MavlinkOrbSubscription::MavlinkOrbSubscription(const orb_id_t topic) :
_fd(orb_subscribe(_topic)),
_published(false),
_topic(topic),
_last_check(0),
next(nullptr)
{
}
@ -67,24 +66,39 @@ MavlinkOrbSubscription::get_topic() const
}
bool
MavlinkOrbSubscription::update(const hrt_abstime t, void* data)
MavlinkOrbSubscription::update(uint64_t *time, void* data)
{
if (_last_check == t) {
/* already checked right now, return result of the check */
return _updated;
// TODO this is NOT atomic operation, we can get data newer than time
// if topic was published between orb_stat and orb_copy calls.
} else {
_last_check = t;
orb_check(_fd, &_updated);
if (_updated && data) {
orb_copy(_topic, _fd, data);
_published = true;
return true;
}
uint64_t time_topic;
if (orb_stat(_fd, &time_topic)) {
/* error getting last topic publication time */
time_topic = 0;
}
return false;
if (orb_copy(_topic, _fd, data)) {
/* error copying topic data */
memset(data, 0, _topic->o_size);
return false;
} else {
/* data copied successfully */
_published = true;
if (time_topic != *time) {
*time = time_topic;
return true;
} else {
return false;
}
}
}
bool
MavlinkOrbSubscription::update(void* data)
{
return !orb_copy(_topic, _fd, data);
}
bool

View File

@ -53,7 +53,21 @@ public:
MavlinkOrbSubscription(const orb_id_t topic);
~MavlinkOrbSubscription();
bool update(const hrt_abstime t, void* data);
/**
* Check if subscription updated and get data.
*
* @return true only if topic was updated and data copied to buffer successfully.
* If topic was not updated since last check it will return false but still copy the data.
* If no data available data buffer will be filled with zeroes.
*/
bool update(uint64_t *time, void* data);
/**
* Copy topic data to given buffer.
*
* @return true only if topic data copied successfully.
*/
bool update(void* data);
/**
* Check if the topic has been published.
@ -68,8 +82,6 @@ private:
const orb_id_t _topic; ///< topic metadata
int _fd; ///< subscription handle
bool _published; ///< topic was ever published
hrt_abstime _last_check; ///< time of last check
bool _updated; ///< updated on last check
};