mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
Copter: set Heli frame default at compile-time
This commit is contained in:
parent
7f3cb09da2
commit
cf45108efb
@ -844,7 +844,6 @@ private:
|
|||||||
bool optflow_position_ok();
|
bool optflow_position_ok();
|
||||||
void update_auto_armed();
|
void update_auto_armed();
|
||||||
bool should_log(uint32_t mask);
|
bool should_log(uint32_t mask);
|
||||||
void set_default_frame_class();
|
|
||||||
MAV_TYPE get_frame_mav_type();
|
MAV_TYPE get_frame_mav_type();
|
||||||
const char* get_frame_string();
|
const char* get_frame_string();
|
||||||
void allocate_motors(void);
|
void allocate_motors(void);
|
||||||
|
@ -28,6 +28,13 @@
|
|||||||
#define GOBJECTVARPTR(v, name, var_info_ptr) { AP_PARAM_GROUP, name, Parameters::k_param_ ## v, (const void *)&copter.v, {group_info_ptr : var_info_ptr}, AP_PARAM_FLAG_POINTER | AP_PARAM_FLAG_INFO_POINTER }
|
#define GOBJECTVARPTR(v, name, var_info_ptr) { AP_PARAM_GROUP, name, Parameters::k_param_ ## v, (const void *)&copter.v, {group_info_ptr : var_info_ptr}, AP_PARAM_FLAG_POINTER | AP_PARAM_FLAG_INFO_POINTER }
|
||||||
#define GOBJECTN(v, pname, name, class) { AP_PARAM_GROUP, name, Parameters::k_param_ ## pname, (const void *)&copter.v, {group_info : class::var_info} }
|
#define GOBJECTN(v, pname, name, class) { AP_PARAM_GROUP, name, Parameters::k_param_ ## pname, (const void *)&copter.v, {group_info : class::var_info} }
|
||||||
|
|
||||||
|
#if FRAME_CONFIG == HELI_FRAME
|
||||||
|
// 6 here is AP_Motors::MOTOR_FRAME_HELI
|
||||||
|
#define DEFAULT_FRAME_CLASS 6
|
||||||
|
#else
|
||||||
|
#define DEFAULT_FRAME_CLASS 0
|
||||||
|
#endif
|
||||||
|
|
||||||
const AP_Param::Info Copter::var_info[] = {
|
const AP_Param::Info Copter::var_info[] = {
|
||||||
// @Param: SYSID_SW_MREV
|
// @Param: SYSID_SW_MREV
|
||||||
// @DisplayName: Eeprom format version number
|
// @DisplayName: Eeprom format version number
|
||||||
@ -819,7 +826,7 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
|
|||||||
// @Values: 0:Undefined, 1:Quad, 2:Hexa, 3:Octa, 4:OctaQuad, 5:Y6, 6:Heli, 7:Tri, 8:SingleCopter, 9:CoaxCopter, 10:BiCopter, 11:Heli_Dual, 12:DodecaHexa, 13:HeliQuad
|
// @Values: 0:Undefined, 1:Quad, 2:Hexa, 3:Octa, 4:OctaQuad, 5:Y6, 6:Heli, 7:Tri, 8:SingleCopter, 9:CoaxCopter, 10:BiCopter, 11:Heli_Dual, 12:DodecaHexa, 13:HeliQuad
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
// @RebootRequired: True
|
// @RebootRequired: True
|
||||||
AP_GROUPINFO("FRAME_CLASS", 15, ParametersG2, frame_class, 0),
|
AP_GROUPINFO("FRAME_CLASS", 15, ParametersG2, frame_class, DEFAULT_FRAME_CLASS),
|
||||||
|
|
||||||
// @Group: SERVO
|
// @Group: SERVO
|
||||||
// @Path: ../libraries/SRV_Channel/SRV_Channels.cpp
|
// @Path: ../libraries/SRV_Channel/SRV_Channels.cpp
|
||||||
|
@ -108,9 +108,6 @@ void Copter::init_ardupilot()
|
|||||||
|
|
||||||
init_rc_in(); // sets up rc channels from radio
|
init_rc_in(); // sets up rc channels from radio
|
||||||
|
|
||||||
// default frame class to match firmware if possible
|
|
||||||
set_default_frame_class();
|
|
||||||
|
|
||||||
// allocate the motors class
|
// allocate the motors class
|
||||||
allocate_motors();
|
allocate_motors();
|
||||||
|
|
||||||
@ -395,16 +392,6 @@ bool Copter::should_log(uint32_t mask)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// default frame_class to match firmware if possible
|
|
||||||
void Copter::set_default_frame_class()
|
|
||||||
{
|
|
||||||
if (FRAME_CONFIG == HELI_FRAME &&
|
|
||||||
g2.frame_class.get() != AP_Motors::MOTOR_FRAME_HELI_DUAL &&
|
|
||||||
g2.frame_class.get() != AP_Motors::MOTOR_FRAME_HELI_QUAD) {
|
|
||||||
g2.frame_class.set(AP_Motors::MOTOR_FRAME_HELI);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// return MAV_TYPE corresponding to frame class
|
// return MAV_TYPE corresponding to frame class
|
||||||
MAV_TYPE Copter::get_frame_mav_type()
|
MAV_TYPE Copter::get_frame_mav_type()
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user