aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLorenz Meier <lm@inf.ethz.ch>2014-07-13 12:43:10 +0200
committerLorenz Meier <lm@inf.ethz.ch>2014-07-13 12:43:10 +0200
commit744eed91dca8a5f2ad8ead7ffa812d25755bcc93 (patch)
tree2669fecad67501c648d0c1aaef563e7c333f4c36 /src
parent8e2346dd5a061a7eb7f0398c45a8d5838a77755e (diff)
downloadpx4-firmware-744eed91dca8a5f2ad8ead7ffa812d25755bcc93.tar.gz
px4-firmware-744eed91dca8a5f2ad8ead7ffa812d25755bcc93.tar.bz2
px4-firmware-744eed91dca8a5f2ad8ead7ffa812d25755bcc93.zip
Fix calibration counter usage
Diffstat (limited to 'src')
-rw-r--r--src/modules/commander/airspeed_calibration.cpp19
1 files changed, 11 insertions, 8 deletions
diff --git a/src/modules/commander/airspeed_calibration.cpp b/src/modules/commander/airspeed_calibration.cpp
index d52cafb8f..a2f11b14a 100644
--- a/src/modules/commander/airspeed_calibration.cpp
+++ b/src/modules/commander/airspeed_calibration.cpp
@@ -168,7 +168,7 @@ int do_airspeed_calibration(int mavlink_fd)
calibration_counter = 0;
/* just take a few samples and make sure pitot tubes are not reversed */
- while (calibration_counter < 10) {
+ while (calibration_counter < 300) {
/* wait blocking for new data */
struct pollfd fds[1];
@@ -182,16 +182,19 @@ int do_airspeed_calibration(int mavlink_fd)
float calibrated_pa = diff_pres.differential_pressure_raw_pa - diff_pres_offset;
- if (fabsf(calibrated_pa) < 9.0f) {
- mavlink_log_critical(mavlink_fd, "Create airflow on pitot (%.1f Pa, #h101)",
- (double)calibrated_pa);
- usleep(3000 * 1000);
+ if (fabsf(calibrated_pa) < 50.0f) {
+ if (calibration_counter % 20 == 0) {
+ mavlink_log_critical(mavlink_fd, "Create airflow on pitot (%d Pa, #h101)",
+ (int)calibrated_pa);
+ }
+ usleep(100 * 1000);
+ calibration_counter++;
continue;
}
/* do not allow negative values */
if (calibrated_pa < 0.0f) {
- mavlink_log_critical(mavlink_fd, "Negative val: swap static vs dynamic ports,restart");
+ mavlink_log_critical(mavlink_fd, "%d Pa: swap static vs dynamic ports,restart", (int)calibrated_pa);
close(diff_pres_sub);
/* the user setup is wrong, wipe the calibration to force a proper re-calibration */
@@ -209,8 +212,8 @@ int do_airspeed_calibration(int mavlink_fd)
close(diff_pres_sub);
return ERROR;
} else {
- mavlink_log_info(mavlink_fd, "positive pressure: (%.1f Pa)",
- (double)diff_pres.differential_pressure_raw_pa);
+ mavlink_log_info(mavlink_fd, "positive pressure: OK (%d Pa)",
+ (int)calibrated_pa);
break;
}