2014-06-05 07:45:19 -03:00
|
|
|
#!nsh
|
|
|
|
|
|
|
|
# APM startup script for NuttX on VRBRAIN
|
|
|
|
|
|
|
|
# To disable APM startup add a /fs/microsd/APM/nostart file
|
|
|
|
|
|
|
|
# check for an old file called APM, caused by
|
|
|
|
# a bug in an earlier firmware release
|
|
|
|
if [ -f /fs/microsd/APM ]
|
|
|
|
then
|
|
|
|
echo "[APM] APM file found - renaming"
|
|
|
|
mv /fs/microsd/APM /fs/microsd/APM.old
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -f /fs/microsd/APM/nostart ]
|
|
|
|
then
|
|
|
|
echo "[APM] APM/nostart found - skipping APM startup"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
# mount binfs so we can find the built-in apps
|
|
|
|
if [ -f /bin/reboot ]
|
|
|
|
then
|
|
|
|
echo "[APM] binfs already mounted"
|
|
|
|
else
|
|
|
|
echo "[APM] Mounting binfs"
|
|
|
|
if mount -t binfs /dev/null /bin
|
|
|
|
then
|
|
|
|
echo "[APM] binfs mounted OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if rm /fs/microsd/APM/boot.log
|
|
|
|
then
|
|
|
|
echo "[APM] Removed old boot.log"
|
|
|
|
fi
|
|
|
|
set logfile /fs/microsd/APM/BOOT.LOG
|
|
|
|
|
|
|
|
if [ ! -f /bin/ArduPilot ]
|
|
|
|
then
|
|
|
|
echo "[APM] /bin/ArduPilot not found"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
if mkdir /fs/microsd/APM > /dev/null
|
|
|
|
then
|
|
|
|
echo "[APM] Created APM directory"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting UORB"
|
|
|
|
if uorb start
|
|
|
|
then
|
|
|
|
echo "[APM] UORB started OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting ADC"
|
|
|
|
if adc start
|
|
|
|
then
|
|
|
|
echo "[APM] ADC started OK"
|
|
|
|
else
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting APM sensors"
|
2014-07-14 07:55:52 -03:00
|
|
|
|
|
|
|
echo "[APM] Starting MS5611 Internal"
|
|
|
|
if ms5611 -I start
|
2014-06-05 07:45:19 -03:00
|
|
|
then
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] MS5611 onboard started OK"
|
2014-06-05 07:45:19 -03:00
|
|
|
else
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] MS5611 onboard start failed"
|
2014-06-05 07:45:19 -03:00
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] Starting MS5611 External EXP"
|
|
|
|
if ms5611 -X start
|
2014-06-05 07:45:19 -03:00
|
|
|
then
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] MS5611 external EXP started OK"
|
2014-06-05 07:45:19 -03:00
|
|
|
else
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] MS5611 external EXP start failed"
|
2014-06-24 10:58:14 -03:00
|
|
|
# sh /etc/init.d/rc.error
|
2014-06-05 07:45:19 -03:00
|
|
|
fi
|
|
|
|
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] Starting MS5611 External IMU"
|
|
|
|
if ms5611 -U start
|
|
|
|
then
|
|
|
|
echo "[APM] MS5611 external IMU started OK"
|
|
|
|
else
|
|
|
|
echo "[APM] MS5611 external IMU start failed"
|
2014-06-05 07:45:19 -03:00
|
|
|
# sh /etc/init.d/rc.error
|
2014-07-14 07:55:52 -03:00
|
|
|
fi
|
2014-06-05 07:45:19 -03:00
|
|
|
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] Starting HMC5883 External GPS"
|
|
|
|
if hmc5883 -X start
|
|
|
|
then
|
|
|
|
echo "[APM] HMC5883 External GPS started OK"
|
|
|
|
if hmc5883 -X calibrate
|
|
|
|
then
|
|
|
|
echo "[APM] HMC5883 External GPS calibrate OK"
|
|
|
|
else
|
|
|
|
echo "[APM] HMC5883 External GPS calibrate failed"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "[APM] HMC5883 External GPS start failed"
|
|
|
|
# sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting HMC5983 External EXP"
|
|
|
|
if hmc5983 -X start
|
|
|
|
then
|
|
|
|
echo "[APM] HMC5983 external EXP started OK"
|
|
|
|
if hmc5983 -X calibrate
|
|
|
|
then
|
|
|
|
echo "[APM] HMC5983 external EXP calibrate OK"
|
|
|
|
else
|
|
|
|
echo "[APM] HMC5983 external EXP calibrate failed"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "[APM] HMC5983 external EXP start failed"
|
|
|
|
# sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting HMC5983 External IMU"
|
|
|
|
if hmc5983 -U start
|
|
|
|
then
|
|
|
|
echo "[APM] HMC5983 external IMU started OK"
|
|
|
|
if hmc5983 -U calibrate
|
|
|
|
then
|
|
|
|
echo "[APM] HMC5983 external IMU calibrate OK"
|
|
|
|
else
|
|
|
|
echo "[APM] HMC5983 external IMU calibrate failed"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "[APM] HMC5983 external IMU start failed"
|
|
|
|
# sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting MPU6000 Internal"
|
|
|
|
if mpu6000 -I start
|
2014-06-05 07:45:19 -03:00
|
|
|
then
|
|
|
|
echo "[APM] MPU6000 onboard started OK"
|
|
|
|
else
|
|
|
|
echo "[APM] MPU6000 onboard start failed"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
2014-07-14 07:55:52 -03:00
|
|
|
echo "[APM] Starting MPU6000 External EXP"
|
|
|
|
if mpu6000 -X start
|
|
|
|
then
|
|
|
|
echo "[APM] MPU6000 external EXP started OK"
|
|
|
|
else
|
|
|
|
echo "[APM] MPU6000 external EXP start failed"
|
|
|
|
# sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting MPU6000 External IMU"
|
|
|
|
if mpu6000 -U start
|
|
|
|
then
|
|
|
|
echo "[APM] MPU6000 external IMU started OK"
|
|
|
|
else
|
|
|
|
echo "[APM] MPU6000 external IMU start failed"
|
2014-06-05 07:45:19 -03:00
|
|
|
# sh /etc/init.d/rc.error
|
2014-07-14 07:55:52 -03:00
|
|
|
fi
|
2014-06-05 07:45:19 -03:00
|
|
|
|
|
|
|
echo "[APM] Starting MTD driver"
|
|
|
|
if mtd start /fs/mtd
|
|
|
|
then
|
|
|
|
echo "[APM] MTD driver started OK"
|
|
|
|
else
|
|
|
|
echo "[APM] MTD driver start failed"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] MTD driver read test"
|
|
|
|
if mtd readtest /fs/mtd
|
|
|
|
then
|
|
|
|
echo "[APM] MTD driver readtest OK"
|
|
|
|
else
|
|
|
|
echo "[APM] MTD driver failed to read"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Starting VROUTPUT driver"
|
|
|
|
vroutput mode_pwm
|
|
|
|
#if vroutput mode_pwm
|
|
|
|
#then
|
|
|
|
# echo "[APM] VROUTPUT driver started OK"
|
|
|
|
#else
|
|
|
|
# echo "[APM] VROUTPUT driver start failed"
|
|
|
|
# sh /etc/init.d/rc.error
|
|
|
|
#fi
|
|
|
|
|
|
|
|
echo "[APM] Starting VRINPUT driver"
|
|
|
|
vrinput start
|
|
|
|
#if vrinput start
|
|
|
|
#then
|
|
|
|
# echo "[APM] VRINPUT driver started OK"
|
|
|
|
#else
|
|
|
|
# echo "[APM] VRINPUT driver start failed"
|
|
|
|
# sh /etc/init.d/rc.error
|
|
|
|
#fi
|
|
|
|
|
|
|
|
set sketch NONE
|
|
|
|
set deviceA /dev/ttyACM0
|
|
|
|
set deviceC /dev/ttyS2
|
|
|
|
|
|
|
|
echo "[APM] Starting ArduPilot"
|
|
|
|
#if ArduPilot -d $deviceA -d2 $deviceC start
|
|
|
|
if ArduPilot start
|
|
|
|
then
|
|
|
|
echo "[APM] ArduPilot started OK"
|
|
|
|
else
|
|
|
|
echo "[APM] ArduPilot start failed"
|
|
|
|
sh /etc/init.d/rc.error
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "[APM] Exiting from nsh shell"
|
|
|
|
exit
|
|
|
|
|
|
|
|
echo "[APM] Script finished"
|
|
|
|
|