aboutsummaryrefslogtreecommitdiff
path: root/src/drivers/px4io/px4io.cpp
diff options
context:
space:
mode:
authorLorenz Meier <lm@inf.ethz.ch>2013-05-29 17:07:26 +0200
committerLorenz Meier <lm@inf.ethz.ch>2013-05-29 17:07:26 +0200
commitf6570172da02bba79b5e050c6e02b86dc96551c9 (patch)
treec71109191584955add43f14a59abf1e3525536a9 /src/drivers/px4io/px4io.cpp
parentd2c60a248da5f2a1070381f330f514687c7abc47 (diff)
downloadpx4-firmware-f6570172da02bba79b5e050c6e02b86dc96551c9.tar.gz
px4-firmware-f6570172da02bba79b5e050c6e02b86dc96551c9.tar.bz2
px4-firmware-f6570172da02bba79b5e050c6e02b86dc96551c9.zip
Set default failsafe value to 0 of mixer
Diffstat (limited to 'src/drivers/px4io/px4io.cpp')
-rw-r--r--src/drivers/px4io/px4io.cpp29
1 files changed, 21 insertions, 8 deletions
diff --git a/src/drivers/px4io/px4io.cpp b/src/drivers/px4io/px4io.cpp
index f25d471aa..873d7eb82 100644
--- a/src/drivers/px4io/px4io.cpp
+++ b/src/drivers/px4io/px4io.cpp
@@ -704,12 +704,8 @@ PX4IO::set_failsafe_values(const uint16_t *vals, unsigned len)
unsigned max = (len < _max_actuators) ? len : _max_actuators;
- /* set failsafe values */
- for (unsigned i = 0; i < max; i++)
- regs[i] = FLOAT_TO_REG(vals[i]);
-
/* copy values to registers in IO */
- return io_reg_set(PX4IO_PAGE_FAILSAFE_PWM, 0, regs, max);
+ return io_reg_set(PX4IO_PAGE_FAILSAFE_PWM, 0, vals, max);
}
int
@@ -1744,11 +1740,28 @@ px4io_main(int argc, char *argv[])
if (!strcmp(argv[1], "failsafe")) {
- /* XXX parse arguments here */
+ if (argc < 3) {
+ errx(1, "failsafe command needs at least one channel value (ppm)");
+ }
if (g_dev != nullptr) {
- /* XXX testing values */
- uint16_t failsafe[4] = {1500, 1500, 1200, 1200};
+
+ /* set values for first 8 channels, fill unassigned channels with 1500. */
+ uint16_t failsafe[8];
+
+ for (int i = 0; i < sizeof(failsafe) / sizeof(failsafe[0]); i++)
+ {
+ /* set channel to commanline argument or to 900 for non-provided channels */
+ if (argc > i + 2) {
+ failsafe[i] = atoi(argv[i+2]);
+ if (failsafe[i] < 800 || failsafe[i] > 2200) {
+ errx(1, "value out of range of 800 < value < 2200. Aborting.");
+ }
+ } else {
+ failsafe[i] = 1500;
+ }
+ }
+
g_dev->set_failsafe_values(failsafe, sizeof(failsafe) / sizeof(failsafe[0]));
} else {
errx(1, "not loaded");