mirror of
https://github.com/paparazzi/paparazzi.git
synced 2026-06-04 22:17:01 +08:00
[boards] Add the new OPA board
This commit is contained in:
@@ -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"
|
||||
|
||||
@@ -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>
|
||||
@@ -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
|
||||
@@ -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
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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>
|
||||
|
||||
Reference in New Issue
Block a user