From b8c7b8a786b2f299acdf513080c6860e330b9d36 Mon Sep 17 00:00:00 2001 From: Amilcar Lucas Date: Sun, 5 Aug 2012 23:08:31 +0200 Subject: [PATCH] RC_Channel: Allow each channel to know who they are, this simplifies the enabling and output function calls. --- ArduCopter/ArduCopter.pde | 11 ++++------- ArduCopter/Parameters.h | 14 ++++++++++++++ ArduCopter/radio.pde | 10 ++-------- ArduPlane/ArduPlane.pde | 1 + ArduPlane/Parameters.h | 14 ++++++++++++++ ArduPlane/radio.pde | 21 ++++++--------------- libraries/RC_Channel/RC_Channel.cpp | 12 ++++++++++++ libraries/RC_Channel/RC_Channel.h | 8 ++++++-- libraries/RC_Channel/RC_Channel_aux.cpp | 11 +++++++++++ libraries/RC_Channel/RC_Channel_aux.h | 5 +++-- 10 files changed, 73 insertions(+), 34 deletions(-) diff --git a/ArduCopter/ArduCopter.pde b/ArduCopter/ArduCopter.pde index 673b0d6950..21711093c1 100644 --- a/ArduCopter/ArduCopter.pde +++ b/ArduCopter/ArduCopter.pde @@ -1271,10 +1271,6 @@ static void fifty_hz_loop() // set-up channel 6 to control pitch camera_mount.set_manual_rc_channel( &g.rc_6 ); - // enable output channels - g.rc_camera_roll.enable_out_ch(CH_CAM_ROLL); - g.rc_camera_pitch.enable_out_ch(CH_CAM_PITCH); - g.rc_camera_yaw.enable_out_ch(CH_CAM_YAW); } // update pilot's commands to mount @@ -1288,9 +1284,9 @@ static void fifty_hz_loop() camera_mount.update_mount_position(); // move camera servos. TO-DO: move this to AP_Mount library - g.rc_camera_roll.output_ch(CH_CAM_ROLL); - g.rc_camera_pitch.output_ch(CH_CAM_PITCH); - g.rc_camera_yaw.output_ch(CH_CAM_PITCH); + g.rc_camera_roll.output(); + g.rc_camera_pitch.output(); + g.rc_camera_yaw.output(); #endif #if CAMERA == ENABLED @@ -1354,6 +1350,7 @@ static void slow_loop() #if MOUNT == ENABLED update_aux_servo_function(&g.rc_camera_roll, &g.rc_camera_pitch, &g.rc_camera_yaw); #endif + enable_aux_servos(); #if MOUNT == ENABLED camera_mount.update_mount_type(); diff --git a/ArduCopter/Parameters.h b/ArduCopter/Parameters.h index daa74c69ca..d8c8d20e64 100644 --- a/ArduCopter/Parameters.h +++ b/ArduCopter/Parameters.h @@ -399,6 +399,20 @@ public: ch7_option (CH7_OPTION), auto_slew_rate (AUTO_SLEW_RATE), + rc_1 (CH_1), + rc_2 (CH_2), + rc_3 (CH_3), + rc_4 (CH_4), + rc_5 (CH_5), + rc_6 (CH_6), + rc_7 (CH_7), + rc_8 (CH_8), +#if MOUNT == ENABLED + rc_camera_roll (CH_9), + rc_camera_pitch (CH_10), + rc_camera_yaw (CH_11), +#endif + rc_speed(RC_FAST_SPEED), stabilize_d (STABILIZE_D), diff --git a/ArduCopter/radio.pde b/ArduCopter/radio.pde index cd2ceb2026..9f085dbc6e 100644 --- a/ArduCopter/radio.pde +++ b/ArduCopter/radio.pde @@ -64,14 +64,6 @@ static void init_rc_out() { APM_RC.Init( &isr_registry ); // APM Radio initialization -#if CONFIG_APM_HARDWARE != APM_HARDWARE_APM1 - APM_RC.enable_out(CH_9); - APM_RC.enable_out(CH_10); - APM_RC.enable_out(CH_11); - APM_RC.OutputCh(CH_9, g.rc_9.radio_trim); - APM_RC.OutputCh(CH_10, g.rc_10.radio_trim); - APM_RC.OutputCh(CH_11, g.rc_11.radio_trim); -#endif #if INSTANT_PWM == 1 motors.set_update_rate(AP_MOTORS_SPEED_INSTANT_PWM); #else @@ -123,6 +115,8 @@ static void init_rc_out() // send miinimum throttle out to ESC output_min(); } + + enable_aux_servos(); } void output_min() diff --git a/ArduPlane/ArduPlane.pde b/ArduPlane/ArduPlane.pde index 06eac72de7..b7b1dc92e8 100644 --- a/ArduPlane/ArduPlane.pde +++ b/ArduPlane/ArduPlane.pde @@ -908,6 +908,7 @@ static void slow_loop() #else update_aux_servo_function(&g.rc_5, &g.rc_6, &g.rc_7, &g.rc_8, &g.rc_9, &g.rc_10, &g.rc_11); #endif + enable_aux_servos(); #if MOUNT == ENABLED camera_mount.update_mount_type(); diff --git a/ArduPlane/Parameters.h b/ArduPlane/Parameters.h index b97e2f604e..670c079fc2 100644 --- a/ArduPlane/Parameters.h +++ b/ArduPlane/Parameters.h @@ -485,6 +485,20 @@ public: inverted_flight_ch (0), sonar_enabled (SONAR_ENABLED), + channel_roll (CH_1), + channel_pitch (CH_2), + channel_throttle (CH_3), + channel_rudder (CH_4), + rc_5 (CH_5), + rc_6 (CH_6), + rc_7 (CH_7), + rc_8 (CH_8), +#if CONFIG_APM_HARDWARE == APM_HARDWARE_APM2 + rc_9 (CH_9), + rc_10 (CH_10), + rc_11 (CH_11), +#endif + // PID controller initial P initial I initial D initial imax //----------------------------------------------------------------------------------- pidNavRoll (NAV_ROLL_P, NAV_ROLL_I, NAV_ROLL_D, NAV_ROLL_INT_MAX_CENTIDEGREE), diff --git a/ArduPlane/radio.pde b/ArduPlane/radio.pde index 8127519230..8c07bfcaab 100644 --- a/ArduPlane/radio.pde +++ b/ArduPlane/radio.pde @@ -50,20 +50,11 @@ static void init_rc_out() { APM_RC.Init( &isr_registry ); // APM Radio initialization - APM_RC.enable_out(CH_1); - APM_RC.enable_out(CH_2); - APM_RC.enable_out(CH_3); - APM_RC.enable_out(CH_4); - APM_RC.enable_out(CH_5); - APM_RC.enable_out(CH_6); - APM_RC.enable_out(CH_7); - APM_RC.enable_out(CH_8); - -#if CONFIG_APM_HARDWARE != APM_HARDWARE_APM1 - APM_RC.enable_out(CH_9); - APM_RC.enable_out(CH_10); - APM_RC.enable_out(CH_11); -#endif + APM_RC.enable_out(CH_1); + APM_RC.enable_out(CH_2); + APM_RC.enable_out(CH_3); + APM_RC.enable_out(CH_4); + enable_aux_servos(); APM_RC.OutputCh(CH_1, g.channel_roll.radio_trim); // Initialization of servo outputs APM_RC.OutputCh(CH_2, g.channel_pitch.radio_trim); @@ -114,7 +105,7 @@ static void read_radio() if (g.channel_throttle.servo_out > 50) { if (airspeed.use()) { airspeed_nudge = (g.flybywire_airspeed_max * 100 - g.airspeed_cruise_cm) * ((g.channel_throttle.norm_input()-0.5) / 0.5); - } else { + } else { throttle_nudge = (g.throttle_max - g.throttle_cruise) * ((g.channel_throttle.norm_input()-0.5) / 0.5); } } else { diff --git a/libraries/RC_Channel/RC_Channel.cpp b/libraries/RC_Channel/RC_Channel.cpp index aed36883d4..afa22eef54 100644 --- a/libraries/RC_Channel/RC_Channel.cpp +++ b/libraries/RC_Channel/RC_Channel.cpp @@ -331,3 +331,15 @@ void RC_Channel::set_apm_rc( APM_RC_Class * apm_rc ) { _apm_rc = apm_rc; } + +void +RC_Channel::output() +{ + _apm_rc->OutputCh(_ch_out, radio_out); +} + +void +RC_Channel::enable_out() +{ + _apm_rc->enable_out(_ch_out); +} diff --git a/libraries/RC_Channel/RC_Channel.h b/libraries/RC_Channel/RC_Channel.h index ca3fc504ac..afaa3cc490 100644 --- a/libraries/RC_Channel/RC_Channel.h +++ b/libraries/RC_Channel/RC_Channel.h @@ -18,7 +18,7 @@ class RC_Channel{ /// @param key EEPROM storage key for the channel trim parameters. /// @param name Optional name for the group. /// - RC_Channel() : + RC_Channel(uint8_t ch_out) : radio_min (1100), radio_trim(1500), radio_max (1900), @@ -26,7 +26,8 @@ class RC_Channel{ _filter(false), _reverse(1), _dead_zone(0), - _high(1) {} + _high(1), + _ch_out(ch_out) {} // setup min and max radio values in CLI void update_min_max(); @@ -90,6 +91,8 @@ class RC_Channel{ float scale_output; static void set_apm_rc(APM_RC_Class * apm_rc); + void output(); + void enable_out(); static APM_RC_Class *_apm_rc; static const struct AP_Param::GroupInfo var_info[]; @@ -103,6 +106,7 @@ class RC_Channel{ int16_t _low; int16_t _high_out; int16_t _low_out; + uint8_t _ch_out; }; // This is ugly, but it fixes compilation on arduino diff --git a/libraries/RC_Channel/RC_Channel_aux.cpp b/libraries/RC_Channel/RC_Channel_aux.cpp index 1ad7134e29..5462d05c53 100644 --- a/libraries/RC_Channel/RC_Channel_aux.cpp +++ b/libraries/RC_Channel/RC_Channel_aux.cpp @@ -190,3 +190,14 @@ void update_aux_servo_function( RC_Channel_aux* rc_a, g_rc_function[RC_Channel_aux::k_cam_trigger]->angle_max / 10); G_RC_AUX(k_egg_drop)->set_range(0,100); } + +/// Should be called after the the servo functions have been initialized +void +enable_aux_servos() +{ + for (uint8_t i = 0; i < RC_Channel_aux::k_nr_aux_servo_functions ; i++) + { + if (g_rc_function[i]) g_rc_function[i]->enable_out(); + } +} + diff --git a/libraries/RC_Channel/RC_Channel_aux.h b/libraries/RC_Channel/RC_Channel_aux.h index 2a248ae4fb..5cf8eb8123 100644 --- a/libraries/RC_Channel/RC_Channel_aux.h +++ b/libraries/RC_Channel/RC_Channel_aux.h @@ -23,8 +23,8 @@ public: /// @param key EEPROM storage key for the channel trim parameters. /// @param name Optional name for the group. /// - RC_Channel_aux() : - RC_Channel(), + RC_Channel_aux(uint8_t ch_out) : + RC_Channel(ch_out), function (0), angle_min (-4500), // assume -45 degrees min deflection angle_max (4500) // assume 45 degrees max deflection @@ -67,6 +67,7 @@ public: }; void update_aux_servo_function(RC_Channel_aux* rc_a = NULL, RC_Channel_aux* rc_b = NULL, RC_Channel_aux* rc_c = NULL, RC_Channel_aux* rc_d = NULL, RC_Channel_aux* rc_e = NULL, RC_Channel_aux* rc_f = NULL, RC_Channel_aux* rc_g = NULL); +void enable_aux_servos(); extern RC_Channel_aux* g_rc_function[RC_Channel_aux::k_nr_aux_servo_functions]; // the aux. servo ch. assigned to each function #endif /* RC_CHANNEL_AUX_H_ */