2011-03-19 07:20:11 -03:00
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
2010-12-19 12:40:33 -04:00
2011-07-17 07:34:05 -03:00
#if CLI_ENABLED == ENABLED
2010-12-19 12:40:33 -04:00
// Functions called from the setup menu
2013-05-31 02:56:08 -03:00
static int8_t setup_factory (uint8_t argc, const Menu::arg *argv);
static int8_t setup_show (uint8_t argc, const Menu::arg *argv);
2013-03-07 04:30:45 -04:00
2011-02-19 17:04:05 -04:00
// Command/function table for the setup menu
2010-12-19 12:40:33 -04:00
const struct Menu::command setup_menu_commands[] PROGMEM = {
2012-08-21 23:19:50 -03:00
// command function called
// ======= ===============
2013-05-31 02:56:08 -03:00
{"reset", setup_factory},
2013-03-07 04:30:45 -04:00
{"show", setup_show},
2010-12-19 12:40:33 -04:00
};
// Create the setup menu object.
MENU(setup_menu, "setup", setup_menu_commands);
// Called from the top-level menu to run the setup menu.
2011-07-17 07:32:00 -03:00
static int8_t
2010-12-19 12:40:33 -04:00
setup_mode(uint8_t argc, const Menu::arg *argv)
{
2012-08-21 23:19:50 -03:00
// Give the user some guidance
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Setup Mode\n\n\n"));
2012-08-21 23:19:50 -03:00
// Run the setup menu. When the menu exits, we will return to the main menu.
setup_menu.run();
2011-07-17 07:30:21 -03:00
return 0;
2010-12-19 12:40:33 -04:00
}
2013-05-31 02:56:08 -03:00
// Initialise the EEPROM to 'factory' settings (mostly defined in APM_Config.h or via defaults).
// Called by the setup menu 'factoryreset' command.
static int8_t
setup_factory(uint8_t argc, const Menu::arg *argv)
{
int16_t c;
cliSerial->printf_P(PSTR("\n'Y' = factory reset, any other key to abort:\n"));
do {
c = cliSerial->read();
} while (-1 == c);
if (('y' != c) && ('Y' != c))
return(-1);
AP_Param::erase_all();
2013-12-27 21:42:10 -04:00
cliSerial->printf_P(PSTR("\nReboot board"));
2013-05-31 02:56:08 -03:00
delay(1000);
for (;; ) {
}
// note, cannot actually return here
return(0);
}
// Print the current configuration.
// Called by the setup menu 'show' command.
static int8_t
setup_show(uint8_t argc, const Menu::arg *argv)
{
AP_Param *param;
ap_var_type type;
//If a parameter name is given as an argument to show, print only that parameter
if(argc>=2)
{
param=AP_Param::find(argv[1].str, &type);
if(!param)
{
cliSerial->printf_P(PSTR("Parameter not found: '%s'\n"), argv[1]);
return 0;
}
AP_Param::show(param, argv[1].str, type, cliSerial);
return 0;
}
// clear the area
print_blanks(8);
report_version();
report_radio();
report_frame();
report_batt_monitor();
report_sonar();
report_flight_modes();
report_ins();
report_compass();
report_optflow();
AP_Param::show_all(cliSerial);
return(0);
}
2011-01-20 03:11:21 -04:00
/***************************************************************************/
2011-02-24 01:56:59 -04:00
// CLI reports
2011-01-20 03:11:21 -04:00
/***************************************************************************/
2011-05-09 12:46:56 -03:00
2011-07-17 07:32:00 -03:00
static void report_batt_monitor()
2011-05-09 12:46:56 -03:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("\nBatt Mon:\n"));
2012-08-21 23:19:50 -03:00
print_divider();
2013-10-01 10:34:44 -03:00
if (battery.monitoring() == AP_BATT_MONITOR_DISABLED) print_enabled(false);
if (battery.monitoring() == AP_BATT_MONITOR_VOLTAGE_ONLY) cliSerial->printf_P(PSTR("volts"));
if (battery.monitoring() == AP_BATT_MONITOR_VOLTAGE_AND_CURRENT) cliSerial->printf_P(PSTR("volts and cur"));
2012-08-21 23:19:50 -03:00
print_blanks(2);
2011-05-09 12:46:56 -03:00
}
2011-05-14 23:02:09 -03:00
2011-07-17 07:32:00 -03:00
static void report_sonar()
2011-02-20 19:09:28 -04:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Sonar\n"));
2012-08-21 23:19:50 -03:00
print_divider();
print_enabled(g.sonar_enabled.get());
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Type: %d (0=XL, 1=LV, 2=XLL, 3=HRLV)"), (int)g.sonar_type);
2012-08-21 23:19:50 -03:00
print_blanks(2);
2011-01-20 03:11:21 -04:00
}
2011-07-17 07:32:00 -03:00
static void report_frame()
2011-01-20 03:11:21 -04:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Frame\n"));
2012-08-21 23:19:50 -03:00
print_divider();
#if FRAME_CONFIG == QUAD_FRAME
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Quad frame\n"));
2012-08-21 23:19:50 -03:00
#elif FRAME_CONFIG == TRI_FRAME
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("TRI frame\n"));
2012-08-21 23:19:50 -03:00
#elif FRAME_CONFIG == HEXA_FRAME
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Hexa frame\n"));
2012-08-21 23:19:50 -03:00
#elif FRAME_CONFIG == Y6_FRAME
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Y6 frame\n"));
2012-08-21 23:19:50 -03:00
#elif FRAME_CONFIG == OCTA_FRAME
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Octa frame\n"));
2012-08-21 23:19:50 -03:00
#elif FRAME_CONFIG == HELI_FRAME
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Heli frame\n"));
2012-08-21 23:19:50 -03:00
#endif
print_blanks(2);
2011-01-20 03:11:21 -04:00
}
2011-07-17 07:32:00 -03:00
static void report_radio()
2011-01-20 03:11:21 -04:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Radio\n"));
2012-08-21 23:19:50 -03:00
print_divider();
// radio
print_radio_values();
print_blanks(2);
2011-01-20 03:11:21 -04:00
}
2012-11-05 00:32:38 -04:00
static void report_ins()
2011-01-20 03:11:21 -04:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("INS\n"));
2012-08-21 23:19:50 -03:00
print_divider();
2011-01-20 03:11:21 -04:00
2012-08-21 23:19:50 -03:00
print_gyro_offsets();
2012-11-05 00:32:38 -04:00
print_accel_offsets_and_scaling();
2012-08-21 23:19:50 -03:00
print_blanks(2);
2011-01-20 03:11:21 -04:00
}
2011-07-17 07:32:00 -03:00
static void report_flight_modes()
2011-01-20 03:11:21 -04:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Flight modes\n"));
2012-08-21 23:19:50 -03:00
print_divider();
2011-02-19 17:04:05 -04:00
2012-08-21 23:19:50 -03:00
for(int16_t i = 0; i < 6; i++ ) {
2013-04-23 10:05:42 -03:00
print_switch(i, flight_modes[i], BIT_IS_SET(g.simple_modes, i));
2012-08-21 23:19:50 -03:00
}
print_blanks(2);
2011-01-20 03:11:21 -04:00
}
2011-07-21 20:14:53 -03:00
void report_optflow()
{
2012-11-18 12:16:07 -04:00
#if OPTFLOW == ENABLED
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("OptFlow\n"));
2012-08-21 23:19:50 -03:00
print_divider();
2011-07-21 20:14:53 -03:00
2012-08-21 23:19:50 -03:00
print_enabled(g.optflow_enabled);
2011-07-21 20:14:53 -03:00
2012-08-21 23:19:50 -03:00
print_blanks(2);
2012-11-18 12:16:07 -04:00
#endif // OPTFLOW == ENABLED
2011-07-21 20:14:53 -03:00
}
2011-12-23 18:41:18 -04:00
2011-01-20 03:11:21 -04:00
/***************************************************************************/
// CLI utilities
/***************************************************************************/
2011-07-17 07:32:00 -03:00
static void
2011-01-20 03:11:21 -04:00
print_radio_values()
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("CH1: %d | %d\n"), (int)g.rc_1.radio_min, (int)g.rc_1.radio_max);
cliSerial->printf_P(PSTR("CH2: %d | %d\n"), (int)g.rc_2.radio_min, (int)g.rc_2.radio_max);
cliSerial->printf_P(PSTR("CH3: %d | %d\n"), (int)g.rc_3.radio_min, (int)g.rc_3.radio_max);
cliSerial->printf_P(PSTR("CH4: %d | %d\n"), (int)g.rc_4.radio_min, (int)g.rc_4.radio_max);
cliSerial->printf_P(PSTR("CH5: %d | %d\n"), (int)g.rc_5.radio_min, (int)g.rc_5.radio_max);
cliSerial->printf_P(PSTR("CH6: %d | %d\n"), (int)g.rc_6.radio_min, (int)g.rc_6.radio_max);
cliSerial->printf_P(PSTR("CH7: %d | %d\n"), (int)g.rc_7.radio_min, (int)g.rc_7.radio_max);
2013-07-12 09:46:03 -03:00
cliSerial->printf_P(PSTR("CH8: %d | %d\n"), (int)g.rc_8.radio_min, (int)g.rc_8.radio_max);
2010-12-19 12:40:33 -04:00
}
2011-07-17 07:32:00 -03:00
static void
2012-12-12 19:46:20 -04:00
print_switch(uint8_t p, uint8_t m, bool b)
2010-12-19 12:40:33 -04:00
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("Pos %d:\t"),p);
2013-04-20 02:18:22 -03:00
print_flight_mode(cliSerial, m);
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR(",\t\tSimple: "));
2012-08-21 23:19:50 -03:00
if(b)
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("ON\n"));
2012-08-21 23:19:50 -03:00
else
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("OFF\n"));
2010-12-19 12:40:33 -04:00
}
2011-07-17 07:32:00 -03:00
static void
2012-11-05 00:32:38 -04:00
print_accel_offsets_and_scaling(void)
2011-02-18 23:59:58 -04:00
{
2013-08-13 12:23:10 -03:00
const Vector3f &accel_offsets = ins.get_accel_offsets();
const Vector3f &accel_scale = ins.get_accel_scale();
2013-03-04 10:14:14 -04:00
cliSerial->printf_P(PSTR("A_off: %4.2f, %4.2f, %4.2f\nA_scale: %4.2f, %4.2f, %4.2f\n"),
2012-11-05 00:32:38 -04:00
(float)accel_offsets.x, // Pitch
(float)accel_offsets.y, // Roll
(float)accel_offsets.z, // YAW
(float)accel_scale.x, // Pitch
(float)accel_scale.y, // Roll
(float)accel_scale.z); // YAW
2011-02-18 23:59:58 -04:00
}
2011-07-17 07:32:00 -03:00
static void
2011-02-18 23:59:58 -04:00
print_gyro_offsets(void)
{
2013-08-13 12:23:10 -03:00
const Vector3f &gyro_offsets = ins.get_gyro_offsets();
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("G_off: %4.2f, %4.2f, %4.2f\n"),
2012-11-05 00:32:38 -04:00
(float)gyro_offsets.x,
(float)gyro_offsets.y,
(float)gyro_offsets.z);
2011-02-18 23:59:58 -04:00
}
2011-07-17 07:34:05 -03:00
#endif // CLI_ENABLED
2014-03-04 23:01:45 -04:00
// report_compass - displays compass information. Also called by compassmot.pde
static void report_compass()
{
cliSerial->printf_P(PSTR("Compass\n"));
print_divider();
print_enabled(g.compass_enabled);
// mag declination
cliSerial->printf_P(PSTR("Mag Dec: %4.4f\n"),
degrees(compass.get_declination()));
Vector3f offsets = compass.get_offsets();
// mag offsets
cliSerial->printf_P(PSTR("Mag off: %4.4f, %4.4f, %4.4f\n"),
offsets.x,
offsets.y,
offsets.z);
// motor compensation
cliSerial->print_P(PSTR("Motor Comp: "));
if( compass.motor_compensation_type() == AP_COMPASS_MOT_COMP_DISABLED ) {
cliSerial->print_P(PSTR("Off\n"));
}else{
if( compass.motor_compensation_type() == AP_COMPASS_MOT_COMP_THROTTLE ) {
cliSerial->print_P(PSTR("Throttle"));
}
if( compass.motor_compensation_type() == AP_COMPASS_MOT_COMP_CURRENT ) {
cliSerial->print_P(PSTR("Current"));
}
Vector3f motor_compensation = compass.get_motor_compensation();
cliSerial->printf_P(PSTR("\nComp Vec: %4.2f, %4.2f, %4.2f\n"),
motor_compensation.x,
motor_compensation.y,
motor_compensation.z);
}
print_blanks(1);
}
2011-07-17 07:34:05 -03:00
static void
2012-08-16 08:04:46 -03:00
print_blanks(int16_t num)
2011-07-17 07:34:05 -03:00
{
2012-08-21 23:19:50 -03:00
while(num > 0) {
num--;
2012-11-21 02:08:03 -04:00
cliSerial->println("");
2012-08-21 23:19:50 -03:00
}
2011-07-17 07:34:05 -03:00
}
static void
print_divider(void)
{
2012-08-21 23:19:50 -03:00
for (int i = 0; i < 40; i++) {
2012-11-21 02:08:03 -04:00
cliSerial->print_P(PSTR("-"));
2012-08-21 23:19:50 -03:00
}
2012-11-21 02:08:03 -04:00
cliSerial->println();
2011-07-17 07:34:05 -03:00
}
2012-11-10 02:02:34 -04:00
static void print_enabled(bool b)
2011-07-17 07:34:05 -03:00
{
2012-08-21 23:19:50 -03:00
if(b)
2012-11-21 02:08:03 -04:00
cliSerial->print_P(PSTR("en"));
2012-08-21 23:19:50 -03:00
else
2012-11-21 02:08:03 -04:00
cliSerial->print_P(PSTR("dis"));
cliSerial->print_P(PSTR("abled\n"));
2011-07-17 07:34:05 -03:00
}
static void
init_esc()
{
2013-01-24 22:34:48 -04:00
// reduce update rate to motors to 50Hz
motors.set_update_rate(50);
2013-05-16 04:32:00 -03:00
// we enable the motors directly here instead of calling output_min because output_min would send a low signal to the ESC and disrupt the calibration process
2012-08-21 23:19:50 -03:00
motors.enable();
motors.armed(true);
while(1) {
read_radio();
delay(100);
2013-08-14 00:07:35 -03:00
AP_Notify::flags.esc_calibration = true;
2012-08-21 23:19:50 -03:00
motors.throttle_pass_through();
}
2011-07-17 07:34:05 -03:00
}
static void report_version()
{
2012-11-21 02:08:03 -04:00
cliSerial->printf_P(PSTR("FW Ver: %d\n"),(int)g.k_format_version);
2012-08-21 23:19:50 -03:00
print_divider();
print_blanks(2);
2011-07-17 07:34:05 -03:00
}