mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 10:28:29 -04:00
Merge branch 'master' of https://code.google.com/p/ardupilot-mega
This commit is contained in:
commit
2337153966
@ -27,7 +27,7 @@
|
||||
V_FRAME
|
||||
*/
|
||||
|
||||
# define CH7_OPTION CH7_DO_NOTHING
|
||||
# define CH7_OPTION CH7_SAVE_WP
|
||||
/*
|
||||
CH7_DO_NOTHING
|
||||
CH7_SET_HOVER
|
||||
|
@ -299,16 +299,18 @@ static bool did_ground_start = false; // have we ground started after first ar
|
||||
|
||||
// Location & Navigation
|
||||
// ---------------------
|
||||
static bool nav_ok;
|
||||
static const float radius_of_earth = 6378100; // meters
|
||||
static const float gravity = 9.81; // meters/ sec^2
|
||||
static int32_t target_bearing; // deg * 100 : 0 to 360 location of the plane to the target
|
||||
|
||||
static byte wp_control; // used to control - navgation or loiter
|
||||
|
||||
static byte command_must_index; // current command memory location
|
||||
static byte command_may_index; // current command memory location
|
||||
static byte command_must_ID; // current command ID
|
||||
static byte command_may_ID; // current command ID
|
||||
static byte command_nav_index; // current command memory location
|
||||
static byte prev_nav_index;
|
||||
static byte command_cond_index; // current command memory location
|
||||
//static byte command_nav_ID; // current command ID
|
||||
//static byte command_cond_ID; // current command ID
|
||||
static byte wp_verify_byte; // used for tracking state of navigating waypoints
|
||||
|
||||
static float cos_roll_x = 1;
|
||||
@ -317,16 +319,20 @@ static float cos_yaw_x = 1;
|
||||
static float sin_pitch_y, sin_yaw_y, sin_roll_y;
|
||||
static int32_t initial_simple_bearing; // used for Simple mode
|
||||
static float simple_sin_y, simple_cos_x;
|
||||
static byte jump = -10; // used to track loops in jump command
|
||||
static int8_t jump = -10; // used to track loops in jump command
|
||||
static int16_t waypoint_speed_gov;
|
||||
|
||||
static float circle_angle;
|
||||
// replace with param
|
||||
static const float circle_rate = 0.0872664625;
|
||||
|
||||
// Acro
|
||||
#if CH7_OPTION == CH7_FLIP
|
||||
static bool do_flip = false;
|
||||
#endif
|
||||
|
||||
static boolean trim_flag;
|
||||
static int16_t CH7_wp_index = 0;
|
||||
static int8_t CH7_wp_index;
|
||||
|
||||
// Airspeed
|
||||
// --------
|
||||
@ -458,7 +464,8 @@ static struct Location prev_WP; // last waypoint
|
||||
static struct Location current_loc; // current location
|
||||
static struct Location next_WP; // next waypoint
|
||||
static struct Location target_WP; // where do we want to you towards?
|
||||
static struct Location next_command; // command preloaded
|
||||
static struct Location command_nav_queue; // command preloaded
|
||||
static struct Location command_cond_queue; // command preloaded
|
||||
static struct Location guided_WP; // guided mode waypoint
|
||||
static int32_t target_altitude; // used for
|
||||
static boolean home_is_set; // Flag for if we have g_gps lock and have set the home location
|
||||
@ -613,9 +620,8 @@ static void medium_loop()
|
||||
update_GPS();
|
||||
}
|
||||
|
||||
//readCommands();
|
||||
|
||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||
#if HIL_MODE != HIL_MODE_ATTITUDE // don't execute in HIL mode
|
||||
if(g.compass_enabled){
|
||||
compass.read(); // Read magnetometer
|
||||
compass.calculate(dcm.get_dcm_matrix()); // Calculate heading
|
||||
@ -637,18 +643,14 @@ static void medium_loop()
|
||||
medium_loopCounter++;
|
||||
|
||||
// Auto control modes:
|
||||
if(g_gps->new_data && g_gps->fix){
|
||||
if(nav_ok){
|
||||
// clear nav flag
|
||||
nav_ok = false;
|
||||
|
||||
// invalidate GPS data
|
||||
// -------------------
|
||||
g_gps->new_data = false;
|
||||
|
||||
// we are not tracking I term on navigation, so this isn't needed
|
||||
dTnav = (float)(millis() - nav_loopTimer)/ 1000.0;
|
||||
nav_loopTimer = millis();
|
||||
|
||||
// prevent runup from bad GPS
|
||||
dTnav = min(dTnav, 1.0);
|
||||
|
||||
// calculate the copter's desired bearing and WP distance
|
||||
// ------------------------------------------------------
|
||||
if(navigate()){
|
||||
@ -660,10 +662,7 @@ static void medium_loop()
|
||||
if (g.log_bitmask & MASK_LOG_NTUN)
|
||||
Log_Write_Nav_Tuning();
|
||||
}
|
||||
}else{
|
||||
g_gps->new_data = false;
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
// command processing
|
||||
@ -673,7 +672,9 @@ static void medium_loop()
|
||||
|
||||
// Read altitude from sensors
|
||||
// --------------------------
|
||||
#if HIL_MODE != HIL_MODE_ATTITUDE // don't execute in HIL mode
|
||||
update_altitude();
|
||||
#endif
|
||||
|
||||
// invalidate the throttle hold value
|
||||
// ----------------------------------
|
||||
@ -689,7 +690,9 @@ static void medium_loop()
|
||||
// perform next command
|
||||
// --------------------
|
||||
if(control_mode == AUTO){
|
||||
update_commands();
|
||||
if(home_is_set == true && g.command_total > 1){
|
||||
update_commands(true);
|
||||
}
|
||||
}
|
||||
|
||||
if(motor_armed){
|
||||
@ -895,18 +898,27 @@ static void update_GPS(void)
|
||||
gps_watchdog++;
|
||||
}else{
|
||||
// we have lost GPS signal for a moment. Reduce our error to avoid flyaways
|
||||
// commented temporarily
|
||||
//nav_roll >>= 1;
|
||||
//nav_pitch >>= 1;
|
||||
nav_roll >>= 1;
|
||||
nav_pitch >>= 1;
|
||||
}
|
||||
|
||||
if (g_gps->new_data && g_gps->fix) {
|
||||
gps_watchdog = 0;
|
||||
|
||||
// OK to run the nav routines
|
||||
nav_ok = true;
|
||||
|
||||
// for performance
|
||||
// ---------------
|
||||
gps_fix_count++;
|
||||
|
||||
// we are not tracking I term on navigation, so this isn't needed
|
||||
dTnav = (float)(millis() - nav_loopTimer)/ 1000.0;
|
||||
nav_loopTimer = millis();
|
||||
|
||||
// prevent runup from bad GPS
|
||||
dTnav = min(dTnav, 1.0);
|
||||
|
||||
if(ground_start_count > 1){
|
||||
ground_start_count--;
|
||||
|
||||
@ -930,6 +942,13 @@ static void update_GPS(void)
|
||||
if (g.log_bitmask & MASK_LOG_GPS){
|
||||
Log_Write_GPS();
|
||||
}
|
||||
|
||||
#if HIL_MODE == HIL_MODE_ATTITUDE // only execute in HIL mode
|
||||
update_altitude();
|
||||
#endif
|
||||
|
||||
} else {
|
||||
g_gps->new_data = false;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1209,32 +1228,50 @@ static void update_trig(void){
|
||||
static void update_altitude()
|
||||
{
|
||||
altitude_sensor = BARO;
|
||||
//current_loc.alt = g_gps->altitude - gps_base_alt;
|
||||
//climb_rate = (g_gps->altitude - old_baro_alt) * 10;
|
||||
//old_baro_alt = g_gps->altitude;
|
||||
//baro_alt = g_gps->altitude;
|
||||
|
||||
#if HIL_MODE == HIL_MODE_ATTITUDE
|
||||
current_loc.alt = g_gps->altitude - gps_base_alt;
|
||||
climb_rate = (g_gps->altitude - old_baro_alt) * 10;
|
||||
old_baro_alt = g_gps->altitude;
|
||||
return;
|
||||
#else
|
||||
// we are in the SIM, fake out the baro and Sonar
|
||||
int fake_relative_alt = g_gps->altitude - gps_base_alt;
|
||||
baro_alt = fake_relative_alt;
|
||||
sonar_alt = fake_relative_alt;
|
||||
|
||||
baro_rate = (baro_alt - old_baro_alt) * 5; // 5hz
|
||||
old_baro_alt = baro_alt;
|
||||
|
||||
#else
|
||||
// This is real life
|
||||
// calc the vertical accel rate
|
||||
int temp_baro_alt = (barometer._offset_press - barometer.RawPress) << 1; // invert and scale
|
||||
baro_rate = (temp_baro_alt - old_baro_alt) * 10;
|
||||
old_baro_alt = temp_baro_alt;
|
||||
|
||||
// read in Actual Baro Altitude
|
||||
baro_alt = (baro_alt + read_barometer()) >> 1;
|
||||
|
||||
// sonar_alt is calculaed in a faster loop and filtered with a mode filter
|
||||
#endif
|
||||
|
||||
// calc the vertical accel rate
|
||||
int temp_alt = (barometer._offset_press - barometer.RawPress) << 1; // invert and scale
|
||||
baro_rate = (temp_alt - old_baro_alt) * 10;
|
||||
old_baro_alt = temp_alt;
|
||||
|
||||
if(g.sonar_enabled){
|
||||
// filter out offset
|
||||
float scale;
|
||||
|
||||
// read barometer
|
||||
baro_alt = (baro_alt + read_barometer()) >> 1;
|
||||
|
||||
// calc rate of change for Sonar
|
||||
sonar_rate = (sonar_alt - old_sonar_alt) * 10;
|
||||
old_sonar_alt = sonar_alt;
|
||||
|
||||
if(baro_alt < 700){
|
||||
#if HIL_MODE == HIL_MODE_ATTITUDE
|
||||
// we are in the SIM, fake outthe Sonar rate
|
||||
sonar_rate = baro_rate;
|
||||
#else
|
||||
// This is real life
|
||||
// calc the vertical accel rate
|
||||
sonar_rate = (sonar_alt - old_sonar_alt) * 10;
|
||||
old_sonar_alt = sonar_alt;
|
||||
#endif
|
||||
|
||||
if(baro_alt < 800){
|
||||
#if SONAR_TILT_CORRECTION == 1
|
||||
// correct alt for angle of the sonar
|
||||
float temp = cos_pitch_x * cos_roll_x;
|
||||
@ -1246,22 +1283,23 @@ static void update_altitude()
|
||||
scale = constrain(scale, 0, 1);
|
||||
|
||||
current_loc.alt = ((float)sonar_alt * (1.0 - scale)) + ((float)baro_alt * scale) + home.alt;
|
||||
|
||||
// solve for a blended climb_rate
|
||||
climb_rate = ((float)sonar_rate * (1.0 - scale)) + (float)baro_rate * scale;
|
||||
|
||||
}else{
|
||||
current_loc.alt = baro_alt + home.alt;
|
||||
climb_rate = baro_rate;
|
||||
// we must be higher than sonar, don't get tricked by bad sonar reads
|
||||
current_loc.alt = baro_alt + home.alt; // home alt = 0
|
||||
// dont blend, go straight baro
|
||||
climb_rate = baro_rate;
|
||||
}
|
||||
|
||||
}else{
|
||||
// No Sonar Case
|
||||
baro_alt = read_barometer();
|
||||
|
||||
// NO Sonar case
|
||||
current_loc.alt = baro_alt + home.alt;
|
||||
climb_rate = baro_rate;
|
||||
}
|
||||
|
||||
|
||||
#endif
|
||||
}
|
||||
|
||||
static void
|
||||
@ -1419,10 +1457,17 @@ static void update_nav_wp()
|
||||
|
||||
// create a virtual waypoint that circles the next_WP
|
||||
// Count the degrees we have circulated the WP
|
||||
int circle_angle = wrap_360(target_bearing + 3000 + 18000) / 100;
|
||||
//int circle_angle = wrap_360(target_bearing + 3000 + 18000) / 100;
|
||||
|
||||
target_WP.lng = next_WP.lng + (g.loiter_radius * cos(radians(90 - circle_angle)));
|
||||
target_WP.lat = next_WP.lat + (g.loiter_radius * sin(radians(90 - circle_angle)));
|
||||
circle_angle += (circle_rate * dTnav);
|
||||
//1° = 0.0174532925 radians
|
||||
|
||||
// wrap
|
||||
if (circle_angle > 6.28318531)
|
||||
circle_angle -= 6.28318531;
|
||||
|
||||
target_WP.lng = next_WP.lng + (g.loiter_radius * cos(1.57 - circle_angle) * scaleLongUp);
|
||||
target_WP.lat = next_WP.lat + (g.loiter_radius * sin(1.57 - circle_angle));
|
||||
|
||||
// calc the lat and long error to the target
|
||||
calc_location_error(&target_WP);
|
||||
@ -1431,9 +1476,14 @@ static void update_nav_wp()
|
||||
// nav_lon, nav_lat is calculated
|
||||
calc_loiter(long_error, lat_error);
|
||||
|
||||
//CIRCLE: angle:29, dist:0, lat:400, lon:242
|
||||
|
||||
// rotate pitch and roll to the copter frame of reference
|
||||
calc_loiter_pitch_roll();
|
||||
|
||||
//int angleTest = degrees(circle_angle);
|
||||
//int nroll = nav_roll;
|
||||
//int npitch = nav_pitch;
|
||||
//Serial.printf("CIRCLE: angle:%d, dist:%d, X:%d, Y:%d, P:%d, R:%d \n", angleTest, (int)wp_distance , (int)long_error, (int)lat_error, npitch, nroll);
|
||||
} else {
|
||||
// use error as the desired rate towards the target
|
||||
calc_nav_rate(g.waypoint_speed_max);
|
||||
|
@ -140,14 +140,23 @@ static void reset_hold_I(void)
|
||||
// Keeps outdated data out of our calculations
|
||||
static void reset_nav(void)
|
||||
{
|
||||
nav_throttle = 0;
|
||||
invalid_throttle = true;
|
||||
nav_throttle = 0;
|
||||
invalid_throttle = true;
|
||||
|
||||
g.pi_nav_lat.reset_I();
|
||||
g.pi_nav_lon.reset_I();
|
||||
|
||||
long_error = 0;
|
||||
lat_error = 0;
|
||||
circle_angle = 0;
|
||||
crosstrack_error = 0;
|
||||
nav_lat = 0;
|
||||
nav_lon = 0;
|
||||
nav_roll = 0;
|
||||
nav_pitch = 0;
|
||||
target_bearing = 0;
|
||||
wp_distance = 0;
|
||||
wp_totalDistance = 0;
|
||||
long_error = 0;
|
||||
lat_error = 0;
|
||||
}
|
||||
|
||||
|
||||
|
@ -66,6 +66,7 @@ static NOINLINE void send_extended_status1(mavlink_channel_t chan, uint16_t pack
|
||||
break;
|
||||
case GUIDED:
|
||||
mode = MAV_MODE_GUIDED;
|
||||
nav_mode = MAV_NAV_WAYPOINT;
|
||||
break;
|
||||
default:
|
||||
mode = control_mode + 100;
|
||||
@ -579,7 +580,7 @@ GCS_MAVLINK::update(void)
|
||||
uint32_t tnow = millis();
|
||||
|
||||
if (waypoint_receiving &&
|
||||
waypoint_request_i <= (unsigned)g.command_total &&
|
||||
waypoint_request_i < (unsigned)g.command_total &&
|
||||
tnow > waypoint_timelast_request + 500) {
|
||||
waypoint_timelast_request = tnow;
|
||||
send_message(MSG_NEXT_WAYPOINT);
|
||||
@ -809,7 +810,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
||||
*/
|
||||
|
||||
case MAV_ACTION_CONTINUE:
|
||||
process_next_command();
|
||||
//process_command_queue();
|
||||
result=1;
|
||||
break;
|
||||
|
||||
@ -947,7 +948,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
||||
mavlink_msg_waypoint_count_send(
|
||||
chan,msg->sysid,
|
||||
msg->compid,
|
||||
g.command_total + 1); // + home
|
||||
g.command_total); // includes home
|
||||
|
||||
waypoint_timelast_send = millis();
|
||||
waypoint_sending = true;
|
||||
@ -1005,8 +1006,8 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
||||
z = tell_command.alt/1.0e2; // local (z), global/relative (altitude)
|
||||
}
|
||||
|
||||
|
||||
switch (tell_command.id) { // Switch to map APM command fields inot MAVLink command fields
|
||||
// Switch to map APM command fields inot MAVLink command fields
|
||||
switch (tell_command.id) {
|
||||
|
||||
case MAV_CMD_NAV_LOITER_TURNS:
|
||||
case MAV_CMD_CONDITION_CHANGE_ALT:
|
||||
@ -1122,7 +1123,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
||||
|
||||
// clear all waypoints
|
||||
uint8_t type = 0; // ok (0), error(1)
|
||||
g.command_total.set_and_save(0);
|
||||
g.command_total.set_and_save(1);
|
||||
|
||||
// send acknowledgement 3 times to makes sure it is received
|
||||
for (int i=0;i<3;i++)
|
||||
@ -1160,7 +1161,7 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
||||
if (packet.count > MAX_WAYPOINTS) {
|
||||
packet.count = MAX_WAYPOINTS;
|
||||
}
|
||||
g.command_total.set_and_save(packet.count - 1);
|
||||
g.command_total.set_and_save(packet.count);
|
||||
|
||||
waypoint_timelast_receive = millis();
|
||||
waypoint_receiving = true;
|
||||
@ -1313,28 +1314,34 @@ void GCS_MAVLINK::handleMessage(mavlink_message_t* msg)
|
||||
// Check if receiving waypoints (mission upload expected)
|
||||
if (!waypoint_receiving) break;
|
||||
|
||||
|
||||
//Serial.printf("req: %d, seq: %d, total: %d\n", waypoint_request_i,packet.seq, g.command_total.get());
|
||||
|
||||
// check if this is the requested waypoint
|
||||
if (packet.seq != waypoint_request_i) break;
|
||||
if (packet.seq != waypoint_request_i)
|
||||
break;
|
||||
|
||||
if(packet.seq != 0)
|
||||
set_command_with_index(tell_command, packet.seq);
|
||||
|
||||
// update waypoint receiving state machine
|
||||
waypoint_timelast_receive = millis();
|
||||
waypoint_timelast_request = 0;
|
||||
waypoint_request_i++;
|
||||
// update waypoint receiving state machine
|
||||
waypoint_timelast_receive = millis();
|
||||
waypoint_timelast_request = 0;
|
||||
waypoint_request_i++;
|
||||
|
||||
if (waypoint_request_i > (uint16_t)g.command_total){
|
||||
uint8_t type = 0; // ok (0), error(1)
|
||||
if (waypoint_request_i == (uint16_t)g.command_total){
|
||||
uint8_t type = 0; // ok (0), error(1)
|
||||
|
||||
mavlink_msg_waypoint_ack_send(
|
||||
chan,
|
||||
msg->sysid,
|
||||
msg->compid,
|
||||
type);
|
||||
mavlink_msg_waypoint_ack_send(
|
||||
chan,
|
||||
msg->sysid,
|
||||
msg->compid,
|
||||
type);
|
||||
|
||||
send_text(SEVERITY_LOW,PSTR("flight plan received"));
|
||||
waypoint_receiving = false;
|
||||
// XXX ignores waypoint radius for individual waypoints, can
|
||||
// only set WP_RADIUS parameter
|
||||
send_text(SEVERITY_LOW,PSTR("flight plan received"));
|
||||
waypoint_receiving = false;
|
||||
// XXX ignores waypoint radius for individual waypoints, can
|
||||
// only set WP_RADIUS parameter
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -1657,7 +1664,7 @@ void
|
||||
GCS_MAVLINK::queued_waypoint_send()
|
||||
{
|
||||
if (waypoint_receiving &&
|
||||
waypoint_request_i <= (unsigned)g.command_total) {
|
||||
waypoint_request_i < (unsigned)g.command_total) {
|
||||
mavlink_msg_waypoint_request_send(
|
||||
chan,
|
||||
waypoint_dest_sysid,
|
||||
|
@ -738,15 +738,14 @@ static void Log_Write_Performance()
|
||||
//DataFlash.WriteByte( loop_step);
|
||||
|
||||
|
||||
//*
|
||||
//DataFlash.WriteLong( millis()- perf_mon_timer);
|
||||
|
||||
//DataFlash.WriteByte( dcm.gyro_sat_count); //2
|
||||
//DataFlash.WriteByte( imu.adc_constraints); //3
|
||||
//DataFlash.WriteByte( dcm.renorm_sqrt_count); //4
|
||||
//DataFlash.WriteByte( dcm.renorm_blowup_count); //5
|
||||
//DataFlash.WriteByte( gps_fix_count); //6
|
||||
|
||||
DataFlash.WriteLong( millis()- perf_mon_timer); //1
|
||||
DataFlash.WriteByte( dcm.gyro_sat_count); //2
|
||||
DataFlash.WriteByte( imu.adc_constraints); //3
|
||||
DataFlash.WriteByte( dcm.renorm_sqrt_count); //4
|
||||
DataFlash.WriteByte( dcm.renorm_blowup_count); //5
|
||||
DataFlash.WriteByte( gps_fix_count); //6
|
||||
DataFlash.WriteByte(END_BYTE);
|
||||
|
||||
|
||||
//DataFlash.WriteInt ( (int)(dcm.get_health() * 1000)); //7
|
||||
@ -754,6 +753,7 @@ static void Log_Write_Performance()
|
||||
|
||||
|
||||
// control_mode
|
||||
/*
|
||||
DataFlash.WriteByte(control_mode); //1
|
||||
DataFlash.WriteByte(yaw_mode); //2
|
||||
DataFlash.WriteByte(roll_pitch_mode); //3
|
||||
@ -761,20 +761,22 @@ static void Log_Write_Performance()
|
||||
DataFlash.WriteInt(g.throttle_cruise.get()); //5
|
||||
DataFlash.WriteLong(throttle_integrator); //6
|
||||
DataFlash.WriteByte(END_BYTE);
|
||||
*/
|
||||
|
||||
}
|
||||
|
||||
// Read a performance packet
|
||||
static void Log_Read_Performance()
|
||||
{
|
||||
int8_t temp1 = DataFlash.ReadByte();
|
||||
int8_t temp2 = DataFlash.ReadByte();
|
||||
int8_t temp3 = DataFlash.ReadByte();
|
||||
int8_t temp4 = DataFlash.ReadByte();
|
||||
int16_t temp5 = DataFlash.ReadInt();
|
||||
int32_t temp6 = DataFlash.ReadLong();
|
||||
int32_t temp1 = DataFlash.ReadLong();
|
||||
int8_t temp2 = DataFlash.ReadByte();
|
||||
int8_t temp3 = DataFlash.ReadByte();
|
||||
int8_t temp4 = DataFlash.ReadByte();
|
||||
int8_t temp5 = DataFlash.ReadByte();
|
||||
int8_t temp6 = DataFlash.ReadByte();
|
||||
|
||||
//1 2 3 4 5 6
|
||||
Serial.printf_P(PSTR("PM, %d, %d, %d, %d, %d, %ld\n"),
|
||||
Serial.printf_P(PSTR("PM, %ld, %d, %d, %d, %d, %d\n"),
|
||||
temp1,
|
||||
temp2,
|
||||
temp3,
|
||||
@ -852,9 +854,9 @@ static void Log_Read_Attitude()
|
||||
int16_t temp1 = DataFlash.ReadInt();
|
||||
int16_t temp2 = DataFlash.ReadInt();
|
||||
uint16_t temp3 = DataFlash.ReadInt();
|
||||
int16_t temp4 = DataFlash.ReadByte();
|
||||
int16_t temp5 = DataFlash.ReadByte();
|
||||
int16_t temp6 = DataFlash.ReadByte();
|
||||
int16_t temp4 = DataFlash.ReadInt();
|
||||
int16_t temp5 = DataFlash.ReadInt();
|
||||
int16_t temp6 = DataFlash.ReadInt();
|
||||
|
||||
// 1 2 3 4 5 6
|
||||
Serial.printf_P(PSTR("ATT, %d, %d, %u, %d, %d, %d\n"),
|
||||
|
@ -75,7 +75,10 @@ public:
|
||||
k_param_heli_collective_mid,
|
||||
k_param_heli_ext_gyro_enabled,
|
||||
k_param_heli_ext_gyro_gain,
|
||||
k_param_heli_servo_averaging, // 94
|
||||
k_param_heli_servo_averaging,
|
||||
k_param_heli_servo_manual,
|
||||
k_param_heli_phase_angle,
|
||||
k_param_heli_coll_yaw_effect, // 97
|
||||
#endif
|
||||
|
||||
// 110: Telemetry control
|
||||
@ -148,7 +151,7 @@ public:
|
||||
k_param_waypoint_mode = 220,
|
||||
k_param_command_total,
|
||||
k_param_command_index,
|
||||
k_param_command_must_index,
|
||||
k_param_command_nav_index,
|
||||
k_param_waypoint_radius,
|
||||
k_param_loiter_radius,
|
||||
k_param_waypoint_speed_max,
|
||||
@ -195,9 +198,9 @@ public:
|
||||
AP_Int8 waypoint_mode;
|
||||
AP_Int8 command_total;
|
||||
AP_Int8 command_index;
|
||||
AP_Int8 command_must_index;
|
||||
AP_Int8 command_nav_index;
|
||||
AP_Int8 waypoint_radius;
|
||||
AP_Int8 loiter_radius;
|
||||
AP_Int16 loiter_radius;
|
||||
AP_Int16 waypoint_speed_max;
|
||||
|
||||
// Throttle
|
||||
@ -247,12 +250,15 @@ public:
|
||||
#if FRAME_CONFIG == HELI_FRAME
|
||||
// Heli
|
||||
RC_Channel heli_servo_1, heli_servo_2, heli_servo_3, heli_servo_4; // servos for swash plate and tail
|
||||
AP_Int16 heli_servo1_pos, heli_servo2_pos, heli_servo3_pos; // servo positions (3 because we don't need pos for tail servo)
|
||||
AP_Int16 heli_servo1_pos, heli_servo2_pos, heli_servo3_pos; // servo positions (3 because we don't need pos for tail servo)
|
||||
AP_Int16 heli_roll_max, heli_pitch_max; // maximum allowed roll and pitch of swashplate
|
||||
AP_Int16 heli_coll_min, heli_coll_max, heli_coll_mid; // min and max collective. mid = main blades at zero pitch
|
||||
AP_Int8 heli_ext_gyro_enabled; // 0 = no external tail gyro, 1 = external tail gyro
|
||||
AP_Int16 heli_ext_gyro_gain; // radio output 1000~2000 (value output on CH_7)
|
||||
AP_Int8 heli_servo_averaging; // 0 or 1 = no averaging (250hz) for **digital servos**, 2=average of two samples (125hz), 3=three samples (83.3hz) **analog servos**, 4=four samples (62.5hz), 5=5 samples(50hz)
|
||||
AP_Int8 heli_servo_manual; // 0 = normal mode, 1 = radio inputs directly control swash. required for swash set-up
|
||||
AP_Int16 heli_phase_angle; // 0 to 360 degrees. specifies mixing between roll and pitch for helis
|
||||
AP_Float heli_coll_yaw_effect; // -5.0 ~ 5.0. Feed forward control from collective to yaw. 1.0 = move rudder right 1% for every 1% of collective above the mid point
|
||||
#endif
|
||||
|
||||
// RC channels
|
||||
@ -318,9 +324,9 @@ public:
|
||||
waypoint_mode (0, k_param_waypoint_mode, PSTR("WP_MODE")),
|
||||
command_total (0, k_param_command_total, PSTR("WP_TOTAL")),
|
||||
command_index (0, k_param_command_index, PSTR("WP_INDEX")),
|
||||
command_must_index (0, k_param_command_must_index, PSTR("WP_MUST_INDEX")),
|
||||
command_nav_index (0, k_param_command_nav_index, PSTR("WP_MUST_INDEX")),
|
||||
waypoint_radius (WP_RADIUS_DEFAULT, k_param_waypoint_radius, PSTR("WP_RADIUS")),
|
||||
loiter_radius (LOITER_RADIUS * 100, k_param_loiter_radius, PSTR("WP_LOITER_RAD")),
|
||||
loiter_radius (LOITER_RADIUS * 100, k_param_loiter_radius, PSTR("WP_LOITER_RAD")),
|
||||
waypoint_speed_max (WAYPOINT_SPEED_MAX, k_param_waypoint_speed_max, PSTR("WP_SPEED_MAX")),
|
||||
|
||||
throttle_min (0, k_param_throttle_min, PSTR("THR_MIN")),
|
||||
@ -361,6 +367,9 @@ public:
|
||||
heli_ext_gyro_enabled (0, k_param_heli_ext_gyro_enabled, PSTR("GYR_ENABLE_")),
|
||||
heli_ext_gyro_gain (1000, k_param_heli_ext_gyro_gain, PSTR("GYR_GAIN_")),
|
||||
heli_servo_averaging (0, k_param_heli_servo_averaging, PSTR("SV_AVG")),
|
||||
heli_servo_manual (0, k_param_heli_servo_manual, PSTR("HSV_MAN")),
|
||||
heli_phase_angle (0, k_param_heli_phase_angle, PSTR("H_PHANG")),
|
||||
heli_coll_yaw_effect (0, k_param_heli_coll_yaw_effect, PSTR("H_COLYAW")),
|
||||
#endif
|
||||
|
||||
// RC channel group key name
|
||||
|
@ -2,22 +2,12 @@
|
||||
|
||||
static void init_commands()
|
||||
{
|
||||
// zero is home, but we always load the next command (1), in the code.
|
||||
g.command_index = 0;
|
||||
|
||||
// This are registers for the current may and must commands
|
||||
// setting to zero will allow them to be written to by new commands
|
||||
command_must_index = NO_COMMAND;
|
||||
command_may_index = NO_COMMAND;
|
||||
|
||||
// clear the command queue
|
||||
clear_command_queue();
|
||||
}
|
||||
|
||||
// forces the loading of a new command
|
||||
// queue is emptied after a new command is processed
|
||||
static void clear_command_queue(){
|
||||
next_command.id = NO_COMMAND;
|
||||
g.command_index = NO_COMMAND;
|
||||
command_nav_index = NO_COMMAND;
|
||||
command_cond_index = NO_COMMAND;
|
||||
prev_nav_index = NO_COMMAND;
|
||||
command_cond_queue.id = NO_COMMAND;
|
||||
command_nav_queue.id = NO_COMMAND;
|
||||
}
|
||||
|
||||
// Getters
|
||||
@ -28,7 +18,7 @@ static struct Location get_cmd_with_index(int i)
|
||||
|
||||
// Find out proper location in memory by using the start_byte position + the index
|
||||
// --------------------------------------------------------------------------------
|
||||
if (i > g.command_total) {
|
||||
if (i >= g.command_total) {
|
||||
// we do not have a valid command to load
|
||||
// return a WP with a "Blank" id
|
||||
temp.id = CMD_BLANK;
|
||||
@ -78,6 +68,15 @@ static struct Location get_cmd_with_index(int i)
|
||||
static void set_command_with_index(struct Location temp, int i)
|
||||
{
|
||||
i = constrain(i, 0, g.command_total.get());
|
||||
//Serial.printf("set_command: %d with id: %d\n", i, temp.id);
|
||||
|
||||
// store home as 0 altitude!!!
|
||||
// Home is always a MAV_CMD_NAV_WAYPOINT (16)
|
||||
if (i == 0){
|
||||
temp.alt = 0;
|
||||
temp.id = MAV_CMD_NAV_WAYPOINT;
|
||||
}
|
||||
|
||||
uint32_t mem = WP_START_BYTE + (i * WP_SIZE);
|
||||
|
||||
eeprom_write_byte((uint8_t *) mem, temp.id);
|
||||
@ -96,19 +95,24 @@ static void set_command_with_index(struct Location temp, int i)
|
||||
|
||||
mem += 4;
|
||||
eeprom_write_dword((uint32_t *) mem, temp.lng); // Long is stored in decimal degrees * 10^7
|
||||
|
||||
// Make sure our WP_total
|
||||
if(g.command_total <= i)
|
||||
g.command_total.set_and_save(i+1);
|
||||
}
|
||||
|
||||
static void increment_WP_index()
|
||||
/*
|
||||
//static void increment_WP_index()
|
||||
{
|
||||
if (g.command_index < g.command_total) {
|
||||
if (g.command_index < (g.command_total-1)) {
|
||||
g.command_index++;
|
||||
}
|
||||
|
||||
SendDebugln(g.command_index,DEC);
|
||||
}
|
||||
|
||||
*/
|
||||
/*
|
||||
static void decrement_WP_index()
|
||||
//static void decrement_WP_index()
|
||||
{
|
||||
if (g.command_index > 0) {
|
||||
g.command_index.set_and_save(g.command_index - 1);
|
||||
@ -117,7 +121,7 @@ static void decrement_WP_index()
|
||||
|
||||
static int32_t read_alt_to_hold()
|
||||
{
|
||||
if(g.RTL_altitude < 0)
|
||||
if(g.RTL_altitude <= 0)
|
||||
return current_loc.alt;
|
||||
else
|
||||
return g.RTL_altitude;// + home.alt;
|
||||
@ -129,18 +133,6 @@ static int32_t read_alt_to_hold()
|
||||
// It's not currently used
|
||||
//********************************************************************************
|
||||
|
||||
/*static Location get_LOITER_home_wp()
|
||||
{
|
||||
//so we know where we are navigating from
|
||||
next_WP = current_loc;
|
||||
|
||||
// read home position
|
||||
struct Location temp = get_cmd_with_index(0); // 0 = home
|
||||
temp.id = MAV_CMD_NAV_LOITER_UNLIM;
|
||||
temp.alt = read_alt_to_hold();
|
||||
return temp;
|
||||
}
|
||||
*/
|
||||
/*
|
||||
This function sets the next waypoint command
|
||||
It precalculates all the necessary stuff.
|
||||
|
@ -3,9 +3,9 @@
|
||||
/********************************************************************************/
|
||||
// Command Event Handlers
|
||||
/********************************************************************************/
|
||||
static void handle_process_must()
|
||||
static void process_nav_command()
|
||||
{
|
||||
switch(next_command.id){
|
||||
switch(command_nav_queue.id){
|
||||
|
||||
case MAV_CMD_NAV_TAKEOFF: // 22
|
||||
do_takeoff();
|
||||
@ -41,9 +41,9 @@ static void handle_process_must()
|
||||
|
||||
}
|
||||
|
||||
static void handle_process_may()
|
||||
static void process_cond_command()
|
||||
{
|
||||
switch(next_command.id){
|
||||
switch(command_cond_queue.id){
|
||||
|
||||
case MAV_CMD_CONDITION_DELAY: // 112
|
||||
do_wait_delay();
|
||||
@ -66,9 +66,9 @@ static void handle_process_may()
|
||||
}
|
||||
}
|
||||
|
||||
static void handle_process_now()
|
||||
static void process_now_command()
|
||||
{
|
||||
switch(next_command.id){
|
||||
switch(command_cond_queue.id){
|
||||
|
||||
case MAV_CMD_DO_JUMP: // 177
|
||||
do_jump();
|
||||
@ -121,9 +121,9 @@ static void handle_no_commands()
|
||||
|
||||
static bool verify_must()
|
||||
{
|
||||
//Serial.printf("vmust: %d\n", command_must_ID);
|
||||
//Serial.printf("vmust: %d\n", command_nav_ID);
|
||||
|
||||
switch(command_must_ID) {
|
||||
switch(command_nav_queue.id) {
|
||||
|
||||
case MAV_CMD_NAV_TAKEOFF:
|
||||
return verify_takeoff();
|
||||
@ -162,7 +162,7 @@ static bool verify_must()
|
||||
|
||||
static bool verify_may()
|
||||
{
|
||||
switch(command_may_ID) {
|
||||
switch(command_cond_queue.id) {
|
||||
|
||||
case MAV_CMD_CONDITION_DELAY:
|
||||
return verify_wait_delay();
|
||||
@ -221,12 +221,12 @@ static void do_takeoff()
|
||||
// Start with current location
|
||||
Location temp = current_loc;
|
||||
|
||||
// next_command.alt is a relative altitude!!!
|
||||
if (next_command.options & WP_OPTION_ALT_RELATIVE) {
|
||||
temp.alt = next_command.alt + home.alt;
|
||||
// command_nav_queue.alt is a relative altitude!!!
|
||||
if (command_nav_queue.options & WP_OPTION_ALT_RELATIVE) {
|
||||
temp.alt = command_nav_queue.alt + home.alt;
|
||||
//Serial.printf("rel alt: %ld",temp.alt);
|
||||
} else {
|
||||
temp.alt = next_command.alt;
|
||||
temp.alt = command_nav_queue.alt;
|
||||
//Serial.printf("abs alt: %ld",temp.alt);
|
||||
}
|
||||
|
||||
@ -241,11 +241,11 @@ static void do_nav_wp()
|
||||
{
|
||||
wp_control = WP_MODE;
|
||||
|
||||
// next_command.alt is a relative altitude!!!
|
||||
if (next_command.options & WP_OPTION_ALT_RELATIVE) {
|
||||
next_command.alt += home.alt;
|
||||
// command_nav_queue.alt is a relative altitude!!!
|
||||
if (command_nav_queue.options & WP_OPTION_ALT_RELATIVE) {
|
||||
command_nav_queue.alt += home.alt;
|
||||
}
|
||||
set_next_WP(&next_command);
|
||||
set_next_WP(&command_nav_queue);
|
||||
|
||||
|
||||
// this is our bitmask to verify we have met all conditions to move on
|
||||
@ -255,7 +255,7 @@ static void do_nav_wp()
|
||||
loiter_time = 0;
|
||||
|
||||
// this is the delay, stored in seconds and expanded to millis
|
||||
loiter_time_max = next_command.p1 * 1000;
|
||||
loiter_time_max = command_nav_queue.p1 * 1000;
|
||||
|
||||
// if we don't require an altitude minimum, we save this flag as passed (1)
|
||||
if((next_WP.options & WP_OPTION_ALT_REQUIRED) == 0){
|
||||
@ -291,37 +291,38 @@ static void do_loiter_unlimited()
|
||||
wp_control = LOITER_MODE;
|
||||
|
||||
//Serial.println("dloi ");
|
||||
if(next_command.lat == 0)
|
||||
if(command_nav_queue.lat == 0)
|
||||
set_next_WP(¤t_loc);
|
||||
else
|
||||
set_next_WP(&next_command);
|
||||
set_next_WP(&command_nav_queue);
|
||||
}
|
||||
|
||||
static void do_loiter_turns()
|
||||
{
|
||||
wp_control = CIRCLE_MODE;
|
||||
|
||||
if(next_command.lat == 0)
|
||||
if(command_nav_queue.lat == 0)
|
||||
set_next_WP(¤t_loc);
|
||||
else
|
||||
set_next_WP(&next_command);
|
||||
set_next_WP(&command_nav_queue);
|
||||
|
||||
loiter_total = next_command.p1 * 360;
|
||||
loiter_total = command_nav_queue.p1 * 360;
|
||||
loiter_sum = 0;
|
||||
old_target_bearing = target_bearing;
|
||||
}
|
||||
|
||||
static void do_loiter_time()
|
||||
{
|
||||
if(next_command.lat == 0){
|
||||
if(command_nav_queue.lat == 0){
|
||||
wp_control = LOITER_MODE;
|
||||
loiter_time = millis();
|
||||
set_next_WP(¤t_loc);
|
||||
}else{
|
||||
wp_control = WP_MODE;
|
||||
set_next_WP(&next_command);
|
||||
set_next_WP(&command_nav_queue);
|
||||
}
|
||||
|
||||
loiter_time_max = next_command.p1 * 1000; // units are (seconds)
|
||||
loiter_time_max = command_nav_queue.p1 * 1000; // units are (seconds)
|
||||
}
|
||||
|
||||
/********************************************************************************/
|
||||
@ -420,7 +421,7 @@ static bool verify_nav_wp()
|
||||
if(wp_verify_byte >= 7){
|
||||
//if(wp_verify_byte & NAV_LOCATION){
|
||||
char message[30];
|
||||
sprintf(message,"Reached Command #%i",command_must_index);
|
||||
sprintf(message,"Reached Command #%i",command_nav_index);
|
||||
gcs_send_text(SEVERITY_LOW,message);
|
||||
wp_verify_byte = 0;
|
||||
return true;
|
||||
@ -452,6 +453,7 @@ static bool verify_loiter_time()
|
||||
|
||||
static bool verify_loiter_turns()
|
||||
{
|
||||
//Serial.printf("loiter_sum: %d \n", loiter_sum);
|
||||
// have we rotated around the center enough times?
|
||||
// -----------------------------------------------
|
||||
if(abs(loiter_sum) > loiter_total) {
|
||||
@ -488,7 +490,7 @@ static void do_wait_delay()
|
||||
{
|
||||
//Serial.print("dwd ");
|
||||
condition_start = millis();
|
||||
condition_value = next_command.lat * 1000; // convert to milliseconds
|
||||
condition_value = command_cond_queue.lat * 1000; // convert to milliseconds
|
||||
//Serial.println(condition_value,DEC);
|
||||
}
|
||||
|
||||
@ -496,14 +498,14 @@ static void do_change_alt()
|
||||
{
|
||||
Location temp = next_WP;
|
||||
condition_start = current_loc.alt;
|
||||
condition_value = next_command.alt;
|
||||
temp.alt = next_command.alt;
|
||||
condition_value = command_cond_queue.alt;
|
||||
temp.alt = command_cond_queue.alt;
|
||||
set_next_WP(&temp);
|
||||
}
|
||||
|
||||
static void do_within_distance()
|
||||
{
|
||||
condition_value = next_command.lat;
|
||||
condition_value = command_cond_queue.lat;
|
||||
}
|
||||
|
||||
static void do_yaw()
|
||||
@ -515,9 +517,9 @@ static void do_yaw()
|
||||
command_yaw_start = nav_yaw; // current position
|
||||
command_yaw_start_time = millis();
|
||||
|
||||
command_yaw_dir = next_command.p1; // 1 = clockwise, 0 = counterclockwise
|
||||
command_yaw_speed = next_command.lat * 100; // ms * 100
|
||||
command_yaw_relative = next_command.lng; // 1 = Relative, 0 = Absolute
|
||||
command_yaw_dir = command_cond_queue.p1; // 1 = clockwise, 0 = counterclockwise
|
||||
command_yaw_speed = command_cond_queue.lat * 100; // ms * 100
|
||||
command_yaw_relative = command_cond_queue.lng; // 1 = Relative, 0 = Absolute
|
||||
|
||||
|
||||
|
||||
@ -533,11 +535,11 @@ static void do_yaw()
|
||||
|
||||
if (command_yaw_relative == 1){
|
||||
// relative
|
||||
command_yaw_delta = next_command.alt * 100;
|
||||
command_yaw_delta = command_cond_queue.alt * 100;
|
||||
|
||||
}else{
|
||||
// absolute
|
||||
command_yaw_end = next_command.alt * 100;
|
||||
command_yaw_end = command_cond_queue.alt * 100;
|
||||
|
||||
// calculate the delta travel in deg * 100
|
||||
if(command_yaw_dir == 1){
|
||||
@ -580,6 +582,7 @@ static bool verify_wait_delay()
|
||||
|
||||
static bool verify_change_alt()
|
||||
{
|
||||
//Serial.printf("change_alt, ca:%d, na:%d\n", (int)current_loc.alt, (int)next_WP.alt);
|
||||
if (condition_start < next_WP.alt){
|
||||
// we are going higer
|
||||
if(current_loc.alt > next_WP.alt){
|
||||
@ -598,6 +601,7 @@ static bool verify_change_alt()
|
||||
|
||||
static bool verify_within_distance()
|
||||
{
|
||||
//Serial.printf("cond dist :%d\n", (int)condition_value);
|
||||
if (wp_distance < condition_value){
|
||||
condition_value = 0;
|
||||
return true;
|
||||
@ -607,7 +611,7 @@ static bool verify_within_distance()
|
||||
|
||||
static bool verify_yaw()
|
||||
{
|
||||
//Serial.print("vyaw ");
|
||||
//Serial.printf("vyaw %d\n", (int)(nav_yaw/100));
|
||||
|
||||
if((millis() - command_yaw_start_time) > command_yaw_time){
|
||||
// time out
|
||||
@ -637,15 +641,15 @@ static bool verify_yaw()
|
||||
|
||||
static void do_change_speed()
|
||||
{
|
||||
g.waypoint_speed_max = next_command.p1 * 100;
|
||||
g.waypoint_speed_max = command_cond_queue.p1 * 100;
|
||||
}
|
||||
|
||||
static void do_target_yaw()
|
||||
{
|
||||
yaw_tracking = next_command.p1;
|
||||
yaw_tracking = command_cond_queue.p1;
|
||||
|
||||
if(yaw_tracking == MAV_ROI_LOCATION){
|
||||
target_WP = next_command;
|
||||
target_WP = command_cond_queue;
|
||||
}
|
||||
}
|
||||
|
||||
@ -656,51 +660,55 @@ static void do_loiter_at_location()
|
||||
|
||||
static void do_jump()
|
||||
{
|
||||
//Serial.printf("do Jump: %d\n", jump);
|
||||
|
||||
if(jump == -10){
|
||||
jump = next_command.lat;
|
||||
//Serial.printf("Fresh Jump\n");
|
||||
// we use a locally stored index for jump
|
||||
jump = command_cond_queue.lat;
|
||||
}
|
||||
//Serial.printf("Jumps left: %d\n",jump);
|
||||
|
||||
if(jump > 0) {
|
||||
//Serial.printf("Do Jump to %d\n",command_cond_queue.p1);
|
||||
jump--;
|
||||
command_must_index = 0;
|
||||
command_may_index = 0;
|
||||
|
||||
// set pointer to desired index
|
||||
g.command_index = next_command.p1 - 1;
|
||||
change_command(command_cond_queue.p1);
|
||||
|
||||
} else if (jump == 0){
|
||||
//Serial.printf("Did last jump\n");
|
||||
// we're done, move along
|
||||
jump = -10;
|
||||
jump = -11;
|
||||
|
||||
} else if (jump == -1) {
|
||||
//Serial.printf("jumpForever\n");
|
||||
// repeat forever
|
||||
g.command_index = next_command.p1 - 1;
|
||||
change_command(command_cond_queue.p1);
|
||||
}
|
||||
}
|
||||
|
||||
static void do_set_home()
|
||||
{
|
||||
if(next_command.p1 == 1) {
|
||||
if(command_cond_queue.p1 == 1) {
|
||||
init_home();
|
||||
} else {
|
||||
home.id = MAV_CMD_NAV_WAYPOINT;
|
||||
home.lng = next_command.lng; // Lon * 10**7
|
||||
home.lat = next_command.lat; // Lat * 10**7
|
||||
home.alt = max(next_command.alt, 0);
|
||||
home.lng = command_cond_queue.lng; // Lon * 10**7
|
||||
home.lat = command_cond_queue.lat; // Lat * 10**7
|
||||
home.alt = max(command_cond_queue.alt, 0);
|
||||
home_is_set = true;
|
||||
}
|
||||
}
|
||||
|
||||
static void do_set_servo()
|
||||
{
|
||||
APM_RC.OutputCh(next_command.p1 - 1, next_command.alt);
|
||||
APM_RC.OutputCh(command_cond_queue.p1 - 1, command_cond_queue.alt);
|
||||
}
|
||||
|
||||
static void do_set_relay()
|
||||
{
|
||||
if (next_command.p1 == 1) {
|
||||
if (command_cond_queue.p1 == 1) {
|
||||
relay.on();
|
||||
} else if (next_command.p1 == 0) {
|
||||
} else if (command_cond_queue.p1 == 0) {
|
||||
relay.off();
|
||||
}else{
|
||||
relay.toggle();
|
||||
@ -709,16 +717,16 @@ static void do_set_relay()
|
||||
|
||||
static void do_repeat_servo()
|
||||
{
|
||||
event_id = next_command.p1 - 1;
|
||||
event_id = command_cond_queue.p1 - 1;
|
||||
|
||||
if(next_command.p1 >= CH_5 + 1 && next_command.p1 <= CH_8 + 1) {
|
||||
if(command_cond_queue.p1 >= CH_5 + 1 && command_cond_queue.p1 <= CH_8 + 1) {
|
||||
|
||||
event_timer = 0;
|
||||
event_value = next_command.alt;
|
||||
event_repeat = next_command.lat * 2;
|
||||
event_delay = next_command.lng * 500.0; // /2 (half cycle time) * 1000 (convert to milliseconds)
|
||||
event_value = command_cond_queue.alt;
|
||||
event_repeat = command_cond_queue.lat * 2;
|
||||
event_delay = command_cond_queue.lng * 500.0; // /2 (half cycle time) * 1000 (convert to milliseconds)
|
||||
|
||||
switch(next_command.p1) {
|
||||
switch(command_cond_queue.p1) {
|
||||
case CH_5:
|
||||
event_undo_value = g.rc_5.radio_trim;
|
||||
break;
|
||||
@ -740,7 +748,7 @@ static void do_repeat_relay()
|
||||
{
|
||||
event_id = RELAY_TOGGLE;
|
||||
event_timer = 0;
|
||||
event_delay = next_command.lat * 500.0; // /2 (half cycle time) * 1000 (convert to milliseconds)
|
||||
event_repeat = next_command.alt * 2;
|
||||
event_delay = command_cond_queue.lat * 500.0; // /2 (half cycle time) * 1000 (convert to milliseconds)
|
||||
event_repeat = command_cond_queue.alt * 2;
|
||||
update_events();
|
||||
}
|
||||
|
@ -4,61 +4,118 @@
|
||||
//----------------------------------------
|
||||
static void change_command(uint8_t cmd_index)
|
||||
{
|
||||
// limit range
|
||||
cmd_index = min(g.command_total-1, cmd_index);
|
||||
|
||||
// load command
|
||||
struct Location temp = get_cmd_with_index(cmd_index);
|
||||
|
||||
//Serial.printf("loading cmd: %d with id:%d\n", cmd_index, temp.id);
|
||||
|
||||
// verify it's a nav command
|
||||
if (temp.id > MAV_CMD_NAV_LAST ){
|
||||
gcs_send_text_P(SEVERITY_LOW,PSTR("error: non-Nav cmd"));
|
||||
//gcs_send_text_P(SEVERITY_LOW,PSTR("error: non-Nav cmd"));
|
||||
|
||||
} else {
|
||||
command_must_index = NO_COMMAND;
|
||||
next_command.id = NO_COMMAND;
|
||||
g.command_index = cmd_index - 1;
|
||||
update_commands();
|
||||
//Serial.printf("APM:New cmd Index: %d\n", cmd_index);
|
||||
init_commands();
|
||||
command_nav_index = cmd_index;
|
||||
prev_nav_index = command_nav_index;
|
||||
update_commands(false);
|
||||
}
|
||||
}
|
||||
|
||||
// called by 10 Hz loop
|
||||
// --------------------
|
||||
static void update_commands(void)
|
||||
static void update_commands(bool increment)
|
||||
{
|
||||
// fill command queue with a new command if available
|
||||
if(next_command.id == NO_COMMAND){
|
||||
// A: if we do not have any commands there is nothing to do
|
||||
// B: We have completed the mission, don't redo the mission
|
||||
if (g.command_total <= 1 || g.command_index == 255)
|
||||
return;
|
||||
|
||||
// fetch next command if the next command queue is empty
|
||||
// -----------------------------------------------------
|
||||
if (g.command_index < g.command_total) {
|
||||
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)) {
|
||||
|
||||
// only if we have a cmd stored in EEPROM
|
||||
next_command = get_cmd_with_index(g.command_index + 1);
|
||||
//Serial.printf("queue CMD %d\n", next_command.id);
|
||||
// load next index
|
||||
if (increment)
|
||||
command_nav_index++;
|
||||
|
||||
command_nav_queue = get_cmd_with_index(command_nav_index);
|
||||
|
||||
if (command_nav_queue.id <= MAV_CMD_NAV_LAST ){
|
||||
// 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 + 1, &command_nav_queue);
|
||||
|
||||
// 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;
|
||||
|
||||
} else{
|
||||
// this is a conditional command so we skip it
|
||||
command_nav_queue.id = NO_COMMAND;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Are we out of must commands and the queue is empty?
|
||||
if(next_command.id == NO_COMMAND && command_must_index == NO_COMMAND){
|
||||
// if no commands were available from EEPROM
|
||||
// And we have no nav commands
|
||||
// --------------------------------------------
|
||||
if (command_must_ID == NO_COMMAND){
|
||||
gcs_send_text_P(SEVERITY_LOW,PSTR("out of commands!"));
|
||||
handle_no_commands();
|
||||
if(command_cond_queue.id == NO_COMMAND){
|
||||
// Our queue is empty
|
||||
// fill command queue with a new command if available, or do nothing
|
||||
// -------------------------------------------------------------------
|
||||
|
||||
// no nav commands completed yet
|
||||
if (prev_nav_index == NO_COMMAND)
|
||||
return;
|
||||
|
||||
if (command_cond_index >= command_nav_index){
|
||||
// don't process the fututre
|
||||
//command_cond_index = NO_COMMAND;
|
||||
return;
|
||||
|
||||
}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;
|
||||
|
||||
}else{
|
||||
// we've completed 1 cond, look at next command for another
|
||||
command_cond_index++;
|
||||
}
|
||||
}
|
||||
|
||||
// check to see if we need to act on our command queue
|
||||
if (process_next_command()){
|
||||
//Serial.printf("did PNC: %d\n", next_command.id);
|
||||
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);
|
||||
|
||||
// We acted on the queue - let's debug that
|
||||
// ----------------------------------------
|
||||
print_wp(&next_command, g.command_index);
|
||||
if (command_cond_queue.id > MAV_CMD_CONDITION_LAST){
|
||||
// this is a do now command
|
||||
process_now_command();
|
||||
|
||||
// invalidate command queue so a new one is loaded
|
||||
// -----------------------------------------------
|
||||
clear_command_queue();
|
||||
// clear command queue
|
||||
command_cond_queue.id = NO_COMMAND;
|
||||
|
||||
// make sure we load the next command index
|
||||
// ----------------------------------------
|
||||
increment_WP_index();
|
||||
}else if (command_cond_queue.id > MAV_CMD_NAV_LAST ){
|
||||
// this is a conditional command
|
||||
process_cond_command();
|
||||
|
||||
}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;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -66,109 +123,22 @@ static void update_commands(void)
|
||||
static void verify_commands(void)
|
||||
{
|
||||
if(verify_must()){
|
||||
//Serial.printf("verified must cmd %d\n" , command_must_index);
|
||||
command_must_index = NO_COMMAND;
|
||||
//Serial.printf("verified must cmd %d\n" , command_nav_index);
|
||||
command_nav_queue.id = NO_COMMAND;
|
||||
|
||||
// store our most recent executed nav command
|
||||
prev_nav_index = command_nav_index;
|
||||
|
||||
// Wipe existing conditionals
|
||||
command_cond_index = NO_COMMAND;
|
||||
command_cond_queue.id = NO_COMMAND;
|
||||
|
||||
}else{
|
||||
//Serial.printf("verified must false %d\n" , command_must_index);
|
||||
//Serial.printf("verified must false %d\n" , command_nav_index);
|
||||
}
|
||||
|
||||
if(verify_may()){
|
||||
//Serial.printf("verified may cmd %d\n" , command_may_index);
|
||||
command_may_index = NO_COMMAND;
|
||||
command_may_ID = NO_COMMAND;
|
||||
//Serial.printf("verified may cmd %d\n" , command_cond_index);
|
||||
command_cond_queue.id = NO_COMMAND;
|
||||
}
|
||||
}
|
||||
|
||||
static bool
|
||||
process_next_command()
|
||||
{
|
||||
// these are Navigation/Must commands
|
||||
// ---------------------------------
|
||||
if (command_must_index == NO_COMMAND){ // no current command loaded
|
||||
if (next_command.id < MAV_CMD_NAV_LAST ){
|
||||
|
||||
// we remember the index of our mission here
|
||||
command_must_index = g.command_index + 1;
|
||||
|
||||
// Save CMD to Log
|
||||
if (g.log_bitmask & MASK_LOG_CMD)
|
||||
Log_Write_Cmd(g.command_index + 1, &next_command);
|
||||
|
||||
// Act on the new command
|
||||
process_must();
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
// these are Condition/May commands
|
||||
// ----------------------
|
||||
if (command_may_index == NO_COMMAND){
|
||||
if (next_command.id > MAV_CMD_NAV_LAST && next_command.id < MAV_CMD_CONDITION_LAST ){
|
||||
|
||||
// we remember the index of our mission here
|
||||
command_may_index = g.command_index + 1;
|
||||
|
||||
//SendDebug("MSG <pnc> new may ");
|
||||
//SendDebugln(next_command.id,DEC);
|
||||
//Serial.print("new command_may_index ");
|
||||
//Serial.println(command_may_index,DEC);
|
||||
|
||||
// Save CMD to Log
|
||||
if (g.log_bitmask & MASK_LOG_CMD)
|
||||
Log_Write_Cmd(g.command_index + 1, &next_command);
|
||||
|
||||
process_may();
|
||||
return true;
|
||||
}
|
||||
|
||||
// these are Do/Now commands
|
||||
// ---------------------------
|
||||
if (next_command.id > MAV_CMD_CONDITION_LAST){
|
||||
//SendDebug("MSG <pnc> new now ");
|
||||
//SendDebugln(next_command.id,DEC);
|
||||
|
||||
if (g.log_bitmask & MASK_LOG_CMD)
|
||||
Log_Write_Cmd(g.command_index + 1, &next_command);
|
||||
process_now();
|
||||
return true;
|
||||
}
|
||||
}
|
||||
// we did not need any new commands
|
||||
return false;
|
||||
}
|
||||
|
||||
/**************************************************/
|
||||
// These functions implement the commands.
|
||||
/**************************************************/
|
||||
static void process_must()
|
||||
{
|
||||
//gcs_send_text_P(SEVERITY_LOW,PSTR("New cmd: <process_must>"));
|
||||
//Serial.printf("pmst %d\n", (int)next_command.id);
|
||||
|
||||
// clear May indexes to force loading of more commands
|
||||
// existing May commands are tossed.
|
||||
command_may_index = NO_COMMAND;
|
||||
command_may_ID = NO_COMMAND;
|
||||
|
||||
// remember our command ID
|
||||
command_must_ID = next_command.id;
|
||||
|
||||
// implements the Flight Logic
|
||||
handle_process_must();
|
||||
|
||||
}
|
||||
|
||||
static void process_may()
|
||||
{
|
||||
//gcs_send_text_P(SEVERITY_LOW,PSTR("<process_may>"));
|
||||
//Serial.print("pmay");
|
||||
|
||||
command_may_ID = next_command.id;
|
||||
handle_process_may();
|
||||
}
|
||||
|
||||
static void process_now()
|
||||
{
|
||||
//Serial.print("pnow");
|
||||
handle_process_now();
|
||||
}
|
||||
|
@ -670,11 +670,11 @@
|
||||
#endif
|
||||
|
||||
#ifndef LOITER_RADIUS
|
||||
# define LOITER_RADIUS 10
|
||||
# define LOITER_RADIUS 10 // meters for circle mode
|
||||
#endif
|
||||
|
||||
#ifndef ALT_HOLD_HOME
|
||||
# define ALT_HOLD_HOME 10
|
||||
# define ALT_HOLD_HOME 0 // height to return to Home, 0 = Maintain current altitude
|
||||
#endif
|
||||
|
||||
#ifndef USE_CURRENT_ALT
|
||||
|
@ -78,13 +78,13 @@ static void read_trim_switch()
|
||||
}else{ // switch is disengaged
|
||||
|
||||
if(trim_flag){
|
||||
trim_flag = false;
|
||||
|
||||
// set the throttle nominal
|
||||
if(g.rc_3.control_in > 150){
|
||||
g.throttle_cruise.set_and_save(g.rc_3.control_in);
|
||||
//Serial.printf("tnom %d\n", g.throttle_cruise.get());
|
||||
}
|
||||
trim_flag = false;
|
||||
}
|
||||
}
|
||||
|
||||
@ -95,11 +95,22 @@ static void read_trim_switch()
|
||||
}else{ // switch is disengaged
|
||||
|
||||
if(trim_flag){
|
||||
// set the next_WP
|
||||
trim_flag = false;
|
||||
// increment index
|
||||
CH7_wp_index++;
|
||||
|
||||
// set the next_WP, 0 is Home so we don't set that
|
||||
// max out at 100 since I think we need to stay under the EEPROM limit
|
||||
CH7_wp_index = constrain(CH7_wp_index, 1, 100);
|
||||
|
||||
// set our location ID to 16, MAV_CMD_NAV_WAYPOINT
|
||||
current_loc.id = MAV_CMD_NAV_WAYPOINT;
|
||||
g.command_total.set_and_save(CH7_wp_index);
|
||||
|
||||
// save command
|
||||
set_command_with_index(current_loc, CH7_wp_index);
|
||||
|
||||
// save the index
|
||||
g.command_total.set_and_save(CH7_wp_index + 1);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -5,8 +5,8 @@
|
||||
#define HELI_SERVO_AVERAGING_DIGITAL 0 // 250Hz
|
||||
#define HELI_SERVO_AVERAGING_ANALOG 2 // 125Hz
|
||||
|
||||
static int heli_manual_override = false;
|
||||
static float heli_throttle_scaler = 0;
|
||||
static bool heli_swash_initialised = false;
|
||||
|
||||
// heli_servo_averaging:
|
||||
// 0 or 1 = no averaging, 250hz
|
||||
@ -29,14 +29,14 @@ static void heli_init_swash()
|
||||
g.heli_servo_4.set_angle(4500);
|
||||
|
||||
// pitch factors
|
||||
heli_pitchFactor[CH_1] = cos(radians(g.heli_servo1_pos));
|
||||
heli_pitchFactor[CH_2] = cos(radians(g.heli_servo2_pos));
|
||||
heli_pitchFactor[CH_3] = cos(radians(g.heli_servo3_pos));
|
||||
heli_pitchFactor[CH_1] = cos(radians(g.heli_servo1_pos - g.heli_phase_angle));
|
||||
heli_pitchFactor[CH_2] = cos(radians(g.heli_servo2_pos - g.heli_phase_angle));
|
||||
heli_pitchFactor[CH_3] = cos(radians(g.heli_servo3_pos - g.heli_phase_angle));
|
||||
|
||||
// roll factors
|
||||
heli_rollFactor[CH_1] = cos(radians(g.heli_servo1_pos + 90));
|
||||
heli_rollFactor[CH_2] = cos(radians(g.heli_servo2_pos + 90));
|
||||
heli_rollFactor[CH_3] = cos(radians(g.heli_servo3_pos + 90));
|
||||
heli_rollFactor[CH_1] = cos(radians(g.heli_servo1_pos + 90 - g.heli_phase_angle));
|
||||
heli_rollFactor[CH_2] = cos(radians(g.heli_servo2_pos + 90 - g.heli_phase_angle));
|
||||
heli_rollFactor[CH_3] = cos(radians(g.heli_servo3_pos + 90 - g.heli_phase_angle));
|
||||
|
||||
// collective min / max
|
||||
total_tilt_max = 0;
|
||||
@ -65,6 +65,9 @@ static void heli_init_swash()
|
||||
g.heli_servo_averaging = 0;
|
||||
g.heli_servo_averaging.save();
|
||||
}
|
||||
|
||||
// mark swash as initialised
|
||||
heli_swash_initialised = true;
|
||||
}
|
||||
|
||||
static void heli_move_servos_to_mid()
|
||||
@ -81,26 +84,39 @@ static void heli_move_servos_to_mid()
|
||||
// yaw: -4500 ~ 4500
|
||||
//
|
||||
static void heli_move_swash(int roll_out, int pitch_out, int coll_out, int yaw_out)
|
||||
{
|
||||
// ensure values are acceptable:
|
||||
roll_out = constrain(roll_out, (int)-g.heli_roll_max, (int)g.heli_roll_max);
|
||||
pitch_out = constrain(pitch_out, (int)-g.heli_pitch_max, (int)g.heli_pitch_max);
|
||||
coll_out = constrain(coll_out, (int)g.heli_coll_min, (int)g.heli_coll_max);
|
||||
{
|
||||
int yaw_offset = 0;
|
||||
|
||||
if( g.heli_servo_manual == 1 ) { // are we in manual servo mode? (i.e. swash set-up mode)?
|
||||
|
||||
// we must be in set-up mode so mark swash as uninitialised
|
||||
heli_swash_initialised = false;
|
||||
|
||||
}else{ // regular flight mode
|
||||
|
||||
// check if we need to reinitialise the swash
|
||||
if( !heli_swash_initialised ) {
|
||||
heli_init_swash();
|
||||
}
|
||||
|
||||
// ensure values are acceptable:
|
||||
roll_out = constrain(roll_out, (int)-g.heli_roll_max, (int)g.heli_roll_max);
|
||||
pitch_out = constrain(pitch_out, (int)-g.heli_pitch_max, (int)g.heli_pitch_max);
|
||||
coll_out = constrain(coll_out, (int)g.heli_coll_min, (int)g.heli_coll_max);
|
||||
|
||||
// rudder feed forward based on collective
|
||||
#if HIL_MODE == HIL_MODE_DISABLED // don't do rudder feed forward in simulator
|
||||
if( !g.heli_ext_gyro_enabled ) {
|
||||
yaw_offset = g.heli_coll_yaw_effect * (coll_out - g.heli_coll_mid);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
// swashplate servos
|
||||
g.heli_servo_1.servo_out = (heli_rollFactor[CH_1] * roll_out + heli_pitchFactor[CH_1] * pitch_out)/10 + coll_out + (g.heli_servo_1.radio_trim-1500);
|
||||
if( g.heli_servo_1.get_reverse() )
|
||||
g.heli_servo_1.servo_out = 3000 - g.heli_servo_1.servo_out;
|
||||
|
||||
g.heli_servo_2.servo_out = (heli_rollFactor[CH_2] * roll_out + heli_pitchFactor[CH_2] * pitch_out)/10 + coll_out + (g.heli_servo_2.radio_trim-1500);
|
||||
if( g.heli_servo_2.get_reverse() )
|
||||
g.heli_servo_2.servo_out = 3000 - g.heli_servo_2.servo_out;
|
||||
|
||||
g.heli_servo_3.servo_out = (heli_rollFactor[CH_3] * roll_out + heli_pitchFactor[CH_3] * pitch_out)/10 + coll_out + (g.heli_servo_3.radio_trim-1500);
|
||||
if( g.heli_servo_3.get_reverse() )
|
||||
g.heli_servo_3.servo_out = 3000 - g.heli_servo_3.servo_out;
|
||||
|
||||
g.heli_servo_4.servo_out = yaw_out;
|
||||
g.heli_servo_1.servo_out = (heli_rollFactor[CH_1] * roll_out + heli_pitchFactor[CH_1] * pitch_out)/10 + coll_out - 1000 + (g.heli_servo_1.radio_trim-1500);
|
||||
g.heli_servo_2.servo_out = (heli_rollFactor[CH_2] * roll_out + heli_pitchFactor[CH_2] * pitch_out)/10 + coll_out - 1000 + (g.heli_servo_2.radio_trim-1500);
|
||||
g.heli_servo_3.servo_out = (heli_rollFactor[CH_3] * roll_out + heli_pitchFactor[CH_3] * pitch_out)/10 + coll_out - 1000 + (g.heli_servo_3.radio_trim-1500);
|
||||
g.heli_servo_4.servo_out = yaw_out + yaw_offset;
|
||||
|
||||
// use servo_out to calculate pwm_out and radio_out
|
||||
g.heli_servo_1.calc_pwm();
|
||||
@ -109,9 +125,9 @@ static void heli_move_swash(int roll_out, int pitch_out, int coll_out, int yaw_o
|
||||
g.heli_servo_4.calc_pwm();
|
||||
|
||||
// add the servo values to the averaging
|
||||
heli_servo_out[0] += g.heli_servo_1.servo_out;
|
||||
heli_servo_out[1] += g.heli_servo_2.servo_out;
|
||||
heli_servo_out[2] += g.heli_servo_3.servo_out;
|
||||
heli_servo_out[0] += g.heli_servo_1.radio_out;
|
||||
heli_servo_out[1] += g.heli_servo_2.radio_out;
|
||||
heli_servo_out[2] += g.heli_servo_3.radio_out;
|
||||
heli_servo_out[3] += g.heli_servo_4.radio_out;
|
||||
heli_servo_out_count++;
|
||||
|
||||
@ -125,13 +141,13 @@ static void heli_move_swash(int roll_out, int pitch_out, int coll_out, int yaw_o
|
||||
heli_servo_out[2] /= g.heli_servo_averaging;
|
||||
heli_servo_out[3] /= g.heli_servo_averaging;
|
||||
}
|
||||
|
||||
|
||||
// actually move the servos
|
||||
APM_RC.OutputCh(CH_1, heli_servo_out[0]);
|
||||
APM_RC.OutputCh(CH_2, heli_servo_out[1]);
|
||||
APM_RC.OutputCh(CH_3, heli_servo_out[2]);
|
||||
APM_RC.OutputCh(CH_4, heli_servo_out[3]);
|
||||
|
||||
|
||||
// output gyro value
|
||||
if( g.heli_ext_gyro_enabled ) {
|
||||
APM_RC.OutputCh(CH_7, g.heli_ext_gyro_gain);
|
||||
@ -164,19 +180,21 @@ static void init_motors_out()
|
||||
// these are not really motors, they're servos but we don't rename the function because it fits with the rest of the code better
|
||||
static void output_motors_armed()
|
||||
{
|
||||
// if manual override (i.e. when setting up swash), pass pilot commands straight through to swash
|
||||
if( g.heli_servo_manual == 1 ) {
|
||||
g.rc_1.servo_out = g.rc_1.control_in;
|
||||
g.rc_2.servo_out = g.rc_2.control_in;
|
||||
g.rc_3.servo_out = g.rc_3.control_in;
|
||||
g.rc_4.servo_out = g.rc_4.control_in;
|
||||
}
|
||||
|
||||
//static int counter = 0;
|
||||
g.rc_1.calc_pwm();
|
||||
g.rc_2.calc_pwm();
|
||||
g.rc_3.calc_pwm();
|
||||
g.rc_4.calc_pwm();
|
||||
|
||||
if( heli_manual_override ) {
|
||||
// straight pass through from radio inputs to swash plate
|
||||
heli_move_swash( g.rc_1.control_in, g.rc_2.control_in, g.rc_3.radio_in, g.rc_4.control_in );
|
||||
}else{
|
||||
// source inputs from attitude controller
|
||||
heli_move_swash( g.rc_1.servo_out, g.rc_2.servo_out, g.rc_3.radio_out, g.rc_4.servo_out );
|
||||
}
|
||||
heli_move_swash( g.rc_1.servo_out, g.rc_2.servo_out, g.rc_3.radio_out, g.rc_4.servo_out );
|
||||
}
|
||||
|
||||
// for helis - armed or disarmed we allow servos to move
|
||||
@ -200,7 +218,7 @@ static void output_motor_test()
|
||||
static int heli_get_scaled_throttle(int throttle)
|
||||
{
|
||||
float scaled_throttle = (g.heli_coll_min - 1000) + throttle * heli_throttle_scaler;
|
||||
return g.heli_coll_min - 1000 + (throttle * heli_throttle_scaler);
|
||||
return scaled_throttle;
|
||||
}
|
||||
|
||||
// heli_angle_boost - takes servo_out position
|
||||
|
@ -7,7 +7,7 @@ static void init_motors_out()
|
||||
#if INSTANT_PWM == 0
|
||||
ICR5 = 5000; // 400 hz output CH 1, 2, 9
|
||||
ICR1 = 5000; // 400 hz output CH 3, 4, 10
|
||||
ICR3 = 5000; // 50 hz output CH 7, 8, 11
|
||||
ICR3 = 5000; // 400 hz output CH 7, 8, 11
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -7,7 +7,7 @@ static void init_motors_out()
|
||||
#if INSTANT_PWM == 0
|
||||
ICR5 = 5000; // 400 hz output CH 1, 2, 9
|
||||
ICR1 = 5000; // 400 hz output CH 3, 4, 10
|
||||
ICR3 = 5000; // 50 hz output CH 7, 8, 11
|
||||
ICR3 = 5000; // 400 hz output CH 7, 8, 11
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -7,7 +7,7 @@ static void init_motors_out()
|
||||
#if INSTANT_PWM == 0
|
||||
ICR5 = 5000; // 400 hz output CH 1, 2, 9
|
||||
ICR1 = 5000; // 400 hz output CH 3, 4, 10
|
||||
ICR3 = 5000; // 50 hz output CH 7, 8, 11
|
||||
ICR3 = 5000; // 400 hz output CH 7, 8, 11
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -4,13 +4,12 @@
|
||||
|
||||
#define YAW_DIRECTION 1
|
||||
|
||||
|
||||
static void init_motors_out()
|
||||
{
|
||||
#if INSTANT_PWM == 0
|
||||
ICR5 = 5000; // 400 hz output CH 1, 2, 9
|
||||
ICR1 = 5000; // 400 hz output CH 3, 4, 10
|
||||
ICR3 = 5000; // 50 hz output CH 7, 8, 11
|
||||
ICR3 = 5000; // 400 hz output CH 7, 8, 11
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -30,7 +30,9 @@ static bool check_missed_wp()
|
||||
{
|
||||
int32_t temp = target_bearing - original_target_bearing;
|
||||
temp = wrap_180(temp);
|
||||
return (abs(temp) > 10000); //we pased the waypoint by 10 °
|
||||
//return (abs(temp) > 10000); //we pased the waypoint by 10 °
|
||||
// temp testing
|
||||
return false;
|
||||
}
|
||||
|
||||
// ------------------------------
|
||||
|
@ -9,8 +9,8 @@ static void default_dead_zones()
|
||||
g.rc_1.set_dead_zone(60);
|
||||
g.rc_2.set_dead_zone(60);
|
||||
#if FRAME_CONFIG == HELI_FRAME
|
||||
g.rc_3.set_dead_zone(0);
|
||||
g.rc_4.set_dead_zone(60);
|
||||
g.rc_3.set_dead_zone(20);
|
||||
g.rc_4.set_dead_zone(30);
|
||||
#else
|
||||
g.rc_3.set_dead_zone(60);
|
||||
g.rc_4.set_dead_zone(200);
|
||||
|
@ -469,8 +469,8 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
// initialise swash plate
|
||||
heli_init_swash();
|
||||
|
||||
// source swash plate movements directly from
|
||||
heli_manual_override = true;
|
||||
// source swash plate movements directly from radio
|
||||
g.heli_servo_manual = true;
|
||||
|
||||
// display initial settings
|
||||
report_heli();
|
||||
@ -494,6 +494,9 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
|
||||
// read radio although we don't use it yet
|
||||
read_radio();
|
||||
|
||||
// allow swash plate to move
|
||||
output_motors_armed();
|
||||
|
||||
// record min/max
|
||||
if( state == 1 ) {
|
||||
@ -501,13 +504,12 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
max_roll = abs(g.rc_1.control_in);
|
||||
if( abs(g.rc_2.control_in) > max_pitch )
|
||||
max_pitch = abs(g.rc_2.control_in);
|
||||
if( g.rc_3.radio_in < min_coll )
|
||||
min_coll = g.rc_3.radio_in;
|
||||
if( g.rc_3.radio_in > max_coll )
|
||||
max_coll = g.rc_3.radio_in;
|
||||
min_tail = min(g.rc_4.radio_in, min_tail);
|
||||
max_tail = max(g.rc_4.radio_in, max_tail);
|
||||
//Serial.printf_P(PSTR("4: ri:%d \tro:%d \tso:%d \n"), (int)g.rc_4.radio_in, (int)g.rc_4.radio_out, (int)g.rc_4.servo_out);
|
||||
if( g.rc_3.radio_out < min_coll )
|
||||
min_coll = g.rc_3.radio_out;
|
||||
if( g.rc_3.radio_out > max_coll )
|
||||
max_coll = g.rc_3.radio_out;
|
||||
min_tail = min(g.rc_4.radio_out, min_tail);
|
||||
max_tail = max(g.rc_4.radio_out, max_tail);
|
||||
}
|
||||
|
||||
if( Serial.available() ) {
|
||||
@ -533,8 +535,8 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
break;
|
||||
case 'c':
|
||||
case 'C':
|
||||
if( g.rc_3.radio_in >= 900 && g.rc_3.radio_in <= 2100 ) {
|
||||
g.heli_coll_mid = g.rc_3.radio_in;
|
||||
if( g.rc_3.radio_out >= 900 && g.rc_3.radio_out <= 2100 ) {
|
||||
g.heli_coll_mid = g.rc_3.radio_out;
|
||||
Serial.printf_P(PSTR("Collective when blade pitch at zero: %d\n"),(int)g.heli_coll_mid);
|
||||
}
|
||||
break;
|
||||
@ -561,7 +563,7 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
max_pitch = abs(g.rc_2.control_in);
|
||||
min_coll = 2000;
|
||||
max_coll = 1000;
|
||||
min_tail = max_tail = abs(g.rc_4.radio_in);
|
||||
min_tail = max_tail = abs(g.rc_4.radio_out);
|
||||
}else{
|
||||
state = 0; // switch back to normal mode
|
||||
// double check values aren't totally terrible
|
||||
@ -639,9 +641,6 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
}
|
||||
}
|
||||
|
||||
// allow swash plate to move
|
||||
output_motors_armed();
|
||||
|
||||
delay(20);
|
||||
}
|
||||
|
||||
@ -664,7 +663,7 @@ setup_heli(uint8_t argc, const Menu::arg *argv)
|
||||
g.heli_servo_averaging.save();
|
||||
|
||||
// return swash plate movements to attitude controller
|
||||
heli_manual_override = false;
|
||||
g.heli_servo_manual = false;
|
||||
|
||||
return(0);
|
||||
}
|
||||
@ -815,7 +814,7 @@ static void report_batt_monitor()
|
||||
static void report_wp(byte index = 255)
|
||||
{
|
||||
if(index == 255){
|
||||
for(byte i = 0; i <= g.command_total; i++){
|
||||
for(byte i = 0; i < g.command_total; i++){
|
||||
struct Location temp = get_cmd_with_index(i);
|
||||
print_wp(&temp, i);
|
||||
}
|
||||
@ -1145,14 +1144,17 @@ init_esc()
|
||||
|
||||
static void print_wp(struct Location *cmd, byte index)
|
||||
{
|
||||
Serial.printf_P(PSTR("command #: %d id:%d op:%d p1:%d p2:%ld p3:%ld p4:%ld \n"),
|
||||
float t1 = (float)cmd->lat / t7;
|
||||
float t2 = (float)cmd->lng / t7;
|
||||
|
||||
Serial.printf_P(PSTR("scommand #: %d id:%d op:%d p1:%d p2:%ld p3:%4.7f p4:%4.7f \n"),
|
||||
(int)index,
|
||||
(int)cmd->id,
|
||||
(int)cmd->options,
|
||||
(int)cmd->p1,
|
||||
cmd->alt,
|
||||
cmd->lat,
|
||||
cmd->lng);
|
||||
(long)cmd->alt,
|
||||
t1,
|
||||
t2);
|
||||
}
|
||||
|
||||
static void report_gps()
|
||||
|
@ -178,6 +178,7 @@ static void init_ardupilot()
|
||||
#endif
|
||||
|
||||
#if FRAME_CONFIG == HELI_FRAME
|
||||
g.heli_servo_manual = false;
|
||||
heli_init_swash(); // heli initialisation
|
||||
#endif
|
||||
|
||||
@ -377,42 +378,33 @@ static void set_mode(byte mode)
|
||||
// report the GPS and Motor arming status
|
||||
led_mode = NORMAL_LEDS;
|
||||
|
||||
reset_nav();
|
||||
|
||||
switch(control_mode)
|
||||
{
|
||||
case ACRO:
|
||||
yaw_mode = YAW_ACRO;
|
||||
roll_pitch_mode = ROLL_PITCH_ACRO;
|
||||
throttle_mode = THROTTLE_MANUAL;
|
||||
reset_hold_I();
|
||||
break;
|
||||
|
||||
case STABILIZE:
|
||||
yaw_mode = YAW_HOLD;
|
||||
roll_pitch_mode = ROLL_PITCH_STABLE;
|
||||
throttle_mode = THROTTLE_MANUAL;
|
||||
reset_hold_I();
|
||||
break;
|
||||
|
||||
case ALT_HOLD:
|
||||
yaw_mode = ALT_HOLD_YAW;
|
||||
roll_pitch_mode = ALT_HOLD_RP;
|
||||
throttle_mode = ALT_HOLD_THR;
|
||||
reset_hold_I();
|
||||
|
||||
init_throttle_cruise();
|
||||
next_WP = current_loc;
|
||||
break;
|
||||
|
||||
case AUTO:
|
||||
reset_hold_I();
|
||||
yaw_mode = AUTO_YAW;
|
||||
roll_pitch_mode = AUTO_RP;
|
||||
throttle_mode = AUTO_THR;
|
||||
|
||||
init_throttle_cruise();
|
||||
|
||||
// loads the commands from where we left off
|
||||
init_commands();
|
||||
break;
|
||||
@ -422,8 +414,7 @@ static void set_mode(byte mode)
|
||||
roll_pitch_mode = CIRCLE_RP;
|
||||
throttle_mode = CIRCLE_THR;
|
||||
|
||||
init_throttle_cruise();
|
||||
next_WP = current_loc;
|
||||
next_WP = current_loc;
|
||||
break;
|
||||
|
||||
case LOITER:
|
||||
@ -431,8 +422,7 @@ static void set_mode(byte mode)
|
||||
roll_pitch_mode = LOITER_RP;
|
||||
throttle_mode = LOITER_THR;
|
||||
|
||||
init_throttle_cruise();
|
||||
next_WP = current_loc;
|
||||
next_WP = current_loc;
|
||||
break;
|
||||
|
||||
case POSITION:
|
||||
@ -440,7 +430,7 @@ static void set_mode(byte mode)
|
||||
roll_pitch_mode = ROLL_PITCH_AUTO;
|
||||
throttle_mode = THROTTLE_MANUAL;
|
||||
|
||||
next_WP = current_loc;
|
||||
next_WP = current_loc;
|
||||
break;
|
||||
|
||||
case GUIDED:
|
||||
@ -448,8 +438,6 @@ static void set_mode(byte mode)
|
||||
roll_pitch_mode = ROLL_PITCH_AUTO;
|
||||
throttle_mode = THROTTLE_AUTO;
|
||||
|
||||
//xtrack_enabled = true;
|
||||
init_throttle_cruise();
|
||||
next_WP = current_loc;
|
||||
set_next_WP(&guided_WP);
|
||||
break;
|
||||
@ -459,8 +447,6 @@ static void set_mode(byte mode)
|
||||
roll_pitch_mode = RTL_RP;
|
||||
throttle_mode = RTL_THR;
|
||||
|
||||
//xtrack_enabled = true;
|
||||
init_throttle_cruise();
|
||||
do_RTL();
|
||||
break;
|
||||
|
||||
@ -468,6 +454,22 @@ static void set_mode(byte mode)
|
||||
break;
|
||||
}
|
||||
|
||||
if(throttle_mode == THROTTLE_MANUAL){
|
||||
// reset all of the throttle iterms
|
||||
g.pi_alt_hold.reset_I();
|
||||
g.pi_throttle.reset_I();
|
||||
}else { // an automatic throttle
|
||||
|
||||
// todo: replace with a throttle cruise estimator
|
||||
init_throttle_cruise();
|
||||
}
|
||||
|
||||
if(roll_pitch_mode <= ROLL_PITCH_ACRO){
|
||||
// We are under manual attitude control
|
||||
// reset out nav parameters
|
||||
reset_nav();
|
||||
}
|
||||
|
||||
Log_Write_Mode(control_mode);
|
||||
}
|
||||
|
||||
|
@ -70,7 +70,7 @@ const struct Menu::command test_menu_commands[] PROGMEM = {
|
||||
{"tri", test_tri},
|
||||
{"current", test_current},
|
||||
{"relay", test_relay},
|
||||
{"waypoints", test_wp},
|
||||
{"wp", test_wp},
|
||||
//{"nav", test_nav},
|
||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||
{"altitude", test_baro},
|
||||
@ -755,6 +755,7 @@ test_wp(uint8_t argc, const Menu::arg *argv)
|
||||
}
|
||||
|
||||
static int8_t test_rawgps(uint8_t argc, const Menu::arg *argv) {
|
||||
/*
|
||||
print_hit_enter();
|
||||
delay(1000);
|
||||
while(1){
|
||||
@ -772,6 +773,7 @@ static int8_t test_rawgps(uint8_t argc, const Menu::arg *argv) {
|
||||
return (0);
|
||||
}
|
||||
}
|
||||
*/
|
||||
}
|
||||
|
||||
/*static int8_t
|
||||
|
@ -16,4 +16,24 @@
|
||||
|
||||
/*
|
||||
#define HIL_MODE HIL_MODE_ATTITUDE
|
||||
*/
|
||||
*/
|
||||
|
||||
/*
|
||||
// HIL_MODE SELECTION
|
||||
//
|
||||
// Mavlink supports
|
||||
// 1. HIL_MODE_ATTITUDE : simulated position, airspeed, and attitude
|
||||
// 2. HIL_MODE_SENSORS: full sensor simulation
|
||||
#define HIL_MODE HIL_MODE_ATTITUDE
|
||||
|
||||
// Sensors
|
||||
// All sensors are supported in all modes.
|
||||
// The magnetometer is not used in
|
||||
// HIL_MODE_ATTITUDE but you may leave it
|
||||
// enabled if you wish.
|
||||
#define AIRSPEED_SENSOR ENABLED
|
||||
#define MAGNETOMETER ENABLED
|
||||
#define AIRSPEED_CRUISE 25
|
||||
#define THROTTLE_FAILSAFE ENABLED
|
||||
*/
|
||||
#define GPS_PROTOCOL GPS_NONE
|
@ -1,6 +1,6 @@
|
||||
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
||||
|
||||
#define THISFIRMWARE "ArduPlane V2.24"
|
||||
#define THISFIRMWARE "ArduPlane V2.251"
|
||||
/*
|
||||
Authors: Doug Weibel, Jose Julio, Jordi Munoz, Jason Short
|
||||
Thanks to: Chris Anderson, HappyKillMore, Bill Premerlani, James Cohen, JB from rotorFX, Automatik, Fefenin, Peter Meister, Remzibi
|
||||
@ -450,7 +450,9 @@ void loop()
|
||||
if (millis() - perf_mon_timer > 20000) {
|
||||
if (mainLoop_count != 0) {
|
||||
if (g.log_bitmask & MASK_LOG_PM)
|
||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||
Log_Write_Performance();
|
||||
#endif
|
||||
|
||||
resetPerfData();
|
||||
}
|
||||
|
@ -53,7 +53,9 @@ print_log_menu(void)
|
||||
{
|
||||
int log_start;
|
||||
int log_end;
|
||||
byte last_log_num = get_num_logs();
|
||||
int temp;
|
||||
uint16_t num_logs = get_num_logs();
|
||||
//Serial.print("num logs: "); Serial.println(num_logs, DEC);
|
||||
|
||||
Serial.printf_P(PSTR("logs enabled: "));
|
||||
if (0 == g.log_bitmask) {
|
||||
@ -78,15 +80,16 @@ print_log_menu(void)
|
||||
}
|
||||
Serial.println();
|
||||
|
||||
if (last_log_num == 0) {
|
||||
if (num_logs == 0) {
|
||||
Serial.printf_P(PSTR("\nNo logs available for download\n"));
|
||||
}else{
|
||||
|
||||
Serial.printf_P(PSTR("\n%d logs available for download\n"), last_log_num);
|
||||
for(int i=1;i<last_log_num+1;i++) {
|
||||
get_log_boundaries(i, log_start, log_end);
|
||||
Serial.printf_P(PSTR("\n%d logs available for download\n"), num_logs);
|
||||
for(int i=num_logs;i>=1;i--) {
|
||||
temp = g.log_last_filenumber-i+1;
|
||||
get_log_boundaries(temp, log_start, log_end);
|
||||
Serial.printf_P(PSTR("Log number %d, start page %d, end page %d\n"),
|
||||
i, log_start, log_end);
|
||||
temp, log_start, log_end);
|
||||
}
|
||||
Serial.println();
|
||||
}
|
||||
@ -103,8 +106,8 @@ dump_log(uint8_t argc, const Menu::arg *argv)
|
||||
|
||||
// check that the requested log number can be read
|
||||
dump_log = argv[1].i;
|
||||
last_log_num = get_num_logs();
|
||||
if ((argc != 2) || (dump_log < 1) || (dump_log > last_log_num)) {
|
||||
last_log_num = g.log_last_filenumber;
|
||||
if ((argc != 2) || (dump_log <= (last_log_num - get_num_logs())) || (dump_log > last_log_num)) {
|
||||
Serial.printf_P(PSTR("bad log number\n"));
|
||||
return(-1);
|
||||
}
|
||||
@ -128,15 +131,13 @@ erase_logs(uint8_t argc, const Menu::arg *argv)
|
||||
delay(1000);
|
||||
}
|
||||
Serial.printf_P(PSTR("\nErasing log...\n"));
|
||||
for(int j = 1; j < 4096; j++)
|
||||
DataFlash.SetFileNumber(0xFFFF);
|
||||
for(int j = 1; j <= DF_LAST_PAGE; j++) {
|
||||
DataFlash.PageErase(j);
|
||||
DataFlash.StartWrite(1);
|
||||
DataFlash.WriteByte(HEAD_BYTE1);
|
||||
DataFlash.WriteByte(HEAD_BYTE2);
|
||||
DataFlash.WriteByte(LOG_INDEX_MSG);
|
||||
DataFlash.WriteByte(0);
|
||||
DataFlash.WriteByte(END_BYTE);
|
||||
DataFlash.FinishWrite();
|
||||
DataFlash.StartWrite(j); // We need this step to clean FileNumbers
|
||||
}
|
||||
g.log_last_filenumber.set_and_save(0);
|
||||
|
||||
Serial.printf_P(PSTR("\nLog erased.\n"));
|
||||
return 0;
|
||||
}
|
||||
@ -192,139 +193,214 @@ process_logs(uint8_t argc, const Menu::arg *argv)
|
||||
}
|
||||
|
||||
|
||||
// This function determines the number of whole or partial log files in the DataFlash
|
||||
// Wholly overwritten files are (of course) lost.
|
||||
static byte get_num_logs(void)
|
||||
{
|
||||
int page = 1;
|
||||
byte data;
|
||||
byte log_step = 0;
|
||||
uint16_t lastpage;
|
||||
uint16_t last;
|
||||
uint16_t first;
|
||||
|
||||
if(g.log_last_filenumber < 1) return 0;
|
||||
|
||||
DataFlash.StartRead(1);
|
||||
|
||||
while (page == 1) {
|
||||
data = DataFlash.ReadByte();
|
||||
|
||||
switch(log_step){ //This is a state machine to read the packets
|
||||
case 0:
|
||||
if(data==HEAD_BYTE1) // Head byte 1
|
||||
log_step++;
|
||||
break;
|
||||
|
||||
case 1:
|
||||
if(data==HEAD_BYTE2) // Head byte 2
|
||||
log_step++;
|
||||
else
|
||||
log_step = 0;
|
||||
break;
|
||||
|
||||
case 2:
|
||||
if(data==LOG_INDEX_MSG){
|
||||
byte num_logs = DataFlash.ReadByte();
|
||||
return num_logs;
|
||||
}else{
|
||||
log_step=0; // Restart, we have a problem...
|
||||
}
|
||||
break;
|
||||
}
|
||||
page = DataFlash.GetPage();
|
||||
if(DataFlash.GetFileNumber() == 0XFFFF) return 0;
|
||||
|
||||
lastpage = find_last();
|
||||
DataFlash.StartRead(lastpage);
|
||||
last = DataFlash.GetFileNumber();
|
||||
DataFlash.StartRead(lastpage + 2);
|
||||
first = DataFlash.GetFileNumber();
|
||||
if(first == 0xFFFF) {
|
||||
DataFlash.StartRead(1);
|
||||
first = DataFlash.GetFileNumber();
|
||||
}
|
||||
if(last == first)
|
||||
{
|
||||
return 1;
|
||||
} else {
|
||||
return (last - first + 1);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
// send the number of the last log?
|
||||
static void start_new_log(byte num_existing_logs)
|
||||
|
||||
// This function starts a new log file in the DataFlash
|
||||
static void start_new_log()
|
||||
{
|
||||
int start_pages[50] = {0,0,0};
|
||||
int end_pages[50] = {0,0,0};
|
||||
uint16_t last_page;
|
||||
|
||||
if(num_existing_logs > 0) {
|
||||
for(int i=0;i<num_existing_logs;i++) {
|
||||
get_log_boundaries(i+1,start_pages[i],end_pages[i]);
|
||||
}
|
||||
end_pages[num_existing_logs - 1] = find_last_log_page(start_pages[num_existing_logs - 1]);
|
||||
}
|
||||
|
||||
if(num_existing_logs == 0 ||
|
||||
(end_pages[num_existing_logs - 1] < 4095 && num_existing_logs < MAX_NUM_LOGS)) {
|
||||
if(num_existing_logs > 0)
|
||||
start_pages[num_existing_logs] = end_pages[num_existing_logs - 1] + 1;
|
||||
else
|
||||
start_pages[0] = 2;
|
||||
num_existing_logs++;
|
||||
DataFlash.StartWrite(1);
|
||||
DataFlash.WriteByte(HEAD_BYTE1);
|
||||
DataFlash.WriteByte(HEAD_BYTE2);
|
||||
DataFlash.WriteByte(LOG_INDEX_MSG);
|
||||
DataFlash.WriteByte(num_existing_logs);
|
||||
for(int i=0;i<MAX_NUM_LOGS;i++) {
|
||||
DataFlash.WriteInt(start_pages[i]);
|
||||
DataFlash.WriteInt(end_pages[i]);
|
||||
}
|
||||
DataFlash.WriteByte(END_BYTE);
|
||||
DataFlash.FinishWrite();
|
||||
DataFlash.StartWrite(start_pages[num_existing_logs-1]);
|
||||
}else{
|
||||
gcs_send_text_P(SEVERITY_LOW,PSTR("<start_new_log> Logs full - logging discontinued"));
|
||||
if(g.log_last_filenumber < 1) {
|
||||
last_page = 0;
|
||||
} else {
|
||||
last_page = find_last();
|
||||
}
|
||||
g.log_last_filenumber.set_and_save(g.log_last_filenumber+1);
|
||||
DataFlash.SetFileNumber(g.log_last_filenumber);
|
||||
DataFlash.StartWrite(last_page + 1);
|
||||
}
|
||||
|
||||
// This function finds the first and last pages of a log file
|
||||
// The first page may be greater than the last page if the DataFlash has been filled and partially overwritten.
|
||||
static void get_log_boundaries(byte log_num, int & start_page, int & end_page)
|
||||
{
|
||||
int page = 1;
|
||||
byte data;
|
||||
byte log_step = 0;
|
||||
|
||||
DataFlash.StartRead(1);
|
||||
while (page == 1) {
|
||||
data = DataFlash.ReadByte();
|
||||
switch(log_step) //This is a state machine to read the packets
|
||||
{
|
||||
case 0:
|
||||
if(data==HEAD_BYTE1) // Head byte 1
|
||||
log_step++;
|
||||
break;
|
||||
case 1:
|
||||
if(data==HEAD_BYTE2) // Head byte 2
|
||||
log_step++;
|
||||
else
|
||||
log_step = 0;
|
||||
break;
|
||||
case 2:
|
||||
if(data==LOG_INDEX_MSG){
|
||||
byte num_logs = DataFlash.ReadByte();
|
||||
for(int i=0;i<log_num;i++) {
|
||||
start_page = DataFlash.ReadInt();
|
||||
end_page = DataFlash.ReadInt();
|
||||
}
|
||||
if(log_num==num_logs)
|
||||
end_page = find_last_log_page(start_page);
|
||||
|
||||
return; // This is the normal exit point
|
||||
}else{
|
||||
log_step=0; // Restart, we have a problem...
|
||||
}
|
||||
break;
|
||||
int num = get_num_logs();
|
||||
if(num == 1)
|
||||
{
|
||||
DataFlash.StartRead(DF_LAST_PAGE);
|
||||
if(DataFlash.GetFileNumber() == 0xFFFF)
|
||||
{
|
||||
start_page = 1;
|
||||
end_page = find_last_log_page((uint16_t)log_num);
|
||||
} else {
|
||||
end_page = find_last_log_page((uint16_t)log_num);
|
||||
start_page = end_page + 1;
|
||||
}
|
||||
|
||||
} else {
|
||||
end_page = find_last_log_page((uint16_t)log_num);
|
||||
if(log_num==1)
|
||||
start_page = 1;
|
||||
else
|
||||
if(log_num == g.log_last_filenumber - num + 1) {
|
||||
start_page = find_last_log_page(g.log_last_filenumber) + 1;
|
||||
} else {
|
||||
start_page = find_last_log_page((uint16_t)(log_num-1)) + 1;
|
||||
}
|
||||
page = DataFlash.GetPage();
|
||||
}
|
||||
// Error condition if we reach here with page = 2 TO DO - report condition
|
||||
if(start_page == DF_LAST_PAGE+1 || start_page == 0) start_page=1;
|
||||
}
|
||||
|
||||
// This function finds the last page of the last file
|
||||
// It also cleans up in the situation where a file was initiated, but no pages written
|
||||
static int find_last(void)
|
||||
{
|
||||
int16_t num;
|
||||
do
|
||||
{
|
||||
num = find_last_log_page(g.log_last_filenumber);
|
||||
if (num == -1) g.log_last_filenumber.set_and_save(g.log_last_filenumber - 1);
|
||||
} while (num == -1);
|
||||
return num;
|
||||
}
|
||||
|
||||
static int find_last_log_page(int bottom_page)
|
||||
// This function finds the last page of a particular log file
|
||||
static int find_last_log_page(uint16_t log_number)
|
||||
{
|
||||
int top_page = 4096;
|
||||
int look_page;
|
||||
int32_t check;
|
||||
|
||||
while((top_page - bottom_page) > 1) {
|
||||
look_page = (top_page + bottom_page) / 2;
|
||||
DataFlash.StartRead(look_page);
|
||||
check = DataFlash.ReadLong();
|
||||
if(check == -1L)
|
||||
top_page = look_page;
|
||||
else
|
||||
bottom_page = look_page;
|
||||
int16_t bottom_page;
|
||||
int16_t top_page;
|
||||
int16_t bottom_page_file;
|
||||
int16_t bottom_page_filepage;
|
||||
int16_t top_page_file;
|
||||
int16_t top_page_filepage;
|
||||
int16_t look_page;
|
||||
int16_t look_page_file;
|
||||
int16_t look_page_filepage;
|
||||
int16_t check;
|
||||
bool XLflag = false;
|
||||
|
||||
// First see if the logs are empty
|
||||
DataFlash.StartRead(1);
|
||||
if(DataFlash.GetFileNumber() == 0XFFFF) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
// Next, see if logs wrap the top of the dataflash
|
||||
DataFlash.StartRead(DF_LAST_PAGE);
|
||||
if(DataFlash.GetFileNumber() == 0xFFFF)
|
||||
{
|
||||
// This case is that we have not wrapped the top of the dataflash
|
||||
top_page = DF_LAST_PAGE;
|
||||
bottom_page = 1;
|
||||
while((top_page - bottom_page) > 1) {
|
||||
look_page = (top_page + bottom_page) / 2;
|
||||
DataFlash.StartRead(look_page);
|
||||
if(DataFlash.GetFileNumber() > log_number)
|
||||
top_page = look_page;
|
||||
else
|
||||
bottom_page = look_page;
|
||||
}
|
||||
return bottom_page;
|
||||
|
||||
} else {
|
||||
// The else case is that the logs do wrap the top of the dataflash
|
||||
bottom_page = 1;
|
||||
top_page = DF_LAST_PAGE;
|
||||
DataFlash.StartRead(bottom_page);
|
||||
bottom_page_file = DataFlash.GetFileNumber();
|
||||
bottom_page_filepage = DataFlash.GetFilePage();
|
||||
DataFlash.StartRead(top_page);
|
||||
top_page_file = DataFlash.GetFileNumber();
|
||||
top_page_filepage = DataFlash.GetFilePage();
|
||||
|
||||
// Check is we have exactly filled the dataflash but not wrapped. If so we can exit quickly.
|
||||
if(top_page_file == log_number && bottom_page_file != log_number) {
|
||||
return top_page_file;
|
||||
}
|
||||
|
||||
// Check if the top is 1 file higher than we want. If so we can exit quickly.
|
||||
if(top_page_file == log_number+1) {
|
||||
return top_page - top_page_filepage;
|
||||
}
|
||||
|
||||
// Check if the file has partially overwritten itself
|
||||
if(top_page_filepage >= DF_LAST_PAGE) {
|
||||
XLflag = true;
|
||||
} else {
|
||||
top_page = top_page - top_page_filepage;
|
||||
DataFlash.StartRead(top_page);
|
||||
top_page_file = DataFlash.GetFileNumber();
|
||||
}
|
||||
if(top_page_file == log_number) {
|
||||
bottom_page = top_page;
|
||||
top_page = DF_LAST_PAGE;
|
||||
DataFlash.StartRead(top_page);
|
||||
top_page_filepage = DataFlash.GetFilePage();
|
||||
if(XLflag) bottom_page = 1;
|
||||
|
||||
while((top_page - bottom_page) > 1) {
|
||||
look_page = (top_page + bottom_page) / 2;
|
||||
DataFlash.StartRead(look_page);
|
||||
if(DataFlash.GetFilePage() < top_page_filepage)
|
||||
{
|
||||
top_page = look_page;
|
||||
top_page_filepage = DataFlash.GetFilePage();
|
||||
} else {
|
||||
bottom_page = look_page;
|
||||
}
|
||||
}
|
||||
return bottom_page;
|
||||
}
|
||||
|
||||
|
||||
// Step down through the files to find the one we want
|
||||
bottom_page = top_page;
|
||||
bottom_page_filepage = top_page_filepage;
|
||||
do
|
||||
{
|
||||
top_page = bottom_page;
|
||||
bottom_page = bottom_page - bottom_page_filepage;
|
||||
if(bottom_page < 1) bottom_page = 1;
|
||||
DataFlash.StartRead(bottom_page);
|
||||
bottom_page_file = DataFlash.GetFileNumber();
|
||||
bottom_page_filepage = DataFlash.GetFilePage();
|
||||
} while (bottom_page_file != log_number && bottom_page != 1);
|
||||
|
||||
// Deal with stepping down too far due to overwriting a file
|
||||
while((top_page - bottom_page) > 1) {
|
||||
look_page = (top_page + bottom_page) / 2;
|
||||
DataFlash.StartRead(look_page);
|
||||
if(DataFlash.GetFileNumber() < log_number)
|
||||
top_page = look_page;
|
||||
else
|
||||
bottom_page = look_page;
|
||||
}
|
||||
|
||||
// The -1 return is for the case where a very short power up increments the log
|
||||
// number counter but no log file is actually created. This happens if power is
|
||||
// removed before the first page is written to flash.
|
||||
if(bottom_page ==1 && DataFlash.GetFileNumber() != log_number) return -1;
|
||||
|
||||
return bottom_page;
|
||||
}
|
||||
return top_page;
|
||||
}
|
||||
|
||||
|
||||
@ -341,6 +417,7 @@ static void Log_Write_Attitude(int log_roll, int log_pitch, uint16_t log_yaw)
|
||||
}
|
||||
|
||||
// Write a performance monitoring packet. Total length : 19 bytes
|
||||
#if HIL_MODE != HIL_MODE_ATTITUDE
|
||||
static void Log_Write_Performance()
|
||||
{
|
||||
DataFlash.WriteByte(HEAD_BYTE1);
|
||||
@ -355,9 +432,13 @@ static void Log_Write_Performance()
|
||||
DataFlash.WriteByte(dcm.renorm_blowup_count);
|
||||
DataFlash.WriteByte(gps_fix_count);
|
||||
DataFlash.WriteInt((int)(dcm.get_health() * 1000));
|
||||
DataFlash.WriteInt((int)(dcm.get_integrator().x * 1000));
|
||||
DataFlash.WriteInt((int)(dcm.get_integrator().y * 1000));
|
||||
DataFlash.WriteInt((int)(dcm.get_integrator().z * 1000));
|
||||
DataFlash.WriteInt(pmTest1);
|
||||
DataFlash.WriteByte(END_BYTE);
|
||||
}
|
||||
#endif
|
||||
|
||||
// Write a command processing packet. Total length : 19 bytes
|
||||
//void Log_Write_Cmd(byte num, byte id, byte p1, long alt, long lat, long lng)
|
||||
@ -547,7 +628,7 @@ static void Log_Read_Performance()
|
||||
pm_time = DataFlash.ReadLong();
|
||||
Serial.print(pm_time);
|
||||
Serial.print(comma);
|
||||
for (int y = 1; y <= 9; y++) {
|
||||
for (int y = 1; y <= 12; y++) {
|
||||
if(y < 3 || y > 7){
|
||||
logvar = DataFlash.ReadInt();
|
||||
}else{
|
||||
@ -642,17 +723,33 @@ static void Log_Read_Raw()
|
||||
// Read the DataFlash log memory : Packet Parser
|
||||
static void Log_Read(int start_page, int end_page)
|
||||
{
|
||||
byte data;
|
||||
byte log_step = 0;
|
||||
int packet_count = 0;
|
||||
int page = start_page;
|
||||
|
||||
|
||||
#ifdef AIRFRAME_NAME
|
||||
Serial.printf_P(PSTR((AIRFRAME_NAME)
|
||||
#endif
|
||||
Serial.printf_P(PSTR("\n" THISFIRMWARE
|
||||
"\nFree RAM: %u\n"),
|
||||
memcheck_available_memory());
|
||||
|
||||
if(start_page > end_page)
|
||||
{
|
||||
packet_count = Log_Read_Process(start_page, DF_LAST_PAGE);
|
||||
packet_count += Log_Read_Process(1, end_page);
|
||||
} else {
|
||||
packet_count = Log_Read_Process(start_page, end_page);
|
||||
}
|
||||
|
||||
Serial.printf_P(PSTR("Number of packets read: %d\n"), packet_count);
|
||||
}
|
||||
|
||||
// Read the DataFlash log memory : Packet Parser
|
||||
static int Log_Read_Process(int start_page, int end_page)
|
||||
{
|
||||
byte data;
|
||||
byte log_step = 0;
|
||||
int page = start_page;
|
||||
int packet_count = 0;
|
||||
|
||||
DataFlash.StartRead(start_page);
|
||||
while (page < end_page && page != -1){
|
||||
@ -726,7 +823,7 @@ static void Log_Read(int start_page, int end_page)
|
||||
}
|
||||
page = DataFlash.GetPage();
|
||||
}
|
||||
Serial.printf_P(PSTR("Number of packets read: %d\n"), packet_count);
|
||||
return packet_count;
|
||||
}
|
||||
|
||||
#else // LOGGING_ENABLED
|
||||
@ -742,7 +839,7 @@ static void Log_Write_GPS( long log_Time, long log_Lattitude, long log_Longitude
|
||||
static void Log_Write_Performance() {}
|
||||
static int8_t process_logs(uint8_t argc, const Menu::arg *argv) { return 0; }
|
||||
static byte get_num_logs(void) { return 0; }
|
||||
static void start_new_log(byte num_existing_logs) {}
|
||||
static void start_new_log() {}
|
||||
static void Log_Write_Attitude(int log_roll, int log_pitch, uint16_t log_yaw) {}
|
||||
static void Log_Write_Control_Tuning() {}
|
||||
static void Log_Write_Raw() {}
|
||||
|
@ -69,6 +69,7 @@ public:
|
||||
k_param_flap_2_percent,
|
||||
k_param_flap_2_speed,
|
||||
k_param_num_resets,
|
||||
k_param_log_last_filenumber,
|
||||
|
||||
|
||||
// 110: Telemetry control
|
||||
@ -305,6 +306,7 @@ public:
|
||||
AP_Int8 reverse_ch2_elevon;
|
||||
AP_Int16 num_resets;
|
||||
AP_Int16 log_bitmask;
|
||||
AP_Int16 log_last_filenumber;
|
||||
AP_Int16 airspeed_cruise;
|
||||
AP_Int16 pitch_trim;
|
||||
AP_Int16 RTL_altitude;
|
||||
@ -410,6 +412,7 @@ public:
|
||||
reverse_ch2_elevon (ELEVON_CH2_REVERSE, k_param_reverse_ch2_elevon, PSTR("ELEVON_CH2_REV")),
|
||||
num_resets (0, k_param_num_resets, PSTR("SYS_NUM_RESETS")),
|
||||
log_bitmask (DEFAULT_LOG_BITMASK, k_param_log_bitmask, PSTR("LOG_BITMASK")),
|
||||
log_last_filenumber (0, k_param_log_last_filenumber, PSTR("LOG_LASTFILE")),
|
||||
airspeed_cruise (AIRSPEED_CRUISE_CM, k_param_airspeed_cruise, PSTR("TRIM_ARSPD_CM")),
|
||||
pitch_trim (0, k_param_pitch_trim, PSTR("TRIM_PITCH_CD")),
|
||||
RTL_altitude (ALT_HOLD_HOME_CM, k_param_RTL_altitude, PSTR("ALT_HOLD_RTL")),
|
||||
|
@ -469,19 +469,30 @@ static void do_loiter_at_location()
|
||||
static void do_jump()
|
||||
{
|
||||
struct Location temp;
|
||||
gcs_send_text_fmt(PSTR("In jump. Jumps left: %i"),next_nonnav_command.lat);
|
||||
if(next_nonnav_command.lat > 0) {
|
||||
|
||||
nav_command_ID = NO_COMMAND;
|
||||
nav_command_ID = NO_COMMAND;
|
||||
next_nav_command.id = NO_COMMAND;
|
||||
non_nav_command_ID = NO_COMMAND;
|
||||
|
||||
temp = get_cmd_with_index(g.command_index);
|
||||
temp.lat = next_nonnav_command.lat - 1; // Decrement repeat counter
|
||||
|
||||
set_cmd_with_index(temp, g.command_index);
|
||||
gcs_send_text_fmt(PSTR("setting command index: %i"),next_nonnav_command.p1 - 1);
|
||||
g.command_index.set_and_save(next_nonnav_command.p1 - 1);
|
||||
nav_command_index = next_nonnav_command.p1 - 1;
|
||||
next_WP = prev_WP; // Need to back "next_WP" up as it was set to the next waypoint following the jump
|
||||
process_next_command();
|
||||
} else if (next_nonnav_command.lat == -1) { // A repeat count of -1 = repeat forever
|
||||
nav_command_ID = NO_COMMAND;
|
||||
non_nav_command_ID = NO_COMMAND;
|
||||
gcs_send_text_fmt(PSTR("setting command index: %i"),next_nonnav_command.p1 - 1);
|
||||
g.command_index.set_and_save(next_nonnav_command.p1 - 1);
|
||||
nav_command_index = next_nonnav_command.p1 - 1;
|
||||
next_WP = prev_WP; // Need to back "next_WP" up as it was set to the next waypoint following the jump
|
||||
process_next_command();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -16,8 +16,8 @@ static void change_command(uint8_t cmd_index)
|
||||
non_nav_command_ID = NO_COMMAND;
|
||||
|
||||
nav_command_index = cmd_index - 1;
|
||||
g.command_index.set_and_save(cmd_index - 1);
|
||||
process_next_command();
|
||||
g.command_index.set_and_save(cmd_index);
|
||||
update_commands();
|
||||
}
|
||||
}
|
||||
|
||||
@ -25,23 +25,21 @@ static void change_command(uint8_t cmd_index)
|
||||
// --------------------
|
||||
static void update_commands(void)
|
||||
{
|
||||
if(home_is_set == false){
|
||||
return; // don't do commands
|
||||
}
|
||||
|
||||
if(control_mode == AUTO){
|
||||
process_next_command();
|
||||
if(home_is_set == true && g.command_total > 1){
|
||||
process_next_command();
|
||||
}
|
||||
} // Other (eg GCS_Auto) modes may be implemented here
|
||||
}
|
||||
|
||||
static void verify_commands(void)
|
||||
{
|
||||
if(verify_nav_command()){
|
||||
nav_command_ID = NO_COMMAND;
|
||||
nav_command_ID = NO_COMMAND;
|
||||
}
|
||||
|
||||
if(verify_condition_command()){
|
||||
non_nav_command_ID = NO_COMMAND;
|
||||
non_nav_command_ID = NO_COMMAND;
|
||||
}
|
||||
}
|
||||
|
||||
@ -63,7 +61,9 @@ static void process_next_command()
|
||||
nav_command_index++;
|
||||
temp = get_cmd_with_index(nav_command_index);
|
||||
}
|
||||
|
||||
gcs_send_text_fmt(PSTR("Nav command index updated to #%i"),nav_command_index);
|
||||
|
||||
if(nav_command_index > g.command_total){
|
||||
// we are out of commands!
|
||||
gcs_send_text_P(SEVERITY_LOW,PSTR("out of commands!"));
|
||||
@ -99,12 +99,14 @@ static void process_next_command()
|
||||
g.command_index.set_and_save(nav_command_index);
|
||||
non_nav_command_index = nav_command_index;
|
||||
non_nav_command_ID = WAIT_COMMAND;
|
||||
gcs_send_text_fmt(PSTR("Non-Nav command ID updated to #%i"),non_nav_command_ID);
|
||||
gcs_send_text_fmt(PSTR("Non-Nav command ID updated to #%i"),non_nav_command_ID);
|
||||
|
||||
} else { // The next command is a non-nav command. Prepare to execute it.
|
||||
g.command_index.set_and_save(non_nav_command_index);
|
||||
next_nonnav_command = temp;
|
||||
non_nav_command_ID = next_nonnav_command.id;
|
||||
gcs_send_text_fmt(PSTR("Non-Nav command ID updated to #%i"),non_nav_command_ID);
|
||||
gcs_send_text_fmt(PSTR("Non-Nav command ID updated to #%i"),non_nav_command_ID);
|
||||
|
||||
if (g.log_bitmask & MASK_LOG_CMD) {
|
||||
Log_Write_Cmd(g.command_index, &next_nonnav_command);
|
||||
}
|
||||
|
@ -143,7 +143,7 @@ enum gcs_severity {
|
||||
#define LOG_STARTUP_MSG 0x0A
|
||||
#define TYPE_AIRSTART_MSG 0x00
|
||||
#define TYPE_GROUNDSTART_MSG 0x01
|
||||
#define MAX_NUM_LOGS 50
|
||||
#define MAX_NUM_LOGS 100
|
||||
|
||||
#define MASK_LOG_ATTITUDE_FAST (1<<0)
|
||||
#define MASK_LOG_ATTITUDE_MED (1<<1)
|
||||
|
@ -183,7 +183,7 @@ static void update_crosstrack(void)
|
||||
|
||||
static void reset_crosstrack()
|
||||
{
|
||||
crosstrack_bearing = get_bearing(¤t_loc, &next_WP); // Used for track following
|
||||
crosstrack_bearing = get_bearing(&prev_WP, &next_WP); // Used for track following
|
||||
}
|
||||
|
||||
static long get_distance(struct Location *loc1, struct Location *loc2)
|
||||
|
@ -210,10 +210,7 @@ static void init_ardupilot()
|
||||
#endif // CLI_ENABLED
|
||||
|
||||
if(g.log_bitmask != 0){
|
||||
// TODO - Here we will check on the length of the last log
|
||||
// We don't want to create a bunch of little logs due to powering on and off
|
||||
byte last_log_num = get_num_logs();
|
||||
start_new_log(last_log_num);
|
||||
start_new_log();
|
||||
}
|
||||
|
||||
// read in the flight switches
|
||||
|
@ -2,6 +2,7 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Management;
|
||||
|
||||
namespace ArdupilotMega
|
||||
{
|
||||
@ -54,6 +55,26 @@ namespace ArdupilotMega
|
||||
|
||||
System.Threading.Thread.Sleep(500);
|
||||
|
||||
//HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USB\VID_2341&PID_0010\640333439373519060F0\Device Parameters
|
||||
if (!MainV2.MAC)
|
||||
{
|
||||
ObjectQuery query = new ObjectQuery("SELECT * FROM Win32_USBControllerDevice");
|
||||
ManagementObjectSearcher searcher = new ManagementObjectSearcher(query);
|
||||
foreach (ManagementObject obj2 in searcher.Get())
|
||||
{
|
||||
Console.WriteLine("Dependant : " + obj2["Dependent"]);
|
||||
|
||||
if (obj2["Dependent"].ToString().Contains(@"USB\\VID_2341&PID_0010"))
|
||||
{
|
||||
return "2560-2";
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
int fixme;
|
||||
}
|
||||
|
||||
serialPort.DtrEnable = true;
|
||||
serialPort.BaudRate = 115200;
|
||||
serialPort.Open();
|
||||
@ -92,7 +113,7 @@ namespace ArdupilotMega
|
||||
port = new ArduinoSTK();
|
||||
port.BaudRate = 57600;
|
||||
}
|
||||
else if (version == "2560")
|
||||
else if (version == "2560" || version == "2560-2")
|
||||
{
|
||||
port = new ArduinoSTKv2();
|
||||
port.BaudRate = 115200;
|
||||
|
@ -166,6 +166,7 @@
|
||||
<HintPath>..\..\..\..\..\Desktop\DIYDrones\myquad\greatmaps_e1bb830a18a3\Demo.WindowsForms\bin\Debug\x86\System.Data.SQLite.DLL</HintPath>
|
||||
</Reference>
|
||||
<Reference Include="System.Drawing" />
|
||||
<Reference Include="System.Management" />
|
||||
<Reference Include="System.Speech">
|
||||
<Private>True</Private>
|
||||
</Reference>
|
||||
@ -539,6 +540,9 @@
|
||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||
<SubType>Designer</SubType>
|
||||
</Content>
|
||||
<Content Include="mavcmd.xml">
|
||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||
</Content>
|
||||
<Content Include="Resources\MAVCmd.zh-Hans.txt" />
|
||||
<Content Include="Resources\MAVParam.zh-Hans.txt" />
|
||||
<None Include="Resources\MAVCmd.txt">
|
||||
|
@ -32,11 +32,14 @@ namespace ArdupilotMega
|
||||
public struct Locationwp
|
||||
{
|
||||
public byte id; // command id
|
||||
public byte options; ///< options bitmask (1<<0 = relative altitude)
|
||||
public byte p1; // param 1
|
||||
public int lat; // Lattitude * 10**7
|
||||
public int lng; // Longitude * 10**7
|
||||
public int alt; // Altitude in centimeters (meters * 100)
|
||||
public byte options;
|
||||
public float p1; // param 1
|
||||
public float p2; // param 2
|
||||
public float p3; // param 3
|
||||
public float p4; // param 4
|
||||
public float lat; // Lattitude * 10**7
|
||||
public float lng; // Longitude * 10**7
|
||||
public float alt; // Altitude in centimeters (meters * 100)
|
||||
};
|
||||
|
||||
|
||||
@ -796,6 +799,7 @@ System.ComponentModel.Description("Text under Bar")]
|
||||
base.OnPaint(e);
|
||||
drawlbl(e.Graphics);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public class HorizontalProgressBar : ProgressBar
|
||||
|
@ -211,7 +211,6 @@ namespace ArdupilotMega
|
||||
dowindcalc();
|
||||
}
|
||||
|
||||
// Console.WriteLine("Updating CurrentState " + DateTime.Now.Millisecond);
|
||||
if (mavinterface.packets[MAVLink.MAVLINK_MSG_ID_STATUSTEXT] != null) // status text
|
||||
{
|
||||
|
||||
|
@ -3,11 +3,13 @@
|
||||
In file included from /root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:32:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
autogenerated:63: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
autogenerated:64: warning: 'void recalc_climb_rate()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void print_climb_debug_info()' declared 'static' but never defined
|
||||
autogenerated:126: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:2057: warning: 'void gcs_send_text(gcs_severity, const char*)' defined but not used
|
||||
autogenerated:87: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/commands.pde:128: warning: 'void increment_cmd_index()' defined but not used
|
||||
autogenerated:144: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:270: warning: 'command_index' defined but not used
|
||||
%% libraries/APM_BMP085/APM_BMP085.o
|
||||
%% libraries/APM_BMP085/APM_BMP085_hil.o
|
||||
%% libraries/APM_RC/APM_RC.o
|
||||
%% libraries/AP_ADC/AP_ADC_ADS7844.o
|
||||
%% libraries/AP_ADC/AP_ADC.o
|
||||
@ -35,11 +37,17 @@ autogenerated:126: warning: 'void low_battery_event()' declared 'static' but nev
|
||||
%% libraries/AP_GPS/AP_GPS_UBLOX.o
|
||||
%% libraries/AP_GPS/GPS.o
|
||||
%% libraries/AP_IMU/AP_IMU_Oilpan.o
|
||||
%% libraries/AP_Mount/AP_Mount.o
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::control_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:182: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::status_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:226: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_MaxsonarXL.o
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_SharpGP2Y.o
|
||||
%% libraries/AP_RangeFinder/RangeFinder.o
|
||||
%% libraries/AP_Relay/AP_Relay.o
|
||||
%% libraries/DataFlash/DataFlash.o
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:35:
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:36:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
%% libraries/FastSerial/BetterStream.o
|
||||
@ -48,6 +56,7 @@ In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp
|
||||
%% libraries/GCS_MAVLink/GCS_MAVLink.o
|
||||
%% libraries/ModeFilter/ModeFilter.o
|
||||
%% libraries/PID/PID.o
|
||||
%% libraries/RC_Channel/RC_Channel_aux.o
|
||||
%% libraries/RC_Channel/RC_Channel.o
|
||||
%% libraries/memcheck/memcheck.o
|
||||
%% libraries/FastSerial/ftoa_engine.o
|
||||
|
@ -3,20 +3,21 @@
|
||||
00000001 b home_is_set
|
||||
00000001 b ch3_failsafe
|
||||
00000001 b land_complete
|
||||
00000001 b command_may_ID
|
||||
00000001 b command_must_ID
|
||||
00000001 b mavlink_active
|
||||
00000001 b nav_command_ID
|
||||
00000001 b failsafeCounter
|
||||
00000001 b counter_one_herz
|
||||
00000001 b in_mavlink_delay
|
||||
00000001 b slow_loopCounter
|
||||
00000001 d takeoff_complete
|
||||
00000001 b command_may_index
|
||||
00000001 b command_must_index
|
||||
00000001 b nav_command_index
|
||||
00000001 b delta_ms_fast_loop
|
||||
00000001 d ground_start_count
|
||||
00000001 b medium_loopCounter
|
||||
00000001 b non_nav_command_ID
|
||||
00000001 b rc_override_active
|
||||
00000001 b delta_ms_medium_loop
|
||||
00000001 b non_nav_command_index
|
||||
00000001 b superslow_loopCounter
|
||||
00000001 b event_id
|
||||
00000001 b GPS_light
|
||||
@ -25,12 +26,10 @@
|
||||
00000001 D control_mode
|
||||
00000001 B hindex
|
||||
00000001 B inverted_flight
|
||||
00000001 B mavdelay
|
||||
00000001 B n
|
||||
00000001 B oldSwitchPosition
|
||||
00000001 B relay
|
||||
00000002 T ReadSCP1000()
|
||||
00000002 T mavlink_acknowledge(mavlink_channel_t, unsigned char, unsigned char, unsigned char)
|
||||
00000002 b climb_rate
|
||||
00000002 b loiter_sum
|
||||
00000002 b event_delay
|
||||
00000002 b event_value
|
||||
@ -50,7 +49,6 @@
|
||||
00000002 b event_undo_value
|
||||
00000002 b ground_start_avg
|
||||
00000002 b airspeed_pressure
|
||||
00000002 b adc
|
||||
00000002 r comma
|
||||
00000002 b g_gps
|
||||
00000002 b pmTest1
|
||||
@ -60,7 +58,6 @@
|
||||
00000002 d ch2_temp
|
||||
00000002 b failsafe
|
||||
00000002 b sonar_alt
|
||||
00000002 T GCS_MAVLINK::acknowledge(unsigned char, unsigned char, unsigned char)
|
||||
00000002 r print_divider()::__c
|
||||
00000002 d throttle_slew_limit()::last
|
||||
00000002 r test_gps(unsigned char, Menu::arg const*)::__c
|
||||
@ -72,6 +69,7 @@
|
||||
00000003 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
00000003 r print_log_menu()::__c
|
||||
00000003 r report_compass()::__c
|
||||
00000003 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 b event_timer
|
||||
00000004 d hold_course
|
||||
00000004 b loiter_time
|
||||
@ -82,6 +80,7 @@
|
||||
00000004 b airspeed_raw
|
||||
00000004 b current_amps
|
||||
00000004 b energy_error
|
||||
00000004 b airspeed_fbwB
|
||||
00000004 b bearing_error
|
||||
00000004 b current_total
|
||||
00000004 b nav_loopTimer
|
||||
@ -123,8 +122,6 @@
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 b mavlink_delay(unsigned long)::last_1hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_3hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_10hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_50hz
|
||||
00000004 r print_enabled(bool)::__c
|
||||
00000004 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
@ -214,14 +211,14 @@
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
0000000a r __menu_name__main_menu
|
||||
00000009 V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a r init_home()::__c
|
||||
0000000a r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000a r verify_nav_wp()::__c
|
||||
0000000a r report_compass()::__c
|
||||
0000000a r report_throttle()::__c
|
||||
0000000a r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
@ -232,31 +229,30 @@
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a T setup
|
||||
0000000b r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r report_gains()::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r control_failsafe(unsigned int)::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000c t process_logs(unsigned char, Menu::arg const*)
|
||||
0000000c T GCS_MAVLINK::send_text(unsigned char, char const*)
|
||||
0000000c T GCS_MAVLINK::send_text(gcs_severity, char const*)
|
||||
0000000c V vtable for IMU
|
||||
0000000c r setup_show(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r report_xtrack()::__c
|
||||
0000000c r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r control_failsafe(unsigned int)::__c
|
||||
0000000c r test_mode(unsigned char, Menu::arg const*)::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000d r init_home()::__c
|
||||
0000000d r verify_RTL()::__c
|
||||
0000000d r demo_servos(unsigned char)::__c
|
||||
@ -267,6 +263,9 @@
|
||||
0000000d r print_log_menu()::__c
|
||||
0000000d r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000d r Log_Read_Startup()::__c
|
||||
0000000d r control_failsafe(unsigned int)::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
@ -287,6 +286,7 @@
|
||||
0000000d B sonar_mode_filter
|
||||
0000000e t global destructors keyed to Serial
|
||||
0000000e t global constructors keyed to Serial
|
||||
0000000e t send_statustext(mavlink_channel_t)
|
||||
0000000e V vtable for AP_Float16
|
||||
0000000e V vtable for AP_VarA<float, (unsigned char)6>
|
||||
0000000e V vtable for AP_VarS<Matrix3<float> >
|
||||
@ -296,10 +296,10 @@
|
||||
0000000e V vtable for AP_VarT<int>
|
||||
0000000e V vtable for AP_VarT<long>
|
||||
0000000e r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r process_may()::__c
|
||||
0000000e r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_gains()::__c
|
||||
0000000e r print_log_menu()::__c
|
||||
0000000e r control_failsafe(unsigned int)::__c
|
||||
0000000e r setup_batt_monitor(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_batt_monitor()::__c
|
||||
0000000e r report_flight_modes()::__c
|
||||
@ -325,23 +325,25 @@
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000f b current_loc
|
||||
0000000f b next_command
|
||||
0000000f b next_nav_command
|
||||
0000000f b next_nonnav_command
|
||||
0000000f b home
|
||||
0000000f b next_WP
|
||||
0000000f b prev_WP
|
||||
0000000f b guided_WP
|
||||
0000000f r report_gains()::__c
|
||||
0000000f r print_log_menu()::__c
|
||||
0000000f r failsafe_short_on_event()::__c
|
||||
0000000f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V AP_IMU_Oilpan::AP_IMU_Oilpan(AP_ADC*, unsigned int)::__c
|
||||
00000010 b rc_override
|
||||
00000010 r planner_menu_commands
|
||||
00000010 T GCS_MAVLINK::send_message(ap_message)
|
||||
00000010 W AP_VarT<float>::cast_to_float() const
|
||||
00000010 W AP_VarT<long>::cast_to_float() const
|
||||
00000010 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
@ -349,17 +351,18 @@
|
||||
00000010 r Log_Read_Startup()::__c
|
||||
00000010 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000010 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000010 t mavlink_get_channel_status
|
||||
00000011 r __menu_name__main_menu
|
||||
00000011 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r set_next_WP(Location*)::__c
|
||||
00000011 r zero_eeprom()::__c
|
||||
00000011 r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r startup_ground()::__c
|
||||
00000011 r Log_Read_Attitude()::__c
|
||||
00000011 r load_next_command_from_EEPROM()::__c
|
||||
00000011 r process_next_command()::__c
|
||||
00000011 r failsafe_short_on_event()::__c
|
||||
00000012 B Serial
|
||||
00000012 B Serial1
|
||||
00000012 B Serial3
|
||||
00000012 t gcs_update()
|
||||
00000012 W AP_Float16::~AP_Float16()
|
||||
00000012 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
00000012 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
@ -372,6 +375,7 @@
|
||||
00000012 r print_done()::__c
|
||||
00000012 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000012 r init_barometer()::__c
|
||||
00000012 r handle_no_commands()::__c
|
||||
00000012 r startup_IMU_ground()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
@ -391,11 +395,11 @@
|
||||
00000014 W AP_VarT<signed char>::unserialize(void*, unsigned int)
|
||||
00000014 W AP_VarT<signed char>::cast_to_float() const
|
||||
00000014 W AP_VarT<int>::cast_to_float() const
|
||||
00000014 r set_guided_WP()::__c
|
||||
00000014 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000014 r test_imu(unsigned char, Menu::arg const*)::__c
|
||||
00000015 r map_baudrate(signed char, unsigned long)::__c
|
||||
00000015 r report_gains()::__c
|
||||
00000015 r verify_nav_wp()::__c
|
||||
00000015 r init_ardupilot()::__c
|
||||
00000015 r print_hit_enter()::__c
|
||||
00000015 r test_gyro(unsigned char, Menu::arg const*)::__c
|
||||
@ -403,21 +407,22 @@
|
||||
00000016 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r report_batt_monitor()::__c
|
||||
00000016 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r GCS_MAVLINK::update()::__c
|
||||
00000016 B sonar
|
||||
00000017 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000018 W AP_VarT<int>::serialize(void*, unsigned int) const
|
||||
00000018 b mavlink_get_channel_status::m_mavlink_status
|
||||
00000018 r process_must()::__c
|
||||
00000018 r report_compass()::__c
|
||||
00000018 r Log_Read_Startup()::__c
|
||||
00000019 r report_batt_monitor()::__c
|
||||
00000019 r failsafe_long_on_event()::__c
|
||||
00000019 r GCS_MAVLINK::update()::__c
|
||||
0000001a r reset_control_switch()::__c
|
||||
00000019 r handle_process_nav_cmd()::__c
|
||||
00000019 r handle_process_do_command()::__c
|
||||
00000019 r handle_process_condition_command()::__c
|
||||
00000019 r do_jump()::__c
|
||||
0000001a r failsafe_short_on_event()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r Log_Read(int, int)::__c
|
||||
0000001b r failsafe_short_off_event()::__c
|
||||
0000001c W AP_VarA<float, (unsigned char)6>::unserialize(void*, unsigned int)
|
||||
@ -434,12 +439,12 @@
|
||||
0000001d r startup_ground()::__c
|
||||
0000001d r report_batt_monitor()::__c
|
||||
0000001e r flight_mode_strings
|
||||
0000001e t failsafe_short_off_event()
|
||||
0000001e r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
0000001e r startup_ground()::__c
|
||||
0000001f r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
0000001f r init_ardupilot()::__c
|
||||
0000001f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
00000020 t gcs_send_message(ap_message)
|
||||
00000020 r test_current(unsigned char, Menu::arg const*)::__c
|
||||
00000020 r report_xtrack()::__c
|
||||
00000020 r init_barometer()::__c
|
||||
@ -447,7 +452,10 @@
|
||||
00000020 t byte_swap_4
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r verify_loiter_time()::__c
|
||||
00000021 r process_next_command()::__c
|
||||
00000022 t print_blanks(int)
|
||||
00000022 t failsafe_short_off_event()
|
||||
00000022 t reset_I()
|
||||
00000022 W AP_Float16::~AP_Float16()
|
||||
00000022 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
@ -459,23 +467,22 @@
|
||||
00000022 W AP_VarT<long>::~AP_VarT()
|
||||
00000022 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000022 r report_compass()::__c
|
||||
00000022 r increment_WP_index()::__c
|
||||
00000022 r verify_loiter_time()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000023 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000023 r print_gyro_offsets()::__c
|
||||
00000023 r verify_loiter_turns()::__c
|
||||
00000023 r navigate()::__c
|
||||
00000024 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000024 r print_accel_offsets()::__c
|
||||
00000024 r verify_loiter_turns()::__c
|
||||
00000026 t print_done()
|
||||
00000026 b mavlink_queue
|
||||
00000026 t print_hit_enter()
|
||||
00000026 r init_ardupilot()::__c
|
||||
00000026 r print_PID(PID*)::__c
|
||||
00000027 r change_command(unsigned char)::__c
|
||||
00000027 r init_ardupilot()::__c
|
||||
00000027 r test_xbee(unsigned char, Menu::arg const*)::__c
|
||||
00000028 t main_menu_help(unsigned char, Menu::arg const*)
|
||||
00000028 t increment_WP_index()
|
||||
00000028 t help_log(unsigned char, Menu::arg const*)
|
||||
00000028 W AP_VarT<float>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<long>::unserialize(void*, unsigned int)
|
||||
@ -485,71 +492,75 @@
|
||||
0000002a t setup_declination(unsigned char, Menu::arg const*)
|
||||
0000002a r init_ardupilot()::__c
|
||||
0000002a r startup_ground()::__c
|
||||
0000002b r verify_must()::__c
|
||||
0000002a r verify_nav_command()::__c
|
||||
0000002a t _mav_put_int8_t_array
|
||||
0000002b r test_battery(unsigned char, Menu::arg const*)::__c
|
||||
0000002b r change_command(unsigned char)::__c
|
||||
0000002c t freeRAM()
|
||||
0000002d r startup_IMU_ground()::__c
|
||||
0000002e t reset_control_switch()
|
||||
0000002e t send_rate(unsigned int, unsigned int)
|
||||
0000002e t gcs_send_text_P(gcs_severity, prog_char_t const*)
|
||||
0000002e t gcs_data_stream_send(unsigned int, unsigned int)
|
||||
0000002e W AP_Var_group::AP_Var_group(unsigned int, prog_char_t const*, unsigned char)
|
||||
0000002e r verify_nav_wp()::__c
|
||||
00000030 t setup_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t planner_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t send_heartbeat(mavlink_channel_t)
|
||||
00000030 t test_mode(unsigned char, Menu::arg const*)
|
||||
00000030 r verify_may()::__c
|
||||
00000030 r print_log_menu()::__c
|
||||
00000031 r start_new_log(unsigned char)::__c
|
||||
00000032 T GCS_MAVLINK::init(FastSerial*)
|
||||
00000032 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000033 b pending_status
|
||||
00000034 W AP_Float16::serialize(void*, unsigned int) const
|
||||
00000034 r test_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000034 t _mav_put_int8_t_array
|
||||
00000034 t mavlink_msg_statustext_send
|
||||
00000035 r test_radio_pwm(unsigned char, Menu::arg const*)::__c
|
||||
00000035 r Log_Read_Nav_Tuning()::__c
|
||||
00000035 r verify_condition_command()::__c
|
||||
00000036 t report_radio()
|
||||
00000036 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000037 r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
00000038 t send_current_waypoint(mavlink_channel_t)
|
||||
00000038 b barometer
|
||||
00000038 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000038 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r planner_mode(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r init_ardupilot()::__c
|
||||
0000003a t report_imu()
|
||||
0000003a t verify_loiter_turns()
|
||||
0000003a W PID::~PID()
|
||||
0000003c t verify_RTL()
|
||||
0000003c t Log_Write_Mode(unsigned char)
|
||||
0000003c t verify_loiter_turns()
|
||||
0000003c W RC_Channel::~RC_Channel()
|
||||
0000003c r test_wp_print(Location*, unsigned char)::__c
|
||||
0000003c r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000003d B g_gps_driver
|
||||
0000003e t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(unsigned char, prog_char_t const*)
|
||||
0000003e T GCS_MAVLINK::send_text(gcs_severity, prog_char_t const*)
|
||||
0000003e W AP_VarT<signed char>::AP_VarT(signed char, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000040 b adc
|
||||
00000040 W AP_Float16::unserialize(void*, unsigned int)
|
||||
00000040 t byte_swap_8
|
||||
00000040 t crc_accumulate
|
||||
00000040 B history
|
||||
00000043 r Log_Read_GPS()::__c
|
||||
00000044 W AP_VarT<int>::AP_VarT(int, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000044 r report_throttle()::__c
|
||||
00000045 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000046 W RC_Channel::~RC_Channel()
|
||||
00000048 t failsafe_long_on_event()
|
||||
0000004a t send_meminfo(mavlink_channel_t)
|
||||
0000004a W AP_VarT<int>::AP_VarT(AP_Var_group*, unsigned int, int, prog_char_t const*, unsigned char)
|
||||
0000004b r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
0000004c t setup_erase(unsigned char, Menu::arg const*)
|
||||
0000004c t Log_Read_Mode()
|
||||
0000004c B imu
|
||||
0000004e T mavlink_send_text(mavlink_channel_t, unsigned char, char const*)
|
||||
0000004e t setup_batt_monitor(unsigned char, Menu::arg const*)
|
||||
00000050 b mavlink_queue
|
||||
00000050 r log_menu_commands
|
||||
00000050 r main_menu_commands
|
||||
00000050 t failsafe_long_on_event()
|
||||
00000050 T GCS_MAVLINK::_find_parameter(unsigned int)
|
||||
00000050 B imu
|
||||
00000054 t print_divider()
|
||||
00000054 t print_enabled(bool)
|
||||
00000054 t report_flight_modes()
|
||||
00000055 r setup_flightmodes(unsigned char, Menu::arg const*)::__c
|
||||
00000056 t change_command(unsigned char)
|
||||
00000056 T GCS_MAVLINK::queued_waypoint_send()
|
||||
00000058 t radio_input_switch()
|
||||
0000005a t update_GPS_light()
|
||||
0000005a W AP_VarT<float>::AP_VarT(float, unsigned int, prog_char_t const*, unsigned char)
|
||||
@ -557,143 +568,158 @@
|
||||
0000005c t readSwitch()
|
||||
0000005c t get_num_logs()
|
||||
0000005e T GCS_MAVLINK::_count_parameters()
|
||||
00000060 b barometer
|
||||
00000060 W AP_Float16::AP_Float16(AP_Var_group*, unsigned int, float, prog_char_t const*, unsigned char)
|
||||
00000060 t _mavlink_send_uart
|
||||
00000062 t print_switch(unsigned char, unsigned char)
|
||||
00000064 t Log_Write_Attitude(int, int, unsigned int)
|
||||
00000064 t mavlink_msg_param_value_send(mavlink_channel_t, char const*, float, unsigned char, unsigned int, unsigned int)
|
||||
00000064 t test_xbee(unsigned char, Menu::arg const*)
|
||||
00000064 t mavlink_msg_param_value_send
|
||||
00000064 W RC_Channel_aux::~RC_Channel_aux()
|
||||
00000068 t zero_eeprom()
|
||||
00000068 t find_last_log_page(int)
|
||||
0000006a T mavlink_send_text(mavlink_channel_t, gcs_severity, char const*)
|
||||
0000006a t demo_servos(unsigned char)
|
||||
0000006a t startup_IMU_ground()
|
||||
0000006a W GCS_MAVLINK::~GCS_MAVLINK()
|
||||
0000006c t setup_show(unsigned char, Menu::arg const*)
|
||||
0000006c t demo_servos(unsigned char)
|
||||
0000006e t setup_factory(unsigned char, Menu::arg const*)
|
||||
00000070 r init_ardupilot()::__c
|
||||
00000074 t verify_loiter_time()
|
||||
00000076 t startup_IMU_ground()
|
||||
00000072 t verify_loiter_time()
|
||||
00000078 t gcs_send_text_fmt(prog_char_t const*, ...)
|
||||
00000078 t read_control_switch()
|
||||
0000007c t failsafe_short_on_event()
|
||||
0000007c t send_gps_status(mavlink_channel_t)
|
||||
0000007c t do_RTL()
|
||||
0000007e t test_rawgps(unsigned char, Menu::arg const*)
|
||||
00000080 r setup_menu_commands
|
||||
00000080 T __vector_25
|
||||
00000080 T __vector_36
|
||||
00000080 T __vector_54
|
||||
00000084 t change_command(unsigned char)
|
||||
00000086 t Log_Read_Attitude()
|
||||
00000088 t Log_Read_Raw()
|
||||
0000008a t Log_Write_Cmd(unsigned char, Location*)
|
||||
0000008c t print_gyro_offsets()
|
||||
0000008c t print_accel_offsets()
|
||||
0000008c r main_menu_help(unsigned char, Menu::arg const*)::__c
|
||||
00000090 t do_RTL()
|
||||
0000008e t handle_no_commands()
|
||||
0000008e t failsafe_short_on_event()
|
||||
00000092 T GCS_MAVLINK::queued_param_send()
|
||||
00000096 t map_baudrate(signed char, unsigned long)
|
||||
00000096 t test_wp_print(Location*, unsigned char)
|
||||
0000009c t update_servo_switches()
|
||||
0000009c t print_PID(PID*)
|
||||
0000009d B gcs
|
||||
0000009d B hil
|
||||
0000009c B gcs0
|
||||
0000009c B gcs3
|
||||
000000a0 t report_xtrack()
|
||||
000000a2 t verify_nav_wp()
|
||||
000000a4 t Log_Read_Cmd()
|
||||
000000a4 T __vector_26
|
||||
000000a4 T __vector_37
|
||||
000000a4 T __vector_55
|
||||
000000a6 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000ac t Log_Read_Performance()
|
||||
000000b0 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b2 t Log_Read_Startup()
|
||||
000000b4 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b4 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000b6 t get_log_boundaries(unsigned char, int&, int&)
|
||||
000000b7 b compass
|
||||
000000bc t Log_Read_Control_Tuning()
|
||||
000000be t update_events()
|
||||
000000c0 t report_throttle()
|
||||
000000c0 t calc_bearing_error()
|
||||
000000c4 t update_events()
|
||||
000000c4 t load_next_command_from_EEPROM()
|
||||
000000c6 t test_eedump(unsigned char, Menu::arg const*)
|
||||
000000c6 t zero_airspeed()
|
||||
000000c6 t startup_ground()
|
||||
000000c7 B dcm
|
||||
000000ca t send_radio_out(mavlink_channel_t)
|
||||
000000ca t test_modeswitch(unsigned char, Menu::arg const*)
|
||||
000000ca t control_failsafe(unsigned int)
|
||||
000000ce t zero_airspeed()
|
||||
000000ce t send_radio_in(mavlink_channel_t)
|
||||
000000ce W PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)
|
||||
000000ce r setup_mode(unsigned char, Menu::arg const*)::__c
|
||||
000000ce r help_log(unsigned char, Menu::arg const*)::__c
|
||||
000000d0 t get_bearing(Location*, Location*)
|
||||
000000da t verify_nav_wp()
|
||||
000000e0 b mavlink_parse_char::m_mavlink_message
|
||||
000000d4 t trim_radio()
|
||||
000000e4 t test_radio_pwm(unsigned char, Menu::arg const*)
|
||||
000000e7 r init_ardupilot()::__c
|
||||
000000ec t dump_log(unsigned char, Menu::arg const*)
|
||||
000000f0 t throttle_slew_limit()
|
||||
000000f2 t test_adc(unsigned char, Menu::arg const*)
|
||||
000000f4 t _mav_finalize_message_chan_send
|
||||
000000fa t Log_Read_Current()
|
||||
00000100 t trim_radio()
|
||||
00000102 t setup_compass(unsigned char, Menu::arg const*)
|
||||
00000106 t test_current(unsigned char, Menu::arg const*)
|
||||
00000106 t calc_nav_pitch()
|
||||
00000106 t get_wp_with_index(int)
|
||||
00000108 t test_battery(unsigned char, Menu::arg const*)
|
||||
0000010c W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000010a t mavlink_delay(unsigned long)
|
||||
0000010a t send_raw_imu2(mavlink_channel_t)
|
||||
00000110 t test_radio(unsigned char, Menu::arg const*)
|
||||
00000110 t get_cmd_with_index(int)
|
||||
00000112 t get_distance(Location*, Location*)
|
||||
00000112 t startup_ground()
|
||||
00000112 t send_servo_out(mavlink_channel_t)
|
||||
00000112 t report_batt_monitor()
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000114 t read_barometer()
|
||||
00000116 t erase_logs(unsigned char, Menu::arg const*)
|
||||
00000118 t test_gps(unsigned char, Menu::arg const*)
|
||||
00000118 T GCS_MAVLINK::_queued_send()
|
||||
00000120 t test_pressure(unsigned char, Menu::arg const*)
|
||||
00000130 t test_dipswitches(unsigned char, Menu::arg const*)
|
||||
00000130 t set_wp_with_index(Location, int)
|
||||
00000130 t setup_flightmodes(unsigned char, Menu::arg const*)
|
||||
00000130 t set_cmd_with_index(Location, int)
|
||||
00000130 r test_menu_commands
|
||||
00000134 T GCS_MAVLINK::send_message(unsigned char, unsigned long)
|
||||
0000013e t process_may()
|
||||
00000136 W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000013e t calc_nav_roll()
|
||||
0000013e t handle_process_condition_command()
|
||||
00000146 t select_logs(unsigned char, Menu::arg const*)
|
||||
0000014e t verify_may()
|
||||
0000014e T GCS_MAVLINK::update()
|
||||
00000146 t send_vfr_hud(mavlink_channel_t)
|
||||
00000152 t report_gains()
|
||||
00000152 t verify_condition_command()
|
||||
0000015a t test_airspeed(unsigned char, Menu::arg const*)
|
||||
0000015e t set_guided_WP()
|
||||
0000015e t handle_process_nav_cmd()
|
||||
0000015e t test_gyro(unsigned char, Menu::arg const*)
|
||||
0000016a t process_must()
|
||||
0000016a t set_guided_WP()
|
||||
00000172 t navigate()
|
||||
0000016c t navigate()
|
||||
0000016e t send_attitude(mavlink_channel_t)
|
||||
00000174 t report_compass()
|
||||
00000174 t mavlink_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
0000017c t send_location(mavlink_channel_t)
|
||||
0000017e t Log_Read_Nav_Tuning()
|
||||
000001a2 t test_imu(unsigned char, Menu::arg const*)
|
||||
000001ae T init_home()
|
||||
00000180 t send_extended_status1(mavlink_channel_t, unsigned int)
|
||||
0000018c T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000192 T init_home()
|
||||
00000192 t test_imu(unsigned char, Menu::arg const*)
|
||||
0000019c t do_jump()
|
||||
000001ae t start_new_log(unsigned char)
|
||||
000001b2 t update_crosstrack()
|
||||
000001b2 t set_mode(unsigned char)
|
||||
000001bc t set_next_WP(Location*)
|
||||
000001bc t send_nav_controller_output(mavlink_channel_t)
|
||||
000001be t Log_Read_GPS()
|
||||
000001c8 t read_airspeed()
|
||||
000001ca t mavlink_delay(unsigned long)
|
||||
000001ca t start_new_log(unsigned char)
|
||||
000001ea T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
000001ec t init_barometer()
|
||||
000001c0 t read_airspeed()
|
||||
000001d2 t mavlink_try_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
000001d2 T GCS_MAVLINK::update()
|
||||
000001da W RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)
|
||||
000001ea t init_barometer()
|
||||
00000202 t test_failsafe(unsigned char, Menu::arg const*)
|
||||
00000206 t set_next_WP(Location*)
|
||||
00000208 t calc_throttle()
|
||||
00000226 t Log_Read(int, int)
|
||||
00000216 t Log_Read(int, int)
|
||||
0000021a t send_raw_imu1(mavlink_channel_t)
|
||||
0000022a t send_gps_raw(mavlink_channel_t)
|
||||
0000022c t process_next_command()
|
||||
0000022c t test_wp(unsigned char, Menu::arg const*)
|
||||
0000022c t set_mode(unsigned char)
|
||||
00000232 t verify_must()
|
||||
00000230 t verify_nav_command()
|
||||
0000023e t print_radio_values()
|
||||
0000024c t update_loiter()
|
||||
0000025c t setup_radio(unsigned char, Menu::arg const*)
|
||||
00000268 t send_raw_imu3(mavlink_channel_t)
|
||||
000002d4 t handle_process_do_command()
|
||||
000002e4 t read_radio()
|
||||
0000031e t read_battery()
|
||||
0000032e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000031e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000033a W Parameters::~Parameters()
|
||||
00000404 t process_next_command()
|
||||
0000041c t set_servos()
|
||||
000003e6 t read_battery()
|
||||
0000044c t print_log_menu()
|
||||
000004b2 t mavlink_parse_char
|
||||
000004de t set_servos()
|
||||
0000059c t __static_initialization_and_destruction_0(int, int)
|
||||
000006da t init_ardupilot()
|
||||
00000831 b g
|
||||
0000090a W Parameters::Parameters()
|
||||
0000156a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
000018ea t mavlink_try_send_message(mavlink_channel_t, unsigned char, unsigned int)
|
||||
00001ae8 T loop
|
||||
0000064a t init_ardupilot()
|
||||
00000920 W Parameters::Parameters()
|
||||
0000092b b g
|
||||
0000149a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001cbe T loop
|
||||
|
@ -3,11 +3,13 @@
|
||||
In file included from /root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:32:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
autogenerated:63: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
autogenerated:64: warning: 'void recalc_climb_rate()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void print_climb_debug_info()' declared 'static' but never defined
|
||||
autogenerated:126: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:2057: warning: 'void gcs_send_text(gcs_severity, const char*)' defined but not used
|
||||
autogenerated:87: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/commands.pde:128: warning: 'void increment_cmd_index()' defined but not used
|
||||
autogenerated:144: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:270: warning: 'command_index' defined but not used
|
||||
%% libraries/APM_BMP085/APM_BMP085.o
|
||||
%% libraries/APM_BMP085/APM_BMP085_hil.o
|
||||
%% libraries/APM_RC/APM_RC.o
|
||||
%% libraries/AP_ADC/AP_ADC_ADS7844.o
|
||||
%% libraries/AP_ADC/AP_ADC.o
|
||||
@ -35,11 +37,17 @@ autogenerated:126: warning: 'void low_battery_event()' declared 'static' but nev
|
||||
%% libraries/AP_GPS/AP_GPS_UBLOX.o
|
||||
%% libraries/AP_GPS/GPS.o
|
||||
%% libraries/AP_IMU/AP_IMU_Oilpan.o
|
||||
%% libraries/AP_Mount/AP_Mount.o
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::control_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:182: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::status_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:226: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_MaxsonarXL.o
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_SharpGP2Y.o
|
||||
%% libraries/AP_RangeFinder/RangeFinder.o
|
||||
%% libraries/AP_Relay/AP_Relay.o
|
||||
%% libraries/DataFlash/DataFlash.o
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:35:
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:36:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
%% libraries/FastSerial/BetterStream.o
|
||||
@ -48,6 +56,7 @@ In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp
|
||||
%% libraries/GCS_MAVLink/GCS_MAVLink.o
|
||||
%% libraries/ModeFilter/ModeFilter.o
|
||||
%% libraries/PID/PID.o
|
||||
%% libraries/RC_Channel/RC_Channel_aux.o
|
||||
%% libraries/RC_Channel/RC_Channel.o
|
||||
%% libraries/memcheck/memcheck.o
|
||||
%% libraries/FastSerial/ftoa_engine.o
|
||||
|
@ -3,20 +3,21 @@
|
||||
00000001 b home_is_set
|
||||
00000001 b ch3_failsafe
|
||||
00000001 b land_complete
|
||||
00000001 b command_may_ID
|
||||
00000001 b command_must_ID
|
||||
00000001 b mavlink_active
|
||||
00000001 b nav_command_ID
|
||||
00000001 b failsafeCounter
|
||||
00000001 b counter_one_herz
|
||||
00000001 b in_mavlink_delay
|
||||
00000001 b slow_loopCounter
|
||||
00000001 d takeoff_complete
|
||||
00000001 b command_may_index
|
||||
00000001 b command_must_index
|
||||
00000001 b nav_command_index
|
||||
00000001 b delta_ms_fast_loop
|
||||
00000001 d ground_start_count
|
||||
00000001 b medium_loopCounter
|
||||
00000001 b non_nav_command_ID
|
||||
00000001 b rc_override_active
|
||||
00000001 b delta_ms_medium_loop
|
||||
00000001 b non_nav_command_index
|
||||
00000001 b superslow_loopCounter
|
||||
00000001 b event_id
|
||||
00000001 b GPS_light
|
||||
@ -25,12 +26,10 @@
|
||||
00000001 D control_mode
|
||||
00000001 B hindex
|
||||
00000001 B inverted_flight
|
||||
00000001 B mavdelay
|
||||
00000001 B n
|
||||
00000001 B oldSwitchPosition
|
||||
00000001 B relay
|
||||
00000002 T ReadSCP1000()
|
||||
00000002 T mavlink_acknowledge(mavlink_channel_t, unsigned char, unsigned char, unsigned char)
|
||||
00000002 b climb_rate
|
||||
00000002 b loiter_sum
|
||||
00000002 b event_delay
|
||||
00000002 b event_value
|
||||
@ -50,7 +49,6 @@
|
||||
00000002 b event_undo_value
|
||||
00000002 b ground_start_avg
|
||||
00000002 b airspeed_pressure
|
||||
00000002 b adc
|
||||
00000002 r comma
|
||||
00000002 b g_gps
|
||||
00000002 b pmTest1
|
||||
@ -60,7 +58,6 @@
|
||||
00000002 d ch2_temp
|
||||
00000002 b failsafe
|
||||
00000002 b sonar_alt
|
||||
00000002 T GCS_MAVLINK::acknowledge(unsigned char, unsigned char, unsigned char)
|
||||
00000002 r print_divider()::__c
|
||||
00000002 d throttle_slew_limit()::last
|
||||
00000002 r test_gps(unsigned char, Menu::arg const*)::__c
|
||||
@ -72,6 +69,7 @@
|
||||
00000003 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
00000003 r print_log_menu()::__c
|
||||
00000003 r report_compass()::__c
|
||||
00000003 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 b event_timer
|
||||
00000004 d hold_course
|
||||
00000004 b loiter_time
|
||||
@ -82,6 +80,7 @@
|
||||
00000004 b airspeed_raw
|
||||
00000004 b current_amps
|
||||
00000004 b energy_error
|
||||
00000004 b airspeed_fbwB
|
||||
00000004 b bearing_error
|
||||
00000004 b current_total
|
||||
00000004 b nav_loopTimer
|
||||
@ -123,8 +122,6 @@
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 b mavlink_delay(unsigned long)::last_1hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_3hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_10hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_50hz
|
||||
00000004 r print_enabled(bool)::__c
|
||||
00000004 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
@ -214,14 +211,14 @@
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
0000000a r __menu_name__main_menu
|
||||
00000009 V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a r init_home()::__c
|
||||
0000000a r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000a r verify_nav_wp()::__c
|
||||
0000000a r report_compass()::__c
|
||||
0000000a r report_throttle()::__c
|
||||
0000000a r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
@ -232,31 +229,30 @@
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a T setup
|
||||
0000000b r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r report_gains()::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r control_failsafe(unsigned int)::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000c t process_logs(unsigned char, Menu::arg const*)
|
||||
0000000c T GCS_MAVLINK::send_text(unsigned char, char const*)
|
||||
0000000c T GCS_MAVLINK::send_text(gcs_severity, char const*)
|
||||
0000000c V vtable for IMU
|
||||
0000000c r setup_show(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r report_xtrack()::__c
|
||||
0000000c r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r control_failsafe(unsigned int)::__c
|
||||
0000000c r test_mode(unsigned char, Menu::arg const*)::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000d r init_home()::__c
|
||||
0000000d r verify_RTL()::__c
|
||||
0000000d r demo_servos(unsigned char)::__c
|
||||
@ -267,6 +263,9 @@
|
||||
0000000d r print_log_menu()::__c
|
||||
0000000d r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000d r Log_Read_Startup()::__c
|
||||
0000000d r control_failsafe(unsigned int)::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
@ -287,6 +286,7 @@
|
||||
0000000d B sonar_mode_filter
|
||||
0000000e t global destructors keyed to Serial
|
||||
0000000e t global constructors keyed to Serial
|
||||
0000000e t send_statustext(mavlink_channel_t)
|
||||
0000000e V vtable for AP_Float16
|
||||
0000000e V vtable for AP_VarA<float, (unsigned char)6>
|
||||
0000000e V vtable for AP_VarS<Matrix3<float> >
|
||||
@ -296,10 +296,10 @@
|
||||
0000000e V vtable for AP_VarT<int>
|
||||
0000000e V vtable for AP_VarT<long>
|
||||
0000000e r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r process_may()::__c
|
||||
0000000e r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_gains()::__c
|
||||
0000000e r print_log_menu()::__c
|
||||
0000000e r control_failsafe(unsigned int)::__c
|
||||
0000000e r setup_batt_monitor(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_batt_monitor()::__c
|
||||
0000000e r report_flight_modes()::__c
|
||||
@ -325,23 +325,25 @@
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000f b current_loc
|
||||
0000000f b next_command
|
||||
0000000f b next_nav_command
|
||||
0000000f b next_nonnav_command
|
||||
0000000f b home
|
||||
0000000f b next_WP
|
||||
0000000f b prev_WP
|
||||
0000000f b guided_WP
|
||||
0000000f r report_gains()::__c
|
||||
0000000f r print_log_menu()::__c
|
||||
0000000f r failsafe_short_on_event()::__c
|
||||
0000000f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V AP_IMU_Oilpan::AP_IMU_Oilpan(AP_ADC*, unsigned int)::__c
|
||||
00000010 b rc_override
|
||||
00000010 r planner_menu_commands
|
||||
00000010 T GCS_MAVLINK::send_message(ap_message)
|
||||
00000010 W AP_VarT<float>::cast_to_float() const
|
||||
00000010 W AP_VarT<long>::cast_to_float() const
|
||||
00000010 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
@ -349,17 +351,18 @@
|
||||
00000010 r Log_Read_Startup()::__c
|
||||
00000010 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000010 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000010 t mavlink_get_channel_status
|
||||
00000011 r __menu_name__main_menu
|
||||
00000011 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r set_next_WP(Location*)::__c
|
||||
00000011 r zero_eeprom()::__c
|
||||
00000011 r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r startup_ground()::__c
|
||||
00000011 r Log_Read_Attitude()::__c
|
||||
00000011 r load_next_command_from_EEPROM()::__c
|
||||
00000011 r process_next_command()::__c
|
||||
00000011 r failsafe_short_on_event()::__c
|
||||
00000012 B Serial
|
||||
00000012 B Serial1
|
||||
00000012 B Serial3
|
||||
00000012 t gcs_update()
|
||||
00000012 W AP_Float16::~AP_Float16()
|
||||
00000012 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
00000012 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
@ -372,6 +375,7 @@
|
||||
00000012 r print_done()::__c
|
||||
00000012 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000012 r init_barometer()::__c
|
||||
00000012 r handle_no_commands()::__c
|
||||
00000012 r startup_IMU_ground()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
@ -391,11 +395,11 @@
|
||||
00000014 W AP_VarT<signed char>::unserialize(void*, unsigned int)
|
||||
00000014 W AP_VarT<signed char>::cast_to_float() const
|
||||
00000014 W AP_VarT<int>::cast_to_float() const
|
||||
00000014 r set_guided_WP()::__c
|
||||
00000014 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000014 r test_imu(unsigned char, Menu::arg const*)::__c
|
||||
00000015 r map_baudrate(signed char, unsigned long)::__c
|
||||
00000015 r report_gains()::__c
|
||||
00000015 r verify_nav_wp()::__c
|
||||
00000015 r init_ardupilot()::__c
|
||||
00000015 r print_hit_enter()::__c
|
||||
00000015 r test_gyro(unsigned char, Menu::arg const*)::__c
|
||||
@ -403,21 +407,22 @@
|
||||
00000016 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r report_batt_monitor()::__c
|
||||
00000016 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r GCS_MAVLINK::update()::__c
|
||||
00000016 B sonar
|
||||
00000017 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000018 W AP_VarT<int>::serialize(void*, unsigned int) const
|
||||
00000018 b mavlink_get_channel_status::m_mavlink_status
|
||||
00000018 r process_must()::__c
|
||||
00000018 r report_compass()::__c
|
||||
00000018 r Log_Read_Startup()::__c
|
||||
00000019 r report_batt_monitor()::__c
|
||||
00000019 r failsafe_long_on_event()::__c
|
||||
00000019 r GCS_MAVLINK::update()::__c
|
||||
0000001a r reset_control_switch()::__c
|
||||
00000019 r handle_process_nav_cmd()::__c
|
||||
00000019 r handle_process_do_command()::__c
|
||||
00000019 r handle_process_condition_command()::__c
|
||||
00000019 r do_jump()::__c
|
||||
0000001a r failsafe_short_on_event()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r Log_Read(int, int)::__c
|
||||
0000001b r failsafe_short_off_event()::__c
|
||||
0000001c W AP_VarA<float, (unsigned char)6>::unserialize(void*, unsigned int)
|
||||
@ -434,12 +439,12 @@
|
||||
0000001d r startup_ground()::__c
|
||||
0000001d r report_batt_monitor()::__c
|
||||
0000001e r flight_mode_strings
|
||||
0000001e t failsafe_short_off_event()
|
||||
0000001e r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
0000001e r startup_ground()::__c
|
||||
0000001f r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
0000001f r init_ardupilot()::__c
|
||||
0000001f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
00000020 t gcs_send_message(ap_message)
|
||||
00000020 r test_current(unsigned char, Menu::arg const*)::__c
|
||||
00000020 r report_xtrack()::__c
|
||||
00000020 r init_barometer()::__c
|
||||
@ -447,7 +452,10 @@
|
||||
00000020 t byte_swap_4
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r verify_loiter_time()::__c
|
||||
00000021 r process_next_command()::__c
|
||||
00000022 t print_blanks(int)
|
||||
00000022 t failsafe_short_off_event()
|
||||
00000022 t reset_I()
|
||||
00000022 W AP_Float16::~AP_Float16()
|
||||
00000022 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
@ -459,23 +467,22 @@
|
||||
00000022 W AP_VarT<long>::~AP_VarT()
|
||||
00000022 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000022 r report_compass()::__c
|
||||
00000022 r increment_WP_index()::__c
|
||||
00000022 r verify_loiter_time()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000023 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000023 r print_gyro_offsets()::__c
|
||||
00000023 r verify_loiter_turns()::__c
|
||||
00000023 r navigate()::__c
|
||||
00000024 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000024 r print_accel_offsets()::__c
|
||||
00000024 r verify_loiter_turns()::__c
|
||||
00000026 t print_done()
|
||||
00000026 b mavlink_queue
|
||||
00000026 t print_hit_enter()
|
||||
00000026 r init_ardupilot()::__c
|
||||
00000026 r print_PID(PID*)::__c
|
||||
00000027 r change_command(unsigned char)::__c
|
||||
00000027 r init_ardupilot()::__c
|
||||
00000027 r test_xbee(unsigned char, Menu::arg const*)::__c
|
||||
00000028 t main_menu_help(unsigned char, Menu::arg const*)
|
||||
00000028 t increment_WP_index()
|
||||
00000028 t help_log(unsigned char, Menu::arg const*)
|
||||
00000028 W AP_VarT<float>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<long>::unserialize(void*, unsigned int)
|
||||
@ -485,71 +492,75 @@
|
||||
0000002a t setup_declination(unsigned char, Menu::arg const*)
|
||||
0000002a r init_ardupilot()::__c
|
||||
0000002a r startup_ground()::__c
|
||||
0000002b r verify_must()::__c
|
||||
0000002a r verify_nav_command()::__c
|
||||
0000002a t _mav_put_int8_t_array
|
||||
0000002b r test_battery(unsigned char, Menu::arg const*)::__c
|
||||
0000002b r change_command(unsigned char)::__c
|
||||
0000002c t freeRAM()
|
||||
0000002d r startup_IMU_ground()::__c
|
||||
0000002e t reset_control_switch()
|
||||
0000002e t send_rate(unsigned int, unsigned int)
|
||||
0000002e t gcs_send_text_P(gcs_severity, prog_char_t const*)
|
||||
0000002e t gcs_data_stream_send(unsigned int, unsigned int)
|
||||
0000002e W AP_Var_group::AP_Var_group(unsigned int, prog_char_t const*, unsigned char)
|
||||
0000002e r verify_nav_wp()::__c
|
||||
00000030 t setup_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t planner_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t send_heartbeat(mavlink_channel_t)
|
||||
00000030 t test_mode(unsigned char, Menu::arg const*)
|
||||
00000030 r verify_may()::__c
|
||||
00000030 r print_log_menu()::__c
|
||||
00000031 r start_new_log(unsigned char)::__c
|
||||
00000032 T GCS_MAVLINK::init(FastSerial*)
|
||||
00000032 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000033 b pending_status
|
||||
00000034 W AP_Float16::serialize(void*, unsigned int) const
|
||||
00000034 r test_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000034 t _mav_put_int8_t_array
|
||||
00000034 t mavlink_msg_statustext_send
|
||||
00000035 r test_radio_pwm(unsigned char, Menu::arg const*)::__c
|
||||
00000035 r Log_Read_Nav_Tuning()::__c
|
||||
00000035 r verify_condition_command()::__c
|
||||
00000036 t report_radio()
|
||||
00000036 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000037 r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
00000038 t send_current_waypoint(mavlink_channel_t)
|
||||
00000038 b barometer
|
||||
00000038 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000038 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r planner_mode(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r init_ardupilot()::__c
|
||||
0000003a t report_imu()
|
||||
0000003a t verify_loiter_turns()
|
||||
0000003a W PID::~PID()
|
||||
0000003c t verify_RTL()
|
||||
0000003c t Log_Write_Mode(unsigned char)
|
||||
0000003c t verify_loiter_turns()
|
||||
0000003c W RC_Channel::~RC_Channel()
|
||||
0000003c r test_wp_print(Location*, unsigned char)::__c
|
||||
0000003c r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000003d B g_gps_driver
|
||||
0000003e t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(unsigned char, prog_char_t const*)
|
||||
0000003e T GCS_MAVLINK::send_text(gcs_severity, prog_char_t const*)
|
||||
0000003e W AP_VarT<signed char>::AP_VarT(signed char, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000040 b adc
|
||||
00000040 W AP_Float16::unserialize(void*, unsigned int)
|
||||
00000040 t byte_swap_8
|
||||
00000040 t crc_accumulate
|
||||
00000040 B history
|
||||
00000043 r Log_Read_GPS()::__c
|
||||
00000044 W AP_VarT<int>::AP_VarT(int, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000044 r report_throttle()::__c
|
||||
00000045 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000046 W RC_Channel::~RC_Channel()
|
||||
00000048 t failsafe_long_on_event()
|
||||
0000004a t send_meminfo(mavlink_channel_t)
|
||||
0000004a W AP_VarT<int>::AP_VarT(AP_Var_group*, unsigned int, int, prog_char_t const*, unsigned char)
|
||||
0000004b r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
0000004c t setup_erase(unsigned char, Menu::arg const*)
|
||||
0000004c t Log_Read_Mode()
|
||||
0000004c B imu
|
||||
0000004e T mavlink_send_text(mavlink_channel_t, unsigned char, char const*)
|
||||
0000004e t setup_batt_monitor(unsigned char, Menu::arg const*)
|
||||
00000050 b mavlink_queue
|
||||
00000050 r log_menu_commands
|
||||
00000050 r main_menu_commands
|
||||
00000050 t failsafe_long_on_event()
|
||||
00000050 T GCS_MAVLINK::_find_parameter(unsigned int)
|
||||
00000050 B imu
|
||||
00000054 t print_divider()
|
||||
00000054 t print_enabled(bool)
|
||||
00000054 t report_flight_modes()
|
||||
00000055 r setup_flightmodes(unsigned char, Menu::arg const*)::__c
|
||||
00000056 t change_command(unsigned char)
|
||||
00000056 T GCS_MAVLINK::queued_waypoint_send()
|
||||
00000058 t radio_input_switch()
|
||||
0000005a t update_GPS_light()
|
||||
0000005a W AP_VarT<float>::AP_VarT(float, unsigned int, prog_char_t const*, unsigned char)
|
||||
@ -558,142 +569,157 @@
|
||||
0000005c t get_num_logs()
|
||||
0000005e T GCS_MAVLINK::_count_parameters()
|
||||
00000060 t print_switch(unsigned char, unsigned char)
|
||||
00000060 b barometer
|
||||
00000060 W AP_Float16::AP_Float16(AP_Var_group*, unsigned int, float, prog_char_t const*, unsigned char)
|
||||
00000060 t _mavlink_send_uart
|
||||
00000064 t Log_Write_Attitude(int, int, unsigned int)
|
||||
00000064 t mavlink_msg_param_value_send(mavlink_channel_t, char const*, float, unsigned char, unsigned int, unsigned int)
|
||||
00000064 t test_xbee(unsigned char, Menu::arg const*)
|
||||
00000064 t mavlink_msg_param_value_send
|
||||
00000064 W RC_Channel_aux::~RC_Channel_aux()
|
||||
00000068 t zero_eeprom()
|
||||
00000068 t find_last_log_page(int)
|
||||
0000006a T mavlink_send_text(mavlink_channel_t, gcs_severity, char const*)
|
||||
0000006a t demo_servos(unsigned char)
|
||||
0000006a t startup_IMU_ground()
|
||||
0000006a W GCS_MAVLINK::~GCS_MAVLINK()
|
||||
0000006c t setup_show(unsigned char, Menu::arg const*)
|
||||
0000006c t demo_servos(unsigned char)
|
||||
0000006e t setup_factory(unsigned char, Menu::arg const*)
|
||||
00000070 r init_ardupilot()::__c
|
||||
00000074 t verify_loiter_time()
|
||||
00000076 t startup_IMU_ground()
|
||||
00000072 t verify_loiter_time()
|
||||
00000078 t gcs_send_text_fmt(prog_char_t const*, ...)
|
||||
00000078 t read_control_switch()
|
||||
0000007c t failsafe_short_on_event()
|
||||
0000007c t send_gps_status(mavlink_channel_t)
|
||||
0000007c t do_RTL()
|
||||
0000007e t test_rawgps(unsigned char, Menu::arg const*)
|
||||
00000080 r setup_menu_commands
|
||||
00000080 T __vector_25
|
||||
00000080 T __vector_36
|
||||
00000080 T __vector_54
|
||||
00000084 t change_command(unsigned char)
|
||||
00000086 t Log_Read_Attitude()
|
||||
00000088 t Log_Read_Raw()
|
||||
0000008a t Log_Write_Cmd(unsigned char, Location*)
|
||||
0000008c t print_gyro_offsets()
|
||||
0000008c t print_accel_offsets()
|
||||
0000008c r main_menu_help(unsigned char, Menu::arg const*)::__c
|
||||
00000090 t do_RTL()
|
||||
0000008e t failsafe_short_on_event()
|
||||
00000090 t handle_no_commands()
|
||||
00000092 T GCS_MAVLINK::queued_param_send()
|
||||
00000096 t map_baudrate(signed char, unsigned long)
|
||||
00000096 t test_wp_print(Location*, unsigned char)
|
||||
0000009c t update_servo_switches()
|
||||
0000009c t print_PID(PID*)
|
||||
0000009d B gcs
|
||||
0000009d B hil
|
||||
0000009c B gcs0
|
||||
0000009c B gcs3
|
||||
000000a0 t report_xtrack()
|
||||
000000a2 t verify_nav_wp()
|
||||
000000a4 t Log_Read_Cmd()
|
||||
000000a4 T __vector_26
|
||||
000000a4 T __vector_37
|
||||
000000a4 T __vector_55
|
||||
000000a6 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000ac t Log_Read_Performance()
|
||||
000000b0 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b0 t Log_Read_Startup()
|
||||
000000b4 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b4 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000b6 t get_log_boundaries(unsigned char, int&, int&)
|
||||
000000b7 b compass
|
||||
000000bc t Log_Read_Control_Tuning()
|
||||
000000be t update_events()
|
||||
000000c0 t report_throttle()
|
||||
000000c0 t calc_bearing_error()
|
||||
000000c2 t test_eedump(unsigned char, Menu::arg const*)
|
||||
000000c4 t update_events()
|
||||
000000c4 t load_next_command_from_EEPROM()
|
||||
000000c6 t zero_airspeed()
|
||||
000000c6 t startup_ground()
|
||||
000000c7 B dcm
|
||||
000000c8 t test_modeswitch(unsigned char, Menu::arg const*)
|
||||
000000ca t send_radio_out(mavlink_channel_t)
|
||||
000000ca t control_failsafe(unsigned int)
|
||||
000000ce t zero_airspeed()
|
||||
000000ce t send_radio_in(mavlink_channel_t)
|
||||
000000ce W PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)
|
||||
000000ce r setup_mode(unsigned char, Menu::arg const*)::__c
|
||||
000000ce r help_log(unsigned char, Menu::arg const*)::__c
|
||||
000000d0 t get_bearing(Location*, Location*)
|
||||
000000d8 t verify_nav_wp()
|
||||
000000e0 b mavlink_parse_char::m_mavlink_message
|
||||
000000d4 t trim_radio()
|
||||
000000e4 t test_radio_pwm(unsigned char, Menu::arg const*)
|
||||
000000e7 r init_ardupilot()::__c
|
||||
000000ec t dump_log(unsigned char, Menu::arg const*)
|
||||
000000f0 t throttle_slew_limit()
|
||||
000000f0 t test_adc(unsigned char, Menu::arg const*)
|
||||
000000f4 t _mav_finalize_message_chan_send
|
||||
000000fa t Log_Read_Current()
|
||||
00000100 t trim_radio()
|
||||
00000102 t setup_compass(unsigned char, Menu::arg const*)
|
||||
00000106 t test_current(unsigned char, Menu::arg const*)
|
||||
00000106 t calc_nav_pitch()
|
||||
00000106 t get_wp_with_index(int)
|
||||
00000108 t test_battery(unsigned char, Menu::arg const*)
|
||||
0000010c W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000010a t mavlink_delay(unsigned long)
|
||||
0000010a t send_raw_imu2(mavlink_channel_t)
|
||||
00000110 t test_radio(unsigned char, Menu::arg const*)
|
||||
00000110 t get_cmd_with_index(int)
|
||||
00000112 t get_distance(Location*, Location*)
|
||||
00000112 t startup_ground()
|
||||
00000112 t send_servo_out(mavlink_channel_t)
|
||||
00000112 t report_batt_monitor()
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000114 t erase_logs(unsigned char, Menu::arg const*)
|
||||
00000114 t read_barometer()
|
||||
00000118 t test_gps(unsigned char, Menu::arg const*)
|
||||
00000118 T GCS_MAVLINK::_queued_send()
|
||||
00000120 t test_pressure(unsigned char, Menu::arg const*)
|
||||
00000130 t test_dipswitches(unsigned char, Menu::arg const*)
|
||||
00000130 t set_wp_with_index(Location, int)
|
||||
00000130 t setup_flightmodes(unsigned char, Menu::arg const*)
|
||||
00000130 t set_cmd_with_index(Location, int)
|
||||
00000130 r test_menu_commands
|
||||
00000134 T GCS_MAVLINK::send_message(unsigned char, unsigned long)
|
||||
0000013e t process_may()
|
||||
00000136 W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000013e t calc_nav_roll()
|
||||
0000013e t handle_process_condition_command()
|
||||
00000146 t select_logs(unsigned char, Menu::arg const*)
|
||||
0000014e t verify_may()
|
||||
0000014e T GCS_MAVLINK::update()
|
||||
00000146 t send_vfr_hud(mavlink_channel_t)
|
||||
00000152 t report_gains()
|
||||
00000152 t verify_condition_command()
|
||||
00000158 t test_airspeed(unsigned char, Menu::arg const*)
|
||||
0000015e t set_guided_WP()
|
||||
0000015e t handle_process_nav_cmd()
|
||||
0000015e t test_gyro(unsigned char, Menu::arg const*)
|
||||
0000016a t process_must()
|
||||
0000016a t set_guided_WP()
|
||||
00000172 t navigate()
|
||||
0000016c t navigate()
|
||||
0000016e t send_attitude(mavlink_channel_t)
|
||||
00000174 t report_compass()
|
||||
00000174 t mavlink_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
0000017c t send_location(mavlink_channel_t)
|
||||
0000017e t Log_Read_Nav_Tuning()
|
||||
000001a2 t test_imu(unsigned char, Menu::arg const*)
|
||||
000001ae T init_home()
|
||||
00000180 t send_extended_status1(mavlink_channel_t, unsigned int)
|
||||
0000018c T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000190 T init_home()
|
||||
00000192 t test_imu(unsigned char, Menu::arg const*)
|
||||
0000019a t do_jump()
|
||||
000001ae t start_new_log(unsigned char)
|
||||
000001b2 t update_crosstrack()
|
||||
000001b2 t set_mode(unsigned char)
|
||||
000001bc t set_next_WP(Location*)
|
||||
000001bc t send_nav_controller_output(mavlink_channel_t)
|
||||
000001be t Log_Read_GPS()
|
||||
000001c8 t read_airspeed()
|
||||
000001ca t mavlink_delay(unsigned long)
|
||||
000001ca t start_new_log(unsigned char)
|
||||
000001ea T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
000001ec t init_barometer()
|
||||
000001c0 t read_airspeed()
|
||||
000001d2 t mavlink_try_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
000001d2 T GCS_MAVLINK::update()
|
||||
000001da W RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)
|
||||
000001ea t init_barometer()
|
||||
000001fe t test_failsafe(unsigned char, Menu::arg const*)
|
||||
00000206 t set_next_WP(Location*)
|
||||
00000208 t calc_throttle()
|
||||
00000222 t Log_Read(int, int)
|
||||
00000210 t Log_Read(int, int)
|
||||
0000021a t send_raw_imu1(mavlink_channel_t)
|
||||
00000228 t test_wp(unsigned char, Menu::arg const*)
|
||||
0000022c t set_mode(unsigned char)
|
||||
00000232 t verify_must()
|
||||
0000022a t send_gps_raw(mavlink_channel_t)
|
||||
0000022c t process_next_command()
|
||||
00000230 t verify_nav_command()
|
||||
0000023e t print_radio_values()
|
||||
0000024c t update_loiter()
|
||||
0000025c t setup_radio(unsigned char, Menu::arg const*)
|
||||
00000268 t send_raw_imu3(mavlink_channel_t)
|
||||
000002d4 t handle_process_do_command()
|
||||
000002e4 t read_radio()
|
||||
0000031e t read_battery()
|
||||
0000032e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000031e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000033a W Parameters::~Parameters()
|
||||
00000404 t process_next_command()
|
||||
0000041c t set_servos()
|
||||
000003e6 t read_battery()
|
||||
00000436 t print_log_menu()
|
||||
000004b2 t mavlink_parse_char
|
||||
000004de t set_servos()
|
||||
0000059c t __static_initialization_and_destruction_0(int, int)
|
||||
000006da t init_ardupilot()
|
||||
00000831 b g
|
||||
0000090a W Parameters::Parameters()
|
||||
0000156a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
000018ea t mavlink_try_send_message(mavlink_channel_t, unsigned char, unsigned int)
|
||||
00001ae8 T loop
|
||||
00000648 t init_ardupilot()
|
||||
00000920 W Parameters::Parameters()
|
||||
0000092b b g
|
||||
0000149a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001cbe T loop
|
||||
|
@ -3,11 +3,13 @@
|
||||
In file included from /root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:32:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
autogenerated:63: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
autogenerated:64: warning: 'void recalc_climb_rate()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void print_climb_debug_info()' declared 'static' but never defined
|
||||
autogenerated:126: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:2057: warning: 'void gcs_send_text(gcs_severity, const char*)' defined but not used
|
||||
autogenerated:87: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/commands.pde:128: warning: 'void increment_cmd_index()' defined but not used
|
||||
autogenerated:144: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:270: warning: 'command_index' defined but not used
|
||||
%% libraries/APM_BMP085/APM_BMP085.o
|
||||
%% libraries/APM_BMP085/APM_BMP085_hil.o
|
||||
%% libraries/APM_RC/APM_RC.o
|
||||
%% libraries/AP_ADC/AP_ADC_ADS7844.o
|
||||
%% libraries/AP_ADC/AP_ADC.o
|
||||
@ -35,11 +37,17 @@ autogenerated:126: warning: 'void low_battery_event()' declared 'static' but nev
|
||||
%% libraries/AP_GPS/AP_GPS_UBLOX.o
|
||||
%% libraries/AP_GPS/GPS.o
|
||||
%% libraries/AP_IMU/AP_IMU_Oilpan.o
|
||||
%% libraries/AP_Mount/AP_Mount.o
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::control_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:182: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::status_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:226: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_MaxsonarXL.o
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_SharpGP2Y.o
|
||||
%% libraries/AP_RangeFinder/RangeFinder.o
|
||||
%% libraries/AP_Relay/AP_Relay.o
|
||||
%% libraries/DataFlash/DataFlash.o
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:35:
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:36:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
%% libraries/FastSerial/BetterStream.o
|
||||
@ -48,6 +56,7 @@ In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp
|
||||
%% libraries/GCS_MAVLink/GCS_MAVLink.o
|
||||
%% libraries/ModeFilter/ModeFilter.o
|
||||
%% libraries/PID/PID.o
|
||||
%% libraries/RC_Channel/RC_Channel_aux.o
|
||||
%% libraries/RC_Channel/RC_Channel.o
|
||||
%% libraries/memcheck/memcheck.o
|
||||
%% libraries/FastSerial/ftoa_engine.o
|
||||
|
@ -3,20 +3,21 @@
|
||||
00000001 b home_is_set
|
||||
00000001 b ch3_failsafe
|
||||
00000001 b land_complete
|
||||
00000001 b command_may_ID
|
||||
00000001 b command_must_ID
|
||||
00000001 b mavlink_active
|
||||
00000001 b nav_command_ID
|
||||
00000001 b failsafeCounter
|
||||
00000001 b counter_one_herz
|
||||
00000001 b in_mavlink_delay
|
||||
00000001 b slow_loopCounter
|
||||
00000001 d takeoff_complete
|
||||
00000001 b command_may_index
|
||||
00000001 b command_must_index
|
||||
00000001 b nav_command_index
|
||||
00000001 b delta_ms_fast_loop
|
||||
00000001 d ground_start_count
|
||||
00000001 b medium_loopCounter
|
||||
00000001 b non_nav_command_ID
|
||||
00000001 b rc_override_active
|
||||
00000001 b delta_ms_medium_loop
|
||||
00000001 b non_nav_command_index
|
||||
00000001 b superslow_loopCounter
|
||||
00000001 b event_id
|
||||
00000001 b GPS_light
|
||||
@ -25,12 +26,10 @@
|
||||
00000001 D control_mode
|
||||
00000001 B hindex
|
||||
00000001 B inverted_flight
|
||||
00000001 B mavdelay
|
||||
00000001 B n
|
||||
00000001 B oldSwitchPosition
|
||||
00000001 B relay
|
||||
00000002 T ReadSCP1000()
|
||||
00000002 T mavlink_acknowledge(mavlink_channel_t, unsigned char, unsigned char, unsigned char)
|
||||
00000002 b climb_rate
|
||||
00000002 b loiter_sum
|
||||
00000002 b event_delay
|
||||
00000002 b event_value
|
||||
@ -50,7 +49,6 @@
|
||||
00000002 b event_undo_value
|
||||
00000002 b ground_start_avg
|
||||
00000002 b airspeed_pressure
|
||||
00000002 b adc
|
||||
00000002 r comma
|
||||
00000002 b g_gps
|
||||
00000002 b pmTest1
|
||||
@ -60,7 +58,6 @@
|
||||
00000002 d ch2_temp
|
||||
00000002 b failsafe
|
||||
00000002 b sonar_alt
|
||||
00000002 T GCS_MAVLINK::acknowledge(unsigned char, unsigned char, unsigned char)
|
||||
00000002 r print_divider()::__c
|
||||
00000002 d throttle_slew_limit()::last
|
||||
00000002 r test_gps(unsigned char, Menu::arg const*)::__c
|
||||
@ -72,6 +69,7 @@
|
||||
00000003 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
00000003 r print_log_menu()::__c
|
||||
00000003 r report_compass()::__c
|
||||
00000003 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 b event_timer
|
||||
00000004 d hold_course
|
||||
00000004 b loiter_time
|
||||
@ -82,6 +80,7 @@
|
||||
00000004 b airspeed_raw
|
||||
00000004 b current_amps
|
||||
00000004 b energy_error
|
||||
00000004 b airspeed_fbwB
|
||||
00000004 b bearing_error
|
||||
00000004 b current_total
|
||||
00000004 b nav_loopTimer
|
||||
@ -123,8 +122,6 @@
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 b mavlink_delay(unsigned long)::last_1hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_3hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_10hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_50hz
|
||||
00000004 r print_enabled(bool)::__c
|
||||
00000004 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
@ -214,14 +211,14 @@
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
0000000a r __menu_name__main_menu
|
||||
00000009 V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a r init_home()::__c
|
||||
0000000a r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000a r verify_nav_wp()::__c
|
||||
0000000a r report_compass()::__c
|
||||
0000000a r report_throttle()::__c
|
||||
0000000a r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
@ -232,31 +229,30 @@
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a T setup
|
||||
0000000b r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r report_gains()::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r control_failsafe(unsigned int)::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000c t process_logs(unsigned char, Menu::arg const*)
|
||||
0000000c T GCS_MAVLINK::send_text(unsigned char, char const*)
|
||||
0000000c T GCS_MAVLINK::send_text(gcs_severity, char const*)
|
||||
0000000c V vtable for IMU
|
||||
0000000c r setup_show(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r report_xtrack()::__c
|
||||
0000000c r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r control_failsafe(unsigned int)::__c
|
||||
0000000c r test_mode(unsigned char, Menu::arg const*)::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000d r init_home()::__c
|
||||
0000000d r verify_RTL()::__c
|
||||
0000000d r demo_servos(unsigned char)::__c
|
||||
@ -267,6 +263,9 @@
|
||||
0000000d r print_log_menu()::__c
|
||||
0000000d r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000d r Log_Read_Startup()::__c
|
||||
0000000d r control_failsafe(unsigned int)::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
@ -287,6 +286,7 @@
|
||||
0000000d B sonar_mode_filter
|
||||
0000000e t global destructors keyed to Serial
|
||||
0000000e t global constructors keyed to Serial
|
||||
0000000e t send_statustext(mavlink_channel_t)
|
||||
0000000e V vtable for AP_Float16
|
||||
0000000e V vtable for AP_VarA<float, (unsigned char)6>
|
||||
0000000e V vtable for AP_VarS<Matrix3<float> >
|
||||
@ -296,10 +296,10 @@
|
||||
0000000e V vtable for AP_VarT<int>
|
||||
0000000e V vtable for AP_VarT<long>
|
||||
0000000e r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r process_may()::__c
|
||||
0000000e r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_gains()::__c
|
||||
0000000e r print_log_menu()::__c
|
||||
0000000e r control_failsafe(unsigned int)::__c
|
||||
0000000e r setup_batt_monitor(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_batt_monitor()::__c
|
||||
0000000e r report_flight_modes()::__c
|
||||
@ -325,23 +325,25 @@
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000f b current_loc
|
||||
0000000f b next_command
|
||||
0000000f b next_nav_command
|
||||
0000000f b next_nonnav_command
|
||||
0000000f b home
|
||||
0000000f b next_WP
|
||||
0000000f b prev_WP
|
||||
0000000f b guided_WP
|
||||
0000000f r report_gains()::__c
|
||||
0000000f r print_log_menu()::__c
|
||||
0000000f r failsafe_short_on_event()::__c
|
||||
0000000f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V AP_IMU_Oilpan::AP_IMU_Oilpan(AP_ADC*, unsigned int)::__c
|
||||
00000010 b rc_override
|
||||
00000010 r planner_menu_commands
|
||||
00000010 T GCS_MAVLINK::send_message(ap_message)
|
||||
00000010 W AP_VarT<float>::cast_to_float() const
|
||||
00000010 W AP_VarT<long>::cast_to_float() const
|
||||
00000010 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
@ -349,17 +351,18 @@
|
||||
00000010 r Log_Read_Startup()::__c
|
||||
00000010 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000010 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000010 t mavlink_get_channel_status
|
||||
00000011 r __menu_name__main_menu
|
||||
00000011 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r set_next_WP(Location*)::__c
|
||||
00000011 r zero_eeprom()::__c
|
||||
00000011 r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r startup_ground()::__c
|
||||
00000011 r Log_Read_Attitude()::__c
|
||||
00000011 r load_next_command_from_EEPROM()::__c
|
||||
00000011 r process_next_command()::__c
|
||||
00000011 r failsafe_short_on_event()::__c
|
||||
00000012 B Serial
|
||||
00000012 B Serial1
|
||||
00000012 B Serial3
|
||||
00000012 t gcs_update()
|
||||
00000012 W AP_Float16::~AP_Float16()
|
||||
00000012 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
00000012 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
@ -372,6 +375,7 @@
|
||||
00000012 r print_done()::__c
|
||||
00000012 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000012 r init_barometer()::__c
|
||||
00000012 r handle_no_commands()::__c
|
||||
00000012 r startup_IMU_ground()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
@ -391,11 +395,11 @@
|
||||
00000014 W AP_VarT<signed char>::unserialize(void*, unsigned int)
|
||||
00000014 W AP_VarT<signed char>::cast_to_float() const
|
||||
00000014 W AP_VarT<int>::cast_to_float() const
|
||||
00000014 r set_guided_WP()::__c
|
||||
00000014 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000014 r test_imu(unsigned char, Menu::arg const*)::__c
|
||||
00000015 r map_baudrate(signed char, unsigned long)::__c
|
||||
00000015 r report_gains()::__c
|
||||
00000015 r verify_nav_wp()::__c
|
||||
00000015 r init_ardupilot()::__c
|
||||
00000015 r print_hit_enter()::__c
|
||||
00000015 r test_gyro(unsigned char, Menu::arg const*)::__c
|
||||
@ -403,21 +407,22 @@
|
||||
00000016 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r report_batt_monitor()::__c
|
||||
00000016 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r GCS_MAVLINK::update()::__c
|
||||
00000016 B sonar
|
||||
00000017 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000018 W AP_VarT<int>::serialize(void*, unsigned int) const
|
||||
00000018 b mavlink_get_channel_status::m_mavlink_status
|
||||
00000018 r process_must()::__c
|
||||
00000018 r report_compass()::__c
|
||||
00000018 r Log_Read_Startup()::__c
|
||||
00000019 r report_batt_monitor()::__c
|
||||
00000019 r failsafe_long_on_event()::__c
|
||||
00000019 r GCS_MAVLINK::update()::__c
|
||||
0000001a r reset_control_switch()::__c
|
||||
00000019 r handle_process_nav_cmd()::__c
|
||||
00000019 r handle_process_do_command()::__c
|
||||
00000019 r handle_process_condition_command()::__c
|
||||
00000019 r do_jump()::__c
|
||||
0000001a r failsafe_short_on_event()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r Log_Read(int, int)::__c
|
||||
0000001b r failsafe_short_off_event()::__c
|
||||
0000001c W AP_VarA<float, (unsigned char)6>::unserialize(void*, unsigned int)
|
||||
@ -434,12 +439,12 @@
|
||||
0000001d r startup_ground()::__c
|
||||
0000001d r report_batt_monitor()::__c
|
||||
0000001e r flight_mode_strings
|
||||
0000001e t failsafe_short_off_event()
|
||||
0000001e r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
0000001e r startup_ground()::__c
|
||||
0000001f r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
0000001f r init_ardupilot()::__c
|
||||
0000001f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
00000020 t gcs_send_message(ap_message)
|
||||
00000020 r test_current(unsigned char, Menu::arg const*)::__c
|
||||
00000020 r report_xtrack()::__c
|
||||
00000020 r init_barometer()::__c
|
||||
@ -447,7 +452,10 @@
|
||||
00000020 t byte_swap_4
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r verify_loiter_time()::__c
|
||||
00000021 r process_next_command()::__c
|
||||
00000022 t print_blanks(int)
|
||||
00000022 t failsafe_short_off_event()
|
||||
00000022 t reset_I()
|
||||
00000022 W AP_Float16::~AP_Float16()
|
||||
00000022 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
@ -459,23 +467,22 @@
|
||||
00000022 W AP_VarT<long>::~AP_VarT()
|
||||
00000022 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000022 r report_compass()::__c
|
||||
00000022 r increment_WP_index()::__c
|
||||
00000022 r verify_loiter_time()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000023 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000023 r print_gyro_offsets()::__c
|
||||
00000023 r verify_loiter_turns()::__c
|
||||
00000023 r navigate()::__c
|
||||
00000024 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000024 r print_accel_offsets()::__c
|
||||
00000024 r verify_loiter_turns()::__c
|
||||
00000026 t print_done()
|
||||
00000026 b mavlink_queue
|
||||
00000026 t print_hit_enter()
|
||||
00000026 r init_ardupilot()::__c
|
||||
00000026 r print_PID(PID*)::__c
|
||||
00000027 r change_command(unsigned char)::__c
|
||||
00000027 r init_ardupilot()::__c
|
||||
00000027 r test_xbee(unsigned char, Menu::arg const*)::__c
|
||||
00000028 t main_menu_help(unsigned char, Menu::arg const*)
|
||||
00000028 t increment_WP_index()
|
||||
00000028 t help_log(unsigned char, Menu::arg const*)
|
||||
00000028 W AP_VarT<float>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<long>::unserialize(void*, unsigned int)
|
||||
@ -485,71 +492,75 @@
|
||||
0000002a t setup_declination(unsigned char, Menu::arg const*)
|
||||
0000002a r init_ardupilot()::__c
|
||||
0000002a r startup_ground()::__c
|
||||
0000002b r verify_must()::__c
|
||||
0000002a r verify_nav_command()::__c
|
||||
0000002a t _mav_put_int8_t_array
|
||||
0000002b r test_battery(unsigned char, Menu::arg const*)::__c
|
||||
0000002b r change_command(unsigned char)::__c
|
||||
0000002c t freeRAM()
|
||||
0000002d r startup_IMU_ground()::__c
|
||||
0000002e t reset_control_switch()
|
||||
0000002e t send_rate(unsigned int, unsigned int)
|
||||
0000002e t gcs_send_text_P(gcs_severity, prog_char_t const*)
|
||||
0000002e t gcs_data_stream_send(unsigned int, unsigned int)
|
||||
0000002e W AP_Var_group::AP_Var_group(unsigned int, prog_char_t const*, unsigned char)
|
||||
0000002e r verify_nav_wp()::__c
|
||||
00000030 t setup_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t planner_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t send_heartbeat(mavlink_channel_t)
|
||||
00000030 t test_mode(unsigned char, Menu::arg const*)
|
||||
00000030 r verify_may()::__c
|
||||
00000030 r print_log_menu()::__c
|
||||
00000031 r start_new_log(unsigned char)::__c
|
||||
00000032 T GCS_MAVLINK::init(FastSerial*)
|
||||
00000032 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000033 b pending_status
|
||||
00000034 W AP_Float16::serialize(void*, unsigned int) const
|
||||
00000034 r test_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000034 t _mav_put_int8_t_array
|
||||
00000034 t mavlink_msg_statustext_send
|
||||
00000035 r test_radio_pwm(unsigned char, Menu::arg const*)::__c
|
||||
00000035 r Log_Read_Nav_Tuning()::__c
|
||||
00000035 r verify_condition_command()::__c
|
||||
00000036 t report_radio()
|
||||
00000036 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000037 r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
00000038 t send_current_waypoint(mavlink_channel_t)
|
||||
00000038 b barometer
|
||||
00000038 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000038 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r planner_mode(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r init_ardupilot()::__c
|
||||
0000003a t report_imu()
|
||||
0000003a t verify_loiter_turns()
|
||||
0000003a W PID::~PID()
|
||||
0000003c t verify_RTL()
|
||||
0000003c t Log_Write_Mode(unsigned char)
|
||||
0000003c t verify_loiter_turns()
|
||||
0000003c W RC_Channel::~RC_Channel()
|
||||
0000003c r test_wp_print(Location*, unsigned char)::__c
|
||||
0000003c r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000003d B g_gps_driver
|
||||
0000003e t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(unsigned char, prog_char_t const*)
|
||||
0000003e T GCS_MAVLINK::send_text(gcs_severity, prog_char_t const*)
|
||||
0000003e W AP_VarT<signed char>::AP_VarT(signed char, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000040 b adc
|
||||
00000040 W AP_Float16::unserialize(void*, unsigned int)
|
||||
00000040 t byte_swap_8
|
||||
00000040 t crc_accumulate
|
||||
00000040 B history
|
||||
00000043 r Log_Read_GPS()::__c
|
||||
00000044 W AP_VarT<int>::AP_VarT(int, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000044 r report_throttle()::__c
|
||||
00000045 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000046 W RC_Channel::~RC_Channel()
|
||||
00000048 t failsafe_long_on_event()
|
||||
0000004a t send_meminfo(mavlink_channel_t)
|
||||
0000004a W AP_VarT<int>::AP_VarT(AP_Var_group*, unsigned int, int, prog_char_t const*, unsigned char)
|
||||
0000004b r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
0000004c t setup_erase(unsigned char, Menu::arg const*)
|
||||
0000004c t Log_Read_Mode()
|
||||
0000004c B imu
|
||||
0000004e T mavlink_send_text(mavlink_channel_t, unsigned char, char const*)
|
||||
0000004e t setup_batt_monitor(unsigned char, Menu::arg const*)
|
||||
00000050 b mavlink_queue
|
||||
00000050 r log_menu_commands
|
||||
00000050 r main_menu_commands
|
||||
00000050 t failsafe_long_on_event()
|
||||
00000050 T GCS_MAVLINK::_find_parameter(unsigned int)
|
||||
00000050 B imu
|
||||
00000054 t print_divider()
|
||||
00000054 t print_enabled(bool)
|
||||
00000054 t report_flight_modes()
|
||||
00000055 r setup_flightmodes(unsigned char, Menu::arg const*)::__c
|
||||
00000056 t change_command(unsigned char)
|
||||
00000056 T GCS_MAVLINK::queued_waypoint_send()
|
||||
00000058 t radio_input_switch()
|
||||
0000005a t update_GPS_light()
|
||||
0000005a W AP_VarT<float>::AP_VarT(float, unsigned int, prog_char_t const*, unsigned char)
|
||||
@ -557,143 +568,158 @@
|
||||
0000005c t readSwitch()
|
||||
0000005c t get_num_logs()
|
||||
0000005e T GCS_MAVLINK::_count_parameters()
|
||||
00000060 b barometer
|
||||
00000060 W AP_Float16::AP_Float16(AP_Var_group*, unsigned int, float, prog_char_t const*, unsigned char)
|
||||
00000060 t _mavlink_send_uart
|
||||
00000062 t print_switch(unsigned char, unsigned char)
|
||||
00000064 t Log_Write_Attitude(int, int, unsigned int)
|
||||
00000064 t mavlink_msg_param_value_send(mavlink_channel_t, char const*, float, unsigned char, unsigned int, unsigned int)
|
||||
00000064 t test_xbee(unsigned char, Menu::arg const*)
|
||||
00000064 t mavlink_msg_param_value_send
|
||||
00000064 W RC_Channel_aux::~RC_Channel_aux()
|
||||
00000068 t zero_eeprom()
|
||||
00000068 t find_last_log_page(int)
|
||||
0000006a T mavlink_send_text(mavlink_channel_t, gcs_severity, char const*)
|
||||
0000006a t demo_servos(unsigned char)
|
||||
0000006a t startup_IMU_ground()
|
||||
0000006a W GCS_MAVLINK::~GCS_MAVLINK()
|
||||
0000006c t setup_show(unsigned char, Menu::arg const*)
|
||||
0000006c t demo_servos(unsigned char)
|
||||
0000006e t setup_factory(unsigned char, Menu::arg const*)
|
||||
00000070 r init_ardupilot()::__c
|
||||
00000074 t verify_loiter_time()
|
||||
00000076 t startup_IMU_ground()
|
||||
00000072 t verify_loiter_time()
|
||||
00000078 t gcs_send_text_fmt(prog_char_t const*, ...)
|
||||
00000078 t read_control_switch()
|
||||
0000007c t failsafe_short_on_event()
|
||||
0000007c t send_gps_status(mavlink_channel_t)
|
||||
0000007c t do_RTL()
|
||||
0000007e t test_rawgps(unsigned char, Menu::arg const*)
|
||||
00000080 r setup_menu_commands
|
||||
00000080 T __vector_25
|
||||
00000080 T __vector_36
|
||||
00000080 T __vector_54
|
||||
00000084 t change_command(unsigned char)
|
||||
00000086 t Log_Read_Attitude()
|
||||
00000088 t Log_Read_Raw()
|
||||
0000008a t Log_Write_Cmd(unsigned char, Location*)
|
||||
0000008c t print_gyro_offsets()
|
||||
0000008c t print_accel_offsets()
|
||||
0000008c r main_menu_help(unsigned char, Menu::arg const*)::__c
|
||||
00000090 t do_RTL()
|
||||
0000008e t handle_no_commands()
|
||||
0000008e t failsafe_short_on_event()
|
||||
00000092 T GCS_MAVLINK::queued_param_send()
|
||||
00000096 t map_baudrate(signed char, unsigned long)
|
||||
00000096 t test_wp_print(Location*, unsigned char)
|
||||
0000009c t update_servo_switches()
|
||||
0000009c t print_PID(PID*)
|
||||
0000009d B gcs
|
||||
0000009d B hil
|
||||
0000009c B gcs0
|
||||
0000009c B gcs3
|
||||
000000a0 t report_xtrack()
|
||||
000000a2 t verify_nav_wp()
|
||||
000000a4 t Log_Read_Cmd()
|
||||
000000a4 T __vector_26
|
||||
000000a4 T __vector_37
|
||||
000000a4 T __vector_55
|
||||
000000a6 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000ac t Log_Read_Performance()
|
||||
000000b0 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b2 t Log_Read_Startup()
|
||||
000000b4 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b4 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000b6 t get_log_boundaries(unsigned char, int&, int&)
|
||||
000000b7 b compass
|
||||
000000bc t Log_Read_Control_Tuning()
|
||||
000000be t update_events()
|
||||
000000c0 t report_throttle()
|
||||
000000c0 t calc_bearing_error()
|
||||
000000c4 t update_events()
|
||||
000000c4 t load_next_command_from_EEPROM()
|
||||
000000c6 t test_eedump(unsigned char, Menu::arg const*)
|
||||
000000c6 t zero_airspeed()
|
||||
000000c6 t startup_ground()
|
||||
000000c7 B dcm
|
||||
000000ca t send_radio_out(mavlink_channel_t)
|
||||
000000ca t test_modeswitch(unsigned char, Menu::arg const*)
|
||||
000000ca t control_failsafe(unsigned int)
|
||||
000000ce t zero_airspeed()
|
||||
000000ce t send_radio_in(mavlink_channel_t)
|
||||
000000ce W PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)
|
||||
000000ce r setup_mode(unsigned char, Menu::arg const*)::__c
|
||||
000000ce r help_log(unsigned char, Menu::arg const*)::__c
|
||||
000000d0 t get_bearing(Location*, Location*)
|
||||
000000da t verify_nav_wp()
|
||||
000000e0 b mavlink_parse_char::m_mavlink_message
|
||||
000000d4 t trim_radio()
|
||||
000000e4 t test_radio_pwm(unsigned char, Menu::arg const*)
|
||||
000000e7 r init_ardupilot()::__c
|
||||
000000ec t dump_log(unsigned char, Menu::arg const*)
|
||||
000000f0 t throttle_slew_limit()
|
||||
000000f2 t test_adc(unsigned char, Menu::arg const*)
|
||||
000000f4 t _mav_finalize_message_chan_send
|
||||
000000fa t Log_Read_Current()
|
||||
00000100 t trim_radio()
|
||||
00000102 t setup_compass(unsigned char, Menu::arg const*)
|
||||
00000106 t test_current(unsigned char, Menu::arg const*)
|
||||
00000106 t calc_nav_pitch()
|
||||
00000106 t get_wp_with_index(int)
|
||||
00000108 t test_battery(unsigned char, Menu::arg const*)
|
||||
0000010c W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000010a t mavlink_delay(unsigned long)
|
||||
0000010a t send_raw_imu2(mavlink_channel_t)
|
||||
00000110 t test_radio(unsigned char, Menu::arg const*)
|
||||
00000110 t get_cmd_with_index(int)
|
||||
00000112 t get_distance(Location*, Location*)
|
||||
00000112 t startup_ground()
|
||||
00000112 t send_servo_out(mavlink_channel_t)
|
||||
00000112 t report_batt_monitor()
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000114 t read_barometer()
|
||||
00000116 t erase_logs(unsigned char, Menu::arg const*)
|
||||
00000118 t test_gps(unsigned char, Menu::arg const*)
|
||||
00000118 T GCS_MAVLINK::_queued_send()
|
||||
00000120 t test_pressure(unsigned char, Menu::arg const*)
|
||||
00000130 t test_dipswitches(unsigned char, Menu::arg const*)
|
||||
00000130 t set_wp_with_index(Location, int)
|
||||
00000130 t setup_flightmodes(unsigned char, Menu::arg const*)
|
||||
00000130 t set_cmd_with_index(Location, int)
|
||||
00000130 r test_menu_commands
|
||||
00000134 T GCS_MAVLINK::send_message(unsigned char, unsigned long)
|
||||
0000013e t process_may()
|
||||
00000136 W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000013e t calc_nav_roll()
|
||||
0000013e t handle_process_condition_command()
|
||||
00000146 t select_logs(unsigned char, Menu::arg const*)
|
||||
0000014e t verify_may()
|
||||
0000014e T GCS_MAVLINK::update()
|
||||
00000146 t send_vfr_hud(mavlink_channel_t)
|
||||
00000152 t report_gains()
|
||||
00000152 t verify_condition_command()
|
||||
0000015a t test_airspeed(unsigned char, Menu::arg const*)
|
||||
0000015e t set_guided_WP()
|
||||
0000015e t handle_process_nav_cmd()
|
||||
0000015e t test_gyro(unsigned char, Menu::arg const*)
|
||||
0000016a t process_must()
|
||||
0000016a t set_guided_WP()
|
||||
00000172 t navigate()
|
||||
0000016c t navigate()
|
||||
0000016e t send_attitude(mavlink_channel_t)
|
||||
00000174 t report_compass()
|
||||
00000174 t mavlink_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
0000017c t send_location(mavlink_channel_t)
|
||||
0000017e t Log_Read_Nav_Tuning()
|
||||
000001a2 t test_imu(unsigned char, Menu::arg const*)
|
||||
000001ae T init_home()
|
||||
00000180 t send_extended_status1(mavlink_channel_t, unsigned int)
|
||||
0000018c T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000192 T init_home()
|
||||
00000192 t test_imu(unsigned char, Menu::arg const*)
|
||||
0000019c t do_jump()
|
||||
000001ae t start_new_log(unsigned char)
|
||||
000001b2 t update_crosstrack()
|
||||
000001b2 t set_mode(unsigned char)
|
||||
000001bc t set_next_WP(Location*)
|
||||
000001bc t send_nav_controller_output(mavlink_channel_t)
|
||||
000001be t Log_Read_GPS()
|
||||
000001c8 t read_airspeed()
|
||||
000001ca t mavlink_delay(unsigned long)
|
||||
000001ca t start_new_log(unsigned char)
|
||||
000001ea T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
000001ec t init_barometer()
|
||||
000001c0 t read_airspeed()
|
||||
000001d2 t mavlink_try_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
000001d2 T GCS_MAVLINK::update()
|
||||
000001da W RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)
|
||||
000001ea t init_barometer()
|
||||
00000202 t test_failsafe(unsigned char, Menu::arg const*)
|
||||
00000206 t set_next_WP(Location*)
|
||||
00000208 t calc_throttle()
|
||||
00000226 t Log_Read(int, int)
|
||||
00000216 t Log_Read(int, int)
|
||||
0000021a t send_raw_imu1(mavlink_channel_t)
|
||||
0000022a t send_gps_raw(mavlink_channel_t)
|
||||
0000022c t process_next_command()
|
||||
0000022c t test_wp(unsigned char, Menu::arg const*)
|
||||
0000022c t set_mode(unsigned char)
|
||||
00000232 t verify_must()
|
||||
00000230 t verify_nav_command()
|
||||
0000023e t print_radio_values()
|
||||
0000024c t update_loiter()
|
||||
0000025c t setup_radio(unsigned char, Menu::arg const*)
|
||||
00000268 t send_raw_imu3(mavlink_channel_t)
|
||||
000002d4 t handle_process_do_command()
|
||||
000002e4 t read_radio()
|
||||
0000031e t read_battery()
|
||||
0000032e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000031e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000033a W Parameters::~Parameters()
|
||||
00000404 t process_next_command()
|
||||
0000041c t set_servos()
|
||||
000003e6 t read_battery()
|
||||
0000044c t print_log_menu()
|
||||
000004b2 t mavlink_parse_char
|
||||
000004de t set_servos()
|
||||
0000059c t __static_initialization_and_destruction_0(int, int)
|
||||
000006da t init_ardupilot()
|
||||
00000831 b g
|
||||
0000090a W Parameters::Parameters()
|
||||
0000156a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
000018ea t mavlink_try_send_message(mavlink_channel_t, unsigned char, unsigned int)
|
||||
00001ae8 T loop
|
||||
0000064a t init_ardupilot()
|
||||
00000920 W Parameters::Parameters()
|
||||
0000092b b g
|
||||
0000149a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001cbe T loop
|
||||
|
@ -3,11 +3,13 @@
|
||||
In file included from /root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:32:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
autogenerated:63: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
autogenerated:64: warning: 'void recalc_climb_rate()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void print_climb_debug_info()' declared 'static' but never defined
|
||||
autogenerated:126: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:2057: warning: 'void gcs_send_text(gcs_severity, const char*)' defined but not used
|
||||
autogenerated:87: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/commands.pde:128: warning: 'void increment_cmd_index()' defined but not used
|
||||
autogenerated:144: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:270: warning: 'command_index' defined but not used
|
||||
%% libraries/APM_BMP085/APM_BMP085.o
|
||||
%% libraries/APM_BMP085/APM_BMP085_hil.o
|
||||
%% libraries/APM_RC/APM_RC.o
|
||||
%% libraries/AP_ADC/AP_ADC_ADS7844.o
|
||||
%% libraries/AP_ADC/AP_ADC.o
|
||||
@ -35,11 +37,17 @@ autogenerated:126: warning: 'void low_battery_event()' declared 'static' but nev
|
||||
%% libraries/AP_GPS/AP_GPS_UBLOX.o
|
||||
%% libraries/AP_GPS/GPS.o
|
||||
%% libraries/AP_IMU/AP_IMU_Oilpan.o
|
||||
%% libraries/AP_Mount/AP_Mount.o
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::control_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:182: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::status_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:226: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_MaxsonarXL.o
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_SharpGP2Y.o
|
||||
%% libraries/AP_RangeFinder/RangeFinder.o
|
||||
%% libraries/AP_Relay/AP_Relay.o
|
||||
%% libraries/DataFlash/DataFlash.o
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:35:
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:36:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
%% libraries/FastSerial/BetterStream.o
|
||||
@ -48,6 +56,7 @@ In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp
|
||||
%% libraries/GCS_MAVLink/GCS_MAVLink.o
|
||||
%% libraries/ModeFilter/ModeFilter.o
|
||||
%% libraries/PID/PID.o
|
||||
%% libraries/RC_Channel/RC_Channel_aux.o
|
||||
%% libraries/RC_Channel/RC_Channel.o
|
||||
%% libraries/memcheck/memcheck.o
|
||||
%% libraries/FastSerial/ftoa_engine.o
|
||||
|
@ -3,20 +3,21 @@
|
||||
00000001 b home_is_set
|
||||
00000001 b ch3_failsafe
|
||||
00000001 b land_complete
|
||||
00000001 b command_may_ID
|
||||
00000001 b command_must_ID
|
||||
00000001 b mavlink_active
|
||||
00000001 b nav_command_ID
|
||||
00000001 b failsafeCounter
|
||||
00000001 b counter_one_herz
|
||||
00000001 b in_mavlink_delay
|
||||
00000001 b slow_loopCounter
|
||||
00000001 d takeoff_complete
|
||||
00000001 b command_may_index
|
||||
00000001 b command_must_index
|
||||
00000001 b nav_command_index
|
||||
00000001 b delta_ms_fast_loop
|
||||
00000001 d ground_start_count
|
||||
00000001 b medium_loopCounter
|
||||
00000001 b non_nav_command_ID
|
||||
00000001 b rc_override_active
|
||||
00000001 b delta_ms_medium_loop
|
||||
00000001 b non_nav_command_index
|
||||
00000001 b superslow_loopCounter
|
||||
00000001 b event_id
|
||||
00000001 b GPS_light
|
||||
@ -25,12 +26,10 @@
|
||||
00000001 D control_mode
|
||||
00000001 B hindex
|
||||
00000001 B inverted_flight
|
||||
00000001 B mavdelay
|
||||
00000001 B n
|
||||
00000001 B oldSwitchPosition
|
||||
00000001 B relay
|
||||
00000002 T ReadSCP1000()
|
||||
00000002 T mavlink_acknowledge(mavlink_channel_t, unsigned char, unsigned char, unsigned char)
|
||||
00000002 b climb_rate
|
||||
00000002 b loiter_sum
|
||||
00000002 b event_delay
|
||||
00000002 b event_value
|
||||
@ -50,7 +49,6 @@
|
||||
00000002 b event_undo_value
|
||||
00000002 b ground_start_avg
|
||||
00000002 b airspeed_pressure
|
||||
00000002 b adc
|
||||
00000002 r comma
|
||||
00000002 b g_gps
|
||||
00000002 b pmTest1
|
||||
@ -60,7 +58,6 @@
|
||||
00000002 d ch2_temp
|
||||
00000002 b failsafe
|
||||
00000002 b sonar_alt
|
||||
00000002 T GCS_MAVLINK::acknowledge(unsigned char, unsigned char, unsigned char)
|
||||
00000002 r print_divider()::__c
|
||||
00000002 d throttle_slew_limit()::last
|
||||
00000002 r test_gps(unsigned char, Menu::arg const*)::__c
|
||||
@ -72,6 +69,7 @@
|
||||
00000003 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
00000003 r print_log_menu()::__c
|
||||
00000003 r report_compass()::__c
|
||||
00000003 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 b event_timer
|
||||
00000004 d hold_course
|
||||
00000004 b loiter_time
|
||||
@ -82,6 +80,7 @@
|
||||
00000004 b airspeed_raw
|
||||
00000004 b current_amps
|
||||
00000004 b energy_error
|
||||
00000004 b airspeed_fbwB
|
||||
00000004 b bearing_error
|
||||
00000004 b current_total
|
||||
00000004 b nav_loopTimer
|
||||
@ -123,8 +122,6 @@
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000004 b mavlink_delay(unsigned long)::last_1hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_3hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_10hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_50hz
|
||||
00000004 r print_enabled(bool)::__c
|
||||
00000004 r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
@ -214,14 +211,14 @@
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
0000000a r __menu_name__main_menu
|
||||
00000009 V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a r init_home()::__c
|
||||
0000000a r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000a r verify_nav_wp()::__c
|
||||
0000000a r report_compass()::__c
|
||||
0000000a r report_throttle()::__c
|
||||
0000000a r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
@ -232,31 +229,30 @@
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a T setup
|
||||
0000000b r test_relay(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r report_gains()::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
0000000b r control_failsafe(unsigned int)::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000c t process_logs(unsigned char, Menu::arg const*)
|
||||
0000000c T GCS_MAVLINK::send_text(unsigned char, char const*)
|
||||
0000000c T GCS_MAVLINK::send_text(gcs_severity, char const*)
|
||||
0000000c V vtable for IMU
|
||||
0000000c r setup_show(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r report_xtrack()::__c
|
||||
0000000c r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000c r control_failsafe(unsigned int)::__c
|
||||
0000000c r test_mode(unsigned char, Menu::arg const*)::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000d r init_home()::__c
|
||||
0000000d r verify_RTL()::__c
|
||||
0000000d r demo_servos(unsigned char)::__c
|
||||
@ -267,6 +263,9 @@
|
||||
0000000d r print_log_menu()::__c
|
||||
0000000d r test_modeswitch(unsigned char, Menu::arg const*)::__c
|
||||
0000000d r Log_Read_Startup()::__c
|
||||
0000000d r control_failsafe(unsigned int)::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
@ -287,6 +286,7 @@
|
||||
0000000d B sonar_mode_filter
|
||||
0000000e t global destructors keyed to Serial
|
||||
0000000e t global constructors keyed to Serial
|
||||
0000000e t send_statustext(mavlink_channel_t)
|
||||
0000000e V vtable for AP_Float16
|
||||
0000000e V vtable for AP_VarA<float, (unsigned char)6>
|
||||
0000000e V vtable for AP_VarS<Matrix3<float> >
|
||||
@ -296,10 +296,10 @@
|
||||
0000000e V vtable for AP_VarT<int>
|
||||
0000000e V vtable for AP_VarT<long>
|
||||
0000000e r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r process_may()::__c
|
||||
0000000e r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_gains()::__c
|
||||
0000000e r print_log_menu()::__c
|
||||
0000000e r control_failsafe(unsigned int)::__c
|
||||
0000000e r setup_batt_monitor(unsigned char, Menu::arg const*)::__c
|
||||
0000000e r report_batt_monitor()::__c
|
||||
0000000e r report_flight_modes()::__c
|
||||
@ -325,23 +325,25 @@
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000f b current_loc
|
||||
0000000f b next_command
|
||||
0000000f b next_nav_command
|
||||
0000000f b next_nonnav_command
|
||||
0000000f b home
|
||||
0000000f b next_WP
|
||||
0000000f b prev_WP
|
||||
0000000f b guided_WP
|
||||
0000000f r report_gains()::__c
|
||||
0000000f r print_log_menu()::__c
|
||||
0000000f r failsafe_short_on_event()::__c
|
||||
0000000f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V AP_IMU_Oilpan::AP_IMU_Oilpan(AP_ADC*, unsigned int)::__c
|
||||
00000010 b rc_override
|
||||
00000010 r planner_menu_commands
|
||||
00000010 T GCS_MAVLINK::send_message(ap_message)
|
||||
00000010 W AP_VarT<float>::cast_to_float() const
|
||||
00000010 W AP_VarT<long>::cast_to_float() const
|
||||
00000010 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
@ -349,17 +351,18 @@
|
||||
00000010 r Log_Read_Startup()::__c
|
||||
00000010 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000010 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000010 t mavlink_get_channel_status
|
||||
00000011 r __menu_name__main_menu
|
||||
00000011 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r set_next_WP(Location*)::__c
|
||||
00000011 r zero_eeprom()::__c
|
||||
00000011 r test_airspeed(unsigned char, Menu::arg const*)::__c
|
||||
00000011 r startup_ground()::__c
|
||||
00000011 r Log_Read_Attitude()::__c
|
||||
00000011 r load_next_command_from_EEPROM()::__c
|
||||
00000011 r process_next_command()::__c
|
||||
00000011 r failsafe_short_on_event()::__c
|
||||
00000012 B Serial
|
||||
00000012 B Serial1
|
||||
00000012 B Serial3
|
||||
00000012 t gcs_update()
|
||||
00000012 W AP_Float16::~AP_Float16()
|
||||
00000012 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
00000012 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
@ -372,6 +375,7 @@
|
||||
00000012 r print_done()::__c
|
||||
00000012 r select_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000012 r init_barometer()::__c
|
||||
00000012 r handle_no_commands()::__c
|
||||
00000012 r startup_IMU_ground()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
00000012 r report_batt_monitor()::__c
|
||||
@ -391,11 +395,11 @@
|
||||
00000014 W AP_VarT<signed char>::unserialize(void*, unsigned int)
|
||||
00000014 W AP_VarT<signed char>::cast_to_float() const
|
||||
00000014 W AP_VarT<int>::cast_to_float() const
|
||||
00000014 r set_guided_WP()::__c
|
||||
00000014 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000014 r test_imu(unsigned char, Menu::arg const*)::__c
|
||||
00000015 r map_baudrate(signed char, unsigned long)::__c
|
||||
00000015 r report_gains()::__c
|
||||
00000015 r verify_nav_wp()::__c
|
||||
00000015 r init_ardupilot()::__c
|
||||
00000015 r print_hit_enter()::__c
|
||||
00000015 r test_gyro(unsigned char, Menu::arg const*)::__c
|
||||
@ -403,21 +407,22 @@
|
||||
00000016 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r report_batt_monitor()::__c
|
||||
00000016 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000016 r GCS_MAVLINK::update()::__c
|
||||
00000016 B sonar
|
||||
00000017 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000017 r test_wp(unsigned char, Menu::arg const*)::__c
|
||||
00000018 W AP_VarT<int>::serialize(void*, unsigned int) const
|
||||
00000018 b mavlink_get_channel_status::m_mavlink_status
|
||||
00000018 r process_must()::__c
|
||||
00000018 r report_compass()::__c
|
||||
00000018 r Log_Read_Startup()::__c
|
||||
00000019 r report_batt_monitor()::__c
|
||||
00000019 r failsafe_long_on_event()::__c
|
||||
00000019 r GCS_MAVLINK::update()::__c
|
||||
0000001a r reset_control_switch()::__c
|
||||
00000019 r handle_process_nav_cmd()::__c
|
||||
00000019 r handle_process_do_command()::__c
|
||||
00000019 r handle_process_condition_command()::__c
|
||||
00000019 r do_jump()::__c
|
||||
0000001a r failsafe_short_on_event()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r Log_Read(int, int)::__c
|
||||
0000001b r failsafe_short_off_event()::__c
|
||||
0000001c W AP_VarA<float, (unsigned char)6>::unserialize(void*, unsigned int)
|
||||
@ -434,12 +439,12 @@
|
||||
0000001d r startup_ground()::__c
|
||||
0000001d r report_batt_monitor()::__c
|
||||
0000001e r flight_mode_strings
|
||||
0000001e t failsafe_short_off_event()
|
||||
0000001e r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
0000001e r startup_ground()::__c
|
||||
0000001f r setup_compass(unsigned char, Menu::arg const*)::__c
|
||||
0000001f r init_ardupilot()::__c
|
||||
0000001f r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
00000020 t gcs_send_message(ap_message)
|
||||
00000020 r test_current(unsigned char, Menu::arg const*)::__c
|
||||
00000020 r report_xtrack()::__c
|
||||
00000020 r init_barometer()::__c
|
||||
@ -447,7 +452,10 @@
|
||||
00000020 t byte_swap_4
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r print_log_menu()::__c
|
||||
00000021 r verify_loiter_time()::__c
|
||||
00000021 r process_next_command()::__c
|
||||
00000022 t print_blanks(int)
|
||||
00000022 t failsafe_short_off_event()
|
||||
00000022 t reset_I()
|
||||
00000022 W AP_Float16::~AP_Float16()
|
||||
00000022 W AP_VarA<float, (unsigned char)6>::~AP_VarA()
|
||||
@ -459,23 +467,22 @@
|
||||
00000022 W AP_VarT<long>::~AP_VarT()
|
||||
00000022 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000022 r report_compass()::__c
|
||||
00000022 r increment_WP_index()::__c
|
||||
00000022 r verify_loiter_time()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000023 r test_pressure(unsigned char, Menu::arg const*)::__c
|
||||
00000023 r print_gyro_offsets()::__c
|
||||
00000023 r verify_loiter_turns()::__c
|
||||
00000023 r navigate()::__c
|
||||
00000024 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000024 r print_accel_offsets()::__c
|
||||
00000024 r verify_loiter_turns()::__c
|
||||
00000026 t print_done()
|
||||
00000026 b mavlink_queue
|
||||
00000026 t print_hit_enter()
|
||||
00000026 r init_ardupilot()::__c
|
||||
00000026 r print_PID(PID*)::__c
|
||||
00000027 r change_command(unsigned char)::__c
|
||||
00000027 r init_ardupilot()::__c
|
||||
00000027 r test_xbee(unsigned char, Menu::arg const*)::__c
|
||||
00000028 t main_menu_help(unsigned char, Menu::arg const*)
|
||||
00000028 t increment_WP_index()
|
||||
00000028 t help_log(unsigned char, Menu::arg const*)
|
||||
00000028 W AP_VarT<float>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<long>::unserialize(void*, unsigned int)
|
||||
@ -485,71 +492,75 @@
|
||||
0000002a t setup_declination(unsigned char, Menu::arg const*)
|
||||
0000002a r init_ardupilot()::__c
|
||||
0000002a r startup_ground()::__c
|
||||
0000002b r verify_must()::__c
|
||||
0000002a r verify_nav_command()::__c
|
||||
0000002a t _mav_put_int8_t_array
|
||||
0000002b r test_battery(unsigned char, Menu::arg const*)::__c
|
||||
0000002b r change_command(unsigned char)::__c
|
||||
0000002c t freeRAM()
|
||||
0000002d r startup_IMU_ground()::__c
|
||||
0000002e t reset_control_switch()
|
||||
0000002e t send_rate(unsigned int, unsigned int)
|
||||
0000002e t gcs_send_text_P(gcs_severity, prog_char_t const*)
|
||||
0000002e t gcs_data_stream_send(unsigned int, unsigned int)
|
||||
0000002e W AP_Var_group::AP_Var_group(unsigned int, prog_char_t const*, unsigned char)
|
||||
0000002e r verify_nav_wp()::__c
|
||||
00000030 t setup_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t planner_mode(unsigned char, Menu::arg const*)
|
||||
00000030 t send_heartbeat(mavlink_channel_t)
|
||||
00000030 t test_mode(unsigned char, Menu::arg const*)
|
||||
00000030 r verify_may()::__c
|
||||
00000030 r print_log_menu()::__c
|
||||
00000031 r start_new_log(unsigned char)::__c
|
||||
00000032 T GCS_MAVLINK::init(FastSerial*)
|
||||
00000032 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000033 b pending_status
|
||||
00000034 W AP_Float16::serialize(void*, unsigned int) const
|
||||
00000034 r test_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000034 t _mav_put_int8_t_array
|
||||
00000034 t mavlink_msg_statustext_send
|
||||
00000035 r test_radio_pwm(unsigned char, Menu::arg const*)::__c
|
||||
00000035 r Log_Read_Nav_Tuning()::__c
|
||||
00000035 r verify_condition_command()::__c
|
||||
00000036 t report_radio()
|
||||
00000036 r test_failsafe(unsigned char, Menu::arg const*)::__c
|
||||
00000037 r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
00000038 t send_current_waypoint(mavlink_channel_t)
|
||||
00000038 b barometer
|
||||
00000038 r test_dipswitches(unsigned char, Menu::arg const*)::__c
|
||||
00000038 r dump_log(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r setup_radio(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r planner_mode(unsigned char, Menu::arg const*)::__c
|
||||
00000039 r init_ardupilot()::__c
|
||||
0000003a t report_imu()
|
||||
0000003a t verify_loiter_turns()
|
||||
0000003a W PID::~PID()
|
||||
0000003c t verify_RTL()
|
||||
0000003c t Log_Write_Mode(unsigned char)
|
||||
0000003c t verify_loiter_turns()
|
||||
0000003c W RC_Channel::~RC_Channel()
|
||||
0000003c r test_wp_print(Location*, unsigned char)::__c
|
||||
0000003c r test_mag(unsigned char, Menu::arg const*)::__c
|
||||
0000003d B g_gps_driver
|
||||
0000003e t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(unsigned char, prog_char_t const*)
|
||||
0000003e T GCS_MAVLINK::send_text(gcs_severity, prog_char_t const*)
|
||||
0000003e W AP_VarT<signed char>::AP_VarT(signed char, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000040 b adc
|
||||
00000040 W AP_Float16::unserialize(void*, unsigned int)
|
||||
00000040 t byte_swap_8
|
||||
00000040 t crc_accumulate
|
||||
00000040 B history
|
||||
00000043 r Log_Read_GPS()::__c
|
||||
00000044 W AP_VarT<int>::AP_VarT(int, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000044 r report_throttle()::__c
|
||||
00000045 r erase_logs(unsigned char, Menu::arg const*)::__c
|
||||
00000046 W RC_Channel::~RC_Channel()
|
||||
00000048 t failsafe_long_on_event()
|
||||
0000004a t send_meminfo(mavlink_channel_t)
|
||||
0000004a W AP_VarT<int>::AP_VarT(AP_Var_group*, unsigned int, int, prog_char_t const*, unsigned char)
|
||||
0000004b r setup_factory(unsigned char, Menu::arg const*)::__c
|
||||
0000004c t setup_erase(unsigned char, Menu::arg const*)
|
||||
0000004c t Log_Read_Mode()
|
||||
0000004c B imu
|
||||
0000004e T mavlink_send_text(mavlink_channel_t, unsigned char, char const*)
|
||||
0000004e t setup_batt_monitor(unsigned char, Menu::arg const*)
|
||||
00000050 b mavlink_queue
|
||||
00000050 r log_menu_commands
|
||||
00000050 r main_menu_commands
|
||||
00000050 t failsafe_long_on_event()
|
||||
00000050 T GCS_MAVLINK::_find_parameter(unsigned int)
|
||||
00000050 B imu
|
||||
00000054 t print_divider()
|
||||
00000054 t print_enabled(bool)
|
||||
00000054 t report_flight_modes()
|
||||
00000055 r setup_flightmodes(unsigned char, Menu::arg const*)::__c
|
||||
00000056 t change_command(unsigned char)
|
||||
00000056 T GCS_MAVLINK::queued_waypoint_send()
|
||||
00000058 t radio_input_switch()
|
||||
0000005a t update_GPS_light()
|
||||
0000005a W AP_VarT<float>::AP_VarT(float, unsigned int, prog_char_t const*, unsigned char)
|
||||
@ -558,142 +569,157 @@
|
||||
0000005c t get_num_logs()
|
||||
0000005e T GCS_MAVLINK::_count_parameters()
|
||||
00000060 t print_switch(unsigned char, unsigned char)
|
||||
00000060 b barometer
|
||||
00000060 W AP_Float16::AP_Float16(AP_Var_group*, unsigned int, float, prog_char_t const*, unsigned char)
|
||||
00000060 t _mavlink_send_uart
|
||||
00000064 t Log_Write_Attitude(int, int, unsigned int)
|
||||
00000064 t mavlink_msg_param_value_send(mavlink_channel_t, char const*, float, unsigned char, unsigned int, unsigned int)
|
||||
00000064 t test_xbee(unsigned char, Menu::arg const*)
|
||||
00000064 t mavlink_msg_param_value_send
|
||||
00000064 W RC_Channel_aux::~RC_Channel_aux()
|
||||
00000068 t zero_eeprom()
|
||||
00000068 t find_last_log_page(int)
|
||||
0000006a T mavlink_send_text(mavlink_channel_t, gcs_severity, char const*)
|
||||
0000006a t demo_servos(unsigned char)
|
||||
0000006a t startup_IMU_ground()
|
||||
0000006a W GCS_MAVLINK::~GCS_MAVLINK()
|
||||
0000006c t setup_show(unsigned char, Menu::arg const*)
|
||||
0000006c t demo_servos(unsigned char)
|
||||
0000006e t setup_factory(unsigned char, Menu::arg const*)
|
||||
00000070 r init_ardupilot()::__c
|
||||
00000074 t verify_loiter_time()
|
||||
00000076 t startup_IMU_ground()
|
||||
00000072 t verify_loiter_time()
|
||||
00000078 t gcs_send_text_fmt(prog_char_t const*, ...)
|
||||
00000078 t read_control_switch()
|
||||
0000007c t failsafe_short_on_event()
|
||||
0000007c t send_gps_status(mavlink_channel_t)
|
||||
0000007c t do_RTL()
|
||||
0000007e t test_rawgps(unsigned char, Menu::arg const*)
|
||||
00000080 r setup_menu_commands
|
||||
00000080 T __vector_25
|
||||
00000080 T __vector_36
|
||||
00000080 T __vector_54
|
||||
00000084 t change_command(unsigned char)
|
||||
00000086 t Log_Read_Attitude()
|
||||
00000088 t Log_Read_Raw()
|
||||
0000008a t Log_Write_Cmd(unsigned char, Location*)
|
||||
0000008c t print_gyro_offsets()
|
||||
0000008c t print_accel_offsets()
|
||||
0000008c r main_menu_help(unsigned char, Menu::arg const*)::__c
|
||||
00000090 t do_RTL()
|
||||
0000008e t failsafe_short_on_event()
|
||||
00000090 t handle_no_commands()
|
||||
00000092 T GCS_MAVLINK::queued_param_send()
|
||||
00000096 t map_baudrate(signed char, unsigned long)
|
||||
00000096 t test_wp_print(Location*, unsigned char)
|
||||
0000009c t update_servo_switches()
|
||||
0000009c t print_PID(PID*)
|
||||
0000009d B gcs
|
||||
0000009d B hil
|
||||
0000009c B gcs0
|
||||
0000009c B gcs3
|
||||
000000a0 t report_xtrack()
|
||||
000000a2 t verify_nav_wp()
|
||||
000000a4 t Log_Read_Cmd()
|
||||
000000a4 T __vector_26
|
||||
000000a4 T __vector_37
|
||||
000000a4 T __vector_55
|
||||
000000a6 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000ac t Log_Read_Performance()
|
||||
000000b0 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b0 t Log_Read_Startup()
|
||||
000000b4 t test_relay(unsigned char, Menu::arg const*)
|
||||
000000b4 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000b6 t get_log_boundaries(unsigned char, int&, int&)
|
||||
000000b7 b compass
|
||||
000000bc t Log_Read_Control_Tuning()
|
||||
000000be t update_events()
|
||||
000000c0 t report_throttle()
|
||||
000000c0 t calc_bearing_error()
|
||||
000000c2 t test_eedump(unsigned char, Menu::arg const*)
|
||||
000000c4 t update_events()
|
||||
000000c4 t load_next_command_from_EEPROM()
|
||||
000000c6 t zero_airspeed()
|
||||
000000c6 t startup_ground()
|
||||
000000c7 B dcm
|
||||
000000c8 t test_modeswitch(unsigned char, Menu::arg const*)
|
||||
000000ca t send_radio_out(mavlink_channel_t)
|
||||
000000ca t control_failsafe(unsigned int)
|
||||
000000ce t zero_airspeed()
|
||||
000000ce t send_radio_in(mavlink_channel_t)
|
||||
000000ce W PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)
|
||||
000000ce r setup_mode(unsigned char, Menu::arg const*)::__c
|
||||
000000ce r help_log(unsigned char, Menu::arg const*)::__c
|
||||
000000d0 t get_bearing(Location*, Location*)
|
||||
000000d8 t verify_nav_wp()
|
||||
000000e0 b mavlink_parse_char::m_mavlink_message
|
||||
000000d4 t trim_radio()
|
||||
000000e4 t test_radio_pwm(unsigned char, Menu::arg const*)
|
||||
000000e7 r init_ardupilot()::__c
|
||||
000000ec t dump_log(unsigned char, Menu::arg const*)
|
||||
000000f0 t throttle_slew_limit()
|
||||
000000f0 t test_adc(unsigned char, Menu::arg const*)
|
||||
000000f4 t _mav_finalize_message_chan_send
|
||||
000000fa t Log_Read_Current()
|
||||
00000100 t trim_radio()
|
||||
00000102 t setup_compass(unsigned char, Menu::arg const*)
|
||||
00000106 t test_current(unsigned char, Menu::arg const*)
|
||||
00000106 t calc_nav_pitch()
|
||||
00000106 t get_wp_with_index(int)
|
||||
00000108 t test_battery(unsigned char, Menu::arg const*)
|
||||
0000010c W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000010a t mavlink_delay(unsigned long)
|
||||
0000010a t send_raw_imu2(mavlink_channel_t)
|
||||
00000110 t test_radio(unsigned char, Menu::arg const*)
|
||||
00000110 t get_cmd_with_index(int)
|
||||
00000112 t get_distance(Location*, Location*)
|
||||
00000112 t startup_ground()
|
||||
00000112 t send_servo_out(mavlink_channel_t)
|
||||
00000112 t report_batt_monitor()
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000114 t erase_logs(unsigned char, Menu::arg const*)
|
||||
00000114 t read_barometer()
|
||||
00000118 t test_gps(unsigned char, Menu::arg const*)
|
||||
00000118 T GCS_MAVLINK::_queued_send()
|
||||
00000120 t test_pressure(unsigned char, Menu::arg const*)
|
||||
00000130 t test_dipswitches(unsigned char, Menu::arg const*)
|
||||
00000130 t set_wp_with_index(Location, int)
|
||||
00000130 t setup_flightmodes(unsigned char, Menu::arg const*)
|
||||
00000130 t set_cmd_with_index(Location, int)
|
||||
00000130 r test_menu_commands
|
||||
00000134 T GCS_MAVLINK::send_message(unsigned char, unsigned long)
|
||||
0000013e t process_may()
|
||||
00000136 W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000013e t calc_nav_roll()
|
||||
0000013e t handle_process_condition_command()
|
||||
00000146 t select_logs(unsigned char, Menu::arg const*)
|
||||
0000014e t verify_may()
|
||||
0000014e T GCS_MAVLINK::update()
|
||||
00000146 t send_vfr_hud(mavlink_channel_t)
|
||||
00000152 t report_gains()
|
||||
00000152 t verify_condition_command()
|
||||
00000158 t test_airspeed(unsigned char, Menu::arg const*)
|
||||
0000015e t set_guided_WP()
|
||||
0000015e t handle_process_nav_cmd()
|
||||
0000015e t test_gyro(unsigned char, Menu::arg const*)
|
||||
0000016a t process_must()
|
||||
0000016a t set_guided_WP()
|
||||
00000172 t navigate()
|
||||
0000016c t navigate()
|
||||
0000016e t send_attitude(mavlink_channel_t)
|
||||
00000174 t report_compass()
|
||||
00000174 t mavlink_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
0000017c t send_location(mavlink_channel_t)
|
||||
0000017e t Log_Read_Nav_Tuning()
|
||||
000001a2 t test_imu(unsigned char, Menu::arg const*)
|
||||
000001ae T init_home()
|
||||
00000180 t send_extended_status1(mavlink_channel_t, unsigned int)
|
||||
0000018c T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000190 T init_home()
|
||||
00000192 t test_imu(unsigned char, Menu::arg const*)
|
||||
0000019a t do_jump()
|
||||
000001ae t start_new_log(unsigned char)
|
||||
000001b2 t update_crosstrack()
|
||||
000001b2 t set_mode(unsigned char)
|
||||
000001bc t set_next_WP(Location*)
|
||||
000001bc t send_nav_controller_output(mavlink_channel_t)
|
||||
000001be t Log_Read_GPS()
|
||||
000001c8 t read_airspeed()
|
||||
000001ca t mavlink_delay(unsigned long)
|
||||
000001ca t start_new_log(unsigned char)
|
||||
000001ea T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
000001ec t init_barometer()
|
||||
000001c0 t read_airspeed()
|
||||
000001d2 t mavlink_try_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
000001d2 T GCS_MAVLINK::update()
|
||||
000001da W RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)
|
||||
000001ea t init_barometer()
|
||||
000001fe t test_failsafe(unsigned char, Menu::arg const*)
|
||||
00000206 t set_next_WP(Location*)
|
||||
00000208 t calc_throttle()
|
||||
00000222 t Log_Read(int, int)
|
||||
00000210 t Log_Read(int, int)
|
||||
0000021a t send_raw_imu1(mavlink_channel_t)
|
||||
00000228 t test_wp(unsigned char, Menu::arg const*)
|
||||
0000022c t set_mode(unsigned char)
|
||||
00000232 t verify_must()
|
||||
0000022a t send_gps_raw(mavlink_channel_t)
|
||||
0000022c t process_next_command()
|
||||
00000230 t verify_nav_command()
|
||||
0000023e t print_radio_values()
|
||||
0000024c t update_loiter()
|
||||
0000025c t setup_radio(unsigned char, Menu::arg const*)
|
||||
00000268 t send_raw_imu3(mavlink_channel_t)
|
||||
000002d4 t handle_process_do_command()
|
||||
000002e4 t read_radio()
|
||||
0000031e t read_battery()
|
||||
0000032e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000031e t test_mag(unsigned char, Menu::arg const*)
|
||||
0000033a W Parameters::~Parameters()
|
||||
00000404 t process_next_command()
|
||||
0000041c t set_servos()
|
||||
000003e6 t read_battery()
|
||||
00000436 t print_log_menu()
|
||||
000004b2 t mavlink_parse_char
|
||||
000004de t set_servos()
|
||||
0000059c t __static_initialization_and_destruction_0(int, int)
|
||||
000006da t init_ardupilot()
|
||||
00000831 b g
|
||||
0000090a W Parameters::Parameters()
|
||||
0000156a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
000018ea t mavlink_try_send_message(mavlink_channel_t, unsigned char, unsigned int)
|
||||
00001ae8 T loop
|
||||
00000648 t init_ardupilot()
|
||||
00000920 W Parameters::Parameters()
|
||||
0000092b b g
|
||||
0000149a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001cbe T loop
|
||||
|
@ -3,59 +3,71 @@
|
||||
In file included from /root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:32:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
autogenerated:25: warning: 'bool print_log_menu()' declared 'static' but never defined
|
||||
autogenerated:28: warning: 'void get_log_boundaries(byte, int&, int&)' declared 'static' but never defined
|
||||
autogenerated:29: warning: 'int find_last_log_page(int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:745: warning: 'void Log_Write_Attitude(int, int, uint16_t)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:746: warning: 'void Log_Write_Control_Tuning()' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:747: warning: 'void Log_Write_Raw()' defined but not used
|
||||
autogenerated:40: warning: 'void Log_Read_Current()' declared 'static' but never defined
|
||||
autogenerated:41: warning: 'void Log_Read_Control_Tuning()' declared 'static' but never defined
|
||||
autogenerated:42: warning: 'void Log_Read_Nav_Tuning()' declared 'static' but never defined
|
||||
autogenerated:43: warning: 'void Log_Read_Performance()' declared 'static' but never defined
|
||||
autogenerated:44: warning: 'void Log_Read_Cmd()' declared 'static' but never defined
|
||||
autogenerated:45: warning: 'void Log_Read_Startup()' declared 'static' but never defined
|
||||
autogenerated:46: warning: 'void Log_Read_Attitude()' declared 'static' but never defined
|
||||
autogenerated:47: warning: 'void Log_Read_Mode()' declared 'static' but never defined
|
||||
autogenerated:48: warning: 'void Log_Read_GPS()' declared 'static' but never defined
|
||||
autogenerated:49: warning: 'void Log_Read_Raw()' declared 'static' but never defined
|
||||
autogenerated:50: warning: 'void Log_Read(int, int)' declared 'static' but never defined
|
||||
autogenerated:63: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
autogenerated:64: warning: 'void recalc_climb_rate()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void print_climb_debug_info()' declared 'static' but never defined
|
||||
autogenerated:126: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
autogenerated:149: warning: 'void init_barometer()' declared 'static' but never defined
|
||||
autogenerated:150: warning: 'long int read_barometer()' declared 'static' but never defined
|
||||
autogenerated:152: warning: 'void zero_airspeed()' declared 'static' but never defined
|
||||
autogenerated:154: warning: 'void report_batt_monitor()' declared 'static' but never defined
|
||||
autogenerated:155: warning: 'void report_radio()' declared 'static' but never defined
|
||||
autogenerated:156: warning: 'void report_gains()' declared 'static' but never defined
|
||||
autogenerated:157: warning: 'void report_xtrack()' declared 'static' but never defined
|
||||
autogenerated:158: warning: 'void report_throttle()' declared 'static' but never defined
|
||||
autogenerated:159: warning: 'void report_imu()' declared 'static' but never defined
|
||||
autogenerated:160: warning: 'void report_compass()' declared 'static' but never defined
|
||||
autogenerated:161: warning: 'void report_flight_modes()' declared 'static' but never defined
|
||||
autogenerated:162: warning: 'void print_PID(PID*)' declared 'static' but never defined
|
||||
autogenerated:163: warning: 'void print_radio_values()' declared 'static' but never defined
|
||||
autogenerated:164: warning: 'void print_switch(byte, byte)' declared 'static' but never defined
|
||||
autogenerated:165: warning: 'void print_done()' declared 'static' but never defined
|
||||
autogenerated:166: warning: 'void print_blanks(int)' declared 'static' but never defined
|
||||
autogenerated:167: warning: 'void print_divider()' declared 'static' but never defined
|
||||
autogenerated:168: warning: 'int8_t radio_input_switch()' declared 'static' but never defined
|
||||
autogenerated:169: warning: 'void zero_eeprom()' declared 'static' but never defined
|
||||
autogenerated:170: warning: 'void print_enabled(bool)' declared 'static' but never defined
|
||||
autogenerated:171: warning: 'void print_accel_offsets()' declared 'static' but never defined
|
||||
autogenerated:172: warning: 'void print_gyro_offsets()' declared 'static' but never defined
|
||||
autogenerated:183: warning: 'void print_hit_enter()' declared 'static' but never defined
|
||||
autogenerated:184: warning: 'void test_wp_print(Location*, byte)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:210: warning: 'comma' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:212: warning: 'flight_mode_strings' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:317: warning: 'airspeed_raw' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:318: warning: 'airspeed_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:322: warning: 'abs_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:742: warning: 'int8_t process_logs(uint8_t, const Menu::arg*)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde: In function 'bool mavlink_try_send_message(mavlink_channel_t, ap_message, uint16_t)':
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:502: warning: enumeration value 'MSG_RAW_IMU1' not handled in switch
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:502: warning: enumeration value 'MSG_RAW_IMU2' not handled in switch
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:502: warning: enumeration value 'MSG_RAW_IMU3' not handled in switch
|
||||
autogenerated: At global scope:
|
||||
autogenerated:34: warning: 'void send_raw_imu1(mavlink_channel_t)' declared 'static' but never defined
|
||||
autogenerated:35: warning: 'void send_raw_imu2(mavlink_channel_t)' declared 'static' but never defined
|
||||
autogenerated:36: warning: 'void send_raw_imu3(mavlink_channel_t)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:2057: warning: 'void gcs_send_text(gcs_severity, const char*)' defined but not used
|
||||
autogenerated:49: warning: 'bool print_log_menu()' declared 'static' but never defined
|
||||
autogenerated:52: warning: 'void get_log_boundaries(byte, int&, int&)' declared 'static' but never defined
|
||||
autogenerated:53: warning: 'int find_last_log_page(int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:749: warning: 'void Log_Write_Attitude(int, int, uint16_t)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:750: warning: 'void Log_Write_Control_Tuning()' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:751: warning: 'void Log_Write_Raw()' defined but not used
|
||||
autogenerated:64: warning: 'void Log_Read_Current()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void Log_Read_Control_Tuning()' declared 'static' but never defined
|
||||
autogenerated:66: warning: 'void Log_Read_Nav_Tuning()' declared 'static' but never defined
|
||||
autogenerated:67: warning: 'void Log_Read_Performance()' declared 'static' but never defined
|
||||
autogenerated:68: warning: 'void Log_Read_Cmd()' declared 'static' but never defined
|
||||
autogenerated:69: warning: 'void Log_Read_Startup()' declared 'static' but never defined
|
||||
autogenerated:70: warning: 'void Log_Read_Attitude()' declared 'static' but never defined
|
||||
autogenerated:71: warning: 'void Log_Read_Mode()' declared 'static' but never defined
|
||||
autogenerated:72: warning: 'void Log_Read_GPS()' declared 'static' but never defined
|
||||
autogenerated:73: warning: 'void Log_Read_Raw()' declared 'static' but never defined
|
||||
autogenerated:74: warning: 'void Log_Read(int, int)' declared 'static' but never defined
|
||||
autogenerated:87: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/commands.pde:128: warning: 'void increment_cmd_index()' defined but not used
|
||||
autogenerated:144: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
autogenerated:164: warning: 'void init_barometer()' declared 'static' but never defined
|
||||
autogenerated:165: warning: 'long int read_barometer()' declared 'static' but never defined
|
||||
autogenerated:166: warning: 'void read_airspeed()' declared 'static' but never defined
|
||||
autogenerated:167: warning: 'void zero_airspeed()' declared 'static' but never defined
|
||||
autogenerated:169: warning: 'void report_batt_monitor()' declared 'static' but never defined
|
||||
autogenerated:170: warning: 'void report_radio()' declared 'static' but never defined
|
||||
autogenerated:171: warning: 'void report_gains()' declared 'static' but never defined
|
||||
autogenerated:172: warning: 'void report_xtrack()' declared 'static' but never defined
|
||||
autogenerated:173: warning: 'void report_throttle()' declared 'static' but never defined
|
||||
autogenerated:174: warning: 'void report_imu()' declared 'static' but never defined
|
||||
autogenerated:175: warning: 'void report_compass()' declared 'static' but never defined
|
||||
autogenerated:176: warning: 'void report_flight_modes()' declared 'static' but never defined
|
||||
autogenerated:177: warning: 'void print_PID(PID*)' declared 'static' but never defined
|
||||
autogenerated:178: warning: 'void print_radio_values()' declared 'static' but never defined
|
||||
autogenerated:179: warning: 'void print_switch(byte, byte)' declared 'static' but never defined
|
||||
autogenerated:180: warning: 'void print_done()' declared 'static' but never defined
|
||||
autogenerated:181: warning: 'void print_blanks(int)' declared 'static' but never defined
|
||||
autogenerated:182: warning: 'void print_divider()' declared 'static' but never defined
|
||||
autogenerated:183: warning: 'int8_t radio_input_switch()' declared 'static' but never defined
|
||||
autogenerated:184: warning: 'void zero_eeprom()' declared 'static' but never defined
|
||||
autogenerated:185: warning: 'void print_enabled(bool)' declared 'static' but never defined
|
||||
autogenerated:186: warning: 'void print_accel_offsets()' declared 'static' but never defined
|
||||
autogenerated:187: warning: 'void print_gyro_offsets()' declared 'static' but never defined
|
||||
autogenerated:188: warning: 'void run_cli()' declared 'static' but never defined
|
||||
autogenerated:198: warning: 'void print_hit_enter()' declared 'static' but never defined
|
||||
autogenerated:199: warning: 'void test_wp_print(Location*, byte)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:194: warning: 'comma' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:196: warning: 'flight_mode_strings' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:270: warning: 'command_index' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:304: warning: 'airspeed_raw' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:305: warning: 'airspeed_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:309: warning: 'abs_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:746: warning: 'int8_t process_logs(uint8_t, const Menu::arg*)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/planner.pde:19: warning: 'int8_t planner_mode(uint8_t, const Menu::arg*)' defined but not used
|
||||
%% libraries/APM_BMP085/APM_BMP085.o
|
||||
%% libraries/APM_BMP085/APM_BMP085_hil.o
|
||||
%% libraries/APM_RC/APM_RC.o
|
||||
%% libraries/AP_ADC/AP_ADC_ADS7844.o
|
||||
%% libraries/AP_ADC/AP_ADC.o
|
||||
@ -83,11 +95,17 @@ autogenerated:184: warning: 'void test_wp_print(Location*, byte)' declared 'stat
|
||||
%% libraries/AP_GPS/AP_GPS_UBLOX.o
|
||||
%% libraries/AP_GPS/GPS.o
|
||||
%% libraries/AP_IMU/AP_IMU_Oilpan.o
|
||||
%% libraries/AP_Mount/AP_Mount.o
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::control_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:182: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::status_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:226: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_MaxsonarXL.o
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_SharpGP2Y.o
|
||||
%% libraries/AP_RangeFinder/RangeFinder.o
|
||||
%% libraries/AP_Relay/AP_Relay.o
|
||||
%% libraries/DataFlash/DataFlash.o
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:35:
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:36:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
%% libraries/FastSerial/BetterStream.o
|
||||
@ -96,6 +114,7 @@ In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp
|
||||
%% libraries/GCS_MAVLink/GCS_MAVLink.o
|
||||
%% libraries/ModeFilter/ModeFilter.o
|
||||
%% libraries/PID/PID.o
|
||||
%% libraries/RC_Channel/RC_Channel_aux.o
|
||||
%% libraries/RC_Channel/RC_Channel.o
|
||||
%% libraries/memcheck/memcheck.o
|
||||
%% libraries/FastSerial/ftoa_engine.o
|
||||
|
@ -3,20 +3,21 @@
|
||||
00000001 b home_is_set
|
||||
00000001 b ch3_failsafe
|
||||
00000001 b land_complete
|
||||
00000001 b command_may_ID
|
||||
00000001 b command_must_ID
|
||||
00000001 b mavlink_active
|
||||
00000001 b nav_command_ID
|
||||
00000001 b failsafeCounter
|
||||
00000001 b counter_one_herz
|
||||
00000001 b in_mavlink_delay
|
||||
00000001 b slow_loopCounter
|
||||
00000001 d takeoff_complete
|
||||
00000001 b command_may_index
|
||||
00000001 b command_must_index
|
||||
00000001 b nav_command_index
|
||||
00000001 b delta_ms_fast_loop
|
||||
00000001 d ground_start_count
|
||||
00000001 b medium_loopCounter
|
||||
00000001 b non_nav_command_ID
|
||||
00000001 b rc_override_active
|
||||
00000001 b delta_ms_medium_loop
|
||||
00000001 b non_nav_command_index
|
||||
00000001 b superslow_loopCounter
|
||||
00000001 b event_id
|
||||
00000001 b GPS_light
|
||||
@ -24,11 +25,9 @@
|
||||
00000001 D control_mode
|
||||
00000001 B hindex
|
||||
00000001 B inverted_flight
|
||||
00000001 B mavdelay
|
||||
00000001 B n
|
||||
00000001 B oldSwitchPosition
|
||||
00000002 T mavlink_acknowledge(mavlink_channel_t, unsigned char, unsigned char, unsigned char)
|
||||
00000002 b climb_rate
|
||||
00000001 B relay
|
||||
00000002 b loiter_sum
|
||||
00000002 b event_delay
|
||||
00000002 b event_value
|
||||
@ -58,11 +57,11 @@
|
||||
00000002 W AP_IMU_Shim::init_accel(void (*)(unsigned long))
|
||||
00000002 W AP_IMU_Shim::init(IMU::Start_style, void (*)(unsigned long))
|
||||
00000002 W AP_IMU_Shim::init_gyro(void (*)(unsigned long))
|
||||
00000002 T GCS_MAVLINK::acknowledge(unsigned char, unsigned char, unsigned char)
|
||||
00000002 d throttle_slew_limit()::last
|
||||
00000002 V PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)::__c
|
||||
00000002 V PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)::__c
|
||||
00000002 V PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)::__c
|
||||
00000003 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 b event_timer
|
||||
00000004 d hold_course
|
||||
00000004 b loiter_time
|
||||
@ -71,6 +70,7 @@
|
||||
00000004 b wp_distance
|
||||
00000004 b current_amps
|
||||
00000004 b energy_error
|
||||
00000004 b airspeed_fbwB
|
||||
00000004 b bearing_error
|
||||
00000004 b current_total
|
||||
00000004 b nav_loopTimer
|
||||
@ -106,8 +106,6 @@
|
||||
00000004 b nav_roll
|
||||
00000004 b nav_pitch
|
||||
00000004 b mavlink_delay(unsigned long)::last_1hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_3hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_10hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_50hz
|
||||
00000004 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
@ -135,7 +133,6 @@
|
||||
00000007 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000007 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000008 r __menu_name__planner_menu
|
||||
00000008 W AP_IMU_Shim::update()
|
||||
00000008 V Parameters::Parameters()::__c
|
||||
00000008 V Parameters::Parameters()::__c
|
||||
00000008 V Parameters::Parameters()::__c
|
||||
@ -149,12 +146,13 @@
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a r init_home()::__c
|
||||
0000000a r verify_nav_wp()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
@ -162,18 +160,17 @@
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a T setup
|
||||
0000000b r control_failsafe(unsigned int)::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000c T GCS_MAVLINK::send_text(unsigned char, char const*)
|
||||
0000000c T GCS_MAVLINK::send_text(gcs_severity, char const*)
|
||||
0000000c V vtable for AP_IMU_Shim
|
||||
0000000c V vtable for IMU
|
||||
0000000c r control_failsafe(unsigned int)::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
@ -182,6 +179,9 @@
|
||||
0000000d r init_home()::__c
|
||||
0000000d r verify_RTL()::__c
|
||||
0000000d r demo_servos(unsigned char)::__c
|
||||
0000000d r control_failsafe(unsigned int)::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
@ -202,6 +202,7 @@
|
||||
0000000d B sonar_mode_filter
|
||||
0000000e t global destructors keyed to Serial
|
||||
0000000e t global constructors keyed to Serial
|
||||
0000000e t send_statustext(mavlink_channel_t)
|
||||
0000000e V vtable for AP_Float16
|
||||
0000000e V vtable for AP_VarS<Matrix3<float> >
|
||||
0000000e V vtable for AP_VarS<Vector3<float> >
|
||||
@ -209,7 +210,7 @@
|
||||
0000000e V vtable for AP_VarT<float>
|
||||
0000000e V vtable for AP_VarT<int>
|
||||
0000000e V vtable for AP_VarT<long>
|
||||
0000000e r process_may()::__c
|
||||
0000000e r control_failsafe(unsigned int)::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
@ -230,12 +231,13 @@
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000f b current_loc
|
||||
0000000f b next_command
|
||||
0000000f b next_nav_command
|
||||
0000000f b next_nonnav_command
|
||||
0000000f b home
|
||||
0000000f b next_WP
|
||||
0000000f b prev_WP
|
||||
0000000f b guided_WP
|
||||
0000000f r failsafe_short_on_event()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
@ -243,15 +245,16 @@
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
00000010 b rc_override
|
||||
00000010 r planner_menu_commands
|
||||
00000010 T GCS_MAVLINK::send_message(ap_message)
|
||||
00000010 W AP_VarT<float>::cast_to_float() const
|
||||
00000010 W AP_VarT<long>::cast_to_float() const
|
||||
00000010 t mavlink_get_channel_status
|
||||
00000011 r set_next_WP(Location*)::__c
|
||||
00000011 r startup_ground()::__c
|
||||
00000011 r load_next_command_from_EEPROM()::__c
|
||||
00000011 r process_next_command()::__c
|
||||
00000011 r failsafe_short_on_event()::__c
|
||||
00000012 B Serial
|
||||
00000012 B Serial1
|
||||
00000012 B Serial3
|
||||
00000012 t gcs_update()
|
||||
00000012 W AP_Float16::~AP_Float16()
|
||||
00000012 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
00000012 W AP_VarS<Vector3<float> >::~AP_VarS()
|
||||
@ -260,34 +263,39 @@
|
||||
00000012 W AP_VarT<int>::~AP_VarT()
|
||||
00000012 W AP_VarT<long>::~AP_VarT()
|
||||
00000012 W AP_VarT<signed char>::serialize(void*, unsigned int) const
|
||||
00000012 r handle_no_commands()::__c
|
||||
00000012 r GCS_MAVLINK::handleMessage(__mavlink_message*)::__c
|
||||
00000012 B adc
|
||||
00000014 W AP_VarT<signed char>::unserialize(void*, unsigned int)
|
||||
00000014 W AP_VarT<signed char>::cast_to_float() const
|
||||
00000014 W AP_VarT<int>::cast_to_float() const
|
||||
00000014 r set_guided_WP()::__c
|
||||
00000015 r map_baudrate(signed char, unsigned long)::__c
|
||||
00000015 r verify_nav_wp()::__c
|
||||
00000015 r init_ardupilot()::__c
|
||||
00000015 r GCS_MAVLINK::handleMessage(__mavlink_message*)::__c
|
||||
00000016 r GCS_MAVLINK::update()::__c
|
||||
00000016 B adc
|
||||
00000016 B sonar
|
||||
00000018 W AP_VarT<int>::serialize(void*, unsigned int) const
|
||||
00000018 b mavlink_get_channel_status::m_mavlink_status
|
||||
00000018 r process_must()::__c
|
||||
00000019 r failsafe_long_on_event()::__c
|
||||
00000019 r GCS_MAVLINK::update()::__c
|
||||
00000019 r handle_process_nav_cmd()::__c
|
||||
00000019 r handle_process_do_command()::__c
|
||||
00000019 r handle_process_condition_command()::__c
|
||||
00000019 r do_jump()::__c
|
||||
0000001a t startup_IMU_ground()
|
||||
0000001a r reset_control_switch()::__c
|
||||
0000001a r failsafe_short_on_event()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001b r failsafe_short_off_event()::__c
|
||||
0000001c W AP_VarS<Matrix3<float> >::unserialize(void*, unsigned int)
|
||||
0000001c W AP_VarS<Vector3<float> >::unserialize(void*, unsigned int)
|
||||
0000001c W AP_VarT<int>::unserialize(void*, unsigned int)
|
||||
0000001c W AP_VarS<Matrix3<float> >::serialize(void*, unsigned int) const
|
||||
0000001c W AP_VarS<Vector3<float> >::serialize(void*, unsigned int) const
|
||||
0000001e t failsafe_short_off_event()
|
||||
0000001e r startup_ground()::__c
|
||||
00000020 t gcs_send_message(ap_message)
|
||||
00000020 t byte_swap_4
|
||||
00000021 r verify_loiter_time()::__c
|
||||
00000021 r process_next_command()::__c
|
||||
00000022 t failsafe_short_off_event()
|
||||
00000022 t reset_I()
|
||||
00000022 W AP_Float16::~AP_Float16()
|
||||
00000022 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
@ -296,117 +304,134 @@
|
||||
00000022 W AP_VarT<float>::~AP_VarT()
|
||||
00000022 W AP_VarT<int>::~AP_VarT()
|
||||
00000022 W AP_VarT<long>::~AP_VarT()
|
||||
00000022 r increment_WP_index()::__c
|
||||
00000022 r verify_loiter_time()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000023 r verify_loiter_turns()::__c
|
||||
00000023 r navigate()::__c
|
||||
00000024 r verify_loiter_turns()::__c
|
||||
00000026 b mavlink_queue
|
||||
00000026 r init_ardupilot()::__c
|
||||
00000027 r change_command(unsigned char)::__c
|
||||
00000027 r init_ardupilot()::__c
|
||||
00000028 t increment_WP_index()
|
||||
00000028 t demo_servos(unsigned char)
|
||||
00000028 W AP_VarT<float>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<long>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<float>::serialize(void*, unsigned int) const
|
||||
00000028 W AP_VarT<long>::serialize(void*, unsigned int) const
|
||||
00000028 B imu
|
||||
0000002a t demo_servos(unsigned char)
|
||||
0000002b r verify_must()::__c
|
||||
0000002a r verify_nav_command()::__c
|
||||
0000002a t _mav_put_int8_t_array
|
||||
0000002b r change_command(unsigned char)::__c
|
||||
0000002e t reset_control_switch()
|
||||
0000002e t send_rate(unsigned int, unsigned int)
|
||||
0000002e t gcs_send_text_P(gcs_severity, prog_char_t const*)
|
||||
0000002e t gcs_data_stream_send(unsigned int, unsigned int)
|
||||
0000002e W AP_Var_group::AP_Var_group(unsigned int, prog_char_t const*, unsigned char)
|
||||
0000002e r verify_nav_wp()::__c
|
||||
00000030 r verify_may()::__c
|
||||
00000030 t send_heartbeat(mavlink_channel_t)
|
||||
00000030 B imu
|
||||
00000032 T GCS_MAVLINK::init(FastSerial*)
|
||||
00000032 r init_ardupilot()::__c
|
||||
00000033 b pending_status
|
||||
00000034 t _MAV_RETURN_float
|
||||
00000034 W AP_Float16::serialize(void*, unsigned int) const
|
||||
00000034 t _mav_put_int8_t_array
|
||||
00000034 t mavlink_msg_statustext_send
|
||||
00000035 r verify_condition_command()::__c
|
||||
00000038 t send_current_waypoint(mavlink_channel_t)
|
||||
00000039 r init_ardupilot()::__c
|
||||
0000003a t verify_loiter_turns()
|
||||
0000003a W PID::~PID()
|
||||
0000003a B g_gps_driver
|
||||
0000003c t verify_loiter_turns()
|
||||
0000003c W RC_Channel::~RC_Channel()
|
||||
0000003e t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(unsigned char, prog_char_t const*)
|
||||
0000003c t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(gcs_severity, prog_char_t const*)
|
||||
0000003e W AP_VarT<signed char>::AP_VarT(signed char, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000040 W AP_Float16::unserialize(void*, unsigned int)
|
||||
00000040 t byte_swap_8
|
||||
00000040 t crc_accumulate
|
||||
00000040 B history
|
||||
00000044 W AP_VarT<int>::AP_VarT(int, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000046 W RC_Channel::~RC_Channel()
|
||||
00000048 t failsafe_long_on_event()
|
||||
0000004a t send_meminfo(mavlink_channel_t)
|
||||
0000004a W AP_VarT<int>::AP_VarT(AP_Var_group*, unsigned int, int, prog_char_t const*, unsigned char)
|
||||
0000004e T mavlink_send_text(mavlink_channel_t, unsigned char, char const*)
|
||||
00000050 t failsafe_long_on_event()
|
||||
00000050 b mavlink_queue
|
||||
00000050 T GCS_MAVLINK::_find_parameter(unsigned int)
|
||||
00000056 t change_command(unsigned char)
|
||||
00000052 W AP_IMU_Shim::update()
|
||||
00000056 T GCS_MAVLINK::queued_waypoint_send()
|
||||
00000057 B dcm
|
||||
0000005a W AP_VarT<float>::AP_VarT(float, unsigned int, prog_char_t const*, unsigned char)
|
||||
0000005e T GCS_MAVLINK::_count_parameters()
|
||||
00000060 W AP_Float16::AP_Float16(AP_Var_group*, unsigned int, float, prog_char_t const*, unsigned char)
|
||||
00000060 t _mavlink_send_uart
|
||||
00000064 t mavlink_msg_param_value_send
|
||||
00000064 t mavlink_msg_param_value_send(mavlink_channel_t, char const*, float, unsigned char, unsigned int, unsigned int)
|
||||
00000064 W RC_Channel_aux::~RC_Channel_aux()
|
||||
0000006a T mavlink_send_text(mavlink_channel_t, gcs_severity, char const*)
|
||||
0000006a W GCS_MAVLINK::~GCS_MAVLINK()
|
||||
0000006e t do_RTL()
|
||||
00000070 r init_ardupilot()::__c
|
||||
00000074 t verify_loiter_time()
|
||||
0000007c t failsafe_short_on_event()
|
||||
00000080 t do_RTL()
|
||||
00000072 t verify_loiter_time()
|
||||
00000078 t gcs_send_text_fmt(prog_char_t const*, ...)
|
||||
0000007c t send_gps_status(mavlink_channel_t)
|
||||
00000080 T __vector_25
|
||||
00000080 T __vector_36
|
||||
00000080 T __vector_54
|
||||
00000084 t change_command(unsigned char)
|
||||
0000008e t handle_no_commands()
|
||||
0000008e t failsafe_short_on_event()
|
||||
00000092 T GCS_MAVLINK::queued_param_send()
|
||||
00000096 t map_baudrate(signed char, unsigned long)
|
||||
0000009b B gcs0
|
||||
0000009b B gcs3
|
||||
0000009c t update_servo_switches()
|
||||
0000009d B gcs
|
||||
0000009d B hil
|
||||
000000a2 t verify_nav_wp()
|
||||
000000a4 T __vector_26
|
||||
000000a4 T __vector_37
|
||||
000000a4 T __vector_55
|
||||
000000a6 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000ab B compass
|
||||
000000b4 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000be t update_events()
|
||||
000000c0 t calc_bearing_error()
|
||||
000000c4 t update_events()
|
||||
000000c4 t load_next_command_from_EEPROM()
|
||||
000000ca t send_radio_out(mavlink_channel_t)
|
||||
000000ca t control_failsafe(unsigned int)
|
||||
000000cc t read_control_switch()
|
||||
000000ce t send_radio_in(mavlink_channel_t)
|
||||
000000ce W PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)
|
||||
000000d0 t get_bearing(Location*, Location*)
|
||||
000000da t verify_nav_wp()
|
||||
000000e0 b mavlink_parse_char::m_mavlink_message
|
||||
000000f0 t throttle_slew_limit()
|
||||
000000f4 t _mav_finalize_message_chan_send
|
||||
00000106 t calc_nav_pitch()
|
||||
00000106 t get_wp_with_index(int)
|
||||
0000010c W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000010a t mavlink_delay(unsigned long)
|
||||
00000110 t get_cmd_with_index(int)
|
||||
00000112 t get_distance(Location*, Location*)
|
||||
00000112 t send_servo_out(mavlink_channel_t)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000118 T GCS_MAVLINK::_queued_send()
|
||||
00000130 t set_wp_with_index(Location, int)
|
||||
00000134 T GCS_MAVLINK::send_message(unsigned char, unsigned long)
|
||||
0000013e t process_may()
|
||||
00000130 t startup_ground()
|
||||
00000130 t set_cmd_with_index(Location, int)
|
||||
00000136 W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000013e t calc_nav_roll()
|
||||
0000014e t verify_may()
|
||||
0000014e T GCS_MAVLINK::update()
|
||||
0000016a t process_must()
|
||||
0000016a t set_guided_WP()
|
||||
00000172 t navigate()
|
||||
0000019e t startup_ground()
|
||||
000001ae T init_home()
|
||||
0000013e t handle_process_condition_command()
|
||||
00000146 t send_vfr_hud(mavlink_channel_t)
|
||||
00000152 t verify_condition_command()
|
||||
0000015e t set_guided_WP()
|
||||
0000015e t handle_process_nav_cmd()
|
||||
0000016c t navigate()
|
||||
0000016e t send_attitude(mavlink_channel_t)
|
||||
00000174 t mavlink_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
0000017c t send_location(mavlink_channel_t)
|
||||
00000180 t send_extended_status1(mavlink_channel_t, unsigned int)
|
||||
00000188 T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000192 T init_home()
|
||||
0000019c t do_jump()
|
||||
000001a2 t mavlink_try_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
000001a2 t set_mode(unsigned char)
|
||||
000001a2 T GCS_MAVLINK::update()
|
||||
000001b2 t update_crosstrack()
|
||||
000001ca t mavlink_delay(unsigned long)
|
||||
000001ea T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000206 t set_next_WP(Location*)
|
||||
000001bc t set_next_WP(Location*)
|
||||
000001bc t send_nav_controller_output(mavlink_channel_t)
|
||||
000001da W RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)
|
||||
000001f4 t process_next_command()
|
||||
00000208 t calc_throttle()
|
||||
0000021c t set_mode(unsigned char)
|
||||
00000232 t verify_must()
|
||||
0000022a t send_gps_raw(mavlink_channel_t)
|
||||
00000230 t verify_nav_command()
|
||||
0000024c t update_loiter()
|
||||
000002d4 t handle_process_do_command()
|
||||
000002e4 t read_radio()
|
||||
00000320 t __static_initialization_and_destruction_0(int, int)
|
||||
0000033a W Parameters::~Parameters()
|
||||
000003c0 t process_next_command()
|
||||
000004b2 t mavlink_parse_char
|
||||
00000518 t init_ardupilot()
|
||||
00000831 b g
|
||||
0000090a W Parameters::Parameters()
|
||||
00001240 t mavlink_try_send_message(mavlink_channel_t, unsigned char, unsigned int)
|
||||
00001868 T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001aac T loop
|
||||
00000494 t init_ardupilot()
|
||||
00000920 W Parameters::Parameters()
|
||||
0000092b b g
|
||||
0000178a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001c82 T loop
|
||||
|
@ -3,59 +3,71 @@
|
||||
In file included from /root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:32:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
autogenerated:25: warning: 'bool print_log_menu()' declared 'static' but never defined
|
||||
autogenerated:28: warning: 'void get_log_boundaries(byte, int&, int&)' declared 'static' but never defined
|
||||
autogenerated:29: warning: 'int find_last_log_page(int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:745: warning: 'void Log_Write_Attitude(int, int, uint16_t)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:746: warning: 'void Log_Write_Control_Tuning()' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:747: warning: 'void Log_Write_Raw()' defined but not used
|
||||
autogenerated:40: warning: 'void Log_Read_Current()' declared 'static' but never defined
|
||||
autogenerated:41: warning: 'void Log_Read_Control_Tuning()' declared 'static' but never defined
|
||||
autogenerated:42: warning: 'void Log_Read_Nav_Tuning()' declared 'static' but never defined
|
||||
autogenerated:43: warning: 'void Log_Read_Performance()' declared 'static' but never defined
|
||||
autogenerated:44: warning: 'void Log_Read_Cmd()' declared 'static' but never defined
|
||||
autogenerated:45: warning: 'void Log_Read_Startup()' declared 'static' but never defined
|
||||
autogenerated:46: warning: 'void Log_Read_Attitude()' declared 'static' but never defined
|
||||
autogenerated:47: warning: 'void Log_Read_Mode()' declared 'static' but never defined
|
||||
autogenerated:48: warning: 'void Log_Read_GPS()' declared 'static' but never defined
|
||||
autogenerated:49: warning: 'void Log_Read_Raw()' declared 'static' but never defined
|
||||
autogenerated:50: warning: 'void Log_Read(int, int)' declared 'static' but never defined
|
||||
autogenerated:63: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
autogenerated:64: warning: 'void recalc_climb_rate()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void print_climb_debug_info()' declared 'static' but never defined
|
||||
autogenerated:126: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
autogenerated:149: warning: 'void init_barometer()' declared 'static' but never defined
|
||||
autogenerated:150: warning: 'long int read_barometer()' declared 'static' but never defined
|
||||
autogenerated:152: warning: 'void zero_airspeed()' declared 'static' but never defined
|
||||
autogenerated:154: warning: 'void report_batt_monitor()' declared 'static' but never defined
|
||||
autogenerated:155: warning: 'void report_radio()' declared 'static' but never defined
|
||||
autogenerated:156: warning: 'void report_gains()' declared 'static' but never defined
|
||||
autogenerated:157: warning: 'void report_xtrack()' declared 'static' but never defined
|
||||
autogenerated:158: warning: 'void report_throttle()' declared 'static' but never defined
|
||||
autogenerated:159: warning: 'void report_imu()' declared 'static' but never defined
|
||||
autogenerated:160: warning: 'void report_compass()' declared 'static' but never defined
|
||||
autogenerated:161: warning: 'void report_flight_modes()' declared 'static' but never defined
|
||||
autogenerated:162: warning: 'void print_PID(PID*)' declared 'static' but never defined
|
||||
autogenerated:163: warning: 'void print_radio_values()' declared 'static' but never defined
|
||||
autogenerated:164: warning: 'void print_switch(byte, byte)' declared 'static' but never defined
|
||||
autogenerated:165: warning: 'void print_done()' declared 'static' but never defined
|
||||
autogenerated:166: warning: 'void print_blanks(int)' declared 'static' but never defined
|
||||
autogenerated:167: warning: 'void print_divider()' declared 'static' but never defined
|
||||
autogenerated:168: warning: 'int8_t radio_input_switch()' declared 'static' but never defined
|
||||
autogenerated:169: warning: 'void zero_eeprom()' declared 'static' but never defined
|
||||
autogenerated:170: warning: 'void print_enabled(bool)' declared 'static' but never defined
|
||||
autogenerated:171: warning: 'void print_accel_offsets()' declared 'static' but never defined
|
||||
autogenerated:172: warning: 'void print_gyro_offsets()' declared 'static' but never defined
|
||||
autogenerated:183: warning: 'void print_hit_enter()' declared 'static' but never defined
|
||||
autogenerated:184: warning: 'void test_wp_print(Location*, byte)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:210: warning: 'comma' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:212: warning: 'flight_mode_strings' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:317: warning: 'airspeed_raw' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:318: warning: 'airspeed_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:322: warning: 'abs_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:742: warning: 'int8_t process_logs(uint8_t, const Menu::arg*)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde: In function 'bool mavlink_try_send_message(mavlink_channel_t, ap_message, uint16_t)':
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:502: warning: enumeration value 'MSG_RAW_IMU1' not handled in switch
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:502: warning: enumeration value 'MSG_RAW_IMU2' not handled in switch
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:502: warning: enumeration value 'MSG_RAW_IMU3' not handled in switch
|
||||
autogenerated: At global scope:
|
||||
autogenerated:34: warning: 'void send_raw_imu1(mavlink_channel_t)' declared 'static' but never defined
|
||||
autogenerated:35: warning: 'void send_raw_imu2(mavlink_channel_t)' declared 'static' but never defined
|
||||
autogenerated:36: warning: 'void send_raw_imu3(mavlink_channel_t)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/GCS_Mavlink.pde:2057: warning: 'void gcs_send_text(gcs_severity, const char*)' defined but not used
|
||||
autogenerated:49: warning: 'bool print_log_menu()' declared 'static' but never defined
|
||||
autogenerated:52: warning: 'void get_log_boundaries(byte, int&, int&)' declared 'static' but never defined
|
||||
autogenerated:53: warning: 'int find_last_log_page(int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:749: warning: 'void Log_Write_Attitude(int, int, uint16_t)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:750: warning: 'void Log_Write_Control_Tuning()' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:751: warning: 'void Log_Write_Raw()' defined but not used
|
||||
autogenerated:64: warning: 'void Log_Read_Current()' declared 'static' but never defined
|
||||
autogenerated:65: warning: 'void Log_Read_Control_Tuning()' declared 'static' but never defined
|
||||
autogenerated:66: warning: 'void Log_Read_Nav_Tuning()' declared 'static' but never defined
|
||||
autogenerated:67: warning: 'void Log_Read_Performance()' declared 'static' but never defined
|
||||
autogenerated:68: warning: 'void Log_Read_Cmd()' declared 'static' but never defined
|
||||
autogenerated:69: warning: 'void Log_Read_Startup()' declared 'static' but never defined
|
||||
autogenerated:70: warning: 'void Log_Read_Attitude()' declared 'static' but never defined
|
||||
autogenerated:71: warning: 'void Log_Read_Mode()' declared 'static' but never defined
|
||||
autogenerated:72: warning: 'void Log_Read_GPS()' declared 'static' but never defined
|
||||
autogenerated:73: warning: 'void Log_Read_Raw()' declared 'static' but never defined
|
||||
autogenerated:74: warning: 'void Log_Read(int, int)' declared 'static' but never defined
|
||||
autogenerated:87: warning: 'void add_altitude_data(long unsigned int, long int)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/commands.pde:128: warning: 'void increment_cmd_index()' defined but not used
|
||||
autogenerated:144: warning: 'void low_battery_event()' declared 'static' but never defined
|
||||
autogenerated:164: warning: 'void init_barometer()' declared 'static' but never defined
|
||||
autogenerated:165: warning: 'long int read_barometer()' declared 'static' but never defined
|
||||
autogenerated:166: warning: 'void read_airspeed()' declared 'static' but never defined
|
||||
autogenerated:167: warning: 'void zero_airspeed()' declared 'static' but never defined
|
||||
autogenerated:169: warning: 'void report_batt_monitor()' declared 'static' but never defined
|
||||
autogenerated:170: warning: 'void report_radio()' declared 'static' but never defined
|
||||
autogenerated:171: warning: 'void report_gains()' declared 'static' but never defined
|
||||
autogenerated:172: warning: 'void report_xtrack()' declared 'static' but never defined
|
||||
autogenerated:173: warning: 'void report_throttle()' declared 'static' but never defined
|
||||
autogenerated:174: warning: 'void report_imu()' declared 'static' but never defined
|
||||
autogenerated:175: warning: 'void report_compass()' declared 'static' but never defined
|
||||
autogenerated:176: warning: 'void report_flight_modes()' declared 'static' but never defined
|
||||
autogenerated:177: warning: 'void print_PID(PID*)' declared 'static' but never defined
|
||||
autogenerated:178: warning: 'void print_radio_values()' declared 'static' but never defined
|
||||
autogenerated:179: warning: 'void print_switch(byte, byte)' declared 'static' but never defined
|
||||
autogenerated:180: warning: 'void print_done()' declared 'static' but never defined
|
||||
autogenerated:181: warning: 'void print_blanks(int)' declared 'static' but never defined
|
||||
autogenerated:182: warning: 'void print_divider()' declared 'static' but never defined
|
||||
autogenerated:183: warning: 'int8_t radio_input_switch()' declared 'static' but never defined
|
||||
autogenerated:184: warning: 'void zero_eeprom()' declared 'static' but never defined
|
||||
autogenerated:185: warning: 'void print_enabled(bool)' declared 'static' but never defined
|
||||
autogenerated:186: warning: 'void print_accel_offsets()' declared 'static' but never defined
|
||||
autogenerated:187: warning: 'void print_gyro_offsets()' declared 'static' but never defined
|
||||
autogenerated:188: warning: 'void run_cli()' declared 'static' but never defined
|
||||
autogenerated:198: warning: 'void print_hit_enter()' declared 'static' but never defined
|
||||
autogenerated:199: warning: 'void test_wp_print(Location*, byte)' declared 'static' but never defined
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:194: warning: 'comma' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:196: warning: 'flight_mode_strings' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:270: warning: 'command_index' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:304: warning: 'airspeed_raw' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:305: warning: 'airspeed_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/ArduPlane.pde:309: warning: 'abs_pressure' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/Log.pde:746: warning: 'int8_t process_logs(uint8_t, const Menu::arg*)' defined but not used
|
||||
/root/apm/ardupilot-mega/ArduPlane/planner.pde:19: warning: 'int8_t planner_mode(uint8_t, const Menu::arg*)' defined but not used
|
||||
%% libraries/APM_BMP085/APM_BMP085.o
|
||||
%% libraries/APM_BMP085/APM_BMP085_hil.o
|
||||
%% libraries/APM_RC/APM_RC.o
|
||||
%% libraries/AP_ADC/AP_ADC_ADS7844.o
|
||||
%% libraries/AP_ADC/AP_ADC.o
|
||||
@ -83,11 +95,17 @@ autogenerated:184: warning: 'void test_wp_print(Location*, byte)' declared 'stat
|
||||
%% libraries/AP_GPS/AP_GPS_UBLOX.o
|
||||
%% libraries/AP_GPS/GPS.o
|
||||
%% libraries/AP_IMU/AP_IMU_Oilpan.o
|
||||
%% libraries/AP_Mount/AP_Mount.o
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::control_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:182: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp: In member function 'void AP_Mount::status_msg(mavlink_message_t*)':
|
||||
/root/apm/ardupilot-mega/libraries/AP_Mount/AP_Mount.cpp:226: warning: enumeration value 'MAV_MOUNT_MODE_ENUM_END' not handled in switch
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_MaxsonarXL.o
|
||||
%% libraries/AP_RangeFinder/AP_RangeFinder_SharpGP2Y.o
|
||||
%% libraries/AP_RangeFinder/RangeFinder.o
|
||||
%% libraries/AP_Relay/AP_Relay.o
|
||||
%% libraries/DataFlash/DataFlash.o
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:35:
|
||||
In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp:36:
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:25:1: warning: "SPI_CLOCK_DIV64" redefined
|
||||
/usr/local/share/arduino/libraries/SPI/SPI.h:20:1: warning: this is the location of the previous definition
|
||||
%% libraries/FastSerial/BetterStream.o
|
||||
@ -96,6 +114,7 @@ In file included from /root/apm/ardupilot-mega/libraries/DataFlash/DataFlash.cpp
|
||||
%% libraries/GCS_MAVLink/GCS_MAVLink.o
|
||||
%% libraries/ModeFilter/ModeFilter.o
|
||||
%% libraries/PID/PID.o
|
||||
%% libraries/RC_Channel/RC_Channel_aux.o
|
||||
%% libraries/RC_Channel/RC_Channel.o
|
||||
%% libraries/memcheck/memcheck.o
|
||||
%% libraries/FastSerial/ftoa_engine.o
|
||||
|
@ -3,20 +3,21 @@
|
||||
00000001 b home_is_set
|
||||
00000001 b ch3_failsafe
|
||||
00000001 b land_complete
|
||||
00000001 b command_may_ID
|
||||
00000001 b command_must_ID
|
||||
00000001 b mavlink_active
|
||||
00000001 b nav_command_ID
|
||||
00000001 b failsafeCounter
|
||||
00000001 b counter_one_herz
|
||||
00000001 b in_mavlink_delay
|
||||
00000001 b slow_loopCounter
|
||||
00000001 d takeoff_complete
|
||||
00000001 b command_may_index
|
||||
00000001 b command_must_index
|
||||
00000001 b nav_command_index
|
||||
00000001 b delta_ms_fast_loop
|
||||
00000001 d ground_start_count
|
||||
00000001 b medium_loopCounter
|
||||
00000001 b non_nav_command_ID
|
||||
00000001 b rc_override_active
|
||||
00000001 b delta_ms_medium_loop
|
||||
00000001 b non_nav_command_index
|
||||
00000001 b superslow_loopCounter
|
||||
00000001 b event_id
|
||||
00000001 b GPS_light
|
||||
@ -24,11 +25,9 @@
|
||||
00000001 D control_mode
|
||||
00000001 B hindex
|
||||
00000001 B inverted_flight
|
||||
00000001 B mavdelay
|
||||
00000001 B n
|
||||
00000001 B oldSwitchPosition
|
||||
00000002 T mavlink_acknowledge(mavlink_channel_t, unsigned char, unsigned char, unsigned char)
|
||||
00000002 b climb_rate
|
||||
00000001 B relay
|
||||
00000002 b loiter_sum
|
||||
00000002 b event_delay
|
||||
00000002 b event_value
|
||||
@ -58,11 +57,11 @@
|
||||
00000002 W AP_IMU_Shim::init_accel(void (*)(unsigned long))
|
||||
00000002 W AP_IMU_Shim::init(IMU::Start_style, void (*)(unsigned long))
|
||||
00000002 W AP_IMU_Shim::init_gyro(void (*)(unsigned long))
|
||||
00000002 T GCS_MAVLINK::acknowledge(unsigned char, unsigned char, unsigned char)
|
||||
00000002 d throttle_slew_limit()::last
|
||||
00000002 V PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)::__c
|
||||
00000002 V PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)::__c
|
||||
00000002 V PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)::__c
|
||||
00000003 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 b event_timer
|
||||
00000004 d hold_course
|
||||
00000004 b loiter_time
|
||||
@ -71,6 +70,7 @@
|
||||
00000004 b wp_distance
|
||||
00000004 b current_amps
|
||||
00000004 b energy_error
|
||||
00000004 b airspeed_fbwB
|
||||
00000004 b bearing_error
|
||||
00000004 b current_total
|
||||
00000004 b nav_loopTimer
|
||||
@ -106,8 +106,6 @@
|
||||
00000004 b nav_roll
|
||||
00000004 b nav_pitch
|
||||
00000004 b mavlink_delay(unsigned long)::last_1hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_3hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_10hz
|
||||
00000004 b mavlink_delay(unsigned long)::last_50hz
|
||||
00000004 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
00000004 V RC_Channel::RC_Channel(unsigned int, prog_char_t const*)::__c
|
||||
@ -135,7 +133,6 @@
|
||||
00000007 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000007 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000008 r __menu_name__planner_menu
|
||||
00000008 W AP_IMU_Shim::update()
|
||||
00000008 V Parameters::Parameters()::__c
|
||||
00000008 V Parameters::Parameters()::__c
|
||||
00000008 V Parameters::Parameters()::__c
|
||||
@ -149,12 +146,13 @@
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 V Parameters::Parameters()::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 r GCS_MAVLINK::GCS_MAVLINK(unsigned int)::__c
|
||||
00000009 V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a r init_home()::__c
|
||||
0000000a r verify_nav_wp()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
@ -162,18 +160,17 @@
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V Parameters::Parameters()::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a V RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)::__c
|
||||
0000000a T setup
|
||||
0000000b r control_failsafe(unsigned int)::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000b V Parameters::Parameters()::__c
|
||||
0000000c T GCS_MAVLINK::send_text(unsigned char, char const*)
|
||||
0000000c T GCS_MAVLINK::send_text(gcs_severity, char const*)
|
||||
0000000c V vtable for AP_IMU_Shim
|
||||
0000000c V vtable for IMU
|
||||
0000000c r control_failsafe(unsigned int)::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
0000000c V Parameters::Parameters()::__c
|
||||
@ -182,6 +179,9 @@
|
||||
0000000d r init_home()::__c
|
||||
0000000d r verify_RTL()::__c
|
||||
0000000d r demo_servos(unsigned char)::__c
|
||||
0000000d r control_failsafe(unsigned int)::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
0000000d V Parameters::Parameters()::__c
|
||||
@ -202,6 +202,7 @@
|
||||
0000000d B sonar_mode_filter
|
||||
0000000e t global destructors keyed to Serial
|
||||
0000000e t global constructors keyed to Serial
|
||||
0000000e t send_statustext(mavlink_channel_t)
|
||||
0000000e V vtable for AP_Float16
|
||||
0000000e V vtable for AP_VarS<Matrix3<float> >
|
||||
0000000e V vtable for AP_VarS<Vector3<float> >
|
||||
@ -209,7 +210,7 @@
|
||||
0000000e V vtable for AP_VarT<float>
|
||||
0000000e V vtable for AP_VarT<int>
|
||||
0000000e V vtable for AP_VarT<long>
|
||||
0000000e r process_may()::__c
|
||||
0000000e r control_failsafe(unsigned int)::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
@ -230,12 +231,13 @@
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000e V Parameters::Parameters()::__c
|
||||
0000000f b current_loc
|
||||
0000000f b next_command
|
||||
0000000f b next_nav_command
|
||||
0000000f b next_nonnav_command
|
||||
0000000f b home
|
||||
0000000f b next_WP
|
||||
0000000f b prev_WP
|
||||
0000000f b guided_WP
|
||||
0000000f r failsafe_short_on_event()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
@ -243,15 +245,16 @@
|
||||
0000000f V Parameters::Parameters()::__c
|
||||
00000010 b rc_override
|
||||
00000010 r planner_menu_commands
|
||||
00000010 T GCS_MAVLINK::send_message(ap_message)
|
||||
00000010 W AP_VarT<float>::cast_to_float() const
|
||||
00000010 W AP_VarT<long>::cast_to_float() const
|
||||
00000010 t mavlink_get_channel_status
|
||||
00000011 r set_next_WP(Location*)::__c
|
||||
00000011 r startup_ground()::__c
|
||||
00000011 r load_next_command_from_EEPROM()::__c
|
||||
00000011 r process_next_command()::__c
|
||||
00000011 r failsafe_short_on_event()::__c
|
||||
00000012 B Serial
|
||||
00000012 B Serial1
|
||||
00000012 B Serial3
|
||||
00000012 t gcs_update()
|
||||
00000012 W AP_Float16::~AP_Float16()
|
||||
00000012 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
00000012 W AP_VarS<Vector3<float> >::~AP_VarS()
|
||||
@ -260,34 +263,39 @@
|
||||
00000012 W AP_VarT<int>::~AP_VarT()
|
||||
00000012 W AP_VarT<long>::~AP_VarT()
|
||||
00000012 W AP_VarT<signed char>::serialize(void*, unsigned int) const
|
||||
00000012 r handle_no_commands()::__c
|
||||
00000012 r GCS_MAVLINK::handleMessage(__mavlink_message*)::__c
|
||||
00000012 B adc
|
||||
00000014 W AP_VarT<signed char>::unserialize(void*, unsigned int)
|
||||
00000014 W AP_VarT<signed char>::cast_to_float() const
|
||||
00000014 W AP_VarT<int>::cast_to_float() const
|
||||
00000014 r set_guided_WP()::__c
|
||||
00000015 r map_baudrate(signed char, unsigned long)::__c
|
||||
00000015 r verify_nav_wp()::__c
|
||||
00000015 r init_ardupilot()::__c
|
||||
00000015 r GCS_MAVLINK::handleMessage(__mavlink_message*)::__c
|
||||
00000016 r GCS_MAVLINK::update()::__c
|
||||
00000016 B adc
|
||||
00000016 B sonar
|
||||
00000018 W AP_VarT<int>::serialize(void*, unsigned int) const
|
||||
00000018 b mavlink_get_channel_status::m_mavlink_status
|
||||
00000018 r process_must()::__c
|
||||
00000019 r failsafe_long_on_event()::__c
|
||||
00000019 r GCS_MAVLINK::update()::__c
|
||||
00000019 r handle_process_nav_cmd()::__c
|
||||
00000019 r handle_process_do_command()::__c
|
||||
00000019 r handle_process_condition_command()::__c
|
||||
00000019 r do_jump()::__c
|
||||
0000001a t startup_IMU_ground()
|
||||
0000001a r reset_control_switch()::__c
|
||||
0000001a r failsafe_short_on_event()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001a r do_jump()::__c
|
||||
0000001b r failsafe_short_off_event()::__c
|
||||
0000001c W AP_VarS<Matrix3<float> >::unserialize(void*, unsigned int)
|
||||
0000001c W AP_VarS<Vector3<float> >::unserialize(void*, unsigned int)
|
||||
0000001c W AP_VarT<int>::unserialize(void*, unsigned int)
|
||||
0000001c W AP_VarS<Matrix3<float> >::serialize(void*, unsigned int) const
|
||||
0000001c W AP_VarS<Vector3<float> >::serialize(void*, unsigned int) const
|
||||
0000001e t failsafe_short_off_event()
|
||||
0000001e r startup_ground()::__c
|
||||
00000020 t gcs_send_message(ap_message)
|
||||
00000020 t byte_swap_4
|
||||
00000021 r verify_loiter_time()::__c
|
||||
00000021 r process_next_command()::__c
|
||||
00000022 t failsafe_short_off_event()
|
||||
00000022 t reset_I()
|
||||
00000022 W AP_Float16::~AP_Float16()
|
||||
00000022 W AP_VarS<Matrix3<float> >::~AP_VarS()
|
||||
@ -296,117 +304,134 @@
|
||||
00000022 W AP_VarT<float>::~AP_VarT()
|
||||
00000022 W AP_VarT<int>::~AP_VarT()
|
||||
00000022 W AP_VarT<long>::~AP_VarT()
|
||||
00000022 r increment_WP_index()::__c
|
||||
00000022 r verify_loiter_time()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000022 r process_next_command()::__c
|
||||
00000023 r verify_loiter_turns()::__c
|
||||
00000023 r navigate()::__c
|
||||
00000024 r verify_loiter_turns()::__c
|
||||
00000026 b mavlink_queue
|
||||
00000026 r init_ardupilot()::__c
|
||||
00000027 r change_command(unsigned char)::__c
|
||||
00000027 r init_ardupilot()::__c
|
||||
00000028 t increment_WP_index()
|
||||
00000028 t demo_servos(unsigned char)
|
||||
00000028 W AP_VarT<float>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<long>::unserialize(void*, unsigned int)
|
||||
00000028 W AP_VarT<float>::serialize(void*, unsigned int) const
|
||||
00000028 W AP_VarT<long>::serialize(void*, unsigned int) const
|
||||
00000028 B imu
|
||||
0000002a t demo_servos(unsigned char)
|
||||
0000002b r verify_must()::__c
|
||||
0000002a r verify_nav_command()::__c
|
||||
0000002a t _mav_put_int8_t_array
|
||||
0000002b r change_command(unsigned char)::__c
|
||||
0000002e t reset_control_switch()
|
||||
0000002e t send_rate(unsigned int, unsigned int)
|
||||
0000002e t gcs_send_text_P(gcs_severity, prog_char_t const*)
|
||||
0000002e t gcs_data_stream_send(unsigned int, unsigned int)
|
||||
0000002e W AP_Var_group::AP_Var_group(unsigned int, prog_char_t const*, unsigned char)
|
||||
0000002e r verify_nav_wp()::__c
|
||||
00000030 r verify_may()::__c
|
||||
00000030 t send_heartbeat(mavlink_channel_t)
|
||||
00000030 B imu
|
||||
00000032 T GCS_MAVLINK::init(FastSerial*)
|
||||
00000032 r init_ardupilot()::__c
|
||||
00000033 b pending_status
|
||||
00000034 t _MAV_RETURN_float
|
||||
00000034 W AP_Float16::serialize(void*, unsigned int) const
|
||||
00000034 t _mav_put_int8_t_array
|
||||
00000034 t mavlink_msg_statustext_send
|
||||
00000035 r verify_condition_command()::__c
|
||||
00000038 t send_current_waypoint(mavlink_channel_t)
|
||||
00000039 r init_ardupilot()::__c
|
||||
0000003a t verify_loiter_turns()
|
||||
0000003a W PID::~PID()
|
||||
0000003a B g_gps_driver
|
||||
0000003c t verify_loiter_turns()
|
||||
0000003c W RC_Channel::~RC_Channel()
|
||||
0000003e t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(unsigned char, prog_char_t const*)
|
||||
0000003c t verify_RTL()
|
||||
0000003e T GCS_MAVLINK::send_text(gcs_severity, prog_char_t const*)
|
||||
0000003e W AP_VarT<signed char>::AP_VarT(signed char, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000040 W AP_Float16::unserialize(void*, unsigned int)
|
||||
00000040 t byte_swap_8
|
||||
00000040 t crc_accumulate
|
||||
00000040 B history
|
||||
00000044 W AP_VarT<int>::AP_VarT(int, unsigned int, prog_char_t const*, unsigned char)
|
||||
00000046 W RC_Channel::~RC_Channel()
|
||||
00000048 t failsafe_long_on_event()
|
||||
0000004a t send_meminfo(mavlink_channel_t)
|
||||
0000004a W AP_VarT<int>::AP_VarT(AP_Var_group*, unsigned int, int, prog_char_t const*, unsigned char)
|
||||
0000004e T mavlink_send_text(mavlink_channel_t, unsigned char, char const*)
|
||||
00000050 t failsafe_long_on_event()
|
||||
00000050 b mavlink_queue
|
||||
00000050 T GCS_MAVLINK::_find_parameter(unsigned int)
|
||||
00000056 t change_command(unsigned char)
|
||||
00000052 W AP_IMU_Shim::update()
|
||||
00000056 T GCS_MAVLINK::queued_waypoint_send()
|
||||
00000057 B dcm
|
||||
0000005a W AP_VarT<float>::AP_VarT(float, unsigned int, prog_char_t const*, unsigned char)
|
||||
0000005e T GCS_MAVLINK::_count_parameters()
|
||||
00000060 W AP_Float16::AP_Float16(AP_Var_group*, unsigned int, float, prog_char_t const*, unsigned char)
|
||||
00000060 t _mavlink_send_uart
|
||||
00000064 t mavlink_msg_param_value_send
|
||||
00000064 t mavlink_msg_param_value_send(mavlink_channel_t, char const*, float, unsigned char, unsigned int, unsigned int)
|
||||
00000064 W RC_Channel_aux::~RC_Channel_aux()
|
||||
0000006a T mavlink_send_text(mavlink_channel_t, gcs_severity, char const*)
|
||||
0000006a W GCS_MAVLINK::~GCS_MAVLINK()
|
||||
0000006e t do_RTL()
|
||||
00000070 r init_ardupilot()::__c
|
||||
00000074 t verify_loiter_time()
|
||||
0000007c t failsafe_short_on_event()
|
||||
00000080 t do_RTL()
|
||||
00000072 t verify_loiter_time()
|
||||
00000078 t gcs_send_text_fmt(prog_char_t const*, ...)
|
||||
0000007c t send_gps_status(mavlink_channel_t)
|
||||
00000080 T __vector_25
|
||||
00000080 T __vector_36
|
||||
00000080 T __vector_54
|
||||
00000084 t change_command(unsigned char)
|
||||
0000008e t failsafe_short_on_event()
|
||||
00000090 t handle_no_commands()
|
||||
00000092 T GCS_MAVLINK::queued_param_send()
|
||||
00000096 t map_baudrate(signed char, unsigned long)
|
||||
0000009b B gcs0
|
||||
0000009b B gcs3
|
||||
0000009c t update_servo_switches()
|
||||
0000009d B gcs
|
||||
0000009d B hil
|
||||
000000a2 t verify_nav_wp()
|
||||
000000a4 T __vector_26
|
||||
000000a4 T __vector_37
|
||||
000000a4 T __vector_55
|
||||
000000a6 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000ab B compass
|
||||
000000b4 t planner_gcs(unsigned char, Menu::arg const*)
|
||||
000000be t update_events()
|
||||
000000c0 t calc_bearing_error()
|
||||
000000c4 t update_events()
|
||||
000000c4 t load_next_command_from_EEPROM()
|
||||
000000ca t send_radio_out(mavlink_channel_t)
|
||||
000000ca t control_failsafe(unsigned int)
|
||||
000000cc t read_control_switch()
|
||||
000000ce t send_radio_in(mavlink_channel_t)
|
||||
000000ce W PID::PID(unsigned int, prog_char_t const*, float const&, float const&, float const&, int const&)
|
||||
000000d0 t get_bearing(Location*, Location*)
|
||||
000000d8 t verify_nav_wp()
|
||||
000000e0 b mavlink_parse_char::m_mavlink_message
|
||||
000000f0 t throttle_slew_limit()
|
||||
000000f4 t _mav_finalize_message_chan_send
|
||||
00000106 t calc_nav_pitch()
|
||||
00000106 t get_wp_with_index(int)
|
||||
0000010c W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000010a t mavlink_delay(unsigned long)
|
||||
00000110 t get_cmd_with_index(int)
|
||||
00000112 t get_distance(Location*, Location*)
|
||||
00000112 t send_servo_out(mavlink_channel_t)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000112 T GCS_MAVLINK::GCS_MAVLINK(unsigned int)
|
||||
00000118 T GCS_MAVLINK::_queued_send()
|
||||
00000130 t set_wp_with_index(Location, int)
|
||||
00000134 T GCS_MAVLINK::send_message(unsigned char, unsigned long)
|
||||
0000013e t process_may()
|
||||
00000130 t startup_ground()
|
||||
00000130 t set_cmd_with_index(Location, int)
|
||||
00000136 W RC_Channel::RC_Channel(unsigned int, prog_char_t const*)
|
||||
0000013e t calc_nav_roll()
|
||||
0000014e t verify_may()
|
||||
0000014e T GCS_MAVLINK::update()
|
||||
0000016a t process_must()
|
||||
0000016a t set_guided_WP()
|
||||
00000172 t navigate()
|
||||
0000019e t startup_ground()
|
||||
000001ae T init_home()
|
||||
0000013e t handle_process_condition_command()
|
||||
00000146 t send_vfr_hud(mavlink_channel_t)
|
||||
00000152 t verify_condition_command()
|
||||
0000015e t set_guided_WP()
|
||||
0000015e t handle_process_nav_cmd()
|
||||
0000016c t navigate()
|
||||
0000016e t send_attitude(mavlink_channel_t)
|
||||
00000174 t mavlink_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
0000017c t send_location(mavlink_channel_t)
|
||||
00000180 t send_extended_status1(mavlink_channel_t, unsigned int)
|
||||
00000188 T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000190 T init_home()
|
||||
0000019a t do_jump()
|
||||
000001a2 t mavlink_try_send_message(mavlink_channel_t, ap_message, unsigned int)
|
||||
000001a2 t set_mode(unsigned char)
|
||||
000001a2 T GCS_MAVLINK::update()
|
||||
000001b2 t update_crosstrack()
|
||||
000001ca t mavlink_delay(unsigned long)
|
||||
000001ea T GCS_MAVLINK::data_stream_send(unsigned int, unsigned int)
|
||||
00000206 t set_next_WP(Location*)
|
||||
000001bc t set_next_WP(Location*)
|
||||
000001bc t send_nav_controller_output(mavlink_channel_t)
|
||||
000001da W RC_Channel_aux::RC_Channel_aux(unsigned int, prog_char_t const*)
|
||||
000001f4 t process_next_command()
|
||||
00000208 t calc_throttle()
|
||||
0000021c t set_mode(unsigned char)
|
||||
00000232 t verify_must()
|
||||
0000022a t send_gps_raw(mavlink_channel_t)
|
||||
00000230 t verify_nav_command()
|
||||
0000024c t update_loiter()
|
||||
000002d4 t handle_process_do_command()
|
||||
000002e4 t read_radio()
|
||||
00000320 t __static_initialization_and_destruction_0(int, int)
|
||||
0000033a W Parameters::~Parameters()
|
||||
000003c0 t process_next_command()
|
||||
000004b2 t mavlink_parse_char
|
||||
00000518 t init_ardupilot()
|
||||
00000831 b g
|
||||
0000090a W Parameters::Parameters()
|
||||
00001240 t mavlink_try_send_message(mavlink_channel_t, unsigned char, unsigned int)
|
||||
00001868 T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001aac T loop
|
||||
00000492 t init_ardupilot()
|
||||
00000920 W Parameters::Parameters()
|
||||
0000092b b g
|
||||
0000178a T GCS_MAVLINK::handleMessage(__mavlink_message*)
|
||||
00001c82 T loop
|
||||
|
@ -3,14 +3,14 @@
|
||||
<Firmware>
|
||||
<url>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/AP-1280.hex</url>
|
||||
<url2560>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/AP-2560.hex</url2560>
|
||||
<name>ArduPlane V2.24 </name>
|
||||
<name>ArduPlane V2.251 </name>
|
||||
<desc></desc>
|
||||
<format_version>11</format_version>
|
||||
<format_version>12</format_version>
|
||||
</Firmware>
|
||||
<Firmware>
|
||||
<url>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/APHIL-1280.hex</url>
|
||||
<url2560>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/APHIL-2560.hex</url2560>
|
||||
<name>ArduPlane V2.24 HIL</name>
|
||||
<name>ArduPlane V2.251 HIL</name>
|
||||
<desc>
|
||||
#define FLIGHT_MODE_CHANNEL 8
|
||||
#define FLIGHT_MODE_1 AUTO
|
||||
@ -39,14 +39,14 @@
|
||||
#define AIRSPEED_CRUISE 25
|
||||
#define THROTTLE_FAILSAFE ENABLED
|
||||
</desc>
|
||||
<format_version>11</format_version>
|
||||
<format_version>12</format_version>
|
||||
</Firmware>
|
||||
<Firmware>
|
||||
<url>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/AP-trunk-1280.hex</url>
|
||||
<url2560>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/AP-trunk-2560.hex</url2560>
|
||||
<name>ArduPlane V2.24 APM trunk</name>
|
||||
<name>ArduPlane V2.251 APM trunk</name>
|
||||
<desc></desc>
|
||||
<format_version>11</format_version>
|
||||
<format_version>12</format_version>
|
||||
</Firmware>
|
||||
<Firmware>
|
||||
<url>http://ardupilot-mega.googlecode.com/git/Tools/ArdupilotMegaPlanner/Firmware/AC2-Quad-1280.hex</url>
|
||||
|
@ -1,545 +1,29 @@
|
||||
From https://code.google.com/p/ardupilot-mega
|
||||
b0bfa54..8d3fb35 APM_Camera -> origin/APM_Camera
|
||||
cd1bcd6..34c9a18 master -> origin/master
|
||||
Updating cd1bcd6..34c9a18
|
||||
66cc8dd..6f4e7ec master -> origin/master
|
||||
Updating 66cc8dd..6f4e7ec
|
||||
Fast-forward
|
||||
.gitignore | 4 +-
|
||||
ArduBoat/ArduBoat.cpp | 7 +-
|
||||
ArduBoat/ArduBoat.pde | 2 +-
|
||||
ArduBoat/BoatGeneric.h | 39 +-
|
||||
ArduBoat/ControllerBoat.h | 157 +-
|
||||
ArduCopter/APM_Config.h | 7 +-
|
||||
ArduCopter/ArduCopter.pde | 64 +-
|
||||
ArduCopter/Attitude.pde | 54 +-
|
||||
ArduCopter/CMakeLists.txt | 165 -
|
||||
ArduCopter/GCS.h | 7 +-
|
||||
ArduCopter/GCS_Mavlink.pde | 23 +-
|
||||
ArduCopter/Log.pde | 261 +-
|
||||
ArduCopter/Parameters.h | 12 +-
|
||||
ArduCopter/config.h | 45 +-
|
||||
ArduCopter/control_modes.pde | 8 +-
|
||||
ArduCopter/defines.h | 1 +
|
||||
ArduCopter/heli.pde | 25 +
|
||||
ArduCopter/motors.pde | 4 +-
|
||||
ArduCopter/navigation.pde | 42 +-
|
||||
ArduCopter/radio.pde | 14 +-
|
||||
ArduCopter/system.pde | 36 +-
|
||||
ArduPlane/.gitignore | 1 -
|
||||
ArduPlane/ArduPlane.pde | 27 +-
|
||||
ArduPlane/CMakeLists.txt | 168 -
|
||||
ArduPlane/GCS.h | 7 +-
|
||||
ArduPlane/GCS_Mavlink.pde | 464 +++-
|
||||
ArduPlane/Log.pde | 10 +-
|
||||
ArduPlane/Mavlink_compat.h | 172 +
|
||||
ArduPlane/Parameters.h | 12 +-
|
||||
ArduPlane/commands.pde | 65 +-
|
||||
ArduPlane/commands_logic.pde | 152 +-
|
||||
ArduPlane/commands_process.pde | 183 +-
|
||||
ArduPlane/config.h | 5 +
|
||||
ArduPlane/defines.h | 3 +-
|
||||
ArduPlane/navigation.pde | 2 +-
|
||||
ArduPlane/system.pde | 21 +-
|
||||
ArduPlane/test.pde | 6 +-
|
||||
ArduRover/ArduRover.cpp | 6 +-
|
||||
ArduRover/ArduRover.pde | 1 +
|
||||
ArduRover/CarStampede.h | 31 +-
|
||||
ArduRover/ControllerCar.h | 158 +-
|
||||
ArduRover/ControllerTank.h | 176 +-
|
||||
ArduRover/TankGeneric.h | 16 +-
|
||||
CMakeLists.txt | 9 +-
|
||||
Tools/ArdupilotMegaPlanner/ArdupilotMega.csproj | 9 +
|
||||
Tools/ArdupilotMegaPlanner/Camera.Designer.cs | 421 +++
|
||||
Tools/ArdupilotMegaPlanner/Camera.cs | 139 +
|
||||
Tools/ArdupilotMegaPlanner/Camera.resx | 120 +
|
||||
Tools/ArdupilotMegaPlanner/CommsTCPSerial.cs | 12 +-
|
||||
Tools/ArdupilotMegaPlanner/CurrentState.cs | 81 +-
|
||||
.../GCSViews/Configuration.Designer.cs | 137 +-
|
||||
.../ArdupilotMegaPlanner/GCSViews/Configuration.cs | 47 +-
|
||||
.../GCSViews/Configuration.resx | 2088 +++++-------
|
||||
Tools/ArdupilotMegaPlanner/GCSViews/Firmware.cs | 12 +-
|
||||
.../GCSViews/FlightData.Designer.cs | 155 +-
|
||||
Tools/ArdupilotMegaPlanner/GCSViews/FlightData.cs | 164 +-
|
||||
.../ArdupilotMegaPlanner/GCSViews/FlightData.resx | 604 ++--
|
||||
.../ArdupilotMegaPlanner/GCSViews/FlightPlanner.cs | 4 +-
|
||||
Tools/ArdupilotMegaPlanner/GCSViews/Simulation.cs | 18 +-
|
||||
Tools/ArdupilotMegaPlanner/GCSViews/Terminal.cs | 7 +
|
||||
Tools/ArdupilotMegaPlanner/Joystick.cs | 50 +-
|
||||
.../ArdupilotMegaPlanner/JoystickSetup.Designer.cs | 276 ++-
|
||||
Tools/ArdupilotMegaPlanner/JoystickSetup.cs | 125 +-
|
||||
Tools/ArdupilotMegaPlanner/JoystickSetup.resx | 763 ++++-
|
||||
Tools/ArdupilotMegaPlanner/MAVLink.cs | 11 +-
|
||||
Tools/ArdupilotMegaPlanner/MainV2.cs | 87 +-
|
||||
Tools/ArdupilotMegaPlanner/MavlinkLog.cs | 9 +-
|
||||
Tools/ArdupilotMegaPlanner/Program.cs | 1 +
|
||||
ArduCopter/APM_Config.h | 2 +-
|
||||
ArduCopter/ArduCopter.pde | 18 ++-
|
||||
ArduCopter/commands.pde | 8 +-
|
||||
ArduCopter/commands_process.pde | 3 +-
|
||||
ArduCopter/motors_hexa.pde | 2 +-
|
||||
ArduCopter/motors_octa.pde | 2 +-
|
||||
ArduCopter/motors_octa_quad.pde | 2 +-
|
||||
ArduCopter/motors_y6.pde | 3 +-
|
||||
ArduPlane/ArduPlane.pde | 2 +-
|
||||
ArduPlane/Log.pde | 5 +-
|
||||
ArduPlane/commands_logic.pde | 13 ++-
|
||||
Tools/ArdupilotMegaPlanner/CurrentState.cs | 1 -
|
||||
Tools/ArdupilotMegaPlanner/GCSViews/FlightData.cs | 27 +++-
|
||||
.../ArdupilotMegaPlanner/GCSViews/FlightPlanner.cs | 149 +++++++++++++++++---
|
||||
Tools/ArdupilotMegaPlanner/HIL/QuadCopter.cs | 14 ++-
|
||||
.../Properties/AssemblyInfo.cs | 2 +-
|
||||
Tools/ArdupilotMegaPlanner/SerialOutput.cs | 13 +-
|
||||
Tools/ArdupilotMegaPlanner/Setup/Setup.cs | 4 +-
|
||||
Tools/ArdupilotMegaPlanner/Updater/Updater.csproj | 2 +-
|
||||
.../bin/Release/ArdupilotMegaPlanner.application | 2 +-
|
||||
.../bin/Release/ArdupilotMegaPlanner.exe | Bin 2194944 -> 2188288 bytes
|
||||
.../bin/Release/GCSViews/Configuration.resx | 2088 +++++-------
|
||||
.../bin/Release/GCSViews/FlightData.resx | 604 ++--
|
||||
.../bin/Release/JoystickSetup.resx | 763 ++++-
|
||||
.../bin/Release/ArdupilotMegaPlanner.exe | Bin 2194432 -> 2195456 bytes
|
||||
Tools/ArdupilotMegaPlanner/bin/Release/Updater.exe | Bin 8192 -> 8192 bytes
|
||||
Tools/ArdupilotMegaPlanner/bin/Release/resedit.exe | Bin 20480 -> 20480 bytes
|
||||
.../ru-RU/ArdupilotMegaPlanner.resources.dll | Bin 53248 -> 53248 bytes
|
||||
.../zh-Hans/ArdupilotMegaPlanner.resources.dll | Bin 380928 -> 380928 bytes
|
||||
Tools/scripts/format.sh | 13 +
|
||||
apo/ControllerPlane.h | 329 +-
|
||||
apo/ControllerQuad.h | 414 +--
|
||||
apo/PlaneEasystar.h | 18 +-
|
||||
apo/QuadArducopter.h | 17 +-
|
||||
apo/apo.pde | 5 +-
|
||||
libraries/APM_BMP085/APM_BMP085.h | 2 +-
|
||||
libraries/APM_PI/APM_PI.cpp | 8 +-
|
||||
libraries/APO/APO.h | 6 +-
|
||||
libraries/APO/APO_DefaultSetup.h | 321 +-
|
||||
libraries/APO/AP_ArmingMechanism.cpp | 14 +-
|
||||
libraries/APO/AP_ArmingMechanism.h | 10 +-
|
||||
libraries/APO/AP_Autopilot.cpp | 461 ++--
|
||||
libraries/APO/AP_Autopilot.h | 195 +-
|
||||
libraries/APO/AP_BatteryMonitor.h | 1 -
|
||||
libraries/APO/AP_CommLink.cpp | 1280 ++++----
|
||||
libraries/APO/AP_CommLink.h | 126 +-
|
||||
libraries/APO/AP_Controller.cpp | 111 +-
|
||||
libraries/APO/AP_Controller.h | 402 ++-
|
||||
libraries/APO/AP_Guide.cpp | 429 ++-
|
||||
libraries/APO/AP_Guide.h | 203 +-
|
||||
libraries/APO/AP_HardwareAbstractionLayer.cpp | 1 +
|
||||
libraries/APO/AP_HardwareAbstractionLayer.h | 258 +-
|
||||
libraries/APO/AP_MavlinkCommand.cpp | 304 +-
|
||||
libraries/APO/AP_MavlinkCommand.h | 654 ++--
|
||||
libraries/APO/AP_Navigator.cpp | 298 +-
|
||||
libraries/APO/AP_Navigator.h | 358 +-
|
||||
libraries/APO/AP_RcChannel.cpp | 125 +-
|
||||
libraries/APO/AP_RcChannel.h | 103 +-
|
||||
libraries/APO/AP_Var_keys.h | 21 +-
|
||||
libraries/APO/constants.h | 1 +
|
||||
libraries/APO/examples/MavlinkTest/MavlinkTest.pde | 64 +-
|
||||
libraries/APO/examples/ServoManual/ServoManual.pde | 144 +-
|
||||
libraries/APO/examples/ServoSweep/ServoSweep.pde | 184 +-
|
||||
libraries/AP_Common/AP_Common.h | 20 +-
|
||||
libraries/AP_Common/AP_Test.h | 4 +-
|
||||
libraries/AP_Common/AP_Var.cpp | 80 +-
|
||||
libraries/AP_Common/AP_Var.h | 12 +-
|
||||
libraries/AP_Common/c++.cpp | 22 +-
|
||||
libraries/AP_Common/examples/menu/menu.pde | 22 +-
|
||||
libraries/AP_Common/include/menu.h | 186 +-
|
||||
libraries/AP_Common/menu.cpp | 198 +-
|
||||
libraries/AP_DCM/AP_DCM_HIL.cpp | 12 +-
|
||||
libraries/AP_GPS/AP_GPS_406.cpp | 72 +-
|
||||
libraries/AP_GPS/AP_GPS_406.h | 8 +-
|
||||
libraries/AP_GPS/AP_GPS_Auto.cpp | 316 +-
|
||||
libraries/AP_GPS/AP_GPS_Auto.h | 58 +-
|
||||
libraries/AP_GPS/AP_GPS_HIL.cpp | 18 +-
|
||||
libraries/AP_GPS/AP_GPS_HIL.h | 10 +-
|
||||
libraries/AP_GPS/AP_GPS_IMU.cpp | 294 +-
|
||||
libraries/AP_GPS/AP_GPS_IMU.h | 68 +-
|
||||
libraries/AP_GPS/AP_GPS_MTK.cpp | 226 +-
|
||||
libraries/AP_GPS/AP_GPS_MTK.h | 74 +-
|
||||
libraries/AP_GPS/AP_GPS_MTK16.cpp | 240 +-
|
||||
libraries/AP_GPS/AP_GPS_MTK16.h | 78 +-
|
||||
libraries/AP_GPS/AP_GPS_NMEA.cpp | 528 ++--
|
||||
libraries/AP_GPS/AP_GPS_NMEA.h | 118 +-
|
||||
libraries/AP_GPS/AP_GPS_None.h | 8 +-
|
||||
libraries/AP_GPS/AP_GPS_SIRF.cpp | 280 +-
|
||||
libraries/AP_GPS/AP_GPS_SIRF.h | 130 +-
|
||||
libraries/AP_GPS/AP_GPS_Shim.h | 38 +-
|
||||
libraries/AP_GPS/AP_GPS_UBLOX.cpp | 292 +-
|
||||
libraries/AP_GPS/AP_GPS_UBLOX.h | 184 +-
|
||||
libraries/AP_GPS/GPS.cpp | 50 +-
|
||||
libraries/AP_GPS/GPS.h | 330 +-
|
||||
.../AP_GPS/examples/GPS_406_test/GPS_406_test.pde | 62 +-
|
||||
.../examples/GPS_AUTO_test/GPS_AUTO_test.pde | 42 +-
|
||||
.../AP_GPS/examples/GPS_MTK_test/GPS_MTK_test.pde | 60 +-
|
||||
.../examples/GPS_NMEA_test/GPS_NMEA_test.pde | 81 +-
|
||||
.../examples/GPS_UBLOX_test/GPS_UBLOX_test.pde | 60 +-
|
||||
libraries/Desktop/Desktop.mk | 2 +-
|
||||
libraries/Desktop/Makefile.desktop | 3 +
|
||||
libraries/GCS_MAVLink/GCS_MAVLink.cpp | 6 +-
|
||||
libraries/GCS_MAVLink/GCS_MAVLink.h | 18 +-
|
||||
.../include/ardupilotmega/ardupilotmega.h | 74 +-
|
||||
.../include/ardupilotmega/mavlink_msg_ap_adc.h | 254 ++
|
||||
.../ardupilotmega/mavlink_msg_digicam_configure.h | 364 ++
|
||||
.../ardupilotmega/mavlink_msg_digicam_control.h | 342 ++
|
||||
.../ardupilotmega/mavlink_msg_mount_configure.h | 254 ++
|
||||
.../ardupilotmega/mavlink_msg_mount_control.h | 254 ++
|
||||
.../ardupilotmega/mavlink_msg_mount_status.h | 232 ++
|
||||
.../GCS_MAVLink/include/ardupilotmega/testsuite.h | 340 ++
|
||||
.../GCS_MAVLink/include/ardupilotmega/version.h | 2 +-
|
||||
libraries/GCS_MAVLink/include/bittest.c | 39 -
|
||||
libraries/GCS_MAVLink/include/common/common.h | 52 +-
|
||||
.../mavlink_msg_attitude_controller_output.h | 169 -
|
||||
.../include/common/mavlink_msg_attitude_new.h | 268 --
|
||||
.../include/common/mavlink_msg_auth_key.h | 6 +-
|
||||
.../common/mavlink_msg_change_operator_control.h | 6 +-
|
||||
.../include/common/mavlink_msg_debug_vect.h | 6 +-
|
||||
.../include/common/mavlink_msg_full_state.h | 428 ---
|
||||
.../include/common/mavlink_msg_gps_status.h | 30 +-
|
||||
.../include/common/mavlink_msg_named_value_float.h | 6 +-
|
||||
.../include/common/mavlink_msg_named_value_int.h | 6 +-
|
||||
.../common/mavlink_msg_object_detection_event.h | 6 +-
|
||||
.../common/mavlink_msg_param_request_read.h | 6 +-
|
||||
.../include/common/mavlink_msg_param_set.h | 6 +-
|
||||
.../include/common/mavlink_msg_param_value.h | 6 +-
|
||||
.../mavlink_msg_position_controller_output.h | 169 -
|
||||
.../mavlink_msg_request_dynamic_gyro_calibration.h | 177 -
|
||||
.../mavlink_msg_request_static_calibration.h | 138 -
|
||||
.../common/mavlink_msg_set_roll_pitch_yaw.h | 184 -
|
||||
.../common/mavlink_msg_set_roll_pitch_yaw_speed.h | 184 -
|
||||
.../include/common/mavlink_msg_statustext.h | 6 +-
|
||||
.../mavlink_msg_waypoint_set_global_reference.h | 294 --
|
||||
libraries/GCS_MAVLink/include/common/testsuite.h | 30 +-
|
||||
libraries/GCS_MAVLink/include/common/version.h | 2 +-
|
||||
libraries/GCS_MAVLink/include/documentation.dox | 41 -
|
||||
libraries/GCS_MAVLink/include/mavlink_helpers.h | 8 +-
|
||||
libraries/GCS_MAVLink/include/minimal/mavlink.h | 11 -
|
||||
.../include/minimal/mavlink_msg_heartbeat.h | 132 -
|
||||
libraries/GCS_MAVLink/include/minimal/minimal.h | 45 -
|
||||
libraries/GCS_MAVLink/include/pixhawk/mavlink.h | 11 -
|
||||
.../include/pixhawk/mavlink_msg_attitude_control.h | 257 --
|
||||
.../include/pixhawk/mavlink_msg_aux_status.h | 204 -
|
||||
.../include/pixhawk/mavlink_msg_brief_feature.h | 249 --
|
||||
.../include/pixhawk/mavlink_msg_control_status.h | 203 -
|
||||
.../mavlink_msg_data_transmission_handshake.h | 174 -
|
||||
.../include/pixhawk/mavlink_msg_debug_vect.h | 156 -
|
||||
.../pixhawk/mavlink_msg_encapsulated_data.h | 124 -
|
||||
.../pixhawk/mavlink_msg_encapsulated_image.h | 76 -
|
||||
.../include/pixhawk/mavlink_msg_get_image_ack.h | 104 -
|
||||
.../include/pixhawk/mavlink_msg_image_available.h | 586 ---
|
||||
.../pixhawk/mavlink_msg_image_trigger_control.h | 101 -
|
||||
.../include/pixhawk/mavlink_msg_image_triggered.h | 352 --
|
||||
.../include/pixhawk/mavlink_msg_manual_control.h | 191 -
|
||||
.../include/pixhawk/mavlink_msg_marker.h | 236 --
|
||||
.../include/pixhawk/mavlink_msg_pattern_detected.h | 160 -
|
||||
.../pixhawk/mavlink_msg_point_of_interest.h | 241 --
|
||||
.../mavlink_msg_point_of_interest_connection.h | 307 --
|
||||
.../mavlink_msg_position_control_offset_set.h | 206 -
|
||||
.../mavlink_msg_position_control_setpoint.h | 192 -
|
||||
.../mavlink_msg_position_control_setpoint_set.h | 226 --
|
||||
.../include/pixhawk/mavlink_msg_raw_aux.h | 226 --
|
||||
.../pixhawk/mavlink_msg_request_data_stream.h | 118 -
|
||||
.../mavlink_msg_request_dynamic_gyro_calibration.h | 123 -
|
||||
.../mavlink_msg_request_static_calibration.h | 90 -
|
||||
.../include/pixhawk/mavlink_msg_set_altitude.h | 78 -
|
||||
.../include/pixhawk/mavlink_msg_set_cam_shutter.h | 197 -
|
||||
.../include/pixhawk/mavlink_msg_watchdog_command.h | 158 -
|
||||
.../pixhawk/mavlink_msg_watchdog_heartbeat.h | 124 -
|
||||
.../pixhawk/mavlink_msg_watchdog_process_info.h | 186 -
|
||||
.../pixhawk/mavlink_msg_watchdog_process_status.h | 200 -
|
||||
libraries/GCS_MAVLink/include/pixhawk/pixhawk.h | 79 -
|
||||
libraries/GCS_MAVLink/include/protocol.h | 37 +-
|
||||
libraries/GCS_MAVLink/include/slugs/mavlink.h | 11 -
|
||||
.../include/slugs/mavlink_msg_air_data.h | 148 -
|
||||
.../include/slugs/mavlink_msg_cpu_load.h | 138 -
|
||||
.../include/slugs/mavlink_msg_ctrl_srfc_pt.h | 121 -
|
||||
.../include/slugs/mavlink_msg_data_log.h | 216 --
|
||||
.../include/slugs/mavlink_msg_diagnostic.h | 210 --
|
||||
.../include/slugs/mavlink_msg_filtered_data.h | 216 --
|
||||
.../include/slugs/mavlink_msg_gps_date_time.h | 203 -
|
||||
.../include/slugs/mavlink_msg_mid_lvl_cmds.h | 167 -
|
||||
.../GCS_MAVLink/include/slugs/mavlink_msg_pid.h | 130 -
|
||||
.../include/slugs/mavlink_msg_pilot_console.h | 145 -
|
||||
.../include/slugs/mavlink_msg_pwm_commands.h | 235 --
|
||||
.../include/slugs/mavlink_msg_sensor_bias.h | 216 --
|
||||
.../include/slugs/mavlink_msg_slugs_action.h | 138 -
|
||||
.../include/slugs/mavlink_msg_slugs_navigation.h | 272 --
|
||||
libraries/GCS_MAVLink/include/slugs/slugs.h | 56 -
|
||||
libraries/GCS_MAVLink/include/ualberta/mavlink.h | 11 -
|
||||
.../include/ualberta/mavlink_msg_nav_filter_bias.h | 242 --
|
||||
.../ualberta/mavlink_msg_radio_calibration.h | 204 -
|
||||
.../mavlink_msg_request_radio_calibration.h | 59 -
|
||||
.../ualberta/mavlink_msg_request_rc_channels.h | 101 -
|
||||
.../ualberta/mavlink_msg_ualberta_sys_status.h | 135 -
|
||||
libraries/GCS_MAVLink/include/ualberta/ualberta.h | 79 -
|
||||
.../include_v1.0/ardupilotmega/ardupilotmega.h | 122 +
|
||||
.../include_v1.0/ardupilotmega/mavlink.h | 27 +
|
||||
.../ardupilotmega/mavlink_msg_ap_adc.h | 254 ++
|
||||
.../ardupilotmega/mavlink_msg_digicam_configure.h | 364 ++
|
||||
.../ardupilotmega/mavlink_msg_digicam_control.h | 342 ++
|
||||
.../ardupilotmega/mavlink_msg_meminfo.h | 166 +
|
||||
.../ardupilotmega/mavlink_msg_mount_configure.h | 254 ++
|
||||
.../ardupilotmega/mavlink_msg_mount_control.h | 254 ++
|
||||
.../ardupilotmega/mavlink_msg_mount_status.h | 232 ++
|
||||
.../ardupilotmega/mavlink_msg_sensor_offsets.h | 386 ++
|
||||
.../ardupilotmega/mavlink_msg_set_mag_offsets.h | 232 ++
|
||||
.../include_v1.0/ardupilotmega/testsuite.h | 538 +++
|
||||
.../include_v1.0/ardupilotmega/version.h | 12 +
|
||||
libraries/GCS_MAVLink/include_v1.0/checksum.h | 89 +
|
||||
libraries/GCS_MAVLink/include_v1.0/common/common.h | 429 +++
|
||||
.../GCS_MAVLink/include_v1.0/common/mavlink.h | 27 +
|
||||
.../include_v1.0/common/mavlink_msg_attitude.h | 276 ++
|
||||
.../common/mavlink_msg_attitude_quaternion.h | 298 ++
|
||||
.../include_v1.0/common/mavlink_msg_auth_key.h | 144 +
|
||||
.../common/mavlink_msg_change_operator_control.h | 204 +
|
||||
.../mavlink_msg_change_operator_control_ack.h | 188 +
|
||||
.../include_v1.0/common/mavlink_msg_command_ack.h | 166 +
|
||||
.../include_v1.0/common/mavlink_msg_command_long.h | 364 ++
|
||||
.../include_v1.0/common/mavlink_msg_data_stream.h | 188 +
|
||||
.../include_v1.0/common/mavlink_msg_debug.h | 188 +
|
||||
.../include_v1.0/common/mavlink_msg_debug_vect.h | 226 ++
|
||||
.../common/mavlink_msg_extended_message.h | 188 +
|
||||
.../common/mavlink_msg_global_position_int.h | 320 ++
|
||||
.../mavlink_msg_global_position_setpoint_int.h | 232 ++
|
||||
.../mavlink_msg_global_vision_position_estimate.h | 276 ++
|
||||
.../common/mavlink_msg_gps_global_origin.h | 188 +
|
||||
.../include_v1.0/common/mavlink_msg_gps_raw_int.h | 342 ++
|
||||
.../include_v1.0/common/mavlink_msg_gps_status.h | 252 ++
|
||||
.../include_v1.0/common/mavlink_msg_heartbeat.h | 251 ++
|
||||
.../include_v1.0/common/mavlink_msg_hil_controls.h | 364 ++
|
||||
.../common/mavlink_msg_hil_rc_inputs_raw.h | 430 +++
|
||||
.../include_v1.0/common/mavlink_msg_hil_state.h | 474 +++
|
||||
.../common/mavlink_msg_local_position_ned.h | 276 ++
|
||||
.../common/mavlink_msg_local_position_setpoint.h | 232 ++
|
||||
.../common/mavlink_msg_manual_control.h | 320 ++
|
||||
.../include_v1.0/common/mavlink_msg_memory_vect.h | 204 +
|
||||
.../include_v1.0/common/mavlink_msg_mission_ack.h | 188 +
|
||||
.../common/mavlink_msg_mission_clear_all.h | 166 +
|
||||
.../common/mavlink_msg_mission_count.h | 188 +
|
||||
.../common/mavlink_msg_mission_current.h | 144 +
|
||||
.../include_v1.0/common/mavlink_msg_mission_item.h | 430 +++
|
||||
.../common/mavlink_msg_mission_item_reached.h | 144 +
|
||||
.../common/mavlink_msg_mission_request.h | 188 +
|
||||
.../common/mavlink_msg_mission_request_list.h | 166 +
|
||||
.../mavlink_msg_mission_request_partial_list.h | 210 ++
|
||||
.../common/mavlink_msg_mission_set_current.h | 188 +
|
||||
.../mavlink_msg_mission_write_partial_list.h | 210 ++
|
||||
.../common/mavlink_msg_named_value_float.h | 182 +
|
||||
.../common/mavlink_msg_named_value_int.h | 182 +
|
||||
.../common/mavlink_msg_nav_controller_output.h | 298 ++
|
||||
.../include_v1.0/common/mavlink_msg_optical_flow.h | 254 ++
|
||||
.../common/mavlink_msg_param_request_list.h | 166 +
|
||||
.../common/mavlink_msg_param_request_read.h | 204 +
|
||||
.../include_v1.0/common/mavlink_msg_param_set.h | 226 ++
|
||||
.../include_v1.0/common/mavlink_msg_param_value.h | 226 ++
|
||||
.../include_v1.0/common/mavlink_msg_ping.h | 210 ++
|
||||
.../include_v1.0/common/mavlink_msg_raw_imu.h | 342 ++
|
||||
.../include_v1.0/common/mavlink_msg_raw_pressure.h | 232 ++
|
||||
.../common/mavlink_msg_rc_channels_override.h | 342 ++
|
||||
.../common/mavlink_msg_rc_channels_raw.h | 364 ++
|
||||
.../common/mavlink_msg_rc_channels_scaled.h | 364 ++
|
||||
.../common/mavlink_msg_request_data_stream.h | 232 ++
|
||||
...link_msg_roll_pitch_yaw_speed_thrust_setpoint.h | 232 ++
|
||||
.../mavlink_msg_roll_pitch_yaw_thrust_setpoint.h | 232 ++
|
||||
.../common/mavlink_msg_safety_allowed_area.h | 276 ++
|
||||
.../common/mavlink_msg_safety_set_allowed_area.h | 320 ++
|
||||
.../include_v1.0/common/mavlink_msg_scaled_imu.h | 342 ++
|
||||
.../common/mavlink_msg_scaled_pressure.h | 210 ++
|
||||
.../common/mavlink_msg_servo_output_raw.h | 342 ++
|
||||
.../mavlink_msg_set_global_position_setpoint_int.h | 232 ++
|
||||
.../common/mavlink_msg_set_gps_global_origin.h | 210 ++
|
||||
.../mavlink_msg_set_local_position_setpoint.h | 276 ++
|
||||
.../include_v1.0/common/mavlink_msg_set_mode.h | 188 +
|
||||
.../mavlink_msg_set_roll_pitch_yaw_speed_thrust.h | 254 ++
|
||||
.../common/mavlink_msg_set_roll_pitch_yaw_thrust.h | 254 ++
|
||||
.../common/mavlink_msg_state_correction.h | 320 ++
|
||||
.../include_v1.0/common/mavlink_msg_statustext.h | 160 +
|
||||
.../include_v1.0/common/mavlink_msg_sys_status.h | 408 ++
|
||||
.../include_v1.0/common/mavlink_msg_system_time.h | 166 +
|
||||
.../include_v1.0/common/mavlink_msg_vfr_hud.h | 254 ++
|
||||
.../common}/mavlink_msg_vicon_position_estimate.h | 198 +-
|
||||
.../common}/mavlink_msg_vision_position_estimate.h | 198 +-
|
||||
.../common}/mavlink_msg_vision_speed_estimate.h | 148 +-
|
||||
.../GCS_MAVLink/include_v1.0/common/testsuite.h | 3908 ++++++++++++++++++++
|
||||
.../GCS_MAVLink/include_v1.0/common/version.h | 12 +
|
||||
.../GCS_MAVLink/include_v1.0/mavlink_helpers.h | 488 +++
|
||||
libraries/GCS_MAVLink/include_v1.0/mavlink_types.h | 182 +
|
||||
libraries/GCS_MAVLink/include_v1.0/protocol.h | 319 ++
|
||||
.../message_definitions/ardupilotmega.xml | 132 +
|
||||
libraries/GCS_MAVLink/message_definitions/test.xml | 31 +
|
||||
.../message_definitions_v1.0/ardupilotmega.xml | 177 +
|
||||
.../message_definitions_v1.0/common.xml | 1536 ++++++++
|
||||
.../message_definitions_v1.0/minimal.xml | 16 +
|
||||
.../message_definitions_v1.0/pixhawk.xml | 193 +
|
||||
.../GCS_MAVLink/message_definitions_v1.0/slugs.xml | 144 +
|
||||
.../GCS_MAVLink/message_definitions_v1.0/test.xml | 31 +
|
||||
.../message_definitions_v1.0/ualberta.xml | 54 +
|
||||
libraries/RC_Channel/RC_Channel.cpp | 2 +-
|
||||
libraries/RC_Channel/RC_Channel.h | 8 +-
|
||||
libraries/RC_Channel/RC_Channel_aux.cpp | 2 +-
|
||||
libraries/RC_Channel/RC_Channel_aux.h | 1 +
|
||||
355 files changed, 43388 insertions(+), 22115 deletions(-)
|
||||
delete mode 100644 ArduCopter/CMakeLists.txt
|
||||
delete mode 100644 ArduPlane/.gitignore
|
||||
delete mode 100644 ArduPlane/CMakeLists.txt
|
||||
create mode 100644 ArduPlane/Mavlink_compat.h
|
||||
create mode 100644 Tools/ArdupilotMegaPlanner/Camera.Designer.cs
|
||||
create mode 100644 Tools/ArdupilotMegaPlanner/Camera.cs
|
||||
create mode 100644 Tools/ArdupilotMegaPlanner/Camera.resx
|
||||
create mode 100755 Tools/scripts/format.sh
|
||||
create mode 100644 libraries/GCS_MAVLink/include/ardupilotmega/mavlink_msg_ap_adc.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include/ardupilotmega/mavlink_msg_digicam_configure.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include/ardupilotmega/mavlink_msg_digicam_control.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include/ardupilotmega/mavlink_msg_mount_configure.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include/ardupilotmega/mavlink_msg_mount_control.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include/ardupilotmega/mavlink_msg_mount_status.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/bittest.c
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_attitude_controller_output.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_attitude_new.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_full_state.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_position_controller_output.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_request_dynamic_gyro_calibration.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_request_static_calibration.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_set_roll_pitch_yaw.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_set_roll_pitch_yaw_speed.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/common/mavlink_msg_waypoint_set_global_reference.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/documentation.dox
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/minimal/mavlink.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/minimal/mavlink_msg_heartbeat.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/minimal/minimal.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_attitude_control.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_aux_status.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_brief_feature.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_control_status.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_data_transmission_handshake.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_debug_vect.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_encapsulated_data.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_encapsulated_image.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_get_image_ack.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_image_available.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_image_trigger_control.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_image_triggered.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_manual_control.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_marker.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_pattern_detected.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_point_of_interest.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_point_of_interest_connection.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_position_control_offset_set.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_position_control_setpoint.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_position_control_setpoint_set.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_raw_aux.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_request_data_stream.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_request_dynamic_gyro_calibration.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_request_static_calibration.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_set_altitude.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_set_cam_shutter.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_watchdog_command.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_watchdog_heartbeat.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_watchdog_process_info.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/mavlink_msg_watchdog_process_status.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/pixhawk/pixhawk.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_air_data.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_cpu_load.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_ctrl_srfc_pt.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_data_log.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_diagnostic.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_filtered_data.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_gps_date_time.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_mid_lvl_cmds.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_pid.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_pilot_console.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_pwm_commands.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_sensor_bias.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_slugs_action.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/mavlink_msg_slugs_navigation.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/slugs/slugs.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/mavlink.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/mavlink_msg_nav_filter_bias.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/mavlink_msg_radio_calibration.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/mavlink_msg_request_radio_calibration.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/mavlink_msg_request_rc_channels.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/mavlink_msg_ualberta_sys_status.h
|
||||
delete mode 100644 libraries/GCS_MAVLink/include/ualberta/ualberta.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/ardupilotmega.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_ap_adc.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_digicam_configure.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_digicam_control.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_meminfo.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_mount_configure.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_mount_control.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_mount_status.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_sensor_offsets.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/mavlink_msg_set_mag_offsets.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/testsuite.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/ardupilotmega/version.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/checksum.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/common.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_attitude.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_attitude_quaternion.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_auth_key.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_change_operator_control.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_change_operator_control_ack.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_command_ack.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_command_long.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_data_stream.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_debug.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_debug_vect.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_extended_message.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_global_position_int.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_global_position_setpoint_int.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_global_vision_position_estimate.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_gps_global_origin.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_gps_raw_int.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_gps_status.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_heartbeat.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_hil_controls.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_hil_rc_inputs_raw.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_hil_state.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_local_position_ned.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_local_position_setpoint.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_manual_control.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_memory_vect.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_ack.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_clear_all.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_count.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_current.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_item.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_item_reached.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_request.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_request_list.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_request_partial_list.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_set_current.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_mission_write_partial_list.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_named_value_float.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_named_value_int.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_nav_controller_output.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_optical_flow.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_param_request_list.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_param_request_read.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_param_set.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_param_value.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_ping.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_raw_imu.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_raw_pressure.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_rc_channels_override.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_rc_channels_raw.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_rc_channels_scaled.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_request_data_stream.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_roll_pitch_yaw_speed_thrust_setpoint.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_roll_pitch_yaw_thrust_setpoint.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_safety_allowed_area.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_safety_set_allowed_area.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_scaled_imu.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_scaled_pressure.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_servo_output_raw.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_set_global_position_setpoint_int.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_set_gps_global_origin.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_set_local_position_setpoint.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_set_mode.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_set_roll_pitch_yaw_speed_thrust.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_set_roll_pitch_yaw_thrust.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_state_correction.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_statustext.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_sys_status.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_system_time.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/mavlink_msg_vfr_hud.h
|
||||
rename libraries/GCS_MAVLink/{include/pixhawk => include_v1.0/common}/mavlink_msg_vicon_position_estimate.h (54%)
|
||||
rename libraries/GCS_MAVLink/{include/pixhawk => include_v1.0/common}/mavlink_msg_vision_position_estimate.h (54%)
|
||||
rename libraries/GCS_MAVLink/{include/pixhawk => include_v1.0/common}/mavlink_msg_vision_speed_estimate.h (57%)
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/testsuite.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/common/version.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/mavlink_helpers.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/mavlink_types.h
|
||||
create mode 100644 libraries/GCS_MAVLink/include_v1.0/protocol.h
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions/test.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/ardupilotmega.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/common.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/minimal.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/pixhawk.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/slugs.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/test.xml
|
||||
create mode 100644 libraries/GCS_MAVLink/message_definitions_v1.0/ualberta.xml
|
||||
Tools/autotest/arducopter.py | 58 ++++++---
|
||||
Tools/autotest/common.py | 16 ++-
|
||||
24 files changed, 251 insertions(+), 78 deletions(-)
|
||||
|
@ -508,7 +508,7 @@ namespace ArdupilotMega.GCSViews
|
||||
ofd.AddExtension = true;
|
||||
ofd.DefaultExt = ".param";
|
||||
ofd.RestoreDirectory = true;
|
||||
ofd.Filter = "Param List|*.param";
|
||||
ofd.Filter = "Param List|*.param;*.parm";
|
||||
DialogResult dr = ofd.ShowDialog();
|
||||
if (dr == DialogResult.OK)
|
||||
{
|
||||
@ -562,7 +562,7 @@ namespace ArdupilotMega.GCSViews
|
||||
sfd.AddExtension = true;
|
||||
sfd.DefaultExt = ".param";
|
||||
sfd.RestoreDirectory = true;
|
||||
sfd.Filter = "Param List|*.param";
|
||||
sfd.Filter = "Param List|*.param;*.parm";
|
||||
DialogResult dr = sfd.ShowDialog();
|
||||
if (dr == DialogResult.OK)
|
||||
{
|
||||
@ -1005,7 +1005,7 @@ namespace ArdupilotMega.GCSViews
|
||||
ofd.AddExtension = true;
|
||||
ofd.DefaultExt = ".param";
|
||||
ofd.RestoreDirectory = true;
|
||||
ofd.Filter = "Param List|*.param";
|
||||
ofd.Filter = "Param List|*.param;*.parm";
|
||||
DialogResult dr = ofd.ShowDialog();
|
||||
if (dr == DialogResult.OK)
|
||||
{
|
||||
|
@ -514,10 +514,15 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
baseurl = temp.url2560.ToString();
|
||||
}
|
||||
else
|
||||
else if (board == "1280")
|
||||
{
|
||||
baseurl = temp.url.ToString();
|
||||
}
|
||||
else
|
||||
{
|
||||
MessageBox.Show("Invalid Board Type");
|
||||
return;
|
||||
}
|
||||
|
||||
// Create a request using a URL that can receive a post.
|
||||
WebRequest request = WebRequest.Create(baseurl);
|
||||
@ -592,6 +597,11 @@ namespace ArdupilotMega.GCSViews
|
||||
|
||||
if (board == "1280")
|
||||
{
|
||||
if (FLASH.Length > 126976)
|
||||
{
|
||||
MessageBox.Show("Firmware is to big for a 1280, Please upgrade!!");
|
||||
return;
|
||||
}
|
||||
//port = new ArduinoSTK();
|
||||
port.BaudRate = 57600;
|
||||
}
|
||||
|
@ -778,7 +778,16 @@ namespace ArdupilotMega.GCSViews
|
||||
return;
|
||||
}
|
||||
|
||||
string alt = (100 * MainV2.cs.multiplierdist).ToString("0");
|
||||
string alt = "100";
|
||||
|
||||
if (MainV2.cs.firmware == MainV2.Firmwares.ArduCopter2)
|
||||
{
|
||||
alt = (10 * MainV2.cs.multiplierdist).ToString("0");
|
||||
}
|
||||
else
|
||||
{
|
||||
alt = (100 * MainV2.cs.multiplierdist).ToString("0");
|
||||
}
|
||||
if (DialogResult.Cancel == Common.InputBox("Enter Alt", "Enter Guided Mode Alt", ref alt))
|
||||
return;
|
||||
|
||||
@ -816,14 +825,18 @@ namespace ArdupilotMega.GCSViews
|
||||
|
||||
private void Zoomlevel_ValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (gMapControl1.MaxZoom + 1 == (double)Zoomlevel.Value)
|
||||
try
|
||||
{
|
||||
gMapControl1.Zoom = (double)Zoomlevel.Value - .1;
|
||||
}
|
||||
else
|
||||
{
|
||||
gMapControl1.Zoom = (double)Zoomlevel.Value;
|
||||
if (gMapControl1.MaxZoom + 1 == (double)Zoomlevel.Value)
|
||||
{
|
||||
gMapControl1.Zoom = (double)Zoomlevel.Value - .1;
|
||||
}
|
||||
else
|
||||
{
|
||||
gMapControl1.Zoom = (double)Zoomlevel.Value;
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
|
||||
private void gMapControl1_MouseMove(object sender, MouseEventArgs e)
|
||||
|
@ -31,14 +31,14 @@
|
||||
{
|
||||
this.components = new System.ComponentModel.Container();
|
||||
System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(FlightPlanner));
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle9 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle13 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle14 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle10 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle11 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle12 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle15 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle16 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle1 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle5 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle6 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle2 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle3 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle4 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle7 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle8 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
this.CHK_altmode = new System.Windows.Forms.CheckBox();
|
||||
this.CHK_holdalt = new System.Windows.Forms.CheckBox();
|
||||
this.Commands = new System.Windows.Forms.DataGridView();
|
||||
@ -47,6 +47,9 @@
|
||||
this.Param2 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||
this.Param3 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||
this.Param4 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||
this.Lat = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||
this.Lon = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||
this.Alt = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||
this.Delete = new System.Windows.Forms.DataGridViewButtonColumn();
|
||||
this.Up = new System.Windows.Forms.DataGridViewImageColumn();
|
||||
this.Down = new System.Windows.Forms.DataGridViewImageColumn();
|
||||
@ -86,6 +89,7 @@
|
||||
this.textBox1 = new System.Windows.Forms.TextBox();
|
||||
this.panelWaypoints = new BSE.Windows.Forms.Panel();
|
||||
this.splitter1 = new BSE.Windows.Forms.Splitter();
|
||||
this.BUT_Camera = new ArdupilotMega.MyButton();
|
||||
this.BUT_grid = new ArdupilotMega.MyButton();
|
||||
this.BUT_Prefetch = new ArdupilotMega.MyButton();
|
||||
this.button1 = new ArdupilotMega.MyButton();
|
||||
@ -116,7 +120,6 @@
|
||||
this.label11 = new System.Windows.Forms.Label();
|
||||
this.panelBASE = new System.Windows.Forms.Panel();
|
||||
this.toolTip1 = new System.Windows.Forms.ToolTip(this.components);
|
||||
this.BUT_Camera = new ArdupilotMega.MyButton();
|
||||
((System.ComponentModel.ISupportInitialize)(this.Commands)).BeginInit();
|
||||
this.panel5.SuspendLayout();
|
||||
this.panel1.SuspendLayout();
|
||||
@ -148,37 +151,41 @@
|
||||
//
|
||||
this.Commands.AllowUserToAddRows = false;
|
||||
resources.ApplyResources(this.Commands, "Commands");
|
||||
dataGridViewCellStyle9.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleLeft;
|
||||
dataGridViewCellStyle9.BackColor = System.Drawing.SystemColors.Control;
|
||||
dataGridViewCellStyle9.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||
dataGridViewCellStyle9.ForeColor = System.Drawing.SystemColors.WindowText;
|
||||
dataGridViewCellStyle9.SelectionBackColor = System.Drawing.SystemColors.Highlight;
|
||||
dataGridViewCellStyle9.SelectionForeColor = System.Drawing.SystemColors.HighlightText;
|
||||
dataGridViewCellStyle9.WrapMode = System.Windows.Forms.DataGridViewTriState.True;
|
||||
this.Commands.ColumnHeadersDefaultCellStyle = dataGridViewCellStyle9;
|
||||
dataGridViewCellStyle1.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleLeft;
|
||||
dataGridViewCellStyle1.BackColor = System.Drawing.SystemColors.Control;
|
||||
dataGridViewCellStyle1.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||
dataGridViewCellStyle1.ForeColor = System.Drawing.SystemColors.WindowText;
|
||||
dataGridViewCellStyle1.SelectionBackColor = System.Drawing.SystemColors.Highlight;
|
||||
dataGridViewCellStyle1.SelectionForeColor = System.Drawing.SystemColors.HighlightText;
|
||||
dataGridViewCellStyle1.WrapMode = System.Windows.Forms.DataGridViewTriState.True;
|
||||
this.Commands.ColumnHeadersDefaultCellStyle = dataGridViewCellStyle1;
|
||||
this.Commands.Columns.AddRange(new System.Windows.Forms.DataGridViewColumn[] {
|
||||
this.Command,
|
||||
this.Param1,
|
||||
this.Param2,
|
||||
this.Param3,
|
||||
this.Param4,
|
||||
this.Lat,
|
||||
this.Lon,
|
||||
this.Alt,
|
||||
this.Delete,
|
||||
this.Up,
|
||||
this.Down});
|
||||
this.Commands.Name = "Commands";
|
||||
dataGridViewCellStyle13.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleLeft;
|
||||
dataGridViewCellStyle13.BackColor = System.Drawing.SystemColors.Control;
|
||||
dataGridViewCellStyle13.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||
dataGridViewCellStyle13.ForeColor = System.Drawing.SystemColors.WindowText;
|
||||
dataGridViewCellStyle13.Format = "N0";
|
||||
dataGridViewCellStyle13.NullValue = "0";
|
||||
dataGridViewCellStyle13.SelectionBackColor = System.Drawing.SystemColors.Highlight;
|
||||
dataGridViewCellStyle13.SelectionForeColor = System.Drawing.SystemColors.HighlightText;
|
||||
this.Commands.RowHeadersDefaultCellStyle = dataGridViewCellStyle13;
|
||||
dataGridViewCellStyle14.ForeColor = System.Drawing.Color.Black;
|
||||
this.Commands.RowsDefaultCellStyle = dataGridViewCellStyle14;
|
||||
dataGridViewCellStyle5.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleLeft;
|
||||
dataGridViewCellStyle5.BackColor = System.Drawing.SystemColors.Control;
|
||||
dataGridViewCellStyle5.Font = new System.Drawing.Font("Microsoft Sans Serif", 8.25F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0)));
|
||||
dataGridViewCellStyle5.ForeColor = System.Drawing.SystemColors.WindowText;
|
||||
dataGridViewCellStyle5.Format = "N0";
|
||||
dataGridViewCellStyle5.NullValue = "0";
|
||||
dataGridViewCellStyle5.SelectionBackColor = System.Drawing.SystemColors.Highlight;
|
||||
dataGridViewCellStyle5.SelectionForeColor = System.Drawing.SystemColors.HighlightText;
|
||||
this.Commands.RowHeadersDefaultCellStyle = dataGridViewCellStyle5;
|
||||
dataGridViewCellStyle6.ForeColor = System.Drawing.Color.Black;
|
||||
this.Commands.RowsDefaultCellStyle = dataGridViewCellStyle6;
|
||||
this.Commands.CellContentClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.Commands_CellContentClick);
|
||||
this.Commands.CellEndEdit += new System.Windows.Forms.DataGridViewCellEventHandler(this.Commands_CellEndEdit);
|
||||
this.Commands.DataError += new System.Windows.Forms.DataGridViewDataErrorEventHandler(this.Commands_DataError);
|
||||
this.Commands.DefaultValuesNeeded += new System.Windows.Forms.DataGridViewRowEventHandler(this.Commands_DefaultValuesNeeded);
|
||||
this.Commands.EditingControlShowing += new System.Windows.Forms.DataGridViewEditingControlShowingEventHandler(this.Commands_EditingControlShowing);
|
||||
this.Commands.RowEnter += new System.Windows.Forms.DataGridViewCellEventHandler(this.Commands_RowEnter);
|
||||
@ -187,15 +194,16 @@
|
||||
//
|
||||
// Command
|
||||
//
|
||||
dataGridViewCellStyle10.BackColor = System.Drawing.Color.FromArgb(((int)(((byte)(67)))), ((int)(((byte)(68)))), ((int)(((byte)(69)))));
|
||||
dataGridViewCellStyle10.ForeColor = System.Drawing.Color.White;
|
||||
this.Command.DefaultCellStyle = dataGridViewCellStyle10;
|
||||
dataGridViewCellStyle2.BackColor = System.Drawing.Color.FromArgb(((int)(((byte)(67)))), ((int)(((byte)(68)))), ((int)(((byte)(69)))));
|
||||
dataGridViewCellStyle2.ForeColor = System.Drawing.Color.White;
|
||||
this.Command.DefaultCellStyle = dataGridViewCellStyle2;
|
||||
this.Command.DisplayStyle = System.Windows.Forms.DataGridViewComboBoxDisplayStyle.ComboBox;
|
||||
resources.ApplyResources(this.Command, "Command");
|
||||
this.Command.Name = "Command";
|
||||
//
|
||||
// Param1
|
||||
//
|
||||
this.Param1.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Param1, "Param1");
|
||||
this.Param1.Name = "Param1";
|
||||
this.Param1.Resizable = System.Windows.Forms.DataGridViewTriState.True;
|
||||
@ -203,6 +211,7 @@
|
||||
//
|
||||
// Param2
|
||||
//
|
||||
this.Param2.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Param2, "Param2");
|
||||
this.Param2.Name = "Param2";
|
||||
this.Param2.Resizable = System.Windows.Forms.DataGridViewTriState.True;
|
||||
@ -210,6 +219,7 @@
|
||||
//
|
||||
// Param3
|
||||
//
|
||||
this.Param3.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Param3, "Param3");
|
||||
this.Param3.Name = "Param3";
|
||||
this.Param3.Resizable = System.Windows.Forms.DataGridViewTriState.True;
|
||||
@ -217,9 +227,32 @@
|
||||
//
|
||||
// Param4
|
||||
//
|
||||
this.Param4.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Param4, "Param4");
|
||||
this.Param4.Name = "Param4";
|
||||
this.Param4.Resizable = System.Windows.Forms.DataGridViewTriState.True;
|
||||
this.Param4.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
|
||||
//
|
||||
// Lat
|
||||
//
|
||||
this.Lat.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Lat, "Lat");
|
||||
this.Lat.Name = "Lat";
|
||||
this.Lat.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
|
||||
//
|
||||
// Lon
|
||||
//
|
||||
this.Lon.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Lon, "Lon");
|
||||
this.Lon.Name = "Lon";
|
||||
this.Lon.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
|
||||
//
|
||||
// Alt
|
||||
//
|
||||
this.Alt.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.DisplayedCellsExceptHeader;
|
||||
resources.ApplyResources(this.Alt, "Alt");
|
||||
this.Alt.Name = "Alt";
|
||||
this.Alt.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
|
||||
//
|
||||
// Delete
|
||||
//
|
||||
@ -229,7 +262,7 @@
|
||||
//
|
||||
// Up
|
||||
//
|
||||
this.Up.DefaultCellStyle = dataGridViewCellStyle11;
|
||||
this.Up.DefaultCellStyle = dataGridViewCellStyle3;
|
||||
resources.ApplyResources(this.Up, "Up");
|
||||
this.Up.Image = global::ArdupilotMega.Properties.Resources.up;
|
||||
this.Up.ImageLayout = System.Windows.Forms.DataGridViewImageCellLayout.Stretch;
|
||||
@ -237,8 +270,8 @@
|
||||
//
|
||||
// Down
|
||||
//
|
||||
dataGridViewCellStyle12.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;
|
||||
this.Down.DefaultCellStyle = dataGridViewCellStyle12;
|
||||
dataGridViewCellStyle4.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;
|
||||
this.Down.DefaultCellStyle = dataGridViewCellStyle4;
|
||||
resources.ApplyResources(this.Down, "Down");
|
||||
this.Down.Image = global::ArdupilotMega.Properties.Resources.down;
|
||||
this.Down.ImageLayout = System.Windows.Forms.DataGridViewImageCellLayout.Stretch;
|
||||
@ -382,8 +415,8 @@
|
||||
//
|
||||
// dataGridViewImageColumn1
|
||||
//
|
||||
dataGridViewCellStyle15.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;
|
||||
this.dataGridViewImageColumn1.DefaultCellStyle = dataGridViewCellStyle15;
|
||||
dataGridViewCellStyle7.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;
|
||||
this.dataGridViewImageColumn1.DefaultCellStyle = dataGridViewCellStyle7;
|
||||
resources.ApplyResources(this.dataGridViewImageColumn1, "dataGridViewImageColumn1");
|
||||
this.dataGridViewImageColumn1.Image = global::ArdupilotMega.Properties.Resources.up;
|
||||
this.dataGridViewImageColumn1.ImageLayout = System.Windows.Forms.DataGridViewImageCellLayout.Stretch;
|
||||
@ -391,8 +424,8 @@
|
||||
//
|
||||
// dataGridViewImageColumn2
|
||||
//
|
||||
dataGridViewCellStyle16.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;
|
||||
this.dataGridViewImageColumn2.DefaultCellStyle = dataGridViewCellStyle16;
|
||||
dataGridViewCellStyle8.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;
|
||||
this.dataGridViewImageColumn2.DefaultCellStyle = dataGridViewCellStyle8;
|
||||
resources.ApplyResources(this.dataGridViewImageColumn2, "dataGridViewImageColumn2");
|
||||
this.dataGridViewImageColumn2.Image = global::ArdupilotMega.Properties.Resources.down;
|
||||
this.dataGridViewImageColumn2.ImageLayout = System.Windows.Forms.DataGridViewImageCellLayout.Stretch;
|
||||
@ -522,6 +555,14 @@
|
||||
this.splitter1.Name = "splitter1";
|
||||
this.splitter1.TabStop = false;
|
||||
//
|
||||
// BUT_Camera
|
||||
//
|
||||
resources.ApplyResources(this.BUT_Camera, "BUT_Camera");
|
||||
this.BUT_Camera.Name = "BUT_Camera";
|
||||
this.toolTip1.SetToolTip(this.BUT_Camera, resources.GetString("BUT_Camera.ToolTip"));
|
||||
this.BUT_Camera.UseVisualStyleBackColor = true;
|
||||
this.BUT_Camera.Click += new System.EventHandler(this.BUT_Camera_Click);
|
||||
//
|
||||
// BUT_grid
|
||||
//
|
||||
resources.ApplyResources(this.BUT_grid, "BUT_grid");
|
||||
@ -790,14 +831,6 @@
|
||||
resources.ApplyResources(this.panelBASE, "panelBASE");
|
||||
this.panelBASE.Name = "panelBASE";
|
||||
//
|
||||
// BUT_Camera
|
||||
//
|
||||
resources.ApplyResources(this.BUT_Camera, "BUT_Camera");
|
||||
this.BUT_Camera.Name = "BUT_Camera";
|
||||
this.toolTip1.SetToolTip(this.BUT_Camera, resources.GetString("BUT_Camera.ToolTip"));
|
||||
this.BUT_Camera.UseVisualStyleBackColor = true;
|
||||
this.BUT_Camera.Click += new System.EventHandler(this.BUT_Camera_Click);
|
||||
//
|
||||
// FlightPlanner
|
||||
//
|
||||
resources.ApplyResources(this, "$this");
|
||||
@ -878,14 +911,6 @@
|
||||
private BSE.Windows.Forms.Splitter splitter1;
|
||||
private System.Windows.Forms.Panel panelBASE;
|
||||
private System.Windows.Forms.Label lbl_homedist;
|
||||
private System.Windows.Forms.DataGridViewComboBoxColumn Command;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param1;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param2;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param3;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param4;
|
||||
private System.Windows.Forms.DataGridViewButtonColumn Delete;
|
||||
private System.Windows.Forms.DataGridViewImageColumn Up;
|
||||
private System.Windows.Forms.DataGridViewImageColumn Down;
|
||||
private MyButton BUT_Prefetch;
|
||||
private MyButton BUT_grid;
|
||||
private System.Windows.Forms.ContextMenuStrip contextMenuStrip1;
|
||||
@ -906,5 +931,16 @@
|
||||
private System.Windows.Forms.ToolStripSeparator toolStripSeparator1;
|
||||
private System.Windows.Forms.ToolStripMenuItem deleteWPToolStripMenuItem;
|
||||
private MyButton BUT_Camera;
|
||||
private System.Windows.Forms.DataGridViewComboBoxColumn Command;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param1;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param2;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param3;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Param4;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Lat;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Lon;
|
||||
private System.Windows.Forms.DataGridViewTextBoxColumn Alt;
|
||||
private System.Windows.Forms.DataGridViewButtonColumn Delete;
|
||||
private System.Windows.Forms.DataGridViewImageColumn Up;
|
||||
private System.Windows.Forms.DataGridViewImageColumn Down;
|
||||
}
|
||||
}
|
@ -25,7 +25,6 @@ namespace ArdupilotMega.GCSViews
|
||||
partial class FlightPlanner : MyUserControl
|
||||
{
|
||||
int selectedrow = 0;
|
||||
int t7 = 10000000;
|
||||
bool quickadd = false;
|
||||
bool isonline = true;
|
||||
bool sethome = false;
|
||||
@ -37,8 +36,7 @@ namespace ArdupilotMega.GCSViews
|
||||
private TextBox textBox1;
|
||||
private ComponentResourceManager rm = new ComponentResourceManager(typeof(FlightPlanner));
|
||||
|
||||
private Dictionary<MAVLink.MAV_CMD, string> cmdNames = new Dictionary<MAVLink.MAV_CMD, string>();
|
||||
private Dictionary<MAVLink.MAV_CMD, string[]> cmdParamNames = new Dictionary<MAVLink.MAV_CMD, string[]>();
|
||||
private Dictionary<string, string[]> cmdParamNames = new Dictionary<string, string[]>();
|
||||
|
||||
|
||||
/// <summary>
|
||||
@ -154,20 +152,21 @@ namespace ArdupilotMega.GCSViews
|
||||
for (int i = 0; i < matchs.Count; i++)
|
||||
{
|
||||
Locationwp temp = new Locationwp();
|
||||
temp.options = 1;
|
||||
temp.id = (byte)(int)Enum.Parse(typeof(MAVLink.MAV_CMD), matchs[i].Groups[1].Value.ToString().Replace("NAV_", ""), false);
|
||||
temp.p1 = byte.Parse(matchs[i].Groups[2].Value.ToString());
|
||||
|
||||
if (temp.id < (byte)MAVLink.MAV_CMD.LAST)
|
||||
{
|
||||
temp.alt = (int)(double.Parse(matchs[i].Groups[3].Value.ToString(), new System.Globalization.CultureInfo("en-US")) * 100);
|
||||
temp.lat = (int)(double.Parse(matchs[i].Groups[4].Value.ToString(), new System.Globalization.CultureInfo("en-US")) * 10000000);
|
||||
temp.lng = (int)(double.Parse(matchs[i].Groups[5].Value.ToString(), new System.Globalization.CultureInfo("en-US")) * 10000000);
|
||||
temp.alt = (float)(double.Parse(matchs[i].Groups[3].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lat = (float)(double.Parse(matchs[i].Groups[4].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lng = (float)(double.Parse(matchs[i].Groups[5].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
}
|
||||
else
|
||||
{
|
||||
temp.alt = (int)(double.Parse(matchs[i].Groups[3].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lat = (int)(double.Parse(matchs[i].Groups[4].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lng = (int)(double.Parse(matchs[i].Groups[5].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.alt = (float)(double.Parse(matchs[i].Groups[3].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lat = (float)(double.Parse(matchs[i].Groups[4].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lng = (float)(double.Parse(matchs[i].Groups[5].Value.ToString(), new System.Globalization.CultureInfo("en-US")));
|
||||
}
|
||||
cmds.Add(temp);
|
||||
|
||||
@ -261,26 +260,26 @@ namespace ArdupilotMega.GCSViews
|
||||
return;
|
||||
}
|
||||
DataGridViewTextBoxCell cell;
|
||||
if (Commands.Columns[Param3.Index].HeaderText.Equals(cmdParamNames[MAVLink.MAV_CMD.WAYPOINT][2]/*"Lat"*/))
|
||||
if (Commands.Columns[Lat.Index].HeaderText.Equals(cmdParamNames["WAYPOINT"][4]/*"Lat"*/))
|
||||
{
|
||||
cell = Commands.Rows[selectedrow].Cells[3] as DataGridViewTextBoxCell;
|
||||
cell = Commands.Rows[selectedrow].Cells[Lat.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = lat.ToString("0.0000000");
|
||||
cell.DataGridView.EndEdit();
|
||||
}
|
||||
if (Commands.Columns[Param4.Index].HeaderText.Equals(cmdParamNames[MAVLink.MAV_CMD.WAYPOINT][3]/*"Long"*/))
|
||||
if (Commands.Columns[Lon.Index].HeaderText.Equals(cmdParamNames["WAYPOINT"][5]/*"Long"*/))
|
||||
{
|
||||
cell = Commands.Rows[selectedrow].Cells[4] as DataGridViewTextBoxCell;
|
||||
cell = Commands.Rows[selectedrow].Cells[Lon.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = lng.ToString("0.0000000");
|
||||
cell.DataGridView.EndEdit();
|
||||
}
|
||||
if (Commands.Columns[Param1.Index].HeaderText.Equals(cmdParamNames[MAVLink.MAV_CMD.WAYPOINT][0]/*"Delay"*/))
|
||||
if (Commands.Columns[Param1.Index].HeaderText.Equals(cmdParamNames["WAYPOINT"][0]/*"Delay"*/))
|
||||
{
|
||||
cell = Commands.Rows[selectedrow].Cells[1] as DataGridViewTextBoxCell;
|
||||
cell = Commands.Rows[selectedrow].Cells[Param1.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = 0;
|
||||
}
|
||||
if (alt != -1 && Commands.Columns[Param2.Index].HeaderText.Equals(cmdParamNames[MAVLink.MAV_CMD.WAYPOINT][1]/*"Alt"*/))
|
||||
if (alt != -1 && Commands.Columns[Alt.Index].HeaderText.Equals(cmdParamNames["WAYPOINT"][6]/*"Alt"*/))
|
||||
{
|
||||
cell = Commands.Rows[selectedrow].Cells[2] as DataGridViewTextBoxCell;
|
||||
cell = Commands.Rows[selectedrow].Cells[Alt.Index] as DataGridViewTextBoxCell;
|
||||
|
||||
cell.Value = TXT_DefaultAlt.Text;
|
||||
|
||||
@ -493,46 +492,7 @@ namespace ArdupilotMega.GCSViews
|
||||
catch { }
|
||||
}
|
||||
|
||||
|
||||
// add first to keep order
|
||||
foreach (object cmd in Enum.GetValues(typeof(MAVLink.MAV_CMD)))
|
||||
{
|
||||
string str = cmd.ToString();
|
||||
if (!str.EndsWith("LAST") && !str.EndsWith("END"))
|
||||
{
|
||||
cmdNames[(MAVLink.MAV_CMD)cmd] = str;
|
||||
cmdParamNames[(MAVLink.MAV_CMD)cmd] = new string[] { "setme", "setme", "setme", "setme" };
|
||||
}
|
||||
}
|
||||
|
||||
// replace with localizied text
|
||||
// the command name and param names are stored in TXT_MAV_CMD, one comand per line, in following format:
|
||||
// COMMAND_TYPE;COMMAND_NAME;PARAM_1_HEAD;PARAM_2_HEAD;PARAM_3_HEAD;PARAM_4_HEAD;
|
||||
|
||||
string[] cmds = rm.GetString("MAVCmd").Split(new char[] { '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries);
|
||||
|
||||
rm.ReleaseAllResources();
|
||||
|
||||
foreach (string cmd in cmds)
|
||||
{
|
||||
string[] field = cmd.Split(new char[] { ';' }, StringSplitOptions.RemoveEmptyEntries);
|
||||
|
||||
if (field.Length >= 2)
|
||||
{
|
||||
MAVLink.MAV_CMD type = (MAVLink.MAV_CMD)Enum.Parse(typeof(MAVLink.MAV_CMD), field[0]);
|
||||
cmdNames[type] = field[1];
|
||||
if (field.Length == 6)
|
||||
{
|
||||
string[] param = new string[4];
|
||||
Array.Copy(field, 2, param, 0, 4);
|
||||
cmdParamNames[type] = param;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Command.DataSource = new List<KeyValuePair<MAVLink.MAV_CMD, string>>(cmdNames as ICollection<KeyValuePair<MAVLink.MAV_CMD, string>>)/*)*/;
|
||||
Command.ValueMember = "Key";
|
||||
Command.DisplayMember = "Value";
|
||||
updateCMDParams();
|
||||
|
||||
Up.Image = global::ArdupilotMega.Properties.Resources.up;
|
||||
Down.Image = global::ArdupilotMega.Properties.Resources.down;
|
||||
@ -544,6 +504,80 @@ namespace ArdupilotMega.GCSViews
|
||||
}
|
||||
}
|
||||
|
||||
void updateCMDParams()
|
||||
{
|
||||
cmdParamNames = readCMDXML();
|
||||
|
||||
List<string> cmds = new List<string>();
|
||||
|
||||
foreach (string item in cmdParamNames.Keys)
|
||||
{
|
||||
cmds.Add(item);
|
||||
}
|
||||
|
||||
Command.DataSource = cmds;
|
||||
}
|
||||
|
||||
Dictionary<string, string[]> readCMDXML()
|
||||
{
|
||||
Dictionary<string, string[]> cmd = new Dictionary<string, string[]>();
|
||||
|
||||
// do lang stuff here
|
||||
|
||||
string file = Path.GetDirectoryName(Application.ExecutablePath) + Path.DirectorySeparatorChar + "mavcmd.xml";
|
||||
|
||||
using (XmlReader reader = XmlReader.Create(file))
|
||||
{
|
||||
reader.Read();
|
||||
reader.ReadStartElement("CMD");
|
||||
if (MainV2.APMFirmware == MainV2.Firmwares.ArduPlane)
|
||||
{
|
||||
reader.ReadToFollowing("APM");
|
||||
}
|
||||
else
|
||||
{
|
||||
reader.ReadToFollowing("AC2");
|
||||
}
|
||||
|
||||
XmlReader inner = reader.ReadSubtree();
|
||||
|
||||
inner.Read();
|
||||
|
||||
inner.MoveToElement();
|
||||
|
||||
inner.Read();
|
||||
|
||||
while (inner.Read())
|
||||
{
|
||||
inner.MoveToElement();
|
||||
if (inner.IsStartElement())
|
||||
{
|
||||
string cmdname = inner.Name;
|
||||
string[] cmdarray = new string[7];
|
||||
int b = 0;
|
||||
|
||||
XmlReader inner2 = inner.ReadSubtree();
|
||||
|
||||
inner2.Read();
|
||||
|
||||
while (inner2.Read())
|
||||
{
|
||||
inner2.MoveToElement();
|
||||
if (inner2.IsStartElement())
|
||||
{
|
||||
cmdarray[b] = inner2.ReadString();
|
||||
b++;
|
||||
}
|
||||
}
|
||||
|
||||
cmd[cmdname] = cmdarray;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return cmd;
|
||||
}
|
||||
|
||||
void Commands_DataError(object sender, DataGridViewDataErrorEventArgs e)
|
||||
{
|
||||
Console.WriteLine(e.Exception.ToString() + " " + e.Context + " col " + e.ColumnIndex);
|
||||
@ -606,40 +640,21 @@ namespace ArdupilotMega.GCSViews
|
||||
isonline = false;
|
||||
}
|
||||
|
||||
updateCMDParams();
|
||||
|
||||
writeKML();
|
||||
}
|
||||
|
||||
private void ChangeColumnHeader(MAVLink.MAV_CMD command)
|
||||
private void ChangeColumnHeader(string command)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (cmdParamNames.ContainsKey(command))
|
||||
for (int i = 1; i <= 4; i++)
|
||||
for (int i = 1; i <= 7; i++)
|
||||
Commands.Columns[i].HeaderText = cmdParamNames[command][i - 1];
|
||||
else
|
||||
for (int i = 1; i <= 4; i++)
|
||||
for (int i = 1; i <= 7; i++)
|
||||
Commands.Columns[i].HeaderText = "setme";
|
||||
switch (command)
|
||||
{
|
||||
case MAVLink.MAV_CMD.WAYPOINT:
|
||||
if (MainV2.APMFirmware == MainV2.Firmwares.ArduPlane)
|
||||
Commands.Columns[1].HeaderText = "N/A";
|
||||
break;
|
||||
case MAVLink.MAV_CMD.LAND:
|
||||
Commands.Columns[1].HeaderText = "N/A";
|
||||
if (MainV2.APMFirmware != MainV2.Firmwares.ArduPlane)
|
||||
{
|
||||
Commands.Columns[2].HeaderText = "N/A";
|
||||
Commands.Columns[3].HeaderText = "N/A";
|
||||
Commands.Columns[4].HeaderText = "N/A";
|
||||
}
|
||||
break;
|
||||
case MAVLink.MAV_CMD.TAKEOFF:
|
||||
if (MainV2.APMFirmware != MainV2.Firmwares.ArduPlane)
|
||||
Commands.Columns[1].HeaderText = "N/A";
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
catch (Exception ex) { MessageBox.Show(ex.ToString()); }
|
||||
}
|
||||
@ -656,8 +671,9 @@ namespace ArdupilotMega.GCSViews
|
||||
try
|
||||
{
|
||||
selectedrow = e.RowIndex;
|
||||
/*string option = Commands[Command.Index, selectedrow].EditedFormattedValue.ToString();*/
|
||||
MAVLink.MAV_CMD cmd = (MAVLink.MAV_CMD)Commands[0, selectedrow].Value;
|
||||
string option = Commands[Command.Index, selectedrow].EditedFormattedValue.ToString();
|
||||
string cmd = Commands[0, selectedrow].Value.ToString();
|
||||
Console.WriteLine("editformat " + option + " value " + cmd);
|
||||
ChangeColumnHeader(cmd);
|
||||
}
|
||||
catch (Exception ex) { MessageBox.Show(ex.ToString()); }
|
||||
@ -668,7 +684,7 @@ namespace ArdupilotMega.GCSViews
|
||||
DataGridViewComboBoxCell cell = Commands.Rows[e.RowIndex].Cells[Command.Index] as DataGridViewComboBoxCell;
|
||||
if (cell.Value == null)
|
||||
{
|
||||
cell.Value = MAVLink.MAV_CMD.WAYPOINT/*"WAYPOINT"*/;
|
||||
cell.Value = "WAYPOINT";
|
||||
Commands.Rows[e.RowIndex].Cells[Delete.Index].Value = "X";
|
||||
if (!quickadd)
|
||||
{
|
||||
@ -684,7 +700,7 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
Commands.CurrentCell = Commands.Rows[e.RowIndex].Cells[0];
|
||||
|
||||
if ((MAVLink.MAV_CMD)Commands.Rows[e.RowIndex - 1].Cells[Command.Index].Value/*.ToString()*/ == MAVLink.MAV_CMD.WAYPOINT/*"WAYPOINT"*/)
|
||||
if (Commands.Rows[e.RowIndex - 1].Cells[Command.Index].Value.ToString() == "WAYPOINT")
|
||||
{
|
||||
Commands.Rows[e.RowIndex].Selected = true; // highlight row
|
||||
}
|
||||
@ -706,7 +722,8 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
DataGridViewTextBoxCell cell;
|
||||
cell = Commands.Rows[selectedrow].Cells[a] as DataGridViewTextBoxCell;
|
||||
if (Commands.Columns[a].HeaderText.Equals("N/A"))
|
||||
|
||||
if (Commands.Columns[a].HeaderText.Equals("") && cell != null && cell.Value == null)
|
||||
{
|
||||
cell.Value = "0";
|
||||
}
|
||||
@ -714,10 +731,11 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
if (cell != null && (cell.Value == null || cell.Value.ToString() == ""))
|
||||
{
|
||||
cell.Value = "I need Data";
|
||||
cell.Value = "?";
|
||||
}
|
||||
else
|
||||
{
|
||||
// not a text box
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -740,30 +758,6 @@ namespace ArdupilotMega.GCSViews
|
||||
}
|
||||
|
||||
}
|
||||
/// <summary>
|
||||
/// copy of ardupilot code for getting distance between WP's
|
||||
/// </summary>
|
||||
/// <param name="loc1"></param>
|
||||
/// <param name="loc2"></param>
|
||||
/// <returns></returns>
|
||||
double getDistance(Locationwp loc1, Locationwp loc2)
|
||||
{
|
||||
if (loc1.lat == 0 || loc1.lng == 0)
|
||||
return -1;
|
||||
if (loc2.lat == 0 || loc2.lng == 0)
|
||||
return -1;
|
||||
|
||||
// this is used to offset the shrinking longitude as we go towards the poles
|
||||
double rads = (double)((Math.Abs(loc2.lat) / t7) * 0.0174532925);
|
||||
//377,173,810 / 10,000,000 = 37.717381 * 0.0174532925 = 0.658292482926943
|
||||
double scaleLongDown = Math.Cos(rads);
|
||||
double scaleLongUp = 1.0f / Math.Cos(rads);
|
||||
|
||||
|
||||
float dlat = (float)(loc2.lat - loc1.lat);
|
||||
float dlong = (float)(((float)(loc2.lng - loc1.lng)) * scaleLongDown);
|
||||
return Math.Sqrt(Math.Pow(dlat, 2) + Math.Pow(dlong, 2)) * .01113195;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// used to add a marker to the map display
|
||||
@ -911,17 +905,16 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
try
|
||||
{
|
||||
//int command = (byte)(int)Enum.Parse(typeof(MAVLink.MAV_CMD), Commands.Rows[a].Cells[Command.Index].Value.ToString(), false);
|
||||
int command = (byte)(MAVLink.MAV_CMD)Commands.Rows[a].Cells[0].Value;
|
||||
int command = (byte)(int)Enum.Parse(typeof(MAVLink.MAV_CMD), Commands.Rows[a].Cells[Command.Index].Value.ToString(), false);
|
||||
if (command < (byte)MAVLink.MAV_CMD.LAST && command != (byte)MAVLink.MAV_CMD.TAKEOFF)
|
||||
{
|
||||
string cell2 = Commands.Rows[a].Cells[Param2.Index].Value.ToString(); // alt
|
||||
string cell3 = Commands.Rows[a].Cells[Param3.Index].Value.ToString(); // lat
|
||||
string cell4 = Commands.Rows[a].Cells[Param4.Index].Value.ToString(); // lng
|
||||
string cell2 = Commands.Rows[a].Cells[Alt.Index].Value.ToString(); // alt
|
||||
string cell3 = Commands.Rows[a].Cells[Lat.Index].Value.ToString(); // lat
|
||||
string cell4 = Commands.Rows[a].Cells[Lon.Index].Value.ToString(); // lng
|
||||
|
||||
if (cell4 == "0" || cell3 == "0")
|
||||
continue;
|
||||
if (cell4 == "I need Data" || cell3 == "I need Data")
|
||||
if (cell4 == "?" || cell3 == "?")
|
||||
continue;
|
||||
|
||||
pointlist.Add(new PointLatLngAlt(double.Parse(cell3), double.Parse(cell4), (int)double.Parse(cell2) + homealt, (a + 1).ToString()));
|
||||
@ -951,11 +944,11 @@ namespace ArdupilotMega.GCSViews
|
||||
float range = 4000;
|
||||
|
||||
Locationwp loc1 = new Locationwp();
|
||||
loc1.lat = (int)(minlat * t7);
|
||||
loc1.lng = (int)(minlong * t7);
|
||||
loc1.lat = (float)(minlat);
|
||||
loc1.lng = (float)(minlong);
|
||||
Locationwp loc2 = new Locationwp();
|
||||
loc2.lat = (int)(maxlat * t7);
|
||||
loc2.lng = (int)(maxlong * t7);
|
||||
loc2.lat = (float)(maxlat);
|
||||
loc2.lng = (float)(maxlong);
|
||||
|
||||
//double distance = getDistance(loc1, loc2); // same code as ardupilot
|
||||
double distance = 2000;
|
||||
@ -1019,8 +1012,8 @@ namespace ArdupilotMega.GCSViews
|
||||
private void savewaypoints()
|
||||
{
|
||||
SaveFileDialog fd = new SaveFileDialog();
|
||||
fd.Filter = "Ardupilot Mission (*.h)|*.*";
|
||||
fd.DefaultExt = ".h";
|
||||
fd.Filter = "Ardupilot Mission (*.txt)|*.*";
|
||||
fd.DefaultExt = ".txt";
|
||||
DialogResult result = fd.ShowDialog();
|
||||
string file = fd.FileName;
|
||||
if (file != "")
|
||||
@ -1028,26 +1021,33 @@ namespace ArdupilotMega.GCSViews
|
||||
try
|
||||
{
|
||||
StreamWriter sw = new StreamWriter(file);
|
||||
sw.WriteLine("#define WP_RADIUS " + TXT_WPRad.Text.ToString() + " // What is the minimum distance to reach a waypoint?");
|
||||
sw.WriteLine("#define LOITER_RADIUS " + TXT_loiterrad.Text.ToString() + " // How close to Loiter?");
|
||||
sw.WriteLine("#define HOLD_CURRENT_ALT 0 // 1 = hold the current altitude, 0 = use the defined altitude to for RTL");
|
||||
sw.WriteLine("#define ALT_TO_HOLD " + TXT_DefaultAlt.Text);
|
||||
sw.WriteLine("");
|
||||
sw.WriteLine("float mission[][5] = {");
|
||||
sw.WriteLine("QGC WPL 110");
|
||||
try
|
||||
{
|
||||
sw.WriteLine("0\t1\t0\t16\t0\t0\t0\t0\t" + double.Parse(TXT_homelat.Text).ToString("0.000000", new System.Globalization.CultureInfo("en-US")) + "\t" + double.Parse(TXT_homelng.Text).ToString("0.000000", new System.Globalization.CultureInfo("en-US")) + "\t" + double.Parse(TXT_homealt.Text).ToString("0.000000", new System.Globalization.CultureInfo("en-US")) + "\t1");
|
||||
}
|
||||
catch
|
||||
{
|
||||
sw.WriteLine("0\t1\t0\t0\t0\t0\t0\t0\t0\t0\t0\t1");
|
||||
}
|
||||
for (int a = 0; a < Commands.Rows.Count - 0; a++)
|
||||
{
|
||||
sw.Write("{" + Commands.Rows[a].Cells[0].Value.ToString() + ",");
|
||||
sw.Write(Commands.Rows[a].Cells[1].Value.ToString() + ",");
|
||||
sw.Write(double.Parse(Commands.Rows[a].Cells[2].Value.ToString()).ToString(new System.Globalization.CultureInfo("en-US")) + ",");
|
||||
sw.Write(double.Parse(Commands.Rows[a].Cells[3].Value.ToString()).ToString(new System.Globalization.CultureInfo("en-US")) + ",");
|
||||
sw.Write(double.Parse(Commands.Rows[a].Cells[4].Value.ToString()).ToString(new System.Globalization.CultureInfo("en-US")) + "}");
|
||||
//if (a < Commands.Rows.Count - 2)
|
||||
//{
|
||||
sw.Write(",");
|
||||
//}
|
||||
byte mode = (byte)(MAVLink.MAV_CMD)Enum.Parse(typeof(MAVLink.MAV_CMD), Commands.Rows[a].Cells[0].Value.ToString());
|
||||
|
||||
sw.Write((a + 1)); // seq
|
||||
sw.Write("\t" + 0); // current
|
||||
sw.Write("\t" + (CHK_altmode.Checked == true ? (byte)MAVLink.MAV_FRAME.MAV_FRAME_GLOBAL : (byte)MAVLink.MAV_FRAME.MAV_FRAME_GLOBAL_RELATIVE_ALT)); //frame
|
||||
sw.Write("\t" + mode);
|
||||
sw.Write("\t" + double.Parse(Commands.Rows[a].Cells[Param1.Index].Value.ToString()).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + double.Parse(Commands.Rows[a].Cells[Param2.Index].Value.ToString()).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + double.Parse(Commands.Rows[a].Cells[Param3.Index].Value.ToString()).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + double.Parse(Commands.Rows[a].Cells[Param4.Index].Value.ToString()).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + double.Parse(Commands.Rows[a].Cells[Lat.Index].Value.ToString()).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + double.Parse(Commands.Rows[a].Cells[Lon.Index].Value.ToString()).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + (double.Parse(Commands.Rows[a].Cells[Alt.Index].Value.ToString()) / MainV2.cs.multiplierdist).ToString("0.000000", new System.Globalization.CultureInfo("en-US")));
|
||||
sw.Write("\t" + 1);
|
||||
sw.WriteLine("");
|
||||
}
|
||||
sw.WriteLine("};");
|
||||
sw.Close();
|
||||
}
|
||||
catch (Exception) { MessageBox.Show("Error writing file"); }
|
||||
@ -1183,9 +1183,9 @@ namespace ArdupilotMega.GCSViews
|
||||
try
|
||||
{
|
||||
home.id = (byte)MAVLink.MAV_CMD.WAYPOINT;
|
||||
home.lat = (int)(float.Parse(TXT_homelat.Text) * 10000000);
|
||||
home.lng = (int)(float.Parse(TXT_homelng.Text) * 10000000);
|
||||
home.alt = (int)(float.Parse(TXT_homealt.Text) / MainV2.cs.multiplierdist * 100); // use saved home
|
||||
home.lat = (float.Parse(TXT_homelat.Text));
|
||||
home.lng = (float.Parse(TXT_homelng.Text));
|
||||
home.alt = (float.Parse(TXT_homealt.Text) / MainV2.cs.multiplierdist); // use saved home
|
||||
}
|
||||
catch { throw new Exception("Your home location is invalid"); }
|
||||
|
||||
@ -1199,8 +1199,8 @@ namespace ArdupilotMega.GCSViews
|
||||
for (int a = 0; a < Commands.Rows.Count - 0; a++)
|
||||
{
|
||||
Locationwp temp = new Locationwp();
|
||||
temp.id = (byte)(MAVLink.MAV_CMD)Commands.Rows[a].Cells[0].Value;// (int)Enum.Parse(typeof(MAVLink.MAV_CMD), Commands.Rows[a].Cells[0].Value.ToString(), false);
|
||||
temp.p1 = byte.Parse(Commands.Rows[a].Cells[1].Value.ToString());
|
||||
temp.id = (byte)(int)Enum.Parse(typeof(MAVLink.MAV_CMD), Commands.Rows[a].Cells[Command.Index].Value.ToString(), false);
|
||||
temp.p1 = float.Parse(Commands.Rows[a].Cells[Param1.Index].Value.ToString());
|
||||
if (temp.id < (byte)MAVLink.MAV_CMD.LAST || temp.id == (byte)MAVLink.MAV_CMD.DO_SET_HOME)
|
||||
{
|
||||
if (CHK_altmode.Checked)
|
||||
@ -1211,25 +1211,15 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
frame = MAVLink.MAV_FRAME.MAV_FRAME_GLOBAL_RELATIVE_ALT;
|
||||
}
|
||||
|
||||
temp.alt = (int)(double.Parse(Commands.Rows[a].Cells[2].Value.ToString()) / MainV2.cs.multiplierdist * 100);
|
||||
temp.lat = (int)(double.Parse(Commands.Rows[a].Cells[3].Value.ToString()) * 10000000);
|
||||
temp.lng = (int)(double.Parse(Commands.Rows[a].Cells[4].Value.ToString()) * 10000000);
|
||||
}
|
||||
else
|
||||
{
|
||||
frame = MAVLink.MAV_FRAME.MAV_FRAME_MISSION;
|
||||
|
||||
temp.alt = (int)(double.Parse(Commands.Rows[a].Cells[2].Value.ToString()));
|
||||
temp.lat = (int)(double.Parse(Commands.Rows[a].Cells[3].Value.ToString()));
|
||||
temp.lng = (int)(double.Parse(Commands.Rows[a].Cells[4].Value.ToString()));
|
||||
|
||||
if (temp.id == (byte)MAVLink.MAV_CMD.CONDITION_CHANGE_ALT && !CHK_altmode.Checked)
|
||||
{
|
||||
frame = MAVLink.MAV_FRAME.MAV_FRAME_GLOBAL_RELATIVE_ALT;
|
||||
temp.alt = (int)(double.Parse(Commands.Rows[a].Cells[2].Value.ToString()) / MainV2.cs.multiplierdist);
|
||||
}
|
||||
}
|
||||
temp.alt = (float)(double.Parse(Commands.Rows[a].Cells[Alt.Index].Value.ToString()) / MainV2.cs.multiplierdist);
|
||||
temp.lat = (float)(double.Parse(Commands.Rows[a].Cells[Lat.Index].Value.ToString()));
|
||||
temp.lng = (float)(double.Parse(Commands.Rows[a].Cells[Lon.Index].Value.ToString()));
|
||||
|
||||
temp.p2 = (float)(double.Parse(Commands.Rows[a].Cells[Param2.Index].Value.ToString()));
|
||||
temp.p3 = (float)(double.Parse(Commands.Rows[a].Cells[Param3.Index].Value.ToString()));
|
||||
temp.p4 = (float)(double.Parse(Commands.Rows[a].Cells[Param4.Index].Value.ToString()));
|
||||
|
||||
port.setWP(temp, (ushort)(a + 1), frame, 0);
|
||||
}
|
||||
@ -1294,6 +1284,7 @@ namespace ArdupilotMega.GCSViews
|
||||
foreach (Locationwp temp in cmds)
|
||||
{
|
||||
i++;
|
||||
//Console.WriteLine("FP processToScreen " + i);
|
||||
if (temp.id == 0 && i != 0) // 0 and not home
|
||||
break;
|
||||
if (temp.id == 255 && i != 0) // bad record - never loaded any WP's - but have started the board up.
|
||||
@ -1307,19 +1298,19 @@ namespace ArdupilotMega.GCSViews
|
||||
DataGridViewTextBoxCell cell;
|
||||
DataGridViewComboBoxCell cellcmd;
|
||||
cellcmd = Commands.Rows[i].Cells[Command.Index] as DataGridViewComboBoxCell;
|
||||
cellcmd.Value = temp.id == 0 ? MAVLink.MAV_CMD.WAYPOINT : (MAVLink.MAV_CMD)temp.id; // treat home as a waypoint to avoid data error.
|
||||
/*foreach (object value in Enum.GetValues(typeof(MAVLink.MAV_CMD)))
|
||||
cellcmd.Value = "WAYPOINT";
|
||||
|
||||
foreach (object value in Enum.GetValues(typeof(MAVLink.MAV_CMD)))
|
||||
{
|
||||
if ((int)value == temp.id)
|
||||
{
|
||||
cellcmd.Value = value.ToString();
|
||||
break;
|
||||
}
|
||||
}*/
|
||||
}
|
||||
|
||||
if (temp.id < (byte)MAVLink.MAV_CMD.LAST || temp.id == (byte)MAVLink.MAV_CMD.DO_SET_HOME)
|
||||
{
|
||||
int alt = temp.alt;
|
||||
|
||||
if ((temp.options & 0x1) == 0 && i != 0) // home is always abs
|
||||
{
|
||||
CHK_altmode.Checked = true;
|
||||
@ -1329,31 +1320,32 @@ namespace ArdupilotMega.GCSViews
|
||||
CHK_altmode.Checked = false;
|
||||
}
|
||||
|
||||
cell = Commands.Rows[i].Cells[Param1.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.p1;
|
||||
cell = Commands.Rows[i].Cells[Param2.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = (int)((double)alt * MainV2.cs.multiplierdist / 100);
|
||||
cell = Commands.Rows[i].Cells[Param3.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = (double)temp.lat / 10000000;
|
||||
cell = Commands.Rows[i].Cells[Param4.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = (double)temp.lng / 10000000;
|
||||
}
|
||||
else
|
||||
{
|
||||
cell = Commands.Rows[i].Cells[Param1.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.p1;
|
||||
cell = Commands.Rows[i].Cells[Param2.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.alt;
|
||||
cell = Commands.Rows[i].Cells[Param3.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.lat;
|
||||
cell = Commands.Rows[i].Cells[Param4.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.lng;
|
||||
|
||||
|
||||
}
|
||||
|
||||
int alt = (int)temp.alt;
|
||||
|
||||
cell = Commands.Rows[i].Cells[Alt.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = (int)((double)alt * MainV2.cs.multiplierdist);
|
||||
cell = Commands.Rows[i].Cells[Lat.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = (double)temp.lat;
|
||||
cell = Commands.Rows[i].Cells[Lon.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = (double)temp.lng;
|
||||
|
||||
cell = Commands.Rows[i].Cells[Param1.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.p1;
|
||||
cell = Commands.Rows[i].Cells[Param2.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.p2;
|
||||
cell = Commands.Rows[i].Cells[Param3.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.p3;
|
||||
cell = Commands.Rows[i].Cells[Param4.Index] as DataGridViewTextBoxCell;
|
||||
cell.Value = temp.p4;
|
||||
}
|
||||
try
|
||||
{
|
||||
DataGridViewTextBoxCell cellhome;
|
||||
cellhome = Commands.Rows[0].Cells[Param3.Index] as DataGridViewTextBoxCell;
|
||||
cellhome = Commands.Rows[0].Cells[Lat.Index] as DataGridViewTextBoxCell;
|
||||
if (cellhome.Value != null)
|
||||
{
|
||||
if (cellhome.Value.ToString() != TXT_homelat.Text)
|
||||
@ -1363,9 +1355,9 @@ namespace ArdupilotMega.GCSViews
|
||||
if (dr == DialogResult.Yes)
|
||||
{
|
||||
TXT_homelat.Text = (double.Parse(cellhome.Value.ToString())).ToString();
|
||||
cellhome = Commands.Rows[0].Cells[Param4.Index] as DataGridViewTextBoxCell;
|
||||
cellhome = Commands.Rows[0].Cells[Lon.Index] as DataGridViewTextBoxCell;
|
||||
TXT_homelng.Text = (double.Parse(cellhome.Value.ToString())).ToString();
|
||||
cellhome = Commands.Rows[0].Cells[Param2.Index] as DataGridViewTextBoxCell;
|
||||
cellhome = Commands.Rows[0].Cells[Alt.Index] as DataGridViewTextBoxCell;
|
||||
TXT_homealt.Text = (double.Parse(cellhome.Value.ToString()) * MainV2.cs.multiplierdist).ToString();
|
||||
}
|
||||
}
|
||||
@ -1598,13 +1590,103 @@ namespace ArdupilotMega.GCSViews
|
||||
private void BUT_loadwpfile_Click(object sender, EventArgs e)
|
||||
{
|
||||
OpenFileDialog fd = new OpenFileDialog();
|
||||
fd.Filter = "Ardupilot Mission (*.h)|*.*";
|
||||
fd.DefaultExt = ".h";
|
||||
fd.Filter = "Ardupilot Mission (*.txt)|*.*";
|
||||
fd.DefaultExt = ".txt";
|
||||
DialogResult result = fd.ShowDialog();
|
||||
string file = fd.FileName;
|
||||
if (file != "")
|
||||
{
|
||||
readwaypointwritterfile(file);
|
||||
if (file.ToLower().EndsWith(".h"))
|
||||
{
|
||||
readwaypointwritterfile(file);
|
||||
}
|
||||
else
|
||||
{
|
||||
readQGC110wpfile(file);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void readQGC110wpfile(string file)
|
||||
{
|
||||
int wp_count = 0;
|
||||
bool error = false;
|
||||
List<Locationwp> cmds = new List<Locationwp>();
|
||||
|
||||
try
|
||||
{
|
||||
StreamReader sr = new StreamReader(file); //"defines.h"
|
||||
string header = sr.ReadLine();
|
||||
if (header == null || !header.Contains("QGC WPL 110"))
|
||||
{
|
||||
MessageBox.Show("Invalid Waypoint file");
|
||||
return;
|
||||
}
|
||||
while (!error && !sr.EndOfStream)
|
||||
{
|
||||
string line = sr.ReadLine();
|
||||
// waypoints
|
||||
|
||||
if (line.StartsWith("#"))
|
||||
continue;
|
||||
|
||||
string[] items = line.Split(new char[] { (char)'\t', ' ' }, StringSplitOptions.RemoveEmptyEntries);
|
||||
|
||||
if (items.Length <= 9)
|
||||
continue;
|
||||
|
||||
try
|
||||
{
|
||||
|
||||
Locationwp temp = new Locationwp();
|
||||
if (items[2] == "3")
|
||||
{ // abs MAV_FRAME_GLOBAL_RELATIVE_ALT=3
|
||||
temp.options = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
temp.options = 0;
|
||||
}
|
||||
temp.id = (byte)(int)Enum.Parse(typeof(MAVLink.MAV_CMD), items[3], false);
|
||||
temp.p1 = float.Parse(items[4], new System.Globalization.CultureInfo("en-US"));
|
||||
|
||||
if (temp.id == 99)
|
||||
temp.id = 0;
|
||||
|
||||
temp.alt = (float)(double.Parse(items[10], new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lat = (float)(double.Parse(items[8], new System.Globalization.CultureInfo("en-US")));
|
||||
temp.lng = (float)(double.Parse(items[9], new System.Globalization.CultureInfo("en-US")));
|
||||
|
||||
temp.p2 = (float)(double.Parse(items[5], new System.Globalization.CultureInfo("en-US")));
|
||||
temp.p3 = (float)(double.Parse(items[6], new System.Globalization.CultureInfo("en-US")));
|
||||
temp.p4 = (float)(double.Parse(items[7], new System.Globalization.CultureInfo("en-US")));
|
||||
|
||||
cmds.Add(temp);
|
||||
|
||||
wp_count++;
|
||||
|
||||
}
|
||||
catch { MessageBox.Show("Line invalid\n" + line); }
|
||||
|
||||
if (wp_count == byte.MaxValue)
|
||||
{
|
||||
MessageBox.Show("To many Waypoints!!!");
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
sr.Close();
|
||||
|
||||
processToScreen(cmds);
|
||||
|
||||
writeKML();
|
||||
|
||||
MainMap.ZoomAndCenterMarkers("objects");
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
MessageBox.Show("Can't open file! " + ex.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
@ -1721,7 +1803,7 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
if (CurentRectMarker.InnerMarker.Tag.ToString().Contains("grid"))
|
||||
{
|
||||
drawnpolygon.Points[int.Parse(CurentRectMarker.InnerMarker.Tag.ToString().Replace("grid","")) - 1] = new PointLatLng(end.Lat,end.Lng);
|
||||
drawnpolygon.Points[int.Parse(CurentRectMarker.InnerMarker.Tag.ToString().Replace("grid", "")) - 1] = new PointLatLng(end.Lat, end.Lng);
|
||||
MainMap.UpdatePolygonLocalPosition(drawnpolygon);
|
||||
}
|
||||
else
|
||||
@ -1990,7 +2072,7 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
// update row headers
|
||||
((ComboBox)sender).ForeColor = Color.White;
|
||||
ChangeColumnHeader((MAVLink.MAV_CMD)((ComboBox)sender).SelectedValue);
|
||||
ChangeColumnHeader(((ComboBox)sender).Text);
|
||||
}
|
||||
/// <summary>
|
||||
/// Get the Google earth ALT for a given coord
|
||||
@ -2134,19 +2216,19 @@ namespace ArdupilotMega.GCSViews
|
||||
{
|
||||
double denom = ((end1.Lng - start1.Lng) * (end2.Lat - start2.Lat)) - ((end1.Lat - start1.Lat) * (end2.Lng - start2.Lng));
|
||||
// AB & CD are parallel
|
||||
if (denom == 0)
|
||||
if (denom == 0)
|
||||
return PointLatLng.Zero;
|
||||
double numer = ((start1.Lat - start2.Lat) * (end2.Lng - start2.Lng)) - ((start1.Lng - start2.Lng) * (end2.Lat - start2.Lat));
|
||||
double r = numer / denom;
|
||||
double r = numer / denom;
|
||||
double numer2 = ((start1.Lat - start2.Lat) * (end1.Lng - start1.Lng)) - ((start1.Lng - start2.Lng) * (end1.Lat - start1.Lat));
|
||||
double s = numer2 / denom;
|
||||
if ((r < 0 || r > 1) || (s < 0 || s > 1))
|
||||
return PointLatLng.Zero;
|
||||
double s = numer2 / denom;
|
||||
if ((r < 0 || r > 1) || (s < 0 || s > 1))
|
||||
return PointLatLng.Zero;
|
||||
// Find intersection point
|
||||
PointLatLng result = new PointLatLng();
|
||||
result.Lng = start1.Lng + (r * (end1.Lng - start1.Lng));
|
||||
result.Lat = start1.Lat + (r * (end1.Lat - start1.Lat));
|
||||
return result;
|
||||
result.Lat = start1.Lat + (r * (end1.Lat - start1.Lat));
|
||||
return result;
|
||||
}
|
||||
|
||||
RectLatLng getPolyMinMax(GMapPolygon poly)
|
||||
@ -2244,7 +2326,7 @@ namespace ArdupilotMega.GCSViews
|
||||
double x = bottomleft.Lat - Math.Abs(fulllatdiff);
|
||||
double y = bottomleft.Lng - Math.Abs(fulllngdiff);
|
||||
|
||||
Console.WriteLine("{0} < {1} {2} < {3}", x , (topright.Lat) ,y , (topright.Lng));
|
||||
Console.WriteLine("{0} < {1} {2} < {3}", x, (topright.Lat), y, (topright.Lng));
|
||||
|
||||
while (x < (topright.Lat + Math.Abs(fulllatdiff)) && y < (topright.Lng + Math.Abs(fulllngdiff)))
|
||||
{
|
||||
@ -2313,12 +2395,12 @@ namespace ArdupilotMega.GCSViews
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (!farestlatlong.IsZero)
|
||||
callMe(farestlatlong.Lat, farestlatlong.Lng, altitude);
|
||||
if (!closestlatlong.IsZero)
|
||||
callMe(closestlatlong.Lat, closestlatlong.Lng - overshootdistlng, altitude);
|
||||
|
||||
|
||||
//callMe(x, topright.Lng, altitude);
|
||||
//callMe(x, bottomleft.Lng - overshootdistlng, altitude);
|
||||
}
|
||||
@ -2341,7 +2423,7 @@ namespace ArdupilotMega.GCSViews
|
||||
newlatlong = FindLineIntersection(area.Points[a - 1], area.Points[a], new PointLatLng(ax, ay), new PointLatLng(bx, by));
|
||||
if (!newlatlong.IsZero)
|
||||
{
|
||||
if (noc > MainMap.Manager.GetDistance(new PointLatLng(ax, ay),newlatlong))
|
||||
if (noc > MainMap.Manager.GetDistance(new PointLatLng(ax, ay), newlatlong))
|
||||
{
|
||||
closestlatlong.Lat = newlatlong.Lat;
|
||||
closestlatlong.Lng = newlatlong.Lng;
|
||||
@ -2433,7 +2515,7 @@ namespace ArdupilotMega.GCSViews
|
||||
if (startmeasure.IsZero)
|
||||
{
|
||||
startmeasure = start;
|
||||
polygons.Markers.Add( new GMapMarkerGoogleRed(start));
|
||||
polygons.Markers.Add(new GMapMarkerGoogleRed(start));
|
||||
MainMap.Invalidate();
|
||||
}
|
||||
else
|
||||
@ -2442,14 +2524,14 @@ namespace ArdupilotMega.GCSViews
|
||||
polygonPoints.Add(startmeasure);
|
||||
polygonPoints.Add(start);
|
||||
|
||||
GMapPolygon line = new GMapPolygon(polygonPoints,"measure dist");
|
||||
GMapPolygon line = new GMapPolygon(polygonPoints, "measure dist");
|
||||
line.Stroke.Color = Color.Green;
|
||||
|
||||
polygons.Polygons.Add(line);
|
||||
|
||||
polygons.Markers.Add(new GMapMarkerGoogleRed(start));
|
||||
MainMap.Invalidate();
|
||||
MessageBox.Show("Distance: " + FormatDistance(MainMap.Manager.GetDistance(startmeasure, start),true) + " AZ: " + (MainMap.Manager.GetBearing(startmeasure, start).ToString("0")));
|
||||
MessageBox.Show("Distance: " + FormatDistance(MainMap.Manager.GetDistance(startmeasure, start), true) + " AZ: " + (MainMap.Manager.GetBearing(startmeasure, start).ToString("0")));
|
||||
polygons.Polygons.Remove(line);
|
||||
polygons.Markers.Clear();
|
||||
startmeasure = new PointLatLng();
|
||||
@ -2459,9 +2541,10 @@ namespace ArdupilotMega.GCSViews
|
||||
private void rotateMapToolStripMenuItem_Click(object sender, EventArgs e)
|
||||
{
|
||||
string heading = "0";
|
||||
Common.InputBox("Rotate map to heading","Enter new UP heading",ref heading);
|
||||
Common.InputBox("Rotate map to heading", "Enter new UP heading", ref heading);
|
||||
float ans = 0;
|
||||
if (float.TryParse(heading,out ans)) {
|
||||
if (float.TryParse(heading, out ans))
|
||||
{
|
||||
MainMap.Bearing = ans;
|
||||
}
|
||||
}
|
||||
@ -2475,14 +2558,14 @@ namespace ArdupilotMega.GCSViews
|
||||
|
||||
polygongridmode = true;
|
||||
|
||||
List < PointLatLng > polygonPoints = new List<PointLatLng>();
|
||||
List<PointLatLng> polygonPoints = new List<PointLatLng>();
|
||||
if (drawnpolygons.Polygons.Count == 0)
|
||||
{
|
||||
drawnpolygon = new GMapPolygon(polygonPoints, "drawnpoly");
|
||||
drawnpolygon.Stroke = new Pen(Color.Red,2);
|
||||
drawnpolygon.Stroke = new Pen(Color.Red, 2);
|
||||
drawnpolygons.Polygons.Add(drawnpolygon);
|
||||
}
|
||||
drawnpolygon.Points.Add(new PointLatLng(start.Lat,start.Lng));
|
||||
drawnpolygon.Points.Add(new PointLatLng(start.Lat, start.Lng));
|
||||
|
||||
addpolygonmarkergrid(drawnpolygon.Points.Count.ToString(), start.Lng, start.Lat, 0);
|
||||
|
||||
@ -2514,7 +2597,7 @@ namespace ArdupilotMega.GCSViews
|
||||
|
||||
Commands.Rows[selectedrow].Cells[Command.Index].Value = MAVLink.MAV_CMD.LOITER_UNLIM;
|
||||
|
||||
setfromGE(end.Lat,end.Lng,(int)float.Parse(TXT_DefaultAlt.Text));
|
||||
setfromGE(end.Lat, end.Lng, (int)float.Parse(TXT_DefaultAlt.Text));
|
||||
}
|
||||
|
||||
private void jumpstartToolStripMenuItem_Click(object sender, EventArgs e)
|
||||
@ -2534,7 +2617,7 @@ namespace ArdupilotMega.GCSViews
|
||||
private void jumpwPToolStripMenuItem_Click(object sender, EventArgs e)
|
||||
{
|
||||
string wp = "1";
|
||||
Common.InputBox("WP No", "Jump to WP no?",ref wp);
|
||||
Common.InputBox("WP No", "Jump to WP no?", ref wp);
|
||||
string repeat = "5";
|
||||
Common.InputBox("Jump repeat", "Number of times to Repeat", ref repeat);
|
||||
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -112,7 +112,7 @@ namespace ArdupilotMega.HIL
|
||||
double pitch_accel = (m[2] - m[3]) * 5000.0;
|
||||
double yaw_accel = -((m[2] + m[3]) - (m[0] + m[1])) * 400.0;
|
||||
|
||||
// Console.WriteLine("roll {0} {1} {2}", roll_accel, roll_rate, roll);
|
||||
//Console.WriteLine("roll {0} {1} {2}", roll_accel, roll_rate, roll);
|
||||
|
||||
//# update rotational rates
|
||||
roll_rate += roll_accel * delta_time.TotalSeconds;
|
||||
@ -225,12 +225,20 @@ namespace ArdupilotMega.HIL
|
||||
#else
|
||||
gps.alt = ((float)(altitude));
|
||||
gps.fix_type = 3;
|
||||
gps.v = ((float)Math.Sqrt((velocity.X * velocity.X) + (velocity.Y * velocity.Y)));
|
||||
gps.hdg = (float)(((Math.Atan2(velocity.Y, velocity.X) * rad2deg) + 360) % 360); ;
|
||||
|
||||
gps.lat = ((float)latitude);
|
||||
gps.lon = ((float)longitude);
|
||||
gps.usec = ((ulong)DateTime.Now.Ticks);
|
||||
|
||||
//Random rand = new Random();
|
||||
//gps.alt += (rand.Next(100) - 50) / 100.0f;
|
||||
//gps.lat += (float)((rand.NextDouble() - 0.5) * 0.00005);
|
||||
//gps.lon += (float)((rand.NextDouble() - 0.5) * 0.00005);
|
||||
//gps.v += (float)(rand.NextDouble() - 0.5) * 1.0f;
|
||||
|
||||
gps.v = ((float)Math.Sqrt((velocity.X * velocity.X) + (velocity.Y * velocity.Y)));
|
||||
gps.hdg = (float)(((Math.Atan2(velocity.Y, velocity.X) * rad2deg) + 360) % 360); ;
|
||||
|
||||
asp.airspeed = gps.v;
|
||||
#endif
|
||||
|
||||
@ -244,7 +252,7 @@ namespace ArdupilotMega.HIL
|
||||
|
||||
MainV2.comPort.sendPacket(asp);
|
||||
|
||||
if (framecount % 10 == 0)
|
||||
if (framecount % 12 == 0)
|
||||
{// 50 / 10 = 5 hz
|
||||
MainV2.comPort.sendPacket(gps);
|
||||
//Console.WriteLine(DateTime.Now.Millisecond + " GPS" );
|
||||
|
@ -348,16 +348,22 @@ namespace ArdupilotMega
|
||||
|
||||
public void sendPacket(object indata)
|
||||
{
|
||||
bool run = false;
|
||||
byte a = 0;
|
||||
foreach (Type ty in mavstructs)
|
||||
{
|
||||
if (ty == indata.GetType())
|
||||
{
|
||||
run = true;
|
||||
generatePacket(a, indata);
|
||||
return;
|
||||
}
|
||||
a++;
|
||||
}
|
||||
if (!run)
|
||||
{
|
||||
Console.WriteLine("Mavlink : NOT VALID PACKET sendPacket() " + indata.GetType().ToString());
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -395,7 +401,7 @@ namespace ArdupilotMega
|
||||
#if MAVLINK10
|
||||
packet[4] = (byte)MAV_COMPONENT.MAV_COMP_ID_MISSIONPLANNER;
|
||||
#else
|
||||
packet[4] = (byte)MAV_COMPONENT.MAV_COMP_ID_WAYPOINTPLANNER;
|
||||
packet[4] = (byte)MAV_COMPONENT.MAV_COMP_ID_WAYPOINTPLANNER;
|
||||
#endif
|
||||
packet[5] = messageType;
|
||||
|
||||
@ -491,7 +497,7 @@ namespace ArdupilotMega
|
||||
#if MAVLINK10
|
||||
Array.Resize(ref temp, 16);
|
||||
#else
|
||||
Array.Resize(ref temp, 15);
|
||||
Array.Resize(ref temp, 15);
|
||||
#endif
|
||||
req.param_id = temp;
|
||||
req.param_value = (value);
|
||||
@ -750,7 +756,7 @@ Array.Resize(ref temp, 15);
|
||||
req.target_component = compid;
|
||||
req.type = 0;
|
||||
|
||||
generatePacket(MAVLINK_MSG_ID_WAYPOINT_ACK, req);
|
||||
generatePacket(MAVLINK_MSG_ID_WAYPOINT_ACK, req);
|
||||
#endif
|
||||
}
|
||||
|
||||
@ -975,7 +981,7 @@ Array.Resize(ref temp, 15);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#endif
|
||||
}
|
||||
|
||||
@ -1176,7 +1182,7 @@ Array.Resize(ref temp, 15);
|
||||
}
|
||||
}
|
||||
}
|
||||
#else
|
||||
#else
|
||||
|
||||
__mavlink_waypoint_request_list_t req = new __mavlink_waypoint_request_list_t();
|
||||
|
||||
@ -1222,8 +1228,8 @@ Array.Resize(ref temp, 15);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
}
|
||||
/// <summary>
|
||||
/// Gets specfied WP
|
||||
@ -1337,30 +1343,27 @@ Array.Resize(ref temp, 15);
|
||||
|
||||
loc.options = (byte)(wp.frame & 0x1);
|
||||
loc.id = (byte)(wp.command);
|
||||
loc.p1 = (byte)(wp.param1);
|
||||
if (loc.id < (byte)MAV_CMD.LAST)
|
||||
{
|
||||
loc.alt = (int)((wp.z) * 100);
|
||||
loc.lat = (int)((wp.x) * 10000000);
|
||||
loc.lng = (int)((wp.y) * 10000000);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
loc.alt = (int)((wp.z));
|
||||
loc.lat = (int)((wp.x));
|
||||
loc.lng = (int)((wp.y));
|
||||
loc.p1 = (wp.param1);
|
||||
loc.p2 = (wp.param2);
|
||||
loc.p3 = (wp.param3);
|
||||
loc.p4 = (wp.param4);
|
||||
|
||||
loc.alt = ((wp.z));
|
||||
loc.lat = ((wp.x));
|
||||
loc.lng = ((wp.y));
|
||||
/*
|
||||
if (MainV2.cs.firmware == MainV2.Firmwares.ArduPlane)
|
||||
{
|
||||
switch (loc.id)
|
||||
{ // Switch to map APM command fields inot MAVLink command fields
|
||||
case (byte)MAV_CMD.LOITER_TURNS:
|
||||
case (byte)MAV_CMD.TAKEOFF:
|
||||
case (byte)MAV_CMD.DO_SET_HOME:
|
||||
//case (byte)MAV_CMD.DO_SET_ROI:
|
||||
loc.alt = (int)((wp.z) * 100);
|
||||
loc.lat = (int)((wp.x) * 10000000);
|
||||
loc.lng = (int)((wp.y) * 10000000);
|
||||
loc.p1 = (byte)wp.param1;
|
||||
loc.alt = (float)((wp.z));
|
||||
loc.lat = (float)((wp.x));
|
||||
loc.lng = (float)((wp.y));
|
||||
loc.p1 = (float)wp.param1;
|
||||
break;
|
||||
|
||||
case (byte)MAV_CMD.CONDITION_CHANGE_ALT:
|
||||
@ -1411,7 +1414,7 @@ Array.Resize(ref temp, 15);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
*/
|
||||
Console.WriteLine("getWP {0} {1} {2} {3} {4} opt {5}", loc.id, loc.p1, loc.alt, loc.lat, loc.lng, loc.options);
|
||||
|
||||
break;
|
||||
@ -1619,7 +1622,7 @@ Array.Resize(ref temp, 15);
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -1632,11 +1635,11 @@ Array.Resize(ref temp, 15);
|
||||
public void setWP(Locationwp loc, ushort index, MAV_FRAME frame, byte current)
|
||||
{
|
||||
MainV2.givecomport = true;
|
||||
#if MAVLINK10
|
||||
#if MAVLINK10
|
||||
__mavlink_mission_item_t req = new __mavlink_mission_item_t();
|
||||
#else
|
||||
__mavlink_waypoint_t req = new __mavlink_waypoint_t();
|
||||
#endif
|
||||
#else
|
||||
__mavlink_waypoint_t req = new __mavlink_waypoint_t();
|
||||
#endif
|
||||
|
||||
req.target_system = sysid;
|
||||
req.target_component = compid; // MAVLINK_MSG_ID_MISSION_ITEM
|
||||
@ -1646,20 +1649,18 @@ Array.Resize(ref temp, 15);
|
||||
|
||||
req.current = current;
|
||||
|
||||
if (loc.id < (byte)MAV_CMD.LAST)
|
||||
{
|
||||
req.frame = (byte)frame;
|
||||
req.y = (float)(loc.lng / 10000000.0);
|
||||
req.x = (float)(loc.lat / 10000000.0);
|
||||
req.z = (float)(loc.alt / 100.0);
|
||||
}
|
||||
else
|
||||
{
|
||||
req.frame = (byte)MAVLink.MAV_FRAME.MAV_FRAME_MISSION; // mission
|
||||
req.y = (float)(loc.lng);
|
||||
req.x = (float)(loc.lat);
|
||||
req.z = (float)(loc.alt);
|
||||
req.frame = (byte)frame;
|
||||
req.y = (float)(loc.lng);
|
||||
req.x = (float)(loc.lat);
|
||||
req.z = (float)(loc.alt);
|
||||
|
||||
req.param1 = loc.p1;
|
||||
req.param2 = loc.p2;
|
||||
req.param3 = loc.p3;
|
||||
req.param4 = loc.p4;
|
||||
/*
|
||||
if (MainV2.cs.firmware == MainV2.Firmwares.ArduPlane)
|
||||
{
|
||||
switch (loc.id)
|
||||
{ // Switch to map APM command fields inot MAVLink command fields
|
||||
case (byte)MAV_CMD.LOITER_TURNS:
|
||||
@ -1667,9 +1668,6 @@ Array.Resize(ref temp, 15);
|
||||
req.param1 = loc.p1;
|
||||
break;
|
||||
case (byte)MAV_CMD.DO_SET_HOME:
|
||||
req.y = (float)(loc.lng / 10000000.0);
|
||||
req.x = (float)(loc.lat / 10000000.0);
|
||||
req.z = (float)(loc.alt / 100.0);
|
||||
req.param1 = loc.p1;
|
||||
break;
|
||||
|
||||
@ -1711,16 +1709,17 @@ Array.Resize(ref temp, 15);
|
||||
break;
|
||||
}
|
||||
}
|
||||
*/
|
||||
req.seq = index;
|
||||
|
||||
Console.WriteLine("setWP {6} frame {0} cmd {1} p1 {2} x {3} y {4} z {5}", req.frame, req.command, req.param1, req.x, req.y, req.z, index);
|
||||
|
||||
// request
|
||||
#if MAVLINK10
|
||||
#if MAVLINK10
|
||||
generatePacket(MAVLINK_MSG_ID_MISSION_ITEM, req);
|
||||
#else
|
||||
generatePacket(MAVLINK_MSG_ID_WAYPOINT, req);
|
||||
#endif
|
||||
#else
|
||||
generatePacket(MAVLINK_MSG_ID_WAYPOINT, req);
|
||||
#endif
|
||||
|
||||
DateTime start = DateTime.Now;
|
||||
int retrys = 6;
|
||||
@ -1732,11 +1731,11 @@ Array.Resize(ref temp, 15);
|
||||
if (retrys > 0)
|
||||
{
|
||||
Console.WriteLine("setWP Retry " + retrys);
|
||||
#if MAVLINK10
|
||||
#if MAVLINK10
|
||||
generatePacket(MAVLINK_MSG_ID_MISSION_ITEM, req);
|
||||
#else
|
||||
generatePacket(MAVLINK_MSG_ID_WAYPOINT, req);
|
||||
#endif
|
||||
#else
|
||||
generatePacket(MAVLINK_MSG_ID_WAYPOINT, req);
|
||||
#endif
|
||||
start = DateTime.Now;
|
||||
retrys--;
|
||||
continue;
|
||||
@ -1747,7 +1746,7 @@ Array.Resize(ref temp, 15);
|
||||
byte[] buffer = readPacket();
|
||||
if (buffer.Length > 5)
|
||||
{
|
||||
#if MAVLINK10
|
||||
#if MAVLINK10
|
||||
if (buffer[5] == MAVLINK_MSG_ID_MISSION_ACK)
|
||||
{
|
||||
__mavlink_mission_ack_t ans = new __mavlink_mission_ack_t();
|
||||
@ -1787,8 +1786,8 @@ Array.Resize(ref temp, 15);
|
||||
{
|
||||
//Console.WriteLine(DateTime.Now + " PC setwp " + buffer[5]);
|
||||
}
|
||||
#else
|
||||
if (buffer[5] == MAVLINK_MSG_ID_WAYPOINT_ACK)
|
||||
#else
|
||||
if (buffer[5] == MAVLINK_MSG_ID_WAYPOINT_ACK)
|
||||
{ //__mavlink_waypoint_request_t
|
||||
Console.WriteLine("set wp " + index + " ACK 47 : " + buffer[5]);
|
||||
break;
|
||||
@ -1821,7 +1820,7 @@ Array.Resize(ref temp, 15);
|
||||
{
|
||||
//Console.WriteLine(DateTime.Now + " PC setwp " + buffer[5]);
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -305,20 +305,6 @@ namespace ArdupilotMega
|
||||
|
||||
};
|
||||
|
||||
public const byte MAVLINK_MSG_ID_ATTITUDE_NEW = 30;
|
||||
[StructLayout(LayoutKind.Sequential,Pack=1)]
|
||||
public struct __mavlink_attitude_new_t
|
||||
{
|
||||
public ulong usec; /// Timestamp (microseconds since UNIX epoch or microseconds since system boot)
|
||||
public float roll; /// Roll angle (rad)
|
||||
public float pitch; /// Pitch angle (rad)
|
||||
public float yaw; /// Yaw angle (rad)
|
||||
public float rollspeed; /// Roll angular speed (rad/s)
|
||||
public float pitchspeed; /// Pitch angular speed (rad/s)
|
||||
public float yawspeed; /// Yaw angular speed (rad/s)
|
||||
|
||||
};
|
||||
|
||||
public const byte MAVLINK_MSG_ID_AUTH_KEY = 7;
|
||||
[StructLayout(LayoutKind.Sequential,Pack=1)]
|
||||
public struct __mavlink_auth_key_t
|
||||
@ -1486,7 +1472,7 @@ namespace ArdupilotMega
|
||||
MAV_FRAME_LOCAL_ENU = 4
|
||||
};
|
||||
|
||||
Type[] mavstructs = new Type[] {typeof( __mavlink_heartbeat_t) ,typeof( __mavlink_boot_t) ,null ,typeof( __mavlink_ping_t) ,null ,typeof( __mavlink_change_operator_control_t) ,typeof( __mavlink_change_operator_control_ack_t) ,typeof( __mavlink_auth_key_t) ,null ,typeof( __mavlink_action_ack_t) ,typeof( __mavlink_action_t) ,typeof( __mavlink_set_mode_t) ,typeof( __mavlink_set_nav_mode_t) ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_param_request_read_t) ,typeof( __mavlink_param_request_list_t) ,typeof( __mavlink_param_value_t) ,typeof( __mavlink_param_set_t) ,null ,typeof( __mavlink_gps_raw_int_t) ,typeof( __mavlink_scaled_imu_t) ,typeof( __mavlink_gps_status_t) ,typeof( __mavlink_raw_imu_t) ,typeof( __mavlink_raw_pressure_t) ,typeof( __mavlink_attitude_new_t ) ,typeof( __mavlink_local_position_t) ,typeof( __mavlink_gps_raw_t) ,typeof( __mavlink_global_position_t) ,typeof( __mavlink_sys_status_t) ,typeof( __mavlink_rc_channels_raw_t) ,typeof( __mavlink_rc_channels_scaled_t) ,typeof( __mavlink_servo_output_raw_t) ,typeof( __mavlink_scaled_pressure_t) ,typeof( __mavlink_waypoint_t) ,typeof( __mavlink_waypoint_request_t) ,typeof( __mavlink_waypoint_set_current_t) ,typeof( __mavlink_waypoint_current_t) ,typeof( __mavlink_waypoint_request_list_t) ,typeof( __mavlink_waypoint_count_t) ,typeof( __mavlink_waypoint_clear_all_t) ,typeof( __mavlink_waypoint_reached_t) ,typeof( __mavlink_waypoint_ack_t) ,typeof( __mavlink_waypoint_set_global_reference_t ) ,typeof( __mavlink_gps_local_origin_set_t) ,typeof( __mavlink_local_position_setpoint_set_t) ,typeof( __mavlink_local_position_setpoint_t) ,typeof( __mavlink_control_status_t) ,typeof( __mavlink_safety_set_allowed_area_t) ,typeof( __mavlink_safety_allowed_area_t) ,typeof( __mavlink_set_roll_pitch_yaw_thrust_t) ,typeof( __mavlink_set_roll_pitch_yaw_speed_thrust_t) ,typeof( __mavlink_roll_pitch_yaw_thrust_setpoint_t) ,typeof( __mavlink_roll_pitch_yaw_speed_thrust_setpoint_t) ,null ,typeof( __mavlink_attitude_controller_output_t ) ,typeof( __mavlink_position_controller_output_t ) ,typeof( __mavlink_nav_controller_output_t) ,typeof( __mavlink_position_target_t) ,typeof( __mavlink_state_correction_t) ,typeof( __mavlink_set_altitude_t) ,typeof( __mavlink_request_data_stream_t) ,typeof( __mavlink_request_dynamic_gyro_calibration_t ) ,typeof( __mavlink_request_static_calibration_t ) ,typeof( __mavlink_manual_control_t) ,typeof( __mavlink_rc_channels_override_t) ,null ,null ,typeof( __mavlink_global_position_int_t) ,typeof( __mavlink_vfr_hud_t) ,typeof( __mavlink_command_t) ,typeof( __mavlink_command_ack_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_optical_flow_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_object_detection_event_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_sensor_offsets_t) ,typeof( __mavlink_set_mag_offsets_t) ,typeof( __mavlink_meminfo_t) ,typeof( __mavlink_ap_adc_t) ,typeof( __mavlink_digicam_configure_t) ,typeof( __mavlink_digicam_control_t) ,typeof( __mavlink_mount_configure_t) ,typeof( __mavlink_mount_control_t) ,typeof( __mavlink_mount_status_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_debug_vect_t) ,typeof( __mavlink_named_value_float_t) ,typeof( __mavlink_named_value_int_t) ,typeof( __mavlink_statustext_t) ,typeof( __mavlink_debug_t) ,null ,};
|
||||
Type[] mavstructs = new Type[] {typeof( __mavlink_heartbeat_t) ,typeof( __mavlink_boot_t) ,null ,typeof( __mavlink_ping_t) ,null ,typeof( __mavlink_change_operator_control_t) ,typeof( __mavlink_change_operator_control_ack_t) ,typeof( __mavlink_auth_key_t) ,null ,typeof( __mavlink_action_ack_t) ,typeof( __mavlink_action_t) ,typeof( __mavlink_set_mode_t) ,typeof( __mavlink_set_nav_mode_t) ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_param_request_read_t) ,typeof( __mavlink_param_request_list_t) ,typeof( __mavlink_param_value_t) ,typeof( __mavlink_param_set_t) ,null ,typeof( __mavlink_gps_raw_int_t) ,typeof( __mavlink_scaled_imu_t) ,typeof( __mavlink_gps_status_t) ,typeof( __mavlink_raw_imu_t) ,typeof( __mavlink_raw_pressure_t) ,typeof( __mavlink_attitude_t ) ,typeof( __mavlink_local_position_t) ,typeof( __mavlink_gps_raw_t) ,typeof( __mavlink_global_position_t) ,typeof( __mavlink_sys_status_t) ,typeof( __mavlink_rc_channels_raw_t) ,typeof( __mavlink_rc_channels_scaled_t) ,typeof( __mavlink_servo_output_raw_t) ,typeof( __mavlink_scaled_pressure_t) ,typeof( __mavlink_waypoint_t) ,typeof( __mavlink_waypoint_request_t) ,typeof( __mavlink_waypoint_set_current_t) ,typeof( __mavlink_waypoint_current_t) ,typeof( __mavlink_waypoint_request_list_t) ,typeof( __mavlink_waypoint_count_t) ,typeof( __mavlink_waypoint_clear_all_t) ,typeof( __mavlink_waypoint_reached_t) ,typeof( __mavlink_waypoint_ack_t) ,typeof( __mavlink_waypoint_set_global_reference_t ) ,typeof( __mavlink_gps_local_origin_set_t) ,typeof( __mavlink_local_position_setpoint_set_t) ,typeof( __mavlink_local_position_setpoint_t) ,typeof( __mavlink_control_status_t) ,typeof( __mavlink_safety_set_allowed_area_t) ,typeof( __mavlink_safety_allowed_area_t) ,typeof( __mavlink_set_roll_pitch_yaw_thrust_t) ,typeof( __mavlink_set_roll_pitch_yaw_speed_thrust_t) ,typeof( __mavlink_roll_pitch_yaw_thrust_setpoint_t) ,typeof( __mavlink_roll_pitch_yaw_speed_thrust_setpoint_t) ,null ,typeof( __mavlink_attitude_controller_output_t ) ,typeof( __mavlink_position_controller_output_t ) ,typeof( __mavlink_nav_controller_output_t) ,typeof( __mavlink_position_target_t) ,typeof( __mavlink_state_correction_t) ,typeof( __mavlink_set_altitude_t) ,typeof( __mavlink_request_data_stream_t) ,typeof( __mavlink_request_dynamic_gyro_calibration_t ) ,typeof( __mavlink_request_static_calibration_t ) ,typeof( __mavlink_manual_control_t) ,typeof( __mavlink_rc_channels_override_t) ,null ,null ,typeof( __mavlink_global_position_int_t) ,typeof( __mavlink_vfr_hud_t) ,typeof( __mavlink_command_t) ,typeof( __mavlink_command_ack_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_optical_flow_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_object_detection_event_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_sensor_offsets_t) ,typeof( __mavlink_set_mag_offsets_t) ,typeof( __mavlink_meminfo_t) ,typeof( __mavlink_ap_adc_t) ,typeof( __mavlink_digicam_configure_t) ,typeof( __mavlink_digicam_control_t) ,typeof( __mavlink_mount_configure_t) ,typeof( __mavlink_mount_control_t) ,typeof( __mavlink_mount_status_t) ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,null ,typeof( __mavlink_debug_vect_t) ,typeof( __mavlink_named_value_float_t) ,typeof( __mavlink_named_value_int_t) ,typeof( __mavlink_statustext_t) ,typeof( __mavlink_debug_t) ,null ,};
|
||||
|
||||
}
|
||||
#endif
|
||||
|
@ -24,9 +24,10 @@ namespace ArdupilotMega
|
||||
|
||||
Application.Idle += new EventHandler(Application_Idle);
|
||||
|
||||
MessageBox.Show("NOTE: This version may break advanced mission scripting");
|
||||
|
||||
Application.EnableVisualStyles();
|
||||
Application.SetCompatibleTextRenderingDefault(false);
|
||||
//Application.Run(new Camera());
|
||||
Application.Run(new MainV2());
|
||||
}
|
||||
|
||||
|
@ -34,5 +34,5 @@ using System.Resources;
|
||||
// by using the '*' as shown below:
|
||||
// [assembly: AssemblyVersion("1.0.*")]
|
||||
[assembly: AssemblyVersion("1.0.0.0")]
|
||||
[assembly: AssemblyFileVersion("1.0.90")]
|
||||
[assembly: AssemblyFileVersion("1.0.94")]
|
||||
[assembly: NeutralResourcesLanguageAttribute("")]
|
||||
|
446
Tools/ArdupilotMegaPlanner/Setup/Setup.Designer.cs
generated
446
Tools/ArdupilotMegaPlanner/Setup/Setup.Designer.cs
generated
@ -113,18 +113,42 @@
|
||||
this.pictureBoxQuad = new System.Windows.Forms.PictureBox();
|
||||
this.BUT_levelac2 = new ArdupilotMega.MyButton();
|
||||
this.tabHeli = new System.Windows.Forms.TabPage();
|
||||
this.label27 = new System.Windows.Forms.Label();
|
||||
this.GYR_GAIN_ = new System.Windows.Forms.TextBox();
|
||||
this.groupBox3 = new System.Windows.Forms.GroupBox();
|
||||
this.label46 = new System.Windows.Forms.Label();
|
||||
this.label45 = new System.Windows.Forms.Label();
|
||||
this.GYR_ENABLE_ = new System.Windows.Forms.CheckBox();
|
||||
this.GYR_GAIN_ = new System.Windows.Forms.TextBox();
|
||||
this.label44 = new System.Windows.Forms.Label();
|
||||
this.label43 = new System.Windows.Forms.Label();
|
||||
this.label42 = new System.Windows.Forms.Label();
|
||||
this.BUT_HS4save = new ArdupilotMega.MyButton();
|
||||
this.groupBox2 = new System.Windows.Forms.GroupBox();
|
||||
this.label24 = new System.Windows.Forms.Label();
|
||||
this.HS4_MIN = new System.Windows.Forms.TextBox();
|
||||
this.HS4_MAX = new System.Windows.Forms.TextBox();
|
||||
this.label40 = new System.Windows.Forms.Label();
|
||||
this.BUT_swash_manual = new ArdupilotMega.MyButton();
|
||||
this.groupBox1 = new System.Windows.Forms.GroupBox();
|
||||
this.label41 = new System.Windows.Forms.Label();
|
||||
this.label21 = new System.Windows.Forms.Label();
|
||||
this.COL_MIN_ = new System.Windows.Forms.TextBox();
|
||||
this.COL_MID_ = new System.Windows.Forms.TextBox();
|
||||
this.COL_MAX_ = new System.Windows.Forms.TextBox();
|
||||
this.BUT_0collective = new ArdupilotMega.MyButton();
|
||||
this.HS4_TRIM = new System.Windows.Forms.NumericUpDown();
|
||||
this.HS3_TRIM = new System.Windows.Forms.NumericUpDown();
|
||||
this.HS2_TRIM = new System.Windows.Forms.NumericUpDown();
|
||||
this.HS1_TRIM = new System.Windows.Forms.NumericUpDown();
|
||||
this.label39 = new System.Windows.Forms.Label();
|
||||
this.label38 = new System.Windows.Forms.Label();
|
||||
this.label37 = new System.Windows.Forms.Label();
|
||||
this.label36 = new System.Windows.Forms.Label();
|
||||
this.label26 = new System.Windows.Forms.Label();
|
||||
this.PIT_MAX_ = new System.Windows.Forms.TextBox();
|
||||
this.label25 = new System.Windows.Forms.Label();
|
||||
this.ROL_MAX_ = new System.Windows.Forms.TextBox();
|
||||
this.label24 = new System.Windows.Forms.Label();
|
||||
this.COL_MID_ = new System.Windows.Forms.Label();
|
||||
this.label23 = new System.Windows.Forms.Label();
|
||||
this.label22 = new System.Windows.Forms.Label();
|
||||
this.label21 = new System.Windows.Forms.Label();
|
||||
this.HS4_REV = new System.Windows.Forms.CheckBox();
|
||||
this.label20 = new System.Windows.Forms.Label();
|
||||
this.label19 = new System.Windows.Forms.Label();
|
||||
@ -136,14 +160,8 @@
|
||||
this.HS2_REV = new System.Windows.Forms.CheckBox();
|
||||
this.HS1_REV = new System.Windows.Forms.CheckBox();
|
||||
this.label17 = new System.Windows.Forms.Label();
|
||||
this.BUT_saveheliconfig = new ArdupilotMega.MyButton();
|
||||
this.BUT_0collective = new ArdupilotMega.MyButton();
|
||||
this.HS4 = new ArdupilotMega.VerticalProgressBar2();
|
||||
this.HS4 = new ArdupilotMega.HorizontalProgressBar2();
|
||||
this.HS3 = new ArdupilotMega.VerticalProgressBar2();
|
||||
this.HS4_TRIM = new ArdupilotMega.MyTrackBar();
|
||||
this.HS3_TRIM = new ArdupilotMega.MyTrackBar();
|
||||
this.HS2_TRIM = new ArdupilotMega.MyTrackBar();
|
||||
this.HS1_TRIM = new ArdupilotMega.MyTrackBar();
|
||||
this.Gservoloc = new AGaugeApp.AGauge();
|
||||
this.toolTip1 = new System.Windows.Forms.ToolTip(this.components);
|
||||
this.tabControl1.SuspendLayout();
|
||||
@ -161,6 +179,9 @@
|
||||
((System.ComponentModel.ISupportInitialize)(this.pictureBoxQuadX)).BeginInit();
|
||||
((System.ComponentModel.ISupportInitialize)(this.pictureBoxQuad)).BeginInit();
|
||||
this.tabHeli.SuspendLayout();
|
||||
this.groupBox3.SuspendLayout();
|
||||
this.groupBox2.SuspendLayout();
|
||||
this.groupBox1.SuspendLayout();
|
||||
((System.ComponentModel.ISupportInitialize)(this.HS4_TRIM)).BeginInit();
|
||||
((System.ComponentModel.ISupportInitialize)(this.HS3_TRIM)).BeginInit();
|
||||
((System.ComponentModel.ISupportInitialize)(this.HS2_TRIM)).BeginInit();
|
||||
@ -849,18 +870,28 @@
|
||||
//
|
||||
// tabHeli
|
||||
//
|
||||
this.tabHeli.Controls.Add(this.label27);
|
||||
this.tabHeli.Controls.Add(this.GYR_GAIN_);
|
||||
this.tabHeli.Controls.Add(this.GYR_ENABLE_);
|
||||
this.tabHeli.Controls.Add(this.groupBox3);
|
||||
this.tabHeli.Controls.Add(this.label44);
|
||||
this.tabHeli.Controls.Add(this.label43);
|
||||
this.tabHeli.Controls.Add(this.label42);
|
||||
this.tabHeli.Controls.Add(this.BUT_HS4save);
|
||||
this.tabHeli.Controls.Add(this.groupBox2);
|
||||
this.tabHeli.Controls.Add(this.BUT_swash_manual);
|
||||
this.tabHeli.Controls.Add(this.groupBox1);
|
||||
this.tabHeli.Controls.Add(this.HS4_TRIM);
|
||||
this.tabHeli.Controls.Add(this.HS3_TRIM);
|
||||
this.tabHeli.Controls.Add(this.HS2_TRIM);
|
||||
this.tabHeli.Controls.Add(this.HS1_TRIM);
|
||||
this.tabHeli.Controls.Add(this.label39);
|
||||
this.tabHeli.Controls.Add(this.label38);
|
||||
this.tabHeli.Controls.Add(this.label37);
|
||||
this.tabHeli.Controls.Add(this.label36);
|
||||
this.tabHeli.Controls.Add(this.label26);
|
||||
this.tabHeli.Controls.Add(this.PIT_MAX_);
|
||||
this.tabHeli.Controls.Add(this.label25);
|
||||
this.tabHeli.Controls.Add(this.ROL_MAX_);
|
||||
this.tabHeli.Controls.Add(this.label24);
|
||||
this.tabHeli.Controls.Add(this.COL_MID_);
|
||||
this.tabHeli.Controls.Add(this.label23);
|
||||
this.tabHeli.Controls.Add(this.label22);
|
||||
this.tabHeli.Controls.Add(this.label21);
|
||||
this.tabHeli.Controls.Add(this.HS4_REV);
|
||||
this.tabHeli.Controls.Add(this.label20);
|
||||
this.tabHeli.Controls.Add(this.label19);
|
||||
@ -872,29 +903,33 @@
|
||||
this.tabHeli.Controls.Add(this.HS2_REV);
|
||||
this.tabHeli.Controls.Add(this.HS1_REV);
|
||||
this.tabHeli.Controls.Add(this.label17);
|
||||
this.tabHeli.Controls.Add(this.BUT_saveheliconfig);
|
||||
this.tabHeli.Controls.Add(this.BUT_0collective);
|
||||
this.tabHeli.Controls.Add(this.HS4);
|
||||
this.tabHeli.Controls.Add(this.HS3);
|
||||
this.tabHeli.Controls.Add(this.HS4_TRIM);
|
||||
this.tabHeli.Controls.Add(this.HS3_TRIM);
|
||||
this.tabHeli.Controls.Add(this.HS2_TRIM);
|
||||
this.tabHeli.Controls.Add(this.HS1_TRIM);
|
||||
this.tabHeli.Controls.Add(this.Gservoloc);
|
||||
resources.ApplyResources(this.tabHeli, "tabHeli");
|
||||
this.tabHeli.Name = "tabHeli";
|
||||
this.tabHeli.UseVisualStyleBackColor = true;
|
||||
this.tabHeli.Click += new System.EventHandler(this.tabHeli_Click);
|
||||
//
|
||||
// label27
|
||||
// groupBox3
|
||||
//
|
||||
resources.ApplyResources(this.label27, "label27");
|
||||
this.label27.Name = "label27";
|
||||
this.groupBox3.Controls.Add(this.label46);
|
||||
this.groupBox3.Controls.Add(this.label45);
|
||||
this.groupBox3.Controls.Add(this.GYR_ENABLE_);
|
||||
this.groupBox3.Controls.Add(this.GYR_GAIN_);
|
||||
resources.ApplyResources(this.groupBox3, "groupBox3");
|
||||
this.groupBox3.Name = "groupBox3";
|
||||
this.groupBox3.TabStop = false;
|
||||
//
|
||||
// GYR_GAIN_
|
||||
// label46
|
||||
//
|
||||
resources.ApplyResources(this.GYR_GAIN_, "GYR_GAIN_");
|
||||
this.GYR_GAIN_.Name = "GYR_GAIN_";
|
||||
this.GYR_GAIN_.Validating += new System.ComponentModel.CancelEventHandler(this.GYR_GAIN__Validating);
|
||||
resources.ApplyResources(this.label46, "label46");
|
||||
this.label46.Name = "label46";
|
||||
//
|
||||
// label45
|
||||
//
|
||||
resources.ApplyResources(this.label45, "label45");
|
||||
this.label45.Name = "label45";
|
||||
//
|
||||
// GYR_ENABLE_
|
||||
//
|
||||
@ -903,6 +938,232 @@
|
||||
this.GYR_ENABLE_.UseVisualStyleBackColor = true;
|
||||
this.GYR_ENABLE_.CheckedChanged += new System.EventHandler(this.GYR_ENABLE__CheckedChanged);
|
||||
//
|
||||
// GYR_GAIN_
|
||||
//
|
||||
resources.ApplyResources(this.GYR_GAIN_, "GYR_GAIN_");
|
||||
this.GYR_GAIN_.Name = "GYR_GAIN_";
|
||||
this.GYR_GAIN_.Validating += new System.ComponentModel.CancelEventHandler(this.GYR_GAIN__Validating);
|
||||
//
|
||||
// label44
|
||||
//
|
||||
resources.ApplyResources(this.label44, "label44");
|
||||
this.label44.Name = "label44";
|
||||
//
|
||||
// label43
|
||||
//
|
||||
resources.ApplyResources(this.label43, "label43");
|
||||
this.label43.Name = "label43";
|
||||
//
|
||||
// label42
|
||||
//
|
||||
resources.ApplyResources(this.label42, "label42");
|
||||
this.label42.Name = "label42";
|
||||
//
|
||||
// BUT_HS4save
|
||||
//
|
||||
resources.ApplyResources(this.BUT_HS4save, "BUT_HS4save");
|
||||
this.BUT_HS4save.Name = "BUT_HS4save";
|
||||
this.BUT_HS4save.UseVisualStyleBackColor = true;
|
||||
this.BUT_HS4save.Click += new System.EventHandler(this.BUT_HS4save_Click);
|
||||
//
|
||||
// groupBox2
|
||||
//
|
||||
this.groupBox2.Controls.Add(this.label24);
|
||||
this.groupBox2.Controls.Add(this.HS4_MIN);
|
||||
this.groupBox2.Controls.Add(this.HS4_MAX);
|
||||
this.groupBox2.Controls.Add(this.label40);
|
||||
resources.ApplyResources(this.groupBox2, "groupBox2");
|
||||
this.groupBox2.Name = "groupBox2";
|
||||
this.groupBox2.TabStop = false;
|
||||
//
|
||||
// label24
|
||||
//
|
||||
resources.ApplyResources(this.label24, "label24");
|
||||
this.label24.Name = "label24";
|
||||
//
|
||||
// HS4_MIN
|
||||
//
|
||||
resources.ApplyResources(this.HS4_MIN, "HS4_MIN");
|
||||
this.HS4_MIN.Name = "HS4_MIN";
|
||||
this.HS4_MIN.Enter += new System.EventHandler(this.HS4_MIN_Enter);
|
||||
this.HS4_MIN.Leave += new System.EventHandler(this.HS4_MIN_Leave);
|
||||
this.HS4_MIN.Validating += new System.ComponentModel.CancelEventHandler(this.PWM_Validating);
|
||||
//
|
||||
// HS4_MAX
|
||||
//
|
||||
resources.ApplyResources(this.HS4_MAX, "HS4_MAX");
|
||||
this.HS4_MAX.Name = "HS4_MAX";
|
||||
this.HS4_MAX.Enter += new System.EventHandler(this.HS4_MAX_Enter);
|
||||
this.HS4_MAX.Leave += new System.EventHandler(this.HS4_MAX_Leave);
|
||||
this.HS4_MAX.Validating += new System.ComponentModel.CancelEventHandler(this.PWM_Validating);
|
||||
//
|
||||
// label40
|
||||
//
|
||||
resources.ApplyResources(this.label40, "label40");
|
||||
this.label40.Name = "label40";
|
||||
//
|
||||
// BUT_swash_manual
|
||||
//
|
||||
resources.ApplyResources(this.BUT_swash_manual, "BUT_swash_manual");
|
||||
this.BUT_swash_manual.Name = "BUT_swash_manual";
|
||||
this.BUT_swash_manual.UseVisualStyleBackColor = true;
|
||||
this.BUT_swash_manual.Click += new System.EventHandler(this.BUT_swash_manual_Click);
|
||||
//
|
||||
// groupBox1
|
||||
//
|
||||
this.groupBox1.Controls.Add(this.label41);
|
||||
this.groupBox1.Controls.Add(this.label21);
|
||||
this.groupBox1.Controls.Add(this.COL_MIN_);
|
||||
this.groupBox1.Controls.Add(this.COL_MID_);
|
||||
this.groupBox1.Controls.Add(this.COL_MAX_);
|
||||
this.groupBox1.Controls.Add(this.BUT_0collective);
|
||||
resources.ApplyResources(this.groupBox1, "groupBox1");
|
||||
this.groupBox1.Name = "groupBox1";
|
||||
this.groupBox1.TabStop = false;
|
||||
//
|
||||
// label41
|
||||
//
|
||||
resources.ApplyResources(this.label41, "label41");
|
||||
this.label41.Name = "label41";
|
||||
//
|
||||
// label21
|
||||
//
|
||||
resources.ApplyResources(this.label21, "label21");
|
||||
this.label21.Name = "label21";
|
||||
//
|
||||
// COL_MIN_
|
||||
//
|
||||
resources.ApplyResources(this.COL_MIN_, "COL_MIN_");
|
||||
this.COL_MIN_.Name = "COL_MIN_";
|
||||
this.COL_MIN_.Enter += new System.EventHandler(this.COL_MIN__Enter);
|
||||
this.COL_MIN_.Leave += new System.EventHandler(this.COL_MIN__Leave);
|
||||
this.COL_MIN_.Validating += new System.ComponentModel.CancelEventHandler(this.PWM_Validating);
|
||||
//
|
||||
// COL_MID_
|
||||
//
|
||||
resources.ApplyResources(this.COL_MID_, "COL_MID_");
|
||||
this.COL_MID_.Name = "COL_MID_";
|
||||
this.COL_MID_.Validating += new System.ComponentModel.CancelEventHandler(this.PWM_Validating);
|
||||
//
|
||||
// COL_MAX_
|
||||
//
|
||||
resources.ApplyResources(this.COL_MAX_, "COL_MAX_");
|
||||
this.COL_MAX_.Name = "COL_MAX_";
|
||||
this.COL_MAX_.Enter += new System.EventHandler(this.COL_MAX__Enter);
|
||||
this.COL_MAX_.Leave += new System.EventHandler(this.COL_MAX__Leave);
|
||||
this.COL_MAX_.Validating += new System.ComponentModel.CancelEventHandler(this.PWM_Validating);
|
||||
//
|
||||
// BUT_0collective
|
||||
//
|
||||
resources.ApplyResources(this.BUT_0collective, "BUT_0collective");
|
||||
this.BUT_0collective.Name = "BUT_0collective";
|
||||
this.BUT_0collective.UseVisualStyleBackColor = true;
|
||||
this.BUT_0collective.Click += new System.EventHandler(this.BUT_0collective_Click);
|
||||
//
|
||||
// HS4_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS4_TRIM, "HS4_TRIM");
|
||||
this.HS4_TRIM.Maximum = new decimal(new int[] {
|
||||
2000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS4_TRIM.Minimum = new decimal(new int[] {
|
||||
1000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS4_TRIM.Name = "HS4_TRIM";
|
||||
this.HS4_TRIM.Value = new decimal(new int[] {
|
||||
1500,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS4_TRIM.ValueChanged += new System.EventHandler(this.HS4_TRIM_ValueChanged);
|
||||
//
|
||||
// HS3_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS3_TRIM, "HS3_TRIM");
|
||||
this.HS3_TRIM.Maximum = new decimal(new int[] {
|
||||
2000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS3_TRIM.Minimum = new decimal(new int[] {
|
||||
1000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS3_TRIM.Name = "HS3_TRIM";
|
||||
this.HS3_TRIM.Value = new decimal(new int[] {
|
||||
1500,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS3_TRIM.ValueChanged += new System.EventHandler(this.HS3_TRIM_ValueChanged);
|
||||
//
|
||||
// HS2_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS2_TRIM, "HS2_TRIM");
|
||||
this.HS2_TRIM.Maximum = new decimal(new int[] {
|
||||
2000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS2_TRIM.Minimum = new decimal(new int[] {
|
||||
1000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS2_TRIM.Name = "HS2_TRIM";
|
||||
this.HS2_TRIM.Value = new decimal(new int[] {
|
||||
1500,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS2_TRIM.ValueChanged += new System.EventHandler(this.HS2_TRIM_ValueChanged);
|
||||
//
|
||||
// HS1_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS1_TRIM, "HS1_TRIM");
|
||||
this.HS1_TRIM.Maximum = new decimal(new int[] {
|
||||
2000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS1_TRIM.Minimum = new decimal(new int[] {
|
||||
1000,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS1_TRIM.Name = "HS1_TRIM";
|
||||
this.HS1_TRIM.Value = new decimal(new int[] {
|
||||
1500,
|
||||
0,
|
||||
0,
|
||||
0});
|
||||
this.HS1_TRIM.ValueChanged += new System.EventHandler(this.HS1_TRIM_ValueChanged);
|
||||
//
|
||||
// label39
|
||||
//
|
||||
resources.ApplyResources(this.label39, "label39");
|
||||
this.label39.Name = "label39";
|
||||
//
|
||||
// label38
|
||||
//
|
||||
resources.ApplyResources(this.label38, "label38");
|
||||
this.label38.Name = "label38";
|
||||
//
|
||||
// label37
|
||||
//
|
||||
resources.ApplyResources(this.label37, "label37");
|
||||
this.label37.Name = "label37";
|
||||
//
|
||||
// label36
|
||||
//
|
||||
resources.ApplyResources(this.label36, "label36");
|
||||
this.label36.Name = "label36";
|
||||
//
|
||||
// label26
|
||||
//
|
||||
resources.ApplyResources(this.label26, "label26");
|
||||
@ -925,16 +1186,6 @@
|
||||
this.ROL_MAX_.Name = "ROL_MAX_";
|
||||
this.ROL_MAX_.Validating += new System.ComponentModel.CancelEventHandler(this.ROL_MAX__Validating);
|
||||
//
|
||||
// label24
|
||||
//
|
||||
resources.ApplyResources(this.label24, "label24");
|
||||
this.label24.Name = "label24";
|
||||
//
|
||||
// COL_MID_
|
||||
//
|
||||
resources.ApplyResources(this.COL_MID_, "COL_MID_");
|
||||
this.COL_MID_.Name = "COL_MID_";
|
||||
//
|
||||
// label23
|
||||
//
|
||||
resources.ApplyResources(this.label23, "label23");
|
||||
@ -945,11 +1196,6 @@
|
||||
resources.ApplyResources(this.label22, "label22");
|
||||
this.label22.Name = "label22";
|
||||
//
|
||||
// label21
|
||||
//
|
||||
resources.ApplyResources(this.label21, "label21");
|
||||
this.label21.Name = "label21";
|
||||
//
|
||||
// HS4_REV
|
||||
//
|
||||
resources.ApplyResources(this.HS4_REV, "HS4_REV");
|
||||
@ -1016,20 +1262,6 @@
|
||||
resources.ApplyResources(this.label17, "label17");
|
||||
this.label17.Name = "label17";
|
||||
//
|
||||
// BUT_saveheliconfig
|
||||
//
|
||||
resources.ApplyResources(this.BUT_saveheliconfig, "BUT_saveheliconfig");
|
||||
this.BUT_saveheliconfig.Name = "BUT_saveheliconfig";
|
||||
this.BUT_saveheliconfig.UseVisualStyleBackColor = true;
|
||||
this.BUT_saveheliconfig.Click += new System.EventHandler(this.BUT_saveheliconfig_Click);
|
||||
//
|
||||
// BUT_0collective
|
||||
//
|
||||
resources.ApplyResources(this.BUT_0collective, "BUT_0collective");
|
||||
this.BUT_0collective.Name = "BUT_0collective";
|
||||
this.BUT_0collective.UseVisualStyleBackColor = true;
|
||||
this.BUT_0collective.Click += new System.EventHandler(this.BUT_0collective_Click);
|
||||
//
|
||||
// HS4
|
||||
//
|
||||
this.HS4.BackgroundColor = System.Drawing.Color.FromArgb(((int)(((byte)(67)))), ((int)(((byte)(68)))), ((int)(((byte)(69)))));
|
||||
@ -1044,6 +1276,7 @@
|
||||
this.HS4.Name = "HS4";
|
||||
this.HS4.Value = 1500;
|
||||
this.HS4.ValueColor = System.Drawing.Color.FromArgb(((int)(((byte)(148)))), ((int)(((byte)(193)))), ((int)(((byte)(31)))));
|
||||
this.HS4.Paint += new System.Windows.Forms.PaintEventHandler(this.HS4_Paint);
|
||||
//
|
||||
// HS3
|
||||
//
|
||||
@ -1059,54 +1292,7 @@
|
||||
this.HS3.Name = "HS3";
|
||||
this.HS3.Value = 1500;
|
||||
this.HS3.ValueColor = System.Drawing.Color.FromArgb(((int)(((byte)(148)))), ((int)(((byte)(193)))), ((int)(((byte)(31)))));
|
||||
//
|
||||
// HS4_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS4_TRIM, "HS4_TRIM");
|
||||
this.HS4_TRIM.LargeChange = 1000;
|
||||
this.HS4_TRIM.Maximum = 2000D;
|
||||
this.HS4_TRIM.Minimum = 1000D;
|
||||
this.HS4_TRIM.Name = "HS4_TRIM";
|
||||
this.HS4_TRIM.SmallChange = 1000;
|
||||
this.HS4_TRIM.TickFrequency = 2000;
|
||||
this.HS4_TRIM.Value = 1500D;
|
||||
this.HS4_TRIM.Scroll += new System.EventHandler(this.HS4_TRIM_Scroll);
|
||||
//
|
||||
// HS3_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS3_TRIM, "HS3_TRIM");
|
||||
this.HS3_TRIM.LargeChange = 1000;
|
||||
this.HS3_TRIM.Maximum = 2000D;
|
||||
this.HS3_TRIM.Minimum = 1000D;
|
||||
this.HS3_TRIM.Name = "HS3_TRIM";
|
||||
this.HS3_TRIM.SmallChange = 1000;
|
||||
this.HS3_TRIM.TickFrequency = 2000;
|
||||
this.HS3_TRIM.Value = 1500D;
|
||||
this.HS3_TRIM.Scroll += new System.EventHandler(this.HS3_TRIM_Scroll);
|
||||
//
|
||||
// HS2_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS2_TRIM, "HS2_TRIM");
|
||||
this.HS2_TRIM.LargeChange = 1000;
|
||||
this.HS2_TRIM.Maximum = 2000D;
|
||||
this.HS2_TRIM.Minimum = 1000D;
|
||||
this.HS2_TRIM.Name = "HS2_TRIM";
|
||||
this.HS2_TRIM.SmallChange = 1000;
|
||||
this.HS2_TRIM.TickFrequency = 2000;
|
||||
this.HS2_TRIM.Value = 1500D;
|
||||
this.HS2_TRIM.Scroll += new System.EventHandler(this.HS2_TRIM_Scroll);
|
||||
//
|
||||
// HS1_TRIM
|
||||
//
|
||||
resources.ApplyResources(this.HS1_TRIM, "HS1_TRIM");
|
||||
this.HS1_TRIM.LargeChange = 1000;
|
||||
this.HS1_TRIM.Maximum = 2000D;
|
||||
this.HS1_TRIM.Minimum = 1000D;
|
||||
this.HS1_TRIM.Name = "HS1_TRIM";
|
||||
this.HS1_TRIM.SmallChange = 1000;
|
||||
this.HS1_TRIM.TickFrequency = 2000;
|
||||
this.HS1_TRIM.Value = 1500D;
|
||||
this.HS1_TRIM.Scroll += new System.EventHandler(this.HS1_TRIM_Scroll);
|
||||
this.HS3.Paint += new System.Windows.Forms.PaintEventHandler(this.HS3_Paint);
|
||||
//
|
||||
// Gservoloc
|
||||
//
|
||||
@ -1280,6 +1466,12 @@
|
||||
((System.ComponentModel.ISupportInitialize)(this.pictureBoxQuad)).EndInit();
|
||||
this.tabHeli.ResumeLayout(false);
|
||||
this.tabHeli.PerformLayout();
|
||||
this.groupBox3.ResumeLayout(false);
|
||||
this.groupBox3.PerformLayout();
|
||||
this.groupBox2.ResumeLayout(false);
|
||||
this.groupBox2.PerformLayout();
|
||||
this.groupBox1.ResumeLayout(false);
|
||||
this.groupBox1.PerformLayout();
|
||||
((System.ComponentModel.ISupportInitialize)(this.HS4_TRIM)).EndInit();
|
||||
((System.ComponentModel.ISupportInitialize)(this.HS3_TRIM)).EndInit();
|
||||
((System.ComponentModel.ISupportInitialize)(this.HS2_TRIM)).EndInit();
|
||||
@ -1355,26 +1547,17 @@
|
||||
private System.Windows.Forms.TextBox SV2_POS_;
|
||||
private System.Windows.Forms.TextBox SV1_POS_;
|
||||
private System.Windows.Forms.CheckBox HS4_REV;
|
||||
private System.Windows.Forms.Label label21;
|
||||
private System.Windows.Forms.Label label22;
|
||||
private MyTrackBar HS1_TRIM;
|
||||
private MyTrackBar HS4_TRIM;
|
||||
private MyTrackBar HS3_TRIM;
|
||||
private MyTrackBar HS2_TRIM;
|
||||
private System.Windows.Forms.Label label23;
|
||||
private VerticalProgressBar2 HS4;
|
||||
private HorizontalProgressBar2 HS4;
|
||||
private VerticalProgressBar2 HS3;
|
||||
private MyButton BUT_0collective;
|
||||
private MyButton BUT_saveheliconfig;
|
||||
private System.Windows.Forms.Label label24;
|
||||
private System.Windows.Forms.Label COL_MID_;
|
||||
private System.Windows.Forms.Label label25;
|
||||
private System.Windows.Forms.TextBox ROL_MAX_;
|
||||
private System.Windows.Forms.Label label26;
|
||||
private System.Windows.Forms.TextBox PIT_MAX_;
|
||||
private System.Windows.Forms.TextBox GYR_GAIN_;
|
||||
private System.Windows.Forms.CheckBox GYR_ENABLE_;
|
||||
private System.Windows.Forms.Label label27;
|
||||
private System.Windows.Forms.Label label28;
|
||||
private MyButton BUT_levelac2;
|
||||
private System.Windows.Forms.ToolTip toolTip1;
|
||||
@ -1406,6 +1589,33 @@
|
||||
private System.Windows.Forms.Label label34;
|
||||
private System.Windows.Forms.Label label33;
|
||||
private System.Windows.Forms.Label label32;
|
||||
private System.Windows.Forms.NumericUpDown HS1_TRIM;
|
||||
private System.Windows.Forms.Label label39;
|
||||
private System.Windows.Forms.Label label38;
|
||||
private System.Windows.Forms.Label label37;
|
||||
private System.Windows.Forms.Label label36;
|
||||
private System.Windows.Forms.NumericUpDown HS3_TRIM;
|
||||
private System.Windows.Forms.NumericUpDown HS2_TRIM;
|
||||
private System.Windows.Forms.NumericUpDown HS4_TRIM;
|
||||
private System.Windows.Forms.GroupBox groupBox1;
|
||||
private MyButton BUT_swash_manual;
|
||||
private System.Windows.Forms.TextBox COL_MIN_;
|
||||
private System.Windows.Forms.TextBox COL_MID_;
|
||||
private System.Windows.Forms.TextBox COL_MAX_;
|
||||
private System.Windows.Forms.Label label41;
|
||||
private System.Windows.Forms.Label label21;
|
||||
private MyButton BUT_HS4save;
|
||||
private System.Windows.Forms.GroupBox groupBox2;
|
||||
private System.Windows.Forms.Label label24;
|
||||
private System.Windows.Forms.TextBox HS4_MIN;
|
||||
private System.Windows.Forms.TextBox HS4_MAX;
|
||||
private System.Windows.Forms.Label label40;
|
||||
private System.Windows.Forms.Label label42;
|
||||
private System.Windows.Forms.Label label44;
|
||||
private System.Windows.Forms.Label label43;
|
||||
private System.Windows.Forms.GroupBox groupBox3;
|
||||
private System.Windows.Forms.Label label46;
|
||||
private System.Windows.Forms.Label label45;
|
||||
|
||||
}
|
||||
}
|
@ -15,6 +15,8 @@ namespace ArdupilotMega.Setup
|
||||
bool run = false;
|
||||
bool startup = false;
|
||||
|
||||
bool inpwmdetect = false;
|
||||
|
||||
const float rad2deg = (float)(180 / Math.PI);
|
||||
const float deg2rad = (float)(1.0 / rad2deg);
|
||||
|
||||
@ -73,6 +75,9 @@ namespace ArdupilotMega.Setup
|
||||
|
||||
if (tabControl1.SelectedTab == tabHeli)
|
||||
{
|
||||
if (MainV2.comPort.param["HSV_MAN"].ToString() == "0")
|
||||
return;
|
||||
|
||||
if (HS3.minline == 0)
|
||||
HS3.minline = 2200;
|
||||
|
||||
@ -84,6 +89,23 @@ namespace ArdupilotMega.Setup
|
||||
|
||||
HS4.minline = Math.Min(HS4.minline, (int)MainV2.cs.ch4in);
|
||||
HS4.maxline = Math.Max(HS4.maxline, (int)MainV2.cs.ch4in);
|
||||
|
||||
if (!inpwmdetect)
|
||||
{
|
||||
HS3_Paint(null, null);
|
||||
HS4_Paint(null, null);
|
||||
}
|
||||
else
|
||||
{
|
||||
try
|
||||
{
|
||||
HS3.minline = int.Parse(COL_MIN_.Text);
|
||||
HS3.maxline = int.Parse(COL_MAX_.Text);
|
||||
HS4.maxline = int.Parse(HS4_MIN.Text);
|
||||
HS4.minline = int.Parse(HS4_MAX.Text);
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@ -442,6 +464,12 @@ namespace ArdupilotMega.Setup
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HS1_REV.Checked = MainV2.comPort.param["HS1_REV"].ToString() == "-1";
|
||||
HS2_REV.Checked = MainV2.comPort.param["HS2_REV"].ToString() == "-1";
|
||||
HS3_REV.Checked = MainV2.comPort.param["HS3_REV"].ToString() == "-1";
|
||||
HS4_REV.Checked = MainV2.comPort.param["HS4_REV"].ToString() == "-1";
|
||||
|
||||
}
|
||||
catch { }
|
||||
startup = false;
|
||||
@ -848,7 +876,10 @@ namespace ArdupilotMega.Setup
|
||||
|
||||
try
|
||||
{
|
||||
MainV2.comPort.setParam("HSV_MAN", 1); // randy request
|
||||
MainV2.comPort.setParam(((TextBox)sender).Name, test);
|
||||
System.Threading.Thread.Sleep(100);
|
||||
MainV2.comPort.setParam("HSV_MAN", 0); // randy request - last
|
||||
|
||||
}
|
||||
catch { MessageBox.Show("Set " + ((TextBox)sender).Name + " failed"); }
|
||||
@ -868,7 +899,10 @@ namespace ArdupilotMega.Setup
|
||||
|
||||
try
|
||||
{
|
||||
MainV2.comPort.setParam("HSV_MAN", 1); // randy request
|
||||
MainV2.comPort.setParam(((TextBox)sender).Name, test);
|
||||
System.Threading.Thread.Sleep(100);
|
||||
MainV2.comPort.setParam("HSV_MAN", 0); // randy request - last
|
||||
}
|
||||
catch { MessageBox.Show("Set " + ((TextBox)sender).Name + " failed"); }
|
||||
}
|
||||
@ -887,7 +921,10 @@ namespace ArdupilotMega.Setup
|
||||
|
||||
try
|
||||
{
|
||||
MainV2.comPort.setParam("HSV_MAN", 1); // randy request
|
||||
MainV2.comPort.setParam(((TextBox)sender).Name, test);
|
||||
System.Threading.Thread.Sleep(100);
|
||||
MainV2.comPort.setParam("HSV_MAN", 0); // randy request - last
|
||||
}
|
||||
catch { MessageBox.Show("Set " + ((TextBox)sender).Name + " failed"); }
|
||||
}
|
||||
@ -910,56 +947,57 @@ namespace ArdupilotMega.Setup
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == true ? 1.0f : -1.0f);
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == false ? 1.0f : -1.0f);
|
||||
}
|
||||
|
||||
private void HS2_REV_CheckedChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == true ? 1.0f : -1.0f);
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == false ? 1.0f : -1.0f);
|
||||
}
|
||||
|
||||
private void HS3_REV_CheckedChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == true ? 1.0f : -1.0f);
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == false ? 1.0f : -1.0f);
|
||||
}
|
||||
|
||||
private void HS4_REV_CheckedChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == true ? 1.0f : -1.0f);
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == false ? 1.0f : -1.0f);
|
||||
HS4.reverse = !HS4.reverse;
|
||||
}
|
||||
|
||||
private void HS1_TRIM_Scroll(object sender, EventArgs e)
|
||||
private void HS1_TRIM_ValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((MyTrackBar)sender).Name, (float)((MyTrackBar)sender).Value);
|
||||
MainV2.comPort.setParam(((NumericUpDown)sender).Name, (float)((NumericUpDown)sender).Value);
|
||||
}
|
||||
|
||||
private void HS2_TRIM_Scroll(object sender, EventArgs e)
|
||||
private void HS2_TRIM_ValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((MyTrackBar)sender).Name, (float)((MyTrackBar)sender).Value);
|
||||
MainV2.comPort.setParam(((NumericUpDown)sender).Name, (float)((NumericUpDown)sender).Value);
|
||||
}
|
||||
|
||||
private void HS3_TRIM_Scroll(object sender, EventArgs e)
|
||||
private void HS3_TRIM_ValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((MyTrackBar)sender).Name, (float)((MyTrackBar)sender).Value);
|
||||
MainV2.comPort.setParam(((NumericUpDown)sender).Name, (float)((NumericUpDown)sender).Value);
|
||||
}
|
||||
|
||||
private void HS4_TRIM_Scroll(object sender, EventArgs e)
|
||||
private void HS4_TRIM_ValueChanged(object sender, EventArgs e)
|
||||
{
|
||||
if (startup)
|
||||
return;
|
||||
MainV2.comPort.setParam(((MyTrackBar)sender).Name, (float)((MyTrackBar)sender).Value);
|
||||
MainV2.comPort.setParam(((NumericUpDown)sender).Name, (float)((NumericUpDown)sender).Value);
|
||||
}
|
||||
|
||||
private void ROL_MAX__Validating(object sender, CancelEventArgs e)
|
||||
@ -1012,19 +1050,6 @@ namespace ArdupilotMega.Setup
|
||||
MainV2.comPort.setParam(((CheckBox)sender).Name, ((CheckBox)sender).Checked == true ? 1.0f : 0.0f);
|
||||
}
|
||||
|
||||
private void BUT_saveheliconfig_Click(object sender, EventArgs e)
|
||||
{
|
||||
try
|
||||
{
|
||||
MainV2.comPort.setParam("COL_MIN_", HS3.minline);
|
||||
MainV2.comPort.setParam("COL_MAX_", HS3.maxline);
|
||||
|
||||
MainV2.comPort.setParam("HS4_MIN", HS4.minline);
|
||||
MainV2.comPort.setParam("HS4_MAX", HS4.maxline);
|
||||
}
|
||||
catch { MessageBox.Show("Failed to set min/max"); }
|
||||
}
|
||||
|
||||
private void BUT_levelac2_Click(object sender, EventArgs e)
|
||||
{
|
||||
try
|
||||
@ -1107,5 +1132,127 @@ namespace ArdupilotMega.Setup
|
||||
{
|
||||
reverseChannel("RC4_REV", ((CheckBox)sender).Checked, BARyaw);
|
||||
}
|
||||
|
||||
private void BUT_swash_manual_Click(object sender, EventArgs e)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (MainV2.comPort.param["HSV_MAN"].ToString() == "1")
|
||||
{
|
||||
MainV2.comPort.setParam("COL_MIN_", int.Parse(COL_MIN_.Text));
|
||||
MainV2.comPort.setParam("COL_MAX_", int.Parse(COL_MAX_.Text));
|
||||
MainV2.comPort.setParam("HSV_MAN", 0); // randy request - last
|
||||
BUT_swash_manual.Text = "Manual";
|
||||
}
|
||||
else
|
||||
{
|
||||
COL_MAX_.Text = "1500";
|
||||
COL_MIN_.Text = "1500";
|
||||
MainV2.comPort.setParam("HSV_MAN", 1); // randy request
|
||||
BUT_swash_manual.Text = "Save";
|
||||
}
|
||||
}
|
||||
catch { MessageBox.Show("Failed to set HSV_MAN"); }
|
||||
}
|
||||
|
||||
private void BUT_HS4save_Click(object sender, EventArgs e)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (MainV2.comPort.param["HSV_MAN"].ToString() == "1")
|
||||
{
|
||||
MainV2.comPort.setParam("HS4_MIN", int.Parse(HS4_MIN.Text));
|
||||
MainV2.comPort.setParam("HS4_MAX", int.Parse(HS4_MAX.Text));
|
||||
MainV2.comPort.setParam("HSV_MAN", 0); // randy request - last
|
||||
BUT_HS4save.Text = "Manual";
|
||||
}
|
||||
else
|
||||
{
|
||||
HS4_MIN.Text = "1500";
|
||||
HS4_MAX.Text = "1500";
|
||||
MainV2.comPort.setParam("HSV_MAN", 1); // randy request
|
||||
BUT_HS4save.Text = "Save";
|
||||
}
|
||||
}
|
||||
catch { MessageBox.Show("Failed to set HSV_MAN"); }
|
||||
}
|
||||
|
||||
private void tabHeli_Click(object sender, EventArgs e)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
private void HS4_Paint(object sender, PaintEventArgs e)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (int.Parse(HS4_MIN.Text) > HS4.minline)
|
||||
HS4_MIN.Text = HS4.minline.ToString();
|
||||
if (int.Parse(HS4_MAX.Text) < HS4.maxline)
|
||||
HS4_MAX.Text = HS4.maxline.ToString();
|
||||
} catch {}
|
||||
}
|
||||
|
||||
private void HS3_Paint(object sender, PaintEventArgs e)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (int.Parse(COL_MIN_.Text) > HS3.minline)
|
||||
COL_MIN_.Text = HS3.minline.ToString();
|
||||
if (int.Parse(COL_MAX_.Text) < HS3.maxline)
|
||||
COL_MAX_.Text = HS3.maxline.ToString();
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
|
||||
private void COL_MAX__Enter(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = true;
|
||||
}
|
||||
|
||||
private void COL_MIN__Enter(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = true;
|
||||
}
|
||||
|
||||
private void COL_MAX__Leave(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = false;
|
||||
}
|
||||
|
||||
private void COL_MIN__Leave(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = false;
|
||||
}
|
||||
|
||||
private void HS4_MIN_Enter(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = true;
|
||||
}
|
||||
|
||||
private void HS4_MIN_Leave(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = false;
|
||||
}
|
||||
|
||||
private void HS4_MAX_Enter(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = true;
|
||||
}
|
||||
|
||||
private void HS4_MAX_Leave(object sender, EventArgs e)
|
||||
{
|
||||
inpwmdetect = false;
|
||||
}
|
||||
|
||||
private void PWM_Validating(object sender, CancelEventArgs e)
|
||||
{
|
||||
Control temp = (Control)(sender);
|
||||
|
||||
if (int.Parse(temp.Text) < 900)
|
||||
temp.Text = "900";
|
||||
if (int.Parse(temp.Text) > 2100)
|
||||
temp.Text = "2100";
|
||||
}
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -4,14 +4,14 @@
|
||||
<description asmv2:publisher="Michael Oborne" asmv2:product="ArdupilotMegaPlanner" xmlns="urn:schemas-microsoft-com:asm.v1" />
|
||||
<deployment install="true" />
|
||||
<dependency>
|
||||
<dependentAssembly dependencyType="install" codebase="ArdupilotMegaPlanner.exe.manifest" size="18145">
|
||||
<dependentAssembly dependencyType="install" codebase="ArdupilotMegaPlanner.exe.manifest" size="18547">
|
||||
<assemblyIdentity name="ArdupilotMegaPlanner.exe" version="0.0.0.1" publicKeyToken="0000000000000000" language="en-US" processorArchitecture="x86" type="win32" />
|
||||
<hash>
|
||||
<dsig:Transforms>
|
||||
<dsig:Transform Algorithm="urn:schemas-microsoft-com:HashTransforms.Identity" />
|
||||
</dsig:Transforms>
|
||||
<dsig:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1" />
|
||||
<dsig:DigestValue>asA4p3xM8idcyyuyecIXR3bVsug=</dsig:DigestValue>
|
||||
<dsig:DigestValue>N43U7y77mNy6nfkD9v5DNdwNLps=</dsig:DigestValue>
|
||||
</hash>
|
||||
</dependentAssembly>
|
||||
</dependency>
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
62
Tools/ArdupilotMegaPlanner/bin/Release/mavcmd.xml
Normal file
62
Tools/ArdupilotMegaPlanner/bin/Release/mavcmd.xml
Normal file
@ -0,0 +1,62 @@
|
||||
<?xml version="1.0"?>
|
||||
<!-- TAGS ARE CASE SENSATIVE -->
|
||||
<CMD>
|
||||
<AC2>
|
||||
<WAYPOINT><P1>Delay</P1><P2>Hit Rad</P2><P3></P3><P4>Yaw Ang</P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></WAYPOINT>
|
||||
<LOITER_UNLIM><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_UNLIM>
|
||||
<LOITER_TURNS><P1>Turns</P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_TURNS>
|
||||
<LOITER_TIME><P1>Time s</P1><P2></P2><P3>rad</P3><P4>yaw per</P4><X></X><Y></Y><Z></Z></LOITER_TIME>
|
||||
<RETURN_TO_LAUNCH><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></RETURN_TO_LAUNCH>
|
||||
<LAND><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></LAND>
|
||||
<TAKEOFF><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></TAKEOFF>
|
||||
<ROI><P1>MAV_ROI</P1><P2>WP#</P2><P3>ROI#</P3><P4></P4><X></X><Y></Y><Z></Z></ROI>
|
||||
<PATHPLANNING><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></PATHPLANNING>
|
||||
<CONDITION_DELAY><P1>Time (sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DELAY>
|
||||
<CONDITION_CHANGE_ALT><P1>Rate (cm/sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></CONDITION_CHANGE_ALT>
|
||||
<CONDITION_DISTANCE><P1>Dist (m)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DISTANCE>
|
||||
<CONDITION_YAW><P1>Deg</P1><P2>Sec</P2><P3>Dir 1=CW</P3><P4>rel/abs</P4><X></X><Y></Y><Z></Z></CONDITION_YAW>
|
||||
<DO_SET_MODE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_MODE>
|
||||
<DO_JUMP><P1>WP #</P1><P2>Repeat#</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_JUMP>
|
||||
<DO_CHANGE_SPEED><P1>Type (0=as 1=gs)</P1><P2>Throttle(%)</P2><P3>Speed (m/s)</P3><P4></P4><X></X><Y></Y><Z></Z></DO_CHANGE_SPEED>
|
||||
<DO_SET_HOME><P1>Current(1)/Spec(0)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_HOME>
|
||||
<DO_SET_PARAMETER><P1>#</P1><P2>Value</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_PARAMETER>
|
||||
<DO_SET_RELAY><P1>off(0)/on(1)</P1><P2>Delay (s)</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_RELAY>
|
||||
<DO_REPEAT_RELAY><P1></P1><P2>Delay (s)</P2><P3>Repeat#</P3><P4></P4><X></X><Y></Y><Z></Z></DO_REPEAT_RELAY>
|
||||
<DO_SET_SERVO><P1>Ser No</P1><P2>PWM</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_SERVO>
|
||||
<DO_REPEAT_SERVO><P1>Ser No</P1><P2>Repeat#</P2><P3>Delay (s)</P3><P4>PWM</P4><X></X><Y></Y><Z></Z></DO_REPEAT_SERVO>
|
||||
<DO_DIGICAM_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONFIGURE>
|
||||
<DO_DIGICAM_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONTROL>
|
||||
<DO_MOUNT_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONFIGURE>
|
||||
<DO_MOUNT_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONTROL>
|
||||
|
||||
</AC2>
|
||||
<!-- -->
|
||||
<APM>
|
||||
<WAYPOINT><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></WAYPOINT>
|
||||
<LOITER_UNLIM><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_UNLIM>
|
||||
<LOITER_TURNS><P1>Turns</P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_TURNS>
|
||||
<LOITER_TIME><P1>Time s</P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_TIME>
|
||||
<RETURN_TO_LAUNCH><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></RETURN_TO_LAUNCH>
|
||||
<LAND><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LAND>
|
||||
<TAKEOFF><P1>Angle</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></TAKEOFF>
|
||||
<ROI><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></ROI>
|
||||
<PATHPLANNING><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></PATHPLANNING>
|
||||
<CONDITION_DELAY><P1>Time (sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DELAY>
|
||||
<CONDITION_CHANGE_ALT><P1>Rate (cm/sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></CONDITION_CHANGE_ALT>
|
||||
<CONDITION_DISTANCE><P1>Dist (m)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DISTANCE>
|
||||
<CONDITION_YAW><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_YAW>
|
||||
<DO_SET_MODE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_MODE>
|
||||
<DO_JUMP><P1>WP #</P1><P2>Repeat#</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_JUMP>
|
||||
<DO_CHANGE_SPEED><P1>Type (0=as 1=gs)</P1><P2>Throttle(%)</P2><P3>Speed (m/s)</P3><P4></P4><X></X><Y></Y><Z></Z></DO_CHANGE_SPEED>
|
||||
<DO_SET_HOME><P1>Current(1)/Spec(0)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_HOME>
|
||||
<DO_SET_PARAMETER><P1>#</P1><P2>Value</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_PARAMETER>
|
||||
<DO_SET_RELAY><P1>off(0)/on(1)</P1><P2>Delay (s)</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_RELAY>
|
||||
<DO_REPEAT_RELAY><P1></P1><P2>Delay (s)</P2><P3>Repeat#</P3><P4></P4><X></X><Y></Y><Z></Z></DO_REPEAT_RELAY>
|
||||
<DO_SET_SERVO><P1>Ser No</P1><P2>PWM</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_SERVO>
|
||||
<DO_REPEAT_SERVO><P1>Ser No</P1><P2>Repeat#</P2><P3>Delay (s)</P3><P4>PWM</P4><X></X><Y></Y><Z></Z></DO_REPEAT_SERVO>
|
||||
<DO_DIGICAM_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONFIGURE>
|
||||
<DO_DIGICAM_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONTROL>
|
||||
<DO_MOUNT_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONFIGURE>
|
||||
<DO_MOUNT_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONTROL>
|
||||
</APM>
|
||||
</CMD>
|
62
Tools/ArdupilotMegaPlanner/mavcmd.xml
Normal file
62
Tools/ArdupilotMegaPlanner/mavcmd.xml
Normal file
@ -0,0 +1,62 @@
|
||||
<?xml version="1.0"?>
|
||||
<!-- TAGS ARE CASE SENSATIVE -->
|
||||
<CMD>
|
||||
<AC2>
|
||||
<WAYPOINT><P1>Delay</P1><P2>Hit Rad</P2><P3></P3><P4>Yaw Ang</P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></WAYPOINT>
|
||||
<LOITER_UNLIM><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_UNLIM>
|
||||
<LOITER_TURNS><P1>Turns</P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_TURNS>
|
||||
<LOITER_TIME><P1>Time s</P1><P2></P2><P3>rad</P3><P4>yaw per</P4><X></X><Y></Y><Z></Z></LOITER_TIME>
|
||||
<RETURN_TO_LAUNCH><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></RETURN_TO_LAUNCH>
|
||||
<LAND><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></LAND>
|
||||
<TAKEOFF><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></TAKEOFF>
|
||||
<ROI><P1>MAV_ROI</P1><P2>WP#</P2><P3>ROI#</P3><P4></P4><X></X><Y></Y><Z></Z></ROI>
|
||||
<PATHPLANNING><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></PATHPLANNING>
|
||||
<CONDITION_DELAY><P1>Time (sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DELAY>
|
||||
<CONDITION_CHANGE_ALT><P1>Rate (cm/sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></CONDITION_CHANGE_ALT>
|
||||
<CONDITION_DISTANCE><P1>Dist (m)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DISTANCE>
|
||||
<CONDITION_YAW><P1>Deg</P1><P2>Sec</P2><P3>Dir 1=CW</P3><P4>rel/abs</P4><X></X><Y></Y><Z></Z></CONDITION_YAW>
|
||||
<DO_SET_MODE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_MODE>
|
||||
<DO_JUMP><P1>WP #</P1><P2>Repeat#</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_JUMP>
|
||||
<DO_CHANGE_SPEED><P1>Type (0=as 1=gs)</P1><P2>Throttle(%)</P2><P3>Speed (m/s)</P3><P4></P4><X></X><Y></Y><Z></Z></DO_CHANGE_SPEED>
|
||||
<DO_SET_HOME><P1>Current(1)/Spec(0)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_HOME>
|
||||
<DO_SET_PARAMETER><P1>#</P1><P2>Value</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_PARAMETER>
|
||||
<DO_SET_RELAY><P1>off(0)/on(1)</P1><P2>Delay (s)</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_RELAY>
|
||||
<DO_REPEAT_RELAY><P1></P1><P2>Delay (s)</P2><P3>Repeat#</P3><P4></P4><X></X><Y></Y><Z></Z></DO_REPEAT_RELAY>
|
||||
<DO_SET_SERVO><P1>Ser No</P1><P2>PWM</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_SERVO>
|
||||
<DO_REPEAT_SERVO><P1>Ser No</P1><P2>Repeat#</P2><P3>Delay (s)</P3><P4>PWM</P4><X></X><Y></Y><Z></Z></DO_REPEAT_SERVO>
|
||||
<DO_DIGICAM_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONFIGURE>
|
||||
<DO_DIGICAM_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONTROL>
|
||||
<DO_MOUNT_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONFIGURE>
|
||||
<DO_MOUNT_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONTROL>
|
||||
|
||||
</AC2>
|
||||
<!-- -->
|
||||
<APM>
|
||||
<WAYPOINT><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></WAYPOINT>
|
||||
<LOITER_UNLIM><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_UNLIM>
|
||||
<LOITER_TURNS><P1>Turns</P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_TURNS>
|
||||
<LOITER_TIME><P1>Time s</P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LOITER_TIME>
|
||||
<RETURN_TO_LAUNCH><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></RETURN_TO_LAUNCH>
|
||||
<LAND><P1></P1><P2></P2><P3></P3><P4></P4><X>Lat</X><Y>Long</Y><Z>Alt</Z></LAND>
|
||||
<TAKEOFF><P1>Angle</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></TAKEOFF>
|
||||
<ROI><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></ROI>
|
||||
<PATHPLANNING><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></PATHPLANNING>
|
||||
<CONDITION_DELAY><P1>Time (sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DELAY>
|
||||
<CONDITION_CHANGE_ALT><P1>Rate (cm/sec)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z>Alt</Z></CONDITION_CHANGE_ALT>
|
||||
<CONDITION_DISTANCE><P1>Dist (m)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_DISTANCE>
|
||||
<CONDITION_YAW><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></CONDITION_YAW>
|
||||
<DO_SET_MODE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_MODE>
|
||||
<DO_JUMP><P1>WP #</P1><P2>Repeat#</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_JUMP>
|
||||
<DO_CHANGE_SPEED><P1>Type (0=as 1=gs)</P1><P2>Throttle(%)</P2><P3>Speed (m/s)</P3><P4></P4><X></X><Y></Y><Z></Z></DO_CHANGE_SPEED>
|
||||
<DO_SET_HOME><P1>Current(1)/Spec(0)</P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_HOME>
|
||||
<DO_SET_PARAMETER><P1>#</P1><P2>Value</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_PARAMETER>
|
||||
<DO_SET_RELAY><P1>off(0)/on(1)</P1><P2>Delay (s)</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_RELAY>
|
||||
<DO_REPEAT_RELAY><P1></P1><P2>Delay (s)</P2><P3>Repeat#</P3><P4></P4><X></X><Y></Y><Z></Z></DO_REPEAT_RELAY>
|
||||
<DO_SET_SERVO><P1>Ser No</P1><P2>PWM</P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_SET_SERVO>
|
||||
<DO_REPEAT_SERVO><P1>Ser No</P1><P2>Repeat#</P2><P3>Delay (s)</P3><P4>PWM</P4><X></X><Y></Y><Z></Z></DO_REPEAT_SERVO>
|
||||
<DO_DIGICAM_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONFIGURE>
|
||||
<DO_DIGICAM_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_DIGICAM_CONTROL>
|
||||
<DO_MOUNT_CONFIGURE><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONFIGURE>
|
||||
<DO_MOUNT_CONTROL><P1></P1><P2></P2><P3></P3><P4></P4><X></X><Y></Y><Z></Z></DO_MOUNT_CONTROL>
|
||||
</APM>
|
||||
</CMD>
|
@ -24,9 +24,9 @@ RC7_TRIM 1500.000000
|
||||
RC8_MAX 2000.000000
|
||||
RC8_MIN 1000.000000
|
||||
RC8_TRIM 1500.000000
|
||||
FLTMODE1 3
|
||||
FLTMODE2 1
|
||||
FLTMODE3 2
|
||||
FLTMODE4 6
|
||||
FLTMODE5 5
|
||||
FLTMODE1 7
|
||||
FLTMODE2 1
|
||||
FLTMODE3 2
|
||||
FLTMODE4 3
|
||||
FLTMODE5 5
|
||||
FLTMODE6 0
|
||||
|
38
Tools/autotest/ArduPlane.parm
Normal file
38
Tools/autotest/ArduPlane.parm
Normal file
@ -0,0 +1,38 @@
|
||||
LOG_BITMASK 4095
|
||||
SWITCH_ENABLE 0
|
||||
RC2_REV -1
|
||||
RC1_MAX 2000
|
||||
RC1_MIN 1000
|
||||
RC1_TRIM 1500
|
||||
RC2_MAX 2000
|
||||
RC2_MIN 1000
|
||||
RC2_TRIM 1500
|
||||
RC3_MAX 2000
|
||||
RC3_MIN 1000
|
||||
RC3_TRIM 1500
|
||||
RC4_MAX 2000
|
||||
RC4_MIN 1000
|
||||
RC4_TRIM 1500
|
||||
RC5_MAX 2000
|
||||
RC5_MIN 1000
|
||||
RC5_TRIM 1500
|
||||
RC6_MAX 2000
|
||||
RC6_MIN 1000
|
||||
RC6_TRIM 1500
|
||||
RC7_MAX 2000
|
||||
RC7_MIN 1000
|
||||
RC7_TRIM 1500
|
||||
RC8_MAX 2000
|
||||
RC8_MIN 1000
|
||||
RC8_TRIM 1500
|
||||
FLTMODE1 10
|
||||
FLTMODE2 11
|
||||
FLTMODE3 12
|
||||
FLTMODE4 5
|
||||
FLTMODE5 2
|
||||
FLTMODE6 0
|
||||
FLTMODE_CH 8
|
||||
PTCH2SRV_P 2
|
||||
RLL2SRV_I 0.1
|
||||
RLL2SRV_P 1.2
|
||||
INVERTEDFLT_CH 7
|
7
Tools/autotest/ap1.txt
Normal file
7
Tools/autotest/ap1.txt
Normal file
@ -0,0 +1,7 @@
|
||||
QGC WPL 110
|
||||
0 1 0 16 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 582.000000 1
|
||||
1 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.361553 149.163956 120.000000 1
|
||||
2 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.364540 149.162857 120.000000 1
|
||||
3 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.361721 149.161835 120.000000 1
|
||||
4 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.364170 149.164627 120.000000 1
|
||||
5 0 3 20 0.000000 0.000000 0.000000 0.000000 -35.363289 149.165253 50.000000 1
|
@ -1,94 +1,24 @@
|
||||
# fly ArduCopter in SIL
|
||||
|
||||
import util, pexpect, sys, time, math, shutil, os
|
||||
from common import *
|
||||
|
||||
# get location of scripts
|
||||
testdir=os.path.dirname(os.path.realpath(__file__))
|
||||
|
||||
sys.path.insert(0, util.reltopdir('../pymavlink'))
|
||||
import mavutil
|
||||
import mavutil, mavwp
|
||||
|
||||
HOME_LOCATION='-35.362938,149.165085,584,270'
|
||||
|
||||
homeloc = None
|
||||
num_wp = 0
|
||||
|
||||
# a list of pexpect objects to read while waiting for
|
||||
# messages. This keeps the output to stdout flowing
|
||||
expect_list = []
|
||||
|
||||
def message_hook(mav, msg):
|
||||
'''called as each mavlink msg is received'''
|
||||
global expect_list
|
||||
if msg.get_type() in [ 'NAV_CONTROLLER_OUTPUT', 'GPS_RAW' ]:
|
||||
print(msg)
|
||||
for p in expect_list:
|
||||
try:
|
||||
p.read_nonblocking(100, timeout=0)
|
||||
except pexpect.TIMEOUT:
|
||||
pass
|
||||
|
||||
def expect_callback(e):
|
||||
'''called when waiting for a expect pattern'''
|
||||
global expect_list
|
||||
for p in expect_list:
|
||||
if p == e:
|
||||
continue
|
||||
try:
|
||||
while p.read_nonblocking(100, timeout=0):
|
||||
pass
|
||||
except pexpect.TIMEOUT:
|
||||
pass
|
||||
|
||||
|
||||
class location(object):
|
||||
'''represent a GPS coordinate'''
|
||||
def __init__(self, lat, lng, alt=0):
|
||||
self.lat = lat
|
||||
self.lng = lng
|
||||
self.alt = alt
|
||||
|
||||
def get_distance(loc1, loc2):
|
||||
'''get ground distance between two locations'''
|
||||
dlat = loc2.lat - loc1.lat
|
||||
dlong = loc2.lng - loc1.lng
|
||||
return math.sqrt((dlat*dlat) + (dlong*dlong)) * 1.113195e5
|
||||
|
||||
def get_bearing(loc1, loc2):
|
||||
'''get bearing from loc1 to loc2'''
|
||||
off_x = loc2.lng - loc1.lng
|
||||
off_y = loc2.lat - loc1.lat
|
||||
bearing = 90.00 + math.atan2(-off_y, off_x) * 57.2957795
|
||||
if bearing < 0:
|
||||
bearing += 360.00
|
||||
return bearing;
|
||||
|
||||
def current_location(mav):
|
||||
'''return current location'''
|
||||
# ensure we have a position
|
||||
mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
return location(mav.messages['GPS_RAW'].lat,
|
||||
mav.messages['GPS_RAW'].lon,
|
||||
mav.messages['VFR_HUD'].alt)
|
||||
|
||||
def wait_altitude(mav, alt_min, alt_max, timeout=30):
|
||||
'''wait for a given altitude range'''
|
||||
tstart = time.time()
|
||||
print("Waiting for altitude between %u and %u" % (alt_min, alt_max))
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("Altitude %u" % m.alt)
|
||||
if m.alt >= alt_min and m.alt <= alt_max:
|
||||
return True
|
||||
print("Failed to attain altitude range")
|
||||
return False
|
||||
|
||||
|
||||
def arm_motors(mavproxy):
|
||||
def arm_motors(mavproxy, mav):
|
||||
'''arm motors'''
|
||||
print("Arming motors")
|
||||
mavproxy.send('switch 6\n') # stabilize mode
|
||||
mavproxy.expect('STABILIZE>')
|
||||
wait_mode(mav, 'STABILIZE')
|
||||
mavproxy.send('rc 3 1000\n')
|
||||
mavproxy.send('rc 4 2000\n')
|
||||
mavproxy.expect('APM: ARMING MOTORS')
|
||||
@ -96,7 +26,7 @@ def arm_motors(mavproxy):
|
||||
print("MOTORS ARMED OK")
|
||||
return True
|
||||
|
||||
def disarm_motors(mavproxy):
|
||||
def disarm_motors(mavproxy, mav):
|
||||
'''disarm motors'''
|
||||
print("Disarming motors")
|
||||
mavproxy.send('switch 6\n') # stabilize mode
|
||||
@ -111,7 +41,7 @@ def disarm_motors(mavproxy):
|
||||
def takeoff(mavproxy, mav):
|
||||
'''takeoff get to 30m altitude'''
|
||||
mavproxy.send('switch 6\n') # stabilize mode
|
||||
mavproxy.expect('STABILIZE>')
|
||||
wait_mode(mav, 'STABILIZE')
|
||||
mavproxy.send('rc 3 1500\n')
|
||||
wait_altitude(mav, 30, 40)
|
||||
print("TAKEOFF COMPLETE")
|
||||
@ -121,9 +51,7 @@ def takeoff(mavproxy, mav):
|
||||
def loiter(mavproxy, mav, maxaltchange=10, holdtime=10, timeout=60):
|
||||
'''hold loiter position'''
|
||||
mavproxy.send('switch 5\n') # loiter mode
|
||||
mavproxy.expect('LOITER>')
|
||||
mavproxy.send('status\n')
|
||||
mavproxy.expect('>')
|
||||
wait_mode(mav, 'LOITER')
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
start_altitude = m.alt
|
||||
tstart = time.time()
|
||||
@ -141,58 +69,17 @@ def loiter(mavproxy, mav, maxaltchange=10, holdtime=10, timeout=60):
|
||||
return False
|
||||
|
||||
|
||||
def wait_heading(mav, heading, accuracy=5, timeout=30):
|
||||
'''wait for a given heading'''
|
||||
tstart = time.time()
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("Heading %u" % m.heading)
|
||||
if math.fabs(m.heading - heading) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain heading %u" % heading)
|
||||
return False
|
||||
|
||||
|
||||
def wait_distance(mav, distance, accuracy=5, timeout=30):
|
||||
'''wait for flight of a given distance'''
|
||||
tstart = time.time()
|
||||
start = current_location(mav)
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
pos = current_location(mav)
|
||||
delta = get_distance(start, pos)
|
||||
print("Distance %.2f meters" % delta)
|
||||
if math.fabs(delta - distance) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain distance %u" % distance)
|
||||
return False
|
||||
|
||||
|
||||
def wait_location(mav, loc, accuracy=5, timeout=30, target_altitude=None, height_accuracy=-1):
|
||||
'''wait for arrival at a location'''
|
||||
tstart = time.time()
|
||||
if target_altitude is None:
|
||||
target_altitude = loc.alt
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
pos = current_location(mav)
|
||||
delta = get_distance(loc, pos)
|
||||
print("Distance %.2f meters" % delta)
|
||||
if delta <= accuracy:
|
||||
if height_accuracy != -1 and math.fabs(pos.alt - target_altitude) > height_accuracy:
|
||||
continue
|
||||
print("Reached location (%.2f meters)" % delta)
|
||||
return True
|
||||
print("Failed to attain location")
|
||||
return False
|
||||
|
||||
|
||||
def fly_square(mavproxy, mav, side=50, timeout=120):
|
||||
'''fly a square, flying N then E'''
|
||||
mavproxy.send('switch 6\n')
|
||||
mavproxy.expect('STABILIZE>')
|
||||
wait_mode(mav, 'STABILIZE')
|
||||
tstart = time.time()
|
||||
failed = False
|
||||
|
||||
print("Save WP 1")
|
||||
save_wp(mavproxy, mav)
|
||||
|
||||
print("turn")
|
||||
mavproxy.send('rc 3 1430\n')
|
||||
mavproxy.send('rc 4 1610\n')
|
||||
if not wait_heading(mav, 0):
|
||||
@ -205,23 +92,37 @@ def fly_square(mavproxy, mav, side=50, timeout=120):
|
||||
failed = True
|
||||
mavproxy.send('rc 2 1500\n')
|
||||
|
||||
print("Save WP 2")
|
||||
save_wp(mavproxy, mav)
|
||||
|
||||
print("Going east %u meters" % side)
|
||||
mavproxy.send('rc 1 1610\n')
|
||||
if not wait_distance(mav, side):
|
||||
failed = True
|
||||
mavproxy.send('rc 1 1500\n')
|
||||
|
||||
print("Save WP 3")
|
||||
save_wp(mavproxy, mav)
|
||||
|
||||
print("Going south %u meters" % side)
|
||||
mavproxy.send('rc 2 1610\n')
|
||||
if not wait_distance(mav, side):
|
||||
failed = True
|
||||
mavproxy.send('rc 2 1500\n')
|
||||
mav.recv_match(condition='RC_CHANNELS_RAW.chan7_raw==1000', blocking=True)
|
||||
|
||||
print("Save WP 4")
|
||||
save_wp(mavproxy, mav)
|
||||
|
||||
print("Going west %u meters" % side)
|
||||
mavproxy.send('rc 1 1390\n')
|
||||
if not wait_distance(mav, side):
|
||||
failed = True
|
||||
mavproxy.send('rc 1 1500\n')
|
||||
|
||||
print("Save WP 5")
|
||||
save_wp(mavproxy, mav)
|
||||
|
||||
return not failed
|
||||
|
||||
|
||||
@ -231,9 +132,7 @@ def land(mavproxy, mav, timeout=60):
|
||||
'''land the quad'''
|
||||
print("STARTING LANDING")
|
||||
mavproxy.send('switch 6\n')
|
||||
mavproxy.expect('STABILIZE>')
|
||||
mavproxy.send('status\n')
|
||||
mavproxy.expect('>')
|
||||
wait_mode(mav, 'STABILIZE')
|
||||
|
||||
# start by dropping throttle till we have lost 5m
|
||||
mavproxy.send('rc 3 1380\n')
|
||||
@ -243,29 +142,78 @@ def land(mavproxy, mav, timeout=60):
|
||||
# now let it settle gently
|
||||
mavproxy.send('rc 3 1400\n')
|
||||
tstart = time.time()
|
||||
if wait_altitude(mav, -5, 0):
|
||||
print("LANDING OK")
|
||||
return True
|
||||
else:
|
||||
print("LANDING FAILED")
|
||||
return False
|
||||
|
||||
ret = wait_altitude(mav, -5, 0)
|
||||
print("LANDING: ok=%s" % ret)
|
||||
return ret
|
||||
|
||||
|
||||
def fly_mission(mavproxy, mav, filename, height_accuracy=-1, target_altitude=None):
|
||||
def circle(mavproxy, mav, maxaltchange=10, holdtime=90, timeout=35):
|
||||
'''fly circle'''
|
||||
print("FLY CIRCLE")
|
||||
mavproxy.send('switch 1\n') # CIRCLE mode
|
||||
wait_mode(mav, 'CIRCLE')
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
start_altitude = m.alt
|
||||
tstart = time.time()
|
||||
tholdstart = time.time()
|
||||
print("Circle at %u meters for %u seconds" % (start_altitude, holdtime))
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("heading %u" % m.heading)
|
||||
|
||||
print("CIRCLE OK for %u seconds" % holdtime)
|
||||
return True
|
||||
|
||||
|
||||
def fly_mission(mavproxy, mav, height_accuracy=-1, target_altitude=None):
|
||||
'''fly a mission from a file'''
|
||||
global homeloc
|
||||
global num_wp
|
||||
print("test: Fly a mission from 0 to %u" % num_wp)
|
||||
mavproxy.send('wp set 0\n')
|
||||
mavproxy.send('switch 4\n') # auto mode
|
||||
wait_mode(mav, 'AUTO')
|
||||
#wait_altitude(mav, 30, 40)
|
||||
ret = wait_waypoint(mav, 0, num_wp, timeout=90)
|
||||
print("test: MISSION COMPLETE: passed=%s" % ret)
|
||||
# wait here until ready
|
||||
mavproxy.send('switch 5\n')
|
||||
wait_mode(mav, 'LOITER')
|
||||
|
||||
return ret
|
||||
|
||||
#if not wait_distance(mav, 30, timeout=120):
|
||||
# return False
|
||||
#if not wait_location(mav, homeloc, timeout=600, target_altitude=target_altitude, height_accuracy=height_accuracy):
|
||||
# return False
|
||||
|
||||
|
||||
def load_mission_from_file(mavproxy, mav, filename):
|
||||
'''load a mission from a file'''
|
||||
global num_wp
|
||||
wploader = mavwp.MAVWPLoader()
|
||||
wploader.load(filename)
|
||||
num_wp = wploader.count()
|
||||
print("loaded mission with %u waypoints" % num_wp)
|
||||
return True
|
||||
|
||||
def upload_mission_from_file(mavproxy, mav, filename):
|
||||
'''Upload a mission from a file to APM'''
|
||||
global num_wp
|
||||
mavproxy.send('wp load %s\n' % filename)
|
||||
mavproxy.expect('flight plan received')
|
||||
mavproxy.send('wp list\n')
|
||||
mavproxy.expect('Requesting [0-9]+ waypoints')
|
||||
mavproxy.send('switch 1\n') # auto mode
|
||||
mavproxy.expect('AUTO>')
|
||||
if not wait_distance(mav, 30, timeout=120):
|
||||
return False
|
||||
if not wait_location(mav, homeloc, timeout=600, target_altitude=target_altitude, height_accuracy=height_accuracy):
|
||||
return False
|
||||
return True
|
||||
|
||||
def save_mission_to_file(mavproxy, mav, filename):
|
||||
global num_wp
|
||||
mavproxy.send('wp save %s\n' % filename)
|
||||
mavproxy.expect('Saved ([0-9]+) waypoints')
|
||||
num_wp = int(mavproxy.match.group(1))
|
||||
print("num_wp: %d" % num_wp)
|
||||
return True
|
||||
|
||||
def setup_rc(mavproxy):
|
||||
'''setup RC override control'''
|
||||
@ -275,8 +223,12 @@ def setup_rc(mavproxy):
|
||||
mavproxy.send('rc 3 1000\n')
|
||||
|
||||
|
||||
def fly_ArduCopter():
|
||||
'''fly ArduCopter in SIL'''
|
||||
def fly_ArduCopter(viewerip=None):
|
||||
'''fly ArduCopter in SIL
|
||||
|
||||
you can pass viewerip as an IP address to optionally send fg and
|
||||
mavproxy packets too for local viewing of the flight in real time
|
||||
'''
|
||||
global expect_list, homeloc
|
||||
|
||||
sil = util.start_SIL('ArduCopter', wipe=True)
|
||||
@ -295,12 +247,13 @@ def fly_ArduCopter():
|
||||
mavproxy.expect('Loaded [0-9]+ parameters')
|
||||
|
||||
# reboot with new parameters
|
||||
print("CLOSING")
|
||||
util.pexpect_close(mavproxy)
|
||||
util.pexpect_close(sil)
|
||||
print("CLOSED THEM")
|
||||
sil = util.start_SIL('ArduCopter')
|
||||
mavproxy = util.start_MAVProxy_SIL('ArduCopter', options='--fgout=127.0.0.1:5502 --fgin=127.0.0.1:5501 --out=127.0.0.1:19550 --out=192.168.2.15:14550 --quadcopter --streamrate=1')
|
||||
options = '--fgout=127.0.0.1:5502 --fgin=127.0.0.1:5501 --out=127.0.0.1:19550 --quadcopter --streamrate=1'
|
||||
if viewerip:
|
||||
options += ' --out=%s:14550' % viewerip
|
||||
mavproxy = util.start_MAVProxy_SIL('ArduCopter', options=options)
|
||||
mavproxy.expect('Logging to (\S+)')
|
||||
logfile = mavproxy.match.group(1)
|
||||
print("LOGFILE %s" % logfile)
|
||||
@ -317,8 +270,10 @@ def fly_ArduCopter():
|
||||
util.expect_setup_callback(mavproxy, expect_callback)
|
||||
|
||||
# start hil_quad.py
|
||||
hquad = pexpect.spawn(util.reltopdir('../HILTest/hil_quad.py') + ' --fgout=192.168.2.15:9123 --fgrate=200 --home=%s' % HOME_LOCATION,
|
||||
logfile=sys.stdout, timeout=10)
|
||||
cmd = util.reltopdir('../HILTest/hil_quad.py') + ' --fgrate=200 --home=%s' % HOME_LOCATION
|
||||
if viewerip:
|
||||
cmd += ' --fgout=192.168.2.15:9123'
|
||||
hquad = pexpect.spawn(cmd, logfile=sys.stdout, timeout=10)
|
||||
util.pexpect_autoclose(hquad)
|
||||
hquad.expect('Starting at')
|
||||
|
||||
@ -332,28 +287,65 @@ def fly_ArduCopter():
|
||||
raise
|
||||
mav.message_hooks.append(message_hook)
|
||||
|
||||
|
||||
failed = False
|
||||
e = 'None'
|
||||
try:
|
||||
mav.wait_heartbeat()
|
||||
mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
setup_rc(mavproxy)
|
||||
homeloc = current_location(mav)
|
||||
if not arm_motors(mavproxy):
|
||||
if not arm_motors(mavproxy, mav):
|
||||
failed = True
|
||||
|
||||
if not takeoff(mavproxy, mav):
|
||||
failed = True
|
||||
|
||||
print("# Fly A square")
|
||||
if not fly_square(mavproxy, mav):
|
||||
failed = True
|
||||
|
||||
# save the stored mission
|
||||
print("# Save out the C7 mission")
|
||||
if not save_mission_to_file(mavproxy, mav, os.path.join(testdir, "ch7_mission.txt")):
|
||||
failed = True
|
||||
|
||||
# Loiter for 10 seconds
|
||||
print("# Loiter for 10 seconds")
|
||||
if not loiter(mavproxy, mav):
|
||||
failed = True
|
||||
|
||||
#Fly a circle for 60 seconds
|
||||
print("# Fly a Circle")
|
||||
if not circle(mavproxy, mav):
|
||||
failed = True
|
||||
|
||||
# save the stored mission
|
||||
print("# Fly CH 7 saved mission")
|
||||
if not fly_mission(mavproxy, mav,height_accuracy = 0.5, target_altitude=10):
|
||||
failed = True
|
||||
|
||||
print("# Upload mission1")
|
||||
if not upload_mission_from_file(mavproxy, mav, os.path.join(testdir, "mission1.txt")):
|
||||
failed = True
|
||||
|
||||
# this grabs our mission count
|
||||
print("# store mission1 locally")
|
||||
if not load_mission_from_file(mavproxy, mav, os.path.join(testdir, "mission1.txt")):
|
||||
failed = True
|
||||
|
||||
print("# Fly mission 1")
|
||||
if not fly_mission(mavproxy, mav,height_accuracy = 0.5, target_altitude=10):
|
||||
failed = True
|
||||
else:
|
||||
print("Flew mission1 OK")
|
||||
|
||||
print("# Land")
|
||||
if not land(mavproxy, mav):
|
||||
failed = True
|
||||
#fly_mission(mavproxy, mav, os.path.join(testdir, "mission_ttt.txt"), height_accuracy=0.2)
|
||||
if not fly_mission(mavproxy, mav, os.path.join(testdir, "mission1.txt"), height_accuracy = 0.5, target_altitude=10):
|
||||
failed = True
|
||||
if not land(mavproxy, mav):
|
||||
failed = True
|
||||
if not disarm_motors(mavproxy):
|
||||
|
||||
print("# disarm motors")
|
||||
if not disarm_motors(mavproxy, mav):
|
||||
failed = True
|
||||
except pexpect.TIMEOUT, e:
|
||||
failed = True
|
||||
|
332
Tools/autotest/arduplane.py
Normal file
332
Tools/autotest/arduplane.py
Normal file
@ -0,0 +1,332 @@
|
||||
# fly ArduPlane in SIL
|
||||
|
||||
import util, pexpect, sys, time, math, shutil, os
|
||||
from common import *
|
||||
|
||||
# get location of scripts
|
||||
testdir=os.path.dirname(os.path.realpath(__file__))
|
||||
|
||||
sys.path.insert(0, util.reltopdir('../pymavlink'))
|
||||
import mavutil
|
||||
|
||||
HOME_LOCATION='-35.362938,149.165085,584,270'
|
||||
|
||||
homeloc = None
|
||||
|
||||
def takeoff(mavproxy, mav):
|
||||
'''takeoff get to 30m altitude'''
|
||||
mavproxy.send('switch 4\n')
|
||||
wait_mode(mav, 'FBWA')
|
||||
|
||||
# some rudder to counteract the prop torque
|
||||
mavproxy.send('rc 4 1600\n')
|
||||
|
||||
# get it moving a bit first to avoid bad fgear ground physics
|
||||
mavproxy.send('rc 3 1150\n')
|
||||
mav.recv_match(condition='VFR_HUD.groundspeed>3', blocking=True)
|
||||
|
||||
# a bit faster
|
||||
mavproxy.send('rc 3 1600\n')
|
||||
mav.recv_match(condition='VFR_HUD.groundspeed>10', blocking=True)
|
||||
|
||||
# hit the gas harder now, and give it some elevator
|
||||
mavproxy.send('rc 4 1500\n')
|
||||
mavproxy.send('rc 2 1200\n')
|
||||
mavproxy.send('rc 3 1800\n')
|
||||
|
||||
# gain a bit of altitude
|
||||
wait_altitude(mav, homeloc.alt+30, homeloc.alt+40, timeout=30)
|
||||
|
||||
# level off
|
||||
mavproxy.send('rc 2 1500\n')
|
||||
|
||||
print("TAKEOFF COMPLETE")
|
||||
return True
|
||||
|
||||
def fly_left_circuit(mavproxy, mav):
|
||||
'''fly a left circuit, 200m on a side'''
|
||||
mavproxy.send('switch 4\n')
|
||||
wait_mode(mav, 'FBWA')
|
||||
wait_level_flight(mavproxy, mav)
|
||||
|
||||
print("Flying left circuit")
|
||||
# do 4 turns
|
||||
for i in range(0,4):
|
||||
# hard left
|
||||
print("Starting turn %u" % i)
|
||||
mavproxy.send('rc 1 1000\n')
|
||||
wait_heading(mav, 270 - (90*i))
|
||||
mavproxy.send('rc 1 1500\n')
|
||||
print("Starting leg %u" % i)
|
||||
wait_distance(mav, 100)
|
||||
print("Circuit complete")
|
||||
return True
|
||||
|
||||
def fly_RTL(mavproxy, mav):
|
||||
'''fly to home'''
|
||||
mavproxy.send('switch 2\n')
|
||||
wait_mode(mav, 'RTL')
|
||||
wait_location(mav, homeloc, accuracy=30,
|
||||
target_altitude=100, height_accuracy=10)
|
||||
print("RTL Complete")
|
||||
return True
|
||||
|
||||
def fly_LOITER(mavproxy, mav):
|
||||
'''loiter where we are'''
|
||||
mavproxy.send('switch 3\n')
|
||||
wait_mode(mav, 'LOITER')
|
||||
while True:
|
||||
wait_heading(mav, 0)
|
||||
wait_heading(mav, 180)
|
||||
return True
|
||||
|
||||
|
||||
def wait_level_flight(mavproxy, mav, accuracy=5, timeout=30):
|
||||
'''wait for level flight'''
|
||||
tstart = time.time()
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='ATTITUDE', blocking=True)
|
||||
roll = math.degrees(m.roll)
|
||||
pitch = math.degrees(m.pitch)
|
||||
print("Roll=%.1f Pitch=%.1f" % (roll, pitch))
|
||||
if math.fabs(roll) <= accuracy and math.fabs(pitch) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain level flight")
|
||||
return False
|
||||
|
||||
|
||||
def change_altitude(mavproxy, mav, altitude, accuracy=10):
|
||||
'''get to a given altitude'''
|
||||
mavproxy.send('switch 4\n')
|
||||
wait_mode(mav, 'FBWA')
|
||||
alt_error = mav.messages['VFR_HUD'].alt - altitude
|
||||
if alt_error > 0:
|
||||
mavproxy.send('rc 2 2000\n')
|
||||
else:
|
||||
mavproxy.send('rc 2 1000\n')
|
||||
wait_altitude(mav, altitude-accuracy/2, altitude+accuracy/2)
|
||||
mavproxy.send('rc 2 1500\n')
|
||||
print("Reached target altitude at %u" % mav.messages['VFR_HUD'].alt)
|
||||
return wait_level_flight(mavproxy, mav)
|
||||
|
||||
|
||||
def axial_left_roll(mavproxy, mav, count=1):
|
||||
'''fly a left axial roll'''
|
||||
# full throttle!
|
||||
mavproxy.send('rc 3 2000\n')
|
||||
change_altitude(mavproxy, mav, homeloc.alt+200)
|
||||
|
||||
# fly the roll in manual
|
||||
mavproxy.send('switch 6\n')
|
||||
wait_mode(mav, 'MANUAL')
|
||||
|
||||
while count > 0:
|
||||
print("Starting roll")
|
||||
mavproxy.send('rc 1 1000\n')
|
||||
wait_roll(mav, -150, accuracy=20)
|
||||
wait_roll(mav, 150, accuracy=20)
|
||||
wait_roll(mav, 0, accuracy=20)
|
||||
count -= 1
|
||||
|
||||
# back to FBWA
|
||||
mavproxy.send('rc 1 1500\n')
|
||||
mavproxy.send('switch 4\n')
|
||||
wait_mode(mav, 'FBWA')
|
||||
mavproxy.send('rc 3 1700\n')
|
||||
return wait_level_flight(mavproxy, mav)
|
||||
|
||||
|
||||
def inside_loop(mavproxy, mav, count=1):
|
||||
'''fly a inside loop'''
|
||||
# full throttle!
|
||||
mavproxy.send('rc 3 2000\n')
|
||||
change_altitude(mavproxy, mav, homeloc.alt+200)
|
||||
|
||||
# fly the loop in manual
|
||||
mavproxy.send('switch 6\n')
|
||||
wait_mode(mav, 'MANUAL')
|
||||
|
||||
while count > 0:
|
||||
print("Starting loop")
|
||||
mavproxy.send('rc 2 1000\n')
|
||||
wait_pitch(mav, 80, accuracy=20)
|
||||
wait_pitch(mav, 0, accuracy=20)
|
||||
count -= 1
|
||||
|
||||
# back to FBWA
|
||||
mavproxy.send('rc 2 1500\n')
|
||||
mavproxy.send('switch 4\n')
|
||||
wait_mode(mav, 'FBWA')
|
||||
mavproxy.send('rc 3 1700\n')
|
||||
return wait_level_flight(mavproxy, mav)
|
||||
|
||||
|
||||
|
||||
def setup_rc(mavproxy):
|
||||
'''setup RC override control'''
|
||||
for chan in [1,2,4,5,6,7]:
|
||||
mavproxy.send('rc %u 1500\n' % chan)
|
||||
mavproxy.send('rc 3 1000\n')
|
||||
mavproxy.send('rc 8 1800\n')
|
||||
|
||||
|
||||
def fly_mission(mavproxy, mav, filename, height_accuracy=-1, target_altitude=None):
|
||||
'''fly a mission from a file'''
|
||||
global homeloc
|
||||
mavproxy.send('wp load %s\n' % filename)
|
||||
mavproxy.expect('flight plan received')
|
||||
mavproxy.send('wp list\n')
|
||||
mavproxy.expect('Requesting [0-9]+ waypoints')
|
||||
mavproxy.send('switch 1\n') # auto mode
|
||||
wait_mode(mav, 'AUTO')
|
||||
if not wait_distance(mav, 30, timeout=120):
|
||||
return False
|
||||
if not wait_location(mav, homeloc, accuracy=50, timeout=600, target_altitude=target_altitude, height_accuracy=height_accuracy):
|
||||
return False
|
||||
print("Mission OK")
|
||||
return True
|
||||
|
||||
|
||||
def fly_ArduPlane(viewerip=None):
|
||||
'''fly ArduPlane in SIL
|
||||
|
||||
you can pass viewerip as an IP address to optionally send fg and
|
||||
mavproxy packets too for local viewing of the flight in real time
|
||||
'''
|
||||
global expect_list, homeloc
|
||||
|
||||
options = '--fgout=127.0.0.1:5502 --fgin=127.0.0.1:5501 --out=127.0.0.1:19550 --streamrate=5'
|
||||
if viewerip:
|
||||
options += ' --out=%s:14550' % viewerip
|
||||
|
||||
sil = util.start_SIL('ArduPlane', wipe=True)
|
||||
mavproxy = util.start_MAVProxy_SIL('ArduPlane', options=options)
|
||||
mavproxy.expect('Received [0-9]+ parameters')
|
||||
|
||||
# setup test parameters
|
||||
mavproxy.send("param load %s/ArduPlane.parm\n" % testdir)
|
||||
mavproxy.expect('Loaded [0-9]+ parameters')
|
||||
|
||||
# restart with new parms
|
||||
util.pexpect_close(mavproxy)
|
||||
util.pexpect_close(sil)
|
||||
|
||||
sil = util.start_SIL('ArduPlane')
|
||||
mavproxy = util.start_MAVProxy_SIL('ArduPlane', options=options)
|
||||
mavproxy.expect('Logging to (\S+)')
|
||||
logfile = mavproxy.match.group(1)
|
||||
print("LOGFILE %s" % logfile)
|
||||
|
||||
buildlog = util.reltopdir("../buildlogs/ArduPlane-test.mavlog")
|
||||
print("buildlog=%s" % buildlog)
|
||||
if os.path.exists(buildlog):
|
||||
os.unlink(buildlog)
|
||||
os.link(logfile, buildlog)
|
||||
|
||||
mavproxy.expect('Received [0-9]+ parameters')
|
||||
|
||||
util.expect_setup_callback(mavproxy, expect_callback)
|
||||
|
||||
fg_scenery = os.getenv("FG_SCENERY")
|
||||
if not fg_scenery:
|
||||
raise RuntimeError("You must set the FG_SCENERY environment variable")
|
||||
|
||||
fgear_options = '''
|
||||
--generic=socket,in,25,,5502,udp,MAVLink \
|
||||
--generic=socket,out,50,,5501,udp,MAVLink \
|
||||
--aircraft=Rascal110-JSBSim \
|
||||
--control=mouse \
|
||||
--disable-intro-music \
|
||||
--airport=YKRY \
|
||||
--lat=-35.362851 \
|
||||
--lon=149.165223 \
|
||||
--heading=350 \
|
||||
--altitude=0 \
|
||||
--geometry=650x550 \
|
||||
--jpg-httpd=5502 \
|
||||
--disable-anti-alias-hud \
|
||||
--disable-hud-3d \
|
||||
--disable-enhanced-lighting \
|
||||
--disable-distance-attenuation \
|
||||
--disable-horizon-effect \
|
||||
--shading-flat \
|
||||
--disable-textures \
|
||||
--timeofday=noon \
|
||||
--fdm=jsb \
|
||||
--disable-sound \
|
||||
--disable-fullscreen \
|
||||
--disable-random-objects \
|
||||
--disable-ai-models \
|
||||
--shading-flat \
|
||||
--fog-disable \
|
||||
--disable-specular-highlight \
|
||||
--disable-skyblend \
|
||||
--fg-scenery=%s \
|
||||
--disable-anti-alias-hud \
|
||||
--wind=0@0 \
|
||||
''' % fg_scenery
|
||||
# start fgear
|
||||
if os.getenv('DISPLAY'):
|
||||
cmd = 'fgfs %s' % fgear_options
|
||||
fgear = pexpect.spawn(cmd, logfile=sys.stdout, timeout=10)
|
||||
else:
|
||||
cmd = "xvfb-run --server-num=42 -s '-screen 0 800x600x24' fgfs --enable-wireframe %s" % fgear_options
|
||||
util.kill_xvfb(42)
|
||||
fgear = pexpect.spawn(cmd, logfile=sys.stdout, timeout=10)
|
||||
fgear.xvfb_server_num = 42
|
||||
util.pexpect_autoclose(fgear)
|
||||
fgear.expect('creating 3D noise', timeout=30)
|
||||
|
||||
expect_list.extend([fgear, sil, mavproxy])
|
||||
|
||||
# get a mavlink connection going
|
||||
try:
|
||||
mav = mavutil.mavlink_connection('127.0.0.1:19550', robust_parsing=True)
|
||||
except Exception, msg:
|
||||
print("Failed to start mavlink connection on 127.0.0.1:19550" % msg)
|
||||
raise
|
||||
mav.message_hooks.append(message_hook)
|
||||
|
||||
failed = False
|
||||
e = 'None'
|
||||
try:
|
||||
mav.wait_heartbeat()
|
||||
setup_rc(mavproxy)
|
||||
mav.recv_match(type='GPS_RAW', condition='GPS_RAW.lat != 0 and GPS_RAW.alt != 0 and VFR_HUD.alt != 0',
|
||||
blocking=True)
|
||||
homeloc = current_location(mav)
|
||||
print("Home location: %s" % homeloc)
|
||||
if not takeoff(mavproxy, mav):
|
||||
print("Failed takeoff")
|
||||
failed = True
|
||||
if not fly_left_circuit(mavproxy, mav):
|
||||
print("Failed left circuit")
|
||||
failed = True
|
||||
if not axial_left_roll(mavproxy, mav, 1):
|
||||
print("Failed left roll")
|
||||
failed = True
|
||||
if not inside_loop(mavproxy, mav):
|
||||
print("Failed inside loop")
|
||||
failed = True
|
||||
if not fly_RTL(mavproxy, mav):
|
||||
print("Failed RTL")
|
||||
failed = True
|
||||
if not fly_mission(mavproxy, mav, os.path.join(testdir, "ap1.txt"), height_accuracy = 10,
|
||||
target_altitude=homeloc.alt+100):
|
||||
print("Failed mission")
|
||||
failed = True
|
||||
except pexpect.TIMEOUT, e:
|
||||
failed = True
|
||||
|
||||
util.pexpect_close(mavproxy)
|
||||
util.pexpect_close(sil)
|
||||
util.pexpect_close(fgear)
|
||||
|
||||
if os.path.exists('ArduPlane-valgrind.log'):
|
||||
os.chmod('ArduPlane-valgrind.log', 0644)
|
||||
shutil.copy("ArduPlane-valgrind.log", util.reltopdir("../buildlogs/ArduPlane-valgrind.log"))
|
||||
|
||||
if failed:
|
||||
print("FAILED: %s" % e)
|
||||
return False
|
||||
return True
|
@ -2,7 +2,8 @@
|
||||
# APM automatic test suite
|
||||
# Andrew Tridgell, October 2011
|
||||
|
||||
import pexpect, os, util, sys, shutil, arducopter
|
||||
import pexpect, os, util, sys, shutil
|
||||
import arducopter, arduplane
|
||||
import optparse, fnmatch, time, glob, traceback
|
||||
|
||||
os.putenv('TMPDIR', util.reltopdir('tmp'))
|
||||
@ -58,7 +59,8 @@ def convert_gpx():
|
||||
util.run_cmd(util.reltopdir("../pymavlink/examples/mavtogpx.py") + " --nofixcheck " + m)
|
||||
gpx = m + '.gpx'
|
||||
kml = m + '.kml'
|
||||
util.run_cmd('gpsbabel -i gpx -f %s -o kml,units=m,floating=1 -F %s' % (gpx, kml), checkfail=False)
|
||||
util.run_cmd('gpsbabel -i gpx -f %s -o kml,units=m,floating=1,extrude=1 -F %s' % (gpx, kml), checkfail=False)
|
||||
util.run_cmd('zip %s.kmz %s.kml' % (m, m), checkfail=False)
|
||||
return True
|
||||
|
||||
|
||||
@ -75,12 +77,14 @@ You can get it from git://git.samba.org/tridge/UAV/HILTest.git
|
||||
''' % util.reltopdir('../HILTest'))
|
||||
return False
|
||||
return True
|
||||
|
||||
|
||||
|
||||
############## main program #############
|
||||
parser = optparse.OptionParser("autotest")
|
||||
parser.add_option("--skip", type='string', default='', help='list of steps to skip (comma separated)')
|
||||
parser.add_option("--list", action='store_true', default=False, help='list the available steps')
|
||||
parser.add_option("--viewerip", default=None, help='IP address to send MAVLink and fg packets to')
|
||||
parser.add_option("--experimental", default=False, action='store_true', help='enable experimental tests')
|
||||
|
||||
opts, args = parser.parse_args()
|
||||
|
||||
@ -90,6 +94,7 @@ steps = [
|
||||
'build2560.ArduPlane',
|
||||
'build.ArduPlane',
|
||||
'defaults.ArduPlane',
|
||||
'fly.ArduPlane',
|
||||
'logs.ArduPlane',
|
||||
'build1280.ArduCopter',
|
||||
'build2560.ArduCopter',
|
||||
@ -147,6 +152,12 @@ def run_step(step):
|
||||
if step == 'fly.ArduCopter':
|
||||
return arducopter.fly_ArduCopter()
|
||||
|
||||
if step == 'fly.ArduPlane':
|
||||
if not opts.experimental:
|
||||
print("DISABLED: use --experimental to enable fly.ArduPlane")
|
||||
return True
|
||||
return arduplane.fly_ArduPlane(viewerip=opts.viewerip)
|
||||
|
||||
if step == 'convertgpx':
|
||||
return convert_gpx()
|
||||
|
||||
@ -240,7 +251,7 @@ def run_tests(steps):
|
||||
results.addglob('DataFlash Log', '*.flashlog')
|
||||
results.addglob("MAVLink log", '*.mavlog')
|
||||
results.addglob("GPX track", '*.gpx')
|
||||
results.addglob("KML track", '*.kml')
|
||||
results.addglob("KMZ track", '*.kmz')
|
||||
results.addfile('ArduPlane build log', 'ArduPlane.txt')
|
||||
results.addfile('ArduPlane code size', 'ArduPlane.sizes.txt')
|
||||
results.addfile('ArduPlane stack sizes', 'ArduPlane.framesizes.txt')
|
||||
|
196
Tools/autotest/common.py
Normal file
196
Tools/autotest/common.py
Normal file
@ -0,0 +1,196 @@
|
||||
import util, pexpect, time, math
|
||||
|
||||
# a list of pexpect objects to read while waiting for
|
||||
# messages. This keeps the output to stdout flowing
|
||||
expect_list = []
|
||||
|
||||
def message_hook(mav, msg):
|
||||
'''called as each mavlink msg is received'''
|
||||
global expect_list
|
||||
# if msg.get_type() in [ 'NAV_CONTROLLER_OUTPUT', 'GPS_RAW' ]:
|
||||
# print(msg)
|
||||
for p in expect_list:
|
||||
try:
|
||||
p.read_nonblocking(100, timeout=0)
|
||||
except pexpect.TIMEOUT:
|
||||
pass
|
||||
|
||||
def expect_callback(e):
|
||||
'''called when waiting for a expect pattern'''
|
||||
global expect_list
|
||||
for p in expect_list:
|
||||
if p == e:
|
||||
continue
|
||||
try:
|
||||
while p.read_nonblocking(100, timeout=0):
|
||||
pass
|
||||
except pexpect.TIMEOUT:
|
||||
pass
|
||||
|
||||
|
||||
class location(object):
|
||||
'''represent a GPS coordinate'''
|
||||
def __init__(self, lat, lng, alt=0):
|
||||
self.lat = lat
|
||||
self.lng = lng
|
||||
self.alt = alt
|
||||
|
||||
def __str__(self):
|
||||
return "lat=%.6f,lon=%.6f,alt=%.1f" % (self.lat, self.lng, self.alt)
|
||||
|
||||
def get_distance(loc1, loc2):
|
||||
'''get ground distance between two locations'''
|
||||
dlat = loc2.lat - loc1.lat
|
||||
dlong = loc2.lng - loc1.lng
|
||||
return math.sqrt((dlat*dlat) + (dlong*dlong)) * 1.113195e5
|
||||
|
||||
def get_bearing(loc1, loc2):
|
||||
'''get bearing from loc1 to loc2'''
|
||||
off_x = loc2.lng - loc1.lng
|
||||
off_y = loc2.lat - loc1.lat
|
||||
bearing = 90.00 + math.atan2(-off_y, off_x) * 57.2957795
|
||||
if bearing < 0:
|
||||
bearing += 360.00
|
||||
return bearing;
|
||||
|
||||
def current_location(mav):
|
||||
'''return current location'''
|
||||
# ensure we have a position
|
||||
mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
return location(mav.messages['GPS_RAW'].lat,
|
||||
mav.messages['GPS_RAW'].lon,
|
||||
mav.messages['VFR_HUD'].alt)
|
||||
|
||||
def wait_altitude(mav, alt_min, alt_max, timeout=30):
|
||||
'''wait for a given altitude range'''
|
||||
tstart = time.time()
|
||||
print("Waiting for altitude between %u and %u" % (alt_min, alt_max))
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("Altitude %u" % m.alt)
|
||||
if m.alt >= alt_min and m.alt <= alt_max:
|
||||
return True
|
||||
print("Failed to attain altitude range")
|
||||
return False
|
||||
|
||||
|
||||
def wait_roll(mav, roll, accuracy, timeout=30):
|
||||
'''wait for a given roll in degrees'''
|
||||
tstart = time.time()
|
||||
print("Waiting for roll of %u" % roll)
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='ATTITUDE', blocking=True)
|
||||
r = math.degrees(m.roll)
|
||||
print("Roll %u" % r)
|
||||
if math.fabs(r - roll) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain roll %u" % roll)
|
||||
return False
|
||||
|
||||
def wait_pitch(mav, pitch, accuracy, timeout=30):
|
||||
'''wait for a given pitch in degrees'''
|
||||
tstart = time.time()
|
||||
print("Waiting for pitch of %u" % pitch)
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='ATTITUDE', blocking=True)
|
||||
r = math.degrees(m.pitch)
|
||||
print("Pitch %u" % r)
|
||||
if math.fabs(r - pitch) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain pitch %u" % pitch)
|
||||
return False
|
||||
|
||||
|
||||
|
||||
def wait_heading(mav, heading, accuracy=5, timeout=30):
|
||||
'''wait for a given heading'''
|
||||
tstart = time.time()
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='VFR_HUD', blocking=True)
|
||||
print("Heading %u" % m.heading)
|
||||
if math.fabs(m.heading - heading) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain heading %u" % heading)
|
||||
return False
|
||||
|
||||
|
||||
def wait_distance(mav, distance, accuracy=5, timeout=30):
|
||||
'''wait for flight of a given distance'''
|
||||
tstart = time.time()
|
||||
start = current_location(mav)
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
pos = current_location(mav)
|
||||
delta = get_distance(start, pos)
|
||||
print("Distance %.2f meters" % delta)
|
||||
if math.fabs(delta - distance) <= accuracy:
|
||||
return True
|
||||
print("Failed to attain distance %u" % distance)
|
||||
return False
|
||||
|
||||
|
||||
def wait_location(mav, loc, accuracy=5, timeout=30, target_altitude=None, height_accuracy=-1):
|
||||
'''wait for arrival at a location'''
|
||||
tstart = time.time()
|
||||
if target_altitude is None:
|
||||
target_altitude = loc.alt
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='GPS_RAW', blocking=True)
|
||||
pos = current_location(mav)
|
||||
delta = get_distance(loc, pos)
|
||||
print("Distance %.2f meters" % delta)
|
||||
if delta <= accuracy:
|
||||
if height_accuracy != -1 and math.fabs(pos.alt - target_altitude) > height_accuracy:
|
||||
continue
|
||||
print("Reached location (%.2f meters)" % delta)
|
||||
return True
|
||||
print("Failed to attain location")
|
||||
return False
|
||||
|
||||
def wait_waypoint(mav, wpnum_start, wpnum_end, allow_skip=True, timeout=400):
|
||||
'''wait for waypoint ranges'''
|
||||
tstart = time.time()
|
||||
# this message arrives after we set the current WP
|
||||
m = mav.recv_match(type='WAYPOINT_CURRENT', blocking=True)
|
||||
|
||||
start_wp = m.seq
|
||||
current_wp = start_wp
|
||||
|
||||
print("\ntest: wait for waypoint ranges start=%u end=%u\n\n" % (wpnum_start, wpnum_end))
|
||||
# if start_wp != wpnum_start:
|
||||
# print("test: Expected start waypoint %u but got %u" % (wpnum_start, start_wp))
|
||||
# return False
|
||||
|
||||
while time.time() < tstart + timeout:
|
||||
m = mav.recv_match(type='WAYPOINT_CURRENT', blocking=True)
|
||||
seq = m.seq
|
||||
m = mav.recv_match(type='NAV_CONTROLLER_OUTPUT', blocking=True)
|
||||
wp_dist = m.wp_dist
|
||||
print("test: WP %u (wp_dist=%u)" % (seq, wp_dist))
|
||||
if seq == current_wp+1 or (seq > current_wp+1 and allow_skip):
|
||||
print("test: Starting new waypoint %u" % seq)
|
||||
tstart = time.time()
|
||||
current_wp = seq
|
||||
# the wp_dist check is a hack until we can sort out the right seqnum
|
||||
# for end of mission
|
||||
if current_wp == wpnum_end or (current_wp == wpnum_end-1 and wp_dist < 2):
|
||||
print("Reached final waypoint %u" % seq)
|
||||
return True
|
||||
if seq > current_wp+1:
|
||||
print("Skipped waypoint! Got wp %u expected %u" % (seq, current_wp+1))
|
||||
return False
|
||||
print("Timed out waiting for waypoint %u of %u" % (wpnum_end, wpnum_end))
|
||||
return False
|
||||
|
||||
def save_wp(mavproxy, mav):
|
||||
mavproxy.send('rc 7 2000\n')
|
||||
mav.recv_match(condition='RC_CHANNELS_RAW.chan7_raw==2000', blocking=True)
|
||||
mavproxy.send('rc 7 1000\n')
|
||||
mav.recv_match(condition='RC_CHANNELS_RAW.chan7_raw==1000', blocking=True)
|
||||
#mavproxy.send('wp list\n')
|
||||
#mav.recv_match(condition='RC_CHANNELS_RAW.chan7_raw==1000', blocking=True)
|
||||
|
||||
def wait_mode(mav, mode):
|
||||
'''wait for a flight mode to be engaged'''
|
||||
mav.recv_match(condition='MAV.flightmode=="%s"' % mode, blocking=True)
|
78
Tools/autotest/mission2.txt
Normal file
78
Tools/autotest/mission2.txt
Normal file
@ -0,0 +1,78 @@
|
||||
QGC WPL 110
|
||||
#s fr ac cmd p1 p2 p3 p4 lat lon alt continue
|
||||
0 1 3 16 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 582 1
|
||||
|
||||
# takeoff
|
||||
1 0 3 22 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 20 1
|
||||
|
||||
# MAV_CMD_NAV_WAYPOINT A
|
||||
# Hold sec Hit rad empty Yaw angle lat lon alt continue
|
||||
2 0 3 16 0 3 0 0 -35.363949 149.164151 20 1
|
||||
|
||||
# MAV_CMD_CONDITION_YAW
|
||||
# delta deg sec Dir 1=CW Rel/Abs Lat lon Alt continue
|
||||
3 0 3 115 640 20 1 1 0 0 0 1
|
||||
|
||||
# MAV_CMD_NAV_LOITER_TIME
|
||||
# seconds empty rad Yaw per Lat lon Alt continue
|
||||
4 0 3 19 35 20 0 1 0 0 0 1
|
||||
|
||||
# MAV_CMD_NAV_WAYPOINT B
|
||||
# Hold sec Hit rad empty Yaw angle lat lon alt continue
|
||||
5 0 3 16 0 3 0 0 -35.363287 149.164958 20 1
|
||||
|
||||
# MAV_CMD_NAV_LOITER_TURNS
|
||||
# Turns lat lon alt continue
|
||||
6 0 3 18 2 0 0 0 0 0 0 1
|
||||
|
||||
# MAV_CMD_DO_SET_ROI, MAV_ROI_WPNEXT = 1
|
||||
# MAV_ROI WP index ROI index lat lon alt continue
|
||||
7 0 3 201 1 0 0 0 0 0 0 1
|
||||
|
||||
# MAV_CMD_NAV_WAYPOINT C
|
||||
# Hold sec Hit rad empty Yaw angle lat lon alt continue
|
||||
8 0 3 16 0 3 0 0 -35.364865 149.164952 20 1
|
||||
|
||||
# MAV_CMD_CONDITION_DISTANCE
|
||||
# meters continue
|
||||
9 0 3 114 100 0 0 0 0 0 0 1
|
||||
|
||||
# MAV_CMD_CONDITION_CHANGE_ALT
|
||||
# climb_rate alt continue
|
||||
10 0 3 113 0 0 0 0 0 0 40 1
|
||||
|
||||
# MAV_CMD_NAV_WAYPOINT D
|
||||
# Hold sec Hit rad empty Yaw angle lat lon alt continue
|
||||
11 0 3 16 0 3 0 0 -35.363165 149.163905 20 1
|
||||
|
||||
# MAV_CMD_NAV_WAYPOINT E
|
||||
# Hold sec Hit rad empty Yaw angle lat lon alt continue
|
||||
12 0 3 16 0 3 0 0 -35.363611 149.163583 20 1
|
||||
|
||||
# MAV_CMD_DO_JUMP
|
||||
# seq# repeat . . . . . continue
|
||||
13 0 3 177 11 3 0 0 0 0 0 1
|
||||
|
||||
# MAV_CMD_NAV_RETURN_TO_LAUNCH
|
||||
# . . . . alt continue
|
||||
14 0 3 20 0 0 0 0 0 0 20 1
|
||||
|
||||
# MAV_CMD_NAV_LAND
|
||||
#
|
||||
15 0 3 21 0 0 0 0 0 0 0 1
|
||||
|
||||
# WP_total = 10
|
||||
# 0 = home
|
||||
|
||||
# seq
|
||||
# current
|
||||
# frame
|
||||
# command
|
||||
# param1,
|
||||
# param2,
|
||||
# param3
|
||||
# param4
|
||||
# x (latitude)
|
||||
# y (longitude)
|
||||
# z (altitude)
|
||||
# autocontinue
|
@ -1,6 +1,6 @@
|
||||
QGC WPL 110
|
||||
#s fr ac cmd p1 p2 p3 p4 lat lon alt continue
|
||||
0 1 3 0 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 582.000000 1
|
||||
0 1 3 16 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 582.000000 1
|
||||
1 0 3 22 0.000000 0.000000 0.000000 0.000000 -35.362881 149.165222 20.000000 1
|
||||
2 0 3 115 360.0 10.0000 1.0 1.0 0 0 0 1
|
||||
3 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.362612 149.164186 20.000000 1
|
||||
@ -8,6 +8,21 @@ QGC WPL 110
|
||||
5 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.363910 149.162632 20.000000 1
|
||||
6 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.365215 149.164145 20.000000 1
|
||||
7 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.362612 149.164186 20.000000 1
|
||||
8 0 3 20 0.000000 0.000000 0.000000 0.000000 -35.363228 149.161896 30.000000 1
|
||||
9 0 3 21 0.000000 0.000000 0.000000 0.000000 -35.363228 149.161896 0.000000 1
|
||||
8 0 3 20 0.000000 0.000000 0.000000 0.000000 0 0 30.000000 1
|
||||
9 0 3 21 0.000000 0.000000 0.000000 0.000000 0 0 0.000000 1
|
||||
|
||||
# WP_total = 10
|
||||
# 0 = home
|
||||
|
||||
# seq
|
||||
# current
|
||||
# frame
|
||||
# command
|
||||
# param1,
|
||||
# param2,
|
||||
# param3
|
||||
# param4
|
||||
# x (latitude)
|
||||
# y (longitude)
|
||||
# z (altitude)
|
||||
# autocontinue
|
||||
|
@ -39,8 +39,8 @@ def rmfile(path):
|
||||
def deltree(path):
|
||||
'''delete a tree of files'''
|
||||
run_cmd('rm -rf %s' % path)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
def build_SIL(atype):
|
||||
'''build desktop SIL'''
|
||||
@ -73,9 +73,19 @@ def pexpect_autoclose(p):
|
||||
def pexpect_close(p):
|
||||
'''close a pexpect child'''
|
||||
global close_list
|
||||
p.close()
|
||||
|
||||
xvfb_server_num = getattr(p, 'xvfb_server_num', None)
|
||||
if xvfb_server_num is not None:
|
||||
kill_xvfb(xvfb_server_num)
|
||||
try:
|
||||
p.close()
|
||||
except Exception:
|
||||
pass
|
||||
time.sleep(1)
|
||||
p.close(force=True)
|
||||
try:
|
||||
p.close(force=True)
|
||||
except Exception:
|
||||
pass
|
||||
if p in close_list:
|
||||
close_list.remove(p)
|
||||
|
||||
@ -83,12 +93,7 @@ def pexpect_close_all():
|
||||
'''close all pexpect children'''
|
||||
global close_list
|
||||
for p in close_list[:]:
|
||||
try:
|
||||
p.close()
|
||||
time.sleep(1)
|
||||
p.close(Force=True)
|
||||
except Exception:
|
||||
pass
|
||||
pexpect_close(p)
|
||||
|
||||
def start_SIL(atype, valgrind=False, wipe=False, CLI=False):
|
||||
'''launch a SIL instance'''
|
||||
@ -111,7 +116,7 @@ def start_MAVProxy_SIL(atype, aircraft=None, setup=False, master='tcp:127.0.0.1:
|
||||
'''launch mavproxy connected to a SIL instance'''
|
||||
global close_list
|
||||
MAVPROXY = reltopdir('../MAVProxy/mavproxy.py')
|
||||
cmd = MAVPROXY + ' --master=%s --fgrate=%u' % (master, fgrate)
|
||||
cmd = MAVPROXY + ' --master=%s --fgrate=%u --out=127.0.0.1:14550' % (master, fgrate)
|
||||
if setup:
|
||||
cmd += ' --setup'
|
||||
if aircraft is None:
|
||||
@ -171,3 +176,13 @@ def lock_file(fname):
|
||||
except Exception:
|
||||
return None
|
||||
return f
|
||||
|
||||
def kill_xvfb(server_num):
|
||||
'''Xvfb is tricky to kill!'''
|
||||
try:
|
||||
import signal
|
||||
pid = int(open('/tmp/.X%s-lock' % server_num).read().strip())
|
||||
print("Killing Xvfb process %u" % pid)
|
||||
os.kill(pid, signal.SIGINT)
|
||||
except Exception, msg:
|
||||
print("failed to kill Xvfb process - %s" % msg)
|
||||
|
@ -2,7 +2,7 @@
|
||||
#define APM_BMP085_h
|
||||
|
||||
#define TEMP_FILTER_SIZE 2
|
||||
#define PRESS_FILTER_SIZE 2
|
||||
#define PRESS_FILTER_SIZE 4
|
||||
|
||||
#include "APM_BMP085_hil.h"
|
||||
|
||||
|
@ -35,7 +35,7 @@
|
||||
#include "DataFlash.h"
|
||||
#include <SPI.h>
|
||||
|
||||
#define OVERWRITE_DATA 0 // 0: When reach the end page stop, 1: Start overwritten from page 1
|
||||
#define OVERWRITE_DATA 1 // 0: When reach the end page stop, 1: Start overwriting from page 1
|
||||
|
||||
// *** INTERNAL FUNCTIONS ***
|
||||
|
||||
@ -160,6 +160,7 @@ void DataFlash_Class::PageToBuffer(unsigned char BufferNum, unsigned int PageAdr
|
||||
while(!ReadStatus()); //monitor the status register, wait until busy-flag is high
|
||||
|
||||
dataflash_CS_inactive();
|
||||
|
||||
}
|
||||
|
||||
void DataFlash_Class::BufferToPage (unsigned char BufferNum, unsigned int PageAdr, unsigned char wait)
|
||||
@ -271,10 +272,15 @@ void DataFlash_Class::ChipErase ()
|
||||
void DataFlash_Class::StartWrite(int PageAdr)
|
||||
{
|
||||
df_BufferNum=1;
|
||||
df_BufferIdx=0;
|
||||
df_BufferIdx=4;
|
||||
df_PageAdr=PageAdr;
|
||||
df_Stop_Write=0;
|
||||
WaitReady();
|
||||
// We are starting a new page - write FileNumber and FilePage
|
||||
BufferWrite(df_BufferNum,0,df_FileNumber>>8); // High byte
|
||||
BufferWrite(df_BufferNum,1,df_FileNumber&0xFF); // Low byte
|
||||
BufferWrite(df_BufferNum,2,df_FilePage>>8); // High byte
|
||||
BufferWrite(df_BufferNum,3,df_FilePage&0xFF); // Low byte
|
||||
}
|
||||
|
||||
void DataFlash_Class::FinishWrite(void)
|
||||
@ -284,12 +290,12 @@ void DataFlash_Class::FinishWrite(void)
|
||||
df_PageAdr++;
|
||||
if (OVERWRITE_DATA==1)
|
||||
{
|
||||
if (df_PageAdr>=4096) // If we reach the end of the memory, start from the begining
|
||||
if (df_PageAdr>DF_LAST_PAGE) // If we reach the end of the memory, start from the begining
|
||||
df_PageAdr = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (df_PageAdr>=4096) // If we reach the end of the memory, stop here
|
||||
if (df_PageAdr>DF_LAST_PAGE) // If we reach the end of the memory, stop here
|
||||
df_Stop_Write=1;
|
||||
}
|
||||
|
||||
@ -306,19 +312,19 @@ void DataFlash_Class::WriteByte(byte data)
|
||||
{
|
||||
BufferWrite(df_BufferNum,df_BufferIdx,data);
|
||||
df_BufferIdx++;
|
||||
if (df_BufferIdx >= df_PageSize) // End of buffer?
|
||||
if (df_BufferIdx >= df_PageSize) // End of buffer?
|
||||
{
|
||||
df_BufferIdx=0;
|
||||
df_BufferIdx=4; //(4 bytes for FileNumber, FilePage)
|
||||
BufferToPage(df_BufferNum,df_PageAdr,0); // Write Buffer to memory, NO WAIT
|
||||
df_PageAdr++;
|
||||
if (OVERWRITE_DATA==1)
|
||||
{
|
||||
if (df_PageAdr>=4096) // If we reach the end of the memory, start from the begining
|
||||
if (df_PageAdr>DF_LAST_PAGE) // If we reach the end of the memory, start from the begining
|
||||
df_PageAdr = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (df_PageAdr>=4096) // If we reach the end of the memory, stop here
|
||||
if (df_PageAdr>DF_LAST_PAGE) // If we reach the end of the memory, stop here
|
||||
df_Stop_Write=1;
|
||||
}
|
||||
|
||||
@ -326,6 +332,12 @@ void DataFlash_Class::WriteByte(byte data)
|
||||
df_BufferNum=2;
|
||||
else
|
||||
df_BufferNum=1;
|
||||
// We are starting a new page - write FileNumber and FilePage
|
||||
BufferWrite(df_BufferNum,0,df_FileNumber>>8); // High byte
|
||||
BufferWrite(df_BufferNum,1,df_FileNumber&0xFF); // Low byte
|
||||
df_FilePage++;
|
||||
BufferWrite(df_BufferNum,2,df_FilePage>>8); // High byte
|
||||
BufferWrite(df_BufferNum,3,df_FilePage&0xFF); // Low byte
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -359,11 +371,19 @@ int DataFlash_Class::GetPage()
|
||||
void DataFlash_Class::StartRead(int PageAdr)
|
||||
{
|
||||
df_Read_BufferNum=1;
|
||||
df_Read_BufferIdx=0;
|
||||
df_Read_BufferIdx=4;
|
||||
df_Read_PageAdr=PageAdr;
|
||||
WaitReady();
|
||||
PageToBuffer(df_Read_BufferNum,df_Read_PageAdr); // Write Memory page to buffer
|
||||
//Serial.print(df_Read_PageAdr, DEC); Serial.print("\t");
|
||||
df_Read_PageAdr++;
|
||||
// We are starting a new page - read FileNumber and FilePage
|
||||
df_FileNumber = BufferRead(df_Read_BufferNum,0); // High byte
|
||||
//Serial.print(df_FileNumber, DEC); Serial.print("\t");
|
||||
df_FileNumber = (df_FileNumber<<8) | BufferRead(df_Read_BufferNum,1); // Low byte
|
||||
//Serial.println(df_FileNumber, DEC); Serial.print("\t");
|
||||
df_FilePage = BufferRead(df_Read_BufferNum,2); // High byte
|
||||
df_FilePage = (df_FilePage<<8) | BufferRead(df_Read_BufferNum,3); // Low byte
|
||||
}
|
||||
|
||||
byte DataFlash_Class::ReadByte()
|
||||
@ -373,16 +393,21 @@ byte DataFlash_Class::ReadByte()
|
||||
WaitReady();
|
||||
result = BufferRead(df_Read_BufferNum,df_Read_BufferIdx);
|
||||
df_Read_BufferIdx++;
|
||||
if (df_Read_BufferIdx >= df_PageSize) // End of buffer?
|
||||
if (df_Read_BufferIdx >= df_PageSize) // End of buffer?
|
||||
{
|
||||
df_Read_BufferIdx=0;
|
||||
df_Read_BufferIdx=4; //(4 bytes for FileNumber, FilePage)
|
||||
PageToBuffer(df_Read_BufferNum,df_Read_PageAdr); // Write memory page to Buffer
|
||||
df_Read_PageAdr++;
|
||||
if (df_Read_PageAdr>=4096) // If we reach the end of the memory, start from the begining
|
||||
if (df_Read_PageAdr>DF_LAST_PAGE) // If we reach the end of the memory, start from the begining
|
||||
{
|
||||
df_Read_PageAdr = 0;
|
||||
df_Read_END = true;
|
||||
}
|
||||
// We are starting a new page - read FileNumber and FilePage
|
||||
df_FileNumber = BufferRead(df_Read_BufferNum,0); // High byte
|
||||
df_FileNumber = (df_FileNumber<<8) | BufferRead(df_Read_BufferNum,1); // Low byte
|
||||
df_FilePage = BufferRead(df_Read_BufferNum,2); // High byte
|
||||
df_FilePage = (df_FilePage<<8) | BufferRead(df_Read_BufferNum,3); // Low byte
|
||||
}
|
||||
return result;
|
||||
}
|
||||
@ -407,5 +432,23 @@ long DataFlash_Class::ReadLong()
|
||||
return result;
|
||||
}
|
||||
|
||||
void DataFlash_Class::SetFileNumber(uint16_t FileNumber)
|
||||
{
|
||||
df_FileNumber = FileNumber;
|
||||
df_FilePage = 1;
|
||||
}
|
||||
|
||||
uint16_t DataFlash_Class::GetFileNumber()
|
||||
{
|
||||
return df_FileNumber;
|
||||
}
|
||||
|
||||
uint16_t DataFlash_Class::GetFilePage()
|
||||
{
|
||||
return df_FilePage;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// make one instance for the user to use
|
||||
DataFlash_Class DataFlash;
|
||||
|
@ -4,6 +4,10 @@
|
||||
#ifndef DataFlash_h
|
||||
#define DataFlash_h
|
||||
|
||||
#include "../FastSerial/FastSerial.h"
|
||||
// flash size
|
||||
#define DF_LAST_PAGE 4096
|
||||
|
||||
// arduino mega SPI pins
|
||||
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
|
||||
#define DF_DATAOUT 51 // MOSI
|
||||
@ -45,15 +49,24 @@ class DataFlash_Class
|
||||
unsigned char df_BufferNum;
|
||||
unsigned char df_Read_BufferNum;
|
||||
uint16_t df_BufferIdx;
|
||||
|
||||
uint16_t df_Read_BufferIdx;
|
||||
|
||||
uint16_t df_PageAdr;
|
||||
|
||||
uint16_t df_Read_PageAdr;
|
||||
|
||||
unsigned char df_Read_END;
|
||||
unsigned char df_Stop_Write;
|
||||
uint16_t df_FileNumber;
|
||||
uint16_t df_FilePage;
|
||||
//Methods
|
||||
unsigned char BufferRead (unsigned char BufferNum, uint16_t IntPageAdr);
|
||||
|
||||
void BufferWrite (unsigned char BufferNum, uint16_t IntPageAdr, unsigned char Data);
|
||||
|
||||
void BufferToPage (unsigned char BufferNum, uint16_t PageAdr, unsigned char wait);
|
||||
|
||||
void PageToBuffer(unsigned char BufferNum, uint16_t PageAdr);
|
||||
void WaitReady();
|
||||
unsigned char ReadStatusReg();
|
||||
@ -69,22 +82,32 @@ class DataFlash_Class
|
||||
DataFlash_Class(); // Constructor
|
||||
void Init();
|
||||
void ReadManufacturerID();
|
||||
int16_t GetPage();
|
||||
int16_t GetPage();
|
||||
int16_t GetWritePage();
|
||||
|
||||
void PageErase (uint16_t PageAdr);
|
||||
|
||||
void ChipErase ();
|
||||
// Write methods
|
||||
void StartWrite(int16_t PageAdr);
|
||||
|
||||
void FinishWrite();
|
||||
void WriteByte(unsigned char data);
|
||||
void WriteInt(int16_t data);
|
||||
|
||||
void WriteLong(int32_t data);
|
||||
|
||||
// Read methods
|
||||
void StartRead(int16_t PageAdr);
|
||||
|
||||
unsigned char ReadByte();
|
||||
int16_t ReadInt();
|
||||
|
||||
int32_t ReadLong();
|
||||
|
||||
void SetFileNumber(uint16_t FileNumber);
|
||||
uint16_t GetFileNumber();
|
||||
uint16_t GetFilePage();
|
||||
};
|
||||
|
||||
extern DataFlash_Class DataFlash;
|
||||
|
@ -123,6 +123,11 @@ void DataFlash_Class::StartWrite(int16_t PageAdr)
|
||||
df_BufferIdx = 0;
|
||||
df_PageAdr = PageAdr;
|
||||
df_Stop_Write = 0;
|
||||
|
||||
BufferWrite(df_BufferNum,0,df_FileNumber>>8); // High byte
|
||||
BufferWrite(df_BufferNum,1,df_FileNumber&0xFF); // Low byte
|
||||
BufferWrite(df_BufferNum,2,df_FilePage>>8); // High byte
|
||||
BufferWrite(df_BufferNum,3,df_FilePage&0xFF); // Low byte
|
||||
}
|
||||
|
||||
void DataFlash_Class::FinishWrite(void)
|
||||
@ -145,6 +150,12 @@ void DataFlash_Class::FinishWrite(void)
|
||||
df_BufferNum=2;
|
||||
else
|
||||
df_BufferNum=1;
|
||||
|
||||
BufferWrite(df_BufferNum,0,df_FileNumber>>8); // High byte
|
||||
BufferWrite(df_BufferNum,1,df_FileNumber&0xFF); // Low byte
|
||||
df_FilePage++;
|
||||
BufferWrite(df_BufferNum,2,df_FilePage>>8); // High byte
|
||||
BufferWrite(df_BufferNum,3,df_FilePage&0xFF); // Low byte
|
||||
}
|
||||
|
||||
|
||||
@ -255,5 +266,21 @@ int32_t DataFlash_Class::ReadLong()
|
||||
return (int32_t)result;
|
||||
}
|
||||
|
||||
void DataFlash_Class::SetFileNumber(uint16_t FileNumber)
|
||||
{
|
||||
df_FileNumber = FileNumber;
|
||||
df_FilePage = 1;
|
||||
}
|
||||
|
||||
uint16_t DataFlash_Class::GetFileNumber()
|
||||
{
|
||||
return df_FileNumber;
|
||||
}
|
||||
|
||||
uint16_t DataFlash_Class::GetFilePage()
|
||||
{
|
||||
return df_FilePage;
|
||||
}
|
||||
|
||||
// make one instance for the user to use
|
||||
DataFlash_Class DataFlash;
|
||||
|
@ -295,11 +295,15 @@ void FastSerial::flush(void)
|
||||
void FastSerial::write(uint8_t c)
|
||||
{
|
||||
struct tcp_state *s = &tcp_state[_u2x];
|
||||
int flags = MSG_NOSIGNAL;
|
||||
check_connection(s);
|
||||
if (!s->connected) {
|
||||
return;
|
||||
}
|
||||
send(s->fd, &c, 1, MSG_DONTWAIT | MSG_NOSIGNAL);
|
||||
if (!desktop_state.slider) {
|
||||
flags |= MSG_DONTWAIT;
|
||||
}
|
||||
send(s->fd, &c, 1, flags);
|
||||
}
|
||||
|
||||
// Buffer management ///////////////////////////////////////////////////////////
|
||||
|
Loading…
Reference in New Issue
Block a user