aboutsummaryrefslogtreecommitdiff
path: root/src/systemcmds
diff options
context:
space:
mode:
authorLorenz Meier <lm@inf.ethz.ch>2013-08-19 22:51:30 +0200
committerLorenz Meier <lm@inf.ethz.ch>2013-08-19 22:51:30 +0200
commitdeb426b66002da2562531b37e4ac0f8097c8a6eb (patch)
treeadd3aaec3729fd7b8f9730e7f68e5b51e1e5f57f /src/systemcmds
parentd90345a16619a6a056ca9158961db36787d97678 (diff)
parentdccdc977d5be4f957bcaea036b66d0391b29fd2b (diff)
downloadpx4-firmware-deb426b66002da2562531b37e4ac0f8097c8a6eb.tar.gz
px4-firmware-deb426b66002da2562531b37e4ac0f8097c8a6eb.tar.bz2
px4-firmware-deb426b66002da2562531b37e4ac0f8097c8a6eb.zip
Merge branch 'sensor_selftests'
Diffstat (limited to 'src/systemcmds')
-rw-r--r--src/systemcmds/config/config.c63
1 files changed, 61 insertions, 2 deletions
diff --git a/src/systemcmds/config/config.c b/src/systemcmds/config/config.c
index 2dad2261b..42814f2b2 100644
--- a/src/systemcmds/config/config.c
+++ b/src/systemcmds/config/config.c
@@ -129,7 +129,19 @@ do_gyro(int argc, char *argv[])
ioctl(fd, GYROIOCSRANGE, i);
}
- } else if (!(argc > 0 && !strcmp(argv[0], "info"))) {
+ } else if (argc > 0) {
+
+ if(!strcmp(argv[0], "check")) {
+ int ret = ioctl(fd, GYROIOCSELFTEST, 0);
+
+ if (ret) {
+ warnx("gyro self test FAILED! Check calibration.");
+ } else {
+ warnx("gyro calibration and self test OK");
+ }
+ }
+
+ } else {
warnx("no arguments given. Try: \n\n\t'sampling 500' to set sampling to 500 Hz\n\t'rate 500' to set publication rate to 500 Hz\n\t'range 2000' to set measurement range to 2000 dps\n\t");
}
@@ -148,6 +160,41 @@ do_gyro(int argc, char *argv[])
static void
do_mag(int argc, char *argv[])
{
+ int fd;
+
+ fd = open(MAG_DEVICE_PATH, 0);
+
+ if (fd < 0) {
+ warn("%s", MAG_DEVICE_PATH);
+ errx(1, "FATAL: no magnetometer found");
+
+ } else {
+
+ if (argc > 0) {
+
+ if (!strcmp(argv[0], "check")) {
+ int ret = ioctl(fd, MAGIOCSELFTEST, 0);
+
+ if (ret) {
+ warnx("mag self test FAILED! Check calibration.");
+ } else {
+ warnx("mag calibration and self test OK");
+ }
+ }
+
+ } else {
+ warnx("no arguments given. Try: \n\n\t'check' or 'info'\n\t");
+ }
+
+ int srate = -1;//ioctl(fd, MAGIOCGSAMPLERATE, 0);
+ int prate = ioctl(fd, SENSORIOCGPOLLRATE, 0);
+ int range = -1;//ioctl(fd, MAGIOCGRANGE, 0);
+
+ warnx("mag: \n\tsample rate:\t%d Hz\n\tread rate:\t%d Hz\n\trange:\t%d gauss", srate, prate, range);
+
+ close(fd);
+ }
+
exit(0);
}
@@ -183,7 +230,19 @@ do_accel(int argc, char *argv[])
/* set the range to i dps */
ioctl(fd, ACCELIOCSRANGE, i);
}
- } else if (!(argc > 0 && !strcmp(argv[0], "info"))) {
+ } else if (argc > 0) {
+
+ if (!strcmp(argv[0], "check")) {
+ int ret = ioctl(fd, ACCELIOCSELFTEST, 0);
+
+ if (ret) {
+ warnx("accel self test FAILED! Check calibration.");
+ } else {
+ warnx("accel calibration and self test OK");
+ }
+ }
+
+ } else {
warnx("no arguments given. Try: \n\n\t'sampling 500' to set sampling to 500 Hz\n\t'rate 500' to set publication rate to 500 Hz\n\t'range 2' to set measurement range to 2 G\n\t");
}