forked from Archive/PX4-Autopilot
Add ST24 test harness
This commit is contained in:
parent
a0c9c88443
commit
72f6aaca96
|
@ -2,3 +2,4 @@
|
||||||
mixer_test
|
mixer_test
|
||||||
sbus2_test
|
sbus2_test
|
||||||
autodeclination_test
|
autodeclination_test
|
||||||
|
st24_test
|
||||||
|
|
|
@ -3,7 +3,7 @@ CC=g++
|
||||||
CFLAGS=-I. -I../../src/modules -I ../../src/include -I../../src/drivers \
|
CFLAGS=-I. -I../../src/modules -I ../../src/include -I../../src/drivers \
|
||||||
-I../../src -I../../src/lib -D__EXPORT="" -Dnullptr="0" -lm
|
-I../../src -I../../src/lib -D__EXPORT="" -Dnullptr="0" -lm
|
||||||
|
|
||||||
all: mixer_test sbus2_test autodeclination_test
|
all: mixer_test sbus2_test autodeclination_test st24_test
|
||||||
|
|
||||||
MIXER_FILES=../../src/systemcmds/tests/test_mixer.cpp \
|
MIXER_FILES=../../src/systemcmds/tests/test_mixer.cpp \
|
||||||
../../src/systemcmds/tests/test_conv.cpp \
|
../../src/systemcmds/tests/test_conv.cpp \
|
||||||
|
@ -20,6 +20,10 @@ SBUS2_FILES=../../src/modules/px4iofirmware/sbus.c \
|
||||||
hrt.cpp \
|
hrt.cpp \
|
||||||
sbus2_test.cpp
|
sbus2_test.cpp
|
||||||
|
|
||||||
|
ST24_FILES=../../src/lib/rc/st24.c \
|
||||||
|
hrt.cpp \
|
||||||
|
st24_test.cpp
|
||||||
|
|
||||||
AUTODECLINATION_FILES= ../../src/lib/geo/geo_mag_declination.c \
|
AUTODECLINATION_FILES= ../../src/lib/geo/geo_mag_declination.c \
|
||||||
hrt.cpp \
|
hrt.cpp \
|
||||||
autodeclination_test.cpp
|
autodeclination_test.cpp
|
||||||
|
@ -33,7 +37,10 @@ sbus2_test: $(SBUS2_FILES)
|
||||||
autodeclination_test: $(SBUS2_FILES)
|
autodeclination_test: $(SBUS2_FILES)
|
||||||
$(CC) -o autodeclination_test $(AUTODECLINATION_FILES) $(CFLAGS)
|
$(CC) -o autodeclination_test $(AUTODECLINATION_FILES) $(CFLAGS)
|
||||||
|
|
||||||
|
st24_test: $(ST24_FILES)
|
||||||
|
$(CC) -o st24_test $(ST24_FILES) $(CFLAGS)
|
||||||
|
|
||||||
.PHONY: clean
|
.PHONY: clean
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~ mixer_test sbus2_test autodeclination_test
|
rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~ mixer_test sbus2_test autodeclination_test st24_test
|
|
@ -0,0 +1,58 @@
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <systemlib/err.h>
|
||||||
|
#include <drivers/drv_hrt.h>
|
||||||
|
#include <px4iofirmware/px4io.h>
|
||||||
|
#include "../../src/systemcmds/tests/tests.h"
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
warnx("ST24 test started");
|
||||||
|
|
||||||
|
if (argc < 2)
|
||||||
|
errx(1, "Need a filename for the input file");
|
||||||
|
|
||||||
|
warnx("loading data from: %s", argv[1]);
|
||||||
|
|
||||||
|
FILE *fp;
|
||||||
|
|
||||||
|
fp = fopen(argv[1],"rt");
|
||||||
|
|
||||||
|
if (!fp)
|
||||||
|
errx(1, "failed opening file");
|
||||||
|
|
||||||
|
float f;
|
||||||
|
unsigned x;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
// Trash the first 20 lines
|
||||||
|
for (unsigned i = 0; i < 20; i++) {
|
||||||
|
(void)fscanf(fp, "%f,%x,,", &f, &x);
|
||||||
|
}
|
||||||
|
|
||||||
|
float last_time = 0;
|
||||||
|
|
||||||
|
while (EOF != (ret = fscanf(fp, "%f,%x,,", &f, &x))) {
|
||||||
|
if (((f - last_time) * 1000 * 1000) > 3000) {
|
||||||
|
warnx("FRAME RESET\n\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
warnx("%f: 0x%02x", (double)f, x);
|
||||||
|
|
||||||
|
last_time = f;
|
||||||
|
|
||||||
|
// Pipe the data into the parser
|
||||||
|
hrt_abstime now = hrt_absolute_time();
|
||||||
|
|
||||||
|
//if (partial_frame_count % 25 == 0)
|
||||||
|
//sbus_parse(now, frame, &partial_frame_count, rc_values, &num_values, &sbus_failsafe, &sbus_frame_drop, max_channels);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ret == EOF) {
|
||||||
|
warnx("Test finished, reached end of file");
|
||||||
|
} else {
|
||||||
|
warnx("Test aborted, errno: %d", ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue