[boards] Add the new OPA board

This commit is contained in:
Freek van Tienen
2016-04-22 16:59:47 +02:00
parent fc988a24fa
commit 38cbd8eb37
10 changed files with 950 additions and 9 deletions
+12 -1
View File
@@ -208,6 +208,17 @@
settings_modules="modules/air_data.xml modules/geo_mag.xml modules/gps_ubx_ucenter.xml modules/light.xml modules/digital_cam.xml"
gui_color="white"
/>
<aircraft
name="Outback"
ac_id="6"
airframe="airframes/TUDELFT/tudelft_outback.xml"
radio="radios/dummy.xml"
telemetry="telemetry/rotorcraft_with_logger.xml"
flight_plan="flight_plans/dummy.xml"
settings="settings/rotorcraft_basic.xml settings/control/stabilization_att_int.xml settings/control/rotorcraft_guidance.xml"
settings_modules="modules/geo_mag.xml modules/air_data.xml modules/temp_adc.xml modules/logger_sd_spi_direct.xml modules/gps_ubx_ucenter.xml"
gui_color="#ffffdffac31f"
/>
<aircraft
name="Quad_Navstik"
ac_id="50"
@@ -342,7 +353,7 @@
/>
<aircraft
name="quadshot"
ac_id="6"
ac_id="7"
airframe="airframes/examples/quadshot_asp21_spektrum.xml"
radio="radios/cockpitSX.xml"
telemetry="telemetry/default_rotorcraft.xml"
+236
View File
@@ -0,0 +1,236 @@
<!DOCTYPE airframe SYSTEM "../airframe.dtd">
<!-- this is a helicopter with a double wing as frame
* Autopilot: OPA/FTD 1.0 and OPA/AP 1.0 with STM32F4
* IMU: MPU6000 (FTD), MPU6000 (AP)
* Baro: MS5611 (AP)
* Actuators: 10 PWM (FTD)
* GPS: UBlox ??
* RC: Spektrum sats (2x)
* Telemetry: Iridium (FTD), 900Mhz ??? (AP)
-->
<airframe name="Outback">
<firmware name="rotorcraft">
<!-- AP (autopilot) part of the board -->
<target name="ap" board="opa_ap_1.0">
<!--target name="nps" board="pc">
<subsystem name="fdm" type="jsbsim"/>
</target-->
<module name="telemetry" type="xbee_api"/>
<module name="imu" type="mpu6000"/>
<module name="gps" type="ublox"/>
<module name="stabilization" type="int_quat"/>
<module name="ahrs" type="int_cmpl_quat"/>
<module name="ins" type="hff"/>
<module name="guidance" type="indi"/>
<module name="intermcu" type="uart"/>
<module name="current_sensor"/>
<module name="geo_mag"/>
<module name="air_data"/>
<module name="temp_adc"/>
<module name="logger_sd_spi_direct">
<define name="SDLOGGER_DIRECT_CONTROL_SWITCH" value="AUX3"/>
</module>
<module name="gps_ubx_ucenter"/>
</target>
<!-- FBW (Flight by Wire) part of the board -->
<target name="fbw" board="opa_ftd_1.0">
<module name="radio_control" type="spektrum">
<configure name="USE_SECONDARY_SPEKTRUM_RECEIVER" value="1"/>
<define name="RADIO_CONTROL_SPEKTRUM_NO_SIGN" value="1"/>
</module>
<module name="actuators" type="pwm"/>
<module name="intermcu" type="uart"/>
<module name="heli_throttle_curve"/>
<module name="heli_swashplate_mixing"/>
<define name="RC_LOST_FBW_MODE" value="FBW_MODE_FAILSAFE"/><!-- Switch to Failsafe or to Autopilot on RC loss? -->
<define name="RC_LOST_IN_AUTO_FBW_MODE" value="FBW_MODE_FAILSAFE"/><!-- Switch to Failsafe with a working autopilot on RC loss? -->
<define name="AP_LOST_FBW_MODE" value="FBW_MODE_MANUAL"/><!-- Switch to Failsafe or to Manual on AP loss? -->
</target>
</firmware>
<!-- This should be different for AP and FBW -->
<section name="BAT">
<define name="CATASTROPHIC_BAT_LEVEL" value="21.0" unit="V"/>
<define name="CRITIC_BAT_LEVEL" value="21.6" unit="V"/>
<define name="LOW_BAT_LEVEL" value="22.2" unit="V"/>
<define name="MAX_BAT_LEVEL" value="25.2" unit="V"/>
</section>
<servos driver="Pwm">
<servo name="THROTTLE" no="0" min="1100" neutral="1100" max="1900"/>
<servo name="SW_BACK" no="1" min="1900" neutral="1500" max="1100"/>
<servo name="SW_LEFTFRONT" no="2" min="1100" neutral="1500" max="1900"/>
<servo name="SW_RIGHTFRONT" no="3" min="1900" neutral="1500" max="1100"/>
<servo name="TAIL_LEFT" no="4" min="1100" neutral="1500" max="1900"/>
<servo name="TAIL_RIGHT" no="5" min="1100" neutral="1500" max="1900"/>
<servo name="AIL_LEFTFRONT" no="6" min="1100" neutral="1500" max="1900"/>
<servo name="AIL_LEFTBACK" no="7" min="1100" neutral="1500" max="1900"/>
<servo name="AIL_RIGHTFRONT" no="8" min="1100" neutral="1500" max="1900"/>
<servo name="AIL_RIGHTBACK" no="9" min="1100" neutral="1500" max="1900"/>
</servos>
<rc_commands>
<set command="THRUST" value="@THROTTLE"/>
<set command="ROLL" value="@ROLL"/>
<set command="PITCH" value="@PITCH"/>
<set command="YAW" value="@YAW"/>
<set command="FMODE" value="@AUX2"/>
</rc_commands>
<commands>
<axis name="THRUST" failsafe_value="0"/>
<axis name="ROLL" failsafe_value="0"/>
<axis name="PITCH" failsafe_value="0"/>
<axis name="YAW" failsafe_value="0"/>
<axis name="FMODE" failsafe_value="0"/>
</commands>
<section name="MIXING" prefix="SW_MIXING_">
<define name="TYPE" value="HR120"/>
<define name="TRIM_ROLL" value="0"/>
<define name="TRIM_PITCH" value="0"/>
<define name="TRIM_COLL" value="0"/>
</section>
<command_laws>
<call fun="throttle_curve_run(autopilot_motors_on, values)"/>
<call fun="swashplate_mixing_run(values)"/>
<set servo="THROTTLE" value="throttle_curve.throttle"/>
<set servo="SW_BACK" value="swashplate_mixing.commands[SW_BACK]"/>
<set servo="SW_LEFTFRONT" value="swashplate_mixing.commands[SW_LEFTFRONT]"/>
<set servo="SW_RIGHTFRONT" value="swashplate_mixing.commands[SW_RIGHTFRONT]"/>
<set servo="TAIL_LEFT" value="@YAW"/>
<set servo="TAIL_RIGHT" value="-@YAW"/>
<set servo="AIL_LEFTFRONT" value="@YAW"/>
<set servo="AIL_LEFTBACK" value="@YAW"/>
<set servo="AIL_RIGHTFRONT" value="@YAW"/>
<set servo="AIL_RIGHTBACK" value="@YAW"/>
</command_laws>
<heli_curves>
<curve throttle="0,4800,7200,8400,9600" collective="-1000,750,2500,4250,6000"/>
<curve throttle="9600,7200,9600" collective="-7500,0,7500"/>
</heli_curves>
<section name="MISC">
<define name="NAV_CLIMB_VSPEED" value="2.5"/>
<define name="NAV_DESCEND_VSPEED" value="-1.0"/>
<define name="NO_RC_THRUST_LIMIT" value="TRUE"/>
</section>
<section name="IMU" prefix="IMU_">
<define name="ACCEL_X_NEUTRAL" value="11"/>
<define name="ACCEL_Y_NEUTRAL" value="11"/>
<define name="ACCEL_Z_NEUTRAL" value="-25"/>
<!-- replace this with your own calibration -->
<define name="MAG_X_NEUTRAL" value="-2"/>
<define name="MAG_Y_NEUTRAL" value="484"/>
<define name="MAG_Z_NEUTRAL" value="53"/>
<define name="MAG_X_SENS" value="4.02836351262" integer="16"/>
<define name="MAG_Y_SENS" value="3.97184580645" integer="16"/>
<define name="MAG_Z_SENS" value="4.08689235615" integer="16"/>
<define name="BODY_TO_IMU_PHI" value="0." unit="deg"/>
<define name="BODY_TO_IMU_THETA" value="0." unit="deg"/>
<define name="BODY_TO_IMU_PSI" value="0." unit="deg"/>
</section>
<section name="AHRS" prefix="AHRS_">
<!-- values used if no GPS fix, on 3D fix is update by geo_mag module -->
<define name="H_X" value="0.3770441"/>
<define name="H_Y" value="0.0193986"/>
<define name="H_Z" value="0.9259921"/>
</section>
<section name="STABILIZATION_RATE" prefix="STABILIZATION_RATE_">
<!-- setpoints -->
<define name="SP_MAX_P" unit="deg/s" value="280"/>
<define name="SP_MAX_Q" unit="deg/s" value="280"/>
<define name="SP_MAX_R" unit="deg/s" value="140"/>
<define name="DEADBAND_P" value="20"/>
<define name="DEADBAND_Q" value="20"/>
<define name="DEADBAND_R" value="200"/>
<!-- feedback -->
<define name="GAIN_P" value="400"/>
<define name="GAIN_Q" value="400"/>
<define name="GAIN_R" value="350"/>
<define name="IGAIN_P" value="75"/>
<define name="IGAIN_Q" value="75"/>
<define name="IGAIN_R" value="50"/>
</section>
<section name="STABILIZATION_ATTITUDE" prefix="STABILIZATION_ATTITUDE_">
<!-- setpoints -->
<define name="SP_MAX_PHI" value="45." unit="deg"/>
<define name="SP_MAX_THETA" value="45." unit="deg"/>
<define name="SP_MAX_R" value="150." unit="deg/s"/>
<define name="DEADBAND_R" value="200"/>
<!-- reference -->
<define name="REF_OMEGA_P" value="800" unit="deg/s"/>
<define name="REF_ZETA_P" value="0.85"/>
<define name="REF_MAX_P" value="300." unit="deg/s"/>
<define name="REF_MAX_PDOT" value="RadOfDeg(7000.)"/>
<define name="REF_OMEGA_Q" value="800" unit="deg/s"/>
<define name="REF_ZETA_Q" value="0.85"/>
<define name="REF_MAX_Q" value="300." unit="deg/s"/>
<define name="REF_MAX_QDOT" value="RadOfDeg(7000.)"/>
<define name="REF_OMEGA_R" value="500" unit="deg/s"/>
<define name="REF_ZETA_R" value="0.85"/>
<define name="REF_MAX_R" value="180." unit="deg/s"/>
<define name="REF_MAX_RDOT" value="RadOfDeg(1800.)"/>
<!-- feedback -->
<define name="PHI_PGAIN" value="500"/>
<define name="PHI_DGAIN" value="100"/>
<define name="PHI_IGAIN" value="0"/>
<define name="THETA_PGAIN" value="500"/>
<define name="THETA_DGAIN" value="100"/>
<define name="THETA_IGAIN" value="0"/>
<define name="PSI_PGAIN" value="200"/>
<define name="PSI_DGAIN" value="0"/>
<define name="PSI_IGAIN" value="0"/>
<!-- feedforward -->
<define name="PHI_DDGAIN" value="0"/>
<define name="THETA_DDGAIN" value="0"/>
<define name="PSI_DDGAIN" value="0"/>
</section>
<section name="GUIDANCE_V" prefix="GUIDANCE_V_">
<define name="HOVER_KP" value="150"/>
<define name="HOVER_KD" value="80"/>
<define name="HOVER_KI" value="20"/>
<define name="NOMINAL_HOVER_THROTTLE" value="0.5"/>
<define name="ADAPT_THROTTLE_ENABLED" value="TRUE"/>
</section>
<section name="GUIDANCE_H" prefix="GUIDANCE_H_">
<define name="MAX_BANK" value="35" unit="deg"/>
<define name="USE_SPEED_REF" value="TRUE"/>
<define name="PGAIN" value="50"/>
<define name="DGAIN" value="100"/>
<define name="AGAIN" value="70"/>
<define name="IGAIN" value="20"/>
</section>
<section name="AUTOPILOT">
<define name="MODE_MANUAL" value="AP_MODE_RATE_DIRECT"/>
<define name="MODE_AUTO1" value="AP_MODE_ATTITUDE_DIRECT"/>
<define name="MODE_AUTO2" value="AP_MODE_NAV"/>
</section>
</airframe>
+70
View File
@@ -0,0 +1,70 @@
# Hey Emacs, this is a -*- makefile -*-
#
# Oversized Paparazzi (AP) Board
#
# http://wiki.paparazziuav.org/wiki/OPA
#
BOARD=opa_ap
BOARD_VERSION=1.0
BOARD_CFG=\"boards/$(BOARD)_$(BOARD_VERSION).h\"
ARCH=stm32
ARCH_L=f4
HARD_FLOAT=yes
$(TARGET).ARCHDIR = $(ARCH)
$(TARGET).LDSCRIPT=$(SRC_ARCH)/lisa-mx.ld
# -----------------------------------------------------------------------
#
# default flash mode is via SWD (JTAG)
#
FLASH_MODE ?= SWD
#
# default LED configuration
#
SYS_TIME_LED ?= 1
RADIO_CONTROL_LED ?= none
BARO_LED ?= none
AHRS_ALIGNER_LED ?= none
GPS_LED ?= none
LOGGER_LED ?= none
#
# default uart configuration
#
MODEM_PORT ?= UART2
MODEM_BAUD ?= B57600
GPS_PORT ?= UART1
GPS_BAUD ?= B57600
INTERMCU_PORT ?= UART3
INTERMCU_BAUD ?= B230400
#
# default IMU configuration
#
IMU_MPU_SPI_DEV ?= spi2
IMU_MPU_SPI_SLAVE_IDX ?= SPI_SLAVE1
#
# BARO configuration
#
# See baro_board.makefile
#
# default SPI logger configuration
#
SDLOGGER_DIRECT_SPI ?= spi1
SDLOGGER_DIRECT_SPI_SLAVE ?= SPI_SLAVE0
HS_LOG_SPI_DEV ?= spi1
HS_LOG_SPI_SLAVE_IDX ?= SPI_SLAVE0
#
# default Current Sensor configuration
#
ADC_CURRENT_SENSOR ?= ADC_2
+48
View File
@@ -0,0 +1,48 @@
# Hey Emacs, this is a -*- makefile -*-
#
# Oversized Paparazzi (AP) Board
#
# http://wiki.paparazziuav.org/wiki/OPA
#
BOARD=opa_ftd
BOARD_VERSION=1.0
BOARD_CFG=\"boards/$(BOARD)_$(BOARD_VERSION).h\"
ARCH=stm32
ARCH_L=f4
HARD_FLOAT=yes
$(TARGET).ARCHDIR = $(ARCH)
$(TARGET).LDSCRIPT=$(SRC_ARCH)/lisa-mx.ld
# -----------------------------------------------------------------------
#
# default flash mode is via SWD (JTAG)
#
FLASH_MODE ?= SWD
#
# default LED configuration
#
SYS_TIME_LED ?= 1
RADIO_CONTROL_LED ?= 2
ARMING_LED ?= 3
FBW_MODE_LED ?= none
#
# default uart configuration
#
RADIO_CONTROL_SPEKTRUM_PRIMARY_PORT ?= UART1
RADIO_CONTROL_SPEKTRUM_SECONDARY_PORT ?= UART5
MODEM_PORT ?= UART3
MODEM_BAUD ?= B57600
INTERMCU_PORT ?= UART2
INTERMCU_BAUD ?= B230400
#
# default actuator configuration
#
ACTUATORS ?= actuators_pwm
@@ -194,15 +194,25 @@ else ifeq ($(BOARD), umarim)
# Naze32
else ifeq ($(BOARD), naze32)
BARO_BOARD_CFLAGS += -DBARO_BOARD=BARO_MS5611_I2C
BARO_BOARD_CFLAGS += -DUSE_I2C2
BARO_BOARD_CFLAGS += -DBB_MS5611_I2C_DEV=i2c2
BARO_BOARD_SRCS += peripherals/ms5611.c
BARO_BOARD_SRCS += peripherals/ms5611_i2c.c
BARO_BOARD_SRCS += boards/baro_board_ms5611_i2c.c
BARO_BOARD_CFLAGS += -DBARO_BOARD=BARO_MS5611_I2C
BARO_BOARD_CFLAGS += -DUSE_I2C2
BARO_BOARD_CFLAGS += -DBB_MS5611_I2C_DEV=i2c2
BARO_BOARD_SRCS += peripherals/ms5611.c
BARO_BOARD_SRCS += peripherals/ms5611_i2c.c
BARO_BOARD_SRCS += boards/baro_board_ms5611_i2c.c
# OPA (AP)
else ifeq ($(BOARD), opa_ap)
include $(CFG_SHARED)/spi_master.makefile
BARO_BOARD_CFLAGS += -DUSE_SPI2 -DUSE_SPI_SLAVE2
BARO_BOARD_CFLAGS += -DBB_MS5611_SPI_DEV=spi2
BARO_BOARD_CFLAGS += -DBB_MS5611_SLAVE_IDX=SPI_SLAVE2
BARO_BOARD_SRCS += peripherals/ms5611.c
BARO_BOARD_SRCS += peripherals/ms5611_spi.c
BARO_BOARD_SRCS += boards/baro_board_ms5611_spi.c
endif # check board
BARO_LED ?= none
ifneq ($(BARO_LED),none)
BARO_BOARD_CFLAGS += -DBARO_LED=$(BARO_LED)
endif
+1 -1
View File
@@ -9,7 +9,7 @@
<file name="swashplate_mixing.h"/>
</header>
<init fun="swashplate_mixing_init()"/>
<makefile>
<makefile target="ap|fbw">
<file name="swashplate_mixing.c"/>
<define name="ROTORCRAFT_IS_HELI" value="TRUE"/>
</makefile>
+1 -1
View File
@@ -8,7 +8,7 @@
<file name="throttle_curve.h"/>
</header>
<init fun="throttle_curve_init()"/>
<makefile>
<makefile target="ap|fbw">
<file name="throttle_curve.c"/>
</makefile>
</module>