Browse Source

mavlink publish WIND_COV (#4913)

* mavlink publish WIND_COV

-closes #4678

* px4fmu-v2_default disable logger and sync configs
sbg
Daniel Agar 9 years ago committed by Lorenz Meier
parent
commit
050eedc4f8
  1. 2
      cmake/configs/nuttx_px4fmu-v2_default.cmake
  2. 13
      cmake/configs/nuttx_px4fmu-v2_ekf2.cmake
  3. 7
      cmake/configs/nuttx_px4fmu-v2_test.cmake
  4. 4
      src/modules/mavlink/mavlink_main.cpp
  5. 109
      src/modules/mavlink/mavlink_messages.cpp

2
cmake/configs/nuttx_px4fmu-v2_default.cmake

@ -101,7 +101,7 @@ set(config_module_list
# #
# Logging # Logging
# #
modules/logger #modules/logger
modules/sdlog2 modules/sdlog2
# #

13
cmake/configs/nuttx_px4fmu-v2_ekf2.cmake

@ -41,11 +41,13 @@ set(config_module_list
modules/sensors modules/sensors
#drivers/mkblctrl #drivers/mkblctrl
drivers/px4flow drivers/px4flow
drivers/oreoled #drivers/oreoled
drivers/gimbal drivers/gimbal
drivers/pwm_input drivers/pwm_input
drivers/camera_trigger drivers/camera_trigger
drivers/bst drivers/bst
#drivers/snapdragon_rc_pwm
#drivers/lis3mdl
# #
# System commands # System commands
@ -64,6 +66,9 @@ set(config_module_list
systemcmds/mtd systemcmds/mtd
systemcmds/dumpfile systemcmds/dumpfile
systemcmds/ver systemcmds/ver
#systemcmds/sd_bench
#systemcmds/tests
systemcmds/motor_ramp
# #
# General system control # General system control
@ -72,7 +77,7 @@ set(config_module_list
modules/load_mon modules/load_mon
modules/navigator modules/navigator
modules/mavlink modules/mavlink
modules/gpio_led #modules/gpio_led
modules/uavcan modules/uavcan
modules/land_detector modules/land_detector
@ -94,8 +99,8 @@ set(config_module_list
# #
# Logging # Logging
# #
modules/sdlog2
modules/logger modules/logger
modules/sdlog2
# #
# Library modules # Library modules
@ -136,7 +141,7 @@ set(config_module_list
# #
# Rover apps # Rover apps
# #
examples/rover_steering_control #examples/rover_steering_control
# #
# Demo apps # Demo apps

7
cmake/configs/nuttx_px4fmu-v2_test.cmake

@ -48,7 +48,6 @@ set(config_module_list
#drivers/bst #drivers/bst
#drivers/snapdragon_rc_pwm #drivers/snapdragon_rc_pwm
#drivers/lis3mdl #drivers/lis3mdl
#drivers/bmi160
# #
# System commands # System commands
@ -67,8 +66,9 @@ set(config_module_list
systemcmds/mtd systemcmds/mtd
systemcmds/dumpfile systemcmds/dumpfile
systemcmds/ver systemcmds/ver
systemcmds/sd_bench #systemcmds/sd_bench
systemcmds/tests systemcmds/tests
systemcmds/motor_ramp
# #
# Testing # Testing
@ -87,7 +87,7 @@ set(config_module_list
modules/load_mon modules/load_mon
modules/navigator modules/navigator
modules/mavlink modules/mavlink
modules/gpio_led #modules/gpio_led
modules/uavcan modules/uavcan
modules/land_detector modules/land_detector
@ -102,7 +102,6 @@ set(config_module_list
# #
# Vehicle Control # Vehicle Control
# #
# modules/segway # XXX Needs GCC 4.7 fix
modules/fw_pos_control_l1 modules/fw_pos_control_l1
modules/fw_att_control modules/fw_att_control
modules/mc_att_control modules/mc_att_control

4
src/modules/mavlink/mavlink_main.cpp

@ -1868,6 +1868,7 @@ Mavlink::task_main(int argc, char *argv[])
configure_stream("ESTIMATOR_STATUS", 0.5f); configure_stream("ESTIMATOR_STATUS", 0.5f);
configure_stream("ADSB_VEHICLE", 2.0f); configure_stream("ADSB_VEHICLE", 2.0f);
configure_stream("NAV_CONTROLLER_OUTPUT", 2.0f); configure_stream("NAV_CONTROLLER_OUTPUT", 2.0f);
configure_stream("WIND", 2.0f);
break; break;
case MAVLINK_MODE_ONBOARD: case MAVLINK_MODE_ONBOARD:
@ -1899,6 +1900,7 @@ Mavlink::task_main(int argc, char *argv[])
configure_stream("ESTIMATOR_STATUS", 1.0f); configure_stream("ESTIMATOR_STATUS", 1.0f);
configure_stream("ADSB_VEHICLE", 10.0f); configure_stream("ADSB_VEHICLE", 10.0f);
configure_stream("NAV_CONTROLLER_OUTPUT", 10.0f); configure_stream("NAV_CONTROLLER_OUTPUT", 10.0f);
configure_stream("WIND", 10.0f);
break; break;
case MAVLINK_MODE_OSD: case MAVLINK_MODE_OSD:
@ -1915,6 +1917,7 @@ Mavlink::task_main(int argc, char *argv[])
configure_stream("EXTENDED_SYS_STATE", 1.0f); configure_stream("EXTENDED_SYS_STATE", 1.0f);
configure_stream("ALTITUDE", 1.0f); configure_stream("ALTITUDE", 1.0f);
configure_stream("ESTIMATOR_STATUS", 1.0f); configure_stream("ESTIMATOR_STATUS", 1.0f);
configure_stream("WIND", 2.0f);
break; break;
case MAVLINK_MODE_MAGIC: case MAVLINK_MODE_MAGIC:
@ -1949,6 +1952,7 @@ Mavlink::task_main(int argc, char *argv[])
configure_stream("ESTIMATOR_STATUS", 5.0f); configure_stream("ESTIMATOR_STATUS", 5.0f);
configure_stream("ADSB_VEHICLE", 20.0f); configure_stream("ADSB_VEHICLE", 20.0f);
configure_stream("NAV_CONTROLLER_OUTPUT", 10.0f); configure_stream("NAV_CONTROLLER_OUTPUT", 10.0f);
configure_stream("WIND", 10.0f);
default: default:
break; break;
} }

109
src/modules/mavlink/mavlink_messages.cpp

@ -39,13 +39,21 @@
* @author Anton Babushkin <anton.babushkin@me.com> * @author Anton Babushkin <anton.babushkin@me.com>
*/ */
#include <px4_time.h>
#include <stdio.h> #include <stdio.h>
#include <errno.h> #include <errno.h>
#include "mavlink_main.h"
#include "mavlink_messages.h"
#include <commander/px4_custom_mode.h> #include <commander/px4_custom_mode.h>
#include <drivers/drv_pwm_output.h>
#include <drivers/drv_rc_input.h>
#include <lib/geo/geo.h> #include <lib/geo/geo.h>
#include <uORB/uORB.h> #include <mathlib/mathlib.h>
#include <px4_time.h>
#include <systemlib/err.h>
#include <systemlib/mavlink_log.h>
#include <uORB/topics/actuator_armed.h> #include <uORB/topics/actuator_armed.h>
#include <uORB/topics/actuator_controls.h> #include <uORB/topics/actuator_controls.h>
#include <uORB/topics/actuator_outputs.h> #include <uORB/topics/actuator_outputs.h>
@ -57,10 +65,10 @@
#include <uORB/topics/debug_key_value.h> #include <uORB/topics/debug_key_value.h>
#include <uORB/topics/distance_sensor.h> #include <uORB/topics/distance_sensor.h>
#include <uORB/topics/estimator_status.h> #include <uORB/topics/estimator_status.h>
#include <uORB/topics/fw_pos_ctrl_status.h>
#include <uORB/topics/home_position.h> #include <uORB/topics/home_position.h>
#include <uORB/topics/manual_control_setpoint.h> #include <uORB/topics/manual_control_setpoint.h>
#include <uORB/topics/mavlink_log.h> #include <uORB/topics/mavlink_log.h>
#include <uORB/topics/fw_pos_ctrl_status.h>
#include <uORB/topics/optical_flow.h> #include <uORB/topics/optical_flow.h>
#include <uORB/topics/position_setpoint_triplet.h> #include <uORB/topics/position_setpoint_triplet.h>
#include <uORB/topics/sensor_combined.h> #include <uORB/topics/sensor_combined.h>
@ -79,15 +87,9 @@
#include <uORB/topics/vehicle_status.h> #include <uORB/topics/vehicle_status.h>
#include <uORB/topics/vision_position_estimate.h> #include <uORB/topics/vision_position_estimate.h>
#include <uORB/topics/vtol_vehicle_status.h> #include <uORB/topics/vtol_vehicle_status.h>
#include <drivers/drv_rc_input.h> #include <uORB/topics/wind_estimate.h>
#include <drivers/drv_pwm_output.h> #include <uORB/uORB.h>
#include <systemlib/err.h>
#include <systemlib/mavlink_log.h>
#include <mathlib/mathlib.h>
#include "mavlink_messages.h"
#include "mavlink_main.h"
static uint16_t cm_uint16_from_m_float(float m); static uint16_t cm_uint16_from_m_float(float m);
static void get_mavlink_mode_state(struct vehicle_status_s *status, uint8_t *mavlink_state, static void get_mavlink_mode_state(struct vehicle_status_s *status, uint8_t *mavlink_state,
@ -3127,6 +3129,90 @@ protected:
} }
}; };
class MavlinkStreamWind : public MavlinkStream
{
public:
const char *get_name() const
{
return MavlinkStreamWind::get_name_static();
}
static const char *get_name_static()
{
return "WIND";
}
static uint8_t get_id_static()
{
return MAVLINK_MSG_ID_WIND_COV;
}
uint8_t get_id()
{
return get_id_static();
}
static MavlinkStream *new_instance(Mavlink *mavlink)
{
return new MavlinkStreamWind(mavlink);
}
unsigned get_size()
{
return MAVLINK_MSG_ID_WIND_COV_LEN + MAVLINK_NUM_NON_PAYLOAD_BYTES;
}
private:
MavlinkOrbSubscription *_wind_estimate_sub;
uint64_t _wind_estimate_time;
MavlinkOrbSubscription *_global_pos_sub;
uint64_t _global_pos_time;
/* do not allow top copying this class */
MavlinkStreamWind(MavlinkStreamWind &);
MavlinkStreamWind& operator = (const MavlinkStreamWind &);
protected:
explicit MavlinkStreamWind(Mavlink *mavlink) : MavlinkStream(mavlink),
_wind_estimate_sub(_mavlink->add_orb_subscription(ORB_ID(wind_estimate))),
_wind_estimate_time(0),
_global_pos_sub(_mavlink->add_orb_subscription(ORB_ID(vehicle_global_position))),
_global_pos_time(0)
{}
void send(const hrt_abstime t)
{
struct wind_estimate_s wind_estimate;
bool updated = _wind_estimate_sub->update(&_wind_estimate_time, &wind_estimate);
if (updated) {
mavlink_wind_cov_t msg;
msg.time_usec = wind_estimate.timestamp;
msg.wind_x = wind_estimate.windspeed_north;
msg.wind_y = wind_estimate.windspeed_east;
msg.wind_z = 0.0f;
msg.var_horiz = wind_estimate.covariance_north + wind_estimate.covariance_east;
msg.var_vert = 0.0f;
struct vehicle_global_position_s global_pos;
_global_pos_sub->update(&_global_pos_time, &global_pos);
msg.wind_alt = (_global_pos_time > 0) ? global_pos.alt : NAN;
msg.horiz_accuracy = 0.0f;
msg.vert_accuracy = 0.0f;
mavlink_msg_wind_cov_send_struct(_mavlink->get_channel(), &msg);
}
}
};
const StreamListItem *streams_list[] = { const StreamListItem *streams_list[] = {
new StreamListItem(&MavlinkStreamHeartbeat::new_instance, &MavlinkStreamHeartbeat::get_name_static, &MavlinkStreamHeartbeat::get_id_static), new StreamListItem(&MavlinkStreamHeartbeat::new_instance, &MavlinkStreamHeartbeat::get_name_static, &MavlinkStreamHeartbeat::get_id_static),
new StreamListItem(&MavlinkStreamStatustext::new_instance, &MavlinkStreamStatustext::get_name_static, &MavlinkStreamStatustext::get_id_static), new StreamListItem(&MavlinkStreamStatustext::new_instance, &MavlinkStreamStatustext::get_name_static, &MavlinkStreamStatustext::get_id_static),
@ -3169,5 +3255,6 @@ const StreamListItem *streams_list[] = {
new StreamListItem(&MavlinkStreamExtendedSysState::new_instance, &MavlinkStreamExtendedSysState::get_name_static, &MavlinkStreamExtendedSysState::get_id_static), new StreamListItem(&MavlinkStreamExtendedSysState::new_instance, &MavlinkStreamExtendedSysState::get_name_static, &MavlinkStreamExtendedSysState::get_id_static),
new StreamListItem(&MavlinkStreamAltitude::new_instance, &MavlinkStreamAltitude::get_name_static, &MavlinkStreamAltitude::get_id_static), new StreamListItem(&MavlinkStreamAltitude::new_instance, &MavlinkStreamAltitude::get_name_static, &MavlinkStreamAltitude::get_id_static),
new StreamListItem(&MavlinkStreamADSBVehicle::new_instance, &MavlinkStreamADSBVehicle::get_name_static, &MavlinkStreamADSBVehicle::get_id_static), new StreamListItem(&MavlinkStreamADSBVehicle::new_instance, &MavlinkStreamADSBVehicle::get_name_static, &MavlinkStreamADSBVehicle::get_id_static),
new StreamListItem(&MavlinkStreamWind::new_instance, &MavlinkStreamWind::get_name_static, &MavlinkStreamWind::get_id_static),
nullptr nullptr
}; };

Loading…
Cancel
Save