Files
bizhang_-obav/ROMFS/px4fmu_common/init.d/rcS

914 lines
16 KiB
Plaintext
Raw Normal View History

#!nsh
#
# PX4FMU startup script.
#
# NOTE: COMMENT LINES ARE REMOVED BEFORE STORED IN ROMFS.
#
#
# Start CDC/ACM serial driver
#
sercon
#
# Default to auto-start mode.
#
set MODE autostart
set TUNE_ERR ML<<CP4CP4CP4CP4CP4
set LOG_FILE /fs/microsd/bootlog.txt
#
# Try to mount the microSD card.
#
2015-02-14 20:33:20 +01:00
# REBOOTWORK this needs to start after the flight control loop
if mount -t vfat /dev/mmcsd0 /fs/microsd
then
# Start playing the startup tune
tone_alarm start
else
tone_alarm MBAGP
if mkfatfs /dev/mmcsd0
then
if mount -t vfat /dev/mmcsd0 /fs/microsd
then
echo "INFO [init] MicroSD card formatted"
else
echo "ERROR [init] Format failed"
tone_alarm MNBG
set LOG_FILE /dev/null
fi
else
set LOG_FILE /dev/null
fi
fi
#
# Look for an init script on the microSD card.
# Disable autostart if the script found.
#
set FRC /fs/microsd/etc/rc.txt
if [ -f $FRC ]
2012-12-27 13:17:43 +01:00
then
echo "INFO [init] Executing script: $FRC"
sh $FRC
set MODE custom
fi
2015-01-08 15:42:25 +01:00
unset FRC
2013-07-18 10:01:03 +02:00
if [ $MODE == autostart ]
then
2014-08-26 10:13:52 +02:00
2013-08-25 19:27:11 +02:00
#
# Start the ORB (first app to start)
#
uorb start
2014-06-01 10:59:11 +02:00
2013-08-25 19:27:11 +02:00
#
# Load parameters
2013-08-25 19:27:11 +02:00
#
set PARAM_FILE /fs/microsd/params
if mtd start
then
set PARAM_FILE /fs/mtd_params
fi
2014-06-01 10:59:11 +02:00
param select $PARAM_FILE
if param load
then
else
if param reset
then
fi
2014-01-12 17:43:33 +01:00
fi
2014-06-01 10:59:11 +02:00
2013-08-25 19:27:11 +02:00
#
# Start system state indicator
#
if rgbled start
2013-08-17 15:48:13 +02:00
then
2013-08-25 19:27:11 +02:00
else
if blinkm start
then
blinkm systemstate
fi
2013-08-17 15:48:13 +02:00
fi
# Currently unused, but might be useful down the road
#if pca8574 start
#then
#fi
2014-06-01 10:59:11 +02:00
#
# Set AUTOCNF flag to use it in AUTOSTART scripts
#
if param compare SYS_AUTOCONFIG 1
then
# Wipe out params except RC*
param reset_nostart RC*
set AUTOCNF yes
else
set AUTOCNF no
#
# Release 1.4.0 transitional support:
# set to old default if unconfigured.
# this preserves the previous behaviour
#
if param compare BAT_N_CELLS 0
then
param set BAT_N_CELLS 3
fi
fi
#
# Set default values
#
set HIL no
set VEHICLE_TYPE none
set MIXER none
set MIXER_AUX none
2014-01-11 17:52:29 +01:00
set OUTPUT_MODE none
set PWM_OUT none
set PWM_RATE none
set PWM_DISARMED none
set PWM_MIN none
set PWM_MAX none
set PWM_AUX_OUT none
set PWM_AUX_RATE none
set PWM_ACHDIS none
set PWM_AUX_DISARMED none
set PWM_AUX_MIN none
set PWM_AUX_MAX none
2015-04-26 23:27:23 +02:00
set FAILSAFE_AUX none
set MK_MODE none
2014-01-11 17:52:29 +01:00
set FMU_MODE pwm
set AUX_MODE pwm
set MAVLINK_F default
set EXIT_ON_END no
set MAV_TYPE none
2014-08-26 10:13:52 +02:00
set FAILSAFE none
set USE_IO yes
#
# Set USE_IO flag
#
if param compare SYS_USE_IO 1
then
if ver hwcmp PX4FMU_V4
then
set USE_IO no
fi
if ver hwcmp MINDPX_V2
then
set USE_IO no
fi
else
set USE_IO no
fi
# should set to 0.8 for mindpx-v2 borad.
if param compare INAV_LIDAR_ERR 0.5
then
if ver hwcmp MINDPX_V2
then
param set INAV_LIDAR_ERR 0.8
param save
fi
fi
2014-06-01 10:59:11 +02:00
2013-08-25 19:27:11 +02:00
#
2014-01-08 20:55:12 +01:00
# Set parameters and env variables for selected AUTOSTART
2013-08-25 19:27:11 +02:00
#
if param compare SYS_AUTOSTART 0
then
echo "INFO [init] No autostart"
else
sh /etc/init.d/rc.autostart
fi
2015-01-09 07:56:20 +01:00
unset MODE
2015-12-07 11:38:28 +01:00
#
# Wipe incompatible settings for boards not having two outputs
if ver hwcmp PX4FMU_V4
then
set MIXER_AUX none
fi
2013-08-25 19:27:11 +02:00
#
# Override parameters from user configuration file
2013-08-25 19:27:11 +02:00
#
set FCONFIG /fs/microsd/etc/config.txt
if [ -f $FCONFIG ]
then
echo "INFO [init] Custom: $FCONFIG"
sh $FCONFIG
fi
unset FCONFIG
#
# If autoconfig parameter was set, reset it and save parameters
#
if [ $AUTOCNF == yes ]
then
param set SYS_AUTOCONFIG 0
param save
fi
2015-01-09 07:56:20 +01:00
unset AUTOCNF
2014-06-01 10:59:11 +02:00
2014-01-11 17:52:29 +01:00
set IO_PRESENT no
2014-06-01 10:59:11 +02:00
2014-01-11 17:52:29 +01:00
if [ $USE_IO == yes ]
then
2014-01-11 17:52:29 +01:00
#
# Check if PX4IO present and update firmware if needed
#
if [ -f /etc/extras/px4io-v2.bin ]
then
set IO_FILE /etc/extras/px4io-v2.bin
2014-01-11 17:52:29 +01:00
else
set IO_FILE /etc/extras/px4io-v1.bin
2014-01-11 17:52:29 +01:00
fi
2014-06-01 10:59:11 +02:00
2015-02-14 20:33:20 +01:00
if px4io checkcrc ${IO_FILE}
2014-01-11 17:52:29 +01:00
then
echo "INFO [init] PX4IO CRC OK" >> $LOG_FILE
2014-06-01 10:59:11 +02:00
2014-01-11 17:52:29 +01:00
set IO_PRESENT yes
else
2014-01-11 18:45:56 +01:00
tone_alarm MLL32CP8MB
2014-06-01 10:59:11 +02:00
if px4io start
then
# try to safe px4 io so motor outputs dont go crazy
if px4io safety_on
then
# success! no-op
else
# px4io did not respond to the safety command
px4io stop
fi
fi
2015-02-14 20:33:20 +01:00
if px4io forceupdate 14662 ${IO_FILE}
2013-08-31 11:56:39 +02:00
then
2014-01-11 17:52:29 +01:00
usleep 500000
if px4io checkcrc $IO_FILE
then
echo "INFO [init] PX4IO CRC OK after updating" >> $LOG_FILE
2014-01-11 18:45:56 +01:00
tone_alarm MLL8CDE
2014-06-01 10:59:11 +02:00
2014-01-11 17:52:29 +01:00
set IO_PRESENT yes
else
echo "ERROR [init] PX4IO update failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-11 17:52:29 +01:00
fi
else
echo "ERROR [init] PX4IO update failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2013-08-31 11:56:39 +02:00
fi
2014-01-11 17:52:29 +01:00
fi
unset IO_FILE
2014-06-01 10:59:11 +02:00
2014-01-11 17:52:29 +01:00
if [ $IO_PRESENT == no ]
then
echo "ERROR [init] PX4IO not found" >> $LOG_FILE
tone_alarm $TUNE_ERR
2013-08-31 11:56:39 +02:00
fi
fi
2014-06-01 10:59:11 +02:00
2013-08-25 19:27:11 +02:00
#
2014-01-11 17:52:29 +01:00
# Set default output if not set
#
if [ $OUTPUT_MODE == none ]
2013-12-28 22:52:23 +01:00
then
if [ $USE_IO == yes ]
2014-01-11 17:52:29 +01:00
then
set OUTPUT_MODE io
else
set OUTPUT_MODE fmu
fi
2013-12-28 22:52:23 +01:00
fi
if [ $OUTPUT_MODE == io -a $IO_PRESENT != yes ]
2013-12-28 22:52:23 +01:00
then
# Need IO for output but it not present, disable output
set OUTPUT_MODE none
2014-06-01 10:59:11 +02:00
# Avoid using ttyS0 for MAVLink on FMUv1
if ver hwcmp PX4FMU_V1
then
set FMU_MODE serial
fi
2013-10-19 11:11:15 +02:00
fi
2014-01-06 09:25:39 +01:00
if [ $OUTPUT_MODE == ardrone ]
then
set FMU_MODE gpio_serial
fi
2014-01-11 17:52:29 +01:00
if [ $HIL == yes ]
2014-01-06 09:25:39 +01:00
then
2014-01-11 17:52:29 +01:00
set OUTPUT_MODE hil
if ver hwcmp PX4FMU_V1
2014-01-18 16:47:23 +01:00
then
set FMU_MODE serial
fi
unset HIL
else
unset HIL
gps start
2014-01-06 09:25:39 +01:00
fi
2014-11-15 16:19:51 +01:00
# waypoint storage
2015-02-14 20:33:20 +01:00
# REBOOTWORK this needs to start in parallel
if dataman start
then
fi
2014-06-30 12:42:26 +02:00
#
# Sensors System (start before Commander so Preflight checks are properly run)
#
sh /etc/init.d/rc.sensors
2014-11-15 16:19:51 +01:00
# Needs to be this early for in-air-restarts
if [ $OUTPUT_MODE == hil ]
then
commander start -hil
else
commander start
fi
2014-06-01 10:59:11 +02:00
2016-04-29 14:27:16 +02:00
#
# Start CPU load monitor
#
load_mon start
#
# Start primary output
#
2014-01-11 17:52:29 +01:00
set TTYS1_BUSY no
2014-06-01 10:59:11 +02:00
#
# Check if UAVCAN is enabled, default to it for ESCs
#
if param greater UAVCAN_ENABLE 2
then
set OUTPUT_MODE uavcan_esc
fi
2014-01-18 16:47:23 +01:00
# If OUTPUT_MODE == none then something is wrong with setup and we shouldn't try to enable output
if [ $OUTPUT_MODE != none ]
then
if [ $OUTPUT_MODE == uavcan_esc ]
2014-05-08 14:23:33 +02:00
then
2014-08-23 17:23:59 +04:00
if param compare UAVCAN_ENABLE 0
2014-05-08 14:23:33 +02:00
then
echo "INFO [init] OVERRIDING UAVCAN_ENABLE = 1" >> $LOG_FILE
2014-08-23 17:23:59 +04:00
param set UAVCAN_ENABLE 1
2014-05-08 14:23:33 +02:00
fi
fi
if [ $OUTPUT_MODE == io -o $OUTPUT_MODE == uavcan_esc ]
2014-01-10 13:18:34 +01:00
then
2014-01-11 17:52:29 +01:00
if px4io start
then
sh /etc/init.d/rc.io
else
echo "INFO [init] PX4IO start failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-11 17:52:29 +01:00
fi
fi
2014-06-01 10:59:11 +02:00
2014-03-06 23:00:00 +01:00
if [ $OUTPUT_MODE == fmu -o $OUTPUT_MODE == ardrone ]
2014-01-11 17:52:29 +01:00
then
if fmu mode_$FMU_MODE
then
else
echo "ERR [init] FMU start failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-11 17:52:29 +01:00
fi
2014-06-01 10:59:11 +02:00
if ver hwcmp PX4FMU_V1
2014-01-11 17:52:29 +01:00
then
if [ $FMU_MODE == pwm -o $FMU_MODE == gpio ]
then
set TTYS1_BUSY yes
fi
2014-03-06 17:44:10 +04:00
if [ $FMU_MODE == pwm_gpio -o $OUTPUT_MODE == ardrone ]
2014-01-11 17:52:29 +01:00
then
set TTYS1_BUSY yes
fi
fi
2014-01-08 20:55:12 +01:00
fi
2014-06-01 10:59:11 +02:00
2014-01-18 16:47:23 +01:00
if [ $OUTPUT_MODE == mkblctrl ]
then
set MKBLCTRL_ARG ""
2015-02-16 22:06:17 +01:00
if [ $MKBLCTRL_MODE == x ]
2014-01-18 16:47:23 +01:00
then
set MKBLCTRL_ARG "-mkmode x"
fi
2015-02-16 22:06:17 +01:00
if [ $MKBLCTRL_MODE == + ]
2014-01-18 16:47:23 +01:00
then
set MKBLCTRL_ARG "-mkmode +"
fi
2014-06-01 10:59:11 +02:00
2014-01-18 16:47:23 +01:00
if mkblctrl $MKBLCTRL_ARG
then
else
echo "ERROR [init] MK start failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-18 16:47:23 +01:00
fi
2015-01-08 15:42:25 +01:00
unset MKBLCTRL_ARG
fi
2015-01-08 15:42:25 +01:00
unset MK_MODE
2014-06-01 10:59:11 +02:00
2014-01-18 16:47:23 +01:00
if [ $OUTPUT_MODE == hil ]
then
2015-08-12 19:24:08 +02:00
if pwm_out_sim mode_port2_pwm8
2014-01-18 16:47:23 +01:00
then
else
echo "ERROR [init] PWM SIM start failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-18 16:47:23 +01:00
fi
fi
2014-06-01 10:59:11 +02:00
2014-01-18 16:47:23 +01:00
#
# Start IO or FMU for RC PPM input if needed
#
if [ $IO_PRESENT == yes ]
then
if [ $OUTPUT_MODE != io ]
then
if px4io start
then
sh /etc/init.d/rc.io
else
echo "ERROR [init] PX4IO start failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-18 16:47:23 +01:00
fi
fi
else
if [ $OUTPUT_MODE != fmu -a $OUTPUT_MODE != ardrone ]
2014-01-18 16:47:23 +01:00
then
if fmu mode_$FMU_MODE
then
else
echo "ERROR [init] FMU mode_$FMU_MODE start failed" >> $LOG_FILE
tone_alarm $TUNE_ERR
2014-01-18 16:47:23 +01:00
fi
2014-06-01 10:59:11 +02:00
if ver hwcmp PX4FMU_V1
2014-01-18 16:47:23 +01:00
then
if [ $FMU_MODE == pwm -o $FMU_MODE == gpio ]
then
set TTYS1_BUSY yes
fi
2014-03-06 17:44:10 +04:00
if [ $FMU_MODE == pwm_gpio -o $OUTPUT_MODE == ardrone ]
2014-01-18 16:47:23 +01:00
then
set TTYS1_BUSY yes
fi
fi
fi
fi
fi
2014-06-01 10:59:11 +02:00
if [ $MAVLINK_F == default ]
2013-08-25 19:27:11 +02:00
then
# Normal mode, use baudrate 57600 (default) and data rate 1000 bytes/s
if [ $TTYS1_BUSY == yes ]
2014-01-10 13:18:34 +01:00
then
# Start MAVLink on ttyS0, because FMU ttyS1 pins configured as something else
set MAVLINK_F "-r 1200 -d /dev/ttyS0"
# Exit from nsh to free port for mavlink
set EXIT_ON_END yes
else
set MAVLINK_F "-r 1200"
2015-11-27 15:14:24 +01:00
# Avoid using ttyS1 for MAVLink on FMUv4
if ver hwcmp PX4FMU_V4
then
2016-01-23 18:25:07 +01:00
set MAVLINK_F "-r 1200 -d /dev/ttyS1"
2015-12-17 22:07:27 +00:00
# Start MAVLink on Wifi (ESP8266 port)
2016-04-11 12:51:07 -07:00
mavlink start -r 20000 -m config -b 921600 -d /dev/ttyS0
2015-11-27 15:14:24 +01:00
fi
2014-01-10 13:18:34 +01:00
fi
2013-08-25 19:27:11 +02:00
fi
mavlink start $MAVLINK_F
unset MAVLINK_F
2014-06-01 10:59:11 +02:00
#
# MAVLink onboard / TELEM2
#
2016-02-19 21:37:36 +01:00
if ver hwcmp PX4FMU_V1
then
2016-02-19 21:37:36 +01:00
else
2015-04-23 13:33:54 +02:00
# XXX We need a better way for runtime eval of shell variables,
# but this works for now
if param compare SYS_COMPANION 10
then
frsky_telemetry start -d /dev/ttyS2
fi
if param compare SYS_COMPANION 921600
then
mavlink start -d /dev/ttyS2 -b 921600 -m onboard -r 80000 -x
fi
2015-04-23 13:33:54 +02:00
if param compare SYS_COMPANION 57600
then
2015-06-30 15:19:57 +02:00
mavlink start -d /dev/ttyS2 -b 57600 -m onboard -r 5000 -x
2015-04-23 13:33:54 +02:00
fi
2015-06-06 22:07:23 +02:00
if param compare SYS_COMPANION 157600
then
mavlink start -d /dev/ttyS2 -b 57600 -m osd -r 1000
fi
if param compare SYS_COMPANION 257600
then
mavlink start -d /dev/ttyS2 -b 57600 -m magic -r 5000 -x
fi
if param compare SYS_COMPANION 357600
then
mavlink start -d /dev/ttyS2 -b 57600 -r 1000
fi
2016-04-29 14:59:11 +02:00
if param compare SYS_COMPANION 1921600
then
mavlink start -d /dev/ttyS2 -b 921600 -r 20000
fi
# Sensors on the PWM interface bank
# clear pins 5 and 6
if param compare SENS_EN_LL40LS 1
then
2016-06-29 12:49:08 +02:00
set FMU_MODE pwm4
set AUX_MODE pwm4
fi
if param greater TRIG_MODE 0
then
2016-06-29 12:49:08 +02:00
set FMU_MODE pwm4
set AUX_MODE pwm4
2016-06-16 15:40:01 +02:00
camera_trigger start
fi
fi
#
# Starting stuff according to UAVCAN_ENABLE value
#
if param greater UAVCAN_ENABLE 0
then
if uavcan start
then
else
tone_alarm $TUNE_ERR
fi
fi
if param greater UAVCAN_ENABLE 1
then
if uavcan start fw
then
else
tone_alarm $TUNE_ERR
fi
fi
#
# Optional drivers
#
# Sensors on the PWM interface bank
if param compare SENS_EN_LL40LS 1
then
if pwm_input start
then
if ll40ls start pwm
then
fi
fi
fi
# sf0x lidar sensor
if param compare SENS_EN_SF0X 1
then
sf0x start
fi
if ver hwcmp PX4FMU_V4
then
frsky_telemetry start -d /dev/ttyS6
fi
if ver hwcmp PX4FMU_V2
then
# Check for flow sensor - as it is a background task, launch it last
px4flow start &
fi
if ver hwcmp MINDPX_V2
then
#mindxp also need flow
px4flow start &
fi
# Start USB shell if no microSD present, MAVLink else
if [ $LOG_FILE == /dev/null ]
then
# Try to get an USB console
nshterm /dev/ttyACM0 &
else
2016-06-16 15:40:01 +02:00
mavlink start -r 800000 -d /dev/ttyACM0 -m config -x
fi
#
# Logging
#
if ver hwcmp PX4FMU_V1
then
if sdlog2 start -r 30 -a -b 2 -t
then
fi
else
# check if we should increase logging rate for ekf2 replay message logging
if param greater EKF2_REC_RPL 0
then
if param compare SYS_LOGGER 0
then
if sdlog2 start -r 500 -e -b 18 -t
then
fi
else
if logger start -r 500
then
fi
fi
else
if param compare SYS_LOGGER 0
then
2016-05-29 16:24:36 +02:00
if sdlog2 start -r 100 -a -b 9 -t
then
fi
else
if logger start -b 12 -t
then
fi
fi
fi
fi
2014-03-05 10:50:16 +01:00
#
# Start up ARDrone Motor interface
#
if [ $OUTPUT_MODE == ardrone ]
2014-03-05 10:50:16 +01:00
then
ardrone_interface start -d /dev/ttyS1
fi
#
# Fixed wing setup
#
if [ $VEHICLE_TYPE == fw ]
2013-09-29 19:00:12 +02:00
then
echo "INFO [init] Fixedwing"
2014-06-01 10:59:11 +02:00
if [ $MIXER == none ]
2014-01-08 20:55:12 +01:00
then
# Set default mixer for fixed wing if not defined
set MIXER AERT
2014-01-08 20:55:12 +01:00
fi
2014-06-01 10:59:11 +02:00
if [ $MAV_TYPE == none ]
then
# Use MAV_TYPE = 1 (fixed wing) if not defined
set MAV_TYPE 1
fi
2014-06-01 10:59:11 +02:00
param set MAV_TYPE $MAV_TYPE
2014-06-01 10:59:11 +02:00
# Load mixer and configure outputs
sh /etc/init.d/rc.interface
2014-06-01 10:59:11 +02:00
# Start standard fixedwing apps
sh /etc/init.d/rc.fw_apps
2013-09-29 19:00:12 +02:00
fi
2013-09-07 12:17:27 +02:00
#
# Multicopters setup
#
if [ $VEHICLE_TYPE == mc ]
2013-12-28 08:56:58 +01:00
then
echo "INFO [init] Multicopter"
2013-12-28 08:56:58 +01:00
if [ $MIXER == none ]
2014-01-10 13:18:34 +01:00
then
echo "INFO [init] Mixer undefined"
fi
2013-12-28 14:45:29 +01:00
if [ $MAV_TYPE == none ]
then
# Use mixer to detect vehicle type
if [ $MIXER == quad_x -o $MIXER == quad_+ ]
then
set MAV_TYPE 2
fi
if [ $MIXER == quad_w -o $MIXER == sk450_deadcat ]
then
set MAV_TYPE 2
fi
2016-02-15 15:58:01 +01:00
if [ $MIXER == quad_h ]
then
set MAV_TYPE 2
fi
2015-02-05 23:23:41 -08:00
if [ $MIXER == tri_y_yaw- -o $MIXER == tri_y_yaw+ ]
then
set MAV_TYPE 15
2015-02-05 23:23:41 -08:00
fi
if [ $MIXER == hexa_x -o $MIXER == hexa_+ ]
2014-02-11 15:35:26 +01:00
then
2014-02-11 08:09:51 +01:00
set MAV_TYPE 13
fi
if [ $MIXER == hexa_cox ]
then
set MAV_TYPE 13
fi
if [ $MIXER == octo_x -o $MIXER == octo_+ ]
then
set MAV_TYPE 14
fi
if [ $MIXER == octo_cox -o $MIXER == octo_cox_w ]
then
set MAV_TYPE 14
fi
2016-05-20 10:06:04 +02:00
if [ $MIXER == coax ]
then
set MAV_TYPE 3
fi
2014-01-10 13:18:34 +01:00
fi
2014-06-01 10:59:11 +02:00
# Still no MAV_TYPE found
if [ $MAV_TYPE == none ]
then
echo "WARN [init] Unknown MAV_TYPE"
param set MAV_TYPE 2
else
param set MAV_TYPE $MAV_TYPE
fi
2014-06-01 10:59:11 +02:00
# Load mixer and configure outputs
sh /etc/init.d/rc.interface
2014-06-01 10:59:11 +02:00
# Start standard multicopter apps
sh /etc/init.d/rc.mc_apps
2013-09-07 12:17:27 +02:00
fi
#
# VTOL setup
#
if [ $VEHICLE_TYPE == vtol ]
then
echo "INFO [init] VTOL"
if [ $MIXER == none ]
then
echo "WARN [init] VTOL mixer undefined"
fi
if [ $MAV_TYPE == none ]
then
# Use mixer to detect vehicle type
if [ $MIXER == caipirinha_vtol ]
then
2014-12-02 11:02:23 +01:00
set MAV_TYPE 19
fi
2015-04-20 17:09:09 +02:00
if [ $MIXER == firefly6 ]
then
set MAV_TYPE 21
fi
if [ $MIXER == quad_x_pusher_vtol ]
then
set MAV_TYPE 22
fi
fi
# Still no MAV_TYPE found
if [ $MAV_TYPE == none ]
then
echo "WARN [init] Unknown MAV_TYPE"
param set MAV_TYPE 19
else
param set MAV_TYPE $MAV_TYPE
fi
# Load mixer and configure outputs
sh /etc/init.d/rc.interface
# Start standard vtol apps
sh /etc/init.d/rc.vtol_apps
fi
2015-02-19 21:50:54 +01:00
#
# Rover setup
#
if [ $VEHICLE_TYPE == rover ]
2015-02-20 14:43:28 +01:00
then
2015-02-19 21:50:54 +01:00
# 10 is MAV_TYPE_GROUND_ROVER
set MAV_TYPE 10
# Load mixer and configure outputs
sh /etc/init.d/rc.interface
# Start standard rover apps
sh /etc/init.d/rc.axialracing_ax10_apps
param set MAV_TYPE 10
2015-02-19 21:50:54 +01:00
fi
#
# For snapdragon, we need a passthrough mode
# Do not run any mavlink instances since we need the serial port for
# communication with Snapdragon.
#
if [ $VEHICLE_TYPE == passthrough ]
then
mavlink stop-all
commander stop
# Stop multicopter attitude controller if it is running, the controls come
# from Snapdragon.
if mc_att_control stop
then
fi
# Start snapdragon interface on serial port.
if ver hwcmp PX4FMU_V2
then
# On Pixfalcon use the standard telemetry port (Telem 1).
snapdragon_rc_pwm start -d /dev/ttyS1
px4io start
fi
if ver hwcmp PX4FMU_V4
then
# On Pixracer use Telem 2 port (TL2).
snapdragon_rc_pwm start -d /dev/ttyS2
fmu mode_pwm4
fi
pwm failsafe -c 1234 -p 900
pwm disarmed -c 1234 -p 900
# Arm straightaway.
pwm arm
# Use 400 Hz PWM on all channels.
pwm rate -a -r 400
fi
2015-01-08 15:42:25 +01:00
unset MIXER
unset MAV_TYPE
unset OUTPUT_MODE
2014-12-15 22:47:10 +01:00
#
# Start the navigator
#
navigator start
#
# Generic setup (autostart ID not found)
#
if [ $VEHICLE_TYPE == none ]
then
echo "WARN [init] No autostart ID found"
fi
# Start any custom addons
2015-01-08 15:42:25 +01:00
set FEXTRAS /fs/microsd/etc/extras.txt
if [ -f $FEXTRAS ]
2013-08-25 19:27:11 +02:00
then
echo "INFO [init] Addons script: $FEXTRAS"
sh $FEXTRAS
fi
unset FEXTRAS
# Run no SD alarm
if [ $LOG_FILE == /dev/null ]
then
# Play SOS
tone_alarm error
fi
# End of autostart
fi
2015-08-10 22:26:09 +02:00
# There is no further script processing, so we can free some RAM
# XXX potentially unset all script variables.
unset TUNE_ERR
# Boot is complete, inform MAVLink app(s) that the system is now fully up and running
mavlink boot_complete
if [ $EXIT_ON_END == yes ]
then
echo "INFO [init] NSH exit"
exit
fi
unset EXIT_ON_END