mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 09:28:31 -04:00
Copter: Add option to disable RPM module
This commit is contained in:
parent
2f59572d42
commit
d633ba8c46
@ -25,6 +25,7 @@
|
|||||||
//#define SPRAYER DISABLED // disable the crop sprayer feature (two ESC controlled pumps the speed of which depends upon the vehicle's horizontal velocity)
|
//#define SPRAYER DISABLED // disable the crop sprayer feature (two ESC controlled pumps the speed of which depends upon the vehicle's horizontal velocity)
|
||||||
//#define WINCH_ENABLED DISABLED // disable winch support
|
//#define WINCH_ENABLED DISABLED // disable winch support
|
||||||
//#define GRIPPER_ENABLED DISABLED // disable gripper support
|
//#define GRIPPER_ENABLED DISABLED // disable gripper support
|
||||||
|
//#define RPM_ENABLED DISABLED // disable rotations per minute sensor support
|
||||||
//#define MAGNETOMETER DISABLED // disable magnetometer support
|
//#define MAGNETOMETER DISABLED // disable magnetometer support
|
||||||
//#define STATS_ENABLED DISABLED // disable statistics support
|
//#define STATS_ENABLED DISABLED // disable statistics support
|
||||||
//#define MODE_ACRO_ENABLED DISABLED // disable acrobatic mode support
|
//#define MODE_ACRO_ENABLED DISABLED // disable acrobatic mode support
|
||||||
|
@ -151,7 +151,9 @@ const AP_Scheduler::Task Copter::scheduler_tasks[] = {
|
|||||||
SCHED_TASK_CLASS(AP_InertialSensor, &copter.ins, periodic, 400, 50),
|
SCHED_TASK_CLASS(AP_InertialSensor, &copter.ins, periodic, 400, 50),
|
||||||
SCHED_TASK_CLASS(AP_Scheduler, &copter.scheduler, update_logging, 0.1, 75),
|
SCHED_TASK_CLASS(AP_Scheduler, &copter.scheduler, update_logging, 0.1, 75),
|
||||||
SCHED_TASK(read_receiver_rssi, 10, 75),
|
SCHED_TASK(read_receiver_rssi, 10, 75),
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
SCHED_TASK(rpm_update, 10, 200),
|
SCHED_TASK(rpm_update, 10, 200),
|
||||||
|
#endif
|
||||||
SCHED_TASK(compass_cal_update, 100, 100),
|
SCHED_TASK(compass_cal_update, 100, 100),
|
||||||
SCHED_TASK(accel_cal_update, 10, 100),
|
SCHED_TASK(accel_cal_update, 10, 100),
|
||||||
SCHED_TASK_CLASS(AP_TempCalibration, &copter.g2.temp_calibration, update, 10, 100),
|
SCHED_TASK_CLASS(AP_TempCalibration, &copter.g2.temp_calibration, update, 10, 100),
|
||||||
|
@ -77,7 +77,6 @@
|
|||||||
#include <AP_BoardConfig/AP_BoardConfig.h> // board configuration library
|
#include <AP_BoardConfig/AP_BoardConfig.h> // board configuration library
|
||||||
#include <AP_BoardConfig/AP_BoardConfig_CAN.h>
|
#include <AP_BoardConfig/AP_BoardConfig_CAN.h>
|
||||||
#include <AP_LandingGear/AP_LandingGear.h> // Landing Gear library
|
#include <AP_LandingGear/AP_LandingGear.h> // Landing Gear library
|
||||||
#include <AP_RPM/AP_RPM.h>
|
|
||||||
#include <AC_InputManager/AC_InputManager.h> // Pilot input handling library
|
#include <AC_InputManager/AC_InputManager.h> // Pilot input handling library
|
||||||
#include <AC_InputManager/AC_InputManager_Heli.h> // Heli specific pilot input handling library
|
#include <AC_InputManager/AC_InputManager_Heli.h> // Heli specific pilot input handling library
|
||||||
#include <AP_Button/AP_Button.h>
|
#include <AP_Button/AP_Button.h>
|
||||||
@ -157,6 +156,9 @@
|
|||||||
# include <AP_WheelEncoder/AP_WheelEncoder.h>
|
# include <AP_WheelEncoder/AP_WheelEncoder.h>
|
||||||
# include <AP_Winch/AP_Winch.h>
|
# include <AP_Winch/AP_Winch.h>
|
||||||
#endif
|
#endif
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
|
#include <AP_RPM/AP_RPM.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
// Local modules
|
// Local modules
|
||||||
#include "Parameters.h"
|
#include "Parameters.h"
|
||||||
@ -237,7 +239,9 @@ private:
|
|||||||
int8_t glitch_count;
|
int8_t glitch_count;
|
||||||
} rangefinder_state = { false, false, 0, 0 };
|
} rangefinder_state = { false, false, 0, 0 };
|
||||||
|
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
AP_RPM rpm_sensor;
|
AP_RPM rpm_sensor;
|
||||||
|
#endif
|
||||||
|
|
||||||
// Inertial Navigation EKF
|
// Inertial Navigation EKF
|
||||||
NavEKF2 EKF2{&ahrs, rangefinder};
|
NavEKF2 EKF2{&ahrs, rangefinder};
|
||||||
|
@ -190,12 +190,14 @@ void NOINLINE Copter::send_vfr_hud(mavlink_channel_t chan)
|
|||||||
*/
|
*/
|
||||||
void NOINLINE Copter::send_rpm(mavlink_channel_t chan)
|
void NOINLINE Copter::send_rpm(mavlink_channel_t chan)
|
||||||
{
|
{
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
if (rpm_sensor.enabled(0) || rpm_sensor.enabled(1)) {
|
if (rpm_sensor.enabled(0) || rpm_sensor.enabled(1)) {
|
||||||
mavlink_msg_rpm_send(
|
mavlink_msg_rpm_send(
|
||||||
chan,
|
chan,
|
||||||
rpm_sensor.get_rpm(0),
|
rpm_sensor.get_rpm(0),
|
||||||
rpm_sensor.get_rpm(1));
|
rpm_sensor.get_rpm(1));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -366,8 +368,10 @@ bool GCS_MAVLINK_Copter::try_send_message(enum ap_message id)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case MSG_RPM:
|
case MSG_RPM:
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
CHECK_PAYLOAD_SIZE(RPM);
|
CHECK_PAYLOAD_SIZE(RPM);
|
||||||
copter.send_rpm(chan);
|
copter.send_rpm(chan);
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MSG_TERRAIN:
|
case MSG_TERRAIN:
|
||||||
|
@ -737,9 +737,11 @@ const AP_Param::Info Copter::var_info[] = {
|
|||||||
GOBJECT(precland, "PLND_", AC_PrecLand),
|
GOBJECT(precland, "PLND_", AC_PrecLand),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
// @Group: RPM
|
// @Group: RPM
|
||||||
// @Path: ../libraries/AP_RPM/AP_RPM.cpp
|
// @Path: ../libraries/AP_RPM/AP_RPM.cpp
|
||||||
GOBJECT(rpm_sensor, "RPM", AP_RPM),
|
GOBJECT(rpm_sensor, "RPM", AP_RPM),
|
||||||
|
#endif
|
||||||
|
|
||||||
#if ADSB_ENABLED == ENABLED
|
#if ADSB_ENABLED == ENABLED
|
||||||
// @Group: ADSB_
|
// @Group: ADSB_
|
||||||
|
@ -241,6 +241,12 @@
|
|||||||
# define WINCH_ENABLED !HAL_MINIMIZE_FEATURES
|
# define WINCH_ENABLED !HAL_MINIMIZE_FEATURES
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
|
// rotations per minute sensor support
|
||||||
|
#ifndef RPM_ENABLED
|
||||||
|
# define RPM_ENABLED ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// Parachute release
|
// Parachute release
|
||||||
#ifndef PARACHUTE
|
#ifndef PARACHUTE
|
||||||
|
@ -89,12 +89,14 @@ bool Copter::rangefinder_alt_ok()
|
|||||||
*/
|
*/
|
||||||
void Copter::rpm_update(void)
|
void Copter::rpm_update(void)
|
||||||
{
|
{
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
rpm_sensor.update();
|
rpm_sensor.update();
|
||||||
if (rpm_sensor.enabled(0) || rpm_sensor.enabled(1)) {
|
if (rpm_sensor.enabled(0) || rpm_sensor.enabled(1)) {
|
||||||
if (should_log(MASK_LOG_RCIN)) {
|
if (should_log(MASK_LOG_RCIN)) {
|
||||||
DataFlash.Log_Write_RPM(rpm_sensor);
|
DataFlash.Log_Write_RPM(rpm_sensor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// initialise compass
|
// initialise compass
|
||||||
|
@ -225,8 +225,10 @@ void Copter::init_ardupilot()
|
|||||||
// init visual odometry
|
// init visual odometry
|
||||||
init_visual_odom();
|
init_visual_odom();
|
||||||
|
|
||||||
|
#if RPM_ENABLED == ENABLED
|
||||||
// initialise AP_RPM library
|
// initialise AP_RPM library
|
||||||
rpm_sensor.init();
|
rpm_sensor.init();
|
||||||
|
#endif
|
||||||
|
|
||||||
#if MODE_AUTO_ENABLED == ENABLED
|
#if MODE_AUTO_ENABLED == ENABLED
|
||||||
// initialise mission library
|
// initialise mission library
|
||||||
|
Loading…
Reference in New Issue
Block a user