Ardupilot2/ArduCopter/commands_process.pde

173 lines
4.7 KiB
Plaintext
Raw Normal View History

/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
// For changing active command mid-mission
//----------------------------------------
static void change_command(uint8_t cmd_index)
{
//Serial.printf("change_command: %d\n",cmd_index );
2011-11-16 04:16:34 -04:00
// limit range
cmd_index = min(g.command_total-1, cmd_index);
// load command
struct Location temp = get_cmd_with_index(cmd_index);
2011-11-17 01:28:56 -04:00
//Serial.printf("loading cmd: %d with id:%d\n", cmd_index, temp.id);
2011-11-16 04:16:34 -04:00
// verify it's a nav command
if (temp.id > MAV_CMD_NAV_LAST ){
2011-11-17 01:28:56 -04:00
//gcs_send_text_P(SEVERITY_LOW,PSTR("error: non-Nav cmd"));
2011-11-16 04:16:34 -04:00
} else {
// clear out command queue
2011-11-17 01:28:56 -04:00
init_commands();
// copy command to the queue
command_nav_queue = temp;
2011-11-17 01:28:56 -04:00
command_nav_index = cmd_index;
execute_nav_command();
}
}
// called by 10 Hz loop
// --------------------
static void update_commands()
{
//Serial.printf("update_commands: %d\n",increment );
// A: if we do not have any commands there is nothing to do
// B: We have completed the mission, don't redo the mission
// XXX debug
//uint8_t tmp = g.command_index.get();
//Serial.printf("command_index %u \n", tmp);
2012-01-11 03:35:05 -04:00
if (g.command_total <= 1 || g.command_index > 127)
return;
2011-11-16 04:16:34 -04:00
if(command_nav_queue.id == NO_COMMAND){
// Our queue is empty
// fill command queue with a new command if available, or exit mission
// -------------------------------------------------------------------
if (command_nav_index < (g.command_total -1)) {
command_nav_index++;
2011-11-16 04:16:34 -04:00
command_nav_queue = get_cmd_with_index(command_nav_index);
2011-11-16 04:16:34 -04:00
if (command_nav_queue.id <= MAV_CMD_NAV_LAST ){
execute_nav_command();
2011-11-16 04:16:34 -04:00
} else{
// this is a conditional command so we skip it
command_nav_queue.id = NO_COMMAND;
}
2011-11-29 02:28:51 -04:00
}else{
// we are out of commands
g.command_index = command_nav_index = 255;
// if we are on the ground, enter stabilize, else Land
if (land_complete == true){
2012-01-11 03:35:05 -04:00
// So what state does this leave us in?
// We are still in the same mode as what landed us,
// so maybe we try to continue to descend just in case we are still in the air
// This will also drive down the Iterm to -300
// We can't disarm the motors easily. We could very well be wrong
//
//init_disarm_motors();
} else {
set_mode(LAND);
}
2011-11-16 04:16:34 -04:00
}
}
2011-11-16 04:16:34 -04:00
if(command_cond_queue.id == NO_COMMAND){
// Our queue is empty
// fill command queue with a new command if available, or do nothing
// -------------------------------------------------------------------
2011-11-16 04:16:34 -04:00
// no nav commands completed yet
if (prev_nav_index == NO_COMMAND)
return;
2011-11-16 04:16:34 -04:00
if (command_cond_index >= command_nav_index){
// don't process the fututre
//command_cond_index = NO_COMMAND;
return;
2011-11-16 04:16:34 -04:00
}else if (command_cond_index == NO_COMMAND){
// start from scratch
// look at command after the most recent completed nav
command_cond_index = prev_nav_index + 1;
2011-11-16 04:16:34 -04:00
}else{
// we've completed 1 cond, look at next command for another
command_cond_index++;
}
2011-11-16 04:16:34 -04:00
if(command_cond_index < (g.command_total -2)){
// we're OK to load a new command (last command must be a nav command)
command_cond_queue = get_cmd_with_index(command_cond_index);
2011-11-16 04:16:34 -04:00
if (command_cond_queue.id > MAV_CMD_CONDITION_LAST){
// this is a do now command
process_now_command();
2011-11-16 04:16:34 -04:00
// clear command queue
command_cond_queue.id = NO_COMMAND;
2011-11-16 04:16:34 -04:00
}else if (command_cond_queue.id > MAV_CMD_NAV_LAST ){
// this is a conditional command
process_cond_command();
2011-11-16 04:16:34 -04:00
}else{
// this is a nav command, don't process
// clear the command conditional queue and index
prev_nav_index = NO_COMMAND;
command_cond_index = NO_COMMAND;
command_cond_queue.id = NO_COMMAND;
}
}
}
}
static void execute_nav_command(void)
{
// This is what we report to MAVLINK
g.command_index = command_nav_index;
// Save CMD to Log
if (g.log_bitmask & MASK_LOG_CMD)
Log_Write_Cmd(g.command_index, &command_nav_queue);
// clear navigation prameters
2012-01-20 14:08:38 -04:00
reset_nav_params();
// Act on the new command
process_nav_command();
// clear May indexes to force loading of more commands
// existing May commands are tossed.
command_cond_index = NO_COMMAND;
}
2011-11-16 04:16:34 -04:00
// called with GPS navigation update - not constantly
static void verify_commands(void)
{
2011-11-16 04:16:34 -04:00
if(verify_must()){
//Serial.printf("verified must cmd %d\n" , command_nav_index);
command_nav_queue.id = NO_COMMAND;
2011-11-16 04:16:34 -04:00
// store our most recent executed nav command
prev_nav_index = command_nav_index;
2011-11-16 04:16:34 -04:00
// Wipe existing conditionals
command_cond_index = NO_COMMAND;
command_cond_queue.id = NO_COMMAND;
2011-11-16 04:16:34 -04:00
}else{
//Serial.printf("verified must false %d\n" , command_nav_index);
}
2011-11-16 04:16:34 -04:00
if(verify_may()){
//Serial.printf("verified may cmd %d\n" , command_cond_index);
command_cond_queue.id = NO_COMMAND;
}
}