#!nsh # APM startup script for NuttX on PX4 # To disable APM startup add a /fs/microsd/APM/nostart file # To enable mkblctrl startup add a /fs/microsd/APM/mkblctrl file # To enable mavlink on ttys0 add a /fs/microsd/APM/mavlink-ttys0 file set deviceA /dev/ttyACM0 # 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 if [ -f /fs/microsd/APM/nostart ] then echo "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 "binfs already mounted" else echo "Mounting binfs" if mount -t binfs /dev/null /bin then echo "binfs mounted OK" else sh /etc/init.d/rc.error fi fi set sketch NONE set logfile /fs/microsd/APM/boot.log if [ ! -f /bin/ArduPilot ] then echo "/bin/ardupilot not found" sh /etc/init.d/rc.error fi if mkdir /fs/microsd/APM > /dev/null then echo "Created APM directory" fi uorb start if mpu6000 start then echo "Detected FMUv1 board" set BOARD FMUv1 else l3gd20 start echo "Detected FMUv2 board" set BOARD FMUv2 fi if [ -f /fs/microsd/APM/mavlink-ttys0 ] then set deviceC /dev/ttyS0 else if [ $BOARD == FMUv1 ] then set deviceC /dev/ttyS2 else set deviceC /dev/ttyS1 fi fi ######################## # PX4IO upgrade handling echo checking for /etc/px4io/px4io.bin sleep 1 if [ -f /etc/px4io/px4io.bin ] then echo "Checking for new px4io firmware" if cmp /etc/px4io/px4io.bin /fs/microsd/px4io.loaded then echo "No new px4io firmware" else echo Loading /etc/px4io/px4io.bin tone_alarm MBABGP if px4io update /etc/px4io/px4io.bin > /fs/microsd/APM/px4io_update.log then cp /etc/px4io/px4io.bin /fs/microsd/px4io.loaded echo Loaded /etc/px4io/px4io.bin OK >> /fs/microsd/APM/px4io_update.log tone_alarm MSPAA else echo Failed loading /etc/px4io/px4io.bin >> /fs/microsd/APM/px4io_update.log echo "check Safety Button" >> /fs/microsd/APM/px4io_update.log echo "Failed to upgrade PX4IO firmware" tone_alarm MNGGG fi fi fi echo "Starting APM sensors" echo "Starting APM sensors" > $logfile if ms5611 start then echo "ms5611 started OK" else sh /etc/init.d/rc.error fi if adc start then echo "adc started OK" else sh /etc/init.d/rc.error fi if [ $BOARD == FMUv1 ] then echo "Starting FMUv1 sensors" if hmc5883 start then echo "hmc5883 started OK" else sh /etc/init.d/rc.error fi else echo "Starting FMUv2 sensors" if hmc5883 start then echo "Using external magnetometer" fi if lsm303d start then echo "lsm303d started OK" else sh /etc/init.d/rc.error fi fi # why is this sleep needed? sleep 1 # optional ETS airspeed sensor if ets_airspeed start then echo "Found ETS airspeed sensor" >> $logfile fi echo "Trying PX4IO board" echo "Trying PX4IO board" >> $logfile if px4io start then echo "PX4IO board OK" echo "PX4IO board OK" >> $logfile echo "Setting FMU mode_pwm" fmu mode_pwm if [ $BOARD == FMUv1 -a $deviceC == /dev/ttyS1 ] then # ttyS1 is used for PWM output for 4 extra channels set deviceC /dev/ttyS2 fi sleep 1 else echo "No PX4IO board found" echo "No PX4IO board found" >> $logfile if [ -f /fs/microsd/APM/mkblctrl ] then echo "APM/mkblctrl found - switch to MK I2C ESCs" echo "APM/mkblctrl found - switch to MK I2C ESCs" >> $logfile echo "Setting up mkblctrl driver" echo "Setting up mkblctrl driver" >> $logfile mkblctrl -mkmode x fi echo "Setting up PX4FMU direct mode" fmu mode_pwm if [ $BOARD == FMUv1 -a $deviceC == /dev/ttyS1 ] then # ttyS1 is used for PWM output when there # is no IO board set deviceC /dev/ttyS2 fi fi echo Starting ArduPilot echo Starting ArduPilot $deviceA $deviceC >> $logfile if ArduPilot -d $deviceA -d2 $deviceC start then echo ArduPilot started OK else sh /etc/init.d/rc.error fi sleep 1 # if starting on the console, tell nsh to exit # this prevents it from chewing bytes if [ $deviceC == /dev/ttyS0 ] then echo "Exiting from nsh shell" exit fi echo "rc.APM finished" echo "rc.APM finished" >> $logfile sleep 1