2013-01-20 17:21:44 -04:00
|
|
|
#!nsh
|
|
|
|
|
|
|
|
# APM startup script for NuttX on PX4
|
|
|
|
|
2013-02-17 22:55:58 -04:00
|
|
|
# To disable APM startup add a /fs/microsd/APM/nostart file
|
2013-07-11 00:18:54 -03:00
|
|
|
# To enable mkblctrl startup add a /fs/microsd/APM/mkblctrl file
|
2014-03-28 15:01:09 -03:00
|
|
|
# To enable mkblctrl_+ startup add a /fs/microsd/APM/mkblctrl_+ file
|
|
|
|
# To enable mkblctrl_x startup add a /fs/microsd/APM/mkblctrl_x file
|
2013-12-30 20:54:42 -04:00
|
|
|
# To enable PWM on FMUv1 on ttyS1 add a /fs/microsd/APM/AUXPWM.en file
|
2013-02-17 22:55:58 -04:00
|
|
|
|
|
|
|
set deviceA /dev/ttyACM0
|
2013-07-11 00:18:54 -03:00
|
|
|
|
2013-03-17 22:25:45 -03:00
|
|
|
# check for an old file called APM, caused by
|
|
|
|
# a bug in an earlier firmware release
|
|
|
|
if [ -f /fs/microsd/APM ]
|
|
|
|
then
|
|
|
|
echo "APM file found - renaming"
|
|
|
|
mv /fs/microsd/APM /fs/microsd/APM.old
|
|
|
|
fi
|
|
|
|
|
2013-01-25 05:36:33 -04:00
|
|
|
if [ -f /fs/microsd/APM/nostart ]
|
|
|
|
then
|
2013-08-03 05:51:59 -03:00
|
|
|
echo "APM/nostart found - skipping APM startup"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2013-01-25 05:36:33 -04:00
|
|
|
|
2013-01-20 17:21:44 -04:00
|
|
|
# mount binfs so we can find the built-in apps
|
2013-02-17 22:55:58 -04:00
|
|
|
if [ -f /bin/reboot ]
|
|
|
|
then
|
|
|
|
echo "binfs already mounted"
|
|
|
|
else
|
|
|
|
echo "Mounting binfs"
|
2013-08-03 05:51:59 -03:00
|
|
|
if mount -t binfs /dev/null /bin
|
|
|
|
then
|
|
|
|
echo "binfs mounted OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2013-02-17 22:55:58 -04:00
|
|
|
fi
|
2013-01-20 17:21:44 -04:00
|
|
|
|
|
|
|
set sketch NONE
|
2014-01-13 21:41:07 -04:00
|
|
|
if rm /fs/microsd/APM/boot.log
|
|
|
|
then
|
|
|
|
echo "removed old boot.log"
|
|
|
|
fi
|
2014-01-13 00:04:42 -04:00
|
|
|
set logfile /fs/microsd/APM/BOOT.LOG
|
2013-01-20 17:21:44 -04:00
|
|
|
|
2013-08-03 05:51:59 -03:00
|
|
|
if [ ! -f /bin/ArduPilot ]
|
2013-01-20 17:21:44 -04:00
|
|
|
then
|
2013-08-03 05:51:59 -03:00
|
|
|
echo "/bin/ardupilot not found"
|
|
|
|
sh /etc/init.d/rc.error
|
2013-01-20 17:21:44 -04:00
|
|
|
fi
|
|
|
|
|
2013-08-05 22:27:34 -03:00
|
|
|
if mkdir /fs/microsd/APM > /dev/null
|
2013-01-20 17:21:44 -04:00
|
|
|
then
|
2013-08-03 05:51:59 -03:00
|
|
|
echo "Created APM directory"
|
|
|
|
fi
|
2013-03-21 00:59:58 -03:00
|
|
|
|
2013-10-30 01:33:42 -03:00
|
|
|
if [ -f /bin/lsm303d ]
|
2013-08-03 05:51:59 -03:00
|
|
|
then
|
|
|
|
echo "Detected FMUv2 board"
|
|
|
|
set BOARD FMUv2
|
2013-10-30 01:33:42 -03:00
|
|
|
else
|
|
|
|
echo "Detected FMUv1 board"
|
|
|
|
set BOARD FMUv1
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
2013-07-25 22:12:37 -03:00
|
|
|
|
2013-11-22 06:54:37 -04:00
|
|
|
if [ $BOARD == FMUv1 ]
|
2013-08-03 05:51:59 -03:00
|
|
|
then
|
2013-11-22 06:54:37 -04:00
|
|
|
set deviceC /dev/ttyS2
|
2013-12-30 20:54:42 -04:00
|
|
|
if [ -f /fs/microsd/APM/AUXPWM.en ]
|
2013-08-03 05:51:59 -03:00
|
|
|
then
|
2013-11-22 06:54:37 -04:00
|
|
|
set deviceD /dev/null
|
2013-12-30 20:54:42 -04:00
|
|
|
else
|
|
|
|
set deviceD /dev/ttyS1
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
2013-11-22 06:54:37 -04:00
|
|
|
else
|
|
|
|
set deviceC /dev/ttyS1
|
|
|
|
set deviceD /dev/ttyS2
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
|
|
|
|
2013-10-30 01:33:42 -03:00
|
|
|
if uorb start
|
|
|
|
then
|
|
|
|
echo "uorb started OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
2014-03-28 15:01:09 -03:00
|
|
|
# start mkblctrl driver if configured
|
|
|
|
if [ -f /fs/microsd/APM/mkblctrl ]
|
|
|
|
then
|
|
|
|
echo "Setting up mkblctrl driver"
|
|
|
|
echo "Setting up mkblctrl driver" >> $logfile
|
|
|
|
mkblctrl -d /dev/pwm_output
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -f /fs/microsd/APM/mkblctrl_+ ]
|
|
|
|
then
|
|
|
|
echo "Setting up mkblctrl driver +"
|
|
|
|
echo "Setting up mkblctrl driver +" >> $logfile
|
|
|
|
mkblctrl -mkmode + -d /dev/pwm_output
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -f /fs/microsd/APM/mkblctrl_x ]
|
|
|
|
then
|
|
|
|
echo "Setting up mkblctrl driver x"
|
|
|
|
echo "Setting up mkblctrl driver x" >> $logfile
|
|
|
|
mkblctrl -mkmode x -d /dev/pwm_output
|
|
|
|
fi
|
|
|
|
|
2013-10-30 01:33:42 -03:00
|
|
|
|
2014-10-29 18:30:38 -03:00
|
|
|
echo "Trying PX4IO board"
|
|
|
|
|
2013-10-30 01:33:42 -03:00
|
|
|
# try the px4io start twice. Some FMUv2 board don't
|
|
|
|
# come up the first time
|
|
|
|
set HAVE_PX4IO false
|
2014-06-30 16:38:33 -03:00
|
|
|
if px4io start norc
|
2013-10-30 01:33:42 -03:00
|
|
|
then
|
|
|
|
set HAVE_PX4IO true
|
|
|
|
else
|
2013-12-12 21:44:47 -04:00
|
|
|
# it may be in bootloader mode
|
|
|
|
echo Loading /etc/px4io/px4io.bin
|
|
|
|
tone_alarm MBABGP
|
|
|
|
if px4io update /etc/px4io/px4io.bin
|
|
|
|
then
|
|
|
|
echo "upgraded PX4IO firmware OK"
|
|
|
|
tone_alarm MSPAA
|
|
|
|
else
|
|
|
|
echo "Failed to upgrade PX4IO firmware"
|
|
|
|
tone_alarm MNGGG
|
|
|
|
fi
|
|
|
|
sleep 1
|
2014-06-30 16:38:33 -03:00
|
|
|
if px4io start norc
|
2013-10-30 01:33:42 -03:00
|
|
|
then
|
|
|
|
set HAVE_PX4IO true
|
|
|
|
# play happy tune again
|
2015-06-12 04:55:29 -03:00
|
|
|
tone_alarm 1
|
2013-10-30 01:33:42 -03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $HAVE_PX4IO == true ]
|
|
|
|
then
|
|
|
|
echo "PX4IO board OK"
|
2013-12-12 21:44:47 -04:00
|
|
|
if px4io checkcrc /etc/px4io/px4io.bin
|
|
|
|
then
|
|
|
|
echo "PX4IO CRC OK"
|
|
|
|
else
|
|
|
|
echo "PX4IO CRC failure"
|
|
|
|
echo "PX4IO CRC failure" >> $logfile
|
|
|
|
tone_alarm MBABGP
|
2015-01-28 21:33:10 -04:00
|
|
|
|
|
|
|
if px4io safety_on
|
|
|
|
then
|
|
|
|
echo "PX4IO disarm OK"
|
|
|
|
else
|
|
|
|
echo "PX4IO disarm failed"
|
|
|
|
fi
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
|
2013-12-12 21:44:47 -04:00
|
|
|
if px4io forceupdate 14662 /etc/px4io/px4io.bin
|
|
|
|
then
|
|
|
|
sleep 1
|
2014-06-30 16:38:33 -03:00
|
|
|
if px4io start norc
|
2013-12-12 21:44:47 -04:00
|
|
|
then
|
|
|
|
echo "PX4IO restart OK"
|
|
|
|
echo "PX4IO restart OK" >> $logfile
|
|
|
|
tone_alarm MSPAA
|
|
|
|
else
|
|
|
|
echo "PX4IO restart failed"
|
|
|
|
echo "PX4IO restart failed" >> $logfile
|
|
|
|
tone_alarm MNGGG
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "PX4IO update failed"
|
|
|
|
echo "PX4IO update failed" >> $logfile
|
|
|
|
tone_alarm MNGGG
|
|
|
|
fi
|
|
|
|
fi
|
2013-10-30 01:33:42 -03:00
|
|
|
else
|
|
|
|
echo "No PX4IO board found"
|
|
|
|
echo "No PX4IO board found" >> $logfile
|
|
|
|
|
|
|
|
if [ $BOARD == FMUv2 ]
|
|
|
|
then
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2013-11-22 06:54:37 -04:00
|
|
|
fi
|
2013-10-30 01:33:42 -03:00
|
|
|
|
2013-11-22 06:54:37 -04:00
|
|
|
if [ $BOARD == FMUv1 -a $deviceD == /dev/ttyS1 ]
|
|
|
|
then
|
|
|
|
echo "Setting FMU mode_serial"
|
|
|
|
fmu mode_serial
|
|
|
|
else
|
2015-02-22 22:23:00 -04:00
|
|
|
if fmu mode_pwm4
|
|
|
|
then
|
|
|
|
echo "Set FMU mode_pwm4"
|
|
|
|
fi
|
2013-10-30 01:33:42 -03:00
|
|
|
fi
|
|
|
|
|
2013-08-05 22:39:00 -03:00
|
|
|
|
2013-08-03 05:51:59 -03:00
|
|
|
echo "Starting APM sensors"
|
2015-01-05 07:12:30 -04:00
|
|
|
|
2013-08-03 05:51:59 -03:00
|
|
|
if ms5611 start
|
|
|
|
then
|
2015-01-31 22:33:55 -04:00
|
|
|
echo "ms5611 started OK"
|
2013-08-03 05:51:59 -03:00
|
|
|
else
|
2015-01-31 22:33:55 -04:00
|
|
|
echo "no ms5611 found"
|
|
|
|
echo "No ms5611 found" >> $logfile
|
|
|
|
sh /etc/init.d/rc.error
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
|
|
|
|
|
|
|
if adc start
|
|
|
|
then
|
2015-01-31 22:33:55 -04:00
|
|
|
echo "adc started OK"
|
2013-08-03 05:51:59 -03:00
|
|
|
else
|
2015-01-31 22:33:55 -04:00
|
|
|
echo "No adc" >> $logfile
|
|
|
|
sh /etc/init.d/rc.error
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $BOARD == FMUv1 ]
|
|
|
|
then
|
|
|
|
echo "Starting FMUv1 sensors"
|
2015-10-21 00:09:29 -03:00
|
|
|
if hmc5883 -C -T -X start
|
|
|
|
then
|
|
|
|
echo "Have external hmc5883"
|
|
|
|
else
|
|
|
|
echo "No external hmc5883"
|
|
|
|
fi
|
|
|
|
if hmc5883 -C -T -I start
|
2013-08-03 05:51:59 -03:00
|
|
|
then
|
2015-10-21 00:09:29 -03:00
|
|
|
echo "Have internal hmc5883"
|
2013-08-03 05:51:59 -03:00
|
|
|
else
|
2015-10-21 00:09:29 -03:00
|
|
|
echo "No internal hmc5883"
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
2013-10-30 01:33:42 -03:00
|
|
|
if mpu6000 start
|
|
|
|
then
|
|
|
|
echo "mpu6000 started OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2013-12-08 05:45:32 -04:00
|
|
|
if l3gd20 start
|
|
|
|
then
|
|
|
|
echo "l3gd20 started OK"
|
|
|
|
else
|
|
|
|
echo "No l3gd20"
|
|
|
|
echo "No l3gd20" >> $logfile
|
|
|
|
fi
|
2013-08-03 05:51:59 -03:00
|
|
|
else
|
|
|
|
echo "Starting FMUv2 sensors"
|
2015-04-02 18:35:52 -03:00
|
|
|
if hmc5883 -C -T -X start
|
2013-08-03 05:51:59 -03:00
|
|
|
then
|
2014-07-03 23:08:17 -03:00
|
|
|
echo "Have external hmc5883"
|
|
|
|
else
|
|
|
|
echo "No external hmc5883"
|
|
|
|
fi
|
2015-04-02 18:35:52 -03:00
|
|
|
if hmc5883 -C -T -I -R 4 start
|
2014-07-03 23:08:17 -03:00
|
|
|
then
|
|
|
|
echo "Have internal hmc5883"
|
|
|
|
else
|
|
|
|
echo "No internal hmc5883"
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
2014-01-22 01:34:48 -04:00
|
|
|
|
2014-07-03 21:47:58 -03:00
|
|
|
# external MPU6000 is rotated YAW_180 from standard
|
2014-07-03 01:21:45 -03:00
|
|
|
if mpu6000 -X -R 4 start
|
2013-10-30 01:33:42 -03:00
|
|
|
then
|
2014-07-03 01:21:45 -03:00
|
|
|
echo "Found MPU6000 external"
|
|
|
|
set HAVE_FMUV3 true
|
2013-12-08 05:45:32 -04:00
|
|
|
else
|
2015-08-01 03:33:54 -03:00
|
|
|
if mpu9250 -X -R 4 start
|
|
|
|
then
|
|
|
|
echo "Found MPU9250 external"
|
|
|
|
set HAVE_FMUV3 true
|
|
|
|
else
|
|
|
|
echo "No MPU6000 or MPU9250 external"
|
|
|
|
set HAVE_FMUV3 false
|
|
|
|
fi
|
2013-12-08 05:45:32 -04:00
|
|
|
fi
|
2014-07-03 01:21:45 -03:00
|
|
|
if [ $HAVE_FMUV3 == true ]
|
2014-07-03 11:34:41 -03:00
|
|
|
then
|
2014-07-03 21:47:58 -03:00
|
|
|
# external L3GD20 is rotated YAW_180 from standard
|
2014-07-03 21:18:04 -03:00
|
|
|
if l3gd20 -X -R 4 start
|
2014-06-26 01:05:15 -03:00
|
|
|
then
|
|
|
|
echo "l3gd20 external started OK"
|
|
|
|
else
|
2014-07-03 01:21:45 -03:00
|
|
|
echo "No l3gd20"
|
2014-06-26 01:05:15 -03:00
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2014-07-03 21:47:58 -03:00
|
|
|
# external LSM303D is rotated YAW_270 from standard
|
2014-07-03 01:21:45 -03:00
|
|
|
if lsm303d -X -R 6 start
|
2014-06-26 01:05:15 -03:00
|
|
|
then
|
|
|
|
echo "lsm303d external started OK"
|
|
|
|
else
|
2014-07-03 01:21:45 -03:00
|
|
|
echo "No lsm303d"
|
2014-06-26 01:05:15 -03:00
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2014-11-18 00:39:37 -04:00
|
|
|
# internal MPU6000 is rotated ROLL_180_YAW_270 from standard
|
|
|
|
if mpu6000 -R 14 start
|
|
|
|
then
|
|
|
|
echo "Found MPU6000 internal"
|
|
|
|
else
|
2015-08-01 03:33:54 -03:00
|
|
|
if mpu9250 -R 14 start
|
|
|
|
then
|
|
|
|
echo "Found MPU9250 internal"
|
|
|
|
else
|
|
|
|
echo "No MPU6000 or MPU9250"
|
|
|
|
echo "No MPU6000 or MPU9250" >> $logfile
|
2014-11-18 00:39:37 -04:00
|
|
|
sh /etc/init.d/rc.error
|
2015-08-01 03:33:54 -03:00
|
|
|
fi
|
2014-11-18 00:39:37 -04:00
|
|
|
fi
|
2015-04-02 18:35:52 -03:00
|
|
|
if hmc5883 -C -T -S -R 8 start
|
2015-03-10 00:41:05 -03:00
|
|
|
then
|
|
|
|
echo "Found SPI hmc5883"
|
|
|
|
fi
|
2014-06-26 01:05:15 -03:00
|
|
|
else
|
2014-07-03 01:21:45 -03:00
|
|
|
if mpu6000 start
|
|
|
|
then
|
|
|
|
echo "Found MPU6000"
|
|
|
|
else
|
2015-08-01 03:33:54 -03:00
|
|
|
if mpu9250 start
|
|
|
|
then
|
|
|
|
echo "Found MPU9250"
|
|
|
|
else
|
|
|
|
echo "No MPU6000 or MPU9250"
|
|
|
|
echo "No MPU9250" >> $logfile
|
|
|
|
fi
|
2014-07-03 01:21:45 -03:00
|
|
|
fi
|
|
|
|
if l3gd20 start
|
|
|
|
then
|
|
|
|
echo "l3gd20 started OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
if lsm303d start
|
|
|
|
then
|
|
|
|
echo "lsm303d started OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# optional ETS airspeed sensor
|
|
|
|
if ets_airspeed start
|
|
|
|
then
|
2014-01-13 22:57:59 -04:00
|
|
|
echo "Found ETS airspeed sensor"
|
2013-08-03 05:51:59 -03:00
|
|
|
fi
|
|
|
|
|
2013-08-21 08:06:54 -03:00
|
|
|
if meas_airspeed start
|
|
|
|
then
|
2014-01-13 22:57:59 -04:00
|
|
|
echo "Found MEAS airspeed sensor"
|
2015-10-16 04:38:40 -03:00
|
|
|
else
|
|
|
|
if meas_airspeed start -b 2
|
|
|
|
then
|
|
|
|
echo "Found MEAS airspeed sensor (bus2)"
|
|
|
|
fi
|
2013-08-21 08:06:54 -03:00
|
|
|
fi
|
|
|
|
|
2014-04-30 14:39:07 -03:00
|
|
|
# optional Range Finder sensor
|
2014-10-19 17:07:14 -03:00
|
|
|
if ll40ls -X start
|
2014-04-30 14:39:07 -03:00
|
|
|
then
|
2014-10-19 17:07:14 -03:00
|
|
|
echo "Found external ll40ls sensor"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ll40ls -I start
|
|
|
|
then
|
|
|
|
echo "Found internal ll40ls sensor"
|
2014-04-30 14:39:07 -03:00
|
|
|
fi
|
|
|
|
|
2015-01-07 15:45:18 -04:00
|
|
|
if trone start
|
|
|
|
then
|
|
|
|
echo "Found trone sensor"
|
|
|
|
fi
|
|
|
|
|
2014-06-06 11:04:14 -03:00
|
|
|
if mb12xx start
|
|
|
|
then
|
|
|
|
echo "Found mb12xx sensor"
|
|
|
|
fi
|
|
|
|
|
2014-07-11 23:28:54 -03:00
|
|
|
# optional PX4Flow sensor
|
|
|
|
if px4flow start
|
|
|
|
then
|
|
|
|
echo "Found px4flow sensor"
|
|
|
|
fi
|
|
|
|
|
2015-02-21 06:55:36 -04:00
|
|
|
# optional PWM input driver
|
|
|
|
if pwm_input start
|
|
|
|
then
|
|
|
|
echo "started pwm_input driver"
|
|
|
|
fi
|
|
|
|
|
2014-07-11 23:28:54 -03:00
|
|
|
echo "Trying PX4IO board"
|
|
|
|
|
2014-01-15 04:32:49 -04:00
|
|
|
if mtd start /fs/mtd
|
2014-01-13 21:41:07 -04:00
|
|
|
then
|
2014-01-15 04:32:49 -04:00
|
|
|
echo "started mtd driver OK"
|
|
|
|
else
|
|
|
|
echo "failed to start mtd driver"
|
2014-01-15 21:47:48 -04:00
|
|
|
echo "failed to start mtd driver" >> $logfile
|
2014-01-15 04:32:49 -04:00
|
|
|
sh /etc/init.d/rc.error
|
2014-01-13 21:41:07 -04:00
|
|
|
fi
|
|
|
|
|
2014-01-15 21:47:48 -04:00
|
|
|
if mtd readtest /fs/mtd
|
|
|
|
then
|
|
|
|
echo "mtd readtest OK"
|
|
|
|
else
|
|
|
|
echo "failed to read mtd"
|
|
|
|
echo "failed to read mtd" >> $logfile
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
2015-01-28 08:28:58 -04:00
|
|
|
# optional oreo leds
|
2015-05-02 00:02:48 -03:00
|
|
|
if oreoled start autoupdate
|
2015-01-28 08:28:58 -04:00
|
|
|
then
|
|
|
|
echo "oreoled started OK"
|
|
|
|
fi
|
|
|
|
|
2015-09-08 08:51:23 -03:00
|
|
|
# optional smbus battery monitor
|
|
|
|
if batt_smbus -b 2 start
|
|
|
|
then
|
|
|
|
echo "Found batt_smbus"
|
|
|
|
fi
|
|
|
|
|
2015-03-17 05:21:32 -03:00
|
|
|
# optional irlock
|
|
|
|
if irlock start
|
|
|
|
then
|
|
|
|
echo "irlock started"
|
|
|
|
fi
|
|
|
|
|
2014-01-15 21:47:48 -04:00
|
|
|
if [ $BOARD == FMUv2 ]
|
|
|
|
then
|
|
|
|
# the ramtron on FMUv2 is very fast and can handle trillions of
|
|
|
|
# writes. This full rw test on each boot ensures it is working
|
|
|
|
# properly. We have one board that failed this, so
|
|
|
|
# the test is arguably worth having
|
|
|
|
if mtd rwtest /fs/mtd
|
|
|
|
then
|
|
|
|
echo "mtd rwtest OK"
|
|
|
|
else
|
|
|
|
echo "failed to test mtd"
|
|
|
|
echo "failed to test mtd" >> $logfile
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2014-01-13 22:57:59 -04:00
|
|
|
echo Starting ArduPilot $deviceA $deviceC $deviceD
|
2013-11-22 06:54:37 -04:00
|
|
|
if ArduPilot -d $deviceA -d2 $deviceC -d3 $deviceD start
|
2013-08-03 05:51:59 -03:00
|
|
|
then
|
|
|
|
echo ArduPilot started OK
|
2013-01-20 17:21:44 -04:00
|
|
|
else
|
2013-08-03 05:51:59 -03:00
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
2013-02-17 22:55:58 -04:00
|
|
|
echo "rc.APM finished"
|
2013-08-05 23:11:18 -03:00
|
|
|
|