Compare commits

...

546 Commits

Author SHA1 Message Date
Andrew Tridgell
e2041b0ae7 AP_Scripting: fixed float register save/restore in setjmp/longjmp
the register save must happen before the setjmp() call, which means
outside of the LUAI_TRY() macro. We also should be saving all 32
floating point registers
2024-05-31 09:44:38 +10:00
Andrew Tridgell
228725a976 CI: force empty version 3.3.4 2024-05-31 09:44:36 +10:00
Andrew Tridgell
8cdf50a1a0 Tools: force pymonocypher version 2024-05-31 09:44:33 +10:00
Peter Barker
763712a04a AP_GPS: correct uBlox M10 configuration on minimised boards 2023-11-14 10:35:03 +11:00
Randy Mackay
60ebf6fbb9 Copter: version to 4.3.8 2023-08-24 20:19:32 +09:00
Randy Mackay
8efd0bc045 Copter: 4.3.8 release notes 2023-08-24 20:19:32 +09:00
Randy Mackay
cb935d037c Copter: version to 4.3.8-beta1 2023-08-16 08:24:06 +09:00
Randy Mackay
b63b671615 Copter: 4.3.8-beta1 release notes 2023-08-16 08:24:06 +09:00
Randy Mackay
12f9fe73ae Rover: version to 4.3.0-beta14 2023-08-16 08:24:06 +09:00
Randy Mackay
a21cd2c9a4 Rover: 4.3.0-beta14 release notes 2023-08-16 08:24:06 +09:00
Randy Mackay
a06660ee00 autotest: relax Copter vibration failsafe timeout 2023-08-16 08:24:06 +09:00
Andrew Tridgell
fd405b65f9 Plane: prepare for 4.3.8-beta1 2023-08-16 08:24:06 +09:00
Andrew Tridgell
69c66ce6b8 Plane: release notes for 4.3.8-beta1 2023-08-16 08:24:06 +09:00
Andrew Tridgell
7055abc269 AP_BattMonitor: fixed reset_remaining() for INAxxx and LTC2946
these can use the generic reset_remaining() call in the backend
2023-08-16 08:24:06 +09:00
Andrew Tridgell
544e38cf82 AP_GPS: fixed RTK injection when first module is a BASE
this is a partial backport of #24132 which fixes RTK injection when
the 1st GPS module is a DroneCAN RTK rover. Without this change RTCM
injection for RTK fix on the base will only work if it happens to come
up as the first module
2023-08-16 08:24:06 +09:00
Andrew Tridgell
16d617c62d AP_Arming: fixed auto-enable of fence with forced arm
when a user forced armed and had FENCE_AUTOENABLE=3 for enable on
arming then the fence did not enable
2023-08-16 08:24:06 +09:00
bugobliterator
e6280e6d37 AP_Scripting: stash and restore FPU register context in LUAI_TRY
this fixes an issue where a lua library function triggers an exception
after it does a math operation which changes the floating point
registers on M7 MCUs (such as STM32H7). An example is math.random()
which calls math_random(), which pre-calculates a double value before
checking if the arguments to the call are valid. When it then checks
and finds invalid values the exception longjmp does not restore the
floating point registers.
2023-08-16 08:24:06 +09:00
Andrew Tridgell
b1505a5f7a AP_NavEKF3: fixed race condition in updateFilterStatus()
filter status was initially set to zero then updated. This interacts
with the IMU filtering code which checks filter status from a
different thread to determine active_EKF_type(). When the race
condition is hit then the IMU we are running notch filters on changes
for a single sample, causing a notch filter glitch
2023-08-16 08:24:06 +09:00
Nicholas Ionata
3b36cd351c Plane: reset target altitude time on mode enter 2023-08-16 08:24:06 +09:00
Andrew Tridgell
7ddb027fb7 Plane: final release notes for 4.3.7 2023-08-16 08:24:06 +09:00
Randy Mackay
c8506ed478 Copter: version to 4.3.7 2023-05-31 09:51:29 +09:00
Randy Mackay
a74464ac13 Copter: 4.3.7 release notes 2023-05-31 09:51:29 +09:00
Andrew Tridgell
65adf4e532 Plane: prepare for 4.3.7 final 2023-05-31 09:51:29 +09:00
Andrew Tridgell
ffdbf532c4 AP_BoardConfig: fixed documentation of safety options
on and off were reversed
2023-05-31 09:51:29 +09:00
Andrew Tridgell
12d132e88f Plane: prepare for 4.3.7beta1 release 2023-05-31 09:51:29 +09:00
Randy Mackay
7de44995e9 Copter: version to 4.3.7-beta1 2023-05-25 11:33:10 +10:00
Randy Mackay
8e17237d38 Copter: 4.3.7-beta1 release notes 2023-05-25 11:33:10 +10:00
Randy Mackay
eaf2f4b1fe Rover: version to 4.3.0-beta13 2023-05-25 11:33:10 +10:00
Randy Mackay
1982ae90c1 Rover: 4.3.0-beta13 release notes 2023-05-25 11:33:10 +10:00
Andrew Tridgell
ab43186189 AP_ICEngine: fixed a bug engine control when running
if you have a mission item for engine control with delayed start at
height and the engine is already running them it would put the ICE
subsystem into a state where it would no longer start the engine

It was actually 2 bugs:

 - an engine control to do a height delayed start should be ignored if
   the engine is already running. This prevents an engine control to
   start the engine from stopping the engine

 - a start_chan high should always try to start the engine
   immediately, even if in the wait state
2023-05-25 11:33:10 +10:00
Andrew Tridgell
d7cf6528ac Tools: rebuild IO firmware 2023-05-25 11:33:10 +10:00
Andrew Tridgell
c868ac5fe4 AP_RCProtocol: return true on initial protocol detection
we need to tell the IO firmware that a byte was consumed when we first
detect a protocol as otherwise the next bad byte on DSM will lock us
on the DSM port
2023-05-25 11:33:10 +10:00
Andrew Tridgell
71cbcb49f5 AP_IOMCU: fixed issue with not regaining RC input
this fixes an issue where when you lose R/C input on IOMCU that you
may not regain it when R/C comes back.

The issue stems from us still processing the DSM uart when we are
using the SD3 "SBUS" uart for RC input, and still doing the switch of
the SD3 config every 2 seconds.

When we are not searching for a new protocol we should not be changing
UART config
2023-05-25 11:33:10 +10:00
bugobliterator
99ff763995 AP_InertialSensor: fix hardfault in BatchSampler 2023-05-25 11:33:10 +10:00
Andrew Tridgell
959b520b27 Plane: release notes for 4.3.6-beta1 2023-05-25 11:33:10 +10:00
Andrew Tridgell
de0b564458 Plane: backport fix for AirMode on quadplanes 2023-05-25 11:33:10 +10:00
Andrew Tridgell
534536664a Tools: disable python cleanliness tests for 4.3 2023-05-25 11:33:10 +10:00
Andrew Tridgell
553207dc58 ChibiOS: backport RCC reset fix for 4.3 2023-05-25 11:33:10 +10:00
Paul Riseborough
255df7c8b5 AP_NavEKF3: Increase delta velocity bias state process noise
Required due to state variance collapse on ground with some systems using RTK GPS.
2023-05-25 11:33:10 +10:00
Paul Riseborough
b6b5a0121a AP_NavEKF3: Strengthen recovery from bad delta velocity bias learning 2023-05-25 11:33:10 +10:00
Paul Riseborough
119a8bb357 AP_NavEKF3: Increase default value of EK3_ABIAS_P_NSE
This is required because some hardware setups with RTK GPS have experienced a collapse of the delta velocity state variances.
2023-05-25 11:33:10 +10:00
Paul Riseborough
96546804b4 AP_NavEKF3: Retune and fix delta velocity bias state variance protection 2023-05-25 11:33:10 +10:00
Andy Piper
fc7f182214 AP_NavEKF: ensure gyro biases are numbers
avoid errors during compass mot
2023-05-25 11:33:10 +10:00
Peter Barker
708124183d AP_EFI: use uint16_t to store offset
prevents infinite loop if there are exactly 255 bytes ready to read
2023-05-25 11:33:10 +10:00
Andrew Tridgell
5b9ac1fdc1 waf: added -g option to configure
this adds debug symbolds to the build without enabling other debug
code. This is needed for analysing watchdog crash dumps
2023-05-25 11:33:10 +10:00
Randy Mackay
0c5e999c44 Copter: version to 4.3.6 2023-04-06 09:16:25 +10:00
Randy Mackay
9b917fc9d1 Copter: 4.3.6 release notes 2023-04-06 09:16:25 +10:00
Randy Mackay
6ca9b4d7b7 Copter: version to 4.3.6-beta2 2023-03-27 11:11:53 +09:00
Randy Mackay
a25289b321 Copter: 4.3.6-beta2 release notes 2023-03-27 11:11:53 +09:00
Randy Mackay
1de151f5cd Rover: version to 4.3.0-beta12 2023-03-27 11:11:53 +09:00
Randy Mackay
bcfb7786aa Rover: 4.3.0-beta12 release notes 2023-03-27 11:11:53 +09:00
Andrew Tridgell
7ba2694c5f Plane: prepare for 4.3.5 stable 2023-03-27 11:11:53 +09:00
Andrew Tridgell
c480aca3a0 Plane: release notes for 4.3.5 2023-03-27 11:11:53 +09:00
Andy Piper
a86e18a09d AP_HAL_ChibiOS: ensure the rcout TIM_UP DMA request source is re-instated after cancellation
This fixes a bug in bdshot whereby dma cancellation could result in the wrong DMA channel
being used for dshot output and hence motors stopping
2023-03-27 11:11:53 +09:00
Andy Piper
b936b474ed AP_HAL_ChibiOS: ensure that DMA source is correct on DMA send for rcout 2023-03-27 11:11:53 +09:00
Randy Mackay
53c106a7d4 Copter: version to 4.3.6-beta1 2023-03-26 11:53:36 +09:00
Randy Mackay
353124a238 Copter: 4.3.6-beta release notes 2023-03-26 11:53:36 +09:00
Randy Mackay
52d359d09e Rover: version to 4.3.0-beta11 2023-03-26 11:53:36 +09:00
Randy Mackay
374660e1e6 Rover: 4.3.6-beta11 release notes 2023-03-26 11:53:36 +09:00
Andrew Tridgell
b35d3edb3d Plane: prepare for 4.3.5beta1 2023-03-26 11:53:36 +09:00
Andrew Tridgell
a318ce8b64 Plane: release notes for 4.3.5beta1 2023-03-26 11:53:36 +09:00
Andrew Tridgell
411a15699a HAL_ChibiOS: switched to 64 bit maths for DShot timings
this fixes a timer wrap bug at 71 minutes after boot that impacts
bdshot
2023-03-26 11:53:36 +09:00
bugobliterator
c33653cd4e bootloaders: add CubeOrangePlus-bdshot bootloader 2023-03-22 18:29:17 +11:00
bugobliterator
3d1e280e84 AP_HAL_ChibiOS: add CubeOrangePlus-bdshot hwdef 2023-03-22 18:29:17 +11:00
Leonard Hall
64b84a942c AutoTest: Remove extra line 2023-03-14 08:38:00 +09:00
Pierre Kancir
287cf0c920 Tools: fix flake8 checks 2023-03-14 08:38:00 +09:00
Randy Mackay
02ff7ea394 Copter: version to 4.3.5 2023-03-14 08:04:07 +09:00
Randy Mackay
1749e80969 Copter: 4.3.5 release notes 2023-03-14 08:03:56 +09:00
Randy Mackay
616c00e64d Copter: version to 4.3.5-rc1 2023-03-02 14:56:47 +09:00
Randy Mackay
1feb8e7f41 Copter: 4.3.5-rc1 release notes 2023-03-02 14:56:47 +09:00
Randy Mackay
84d47bbad6 Rover: version to 4.3.0-beta10 2023-03-02 14:56:47 +09:00
Randy Mackay
5e43cb32c3 Rover: 4.3.0-beta10 release notes 2023-03-02 14:56:47 +09:00
Peter Barker
9fcb678b93 AP_Mount: rename local _chan to chan in Gremsy methods
based on PR feedback
2023-03-02 14:56:47 +09:00
Peter Barker
3c8e89f540 GCS_MAVLink: add method to get link (not just channel number) for mavtype and compid 2023-03-02 14:56:47 +09:00
Peter Barker
a613ae8d1d AP_Mount: correct double-mapping of port to channel number
set_message_interval takes a port number, not a channel number (it was originally written as an internal function, after all).  Before this patch we were double-mapping from one to the other.  That works so long as the port you are mapping also corresponds to the chanel number - which it will, for example, if you are using serial2 with both serial0 and serial1 also set to mavlink.  If you set serial5_protocol to 2 an attempt to use it for controlling a gremsy it will *not* work because we map into backwards twice.
2023-03-02 14:56:47 +09:00
Reilly Callaway
865da3a0f0 AP_PiccoloCAN: Fix ESC voltage and current telem scaling 2023-03-02 14:56:47 +09:00
bugobliterator
0458d424af AP_HAL_ChibiOS: add HAL_WITH_MCU_MONITORING define for H757 2023-03-02 14:56:47 +09:00
Randy Mackay
71361ac598 AP_Mount: servo mount yaw handling fix 2023-03-02 14:56:47 +09:00
Andrew Tridgell
088bc33900 Plane: prepare for 4.3.4 release 2023-03-02 14:56:47 +09:00
Andrew Tridgell
5cdd254828 Plane: release notes for 4.3.4 2023-03-02 14:56:47 +09:00
Andrew Tridgell
0989273250 AP_AHRS: fixed earth frame accel for EKF3 with significant trim 2023-03-02 14:56:47 +09:00
Andrew Tridgell
8187b993ce Plane: re-init throttle wait on quadplane arm and disarm
this prevents yaw from rudder arming on 2nd flight
2023-03-02 14:56:47 +09:00
Andy Piper
15b9bf6820 AP_HAL_ChibiOS: enable VTX power on MambaF405 2022 2023-03-02 14:56:47 +09:00
Andy Piper
f3ab56bc57 bootloaders: update MambaF405-2022 to include VTX pwoer 2023-03-02 14:56:47 +09:00
Iampete1
969ee8be2c AP_TECS: protect against low airspeed in reset 2023-03-02 14:56:47 +09:00
Andrew Tridgell
ac395450cd Plane: prepare for 4.3.4beta2 2023-03-02 14:56:47 +09:00
Andrew Tridgell
96a0e2747e Plane: release notes for 4.3.4beta2 2023-03-02 14:56:47 +09:00
Andrew Tridgell
6978df3348 AP_GPS: don't try and configure M10 options on non-M10 GPS
this fixes a pre-arm failure "GPS 1 failing configuration checks" on
non-M10 GPS modules, including AP_Periph

it also adds the ublox unconfigured msgs to the DroneCAN GNSS.Status
errors field for easier diagnosis of this type of issue in the future
2023-03-02 14:56:47 +09:00
Andrew Tridgell
aa6c2fe864 Plane: ensure home is up to date on arming
remove any discrepancy which has crept in over the last few seconds

this also ensures that relative_altitude is updated, and copes with
the EKF refusing the resetHeightDatum call
2023-03-02 14:56:47 +09:00
Andrew Tridgell
dcfb648c57 autotest: added AltResetBadGPS test
this tests the bug in handling a glitching GPS with low accuracy with
AHRS alt reset
2023-03-02 14:56:47 +09:00
Randy Mackay
43447be866 Copter: version to 4.3.4 2023-03-01 11:57:54 +09:00
Randy Mackay
4b14517134 Copter: 4.3.4 release notes 2023-03-01 11:57:54 +09:00
Andrew Tridgell
92f9b7e11f AP_Scripting: disable PWMSource in scripts for 4.3.4
this avoids the interrupt handling bug. Proper fix in 4.4.x
2023-03-01 11:57:54 +09:00
Randy Mackay
fe838aab8d Copter: update 4.3.4-rc1 release notes again 2023-02-14 16:35:00 +09:00
Randy Mackay
ce40bf7bee Rover: update 4.3.0-beta9 release notes again 2023-02-14 16:34:32 +09:00
Andy Piper
2ce8005f22 AP_HAL_ChibiOS: probe external compasses on foxeer reaper f745 2023-02-14 16:30:46 +09:00
Andy Piper
1ffd0f2451 bootloaders: update bootloader for MambaH743v4 to include VTX power 2023-02-14 16:29:55 +09:00
Andy Piper
79e1f4eca1 AP_HAL_ChibiOS: enable VTX power on MambaH743v4 2023-02-14 16:29:45 +09:00
Randy Mackay
f7c255831a Copter: update 4.3.4-rc1 release notes 2023-02-14 16:25:12 +09:00
Randy Mackay
ae3b5105e9 Rover: update 4.3.0-beta9 release notes 2023-02-14 16:25:07 +09:00
bugobliterator
57e702ae31 AP_HAL_ChibiOS: add support for CubeOrangePlus BG edition 2023-02-14 16:22:17 +09:00
Andrew Tridgell
daec6e6ee3 AP_IOMCU: fixed an issue with double reset of IOMCU
if the IOMCU resets twice in quick succession then the code that
restores the safety state while flying can fail, leading to the
aircraft trying to continue flying with safety on

This results from two issues:

- a race in handling the last_safety_off variable
- the fact that plane sets the soft_armed state based on safety state
2023-02-14 16:22:17 +09:00
Andrew Tridgell
371e88ae55 Plane: update release notes for 4.3.4-beta1 2023-02-14 16:22:12 +09:00
Randy Mackay
760bd86c58 Copter: version to 4.3.4-rc1 2023-02-11 09:42:55 +09:00
Randy Mackay
d0d753d116 Copter: 4.3.4-rc1 release notes 2023-02-11 09:42:55 +09:00
Randy Mackay
5557114398 Rover: version to 4.3.0-beta9 2023-02-11 09:42:55 +09:00
Randy Mackay
1023024204 Rover: 4.3.0-beta9 release notes 2023-02-11 09:42:55 +09:00
Andrew Tridgell
5675157a21 Plane: prepare for 4.3.4beta1 2023-02-11 09:42:55 +09:00
Andrew Tridgell
718dd2742b Plane: release notes for 4.3.4-beta1 2023-02-11 09:42:55 +09:00
Andrew Tridgell
f7b9d2ef5b CI: added git safe directory 2023-02-11 09:42:55 +09:00
Bob Long
3fbeda3e1d AP_Baro: fix bug in alt error arming check
get_altitude_difference already subtracts MSL altitude
2023-02-11 09:42:55 +09:00
Andrew Tridgell
a4835634e0 RC_Channel: disable FFT notch tune feature
See https://github.com/ArduPilot/ardupilot/pull/22686
2023-02-11 09:42:55 +09:00
Andy Piper
7408b46fdb AP_HAL: ensure the DSP tracked peaks do not overflow the buffer 2023-02-11 09:42:55 +09:00
rishabsingh3003
3859d153fa Copter: Add option to resume precland after reposiiton 2023-02-11 09:42:55 +09:00
rishabsingh3003
4fd2288082 AC_Precland: Add option to resume precland after manual override 2023-02-11 09:42:55 +09:00
Andrew Tridgell
886210f8f1 AP_CANManager: add an output buffer for MAVCAN
this fixes firmware update of peripheral nodes using MAVCAN
2023-02-11 09:42:55 +09:00
Peter Barker
fd84805f68 AP_Logger: avoid logging duplicate FMT/UNIT/FMTU/MULT messages
Failing due to being out of time meant we wouldn't incremement the counter, even though we'd emitted the item.

it is important we try to send something, so move this check to be after we increment whichever counter we are using.
2023-02-11 09:42:55 +09:00
Andrew Tridgell
12721f37b7 AP_OpenDroneID: set EMERGENCY status on crash or chute deploy
RemoteID modules are required to set EMERGENCY status on uncontrolled
descent or crash. This fixes our implementation to do that, either via
existing vehicle crash checking code or via a parachute release
2023-02-11 09:42:55 +09:00
Andrew Tridgell
c483b26737 AP_Compass: fixed zero compass diagonals
this fixes a regression from 4.2 to 4.3.

previously we automatically set the diagnoals to 1,1,1 if they were
0,0,0. We don't do that any more. I was helping a user who had copied
an old config with 0,0,0 for diagonals and did not understand two
things:

- the compass did not work in 4.3
- large vehicle mag cal didn't work
2023-02-11 09:42:55 +09:00
rishabsingh3003
3cf65ce4ec Copter: update terrain db pre-arm checks 2023-02-11 09:42:55 +09:00
Leonard Hall
5d93c90782 Copter: Use filtered and corrected range finder in surface tracking 2023-02-11 09:42:55 +09:00
Randy Mackay
81813f8015 GCS_MAVlink: send_autopilot_state_for_gimbal_device sends ef z-axis rate target 2023-02-11 09:42:55 +09:00
Randy Mackay
82cbc21404 Copter: replace get_rate_bf_targets with get_rate_ef_targets 2023-02-11 09:42:55 +09:00
Randy Mackay
e678a9666d AP_Vehicle: replace get_rate_bf_targets with get_rate_ef_targets 2023-02-11 09:42:55 +09:00
Randy Mackay
f8414200c7 AC_AttitudeControl: add get_rate_ef_targets accessor 2023-02-11 09:42:55 +09:00
Andrew Tridgell
a5b0cb399f Plane: transition pitch limit should not apply to FBWA
pilot should be able to override pitch, very important on motor
failure to control glide
2023-02-11 09:42:55 +09:00
Andrew Tridgell
454a002a3e Tools: update IO firmware 2023-02-11 09:42:55 +09:00
Andrew Tridgell
518388c9c3 AP_RCProtocol: on IOMCU don't allow protocol to change once detected
this prevents a crash where in-flight noise causes an incorrect
protocol detection, such as DSM for a SBUS input
2023-02-11 09:42:55 +09:00
Andrew Tridgell
8c9227440f Plane: prepare for 4.3.3 release 2023-02-11 09:42:55 +09:00
Andrew Tridgell
e992c73a52 Plane: release notes for 4.3.3 2023-02-11 09:42:55 +09:00
Randy Mackay
34e8e02c48 Copter: version to 4.3.3 2023-01-20 10:08:23 +09:00
Randy Mackay
7f1ca5c61a Copter: 4.3.3 release notes 2023-01-20 10:08:03 +09:00
Randy Mackay
91506aad04 Rover: version to 4.3.0-beta8 2023-01-20 10:07:28 +09:00
Randy Mackay
3c7e85b254 Rover: 4.3.0-beta8 release notes 2023-01-20 10:07:11 +09:00
Andrew Tridgell
af3f492473 AP_Scripting: fixed alt frame error in ship landing
if terrain follow is enabled then this would result in mixing a
terrain alt with an absolute alt, resulting in attempts to descend to
a negative alt
2023-01-20 09:58:14 +09:00
Andrew Tridgell
6c93d1cbdb AP_InertialSensor: cleanup NAMED_VALUE_FLOAT for fifo error 2023-01-20 09:58:14 +09:00
Andrew Tridgell
b5549078a2 AP_InertialSensor: fixed flood of log with fast fifo reset 2023-01-20 09:58:14 +09:00
Andrew Tridgell
e1883bcaa4 GCS_MAVLink: fixed FTP terminate session error
this caused ftp downloads to intermittently fail. The cause is the FTP
client may ask for a session terminate and then immediately afterwards
a ftp open. The open would fail as the ftp session was considered
active
2023-01-20 09:58:14 +09:00
Andrew Tridgell
1c87a48774 Plane: fixed loiter.direction for VTOL approach
ensure the direction is setup correctly for both CW and CCW
2023-01-20 09:58:14 +09:00
Andrew Tridgell
4e54f84c10 Plane: fixed version number for 4.3.3beta1 2023-01-20 09:58:14 +09:00
Randy Mackay
22d89f5978 Copter: version to 4.3.3-rc1 2023-01-10 08:12:47 +09:00
Randy Mackay
da8197ea18 Copter: update 4.3.3-rc1 release notes 2023-01-10 08:12:47 +09:00
Randy Mackay
b4b49649db Copter: 4.3.3-rc1 release notes 2023-01-10 08:12:47 +09:00
Randy Mackay
9c1b4e9c2a Rover: version to 4.3.0-beta7 2023-01-10 08:12:47 +09:00
Randy Mackay
f52f90a68d Rover: update 4.3.0-beta7 release notes 2023-01-10 08:12:47 +09:00
Randy Mackay
14565e98d2 Rover: 4.3.0-beta7 release notes 2023-01-10 08:12:47 +09:00
Andrew Tridgell
7f21802dbf Plane: prepare for 4.3.3beta1 2023-01-10 08:12:47 +09:00
Andrew Tridgell
ae5d7cf563 Plane: update release notes for 4.3.3beta1 2023-01-10 08:12:47 +09:00
Andrew Tridgell
9d7bbdece5 hwdef: save flash to get 4.3.3 building on some low flash boards 2023-01-10 08:12:47 +09:00
Andrew Tridgell
cbfba1b719 waf: add -fcheck-new to g++ build
this ensures the compiler doesn't assume that new always returns a
non-NULL value. Without this the compiler may remove the error path in
code like this:

```
MyObject *x = new MyObject;
if (x == nullptr) {
  ::printf("Alloc failed\n");
}
```

the reason it can do this is the new operator is marked as throwing an
exception on failure, which means the error path is unreachable. As we
don't have C++ exceptions in ArduPilot could (and do!) have code that
ends up losing protection against allocation failures
2023-01-10 08:12:47 +09:00
Andy Piper
67c9a04223 AP_HAL_ChibiOS: support for MambaF405-2022B
Co-authored-by: vidmantas zemleris <vidmantas.zemleris@gmail.com>
2023-01-10 08:12:47 +09:00
Andy Piper
6412c2cb8e AP_HAL_ChibiOS: MambaH743 v2 with dual ICM42688 2023-01-10 08:12:47 +09:00
Andy Piper
2e29f2664b AP_HAL_ChibiOS: add UART baudrate accessor 2023-01-10 08:12:47 +09:00
Andy Piper
0f90672bcd AP_HAL: add UART baudrate accessor 2023-01-10 08:12:47 +09:00
Andy Piper
5477acf3b4 RC_Channel: add option to support ELRS at 420kbaud 2023-01-10 08:12:47 +09:00
Andy Piper
7206e49c0c Copter: read radio more frequently to support more modern RX/TX 2023-01-10 08:12:47 +09:00
Andy Piper
ba6842d19e AP_RCTelemetry: report CRSF link rate rather than mode.
Encode actual protocol being used
cleanup is_elrs() and version numbers
2023-01-10 08:12:47 +09:00
Andy Piper
b7e9330953 AP_RCProtocol: check for 3 good frames for CRSF
Move get_link_rate() and get_protocol_string() to CRSF protocol
allow ELRS at 420kbaud to be configured
allow CRSF to bootstrap at ELRS desired baudrate
2023-01-10 08:12:47 +09:00
bugobliterator
0b63b679c4 Tools: fix CI error while building for macos 2023-01-10 08:12:47 +09:00
Andrew Tridgell
bd9f3ef696 AC_AttitudeControl: fixed time wrap bug in is_active_xy()
this failed at 70 minutes
2023-01-10 08:12:47 +09:00
Kirill Shilov
fe3ae67b73 AIRLink hwdef: added heater parameters 2023-01-10 08:12:47 +09:00
Andrew Tridgell
22a2d2b4ce GCS_MAVLink: optimise FTP for available bandwidth
when we don't have hardware flow control don't use more than 1/3 of
available bandwidth for ftp outgoing transfers. This makes parameter
download faster on radios without flow control
2023-01-10 08:12:47 +09:00
Andrew Tridgell
0998bdc057 AP_HAL: check for null buffer in ObjectBuffer get_size() 2023-01-10 08:12:47 +09:00
Andrew Tridgell
da4a9297a0 GCS_MAVLink: check for alloc failure of ObjectBuffer 2023-01-10 08:12:47 +09:00
Andrew Tridgell
6e6df75b2a AP_Scripting: check for alloc failure of ObjectBuffer 2023-01-10 08:12:47 +09:00
Andrew Tridgell
54c3e7f74b AP_HAL_Linux: check for alloc failure of ObjectBuffer 2023-01-10 08:12:47 +09:00
Andrew Tridgell
c602757c02 AC_Avoidance: check for alloc failure of ObjectBuffer 2023-01-10 08:12:47 +09:00
Andrew Tridgell
869a1442ec GCS_MAVLink: send FTP replies directly from the FTP thread
this saves over 700 bytes of memory while also making ftp faster
2023-01-10 08:12:47 +09:00
bugobliterator
5d559093b8 AP_HAL_ChibiOS: swap order of ICM20602 and ICM20948_ext on CubeYellow 2023-01-10 08:12:47 +09:00
bugobliterator
2c8cd15b1a AP_HAL_ChibiOS: enable fast fifo reset for CubeYellow as well 2023-01-10 08:12:47 +09:00
bugobliterator
47759c534c AP_HAL_ChibiOS: enable fast reset on ICM20602 for CubeOrange HW 2023-01-10 08:12:47 +09:00
bugobliterator
fd1a7fec05 AP_InertialSensor: add option to enable fast fifo reset on ICM20602 2023-01-10 08:12:47 +09:00
bugobliterator
c8f5e3b6b5 AP_InertialSensor: add fast reset for ICM20602 instead of full reset on bad temp sample 2023-01-10 08:12:47 +09:00
Leonard Hall
7dd5244bad Copter: Fix takeoff with alt drift and wp_navalt_min set 2023-01-10 08:12:47 +09:00
Leonard Hall
9ff591eb15 Copter: Fix Auto Takeoff when complete_alt_cm is current altitude 2023-01-10 08:12:47 +09:00
Leonard Hall
9786a99117 AC_WPNav: remove _wp_accel_cmss.set_and_save_ifchanged 2023-01-10 08:12:47 +09:00
Leonard Hall
b6e781629b AP_Math: extend the control.cpp test suite 2023-01-10 08:12:47 +09:00
Andrew Tridgell
3ca4a56eba AP_Math: added a control.cpp test suite 2023-01-10 08:12:47 +09:00
Iampete1
e9a0844dc9 Plane: Quadaplane: use land_at_climb_rate_cm only when landing 2023-01-10 08:12:47 +09:00
Leonard Hall
b6a59c0c13 Copter: Update use of input_vel_accel_z 2023-01-10 08:12:47 +09:00
Leonard Hall
97a531a913 Plane: Vtol: use land_at_climb_rate_cm for vertical rate control 2023-01-10 08:12:47 +09:00
Leonard Hall
eec407e309 AC_AttitudeControl: AC_PosControl: Simplify and clarify use of vertical controllers 2023-01-10 08:12:47 +09:00
Leonard Hall
4aabd770d6 AP_Math: Target velocity can reduce when limited
AP_Math: Target velocity can reduce when limited
2023-01-10 08:12:47 +09:00
Leonard Hall
124a3703d2 AC_AttitudeControl: AC_PosControl: Comment fix and small efficiency gain 2023-01-10 08:12:47 +09:00
Leonard Hall
cacc69c44d AP_Math: Control Tools Enhancments
AP_Math: Control Tools Enhancments
2023-01-10 08:12:47 +09:00
Leonard Hall
ce8389bab8 AC_AttitudeControl: AC_PosControl: Include FF in _pid_vel_xy integrator initialisation 2023-01-10 08:12:47 +09:00
Randy Mackay
108b69e615 AP_Mount: servo driver loses unnecessary closest_limits method 2023-01-10 08:12:47 +09:00
Peter Barker
54c0044f8c github: macosx: remove github-installed Python symlinks in /usr/local/bin
installing packages fails as symlinks that brew wants to install already exist

https://github.com/orgs/Homebrew/discussions/3895
2023-01-10 08:12:47 +09:00
Randy Mackay
8d613e8f9e AP_Mount: siyi recording send-text demoted to INFO 2023-01-10 08:12:47 +09:00
Randy Mackay
1bde74f68f AP_Mount: Siyi fix for record ON OFF reporting 2023-01-10 08:12:47 +09:00
Randy Mackay
aa9c8b1d81 AP_Mount: siyi a8 fix for gimbal-config-info message
Siyi A8 uses a different format from Z10 for this message
2023-01-10 08:12:47 +09:00
Kirill Shilov
9f73c1498f AIRLink: added LTE module enable pin to hwdef 2023-01-10 08:12:47 +09:00
Randy Mackay
cbe0569179 Copter: skip ap arming check of GPS hdop if GPS is disabled 2023-01-10 08:12:47 +09:00
Randy Mackay
3ae61ce5d3 AP_Arming: correct prefix is ahrs is waiting for home 2023-01-10 08:12:47 +09:00
Randy Mackay
f670af63a6 AP_Arming: only compare AHRS vs GPS if GPS is enabled 2023-01-10 08:12:47 +09:00
Randy Mackay
74a903109d AP_Arming: minor format fix 2023-01-10 08:12:47 +09:00
Moe Bataineh
b91f5e377b AP_Mount: Align received data to AP frame for Storm32 Serial
(Note: reversed pitch and yaw) to match NED.

Update AP_Mount_SToRM32_serial.cpp
2023-01-10 08:12:47 +09:00
Iampete1
96edba0f50 Plane: QRTL if RTL is expecting to VTOL land and close home with VTOL motors active 2023-01-10 08:12:47 +09:00
Iampete1
aa8e4d115a AP_RangeFinder: skip GPIO arming check on analog backend 2023-01-10 08:12:47 +09:00
Leonard Hall
f3b6c51f6b Copter: Support changing update period in Motors 2023-01-10 08:12:47 +09:00
Leonard Hall
61de8a0b28 Plane: Support changing update period in Motors 2023-01-10 08:12:47 +09:00
Leonard Hall
5b3452e80d Sub: Support changing update period in Motors 2023-01-10 08:12:47 +09:00
Leonard Hall
f2c7383690 AP_Motors: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
8eb8c4c65f Copter: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
a446001e44 Plane: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
749ac19295 AntennaTracker: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
f8d4f6afc9 Sub: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
2ceec6b17d Blimp: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
5cadbc03f2 AC_WPNav: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
451faaa059 AC_AttitudeControl: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
323718b86b AP_WheelEncoder: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
0c55933378 AP_Control: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
78e125c41b Filter: Support changing update period 2023-01-10 08:12:47 +09:00
Leonard Hall
67024a9516 AP_Math: Support changing update period 2023-01-10 08:12:47 +09:00
lthall
4104da3864 AC_PID: Support changing update period 2023-01-10 08:12:47 +09:00
Peter Hall
6bad9ac4d7 Plane: Quadplane: tiltrotor: add Q_OPTION to keep motors tilted up when disarmed in FW modes 2023-01-10 08:12:47 +09:00
Peter Barker
07f915ecf0 bootloaders: add bootloader for PixPilot-v6 2023-01-10 08:12:47 +09:00
xiao
ebe45361be Tools: reserve ID for PixPilot-V6 2023-01-10 08:12:47 +09:00
xiao
8a4a873564 AP_HAL_ChibiOS: added PixPilot-V6 2023-01-10 08:12:47 +09:00
Andrew Tridgell
6097fbc195 CI: only run test_size on a pull request 2023-01-10 08:12:47 +09:00
Andy Piper
52d3db487e AP_HAL_ChibiOS: increase SPI clock for ICM42688 on CUAV-Nora
use regular speed for ICM42688 CS on Nora
2023-01-10 08:12:47 +09:00
Andy Piper
68ec1c94f4 scripts: add CUAV-Nora-bdshot 2023-01-10 08:12:47 +09:00
Andy Piper
7a52a634a7 bootloaders: add CUAV Nora bdshot bootloaders 2023-01-10 08:12:47 +09:00
Andy Piper
3424051d5b AP_HAL_ChibiOS: hwdef for bdshot version of CUAV Nora/Nora+ 2023-01-10 08:12:47 +09:00
Randy Mackay
fcef79e79e Copter: version to 4.3.2 2022-12-23 09:46:18 +09:00
Randy Mackay
9736097057 Copter: 4.3.2 release notes 2022-12-23 09:46:16 +09:00
Andrew Tridgell
28693a4541 Plane: prepare for 4.3.2 release 2022-12-23 09:43:59 +09:00
Andrew Tridgell
1c3f6ff636 Plane: release notes for 4.3.2 2022-12-23 09:43:56 +09:00
Randy Mackay
2c66e30bb3 AP_Arming: revert add system check of main loop rate
This reverts commit 6713caba55.
2022-12-23 09:43:53 +09:00
Andrew Tridgell
c042374274 Plane: prepare for 4.3.2beta2 2022-12-23 09:43:49 +09:00
Andrew Tridgell
75967081f0 Plane: updated release notes for 4.3.2beta2 2022-12-23 09:43:46 +09:00
Andrew Tridgell
66df43176c AP_Landing: prevent a landing division by zero
if sink rate set to zero
2022-12-23 09:43:42 +09:00
Bredemeier, Fabian (TD-M)
fef5c75e23 Copter: Simulink Model and init scripts for Copter-4.3
- arducopter.slx: Simulates ArduCopter Stabilize and Althold controller and optional plant model
- sid_pre.m: Loads *.bin files to Matlab structs
- sid_sim_init.m: Loads signals and parameters from Matlab structure into Simulink model
- sid_controller_validation.m: Validation of the flight controller model with the flight data loaded to the Matlab workspace.
2022-12-15 08:38:03 +11:00
Randy Mackay
e19ce32867 Copter: version to 4.3.2-rc1 2022-12-10 10:34:44 +09:00
Randy Mackay
8ceb3d411a Copter: 4.3.2-rc1 release notes 2022-12-10 10:34:44 +09:00
Randy Mackay
f8708dc953 Rover: version to 4.3.0-beta6 2022-12-10 10:34:44 +09:00
Randy Mackay
7fd3360a03 Rover: 4.3.0-beta6 release notes 2022-12-10 10:34:44 +09:00
bugobliterator
d486b095d2 AP_HAL_ChibiOS: make EKF running on second IMU primary 2022-12-10 10:34:44 +09:00
Andrew Tridgell
ce7b0fb68f hwdef: save flash space on boards that are over 2022-12-10 10:34:44 +09:00
Peter Barker
493fb57efc Tools: move to compiling 64-bit Windows executables
Co-authored-by: davidbuzz@gmail.com
Co-authored-by: robertlong13

cygwin has dropped 32-bit support
2022-12-10 10:34:44 +09:00
Peter Barker
74d3a5ba05 .github: move to compiling 64-bit Windows executables
cygwin has dropped 32-bit support
2022-12-10 10:34:44 +09:00
Andrew Tridgell
18bbf68332 AP_Scheduler: guarantee that FAST_TASK tasks do run on every loop
the breakup of the fast loop resulted in us sometimes (under heavy CPU
load) not running a fast task on every loop
2022-12-10 10:34:44 +09:00
Andrew Tridgell
105daa9734 Plane: added FAST_TASK() for key scheduler tasks
this will be needed with #22298 as that now relies on integrating
position based on loop times
2022-12-10 10:34:44 +09:00
Randy Mackay
6713caba55 AP_Arming: add system check of main loop rate 2022-12-10 10:34:44 +09:00
Randy Mackay
1cc033746f AP_Scheduler: load_average returns 1 if main loop running slowly 2022-12-10 10:34:44 +09:00
Randy Mackay
a8306ce5fc AP_Scheduler: add get_filtered_loop_rate_hz 2022-12-10 10:34:44 +09:00
Randy Mackay
bfdda59f7e AP_Logger: PM msg gets LR field 2022-12-10 10:34:44 +09:00
Andrew Tridgell
0022c0b6b8 Plane: ensure smoothed airspeed is > 0
prevent possible divide by zero
2022-12-10 10:34:44 +09:00
Andrew Tridgell
3579cb451d Plane: added turn corrdination to autotune yaw rate tuning
this makes it much easier to do a yaw rate autotune, and also means
you don't need to use the rudder stick at all, as the yaw controller
is already exercised nicely with roll movements, so overall the tune
is faster and more accurate as less cross-axis coupling
2022-12-10 10:34:44 +09:00
Andrew Tridgell
502e28e8bc Tools: rebuilt bootloaders affected by STORAGE_FLASH_SIZE bug 2022-12-10 10:34:44 +09:00
Andrew Tridgell
7939213be8 hwdef: use only USB for bootloader on MatekF405-Wing
the bootloader doesn't fit in flash with UARTs as well
2022-12-10 10:34:44 +09:00
Andrew Tridgell
42aeda4e48 Tools: added --only-bl option to configure_all.py 2022-12-10 10:34:44 +09:00
Andrew Tridgell
a1f8d9c43d hwdef: stop defining STORAGE_FLASH_PAGE in hwdef-bl.dat
this should only be in hwdef.dat, so we don't have it in 2 places
2022-12-10 10:34:44 +09:00
Andrew Tridgell
8bdb72747f HAL_ChibiOS: fixed a bug in processing STORAGE_FLASH_PAGE
when we look in hwdef.dat for STORAGE_FLASH_PAGE we need to recurse
into includes, or we may miss it
2022-12-10 10:34:44 +09:00
Andrew Tridgell
b7d62d5609 Plane: ensure we init z controller when inactive
this prevents us getting the AC_PosControl internal error, which is
turning up as a common false positive.
2022-12-10 10:34:44 +09:00
Andrew Tridgell
608a9ce2d7 AP_Camera: fixed CAM_MIN_INTERVAL
delay the next photo until minimum interval is met, which is what the
documentation says. This fixes a nasty bug with mission plans where an
extra photo can be triggered by a camera trigger in a mission which
results in the number of CAM msgs being more than the number of images
on the microSD, which makes the mapping run unusable
2022-12-10 10:34:44 +09:00
Andrew Tridgell
f55ec103e6 AP_Logger: prevent long loops due to parameter logging
ensure that the logging process() doesn't take more than 1ms
2022-12-10 10:34:44 +09:00
Andrew Tridgell
e905889328 AP_HAL: added TIME_CHECK() macro
this can be used to find places where we use more time than
expected. It works similarly to WITH_SEMAPHORE()
2022-12-10 10:34:44 +09:00
Randy Mackay
32e8c47c70 AP_Mount: fix siyi version display 2022-12-10 10:34:44 +09:00
Randy Mackay
03748afd6d AP_Mount: fix for Siyi A8 2022-12-10 10:34:44 +09:00
Peter Barker
19ca387537 GCS_MAVLink: do not run all commands received on private channel
Co-authored-by: dawid.kopec.spectalight@gmail.com

returning true from this function means that we should run the command locally.  We really don't want to do that unless the command (or other targetted message) was actually sent at us!
2022-12-10 10:34:44 +09:00
Peter Barker
33218b4bc9 autotest: fix warning about deprecated distutils.dir_utils.copy_tree 2022-12-10 10:34:44 +09:00
Randy Mackay
9fae8b4376 SITL: vicon odometry corrected 2022-12-10 10:34:44 +09:00
Randy Mackay
6dbc4c657a GCS_MAVLink: correct consumption of ODOMETRY velocity 2022-12-10 10:34:44 +09:00
Randy Mackay
e9b8948ade GCS_MAVLink: minor format fix 2022-12-10 10:34:44 +09:00
Paul Riseborough
ab8c30a282 AP_NavEKF3: Prevent on ground range to ground being used in flight 2022-12-10 10:34:44 +09:00
Paul Riseborough
74ff64f440 AP_NavEKF3: Don't allow range finder use to start if terrain state is stale 2022-12-10 10:34:44 +09:00
Andrew Tridgell
c4425d51e1 AP_GPS: improve support for uBlox-M10
this sets up the M10 to use the BaiDou B1C signal instead of B1, and
disables glonass. This is needed to get a consistent 5Hz lock
2022-12-10 10:34:44 +09:00
Bill Geyer
5780fac5fe AC_AutoTune: fix pilot testing bug 2022-12-10 10:34:44 +09:00
Andrew Tridgell
5eede68dce Plane: prepare for 4.3.2beta1 2022-12-10 10:34:44 +09:00
Andrew Tridgell
5d653d5c67 Plane: update release notes for 4.3.2-beta1 2022-12-10 10:34:44 +09:00
Randy Mackay
22f4567569 Copter: version to 4.3.1 2022-12-05 16:03:44 +09:00
Randy Mackay
664b04112e Copter: 4.3.1 release notes 2022-12-05 16:03:44 +09:00
Randy Mackay
40acfdfa51 Copter: correct version to 4.3.1-rc1 2022-11-21 19:00:53 +09:00
Randy Mackay
e6a620beb7 Copter: version to 4.3.1-rc1 2022-11-21 18:48:35 +09:00
Randy Mackay
42d2b6194c Copter: 4.3.1-rc1 release notes 2022-11-21 18:48:35 +09:00
Randy Mackay
7683c9b48c Rover: version to 4.3.0-beta5 2022-11-21 18:48:35 +09:00
Randy Mackay
b7d1027ce3 Rover: 4.3.0-beta5 release notes 2022-11-21 18:48:35 +09:00
Peter Barker
a5482a1456 .github: stop using choco to install cygwin packages
Instead use a github action to install cygwin and the packages we require.

chocolately's cygwin integration appears to have broken - installing cygwin directly using a convenient github action seems preferable than putting up with further breakage past this one.
2022-11-21 18:48:35 +09:00
Andrew Tridgell
ced55236a2 Plane: fixed yaw rate tuning in AUTOTUNE mode
don't reset yaw rate controller continuously while we are trying to
use it
2022-11-21 18:48:35 +09:00
MatthewHampsey
da309c5622 APM_Control: fixed yaw PID reset 2022-11-21 18:48:35 +09:00
Peter Barker
726efb9cf2 AP_Compass: correct is_calibrating check
before this we only ever looked at the first backend
2022-11-21 18:48:35 +09:00
Peter Barker
fa80cda260 AP_Compass: remove default clause from calibrator status switch
bad_radius should almost certainly be treated just like bad orientation
2022-11-21 18:48:35 +09:00
Randy Mackay
bd9b34b828 AP_Mount: Siyi enabled only on >1MB boards 2022-11-21 18:48:35 +09:00
Andy Piper
2c88657a85 AP_Camera: fix parameter caching with RunCam enablement and setup on 3-pos switch 2022-11-21 18:48:35 +09:00
Andy Piper
54789a1887 AP_HAL_ChibiOS: hwdef for SpeedyBee F405 v3 2022-11-21 18:48:35 +09:00
Andy Piper
bfaf900dee scripts: add SpeedyBee F405 v3 to manifest generator 2022-11-21 18:48:35 +09:00
Andy Piper
02119215eb bootloaders: add SpeedyBee F405 v3 bootloader 2022-11-21 18:48:35 +09:00
Andy Piper
c538e20213 AP_Bootloader: add board id for SpeedyBee F405 v3 2022-11-21 18:48:35 +09:00
Andy Piper
09d044090b AP_HAL_ChibiOS: support 8 bi-directional dshot channels on MatekH743 2022-11-21 18:48:35 +09:00
Andy Piper
39f243ca8f AP_HAL_ChibiOS: correctly default SERIAL7 to RCIN and SERIAL5 to ESC telem on MatekH743-bdshot 2022-11-21 18:48:35 +09:00
Randy Mackay
9494c14d38 Rover: integrate balancebot pitch limit protection 2022-11-21 18:48:35 +09:00
Randy Mackay
d3a39e016a AR_AttitudeControl: balancebot gets pitch limit protection 2022-11-21 18:48:35 +09:00
Randy Mackay
304eb55956 Tools: ArduRoller param file loses ATC_BAL_SPD_FF 2022-11-21 18:48:35 +09:00
Randy Mackay
35e90f3149 Tools: balancebot test does not set ATC_BAL_SPD_FF
also update autotest balance bot tuning
2022-11-21 18:48:35 +09:00
Randy Mackay
3ff211f827 Rover: integrate ATC change to balancebot pitch control 2022-11-21 18:48:35 +09:00
Randy Mackay
e57bd59c31 AR_AttitudeControl: balancebot pitch feedforward uses current pitch angle 2022-11-21 18:48:35 +09:00
Randy Mackay
63f8882744 AR_AttitudeControl: improve balancebot pitch control param description 2022-11-21 18:48:35 +09:00
Randy Mackay
46c9eea17f Rover: balance bot max pitch default to 10deg 2022-11-21 18:48:35 +09:00
Randy Mackay
43dd733084 AP_Mount: gremsy driver sends vehicle att at 50hz 2022-11-21 18:48:35 +09:00
Andrew Tridgell
207484e69d AP_GPS: fixed injection of RTCM on 2 different CAN buses
if we have two CAN GPS on difference can drivers we need to inject to
both
2022-11-21 18:48:35 +09:00
Andrew Tridgell
8e91811a42 AP_GPS: disable GPS lag checking in AP_Periph
it is much more useful to check on the flight controller, not on the
periph, or users just get mysterious failures
2022-11-21 18:48:35 +09:00
Lucas De Marchi
0a5ef6dbed Tools: Update fram params for skyviper
Set the necessary SERVO*_FUNCTION params so it doesn't conflict.
2022-11-21 18:48:35 +09:00
Andrew Tridgell
35f649ba1c AP_BoardConfig: fixed description of BRD_IO_ENABLE 2022-11-21 18:48:35 +09:00
Andrew Tridgell
2f65a9b35a HAL_ChibiOS: fixed BRD_SAFETY_MASK on some boards
for boards that have an IOMCU but also have a safety button on the FMU
this fixes the BRD_SAFETY_MASK
2022-11-21 18:48:35 +09:00
Andrew Tridgell
02716eb379 Tools: fixed filename for AtomRCF405NAVI bl 2022-11-21 18:48:35 +09:00
Henry Wurzburg
3e7c1ca88b AP_OSD: fix error in stats screen introduced in #18396 2022-11-21 18:48:35 +09:00
Andy Piper
1f4f8df30f Copter: add turtle mode safety features. 2022-11-21 18:48:35 +09:00
Andy Piper
356b2a9656 AP_InertialSensor: ensure that hardware AAF and notch filter are enabled on 42605 and 42609 2022-11-21 18:48:35 +09:00
Henry Wurzburg
2617c2de99 AP_SerialManager: move multiple RC input error to pre-arm failure 2022-11-21 18:48:35 +09:00
Henry Wurzburg
3e815dd1b0 AP_Arming: move multiple RC input error to pre-arm failure 2022-11-21 18:48:35 +09:00
Yuri
4a9ac7ce1c AP_Vehicle: enable HNTCH for Rover 2022-11-21 18:48:35 +09:00
Yuri
cec53233dd Rover: enable HNTCH for Rover 2022-11-21 18:48:35 +09:00
Andrew Tridgell
4755ca7434 AP_Scripting: adjust EFI_SkyPower for rev 0.3 protocol 2022-11-21 18:48:35 +09:00
Andrew Tridgell
d9e8d0ab19 AP_EFI: fixed units of exhaust gas temperature 2022-11-21 18:48:35 +09:00
Andrew Tridgell
2eeff1de32 AP_Scripting: added CANDRV to HFE EFI driver and document 2022-11-21 18:48:35 +09:00
Andrew Tridgell
037468c1de Rover: enable EFI_STATUS mavlink message 2022-11-21 18:48:35 +09:00
Andrew Tridgell
2538490c60 AP_Scripting: added throttle and generator control for EFI_SkyPower driver
and added documentation for the driver
2022-11-21 18:48:35 +09:00
Andrew Tridgell
85e5ddca5e Copter: enable send of EFI_STATUS 2022-11-21 18:48:35 +09:00
Andrew Tridgell
33f49daada Plane: check for EFI enable in messages 2022-11-21 18:48:35 +09:00
alexklimaj
ca54c9f5e8 AP_Baro: BMP390 2022-11-21 18:48:35 +09:00
alexklimaj
a5b13043bf hwdef: ARKV6X 2022-11-21 18:48:35 +09:00
Andrew Tridgell
95688be02f AP_Airspeed: add instance to hygrometer logging 2022-11-21 18:48:35 +09:00
Andrew Tridgell
953f542ec5 Plane: send HYGROMETER_SENSOR data if available 2022-11-21 18:48:35 +09:00
Andrew Tridgell
75bd885c0e GCS_MAVLink: send HYGROMETER_SENSOR message if data available 2022-11-21 18:48:35 +09:00
Andrew Tridgell
48b4ca6962 AP_Airspeed: support DroneCAN airspeed with hygrometer data
some DroneCAN airspeed sensors can send hygrometer data, for when they
have de-icing support
2022-11-21 18:48:35 +09:00
Andrew Tridgell
913682928a Tools: added new baro types 2022-11-21 18:48:35 +09:00
Andrew Tridgell
0c3be8b782 AP_Arming: use baro arming checks call 2022-11-21 18:48:35 +09:00
Andrew Tridgell
52e1be74a2 AP_Baro: added option to treat MS5611 as MS5607
and add arming check for pressure altitude error
2022-11-21 18:48:35 +09:00
Pierre Kancir
2fa3f94f20 GCS_MAVLink: fix always 0 division.
7/8 into array range bracket will be integral type, therefore 7/8 is reported as always 0.
2022-11-21 18:48:35 +09:00
Randy Mackay
352df63a0e AP_AHRS: pre-arm msg loses extra AHRS prefix 2022-11-21 18:48:35 +09:00
Andy Piper
5bb2be206a AP_SerialManager: only use the first defined serial port for RCIN 2022-11-21 18:48:35 +09:00
Andy Piper
5ce0c23beb AP_RCProtocol: add has_uart() 2022-11-21 18:48:35 +09:00
murata
4ea763eda1 Copter: Message length within 50 bytes 2022-11-21 18:48:35 +09:00
Randy Mackay
f44135ec77 AP_Mount: minor comment fix to has_pan_control 2022-11-21 18:48:35 +09:00
Randy Mackay
ae6ec4bfe0 Tools: custom build server option for Siyi gimbal mount 2022-11-21 18:48:35 +09:00
Randy Mackay
35c948497b RC_Channel: add camera aux functions 2022-11-21 18:48:35 +09:00
Randy Mackay
562fcb5963 AP_Camera: add record video zoom and focus 2022-11-21 18:48:35 +09:00
Randy Mackay
df55701c56 AP_Mount: add Siyi gimbal driver 2022-11-21 18:48:35 +09:00
Randy Mackay
8b119507b0 AP_Mount: add camera controls 2022-11-21 18:48:35 +09:00
Randy Mackay
93448b7138 Copter: version to 4.3.0 official 2022-10-31 12:34:40 +09:00
Randy Mackay
ef03e47010 Copter: 4.3.0 release notes 2022-10-31 12:34:40 +09:00
Randy Mackay
c4c4526903 Copter: version to 4.3.0-beta4 2022-10-24 22:23:32 +09:00
Randy Mackay
39a4b70f59 Copter: 4.3.0-beta4 release notes 2022-10-24 22:23:32 +09:00
Randy Mackay
a7fec7473d Rover: version to 4.3.0-beta4 2022-10-24 22:23:32 +09:00
Randy Mackay
757951d5c7 Rover: 4.3.0-beta4 release notes 2022-10-24 22:23:32 +09:00
Andrew Tridgell
e7d0a285cf Plane: prepare for 4.3.1 2022-10-24 22:23:32 +09:00
Andrew Tridgell
2bc28e7d23 Plane: release notes for 4.3.1 2022-10-24 22:23:32 +09:00
Andrew Tridgell
3a9f1475a7 Plane: cover more cases in fence breach mode change
we want to allow all landing sequence mode changes
2022-10-24 22:23:32 +09:00
Andrew Tridgell
5a75b78cec Plane: allow mode switch on fence breach for RTL_AUTOLAND
when we are in a fence breach we by default disallow mode changes, but
we need to allow for the switch to AUTO if the reason is we are
entering a landing sequence, which is part of the RTL process which is
the fence action
2022-10-24 22:23:32 +09:00
Andrew Tridgell
b9a168fe3d AP_NavEKF3: fixed getLLH alt for local origin height
this fixes a bug introduced in #21834

this fix in #21834 was correct for getPosD, but should not have been
applied to getLLH

this caused cruise mode in plane to descend/ascend by the difference
between the public and local origins on mode entry

fixes #21984
2022-10-24 22:23:32 +09:00
Andrew Tridgell
aa12184bd4 Plane: prepare for 4.3.1beta1 2022-10-24 22:23:32 +09:00
Andrew Tridgell
e09a634c63 Plane: release notes for 4.3.1beta1 2022-10-24 22:23:32 +09:00
Andrew Tridgell
3b7b365ae3 AP_AHRS: added ATSC logging
log scale factors for angle P scaling when not == 1.0
2022-10-24 22:23:32 +09:00
Andrew Tridgell
71ad3587dd AC_AttitudeControl: added single loop override of angle P gains
this is used by quadplanes in back-transiton to prevent oscillation
caused by driving the fixed wing controller too fast
2022-10-24 22:23:32 +09:00
Andrew Tridgell
f6069c35f4 APM_Control: added access to time constant 2022-10-24 22:23:32 +09:00
Andrew Tridgell
1f7b4dcef6 Plane: scale VTOL angle P gains with airspeed
During POSITION1 back-transiton we scale the MC angle P gains with
airspeed to reduce the chance of oscillations. At higher airspeeds the
fixed wing controller dominates so we should use the fixed wing angle
P gain.
2022-10-24 22:23:32 +09:00
Iampete1
5d2f47a4bc AP_Scripting: set lua nullptr after delete 2022-10-24 22:23:32 +09:00
Andrew Tridgell
e986983b8a Plane: log TECS target alt
log the target alt we pass into TECS to help debug a CRUISE height
issue
2022-10-24 22:23:32 +09:00
Andrew Tridgell
220fd7caa1 AP_RPM: fixed SITL RPM backend for new motor mask 2022-10-24 22:23:32 +09:00
Andrew Tridgell
e4a747c247 SITL: allow for extra actuators to be marked as motors 2022-10-24 22:23:32 +09:00
Andrew Tridgell
a35055a6ec AP_ESC_TELEM: allow for non-continguous ESC telem motor sets
this fixes ESC telem for quadplanes with motors at 5-8 or 9-12
2022-10-24 22:23:32 +09:00
Andrew Tridgell
e584a07610 HAL_SITL: use motor mask for noise checking for motors 2022-10-24 22:23:32 +09:00
Andrew Tridgell
d062688b30 AP_InertialSensor: use motor_mask from SITL for which outputs are motors
generate noise based on motor_mask
2022-10-24 22:23:32 +09:00
Andrew Tridgell
4dba724fc7 AP_Vehicle: removed num_dynamic_notches limit in dynamic harmonic
use INS_MAX_NOTCHES instead, allowing for more ESCs to be added by lua
scripts
2022-10-24 22:23:32 +09:00
Andrew Tridgell
3e8fd1800f Filter: allow for expansion of dynamic filters
this allows for the number of dynamic filters on a harmonic notch
filter to expand at runtime, which allows for ESC RPMs to be populated
from other than AP_Motors, such as with lua scripts or for fwd motors
in a SLT quadplane
2022-10-24 22:23:32 +09:00
Andrew Tridgell
cca7a540ea SITL switched to motor_mask for which actuators are motors
this allows for any output to be an ESC, which allows for proper
simulation of quadplanes with ESCs on outputs 5-8 or 9-12, for testing
notch filtering
2022-10-24 22:23:32 +09:00
Iampete1
46fae47a06 Plane: Quadplane: SLT: enforce TECS pitch limits to beat race 2022-10-24 22:23:32 +09:00
Andrew Tridgell
854061fdbe waf: added --enable-gps-logging 2022-10-24 22:23:32 +09:00
Andrew Tridgell
ead4974b01 SITL: support playback of new GPS log format 2022-10-24 22:23:32 +09:00
Andrew Tridgell
0e09a07de0 AP_GPS: fixed resolution of KSXT parsing for NMEA
needs to be double precision for lat/lon
2022-10-24 22:23:32 +09:00
Andrew Tridgell
4a6673c04e AP_GPS: added logging to more serial GPS backends 2022-10-24 22:23:32 +09:00
Andrew Tridgell
6e3ca69ae6 AP_GPS: improve GPS debug logging
use timestamped data allowing for much more precise playback
2022-10-24 22:23:32 +09:00
Leonardo Garcia
9b78f6af08 AP_InertialSensor: Fix BMI085 accel scaling
Original BMI088 has 24G range so it was hardcoded for *scale* within
read_fifo_accel. Added a class variable accel_range which is assigned
the correct value when the sensor type is received (16.0 or 24.0).
2022-10-24 22:23:32 +09:00
Andrew Tridgell
b99952e7f3 GCS_MAVLink: prevent segv in ftp
if the user disables ftp by changing BRD_OPTIONS after ftp has started
then we could dereference a nullptr
2022-10-24 22:23:32 +09:00
Andrew Tridgell
e9a5c2553a AP_Scripting: added rc:get_aux_cached() example 2022-10-24 22:23:32 +09:00
Andrew Tridgell
71696b9fb0 AP_Scripting: added get_aux_cached() RC binding 2022-10-24 22:23:32 +09:00
Andrew Tridgell
9ccf043884 RC_Channel: added cache of aux functions for scripting
allows for scripting to act on aux functions
2022-10-24 22:23:32 +09:00
Andrew Tridgell
1a49c33a4a AP_Common: added setonoff() method for bitmask 2022-10-24 22:23:32 +09:00
Andrew Tridgell
04fb0b8ebc AP_Scripting: added relay get() binding 2022-10-24 22:23:32 +09:00
Andrew Tridgell
dcecff3bef AP_Relay: added get() method for scripting 2022-10-24 22:23:32 +09:00
bugobliterator
263ea03f13 modules: update chibios 2022-10-24 22:23:32 +09:00
Andrew Tridgell
fd126b0d37 waf: ensure we don't try to use non-implemented functions 2022-10-24 22:23:32 +09:00
Andrew Tridgell
8555a815d8 Tools: added CubePilot to board recognition for uploader.py
for CubeOrangePlus
2022-10-24 22:23:32 +09:00
Andrew Tridgell
5c9e222366 HAL_ChibiOS: fixed build error with gcc 11.3 2022-10-24 22:23:32 +09:00
Andrew Tridgell
bc14301e58 AP_Scripting: fixed use of clock and time in lua
not available on stm32
2022-10-24 22:23:32 +09:00
Andrew Tridgell
80302ba27c GCS_MAVLINK: fixed warning in ftp build with gcc 11.3 2022-10-24 22:23:32 +09:00
Willian Galvani
40d514e1c3 Tools: attempt to fix Sub flapping test 2022-10-24 22:23:32 +09:00
Randy Mackay
553af39593 Copter: version to 4.3.0-beta3 2022-10-14 17:13:10 +09:00
Randy Mackay
69ebb6cf34 Copter: 4.3.0-beta3 release notes 2022-10-14 17:13:10 +09:00
Randy Mackay
af443fe5c0 Rover: version to 4.3.0-beta3 2022-10-14 17:13:10 +09:00
Randy Mackay
614c01c93e Rover: 4.3.0-beta3 release notes 2022-10-14 17:13:10 +09:00
Andrew Tridgell
c4632777e7 Plane: prepare for 4.3.0 release 2022-10-14 17:13:10 +09:00
Andrew Tridgell
669f45f8aa Plane: 4.3.0 final release notes 2022-10-14 17:13:10 +09:00
Andrew Tridgell
4fab724c76 RC_Channel: add winch enable to option param docs for Copter 2022-10-14 17:13:10 +09:00
Iampete1
8877f45578 AP_Scripting: clear alocated i2c devices on scripting stop 2022-10-14 17:13:10 +09:00
Iampete1
bc1c2bbed4 AP_Scripting: add maunal i2c binding allowing read of sequentual registers 2022-10-14 17:13:10 +09:00
Iampete1
e7ee0ce526 AP_Scripting: allow maunal apobject bindings 2022-10-14 17:13:10 +09:00
Andrew Tridgell
8031dd2be8 AP_Vehicle: implement 1M/2M warnings
encourage users to run the right firmware for their boards
2022-10-14 17:13:10 +09:00
Andrew Tridgell
3bf18422cd hwdef: added warning messages about flash size 2022-10-14 17:13:10 +09:00
Andrew Tridgell
8957152b80 AP_Bootloader: use new check_limit_flash_1M()
use common function
2022-10-14 17:13:10 +09:00
Andrew Tridgell
b6e7236d3c HAL_ChibiOS: make check_limit_flash_1M() available in main firmware 2022-10-14 17:13:10 +09:00
Andrew Tridgell
7b1b021c7e Tools: fixed build of bootloaders with debug 2022-10-14 17:13:10 +09:00
Andrew Tridgell
8a862adc29 Plane: prepare for 4.3.0beta3 2022-10-14 17:13:10 +09:00
Andrew Tridgell
e40fd07183 Plane: release notes for 4.3.0beta3 2022-10-14 17:13:10 +09:00
Andrew Tridgell
88795dac18 AP_Airspeed: use DEVID to maintain lineup of CAN sensors
persist DEVID and use it to ensure that we keep the order of DroneCAN
sensors between boots. It still allows for a sensor to be swapped out
for a new one, while keeping slot of the one that hasn't been removed
2022-10-14 17:13:10 +09:00
davidsastresas
4c9156eab9 AP_NMEA_Output.cpp: Fix conversion precision issue:
We were casting the location in integer 32 bits
to float, and making fabsf in float as well, so
we were losing precision translated in about 40 cm
minimum variation in position for the NMEA output.

Also, even if using double and fabsF, we were still
rounding up last 2 decimals, so now the logic is
done in degree * 10e7 to not loose precision and
then converted properly before building the string
2022-10-14 17:13:10 +09:00
Andrew Tridgell
0118b8a27f AP_ICEngine: report when engine goes into run state 2022-10-14 17:13:10 +09:00
Andrew Tridgell
f489af18eb AP_Vehicle: check for motors being nullptr
this can happen with plane with Q_ENABLE=0
2022-10-14 17:13:10 +09:00
Andrew Tridgell
902b60c88e AP_BoardConfig: fixed BRD_SAFETY_MASK
this was being omitted on most boards since we changed to
SERVOn_FUNCTION=-1 method for GPIO
2022-10-14 17:13:10 +09:00
Andrew Tridgell
e7a5bcf6aa AP_Param: fixed handling of long lines in defaults.parm
lines longer than 100 bytes were causing the parsing to stop
2022-10-14 17:13:10 +09:00
mattbooker
e4b4d00645 Plane: Fixed divide by zero error when transitioning to guided 2022-10-14 17:13:10 +09:00
Andrew Tridgell
6e009a82ed Plane: prepare for 4.3.0beta2 2022-10-14 17:13:10 +09:00
Randy Mackay
a1417a6a90 Copter: version to 4.3.0-beta2 2022-10-04 16:50:08 +09:00
Randy Mackay
fcd6d34247 Copter: 4.3.0-beta2 release notes 2022-10-04 16:50:08 +09:00
Randy Mackay
5ac93f1488 Rover: version to 4.3.0-beta2 2022-10-04 16:50:08 +09:00
Randy Mackay
2dd0caab93 Rover: 4.3.0-beta2 release notes 2022-10-04 16:50:08 +09:00
Andrew Tridgell
b07a2a93ee Plane: added release notes for 4.3.0beta2 2022-10-04 16:50:08 +09:00
Michael du Breuil
d30891e3d1 Plane: Allow reseting target airspeed to the parameter value 2022-10-04 16:50:08 +09:00
Kirill Shilov
84986fda01 hwdef: AIRLink: USART2 enabled in hwdef 2022-10-04 16:50:08 +09:00
Andy Piper
6fc232af92 AP_GyroFFT: correct ref_energy indexing that could lead to free memory read
Fix doc spelling mistakes
2022-10-04 16:50:08 +09:00
Andrew Tridgell
826d7bf984 CI: use base branch for test size
allow test size CI to run for beta builds
2022-10-04 16:50:08 +09:00
Andy Piper
a012e9a740 AP_Logger: ensure that we don't read the same block more than once, dramatically increasing performance. 2022-10-04 16:50:08 +09:00
Andrew Tridgell
ce103fe101 hwdef: reduce flash usage to allow build 2022-10-04 16:50:08 +09:00
Andrew Tridgell
9415d9fc40 AP_Scripting: delay getting EFI backend
allow for AP_EFI startup after scripting
2022-10-04 16:50:08 +09:00
Andrew Tridgell
24ef595af6 AP_Scripting: changed bindings to ap_object 2022-10-04 16:50:08 +09:00
Andrew Tridgell
fe2cc8315a AP_Scripting: convert HFE driver to get_backend 2022-10-04 16:50:08 +09:00
Andrew Tridgell
5d3a34ab10 AP_RPM: added AP_RPM_config.h 2022-10-04 16:50:08 +09:00
Andrew Tridgell
920d7e1bc5 AP_EFI: switched to AP_EFI_config.h 2022-10-04 16:50:08 +09:00
Andrew Tridgell
be18ed8245 AP_EFI: convert to using ap_object approach 2022-10-04 16:50:08 +09:00
Andrew Tridgell
1a68678dd6 AP_Scripting: added mag_heading example 2022-10-04 16:50:08 +09:00
Andrew Tridgell
a3c6bd0a9c AP_Scripting: added EFI HFE driver 2022-10-04 16:50:08 +09:00
Andrew Tridgell
710eb1046a AP_Scripting: added EFI_HFE tester 2022-10-04 16:50:08 +09:00
Andrew Tridgell
8fe3310ff3 AP_HAL: added id_signed for CANFrame
makes for more efficient lua processing
2022-10-04 16:50:08 +09:00
Andrew Tridgell
1ee32bff88 AP_Scripting: update bindings for new fields 2022-10-04 16:50:08 +09:00
Andrew Tridgell
9b789ac47f AP_EFI: added more fields
fill in 3 remaining fields available in MAVLink
2022-10-04 16:50:08 +09:00
Andrew Tridgell
7f0d71ef98 AP_Scripting: added EFI testing script 2022-10-04 16:50:08 +09:00
Andrew Tridgell
6b08b2a2fd AP_Scripting: added EFI_SkyPower driver 2022-10-04 16:50:08 +09:00
Andrew Tridgell
23e2b6a374 AP_EFI: removed array from cylinder_status
this array was never used and just makes doing drivers harder. Removed
to reduce complexity
2022-10-04 16:50:08 +09:00
Joshua Henderson
75abceeb85 AP_EFI: add EFI scripting driver 2022-10-04 16:50:08 +09:00
Andrew Tridgell
7b975a1b71 AP_Scripting: update docs 2022-10-04 16:50:08 +09:00
Joshua Henderson
d71496206f AP_Scripting: add scripting EFI bindings 2022-10-04 16:50:08 +09:00
Joshua Henderson
c1f2c1a382 AP_Vehicle: EFI increase loop rate to 50Hz 2022-10-04 16:50:08 +09:00
Andrew Tridgell
d492d017e8 AP_PiccoloCAN: fix for new param set 2022-10-04 16:50:08 +09:00
Reilly Callaway
10eb5d3867 AP_PiccoloCAN: SendECU throttle commands over CAN 2022-10-04 16:50:08 +09:00
Reilly Callaway
26116675bf AP_EFI: Add Currawong ECU packet decoding 2022-10-04 16:50:08 +09:00
Reilly Callaway
6f6725019a AP_EFI: Add ECU density parameter for Currawong fuel flow calculations 2022-10-04 16:50:08 +09:00
Reilly Callaway
af07ec124b AP_EFI: Add Currawong ECU to known types 2022-10-04 16:50:08 +09:00
Reilly Callaway
be580bbbf8 AP_PiccoloCAN: Add Currawong ECU message handling 2022-10-04 16:50:08 +09:00
Reilly Callaway
95f28b3693 AP_PiccoloCAN: Add Currawong ECU piccolo protocol 2022-10-04 16:50:08 +09:00
Reilly Callaway
49b7efe4cb AP_EFI: Add currawong ECU EFI backend 2022-10-04 16:50:08 +09:00
Reilly Callaway
d3ee4ebf64 AP_Math: Add kg/m^3 to g/cm^3 conversion define 2022-10-04 16:50:08 +09:00
Reilly Callaway
a95e4def52 Tools: Add kg per cubic meter unit metadata 2022-10-04 16:50:08 +09:00
Andrew Tridgell
13bc86ba60 DSDL: update submodule 2022-10-04 16:50:08 +09:00
Andrew Tridgell
232c31053e AP_UAVCAN: support sending pulses as PWM for DroneCAN actuators 2022-10-04 16:50:08 +09:00
Andrew Tridgell
52ba9be204 AP_Periph: support actuator type with PWM
this makes debugging much easier in CAN analyser
2022-10-04 16:50:08 +09:00
Andy Piper
a5a8bfaf43 Filter: optimize notch filter frequency updates when the requested frequency has not changed 2022-10-04 16:50:08 +09:00
yaapu
99a73a6a12 AP_MSP: move arming status to MSP telemetry base class 2022-10-04 16:50:08 +09:00
yaapu
9e0425495e AP_OSD: New per screen PARAMs for OSD overlay resolution and font
This adds
 OSDn_TXT_RES to select SD/HD overlay resoloution
 OSDn_FONT_INDEX for font index selection

Right now support is limited to MSP Displayport OSD devices
2022-10-04 16:50:08 +09:00
Randy Mackay
2e70b585b4 AP_Mount: remove set_mode overrides
The mode state is local to the driver and does not depend upon successful communication with the gimbal
2022-10-04 16:50:08 +09:00
yaapu
871627eb2d AP_OSD: Fixed UART thread ownership for the MSP DisplayPort OSD Backend 2022-10-04 16:50:08 +09:00
Henry Wurzburg
c49fede360 SRV_Channel: change sw and output names to match new MOUNT params 2022-10-04 16:50:08 +09:00
Henry Wurzburg
9e365dfc36 RC_Channel: change sw and output names to match new MOUNT params 2022-10-04 16:50:08 +09:00
Michael du Breuil
6a5ad848a4 AP_Arming: Expose ARMING_OPTIONS to all vehicles 2022-10-04 16:50:08 +09:00
murata
40a03367f3 AP_InertialSensor: Allow gyro counts to be returned 2022-10-04 16:50:08 +09:00
Andy Piper
b159268af2 AP_InertialSensor: make sure dynamic notches always get updates so that slew limiting is not too aggressive 2022-10-04 16:50:08 +09:00
Andy Piper
c468958e60 Filter: constrain harmonic notch center frequency changes to be within a slew limit
raise notch filter slew for smaller aircraft
ensure NotchFilter init() resets the center frequency
2022-10-04 16:50:08 +09:00
Andy Piper
c232cf3d4f AP_Vehicle: make sure notches are not spurious disabled when not using throttle notch 2022-10-04 16:50:08 +09:00
Yuri
95ec0185c4 AP_HAL_ChibiOS: define skyviper short board names 2022-10-04 16:50:08 +09:00
Yuri
0dd396daeb GCS_MAVLink: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
b11a280b6d AP_Radio: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
0c7aadc8f8 AP_Logger: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
b6eca86a96 AP_HAL_SITL: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
ebe27b95a9 AP_HAL_Linux: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
8519ccfa2f AP_HAL_ESP32: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
4a2cb5f3dd AP_HAL_ChibiOS: define CubeOrange-SimOnHardWare short board name 2022-10-04 16:50:08 +09:00
Yuri
acb4702689 AP_HAL_ChibiOS: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Yuri
d9b19b797d AP_HAL: increase short board names to 23 chars 2022-10-04 16:50:08 +09:00
Peter Barker
5647db13ea AP_GPS: use default case for sending blob
This structure avoids a compiler warning that a statement isn't reachable when all backends are compiled out.
2022-10-04 16:50:08 +09:00
Peter Barker
eacfbc599e AP_GPS: no init blobs for SBF/GSOF/NOVA/SITL 2022-10-04 16:50:08 +09:00
Peter Barker
1bb7d045c7 AP_GPS: cycle through baud rates for SBF/GSOF/NOVA/SITL 2022-10-04 16:50:08 +09:00
Iampete1
d1d020fb50 SRV_Channel: adjust trim, check all channels for range limit 2022-10-04 16:50:08 +09:00
Paul Riseborough
829def567b AP_NavEKF3: Allow wind states to recover faster when airspeed sensor failed 2022-10-04 16:50:08 +09:00
Paul Riseborough
7430932288 Tools: Use a more typical wind speed for the PitotBlockage autotest 2022-10-04 16:50:08 +09:00
Paul Riseborough
e0a7e36e01 Tolls/autotest: Fix Flake8 style check fails 2022-10-04 16:50:08 +09:00
Paul Riseborough
9090319343 Tools/autotest: fail pitot tube at start of takeoff 2022-10-04 16:50:08 +09:00
Paul Riseborough
db64d85a18 Tools/autotest: rework arming and takeoff mode change order
Co-authored-by: Peter Barker <pb-gh@barker.dropbear.id.au>
2022-10-04 16:50:08 +09:00
Paul Riseborough
3d4ea4ec37 Tools/autotest: Use clearer method of setting parameters
Co-authored-by: Peter Barker <pb-gh@barker.dropbear.id.au>
2022-10-04 16:50:08 +09:00
Andrew Tridgell
2afbbfde21 AP_Airspeed: allow EKF checking without wind max 2022-10-04 16:50:08 +09:00
Paul Riseborough
02e30b067f AP_Airspeed: Update documentation for used parameter index warnings 2022-10-04 16:50:08 +09:00
Andrew Tridgell
3303ca717e AP_Logger: fixed missing doc field 2022-10-04 16:50:08 +09:00
Paul Riseborough
86fdb6617f Tools: Python coding style fixes 2022-10-04 16:50:08 +09:00
Paul Riseborough
a782f849da AP_Airspeed: remove unsupported parameter units descriptor 2022-10-04 16:50:08 +09:00
Paul Riseborough
bd0d320fe4 AP_Airspeed: Add tuning advice for ARSP_WIND_GATE 2022-10-04 16:50:08 +09:00
Paul Riseborough
b3f289d3d1 AP_Airspeed: Add hysteresis to consistency check 2022-10-04 16:50:08 +09:00
Paul Riseborough
705c6e1a83 Tools: Add partial unblockage to pitot blockage test 2022-10-04 16:50:08 +09:00
Paul Riseborough
72d7ab2a4e Tools: Add autotest for pitot tube blockage handling 2022-10-04 16:50:08 +09:00
Paul Riseborough
3d2fbf9438 AP_TECS: Assume flight at cruise speed if speed measurement not available 2022-10-04 16:50:08 +09:00
Paul Riseborough
fa06e3e612 AP_Airspeed: Enable use of EKF3 to check airspeed health 2022-10-04 16:50:08 +09:00
Paul Riseborough
a49eca341e AP_Logger: Fix ARSP data type string 2022-10-04 16:50:08 +09:00
Paul Riseborough
9f523547ca AP_Logger: Add consistency test ratio to ASPD logging 2022-10-04 16:50:08 +09:00
Paul Riseborough
f613c4088e AP_AHRS: Add accessor function for airspeed health monitoring 2022-10-04 16:50:08 +09:00
Paul Riseborough
66e26bb5cc AP_NavEKF3: Allow reporting of airspeed consistency for a deselected sensor 2022-10-04 16:50:08 +09:00
Paul Riseborough
037cf9d2e9 AP_NavEKF3: Add accessor function for airspeed health monitoring 2022-10-04 16:50:08 +09:00
Paul Riseborough
991959ddf7 AP_NavEKF3: Enable monitoring of unhealthy airspeed sensors
Innovations and innovation test ratios will still be calculated and reported for an unhealthy sensor, but the EKF states wnd covariance matrix will not be modified.
2022-10-04 16:50:08 +09:00
Andy Piper
ec7b9aa272 AP_RPM: fix reporting of RPM from the harmonic notch 2022-10-04 16:50:08 +09:00
Andrew Tridgell
37da615334 AP_Motors: added a SPIN_MIN check
and check SPIN_ARM <= SPIN_MIN
2022-10-04 16:50:08 +09:00
Andrew Tridgell
2fcd371857 AP_BoardConfig: load CUAVv6X defaults when detected 2022-10-04 16:50:08 +09:00
Andrew Tridgell
bcd8ccf038 AP_Param: make load_defaults_file() available on ChibiOS 2022-10-04 16:50:08 +09:00
Andrew Tridgell
b77db1f590 hwdef: added CUAV_V6X default parameters 2022-10-04 16:50:08 +09:00
Andrew Tridgell
6bb477715d AP_CANManager: disable SLCAN when armed
this disables SLCAN if enabled using CAN_SLCAN_CPORT and
SERIALn_PROTOCOL=22 when we are armed, to reduce load on the CAN
thread from the very inefficient SLCAN processing
2022-10-04 16:50:08 +09:00
Andrew Tridgell
6a048da6ad hwdef: reduced memory usage on MatekF405-CAN board 2022-10-04 16:50:08 +09:00
Andy Piper
0b7ff5eeb3 bootloaders: make sure SkystarsH7HD has functioning VTX on Camera 1 by default 2022-10-04 16:50:08 +09:00
Andy Piper
71e860feec AP_HAL_ChibiOS: make sure SkystarsH7HD has functioning VTX on Camera 1 by default 2022-10-04 16:50:08 +09:00
Andy Piper
23c6ea320c AP_HAL_ChibiOS: put RX on UART1 on Skystars H7HD bdshot
make sure VTX has power on Skystars H7HD at boot
2022-10-04 16:50:08 +09:00
Andy Piper
d05e79dfa3 scripts: add Skystars variants to manifest generator 2022-10-04 16:50:08 +09:00
Andy Piper
ee5e1a6055 bootloaders: add and correct SkystarsH7HD bootloaders 2022-10-04 16:50:08 +09:00
Andy Piper
f3fbc6691e AP_HAL_ChibiOS: hwdef for bdshot variant of SkystarsH7HD
Correct bootloader storage location for SkystarsH7HD
2022-10-04 16:50:08 +09:00
yaapu
bc26aabafb ArduPlane: fixed roll and pitch for OSD VTOL view 2022-10-04 16:50:08 +09:00
Bob Long
c170f1bccf AP_Mission: initialize jump-tracking in init() 2022-10-04 16:50:08 +09:00
Peter Barker
c5a786559a autotest: check target system on return mission_item_int packets 2022-10-04 16:50:08 +09:00
Peter Barker
5f1388f366 AP_Mission: zero frame field when filling mavlink_int from mavlink_cmd
Callers should be filling their bits in after calling this.
2022-10-04 16:50:08 +09:00
Andrew Tridgell
c52f620127 AP_NavEKF3: fixed EKF3 origin alt inconsistency
always use common origin, and adjust output posD for difference
between public and local lane origin heights
2022-10-04 16:50:08 +09:00
Andrew Tridgell
44b2a42953 autotest: added a test for EKF lane change in GUIDED
an EKF lane change when the two lanes are using different GPS should
not cause a height change in GUIDED
2022-10-04 16:50:08 +09:00
Andrew Tridgell
37cb0fe0c5 autotest: move do_aux_function to common 2022-10-04 16:50:08 +09:00
Peter Barker
1b6e65cc2f ArduSub: add missing include 2022-10-04 16:50:08 +09:00
Peter Barker
c39129d4fe AP_RPM: correct SITL backend compilation if RPM disabled in SITL 2022-10-04 16:50:08 +09:00
Peter Barker
2c91e902de Rover: do not send MSG_RPM if RPM not enabled 2022-10-04 16:50:08 +09:00
Peter Barker
51d176338c Blimp: do not send MSG_RPM if RPM not enabled 2022-10-04 16:50:08 +09:00
Peter Barker
659ea9e08b ArduPlane: do not send MSG_RPM if RPM not enabled 2022-10-04 16:50:08 +09:00
Peter Barker
6cdfe13e05 ArduCopter: do not send MSG_RPM if RPM not enabled 2022-10-04 16:50:08 +09:00
Andy Piper
202bbc3fab AP_VideoTX: ensure that Tramp changes are broadcast to the GCS 2022-10-04 16:50:08 +09:00
Andy Piper
4b06cafcc0 AP_VideoTX: fix potential buffer overrun bug 2022-10-04 16:50:08 +09:00
Andy Piper
7fafc49321 AP_VideoTX: add lookup tables for VTX power settings
correct settings when power set is received
add support for capturing all supported power levels
learn power levels in SmartAudio 2.1
add better support for VTX power levels
don't set power to 0 if in pitmode
add option for iNav compatibility
support non-conforming SmartAudio implementations
re-enable pitmode on SmartAudio 2.0
add support for "blind" VTX setting
2022-10-04 16:50:08 +09:00
Andrew Tridgell
b293a8cdff hwdef: rename board at request of vendor
there are multiple AtomRCF405 boards
2022-10-04 16:50:08 +09:00
Randy Mackay
8e12e51362 Copter: version to 4.3.0-beta1 2022-09-13 14:19:47 +09:00
Randy Mackay
55d0cbd2a6 Copter: 4.3.0-beta1 release notes 2022-09-13 14:19:47 +09:00
Randy Mackay
2b11a8ad5b Rover: version to 4.3.0-beta1 2022-09-13 14:19:47 +09:00
Randy Mackay
cefb8856d4 Rover: 4.3.0-beta1 release notes 2022-09-13 14:19:47 +09:00
Andrew Tridgell
108842c727 Plane: prepare for 4.3.0beta1 2022-09-13 14:19:47 +09:00
Andrew Tridgell
59f7d5666f Plane: release notes for Plane 4.3.0beta1 2022-09-13 14:19:47 +09:00
Andrew Tridgell
ed53dc0988 SITL: fixed tailsitter airspeed in RF9 2022-09-13 14:19:47 +09:00
Andrew Tridgell
6dc63e5d86 AP_Scripting: added set_rpm_scale example 2022-09-13 14:19:47 +09:00
Andrew Tridgell
d3461452ef AP_Scripting: added set_rpm_scale API 2022-09-13 14:19:47 +09:00
Andrew Tridgell
e7ab8147b3 AP_ESC_Telem: support set_rpm_scale() call for scripting 2022-09-13 14:19:47 +09:00
m
8b601fbf63 autotest: Fix watch_altitude_maintained for Copter 2022-09-13 14:19:47 +09:00
552 changed files with 20239 additions and 1954 deletions

View File

@ -1,6 +1,8 @@
# common ccache env vars for CI # common ccache env vars for CI
export CCACHE_SLOPPINESS=file_stat_matches export CCACHE_SLOPPINESS=file_stat_matches
git config --global --add safe.directory ${GITHUB_WORKSPACE}
mkdir -p ~/.ccache mkdir -p ~/.ccache
echo "base_dir = ${GITHUB_WORKSPACE}" > ~/.ccache/ccache.conf echo "base_dir = ${GITHUB_WORKSPACE}" > ~/.ccache/ccache.conf
echo "compression = true" >> ~/.ccache/ccache.conf echo "compression = true" >> ~/.ccache/ccache.conf

View File

@ -13,26 +13,27 @@ jobs:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with: with:
submodules: 'recursive' submodules: 'recursive'
- name: Install cygwin - uses: cygwin/cygwin-install-action@master
with:
packages: cygwin64 gcc-g++=10.2.0-1 python37 python37-future python37-lxml python37-pip python37-setuptools python37-wheel git procps gettext
- name: Prepare Python environment
env: env:
HOME: ${{ runner.workspace }}/ardupilot HOME: ${{ runner.workspace }}/ardupilot
run: | run: |
choco install cygwin --params "/InstallDir:C:\Cygwin /NoStartMenu /NoAdmin" bash --login -c "ln -sf /usr/bin/python3.7 /usr/bin/python && ln -sf /usr/bin/pip3.7 /usr/bin/pip"
choco install cygwin32-gcc-g++ python37 python37-future python37-lxml python37-pip python37-setuptools python37-wheel git libexpat procps gettext --source cygwin bash --login -c "python -m pip install empy==3.3.4 pexpect"
C:\Cygwin\bin\bash --login -c "ln -sf /usr/bin/python3.7 /usr/bin/python && ln -sf /usr/bin/pip3.7 /usr/bin/pip" bash --login -c "python -m pip install dronecan --upgrade"
C:\Cygwin\bin\bash --login -c "python -m pip install empy pexpect"
C:\Cygwin\bin\bash --login -c "python -m pip install dronecan --upgrade"
- name: Build SITL - name: Build SITL
env: env:
HOME: ${{ runner.workspace }}/ardupilot HOME: ${{ runner.workspace }}/ardupilot
run: | run: |
C:\Cygwin\bin\bash --login -c "Tools/scripts/cygwin_build.sh" bash --login -c "Tools/scripts/cygwin_build.sh"
- name: Check build files - name: Check build files
id: check_files id: check_files
uses: andstor/file-existence-action@v1 uses: andstor/file-existence-action@v1
with: with:
files: "artifacts/ArduPlane.elf.exe, artifacts/ArduCopter.elf.exe, artifacts/ArduHeli.elf.exe, artifacts/ArduRover.elf.exe, artifacts/ArduSub.elf.exe" files: "artifacts/*"
allow_failure: true allow_failure: true
- name: Archive build - name: Archive build

View File

@ -1,6 +1,6 @@
name: test size name: test size
on: [push, pull_request, workflow_dispatch] on: [pull_request]
# paths: # paths:
# - "*" # - "*"
# - "!README.md" <-- don't rebuild on doc change # - "!README.md" <-- don't rebuild on doc change
@ -28,8 +28,8 @@ jobs:
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with: with:
ref: 'master' ref: ${{ github.event.pull_request.base.ref }}
path: 'master' path: base_branch
submodules: 'recursive' submodules: 'recursive'
# Put ccache into github cache for faster build # Put ccache into github cache for faster build
- name: Prepare ccache timestamp - name: Prepare ccache timestamp
@ -42,14 +42,14 @@ jobs:
with: with:
path: ~/.ccache path: ~/.ccache
key: ${{github.workflow}}-ccache-${{ matrix.toolchain }}-${{steps.ccache_cache_timestamp.outputs.timestamp}} key: ${{github.workflow}}-ccache-${{ matrix.toolchain }}-${{steps.ccache_cache_timestamp.outputs.timestamp}}
restore-keys: ${{github.workflow}}-ccache-${{ matrix.toolchain }}- # restore ccache from either previous build on this branch or on master restore-keys: ${{github.workflow}}-ccache-${{ matrix.toolchain }}- # restore ccache from either previous build on this branch or on base branch
- name: Build master ${{matrix.config}} ${{ matrix.toolchain }} - name: Build ${{ github.event.pull_request.base.ref }} ${{matrix.config}} ${{ matrix.toolchain }}
env: env:
CI_BUILD_TARGET: ${{matrix.config}} CI_BUILD_TARGET: ${{matrix.config}}
shell: bash shell: bash
run: | run: |
PATH="/github/home/.local/bin:$PATH" PATH="/github/home/.local/bin:$PATH"
cd master cd base_branch
./waf configure --board ${{matrix.config}} ./waf configure --board ${{matrix.config}}
if [ "${{matrix.config}}" = "Hitec-Airspeed" ] || if [ "${{matrix.config}}" = "Hitec-Airspeed" ] ||
[ "${{matrix.config}}" = "f103-GPS" ]; then [ "${{matrix.config}}" = "f103-GPS" ]; then
@ -57,14 +57,14 @@ jobs:
else else
./waf ./waf
fi fi
mkdir -p $GITHUB_WORKSPACE/master_bin mkdir -p $GITHUB_WORKSPACE/base_branch_bin
cp -r build/${{matrix.config}}/bin/* $GITHUB_WORKSPACE/master_bin/ cp -r build/${{matrix.config}}/bin/* $GITHUB_WORKSPACE/base_branch_bin/
# build a set of binaries without symbols so we can check if # build a set of binaries without symbols so we can check if
# the binaries have changed. # the binaries have changed.
echo [`date`] Building master with no versions echo [`date`] Building ${{ github.event.pull_request.base.ref }} with no versions
NO_VERSIONS_DIR="$GITHUB_WORKSPACE/master_bin_no_versions" NO_VERSIONS_DIR="$GITHUB_WORKSPACE/base_branch_bin_no_versions"
mkdir "$NO_VERSIONS_DIR" mkdir "$NO_VERSIONS_DIR"
if [ "${{matrix.config}}" = "Hitec-Airspeed" ] || if [ "${{matrix.config}}" = "Hitec-Airspeed" ] ||
@ -75,7 +75,7 @@ jobs:
fi fi
cp -r build/${{matrix.config}}/bin/* "$NO_VERSIONS_DIR" cp -r build/${{matrix.config}}/bin/* "$NO_VERSIONS_DIR"
echo [`date`] Built master with no versions echo [`date`] Built ${{ github.event.pull_request.base.ref }} with no versions
- uses: actions/checkout@v2 - uses: actions/checkout@v2
with: with:
@ -92,8 +92,8 @@ jobs:
git config user.email "ardupilot-ci@ardupilot.org" git config user.email "ardupilot-ci@ardupilot.org"
git config user.name "ArduPilot CI" git config user.name "ArduPilot CI"
git remote add ardupilot https://github.com/ArduPilot/ardupilot.git git remote add ardupilot https://github.com/ArduPilot/ardupilot.git
git fetch --no-tags --prune --progress ardupilot master git fetch --no-tags --prune --progress ardupilot ${{ github.event.pull_request.base.ref }}
git rebase ardupilot/master git rebase ardupilot/${{ github.event.pull_request.base.ref }}
git submodule update --init --recursive --depth=1 git submodule update --init --recursive --depth=1
./waf configure --board ${{matrix.config}} ./waf configure --board ${{matrix.config}}
if [ "${{matrix.config}}" = "Hitec-Airspeed" ] || if [ "${{matrix.config}}" = "Hitec-Airspeed" ] ||
@ -136,29 +136,29 @@ jobs:
ls -l "$PLANE_BINARY" ls -l "$PLANE_BINARY"
fi fi
- name: Full size compare with Master - name: Full size compare with base branch
shell: bash shell: bash
run: | run: |
cd pr/ cd pr/
python3 -m pip install -U tabulate python3 -m pip install -U tabulate
Tools/scripts/pretty_diff_size.py -m $GITHUB_WORKSPACE/master_bin -s $GITHUB_WORKSPACE/pr_bin Tools/scripts/pretty_diff_size.py -m $GITHUB_WORKSPACE/base_branch_bin -s $GITHUB_WORKSPACE/pr_bin
- name: Checksum compare with Master - name: Checksum compare with ${{ github.event.pull_request.base.ref }}
shell: bash shell: bash
run: | run: |
diff -r $GITHUB_WORKSPACE/master_bin_no_versions $GITHUB_WORKSPACE/pr_bin_no_versions --exclude=*.elf --exclude=*.apj || true diff -r $GITHUB_WORKSPACE/base_branch_bin_no_versions $GITHUB_WORKSPACE/pr_bin_no_versions --exclude=*.elf --exclude=*.apj || true
- name: elf_diff compare with Master - name: elf_diff compare with ${{ github.event.pull_request.base.ref }}
shell: bash shell: bash
run: | run: |
python3 -m pip install -U weasyprint elf_diff anytree python3 -m pip install -U weasyprint elf_diff anytree
mkdir elf_diff mkdir elf_diff
if [ "${{matrix.config}}" = "Hitec-Airspeed" ] || if [ "${{matrix.config}}" = "Hitec-Airspeed" ] ||
[ "${{matrix.config}}" = "f103-GPS" ]; then [ "${{matrix.config}}" = "f103-GPS" ]; then
python3 -m elf_diff --bin_prefix=arm-none-eabi- --html_dir=elf_diff/AP_Periph $GITHUB_WORKSPACE/master_bin/AP_Periph $GITHUB_WORKSPACE/pr_bin/AP_Periph python3 -m elf_diff --bin_prefix=arm-none-eabi- --html_dir=elf_diff/AP_Periph $GITHUB_WORKSPACE/base_branch_bin/AP_Periph $GITHUB_WORKSPACE/pr_bin/AP_Periph
else else
python3 -m elf_diff --bin_prefix=arm-none-eabi- --html_dir=elf_diff/plane $GITHUB_WORKSPACE/master_bin/arduplane $GITHUB_WORKSPACE/pr_bin/arduplane python3 -m elf_diff --bin_prefix=arm-none-eabi- --html_dir=elf_diff/plane $GITHUB_WORKSPACE/base_branch_bin/arduplane $GITHUB_WORKSPACE/pr_bin/arduplane
python3 -m elf_diff --bin_prefix=arm-none-eabi- --html_dir=elf_diff/copter $GITHUB_WORKSPACE/master_bin/arducopter $GITHUB_WORKSPACE/pr_bin/arducopter python3 -m elf_diff --bin_prefix=arm-none-eabi- --html_dir=elf_diff/copter $GITHUB_WORKSPACE/base_branch_bin/arducopter $GITHUB_WORKSPACE/pr_bin/arducopter
fi fi
zip -r elf_diff.zip elf_diff zip -r elf_diff.zip elf_diff

View File

@ -23,7 +23,7 @@ jobs:
] ]
config: [ config: [
unit-tests, unit-tests,
python-cleanliness, # python-cleanliness, # DISABLED for 4.3.x
sitl sitl
# examples, # examples,
] ]

View File

@ -74,7 +74,7 @@ void Tracker::update_pitch_position_servo()
// PITCH2SRV_IMAX 4000.000000 // PITCH2SRV_IMAX 4000.000000
// calculate new servo position // calculate new servo position
float new_servo_out = SRV_Channels::get_output_scaled(SRV_Channel::k_tracker_pitch) + g.pidPitch2Srv.update_error(nav_status.angle_error_pitch); float new_servo_out = SRV_Channels::get_output_scaled(SRV_Channel::k_tracker_pitch) + g.pidPitch2Srv.update_error(nav_status.angle_error_pitch, G_Dt);
// position limit pitch servo // position limit pitch servo
if (new_servo_out <= pitch_min_cd) { if (new_servo_out <= pitch_min_cd) {
@ -125,7 +125,7 @@ void Tracker::update_pitch_onoff_servo(float pitch) const
*/ */
void Tracker::update_pitch_cr_servo(float pitch) void Tracker::update_pitch_cr_servo(float pitch)
{ {
const float pitch_out = constrain_float(g.pidPitch2Srv.update_error(nav_status.angle_error_pitch), -(-g.pitch_min+g.pitch_max) * 100/2, (-g.pitch_min+g.pitch_max) * 100/2); const float pitch_out = constrain_float(g.pidPitch2Srv.update_error(nav_status.angle_error_pitch, G_Dt), -(-g.pitch_min+g.pitch_max) * 100/2, (-g.pitch_min+g.pitch_max) * 100/2);
SRV_Channels::set_output_scaled(SRV_Channel::k_tracker_pitch, pitch_out); SRV_Channels::set_output_scaled(SRV_Channel::k_tracker_pitch, pitch_out);
} }
@ -187,7 +187,7 @@ void Tracker::update_yaw_position_servo()
right direction right direction
*/ */
float servo_change = g.pidYaw2Srv.update_error(nav_status.angle_error_yaw); float servo_change = g.pidYaw2Srv.update_error(nav_status.angle_error_yaw, G_Dt);
servo_change = constrain_float(servo_change, -18000, 18000); servo_change = constrain_float(servo_change, -18000, 18000);
float new_servo_out = constrain_float(SRV_Channels::get_output_scaled(SRV_Channel::k_tracker_yaw) + servo_change, -18000, 18000); float new_servo_out = constrain_float(SRV_Channels::get_output_scaled(SRV_Channel::k_tracker_yaw) + servo_change, -18000, 18000);
@ -238,6 +238,6 @@ void Tracker::update_yaw_onoff_servo(float yaw) const
*/ */
void Tracker::update_yaw_cr_servo(float yaw) void Tracker::update_yaw_cr_servo(float yaw)
{ {
const float yaw_out = constrain_float(-g.pidYaw2Srv.update_error(nav_status.angle_error_yaw), -g.yaw_range * 100/2, g.yaw_range * 100/2); const float yaw_out = constrain_float(-g.pidYaw2Srv.update_error(nav_status.angle_error_yaw, G_Dt), -g.yaw_range * 100/2, g.yaw_range * 100/2);
SRV_Channels::set_output_scaled(SRV_Channel::k_tracker_yaw, yaw_out); SRV_Channels::set_output_scaled(SRV_Channel::k_tracker_yaw, yaw_out);
} }

View File

@ -162,6 +162,12 @@ bool AP_Arming_Copter::board_voltage_checks(bool display_failure)
// all data loaded // all data loaded
bool AP_Arming_Copter::terrain_database_required() const bool AP_Arming_Copter::terrain_database_required() const
{ {
if (copter.wp_nav->get_terrain_source() == AC_WPNav::TerrainSource::TERRAIN_FROM_RANGEFINDER) {
// primary terrain source is from rangefinder, allow arming without terrain database
return false;
}
if (copter.wp_nav->get_terrain_source() == AC_WPNav::TerrainSource::TERRAIN_FROM_TERRAINDATABASE && if (copter.wp_nav->get_terrain_source() == AC_WPNav::TerrainSource::TERRAIN_FROM_TERRAINDATABASE &&
copter.mode_rtl.get_alt_type() == ModeRTL::RTLAltType::RTL_ALTTYPE_TERRAIN) { copter.mode_rtl.get_alt_type() == ModeRTL::RTLAltType::RTL_ALTTYPE_TERRAIN) {
return true; return true;
@ -380,7 +386,7 @@ bool AP_Arming_Copter::gps_checks(bool display_failure)
} }
// warn about hdop separately - to prevent user confusion with no gps lock // warn about hdop separately - to prevent user confusion with no gps lock
if (copter.gps.get_hdop() > copter.g.gps_hdop_good) { if ((copter.gps.num_sensors() > 0) && (copter.gps.get_hdop() > copter.g.gps_hdop_good)) {
check_failed(ARMING_CHECK_GPS, display_failure, "High GPS HDOP"); check_failed(ARMING_CHECK_GPS, display_failure, "High GPS HDOP");
AP_Notify::flags.pre_arm_gps_check = false; AP_Notify::flags.pre_arm_gps_check = false;
return false; return false;

View File

@ -1,5 +1,23 @@
#include "Copter.h" #include "Copter.h"
/*************************************************************
* Attitude Rate controllers and timing
****************************************************************/
// update rate controllers and output to roll, pitch and yaw actuators
// called at 400hz by default
void Copter::run_rate_controller()
{
// set attitude and position controller loop time
const float last_loop_time_s = AP::scheduler().get_last_loop_time_s();
motors->set_dt(last_loop_time_s);
attitude_control->set_dt(last_loop_time_s);
pos_control->set_dt(last_loop_time_s);
// run low level rate controllers that only require IMU data
attitude_control->rate_controller_run();
}
/************************************************************* /*************************************************************
* throttle control * throttle control
****************************************************************/ ****************************************************************/

View File

@ -143,7 +143,7 @@ const AP_Scheduler::Task Copter::scheduler_tasks[] = {
#endif #endif
FAST_TASK(Log_Video_Stabilisation), FAST_TASK(Log_Video_Stabilisation),
SCHED_TASK(rc_loop, 100, 130, 3), SCHED_TASK(rc_loop, 250, 130, 3),
SCHED_TASK(throttle_loop, 50, 75, 6), SCHED_TASK(throttle_loop, 50, 75, 6),
SCHED_TASK_CLASS(AP_GPS, &copter.gps, update, 50, 200, 9), SCHED_TASK_CLASS(AP_GPS, &copter.gps, update, 50, 200, 9),
#if AP_OPTICALFLOW_ENABLED #if AP_OPTICALFLOW_ENABLED
@ -750,10 +750,15 @@ bool Copter::get_wp_crosstrack_error_m(float &xtrack_error) const
return true; return true;
} }
// get the target body-frame angular velocities in rad/s (Z-axis component used by some gimbals) // get the target earth-frame angular velocities in rad/s (Z-axis component used by some gimbals)
bool Copter::get_rate_bf_targets(Vector3f& rate_bf_targets) const bool Copter::get_rate_ef_targets(Vector3f& rate_ef_targets) const
{ {
rate_bf_targets = attitude_control->rate_bf_targets(); // always returns zero vector if landed or disarmed
if (copter.ap.land_complete) {
rate_ef_targets.zero();
} else {
rate_ef_targets = attitude_control->get_rate_ef_targets();
}
return true; return true;
} }

View File

@ -687,7 +687,7 @@ private:
bool get_wp_distance_m(float &distance) const override; bool get_wp_distance_m(float &distance) const override;
bool get_wp_bearing_deg(float &bearing) const override; bool get_wp_bearing_deg(float &bearing) const override;
bool get_wp_crosstrack_error_m(float &xtrack_error) const override; bool get_wp_crosstrack_error_m(float &xtrack_error) const override;
bool get_rate_bf_targets(Vector3f& rate_bf_targets) const override; bool get_rate_ef_targets(Vector3f& rate_ef_targets) const override;
// Attitude.cpp // Attitude.cpp
void update_throttle_hover(); void update_throttle_hover();
@ -696,7 +696,7 @@ private:
void set_accel_throttle_I_from_pilot_throttle(); void set_accel_throttle_I_from_pilot_throttle();
void rotate_body_frame_to_NE(float &x, float &y); void rotate_body_frame_to_NE(float &x, float &y);
uint16_t get_pilot_speed_dn() const; uint16_t get_pilot_speed_dn() const;
void run_rate_controller() { attitude_control->rate_controller_run(); } void run_rate_controller();
#if AC_CUSTOMCONTROL_MULTI_ENABLED == ENABLED #if AC_CUSTOMCONTROL_MULTI_ENABLED == ENABLED
void run_custom_controller() { custom_control.update(); } void run_custom_controller() { custom_control.update(); }

View File

@ -1,6 +1,8 @@
#include "Copter.h" #include "Copter.h"
#include "GCS_Mavlink.h" #include "GCS_Mavlink.h"
#include <AP_RPM/AP_RPM_config.h>
#include <AP_EFI/AP_EFI_config.h>
MAV_TYPE GCS_Copter::frame_type() const MAV_TYPE GCS_Copter::frame_type() const
{ {
@ -534,10 +536,15 @@ static const ap_message STREAM_EXTRA3_msgs[] = {
MSG_MAG_CAL_PROGRESS, MSG_MAG_CAL_PROGRESS,
MSG_EKF_STATUS_REPORT, MSG_EKF_STATUS_REPORT,
MSG_VIBRATION, MSG_VIBRATION,
#if AP_RPM_ENABLED
MSG_RPM, MSG_RPM,
#endif
MSG_ESC_TELEMETRY, MSG_ESC_TELEMETRY,
MSG_GENERATOR_STATUS, MSG_GENERATOR_STATUS,
MSG_WINCH_STATUS, MSG_WINCH_STATUS,
#if HAL_EFI_ENABLED
MSG_EFI_STATUS,
#endif
}; };
static const ap_message STREAM_PARAMS_msgs[] = { static const ap_message STREAM_PARAMS_msgs[] = {
MSG_NEXT_PARAM MSG_NEXT_PARAM

View File

@ -1,5 +1,305 @@
ArduPilot Copter Release Notes: ArduPilot Copter Release Notes:
------------------------------------------------------------------ ------------------------------------------------------------------
Copter 4.3.8 24-Aug-2023 / 4.3.8-beta1 12-Aug-2023
Changes from 4.3.7
1) Bug fixes
- DroneCAN GPS RTK injection fix
- INAxxx battery monitors allow for battery reset remaining
- Notch filter gyro glitch caused by race condition fixed
- Scripting restart memory corruption bug fixed
------------------------------------------------------------------
Copter 4.3.7 31-May-2023 / 4.3.7-beta1 24-May-2023
Changes from 4.3.6
1) Bug fixes
a) EKF3 accel bias calculations bug fix
b) EKF3 accel bias process noise adjusted for greater robustness
c) GSF yaw numerical stability fix caused by compassmot
d) INS batch sampler fix to avoid watchdog if INS_LOG_BAT_CNT changed without rebooting
e) Memory corruption bug in the STM32H757 (very rare)
f) RC input on IOMCU bug fix (RC might not be regained if lost)
------------------------------------------------------------------
Copter 4.3.6 05-Apr-2023 / 4.3.6-beta1, 4.3.6--beta2 27-Mar-2023
Changes from 4.3.5
1) Bi-directional DShot fix for possible motor stop approx 72min after startup
------------------------------------------------------------------
Copter Copter 4.3.5 14-Mar-2023 / 4.3.5-rc1 01-Mar-2023
Changes from 4.3.4
1) Bug fixes
a) GPS unconfigured error fix for non-M10 uBlox GPS
b) Gremsy gimbal fix when attached to autopilot's serial3 (or higher)
c) Landing detector fix with large AHRS_TRIM values (>0.1)
d) MambaF405 2022 gets VTX power on support
e) MCU voltage enabled on H757 CPUs (including CubeOrangePlus)
f) PiccoloCAN fix for ESC voltage and current scaling
g) Servo gimbal mount yaw handling fix (only affects 3-axis servo gimbals)
------------------------------------------------------------------
Copter 4.3.4 01-Mar-2023
Changes from 4.3.4-rc1
1) Lua script PWMSource feature disabled (will be back in 4.4.x)
------------------------------------------------------------------
Copter 4.3.4-rc1 14-Feb-2023
Changes from 4.3.3
1) AutoPilot specific enhancements
a) CubeOrangePlusBG support
b) Foxeer ReaperF745 supports external compass
c) MambaH743v4 supports VTX power
2) Precision landing option to resume tracking target after pilot repositioning
3) Bug fixes
a) Arming check fix for terrain following with rangefinder (failed if terrain db was disabled)
b) Arming check fix if BARO_FIELD_ELEV set
c) Compass calibration diagonals set to 1,1,1 if incorrectly set to 0,0,0
d) FFT notch tune feature disabled (will be re-released in 4.4)
e) Gimbal's yaw feed-forward set to zero when landed (affects Gremsy gimbals)
f) IOMCU double reset and safety disable fix
g) Logging fix for duplicate format messages
h) OpenDroneId sets emergency status on crash or chute deploy
i) Peripheral firmware updates using MAVCAN fixed
j) RC protocol cannot be changed once detected on boards with IOMCU
k) Surface tracking uses filtered and corrected rangefinder values
------------------------------------------------------------------
Copter 4.3.3 20-Jan-2023
Changes from 4.3.3-rc1
1) Bug fixes
a) MAVFTP fix to terminate session error (could cause FTP failures)
b) IMU fast fifo reset log message max frequency reduced
------------------------------------------------------------------
Copter 4.3.3-rc1 09-Jan-2023
Changes from 4.3.2
1) Autopilot related changes
a) AIRLink LTE module enable pin and HEAT_ params added
b) CUAV Nora/Nora+ bdshot firmware (allows Bi-directional DShot)
c) CubeOrange, CubeYellow gets fast reset of ICM20602
d) MambaH743v2 with dual ICM42688 supported
e) PixPilot-V6
2) Attitude and Navigation controllers use real-time dt (better handles variable or slow main loop)
3) MAVFTP speed improvement including faster param download
4) Bug fixes
a) Analog rangefinder GPIO pin arming check fixed
b) Arming check of AHRS/EKF vs GPS location disabled if GPS disabled
c) CRSF gets RC_OPTIONS for ELRS baudrate to avoid RC failsafes
d) Null pointer checks avoid watchdog when out of memory
e) Position Controller limit handling improved to avoid overshooting and hard landings
f) Position Controller internal error after 70min of flight fixed
g) PSC_ANGLE_MAX param reduction causing WPNAV_ACCEL to be set too low fixed
h) Servo gimbal yaw jump to opposite side fixed
i) Siyi A8 gimbal driver's record video feature fixed
j) SToRM32 serial gimbal driver actual angle reporting fixed (pitch and yaw angle signs were reversed)
k) Takeoff in Auto, Guided fixed when target altitude is current altitude
l) Takeoff in Auto handles baro drift before takeoff
m) Takeoff twitch due to velocity integrator init bug fixed
------------------------------------------------------------------
Copter 4.3.2 23-Dec-2022
Changes from 4.3.2-rc1
1) Reverted arming check that main loop is running at configured speed (e.g. SCHED_LOOP_RATE)
------------------------------------------------------------------
Copter 4.3.2-rc1 10-Dec-2022
Changes from 4.3.1
1) Arming check that main loop is running at configured speed (e.g. SCHED_LOOP_RATE)
2) uBlox M10 support
3) Autopilot specific changes
a) CubeOrange defaults to using 2nd IMU as primary
b) SIRF and SBP GPS disabled on BeastF7v2, MatekF405-STD, MAtekF405-Wing, omnibusf4pro
4) Bug fixes
a) AutoTune gains loaded correctly during pilot testing
b) Camera driver's CAM_MIN_INTERVAL fixed if pilot manually triggers extra picture
c) EKF3 fix when using EK3_RNG_USE_HGT/SPD params and rangefinder provides bad readings
d) Main loop slowdown after arming fixed (parameter logging was causing delays)
e) Main loop's fast tasks always run (caused twitches in Loiter on heavily loaded CPUs)
f) MAVLink commands received on private channels checked for valid target sysid
g) ModalAI cameras support fixed (ODOMETRY message frame was consumed incorrectly)
h) Param reset after firmware load fixed on these boards
- BeastF7v2
- CubeYellow-bdshot
- f405-MatekAirspeed
- FlywooF745Nano
- KakuteF4Mini
- KakuteF7-bdshot
- MatekF405-bdshot
- MatekF405-STD
- MatekF405-Wing-bdshot
- MatekF765-SE
- MatekF765-Wing-bdshot
i) Siyi A8 gimbal support fixed
j) Windows builds move to compiling only 64-bit executables
------------------------------------------------------------------
Copter 4.3.1 05-Dec-2022 / 4.3.1-rc1 17-Nov-2022
Changes from 4.3.0
1) Autopilot specific enhancements
a) ARKV6X support
b) MatekH743 supports 8 bi-directional dshot channels
c) Pixhawk boards support MS5607 baros
d) SpeedbyBee F405v3 support
2) DroneCAN Airspeed sensor support including hygrometer (aka water vapour) readings
3) EFI support (electronic fuel injection engines)
4) Pre-arm warning if multiple UARTs with SERIALx_PROTOCOL = RCIN
5) Siyi gimbal support
6) Bug fixes
a) Arm check warning loses duplicate "AHRS" prefix
b) AtomRCF405NAVI bootloader file name fixed
c) BRD_SAFETY_MASK fixed on boards with both FMU safety switch and IOMCU
d) Compass calibration continues even if a single compass's cal fails
e) Gremsy gimbal driver sends autopilot info at lower rate to save bandwidth
f) Invensense 42605 and 42609 IMUs use anti-aliasing filter and notch filter
g) Mode change to AUTOTUNE message shortened
h) OSD stats screen fix
i) RC input on serial port uses first UART with SERIALx_PROTOCOL = 23 (was using last)
j) RunCam caching fix with enablement and setup on 3-pos switch
k) RTK CAN GPS fix when GPSs conneted to separate CAN ports on autopilot
l) SkyViper GPS fix
m) Turtle mode safety fixes (e.g. can only enter Tutle mode with at zero throttle)
------------------------------------------------------------------
Copter 4.3.0 31-Oct-2022 / 4.3.0-beta4 24-Oct-2022
Changes from 4.3.0-beta3
1) Scripting supports implementing AUX functions
2) Bug fixes
a) BMI085 accel scaling fixed
b) Build with gcc 11.3 fixed (developer only)
c) EKF3 alt discrepancy if GPS or baro alt changed soon after startup fixed
d) Harmonic Notch and ESC telem fix when motor outputs are non-contiguous
e) NMEA GPS's KSXT message parsing fixed (affected position accuracy)
f) Scripting random number generator fix
------------------------------------------------------------------
Copter 4.3.0-beta3 14-Oct-2022
Changes from 4.3.0-beta2
1) Pixhawk1-1M, fmuv2, fmuv3 display warning if firmware mismatches board's flash size (1M and 2M)
2) Scripting support for multi-byte i2c reads
3) Bug fixes
a) Airspeed CAN sensor ordering fixed (ordering could change if using multiple airspeed sensors)
b) BRD_SAFETY_MASK fix for enabling outputs when safety is on
c) Defaults.parm file processing fixed when a line has >100 characters and/or no new line (developer only)
d) NMEA serial output precision fixed (was only accurate to 1m, now accurate to 1cm)
------------------------------------------------------------------
Copter 4.3.0-beta2 4-Oct-2022
Changes from 4.3.0-beta1
1) Autopilot specific fixes and enhancements
a) AIRLink autopilot supports UART2
b) CUAV V6X supports CAN battery monitor by default
c) MatekF405-CAN board uses less memory to fix compass calibration issues
d) Pixhawk1-1M only supports uBlox and NMEA GPSs to save flash space
e) SkystarsH7HD-bdshot (allows Bi-directional DShot)
f) SkystarsH7HD supports VTX power by default
2) EFI support
a) Currawong ECU support (added as Electronic Fuel Injection driver)
b) Scripting support for EFI drivers (allows writing EFI drivers in Lua)
c) SkyPower and HFE CAN EFI drivers (via scripting)
3) Safety features
a) Arming check that SPIN_MIN less than 0.3 and greater than SPIN_ARM
4) Minor enhancements
a) Autopilot board names max length increased to 23 characters (was 13)
b) CAN actuators can report PWM equivalent values (eases debugging)
c) Log download speed improved for boards with "block" backends
d) Notch filter slew limit reduces chance of notch freq moving incorrectly
e) SLCAN disabled when vehicle is armed to reduce CPU load
5) Bug fixes
a) DO_JUMP mission command fixed if active command changed before changing to Auto mode
b) EKF3 altitude error fix when using dual GPSs and affinity enabled
c) FFT indexing bug fixed
d) Gimbal mount fix to default mode (see MNTx_DEFLT_MODE parameter)
e) MSP fix to report arm status to DJI FPV goggles
f) Notch fix for non-throttle notch (was being incorrectly disabled)
g) OSD fixes for params, font and resolution
h) RPM reporting from harmonic notch fixed
i) "Sending unknown message (50)" warning removed
j) SBF/GSOF/NOVA GPS auto detction of baud rate fixed
k) VideoTX fixes for buffer overruns and Tramp video transmitter support
------------------------------------------------------------------
Copter 4.3.0-beta1 14-Sep-2022
Changes from 4.2.3
1) New autopilot support
a) AtomRCF405
b) CubeOrange-SimOnHardWare
c) DevEBoxH7v2
d) KakuteH7Mini-Nand
e) KakuteH7v2
f) Mamba F405 Mk4
g) SkystarsH7HD
h) bi-directional dshot (aka "bdshot") versions for CubeOrange, CubeYellow, KakuteF7, KakuteH7, MatekF405-Wing, Matek F765, PH4-mini, Pixhawk-1M
2) EKF enhancements and fixes
a) EK3_GPS_VACC_MAX threshold to control when GPS altitude is used as alt source
b) EKF ring buffer fix for very slow sensor updates (those that update once every few seconds)
c) EKF3 source set change captured in Replay logs
3) Gimbal enhancements
a) Angle limit params renamed and scaled to degrees (e.g. MNT1_ROLL_MIN, MNT1_PITCH_MIN, etc)
b) BrushlessPWM driver (set MNT1_TYPE = 7) is unstabilized Servo driver
c) Dual mount support (see MNT1_, MNT2 params)
d) Gremsy driver added (set MNT1_TYPE = 6)
e) MAVLink gimbalv2 support including sending GIMBAL_DEVICE_STATUS_UPDATE (replaces MOUNT_STATUS message)
f) "Mount Lock" auxiliary switch supports follow and lock modes in RC targetting (aka earth-frame and body-frame)
g) RC channels to control gimbal set using RCx_OPTION = 212 (Roll), 213 (Pitch) or 214 (Yaw)
h) RC targetting rotation rate in deg/sec (see MNT1_RC_RATE which replaces MNT_JSTICK_SPD)
i) Yaw can be disabled on 3-axis gimbals (set MNTx_YAW_MIN = MNTx_YAW_MAX)
4) Navigation and Flight mode enhancements
a) Auto mode ATTITUDE_TIME command allows specifying lean angle for specified number of seconds (GPS not required)
b) Auto mode support of DO_GIMBAL_MANAGER_PITCHYAW command
c) Auto mode LOITER_TURNS command max radius increased to 2.5km
d) AutoTune allows higher ANGLE_P gains
e) Guided mode support DO_CHANGE_SPEED commands
f) Manual modes throttle mix reduced (improves landing)
g) Payload touchdown detection reliability improved
h) Takeoff detection improved to reduce chance of flip before takeoff if GPS moves
i) TKOFF_SLEW_TIME allows slower takeoffs in Auto, Guided, etc
5) Notch filter enhancements
a) Attitude and filter logging at main loop rate
b) Batch sampler logging both pre and post-filter
c) FFT frame averaging
d) In-flight throttle notch parameter learning using averaged FFTs
e) Triple harmonic notch
5) RemoteId and SecureBoot enhancements
a) Remote update of secure boot's public keys (also allows remote unlocking of bootloader)
6) Safety enhancements
a) Arming checks of FRAME_CLASS/TYPE made mandatory (even if ARMING_CHECK=0)
b) crash_dump.bin file saved to SD Card on startup (includes details re cause of software failures)
c) Dead-reckoning for 30sec on loss of GPS (requires wind estimation be enabled)
d) Dead-reckoning Lua script (On loss of GPS flies towards home for specified number of seconds)
e) Disabling Fence clears any active breaches (e.g. FENCE_TYPE = 0 will clear breaches)
f) "GPS Glitch" message clarified to "GPS Glitch or Compass error"
g) Pre-arm check that configured AHRS is being used (e.g. checks AHRS_EKF_TYPE not changed since boot)
h) Pre-arm check that gimbals are healthy (currently only for Gremsy gimbals, others in future release)
i) Pre-arm check that all motors are setup
j) Pre-arm check that scripts are running
k) Pre-arm check that terrain data loaded if RTL_ALT_TYPE set to Terrain
l) Pre-arm messages are correctly prefixed with "PreArm:" (instead of "Arm:")
m) RC auxiliary switch option for Arm / Emergency Stop
n) RC failsafe made pre-arm check (previously only triggered at arming)
o) RC failsafe option (see FS_OPTIONS) to continue in Guided obeyed even if GCS failsafe disabled
p) TKOFF_RPM_MIN checks all motors spinning before takeoff
q) Vibration compensation disabled in manual modes
7) Scripting enhancements
a) CAN2 port bindings to allow scripts to communicate on 2nd CAN bus
b) ESC RPM bindings to allow scripts to report engine RPM
c) Gimbal bingings to allow scripts to control gimbal
d) Pre-arm check bindings (allows scripts to check if pre-arm checks have passed)
e) Semicolon (:) and period (.) supported (e.g both Logger:write() and Logger.write will work)
8) Sensor driver enhancements
a) Benewake H30 radar support
b) BMI270 IMU performance improvements
c) IRC Tramp VTX suppor
d) Logging pause-able with auxiliary switch. see RCx_OPTION = 165 (Pause Stream Logging)
e) Proximity sensor support for up to 3 sensors
f) Precision Landing consumes LANDING_TARGET MAVLink message's PositionX,Y,Z fields
g) RichenPower generator maintenance-required messages can be suppressed using GEN_OPTIONS param
h) TeraRanger Neo rangefinder support
i) GPS support to provide ellipsoid altitude instead of AMSL (see GPS_DRV_OPTIONS)
j) W25N01GV 1Gb flash support
9) Bug fixes
a) Accel calibration throws away queued commands from GCS (avoids commands being run long after they were sent)
b) Airmode throttle mix at zero throttle fix
c) Cygbot proximity sensor fix to support different orientations (see PRXx_ORIENT)
d) Loiter fix to avoid potential wobble on 2nd takeoff (was not clearing non-zero attitude target from previous landing)
e) Lutan EFI message flood reduced
f) Missions download to GCS corruption avoided by checking serial buffer has space
g) Payload place fix so vehicle flies to specified Lat,Lon (if provided). Previously it could get stuck
h) Safety switch disabled if IOMCU is disabled (see BRD_IO_ENABLE=0)
i) Script restart memory leak fixed
j) Takeoff vertical velocity limits enforced correctly even if PILOT_TKOFF_ALT set to a significant height
10) Developer items
a) Custom controller support
b) Fast loop task list available in real-time using @SYS/tasks.txt
c) Parameter defaults sent to GCS with param FTP and recorded in onboard logs
d) ROS+ArduPilot environment installation script
e) Sim on Hardware allows simulator to run on autopilot (good for exhibitions)
f) Timer info available in real-time using @SYS/timers.txt
------------------------------------------------------------------
Copter 4.2.3 30-Aug-2022 Copter 4.2.3 30-Aug-2022
Changes from 4.2.3-rc3 Changes from 4.2.3-rc3
1) OpenDroneId bug fix to consume open-drone-id-system-update message 1) OpenDroneId bug fix to consume open-drone-id-system-update message

View File

@ -292,7 +292,7 @@ bool Copter::set_mode(Mode::Number mode, ModeReason reason)
} }
if (!new_flightmode->init(ignore_checks)) { if (!new_flightmode->init(ignore_checks)) {
mode_change_failed(new_flightmode, "initialisation failed"); mode_change_failed(new_flightmode, "init failed");
return false; return false;
} }
@ -667,6 +667,13 @@ void Mode::land_run_horizontal_control()
AP::logger().Write_Event(LogEvent::LAND_REPO_ACTIVE); AP::logger().Write_Event(LogEvent::LAND_REPO_ACTIVE);
} }
copter.ap.land_repo_active = true; copter.ap.land_repo_active = true;
#if PRECISION_LANDING == ENABLED
} else {
// no override right now, check if we should allow precland
if (copter.precland.allow_precland_after_reposition()) {
copter.ap.land_repo_active = false;
}
#endif
} }
} }

View File

@ -221,7 +221,6 @@ protected:
static float auto_takeoff_no_nav_alt_cm; static float auto_takeoff_no_nav_alt_cm;
// auto takeoff variables // auto takeoff variables
static float auto_takeoff_start_alt_cm; // start altitude expressed as cm above ekf origin
static float auto_takeoff_complete_alt_cm; // completion altitude expressed in cm above ekf origin or above terrain (depending upon auto_takeoff_terrain_alt) static float auto_takeoff_complete_alt_cm; // completion altitude expressed in cm above ekf origin or above terrain (depending upon auto_takeoff_terrain_alt)
static bool auto_takeoff_terrain_alt; // true if altitudes are above terrain static bool auto_takeoff_terrain_alt; // true if altitudes are above terrain
static bool auto_takeoff_complete; // true when takeoff is complete static bool auto_takeoff_complete; // true when takeoff is complete
@ -1641,6 +1640,9 @@ protected:
const char *name4() const override { return "TRTL"; } const char *name4() const override { return "TRTL"; }
private: private:
void arm_motors();
void disarm_motors();
float motors_output; float motors_output;
Vector2f motors_input; Vector2f motors_input;
}; };

View File

@ -778,7 +778,7 @@ void ModeGuided::accel_control_run()
auto_yaw.set_rate(0.0f); auto_yaw.set_rate(0.0f);
} }
pos_control->input_vel_accel_xy(guided_vel_target_cms.xy(), guided_accel_target_cmss.xy(), false); pos_control->input_vel_accel_xy(guided_vel_target_cms.xy(), guided_accel_target_cmss.xy(), false);
pos_control->input_vel_accel_z(guided_vel_target_cms.z, guided_accel_target_cmss.z, false, false); pos_control->input_vel_accel_z(guided_vel_target_cms.z, guided_accel_target_cmss.z, false);
} else { } else {
// update position controller with new target // update position controller with new target
pos_control->input_accel_xy(guided_accel_target_cmss); pos_control->input_accel_xy(guided_accel_target_cmss);
@ -865,7 +865,7 @@ void ModeGuided::velaccel_control_run()
// set position errors to zero // set position errors to zero
pos_control->stop_pos_xy_stabilisation(); pos_control->stop_pos_xy_stabilisation();
} }
pos_control->input_vel_accel_z(guided_vel_target_cms.z, guided_accel_target_cmss.z, false, false); pos_control->input_vel_accel_z(guided_vel_target_cms.z, guided_accel_target_cmss.z, false);
// call velocity controller which includes z axis controller // call velocity controller which includes z axis controller
pos_control->update_xy_controller(); pos_control->update_xy_controller();
@ -904,7 +904,7 @@ void ModeGuided::pause_control_run()
// set the vertical velocity and acceleration targets to zero // set the vertical velocity and acceleration targets to zero
float vel_z = 0.0; float vel_z = 0.0;
pos_control->input_vel_accel_z(vel_z, 0.0, false, false); pos_control->input_vel_accel_z(vel_z, 0.0, false);
// call velocity controller which includes z axis controller // call velocity controller which includes z axis controller
pos_control->update_xy_controller(); pos_control->update_xy_controller();

View File

@ -18,12 +18,29 @@ bool ModeTurtle::init(bool ignore_checks)
return false; return false;
} }
// do not enter the mode if sticks are not centered // do not enter the mode if sticks are not centered or throttle is not at zero
if (!is_zero(channel_pitch->norm_input_dz()) if (!is_zero(channel_pitch->norm_input_dz())
|| !is_zero(channel_roll->norm_input_dz()) || !is_zero(channel_roll->norm_input_dz())
|| !is_zero(channel_yaw->norm_input_dz())) { || !is_zero(channel_yaw->norm_input_dz())
|| !is_zero(channel_throttle->norm_input_dz())) {
return false; return false;
} }
// turn on notify leds
AP_Notify::flags.esc_calibration = true;
return true;
}
void ModeTurtle::arm_motors()
{
if (hal.util->get_soft_armed()) {
return;
}
// stop the spoolup block activating
motors->set_spoolup_block(false);
// reverse the motors // reverse the motors
hal.rcout->disable_channel_mask_updates(); hal.rcout->disable_channel_mask_updates();
change_motor_direction(true); change_motor_direction(true);
@ -36,8 +53,6 @@ bool ModeTurtle::init(bool ignore_checks)
// arm // arm
motors->armed(true); motors->armed(true);
hal.util->set_soft_armed(true); hal.util->set_soft_armed(true);
return true;
} }
bool ModeTurtle::allows_arming(AP_Arming::Method method) const bool ModeTurtle::allows_arming(AP_Arming::Method method) const
@ -47,6 +62,18 @@ bool ModeTurtle::allows_arming(AP_Arming::Method method) const
void ModeTurtle::exit() void ModeTurtle::exit()
{ {
disarm_motors();
// turn off notify leds
AP_Notify::flags.esc_calibration = false;
}
void ModeTurtle::disarm_motors()
{
if (!hal.util->get_soft_armed()) {
return;
}
// disarm // disarm
motors->armed(false); motors->armed(false);
hal.util->set_soft_armed(false); hal.util->set_soft_armed(false);
@ -142,6 +169,14 @@ void ModeTurtle::run()
// actually write values to the motors // actually write values to the motors
void ModeTurtle::output_to_motors() void ModeTurtle::output_to_motors()
{ {
// throttle needs to be raised
if (is_zero(channel_throttle->norm_input_dz())) {
disarm_motors();
return;
}
arm_motors();
// check if motor are allowed to spin // check if motor are allowed to spin
const bool allow_output = motors->armed() && motors->get_interlock(); const bool allow_output = motors->armed() && motors->get_interlock();

View File

@ -41,7 +41,6 @@ void Copter::init_rc_in()
// init_rc_out -- initialise motors // init_rc_out -- initialise motors
void Copter::init_rc_out() void Copter::init_rc_out()
{ {
motors->set_loop_rate(scheduler.get_loop_rate_hz());
motors->init((AP_Motors::motor_frame_class)g2.frame_class.get(), (AP_Motors::motor_frame_type)g.frame_type.get()); motors->init((AP_Motors::motor_frame_class)g2.frame_class.get(), (AP_Motors::motor_frame_type)g.frame_type.get());
// enable aux servos to cope with multiple output channels per motor // enable aux servos to cope with multiple output channels per motor

View File

@ -17,7 +17,7 @@ void Copter::SurfaceTracking::update_surface_offset()
// e.g. if vehicle is 10m above the EKF origin and rangefinder reports alt of 3m. curr_surface_alt_above_origin_cm is 7m (or 700cm) // e.g. if vehicle is 10m above the EKF origin and rangefinder reports alt of 3m. curr_surface_alt_above_origin_cm is 7m (or 700cm)
RangeFinderState &rf_state = (surface == Surface::GROUND) ? copter.rangefinder_state : copter.rangefinder_up_state; RangeFinderState &rf_state = (surface == Surface::GROUND) ? copter.rangefinder_state : copter.rangefinder_up_state;
const float dir = (surface == Surface::GROUND) ? 1.0f : -1.0f; const float dir = (surface == Surface::GROUND) ? 1.0f : -1.0f;
const float curr_surface_alt_above_origin_cm = copter.inertial_nav.get_position_z_up_cm() - dir * rf_state.alt_cm; const float curr_surface_alt_above_origin_cm = rf_state.inertial_alt_cm - dir * rf_state.alt_cm_filt.get();
// update position controller target offset to the surface's alt above the EKF origin // update position controller target offset to the surface's alt above the EKF origin
copter.pos_control->set_pos_offset_target_z_cm(curr_surface_alt_above_origin_cm); copter.pos_control->set_pos_offset_target_z_cm(curr_surface_alt_above_origin_cm);

View File

@ -448,15 +448,15 @@ void Copter::allocate_motors(void)
#if FRAME_CONFIG != HELI_FRAME #if FRAME_CONFIG != HELI_FRAME
if ((AP_Motors::motor_frame_class)g2.frame_class.get() == AP_Motors::MOTOR_FRAME_6DOF_SCRIPTING) { if ((AP_Motors::motor_frame_class)g2.frame_class.get() == AP_Motors::MOTOR_FRAME_6DOF_SCRIPTING) {
#if AP_SCRIPTING_ENABLED #if AP_SCRIPTING_ENABLED
attitude_control = new AC_AttitudeControl_Multi_6DoF(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s()); attitude_control = new AC_AttitudeControl_Multi_6DoF(*ahrs_view, aparm, *motors);
ac_var_info = AC_AttitudeControl_Multi_6DoF::var_info; ac_var_info = AC_AttitudeControl_Multi_6DoF::var_info;
#endif // AP_SCRIPTING_ENABLED #endif // AP_SCRIPTING_ENABLED
} else { } else {
attitude_control = new AC_AttitudeControl_Multi(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s()); attitude_control = new AC_AttitudeControl_Multi(*ahrs_view, aparm, *motors);
ac_var_info = AC_AttitudeControl_Multi::var_info; ac_var_info = AC_AttitudeControl_Multi::var_info;
} }
#else #else
attitude_control = new AC_AttitudeControl_Heli(*ahrs_view, aparm, *motors, scheduler.get_loop_period_s()); attitude_control = new AC_AttitudeControl_Heli(*ahrs_view, aparm, *motors);
ac_var_info = AC_AttitudeControl_Heli::var_info; ac_var_info = AC_AttitudeControl_Heli::var_info;
#endif #endif
if (attitude_control == nullptr) { if (attitude_control == nullptr) {
@ -464,7 +464,7 @@ void Copter::allocate_motors(void)
} }
AP_Param::load_object_from_eeprom(attitude_control, ac_var_info); AP_Param::load_object_from_eeprom(attitude_control, ac_var_info);
pos_control = new AC_PosControl(*ahrs_view, inertial_nav, *motors, *attitude_control, scheduler.get_loop_period_s()); pos_control = new AC_PosControl(*ahrs_view, inertial_nav, *motors, *attitude_control);
if (pos_control == nullptr) { if (pos_control == nullptr) {
AP_BoardConfig::allocation_error("PosControl"); AP_BoardConfig::allocation_error("PosControl");
} }

View File

@ -4,7 +4,6 @@ Mode::_TakeOff Mode::takeoff;
bool Mode::auto_takeoff_no_nav_active = false; bool Mode::auto_takeoff_no_nav_active = false;
float Mode::auto_takeoff_no_nav_alt_cm = 0; float Mode::auto_takeoff_no_nav_alt_cm = 0;
float Mode::auto_takeoff_start_alt_cm = 0;
float Mode::auto_takeoff_complete_alt_cm = 0; float Mode::auto_takeoff_complete_alt_cm = 0;
bool Mode::auto_takeoff_terrain_alt = false; bool Mode::auto_takeoff_terrain_alt = false;
bool Mode::auto_takeoff_complete = false; bool Mode::auto_takeoff_complete = false;
@ -125,6 +124,8 @@ void Mode::auto_takeoff_run()
if (!motors->armed() || !copter.ap.auto_armed) { if (!motors->armed() || !copter.ap.auto_armed) {
// do not spool down tradheli when on the ground with motor interlock enabled // do not spool down tradheli when on the ground with motor interlock enabled
make_safe_ground_handling(copter.is_tradheli() && motors->get_interlock()); make_safe_ground_handling(copter.is_tradheli() && motors->get_interlock());
// update auto_takeoff_no_nav_alt_cm
auto_takeoff_no_nav_alt_cm = inertial_nav.get_position_z_up_cm() + g2.wp_navalt_min * 100;
return; return;
} }
@ -159,6 +160,8 @@ void Mode::auto_takeoff_run()
attitude_control->reset_yaw_target_and_rate(); attitude_control->reset_yaw_target_and_rate();
attitude_control->reset_rate_controller_I_terms(); attitude_control->reset_rate_controller_I_terms();
attitude_control->input_thrust_vector_rate_heading(pos_control->get_thrust_vector(), 0.0); attitude_control->input_thrust_vector_rate_heading(pos_control->get_thrust_vector(), 0.0);
// update auto_takeoff_no_nav_alt_cm
auto_takeoff_no_nav_alt_cm = inertial_nav.get_position_z_up_cm() + g2.wp_navalt_min * 100;
return; return;
} }
@ -220,9 +223,13 @@ void Mode::auto_takeoff_run()
attitude_control->input_thrust_vector_heading(pos_control->get_thrust_vector(), auto_yaw.yaw(), auto_yaw.rate_cds()); attitude_control->input_thrust_vector_heading(pos_control->get_thrust_vector(), auto_yaw.yaw(), auto_yaw.rate_cds());
} }
// handle takeoff completion // takeoff complete when we are less than 1% of the stopping distance from the target altitude
bool reached_altitude = (copter.pos_control->get_pos_target_z_cm() - auto_takeoff_start_alt_cm) >= ((auto_takeoff_complete_alt_cm + terr_offset - auto_takeoff_start_alt_cm) * 0.90); // and 10% our maximum climb rate
bool reached_climb_rate = copter.pos_control->get_vel_desired_cms().z < copter.pos_control->get_max_speed_up_cms() * 0.1; const float vel_threshold_fraction = 0.1;
// stopping distance from vel_threshold_fraction * max velocity
const float stop_distance = 0.5 * sq(vel_threshold_fraction * copter.pos_control->get_max_speed_up_cms()) / copter.pos_control->get_max_accel_z_cmss();
bool reached_altitude = copter.pos_control->get_pos_target_z_cm() >= pos_z - stop_distance;
bool reached_climb_rate = copter.pos_control->get_vel_desired_cms().z < copter.pos_control->get_max_speed_up_cms() * vel_threshold_fraction;
auto_takeoff_complete = reached_altitude && reached_climb_rate; auto_takeoff_complete = reached_altitude && reached_climb_rate;
// calculate completion for location in case it is needed for a smooth transition to wp_nav // calculate completion for location in case it is needed for a smooth transition to wp_nav
@ -234,13 +241,14 @@ void Mode::auto_takeoff_run()
void Mode::auto_takeoff_start(float complete_alt_cm, bool terrain_alt) void Mode::auto_takeoff_start(float complete_alt_cm, bool terrain_alt)
{ {
auto_takeoff_start_alt_cm = inertial_nav.get_position_z_up_cm(); // auto_takeoff_complete_alt_cm is a problem if equal to auto_takeoff_start_alt_cm
auto_takeoff_complete_alt_cm = complete_alt_cm; auto_takeoff_complete_alt_cm = complete_alt_cm;
auto_takeoff_terrain_alt = terrain_alt; auto_takeoff_terrain_alt = terrain_alt;
auto_takeoff_complete = false; auto_takeoff_complete = false;
// initialise auto_takeoff_no_nav_alt_cm
auto_takeoff_no_nav_alt_cm = inertial_nav.get_position_z_up_cm() + g2.wp_navalt_min * 100;
if ((g2.wp_navalt_min > 0) && (is_disarmed_or_landed() || !motors->get_interlock())) { if ((g2.wp_navalt_min > 0) && (is_disarmed_or_landed() || !motors->get_interlock())) {
// we are not flying, climb with no navigation to current alt-above-ekf-origin + wp_navalt_min // we are not flying, climb with no navigation to current alt-above-ekf-origin + wp_navalt_min
auto_takeoff_no_nav_alt_cm = auto_takeoff_start_alt_cm + g2.wp_navalt_min * 100;
auto_takeoff_no_nav_active = true; auto_takeoff_no_nav_active = true;
} else { } else {
auto_takeoff_no_nav_active = false; auto_takeoff_no_nav_active = false;

View File

@ -6,14 +6,14 @@
#include "ap_version.h" #include "ap_version.h"
#define THISFIRMWARE "ArduCopter V4.3.0-dev" #define THISFIRMWARE "ArduCopter V4.3.8"
// the following line is parsed by the autotest scripts // the following line is parsed by the autotest scripts
#define FIRMWARE_VERSION 4,3,0,FIRMWARE_VERSION_TYPE_DEV #define FIRMWARE_VERSION 4,3,8,FIRMWARE_VERSION_TYPE_OFFICIAL
#define FW_MAJOR 4 #define FW_MAJOR 4
#define FW_MINOR 3 #define FW_MINOR 3
#define FW_PATCH 0 #define FW_PATCH 8
#define FW_TYPE FIRMWARE_VERSION_TYPE_DEV #define FW_TYPE FIRMWARE_VERSION_TYPE_OFFICIAL
#include <AP_Common/AP_FWVersionDefine.h> #include <AP_Common/AP_FWVersionDefine.h>

View File

@ -306,6 +306,18 @@ bool AP_Arming_Plane::arm(const AP_Arming::Method method, const bool do_arming_c
return false; return false;
} }
if (plane.update_home()) {
// after update_home the home position could still be
// different from the current_loc if the EKF refused the
// resetHeightDatum call. If we are updating home then we want
// to force the home to be the current_loc so relative alt
// takeoffs work correctly
if (plane.ahrs.set_home(plane.current_loc)) {
// update current_loc
plane.update_current_loc();
}
}
change_arm_state(); change_arm_state();
// rising edge of delay_arming oneshot // rising edge of delay_arming oneshot

View File

@ -23,6 +23,7 @@
#include "Plane.h" #include "Plane.h"
#define SCHED_TASK(func, rate_hz, max_time_micros, priority) SCHED_TASK_CLASS(Plane, &plane, func, rate_hz, max_time_micros, priority) #define SCHED_TASK(func, rate_hz, max_time_micros, priority) SCHED_TASK_CLASS(Plane, &plane, func, rate_hz, max_time_micros, priority)
#define FAST_TASK(func) FAST_TASK_CLASS(Plane, &plane, func)
/* /*
@ -49,16 +50,18 @@ SCHED_TASK_CLASS arguments:
- expected time (in MicroSeconds) that the method should take to run - expected time (in MicroSeconds) that the method should take to run
- priority (0 through 255, lower number meaning higher priority) - priority (0 through 255, lower number meaning higher priority)
FAST_TASK entries are run on every loop even if that means the loop
overruns its allotted time
*/ */
const AP_Scheduler::Task Plane::scheduler_tasks[] = { const AP_Scheduler::Task Plane::scheduler_tasks[] = {
// Units: Hz us // Units: Hz us
SCHED_TASK(ahrs_update, 400, 400, 3), FAST_TASK(ahrs_update),
FAST_TASK(update_control_mode),
FAST_TASK(stabilize),
FAST_TASK(set_servos),
SCHED_TASK(read_radio, 50, 100, 6), SCHED_TASK(read_radio, 50, 100, 6),
SCHED_TASK(check_short_failsafe, 50, 100, 9), SCHED_TASK(check_short_failsafe, 50, 100, 9),
SCHED_TASK(update_speed_height, 50, 200, 12), SCHED_TASK(update_speed_height, 50, 200, 12),
SCHED_TASK(update_control_mode, 400, 100, 15),
SCHED_TASK(stabilize, 400, 100, 18),
SCHED_TASK(set_servos, 400, 100, 21),
SCHED_TASK(update_throttle_hover, 100, 90, 24), SCHED_TASK(update_throttle_hover, 100, 90, 24),
SCHED_TASK(read_control_switch, 7, 100, 27), SCHED_TASK(read_control_switch, 7, 100, 27),
SCHED_TASK(update_GPS_50Hz, 50, 300, 30), SCHED_TASK(update_GPS_50Hz, 50, 300, 30),
@ -403,10 +406,7 @@ void Plane::update_GPS_50Hz(void)
{ {
gps.update(); gps.update();
// get position from AHRS update_current_loc();
have_position = ahrs.get_location(current_loc);
ahrs.get_relative_position_D_home(relative_altitude);
relative_altitude *= -1.0f;
} }
/* /*
@ -547,16 +547,16 @@ void Plane::update_alt()
distance_beyond_land_wp = current_loc.get_distance(next_WP_loc); distance_beyond_land_wp = current_loc.get_distance(next_WP_loc);
} }
float target_alt = relative_target_altitude_cm(); tecs_target_alt_cm = relative_target_altitude_cm();
if (control_mode == &mode_rtl && !rtl.done_climb && (g2.rtl_climb_min > 0 || (plane.g2.flight_options & FlightOptions::CLIMB_BEFORE_TURN))) { if (control_mode == &mode_rtl && !rtl.done_climb && (g2.rtl_climb_min > 0 || (plane.g2.flight_options & FlightOptions::CLIMB_BEFORE_TURN))) {
// ensure we do the initial climb in RTL. We add an extra // ensure we do the initial climb in RTL. We add an extra
// 10m in the demanded height to push TECS to climb // 10m in the demanded height to push TECS to climb
// quickly // quickly
target_alt = MAX(target_alt, prev_WP_loc.alt - home.alt) + (g2.rtl_climb_min+10)*100; tecs_target_alt_cm = MAX(tecs_target_alt_cm, prev_WP_loc.alt - home.alt) + (g2.rtl_climb_min+10)*100;
} }
TECS_controller.update_pitch_throttle(target_alt, TECS_controller.update_pitch_throttle(tecs_target_alt_cm,
target_airspeed_cm, target_airspeed_cm,
flight_stage, flight_stage,
distance_beyond_land_wp, distance_beyond_land_wp,
@ -796,26 +796,33 @@ bool Plane::set_velocity_match(const Vector2f &velocity)
#endif // AP_SCRIPTING_ENABLED #endif // AP_SCRIPTING_ENABLED
#if OSD_ENABLED
// correct AHRS pitch for TRIM_PITCH_CD in non-VTOL modes, and return VTOL view in VTOL // correct AHRS pitch for TRIM_PITCH_CD in non-VTOL modes, and return VTOL view in VTOL
void Plane::get_osd_roll_pitch_rad(float &roll, float &pitch) const void Plane::get_osd_roll_pitch_rad(float &roll, float &pitch) const
{ {
pitch = ahrs.pitch;
roll = ahrs.roll;
#if HAL_QUADPLANE_ENABLED #if HAL_QUADPLANE_ENABLED
if (quadplane.show_vtol_view()) { if (quadplane.show_vtol_view()) {
return; pitch = quadplane.ahrs_view->pitch;
} roll = quadplane.ahrs_view->roll;
#endif return;
if (!(g2.flight_options & FlightOptions::OSD_REMOVE_TRIM_PITCH_CD)) { // correct for TRIM_PITCH_CD }
pitch -= g.pitch_trim_cd * 0.01 * DEG_TO_RAD;
return;
}
#if HAL_QUADPLANE_ENABLED
pitch = quadplane.ahrs_view->pitch;
roll = quadplane.ahrs_view->roll;
#endif #endif
pitch = ahrs.pitch;
roll = ahrs.roll;
if (!(g2.flight_options & FlightOptions::OSD_REMOVE_TRIM_PITCH_CD)) { // correct for TRIM_PITCH_CD
pitch -= g.pitch_trim_cd * 0.01 * DEG_TO_RAD;
}
}
/*
update current_loc Location
*/
void Plane::update_current_loc(void)
{
have_position = plane.ahrs.get_location(plane.current_loc);
// re-calculate relative altitude
ahrs.get_relative_position_D_home(plane.relative_altitude);
relative_altitude *= -1.0f;
} }
#endif
AP_HAL_MAIN_CALLBACKS(&plane); AP_HAL_MAIN_CALLBACKS(&plane);

View File

@ -607,6 +607,7 @@ void Plane::calc_nav_yaw_coordinated(float speed_scaler)
int16_t rudder_in = rudder_input(); int16_t rudder_in = rudder_input();
int16_t commanded_rudder; int16_t commanded_rudder;
bool using_rate_controller = false;
// Received an external msg that guides yaw in the last 3 seconds? // Received an external msg that guides yaw in the last 3 seconds?
if (control_mode->is_guided_mode() && if (control_mode->is_guided_mode() &&
@ -617,7 +618,10 @@ void Plane::calc_nav_yaw_coordinated(float speed_scaler)
// user is doing an AUTOTUNE with yaw rate control // user is doing an AUTOTUNE with yaw rate control
const float rudd_expo = rudder_in_expo(true); const float rudd_expo = rudder_in_expo(true);
const float yaw_rate = (rudd_expo/SERVO_MAX) * g.acro_yaw_rate; const float yaw_rate = (rudd_expo/SERVO_MAX) * g.acro_yaw_rate;
commanded_rudder = yawController.get_rate_out(yaw_rate, speed_scaler, false); // add in the corrdinated turn yaw rate to make it easier to fly while tuning the yaw rate controller
const float coordination_yaw_rate = degrees(GRAVITY_MSS * tanf(radians(nav_roll_cd*0.01f))/MAX(aparm.airspeed_min,smoothed_airspeed));
commanded_rudder = yawController.get_rate_out(yaw_rate+coordination_yaw_rate, speed_scaler, false);
using_rate_controller = true;
} else { } else {
if (control_mode == &mode_stabilize && rudder_in != 0) { if (control_mode == &mode_stabilize && rudder_in != 0) {
disable_integrator = true; disable_integrator = true;
@ -631,6 +635,13 @@ void Plane::calc_nav_yaw_coordinated(float speed_scaler)
} }
steering_control.rudder = constrain_int16(commanded_rudder, -4500, 4500); steering_control.rudder = constrain_int16(commanded_rudder, -4500, 4500);
if (!using_rate_controller) {
/*
When not running the yaw rate controller, we need to reset the rate
*/
yawController.reset_rate_PID();
}
} }
/* /*
@ -749,8 +760,7 @@ void Plane::calc_nav_roll()
float bank_limit = degrees(atanf(guided_state.target_heading_accel_limit/GRAVITY_MSS)) * 1e2f; float bank_limit = degrees(atanf(guided_state.target_heading_accel_limit/GRAVITY_MSS)) * 1e2f;
g2.guidedHeading.update_error(error); // push error into AC_PID , possible improvement is to use update_all instead.? g2.guidedHeading.update_error(error, delta); // push error into AC_PID , possible improvement is to use update_all instead.?
g2.guidedHeading.set_dt(delta);
float i = g2.guidedHeading.get_i(); // get integrator TODO float i = g2.guidedHeading.get_i(); // get integrator TODO
if (((is_negative(error) && !guided_state.target_heading_limit_low) || (is_positive(error) && !guided_state.target_heading_limit_high))) { if (((is_negative(error) && !guided_state.target_heading_limit_low) || (is_positive(error) && !guided_state.target_heading_limit_high))) {

View File

@ -1,6 +1,9 @@
#include "GCS_Mavlink.h" #include "GCS_Mavlink.h"
#include "Plane.h" #include "Plane.h"
#include <AP_RPM/AP_RPM_config.h>
#include <AP_Airspeed/AP_Airspeed_config.h>
#include <AP_EFI/AP_EFI_config.h>
MAV_TYPE GCS_Plane::frame_type() const MAV_TYPE GCS_Plane::frame_type() const
{ {
@ -416,12 +419,58 @@ bool GCS_MAVLINK_Plane::try_send_message(enum ap_message id)
case MSG_LANDING: case MSG_LANDING:
plane.landing.send_landing_message(chan); plane.landing.send_landing_message(chan);
break; break;
case MSG_HYGROMETER:
#if AP_AIRSPEED_HYGROMETER_ENABLE
CHECK_PAYLOAD_SIZE(HYGROMETER_SENSOR);
send_hygrometer();
#endif
break;
default: default:
return GCS_MAVLINK::try_send_message(id); return GCS_MAVLINK::try_send_message(id);
} }
return true; return true;
} }
#if AP_AIRSPEED_HYGROMETER_ENABLE
void GCS_MAVLINK_Plane::send_hygrometer()
{
if (!HAVE_PAYLOAD_SPACE(chan, HYGROMETER_SENSOR)) {
return;
}
const auto *airspeed = AP::airspeed();
if (airspeed == nullptr) {
return;
}
const uint32_t now = AP_HAL::millis();
for (uint8_t i=0; i<AIRSPEED_MAX_SENSORS; i++) {
uint8_t idx = (i+last_hygrometer_send_idx+1) % AIRSPEED_MAX_SENSORS;
float temperature, humidity;
uint32_t last_sample_ms;
if (!airspeed->get_hygrometer(idx, last_sample_ms, temperature, humidity)) {
continue;
}
if (now - last_sample_ms > 2000) {
// not updating, stop sending
continue;
}
if (!HAVE_PAYLOAD_SPACE(chan, HYGROMETER_SENSOR)) {
return;
}
mavlink_msg_hygrometer_sensor_send(
chan,
idx,
int16_t(temperature*100),
uint16_t(humidity*100));
last_hygrometer_send_idx = idx;
}
}
#endif // AP_AIRSPEED_HYGROMETER_ENABLE
/* /*
default stream rates to 1Hz default stream rates to 1Hz
@ -567,12 +616,19 @@ static const ap_message STREAM_EXTRA1_msgs[] = {
MSG_ATTITUDE, MSG_ATTITUDE,
MSG_SIMSTATE, MSG_SIMSTATE,
MSG_AHRS2, MSG_AHRS2,
#if AP_RPM_ENABLED
MSG_RPM, MSG_RPM,
#endif
MSG_AOA_SSA, MSG_AOA_SSA,
MSG_PID_TUNING, MSG_PID_TUNING,
MSG_LANDING, MSG_LANDING,
MSG_ESC_TELEMETRY, MSG_ESC_TELEMETRY,
#if HAL_EFI_ENABLED
MSG_EFI_STATUS, MSG_EFI_STATUS,
#endif
#if AP_AIRSPEED_HYGROMETER_ENABLE
MSG_HYGROMETER,
#endif
}; };
static const ap_message STREAM_EXTRA2_msgs[] = { static const ap_message STREAM_EXTRA2_msgs[] = {
MSG_VFR_HUD MSG_VFR_HUD

View File

@ -2,6 +2,7 @@
#include <GCS_MAVLink/GCS.h> #include <GCS_MAVLink/GCS.h>
#include <AP_Logger/AP_Logger.h> #include <AP_Logger/AP_Logger.h>
#include <AP_Airspeed/AP_Airspeed_config.h>
class GCS_MAVLINK_Plane : public GCS_MAVLINK class GCS_MAVLINK_Plane : public GCS_MAVLINK
{ {
@ -71,6 +72,11 @@ private:
uint8_t high_latency_wind_direction() const override; uint8_t high_latency_wind_direction() const override;
#endif // HAL_HIGH_LATENCY2_ENABLED #endif // HAL_HIGH_LATENCY2_ENABLED
#if AP_AIRSPEED_HYGROMETER_ENABLE
void send_hygrometer();
uint8_t last_hygrometer_send_idx;
#endif
MAV_VTOL_STATE vtol_state() const override; MAV_VTOL_STATE vtol_state() const override;
MAV_LANDED_STATE landed_state() const override; MAV_LANDED_STATE landed_state() const override;

View File

@ -147,7 +147,8 @@ struct PACKED log_Nav_Tuning {
float airspeed_error; float airspeed_error;
int32_t target_lat; int32_t target_lat;
int32_t target_lng; int32_t target_lng;
int32_t target_alt; int32_t target_alt_wp;
int32_t target_alt_tecs;
int32_t target_airspeed; int32_t target_airspeed;
}; };
@ -166,7 +167,8 @@ void Plane::Log_Write_Nav_Tuning()
airspeed_error : airspeed_error, airspeed_error : airspeed_error,
target_lat : next_WP_loc.lat, target_lat : next_WP_loc.lat,
target_lng : next_WP_loc.lng, target_lng : next_WP_loc.lng,
target_alt : next_WP_loc.alt, target_alt_wp : next_WP_loc.alt,
target_alt_tecs : tecs_target_alt_cm,
target_airspeed : target_airspeed_cm, target_airspeed : target_airspeed_cm,
}; };
logger.WriteBlock(&pkt, sizeof(pkt)); logger.WriteBlock(&pkt, sizeof(pkt));
@ -306,16 +308,17 @@ const struct LogStructure Plane::log_structure[] = {
// @Field: Dist: distance to the current navigation waypoint // @Field: Dist: distance to the current navigation waypoint
// @Field: TBrg: bearing to the current navigation waypoint // @Field: TBrg: bearing to the current navigation waypoint
// @Field: NavBrg: the vehicle's desired heading // @Field: NavBrg: the vehicle's desired heading
// @Field: AltErr: difference between current vehicle height and target height // @Field: AltE: difference between current vehicle height and target height
// @Field: XT: the vehicle's current distance from the current travel segment // @Field: XT: the vehicle's current distance from the current travel segment
// @Field: XTi: integration of the vehicle's crosstrack error // @Field: XTi: integration of the vehicle's crosstrack error
// @Field: AspdE: difference between vehicle's airspeed and desired airspeed // @Field: AsE: difference between vehicle's airspeed and desired airspeed
// @Field: TLat: target latitude // @Field: TLat: target latitude
// @Field: TLng: target longitude // @Field: TLng: target longitude
// @Field: TAlt: target altitude // @Field: TAW: target altitude WP
// @Field: TAspd: target airspeed // @Field: TAT: target altitude TECS
// @Field: TAsp: target airspeed
{ LOG_NTUN_MSG, sizeof(log_Nav_Tuning), { LOG_NTUN_MSG, sizeof(log_Nav_Tuning),
"NTUN", "QfcccfffLLii", "TimeUS,Dist,TBrg,NavBrg,AltErr,XT,XTi,AspdE,TLat,TLng,TAlt,TAspd", "smddmmmnDUmn", "F0BBB0B0GGBB" , true }, "NTUN", "QfcccfffLLeee", "TimeUS,Dist,TBrg,NavBrg,AltE,XT,XTi,AsE,TLat,TLng,TAW,TAT,TAsp", "smddmmmnDUmmn", "F0BBB0B0GG000" , true },
// @LoggerMessage: ATRP // @LoggerMessage: ATRP
// @Description: Plane AutoTune // @Description: Plane AutoTune

View File

@ -946,7 +946,13 @@ private:
// commands.cpp // commands.cpp
void set_guided_WP(const Location &loc); void set_guided_WP(const Location &loc);
void update_home();
// update home position. Return true if update done
bool update_home();
// update current_loc
void update_current_loc(void);
// set home location and store it persistently: // set home location and store it persistently:
bool set_home_persistently(const Location &loc) WARN_IF_UNUSED; bool set_home_persistently(const Location &loc) WARN_IF_UNUSED;
@ -984,9 +990,7 @@ private:
// ArduPlane.cpp // ArduPlane.cpp
void disarm_if_autoland_complete(); void disarm_if_autoland_complete();
# if OSD_ENABLED
void get_osd_roll_pitch_rad(float &roll, float &pitch) const override; void get_osd_roll_pitch_rad(float &roll, float &pitch) const override;
#endif
float tecs_hgt_afe(void); float tecs_hgt_afe(void);
void efi_update(void); void efi_update(void);
void get_scheduler_tasks(const AP_Scheduler::Task *&tasks, void get_scheduler_tasks(const AP_Scheduler::Task *&tasks,
@ -1206,6 +1210,9 @@ private:
// mode reason for entering previous mode // mode reason for entering previous mode
ModeReason previous_mode_reason = ModeReason::UNKNOWN; ModeReason previous_mode_reason = ModeReason::UNKNOWN;
// last target alt we passed to tecs
int32_t tecs_target_alt_cm;
public: public:
void failsafe_check(void); void failsafe_check(void);
#if AP_SCRIPTING_ENABLED #if AP_SCRIPTING_ENABLED

View File

@ -309,6 +309,7 @@ bool RC_Channel_Plane::do_aux_function(const aux_func_t ch_option, const AuxSwit
switch (ch_flag) { switch (ch_flag) {
case AuxSwitchPos::HIGH: case AuxSwitchPos::HIGH:
plane.quadplane.air_mode = AirMode::ON; plane.quadplane.air_mode = AirMode::ON;
plane.quadplane.throttle_wait = false;
break; break;
case AuxSwitchPos::MIDDLE: case AuxSwitchPos::MIDDLE:
break; break;
@ -359,6 +360,7 @@ bool RC_Channel_Plane::do_aux_function(const aux_func_t ch_option, const AuxSwit
RC_Channel::do_aux_function_armdisarm(ch_flag); RC_Channel::do_aux_function_armdisarm(ch_flag);
if (plane.arming.is_armed()) { if (plane.arming.is_armed()) {
plane.quadplane.air_mode = AirMode::ON; plane.quadplane.air_mode = AirMode::ON;
plane.quadplane.throttle_wait = false;
} }
break; break;

View File

@ -1,3 +1,383 @@
Release 4.3.8-beta1 12th August 2023
------------------------------------
Changes since 4.3.7:
- fixed scripting restart bug which could cause a crash on a math error
- fixed RTK injection when first module is a moving baseline BASE
- fixed auto-enable of fence on forced arm
- fixed race condition that can cause gyro glitches with notch filtering
- fixed INAxxx battery monitors to allow for battery reset remaining
Release 4.3.7 31st May 2023
---------------------------
This stable release is for the 4.3.x stable series and is being done
because of a serious bug that has been found with RC input on boards
that use an IOMCU for RC input (boards with a separate set of 8 "main"
outputs from "aux" outputs).
The bug was that when RC input is lost and the receiver is one that
uses "no pulses" for loss of RC input then there is a chance that when
the RC link is regained that ArduPilot will not regain RC control and
will continue in RC failsafe.
The bug is an old one, first introduced in the 4.0.6 release in
September 2020. The bug does not occur often which is why it has been
such a long time before it was noticed. We would like to thank CUAV
for noticing and reporting the bug!
This release also has some other changes, some of which are to sync
with the Copter 4.3.6 release (which will go to 4.3.7 with this RC
input bug fix) and some are other bugs found since the 4.3.5 plane
release.
This release skips the 4.3.6 number to sync with copter.
The full list of changes is:
- fixed a fault in the INS batch sampler code if you change the INS_LOG_BAT_CNT parameter without rebooting
- fixed the RC input on IOMCU bug explained above
- fixed a bug in ICE engine control if you do a "delay engine start" mission command while flying
- added MCU voltage monitoring for the H757 microcontroller (eg. CubeOrangePlus)
- servo gimbal mount yaw handling fix (only affects 3-axis servo gimbals)
- PiccoloCAN fix for ESC voltage and current scaling
- Gremsy gimbal fix when attached to autopilot's serial3 (or higher)
- added CubeOrangePlus-bdshot build
- fixed a bug in handling bad UART data in the megasquirt serial EFI driver
- added -g option for configuring with debug symbols without full debug (helped with RCIN bug diagnosis)
- fixed airmode switch for QACRO and QSTABILIZE modes
- fixed a rare memory corruption bug in the STM32H757
- fixed an EKF3 bug in accel bias calculations
- adjust EKF3 accel bias process noise for greater robustness
- cope with compassmot impacting GSF yaw numerical stability
Please test and report any issues!
Release 4.3.5 26th March 2023
------------------------------
- fixed 32 bit microsecond wrap in BDShot code
This release has a single bug fix for a critical bug for anyone using
bi-directional DShot on their vehicle. If using bi-directional DShot
and the vehicle is running its motors when 32 bit microsecond time
wraps at 71 minutes (or multiples of 71 minutes) then the bug that is
fixed in this release has an approximately 1 in 3 chance of causing
the motor to stop.
Note that the time is the time since boot, not the time since arming,
so even vehicles flying for a short time could be vulnerable if they
sit for a long time on the ground before takeoff.
Release 4.3.4 1st March 2023
-----------------------------
- support CubeOrangePlus BG edition
- enable VTX power on MambaH743v4
- probe external compasses on Foxeer Reaper F745
- fixed home update on bad GPS quality
- fixed GPS unconfigured error for non-M10 uBlox GPS
- don't allow RC protocol change on IOMCU once detected
- fixed FBWA pitch limits when in VTOL qassist
- fixed handling of zero compass diagonals
- added an output buffer to MAVCAN
- set emergency status in OpenDroneID on crash or chute deploy
- avoid logging duplicate format messages
- fixed bug in alt error arming check with BARO_FIELD_ELEV set
- fixed handling of double IOMCU reset and safety disable
- enable VTX power on MambaF405 2022
- disable PWMSource feature in lua scripts (will be back in 4.4.x)
- fixed throttle wait on rudder arming in quadplanes
- fixed earth frame accel compensation for AHRS_TRIM
Happy flying!
Release 4.3.3 Jan 19th 2023
---------------------------
- AIRLink LTE module enable pin added
- CUAV Nora/Nora+ bdshot firmware (allows Bi-directional DShot)
- CubeOrange, CubeYellow gets fast reset of ICM20602
- PixPilot-V6 support
- Attitude and Navigation controllers use real-time dt (better handles variable or slow main loop)
- Analog rangefinder GPIO pin arming check fixed
- Arming check of AHRS/EKF vs GPS location disabled if GPS disabled
- Position Controller limit handling improved to avoid overshooting and hard landings
- PSC_ANGLE_MAX param reduction causing WPNAV_ACCEL to be set too low fixed
- Servo gimbal yaw jump to opposite side fixed
- Siyi A8 gimbal driver's record video feature fixed
- SToRM32 serial gimbal driver actual angle reporting fixed (pitch and yaw angle signs were reversed)
- Takeoff in Auto, Guided fixed when target altitude is current altitude
- Takeoff in Auto handles baro drift before takeoff
- Takeoff twitch due to velocity integrator init bug fixed
- moved FTP MAVLink transfers to FTP thread and better control bandwidth
- switch to QRTL if indide RTL radius when using Q_RTL_MODE=3 (approach)
- check for 3 good frames for CRSF
- allow for ELRS at 420kbaud
- support MambaH743-v2
- support MambaF405-2022B
- fixed nullptr checks on new
- fixed a bug in terrain handling for ship landing lua script checks on new
Happy flying!
Release 4.3.2 Dec 23rd 2022
---------------------------
This is a minor release with bug fixes for the 4.3.x release series.
Changes from 4.3.1:
- improved uBlox M10 support
- CubeOrange defaults to using 2nd IMU as primary
- SIRF and SBP GPS disabled on BeastF7v2, MatekF405-STD, MAtekF405-Wing, omnibusf4pro
- fixed loading of autotune gains during pilot testing
- Fixed CAM_MIN_INTERVAL to cope with mission and pilot triggering
- EKF3 fix when using EK3_RNG_USE_HGT/SPD params and rangefinder provides bad readings
- Main loop slowdown after arming fixed (parameter logging was causing delays)
- changed to 'fast task' scheme for critical loop updates
- MAVLink commands received on private channels checked for valid target sysid
- ModalAI camera support fixed (ODOMETRY message frame was consumed incorrectly)
- Param reset after firmware load fixed on several boards
- Siyi A8 gimbal support fixed
- Windows builds move to compiling only 64-bit executables
- ARKV6X support
- MatekH743 supports 8 bi-directional dshot channels
- Pixhawk1 boards support MS5607 baros
- SpeedbyBee F405v3 support
- DroneCAN Airspeed sensor support including hygrometer readings
- Pre-arm warning if multiple UARTs with SERIALx_PROTOCOL = RCIN
- Siyi gimbal support
- Arm check warning loses duplicate "AHRS" prefix
- AtomRCF405NAVI bootloader file name fixed
- BRD_SAFETY_MASK fixed on boards with both FMU safety switch and IOMCU
- Compass calibration continues even if a single compass's cal fails
- Gremsy gimbal driver sends autopilot info at lower rate to save bandwidth
- Invensense 42605 and 42609 IMUs use anti-aliasing filter and notch filter
- OSD stats screen fix
- RC input on serial port uses first UART with SERIALx_PROTOCOL = 23 (was using last)
- RunCam caching fix with enablement and setup on 3-pos switch
- RTK CAN GPS fix when GPSs conneted to separate CAN ports on autopilot
- fixed yaw rate for fixed wing autotune
Release 4.3.1 24th Oct 2022
---------------------------
This is a minor release with some important fixes:
- fixed build with gcc 11.3
- fixed random number generator in lua core
- scale VTOL angle P with airspeed in quadplane back-transiton
- added support for implementing AUX functions in lua scripts
- fixed BMI085 accel scaling
- fixed KSXT NMEA parsing affecting position resolution
- fixed race condition in TECS control leading to 'nod' in forward transiton
- allow for expansion of notch filters to fix notch of fwd motors in quadplanes
- added logging of TECS target alt
- fixed EKF3 altitude discrepancy with GPS or baro alt change on startup
- allow auto mode sequencing to land in a fence breach
Happy flying!
Release 4.3.0 9th Oct 2022
--------------------------
The is the first 4.3.x stable release for plane. It is a major release
with a lot of changes since 4.2.3.
Changes since 4.3.0beta3:
- added 1M and 2M flash warning checks for for fmuv2, fmuv3 and Pixhawk1-1M firmwares
- added support for multi-byte i2c reads in scripting
The change list from 4.2.3 stable is very long. Here are the main changes:
- fixed BRD_SAFETY_MASK for enabling outputs when safety on
- fixed persistence of mapping of CAN airspeed sensors to instances
- fixed precision of NMEA serial output function
- added report of "Engine Running" when using ICE
- fixed handling of defaults.parm files with lines over 100 chars
- fixed handling of defaults.parm files with no newline on last line
- fixed possible divide by zero when changing to GUIDED on quadplanes
- fixes for VideoTX, fixing buffer overrun and tramp handling
- fixed spurious error about sending RPM when RPM disabled
- fixed an EKF3 lane switch issue that can cause incorrect height with dual GPS
- fixed mission cmd to mission int initialisation error
- fixed mission jump tracking init on startup
- fixed OSD view roll/pitch error for tailsitters
- added SkystarsH7HD-bdshot
- fixed SkystarsH7HD VTX control
- reduced memory usage on MatekF405-CAN board
- disable SLCAN when armed to reduce CPU load
- enable CAN battery mon on CUAV V6X by default
- added arming check for Q_M_SPIN_MIN value too high
- fixed reporting of RPM from harmonic notch
- improved handling of airspeed errors and airspeed auto disable
- fixed SERVO_AUTO_TRIM for multiple outputs of same type
- fixed auto baud rate detection on SBF/GSOF/NOVA GPS
- increased max board name length for mavlink statustext to 23
- fixed incorrect disable of notches for non-throttle notch
- added notch filter slew limit to reduce notch errors
- added ARMING_OPTIONS to control display of pre-arm errors
- several OSD fixes for params, font and resolution
- support PWM type transmission for CAN PWM output
- support Currawong ECU as EFI backend
- support lua scripts for EFI backends
- implement SkyPower and HFE CAN EFI lua scripts
- improved speed of log download with dataflash block backends
- disabled all GPS drivers except uBlox and NMEA on Pixhawk1-1M to save flash
- disabled all GPS drivers except uBlox on MatekF405-bdshot and omnibusf4pro-bdshot
- fixed FFT indexing bug
- added USART2 for AIRLink
- allow reset to default airspeed using mission item DO_CHANGE_SPEED
- added new boards AtomRCF405, KakuteH7Mini-Nand, SkystarsH7HD
- added bi-directional dshot for several new boards
- EK3_GPS_VACC_MAX threshold to control when GPS altitude is used as alt source
- EKF ring buffer fix for slow sensor updates
- EKF3 source set change captured in replay logs
- numerous gimbal support improvements
- improved RemoteId support
- SecureBoot support with remote update of secure boot public keys
- crash_dump.bin file saved to SD Card on startup (includes details re cause of software failures)
- several new pre-arm checks (AHRS type, scripts, terrain)
- numerous scripting improvements
- fixed scripting restart leaking memory
- Benewake H30 radar support
- BMI270 IMU performance improvements
- Logging pause with auxiliary switch
- TeraRanger Neo rangefinder support
- support for both AMSL and ellipsoid height in most GPS drivers
- Custom controller support
- parameter defaults sent with param FTP and onboard logs
- Sim on Hardware allows simulator to run on autopilot
- added Q_LAND_ALTCHG parameter
- added climb before QRTL for safer QRTL from low altitudes
- added support for logging pre and post filtered FFT data
- support triple-notch harmonic notch filter
- support up to 32 actuators (with SERVO_32_ENABLE parameter)
- support EFI input over DroneCAN
- by default only run notch filter on first IMU
- added ESC_TLM_MAV_OFS parameter for mapping ESCs to MAVLink ESC telemetry
- added Q_NAVALT_MIN for quadplane takeoff
- added ICE redline governor
- added in-flight FFT notch tuning option
- added Sagetech ADSB support
- added INS_HNTCH_FM_RAT parameter for handling under-hover throttle
- improvements to filtering on ICM42xxx IMUs
- added option parameters to NAV_VTOL_LAND mission item for fixed wing approach
Many thanks to the huge number of developers, testers and documenters
who contributed to the 4.3.0 release!
Special thanks to all the ArduPilot Parters who have worked closely
with us on the 4.3.x development and testing, with many partners
contributing suggestions or supporting particular features.
Release 4.3.0beta3 7th Oct 2022
-------------------------------
This is the third beta of the 4.3.0 stable release. Changes since
beta1 are:
- fixed BRD_SAFETY_MASK for enabling outputs when safety on
- fixed persistence of mapping of CAN airspeed sensors to instances
- fixed precision of NMEA serial output function
- added report of "Engine Running" when using ICE
- fixed handling of defaults.parm files with lines over 100 chars
- fixed handling of defaults.parm files with no newline on last line
- fixed possible divide by zero when changing to GUIDED on quadplanes
Happy flying!
Release 4.3.0beta2 3rd Oct 2022
-------------------------------
This is the second beta of the 4.3.0 stable release. Changes since
beta1 are:
- fixes for VideoTX, fixing buffer overrun and tramp handling
- fixed spurious error about sending RPM when RPM disabled
- fixed an EKF3 lane switch issue that can cause incorrect height with dual GPS
- fixed mission cmd to mission int initialisation error
- fixed mission jump tracking init on startup
- fixed OSD view roll/pitch error for tailsitters
- added SkystarsH7HD-bdshot
- fixed SkystarsH7HD VTX control
- reduced memory usage on MatekF405-CAN board
- disable SLCAN when armed to reduce CPU load
- enable CAN battery mon on CUAV V6X by default
- added arming check for Q_M_SPIN_MIN value too high
- fixed reporting of RPM from harmonic notch
- improved handling of airspeed errors and airspeed auto disable
- fixed SERVO_AUTO_TRIM for multiple outputs of same type
- fixed auto baud rate detection on SBF/GSOF/NOVA GPS
- increased max board name length for mavlink statustext to 23
- fixed incorrect disable of notches for non-throttle notch
- added notch filter slew limit to reduce notch errors
- added ARMING_OPTIONS to control display of pre-arm errors
- several OSD fixes for params, font and resolution
- support PWM type transmission for CAN PWM output
- support Currawong ECU as EFI backend
- support lua scripts for EFI backends
- implement SkyPower and HFE CAN EFI lua scripts
- improved speed of log download with dataflash block backends
- disabled all GPS drivers except uBlox and NMEA on Pixhawk1-1M to save flash
- disabled all GPS drivers except uBlox on MatekF405-bdshot and omnibusf4pro-bdshot
- fixed FFT indexing bug
- added USART2 for AIRLink
- allow reset to default airspeed using mission item DO_CHANGE_SPEED
Happy flying!
Release 4.3.0beta1 13th Sep 2022
--------------------------------
This is the first beta of the 4.3.0 stable release. There are a lot of
changes since the 4.2.3 stable release. Key changes are:
- added new boards AtomRCF405, KakuteH7Mini-Nand, SkystarsH7HD
- added bi-directional dshot for several new boards
- EK3_GPS_VACC_MAX threshold to control when GPS altitude is used as alt source
- EKF ring buffer fix for slow sensor updates
- EKF3 source set change captured in replay logs
- numerous gimbal support improvements
- improved RemoteId support
- SecureBoot support with remote update of secure boot public keys
- crash_dump.bin file saved to SD Card on startup (includes details re cause of software failures)
- several new pre-arm checks (AHRS type, scripts, terrain)
- numerous scripting improvements
- fixed scripting restart leaking memory
- Benewake H30 radar support
- BMI270 IMU performance improvements
- Logging pause with auxiliary switch
- TeraRanger Neo rangefinder support
- support for both AMSL and ellipsoid height in most GPS drivers
- Custom controller support
- parameter defaults sent with param FTP and onboard logs
- Sim on Hardware allows simulator to run on autopilot
- added Q_LAND_ALTCHG parameter
- added climb before QRTL for safer QRTL from low altitudes
- added support for logging pre and post filtered FFT data
- support triple-notch harmonic notch filter
- support up to 32 actuators (with SERVO_32_ENABLE parameter)
- support EFI input over DroneCAN
- by default only run notch filter on first IMU
- added ESC_TLM_MAV_OFS parameter for mapping ESCs to MAVLink ESC telemetry
- added Q_NAVALT_MIN for quadplane takeoff
- added ICE redline governor
- added in-flight FFT notch tuning option
- added Sagetech ADSB support
- added INS_HNTCH_FM_RAT parameter for handling under-hover throttle
- improvements to filtering on ICM42xxx IMUs
- added option parameters to NAV_VTOL_LAND mission item for fixed wing approach
Please report flight tests of the 4.3.0beta series on discuss.ardupilot.org
Happy flying!
Release 4.2.3 21st August 2022 Release 4.2.3 21st August 2022
------------------------------ ------------------------------

View File

@ -105,11 +105,13 @@ void Plane::set_guided_WP(const Location &loc)
update home location from GPS update home location from GPS
this is called as long as we have 3D lock and the arming switch is this is called as long as we have 3D lock and the arming switch is
not pushed not pushed
returns true if home is changed
*/ */
void Plane::update_home() bool Plane::update_home()
{ {
if (hal.util->was_watchdog_armed()) { if (hal.util->was_watchdog_armed()) {
return; return false;
} }
if ((g2.home_reset_threshold == -1) || if ((g2.home_reset_threshold == -1) ||
((g2.home_reset_threshold > 0) && ((g2.home_reset_threshold > 0) &&
@ -118,24 +120,30 @@ void Plane::update_home()
// significantly. This allows us to cope with slow baro drift // significantly. This allows us to cope with slow baro drift
// but not re-do home and the baro if we have changed height // but not re-do home and the baro if we have changed height
// significantly // significantly
return; return false;
} }
if (ahrs.home_is_set() && !ahrs.home_is_locked()) { bool ret = false;
if (ahrs.home_is_set() && !ahrs.home_is_locked() && gps.status() >= AP_GPS::GPS_OK_FIX_3D) {
Location loc; Location loc;
if(ahrs.get_location(loc) && gps.status() >= AP_GPS::GPS_OK_FIX_3D) { if (ahrs.get_location(loc)) {
// we take the altitude directly from the GPS as we are // we take the altitude directly from the GPS as we are
// about to reset the baro calibration. We can't use AHRS // about to reset the baro calibration. We can't use AHRS
// altitude or we can end up perpetuating a bias in // altitude or we can end up perpetuating a bias in
// altitude, as AHRS alt depends on home alt, which means // altitude, as AHRS alt depends on home alt, which means
// we would have a circular dependency // we would have a circular dependency
loc.alt = gps.location().alt; loc.alt = gps.location().alt;
if (!AP::ahrs().set_home(loc)) { ret = AP::ahrs().set_home(loc);
// silently fail
}
} }
} }
// even if home is not updated we do a baro reset to stop baro
// drift errors while disarmed
barometer.update_calibration(); barometer.update_calibration();
ahrs.resetHeightDatum(); ahrs.resetHeightDatum();
update_current_loc();
return ret;
} }
bool Plane::set_home_persistently(const Location &loc) bool Plane::set_home_persistently(const Location &loc)

View File

@ -937,8 +937,12 @@ bool Plane::do_change_speed(const AP_Mission::Mission_Command& cmd)
switch (cmd.content.speed.speed_type) switch (cmd.content.speed.speed_type)
{ {
case 0: // Airspeed case 0: // Airspeed
if ((cmd.content.speed.target_ms >= aparm.airspeed_min.get()) && (cmd.content.speed.target_ms <= aparm.airspeed_max.get())) { if (is_equal(cmd.content.speed.target_ms, -2.0f)) {
new_airspeed_cm = cmd.content.speed.target_ms * 100; //new airspeed target for AUTO or GUIDED modes new_airspeed_cm = -1; // return to default airspeed
return true;
} else if ((cmd.content.speed.target_ms >= aparm.airspeed_min.get()) &&
(cmd.content.speed.target_ms <= aparm.airspeed_max.get())) {
new_airspeed_cm = cmd.content.speed.target_ms * 100; //new airspeed target for AUTO or GUIDED modes
gcs().send_text(MAV_SEVERITY_INFO, "Set airspeed %u m/s", (unsigned)cmd.content.speed.target_ms); gcs().send_text(MAV_SEVERITY_INFO, "Set airspeed %u m/s", (unsigned)cmd.content.speed.target_ms);
return true; return true;
} }
@ -1015,6 +1019,8 @@ bool Plane::verify_landing_vtol_approach(const AP_Mission::Mission_Command &cmd)
const int8_t direction = is_negative(radius) ? -1 : 1; const int8_t direction = is_negative(radius) ? -1 : 1;
const float abs_radius = fabsf(radius); const float abs_radius = fabsf(radius);
loiter.direction = direction;
switch (vtol_approach_s.approach_stage) { switch (vtol_approach_s.approach_stage) {
case RTL: case RTL:
{ {

View File

@ -50,6 +50,7 @@ bool Mode::enter()
plane.guided_state.target_heading_type = GUIDED_HEADING_NONE; plane.guided_state.target_heading_type = GUIDED_HEADING_NONE;
plane.guided_state.target_airspeed_cm = -1; // same as above, although an airspeed of -1 is rare on plane. plane.guided_state.target_airspeed_cm = -1; // same as above, although an airspeed of -1 is rare on plane.
plane.guided_state.target_alt = -1; // same as above, although a target alt of -1 is rare on plane. plane.guided_state.target_alt = -1; // same as above, although a target alt of -1 is rare on plane.
plane.guided_state.target_alt_time_ms = 0;
plane.guided_state.last_target_alt = 0; plane.guided_state.last_target_alt = 0;
#endif #endif

View File

@ -341,7 +341,7 @@ protected:
private: private:
// Switch to QRTL if enabled and within radius // Switch to QRTL if enabled and within radius
bool switch_QRTL(bool check_loiter_target = true); bool switch_QRTL();
}; };
class ModeStabilize : public Mode class ModeStabilize : public Mode

View File

@ -8,7 +8,7 @@ bool ModeQHover::_enter()
// set vertical speed and acceleration limits // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-quadplane.get_pilot_velocity_z_max_dn(), quadplane.pilot_velocity_z_max_up, quadplane.pilot_accel_z); pos_control->set_max_speed_accel_z(-quadplane.get_pilot_velocity_z_max_dn(), quadplane.pilot_velocity_z_max_up, quadplane.pilot_accel_z);
pos_control->set_correction_speed_accel_z(-quadplane.get_pilot_velocity_z_max_dn(), quadplane.pilot_velocity_z_max_up, quadplane.pilot_accel_z); pos_control->set_correction_speed_accel_z(-quadplane.get_pilot_velocity_z_max_dn(), quadplane.pilot_velocity_z_max_up, quadplane.pilot_accel_z);
quadplane.set_climb_rate_cms(0, false); quadplane.set_climb_rate_cms(0);
quadplane.init_throttle_wait(); quadplane.init_throttle_wait();
return true; return true;

View File

@ -103,13 +103,13 @@ void ModeQLoiter::run()
quadplane.ahrs.set_touchdown_expected(true); quadplane.ahrs.set_touchdown_expected(true);
} }
quadplane.set_climb_rate_cms(-descent_rate_cms, descent_rate_cms>0); pos_control->land_at_climb_rate_cm(-descent_rate_cms, descent_rate_cms>0);
quadplane.check_land_complete(); quadplane.check_land_complete();
} else if (plane.control_mode == &plane.mode_guided && quadplane.guided_takeoff) { } else if (plane.control_mode == &plane.mode_guided && quadplane.guided_takeoff) {
quadplane.set_climb_rate_cms(0, false); quadplane.set_climb_rate_cms(0);
} else { } else {
// update altitude target and call position controller // update altitude target and call position controller
quadplane.set_climb_rate_cms(quadplane.get_pilot_desired_climb_rate_cms(), false); quadplane.set_climb_rate_cms(quadplane.get_pilot_desired_climb_rate_cms());
} }
quadplane.run_z_controller(); quadplane.run_z_controller();
} }

View File

@ -88,7 +88,7 @@ void ModeQRTL::run()
quadplane.get_weathervane_yaw_rate_cds()); quadplane.get_weathervane_yaw_rate_cds());
// climb at full WP nav speed // climb at full WP nav speed
quadplane.set_climb_rate_cms(quadplane.wp_nav->get_default_speed_up(), false); quadplane.set_climb_rate_cms(quadplane.wp_nav->get_default_speed_up());
quadplane.run_z_controller(); quadplane.run_z_controller();
ftype alt_diff; ftype alt_diff;

View File

@ -9,15 +9,36 @@ bool ModeRTL::_enter()
#if HAL_QUADPLANE_ENABLED #if HAL_QUADPLANE_ENABLED
plane.vtol_approach_s.approach_stage = Plane::Landing_ApproachStage::RTL; plane.vtol_approach_s.approach_stage = Plane::Landing_ApproachStage::RTL;
// treat RTL as QLAND if we are in guided wait takeoff state, to cope // Quadplane specific checks
// with failsafes during GUIDED->AUTO takeoff sequence if (plane.quadplane.available()) {
if (plane.quadplane.guided_wait_takeoff_on_mode_enter) { // treat RTL as QLAND if we are in guided wait takeoff state, to cope
plane.set_mode(plane.mode_qland, ModeReason::QLAND_INSTEAD_OF_RTL); // with failsafes during GUIDED->AUTO takeoff sequence
return true; if (plane.quadplane.guided_wait_takeoff_on_mode_enter) {
} plane.set_mode(plane.mode_qland, ModeReason::QLAND_INSTEAD_OF_RTL);
return true;
}
// do not check if we have reached the loiter target if switching from loiter this will trigger as the nav controller has not yet proceeded the new destination // if Q_RTL_MODE is QRTL always, immediately switch to QRTL mode
switch_QRTL(false); if (plane.quadplane.rtl_mode == QuadPlane::RTL_MODE::QRTL_ALWAYS) {
plane.set_mode(plane.mode_qrtl, ModeReason::QRTL_INSTEAD_OF_RTL);
return true;
}
// if VTOL landing is expected and quadplane motors are active and within QRTL radius and under QRTL altitude then switch to QRTL
const bool vtol_landing = (plane.quadplane.rtl_mode == QuadPlane::RTL_MODE::SWITCH_QRTL) || (plane.quadplane.rtl_mode == QuadPlane::RTL_MODE::VTOL_APPROACH_QRTL);
if (vtol_landing && (quadplane.motors->get_desired_spool_state() == AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED)) {
uint16_t qrtl_radius = abs(plane.g.rtl_radius);
if (qrtl_radius == 0) {
qrtl_radius = abs(plane.aparm.loiter_radius);
}
int32_t alt_cm;
if ((plane.current_loc.get_distance(plane.next_WP_loc) < qrtl_radius) &&
plane.current_loc.get_alt_cm(Location::AltFrame::ABOVE_HOME, alt_cm) && (alt_cm < plane.quadplane.qrtl_alt*100)) {
plane.set_mode(plane.mode_qrtl, ModeReason::QRTL_INSTEAD_OF_RTL);
return true;
}
}
}
#endif #endif
return true; return true;
@ -60,10 +81,10 @@ void ModeRTL::update()
void ModeRTL::navigate() void ModeRTL::navigate()
{ {
#if HAL_QUADPLANE_ENABLED #if HAL_QUADPLANE_ENABLED
if (plane.control_mode->mode_number() != QRTL) { if ((plane.control_mode->mode_number() != QRTL) && plane.quadplane.available()) {
// QRTL shares this navigate function with RTL // QRTL shares this navigate function with RTL
if (plane.quadplane.available() && (plane.quadplane.rtl_mode == QuadPlane::RTL_MODE::VTOL_APPROACH_QRTL)) { if (plane.quadplane.rtl_mode == QuadPlane::RTL_MODE::VTOL_APPROACH_QRTL) {
// VTOL approach landing // VTOL approach landing
AP_Mission::Mission_Command cmd; AP_Mission::Mission_Command cmd;
cmd.content.location = plane.next_WP_loc; cmd.content.location = plane.next_WP_loc;
@ -118,24 +139,18 @@ void ModeRTL::navigate()
#if HAL_QUADPLANE_ENABLED #if HAL_QUADPLANE_ENABLED
// Switch to QRTL if enabled and within radius // Switch to QRTL if enabled and within radius
bool ModeRTL::switch_QRTL(bool check_loiter_target) bool ModeRTL::switch_QRTL()
{ {
if (!plane.quadplane.available() || ((plane.quadplane.rtl_mode != QuadPlane::RTL_MODE::SWITCH_QRTL) && (plane.quadplane.rtl_mode != QuadPlane::RTL_MODE::QRTL_ALWAYS))) { if (plane.quadplane.rtl_mode != QuadPlane::RTL_MODE::SWITCH_QRTL) {
return false; return false;
} }
// if Q_RTL_MODE is QRTL always, then immediately switch to QRTL mode
if (plane.quadplane.rtl_mode == QuadPlane::RTL_MODE::QRTL_ALWAYS) {
plane.set_mode(plane.mode_qrtl, ModeReason::QRTL_INSTEAD_OF_RTL);
return true;
}
uint16_t qrtl_radius = abs(plane.g.rtl_radius); uint16_t qrtl_radius = abs(plane.g.rtl_radius);
if (qrtl_radius == 0) { if (qrtl_radius == 0) {
qrtl_radius = abs(plane.aparm.loiter_radius); qrtl_radius = abs(plane.aparm.loiter_radius);
} }
if ( (check_loiter_target && plane.nav_controller->reached_loiter_target()) || if (plane.nav_controller->reached_loiter_target() ||
plane.current_loc.past_interval_finish_line(plane.prev_WP_loc, plane.next_WP_loc) || plane.current_loc.past_interval_finish_line(plane.prev_WP_loc, plane.next_WP_loc) ||
plane.auto_state.wp_distance < MAX(qrtl_radius, plane.quadplane.stopping_distance())) { plane.auto_state.wp_distance < MAX(qrtl_radius, plane.quadplane.stopping_distance())) {
/* /*

View File

@ -143,9 +143,9 @@ void Plane::calc_airspeed_errors()
// Get the airspeed_estimate, update smoothed airspeed estimate // Get the airspeed_estimate, update smoothed airspeed estimate
// NOTE: we use the airspeed estimate function not direct sensor // NOTE: we use the airspeed estimate function not direct sensor
// as TECS may be using synthetic airspeed // as TECS may be using synthetic airspeed
float airspeed_measured = 0; float airspeed_measured = 0.1;
if (ahrs.airspeed_estimate(airspeed_measured)) { if (ahrs.airspeed_estimate(airspeed_measured)) {
smoothed_airspeed = smoothed_airspeed * 0.8f + airspeed_measured * 0.2f; smoothed_airspeed = MAX(0.1, smoothed_airspeed * 0.8f + airspeed_measured * 0.2f);
} }
// low pass filter speed scaler, with 1Hz cutoff, at 10Hz // low pass filter speed scaler, with 1Hz cutoff, at 10Hz

View File

@ -258,7 +258,7 @@ const AP_Param::GroupInfo QuadPlane::var_info[] = {
// @Param: OPTIONS // @Param: OPTIONS
// @DisplayName: quadplane options // @DisplayName: quadplane options
// @Description: Level Transition:Keep wings within LEVEL_ROLL_LIMIT and only use forward motor(s) for climb during transition, Allow FW Takeoff: If bit is not set then NAV_TAKEOFF command on quadplanes will instead perform a NAV_VTOL takeoff, Allow FW Land:If bit is not set then NAV_LAND command on quadplanes will instead perform a NAV_VTOL_LAND, Vtol Takeoff Frame: command NAV_VTOL_TAKEOFF altitude is as set by the command's reference frame rather than a delta above current location, Always use FW spiral approach:Always use Use a fixed wing spiral approach for VTOL landings, USE QRTL:instead of QLAND for rc failsafe when in VTOL modes, Use Governor:Use ICE Idle Governor in MANUAL for forward motor, Force Qassist: on always,Mtrs_Only_Qassist: in tailsitters only, uses VTOL motors and not flying surfaces for QASSIST, Airmode_On_Arm:Airmode enabled when arming by aux switch, Disarmed Yaw Tilt:Enable motor tilt for yaw when disarmed, Delay Spoolup:Delay VTOL spoolup for 2 seconds after arming, ThrLandControl: enable throttle stick control of landing rate, DisableApproach: Disable use of approach and airbrake stages in VTOL landing, EnableLandResposition: enable pilot controlled repositioning in AUTO land. Descent will pause while repositioning. ARMVTOL: Arm only in VTOL or AUTO modes. CompleteTransition: to fixed wing if Q_TRANS_FAIL timer times out instead of QLAND. Force RTL mode: forces RTL mode on rc failsafe in VTOL modes overriding bit 5(USE_QRTL). // @Description: Level Transition:Keep wings within LEVEL_ROLL_LIMIT and only use forward motor(s) for climb during transition, Allow FW Takeoff: If bit is not set then NAV_TAKEOFF command on quadplanes will instead perform a NAV_VTOL takeoff, Allow FW Land:If bit is not set then NAV_LAND command on quadplanes will instead perform a NAV_VTOL_LAND, Vtol Takeoff Frame: command NAV_VTOL_TAKEOFF altitude is as set by the command's reference frame rather than a delta above current location, Always use FW spiral approach:Always use Use a fixed wing spiral approach for VTOL landings, USE QRTL:instead of QLAND for rc failsafe when in VTOL modes, Use Governor:Use ICE Idle Governor in MANUAL for forward motor, Force Qassist: on always,Mtrs_Only_Qassist: in tailsitters only, uses VTOL motors and not flying surfaces for QASSIST, Airmode_On_Arm:Airmode enabled when arming by aux switch, Disarmed Yaw Tilt:Enable motor tilt for yaw when disarmed, Delay Spoolup:Delay VTOL spoolup for 2 seconds after arming, ThrLandControl: enable throttle stick control of landing rate, DisableApproach: Disable use of approach and airbrake stages in VTOL landing, EnableLandResposition: enable pilot controlled repositioning in AUTO land. Descent will pause while repositioning. ARMVTOL: Arm only in VTOL or AUTO modes. CompleteTransition: to fixed wing if Q_TRANS_FAIL timer times out instead of QLAND. Force RTL mode: forces RTL mode on rc failsafe in VTOL modes overriding bit 5(USE_QRTL).
// @Bitmask: 0:Level Transition,1:Allow FW Takeoff,2:Allow FW Land,3:Vtol Takeoff Frame,4:Always use FW spiral approach,5:Use QRTL,6:Use Governor,7:Force Qassist,8:Mtrs_Only_Qassist,10:Disarmed Yaw Tilt,11:Delay Spoolup,12:disable Qassist based on synthetic airspeed,13:Disable Ground Effect Compensation,14:Ignore forward flight angle limits in Qmodes,15:ThrLandControl,16:DisableApproach,17:EnableLandReposition,18:ARMVtol, 19: CompleteTransition if Q_TRANS_FAIL, 20: Force RTL mode on VTOL failsafes overriding bit 5(USE QRTL) // @Bitmask: 0:Level Transition,1:Allow FW Takeoff,2:Allow FW Land,3:Vtol Takeoff Frame,4:Always use FW spiral approach,5:Use QRTL,6:Use Governor,7:Force Qassist,8:Mtrs_Only_Qassist,10:Disarmed Yaw Tilt,11:Delay Spoolup,12:disable Qassist based on synthetic airspeed,13:Disable Ground Effect Compensation,14:Ignore forward flight angle limits in Qmodes,15:ThrLandControl,16:DisableApproach,17:EnableLandReposition,18:ARMVtol, 19: CompleteTransition if Q_TRANS_FAIL, 20: Force RTL mode on VTOL failsafes overriding bit 5(USE QRTL), 21:Tilt rotor tilt motors up when disarmed in FW modes (except manual) to prevent ground strikes
AP_GROUPINFO("OPTIONS", 58, QuadPlane, options, 0), AP_GROUPINFO("OPTIONS", 58, QuadPlane, options, 0),
AP_SUBGROUPEXTENSION("",59, QuadPlane, var_info2), AP_SUBGROUPEXTENSION("",59, QuadPlane, var_info2),
@ -607,7 +607,6 @@ bool QuadPlane::setup(void)
if (!enable || hal.util->get_soft_armed()) { if (!enable || hal.util->get_soft_armed()) {
return false; return false;
} }
float loop_delta_t = 1.0 / plane.scheduler.get_loop_rate_hz();
/* /*
cope with upgrade from old AP_Motors values for frame_class cope with upgrade from old AP_Motors values for frame_class
@ -683,12 +682,12 @@ bool QuadPlane::setup(void)
switch ((AP_Motors::motor_frame_class)frame_class) { switch ((AP_Motors::motor_frame_class)frame_class) {
case AP_Motors::MOTOR_FRAME_TRI: case AP_Motors::MOTOR_FRAME_TRI:
motors = new AP_MotorsTri(plane.scheduler.get_loop_rate_hz(), rc_speed); motors = new AP_MotorsTri(rc_speed);
motors_var_info = AP_MotorsTri::var_info; motors_var_info = AP_MotorsTri::var_info;
break; break;
case AP_Motors::MOTOR_FRAME_TAILSITTER: case AP_Motors::MOTOR_FRAME_TAILSITTER:
// this is a duo-motor tailsitter // this is a duo-motor tailsitter
tailsitter.tailsitter_motors = new AP_MotorsTailsitter(plane.scheduler.get_loop_rate_hz(), rc_speed); tailsitter.tailsitter_motors = new AP_MotorsTailsitter(rc_speed);
motors = tailsitter.tailsitter_motors; motors = tailsitter.tailsitter_motors;
motors_var_info = AP_MotorsTailsitter::var_info; motors_var_info = AP_MotorsTailsitter::var_info;
break; break;
@ -699,7 +698,7 @@ bool QuadPlane::setup(void)
#endif // AP_SCRIPTING_ENABLED #endif // AP_SCRIPTING_ENABLED
break; break;
default: default:
motors = new AP_MotorsMatrix(plane.scheduler.get_loop_rate_hz(), rc_speed); motors = new AP_MotorsMatrix(rc_speed);
motors_var_info = AP_MotorsMatrix::var_info; motors_var_info = AP_MotorsMatrix::var_info;
break; break;
} }
@ -716,13 +715,13 @@ bool QuadPlane::setup(void)
AP_BoardConfig::allocation_error("ahrs_view"); AP_BoardConfig::allocation_error("ahrs_view");
} }
attitude_control = new AC_AttitudeControl_TS(*ahrs_view, aparm, *motors, loop_delta_t); attitude_control = new AC_AttitudeControl_TS(*ahrs_view, aparm, *motors);
if (!attitude_control) { if (!attitude_control) {
AP_BoardConfig::allocation_error("attitude_control"); AP_BoardConfig::allocation_error("attitude_control");
} }
AP_Param::load_object_from_eeprom(attitude_control, attitude_control->var_info); AP_Param::load_object_from_eeprom(attitude_control, attitude_control->var_info);
pos_control = new AC_PosControl(*ahrs_view, inertial_nav, *motors, *attitude_control, loop_delta_t); pos_control = new AC_PosControl(*ahrs_view, inertial_nav, *motors, *attitude_control);
if (!pos_control) { if (!pos_control) {
AP_BoardConfig::allocation_error("pos_control"); AP_BoardConfig::allocation_error("pos_control");
} }
@ -963,7 +962,7 @@ void QuadPlane::run_z_controller(void)
// never run Z controller in tailsitter transtion // never run Z controller in tailsitter transtion
return; return;
} }
if ((now - last_pidz_active_ms) > 20) { if ((now - last_pidz_active_ms) > 20 || !pos_control->is_active_z()) {
// set vertical speed and acceleration limits // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
@ -1004,9 +1003,9 @@ void QuadPlane::check_yaw_reset(void)
} }
} }
void QuadPlane::set_climb_rate_cms(float target_climb_rate_cms, bool force_descend) void QuadPlane::set_climb_rate_cms(float target_climb_rate_cms)
{ {
pos_control->input_vel_accel_z(target_climb_rate_cms, 0, force_descend); pos_control->input_vel_accel_z(target_climb_rate_cms, 0, false);
} }
/* /*
@ -1024,7 +1023,7 @@ void QuadPlane::hold_hover(float target_climb_rate_cms)
multicopter_attitude_rate_update(get_desired_yaw_rate_cds(false)); multicopter_attitude_rate_update(get_desired_yaw_rate_cds(false));
// call position controller // call position controller
set_climb_rate_cms(target_climb_rate_cms, false); set_climb_rate_cms(target_climb_rate_cms);
run_z_controller(); run_z_controller();
} }
@ -1325,6 +1324,12 @@ void QuadPlane::set_armed(bool armed)
if (plane.control_mode == &plane.mode_guided) { if (plane.control_mode == &plane.mode_guided) {
guided_wait_takeoff = armed; guided_wait_takeoff = armed;
} }
// re-init throttle wait on arm and disarm, to prevent rudder
// arming on 2nd flight causing yaw
if (!air_mode_active()) {
init_throttle_wait();
}
} }
@ -1529,18 +1534,7 @@ void SLT_Transition::update()
transition_start_ms = 0; transition_start_ms = 0;
transition_low_airspeed_ms = 0; transition_low_airspeed_ms = 0;
} }
if (transition_state < TRANSITION_TIMER) {
// set a single loop pitch limit in TECS
if (plane.ahrs.groundspeed() < 3) {
// until we have some ground speed limit to zero pitch
plane.TECS_controller.set_pitch_max_limit(0);
} else {
plane.TECS_controller.set_pitch_max_limit(quadplane.transition_pitch_max);
}
} else if (transition_state < TRANSITION_DONE) {
plane.TECS_controller.set_pitch_max_limit((quadplane.transition_pitch_max+1)*2);
}
if (transition_state < TRANSITION_DONE) { if (transition_state < TRANSITION_DONE) {
// during transition we ask TECS to use a synthetic // during transition we ask TECS to use a synthetic
// airspeed. Otherwise the pitch limits will throw off the // airspeed. Otherwise the pitch limits will throw off the
@ -1997,6 +1991,11 @@ void QuadPlane::motors_output(bool run_rate_controller)
// relax if have been inactive // relax if have been inactive
relax_attitude_control(); relax_attitude_control();
} }
// run low level rate controllers that only require IMU data and set loop time
const float last_loop_time_s = AP::scheduler().get_last_loop_time_s();
motors->set_dt(last_loop_time_s);
attitude_control->set_dt(last_loop_time_s);
pos_control->set_dt(last_loop_time_s);
attitude_control->rate_controller_run(); attitude_control->rate_controller_run();
last_att_control_ms = now; last_att_control_ms = now;
} }
@ -2501,7 +2500,11 @@ void QuadPlane::vtol_position_controller(void)
const float distance = diff_wp.length(); const float distance = diff_wp.length();
const Vector2f rel_groundspeed_vector = landing_closing_velocity(); const Vector2f rel_groundspeed_vector = landing_closing_velocity();
const float rel_groundspeed_sq = rel_groundspeed_vector.length_squared(); const float rel_groundspeed_sq = rel_groundspeed_vector.length_squared();
const float closing_groundspeed = rel_groundspeed_vector * diff_wp.normalized(); float closing_groundspeed = 0;
if (distance > 0.1) {
closing_groundspeed = rel_groundspeed_vector * diff_wp.normalized();
}
// calculate speed we should be at to reach the position2 // calculate speed we should be at to reach the position2
// target speed at the position2 distance threshold, assuming // target speed at the position2 distance threshold, assuming
@ -2622,6 +2625,10 @@ void QuadPlane::vtol_position_controller(void)
// call attitude controller // call attitude controller
disable_yaw_rate_time_constant(); disable_yaw_rate_time_constant();
// setup scaling of roll and pitch angle P gains to match fixed wing gains
setup_rp_fw_angle_gains();
if (have_target_yaw) { if (have_target_yaw) {
attitude_control->input_euler_angle_roll_pitch_yaw(plane.nav_roll_cd, attitude_control->input_euler_angle_roll_pitch_yaw(plane.nav_roll_cd,
plane.nav_pitch_cd, plane.nav_pitch_cd,
@ -2789,7 +2796,7 @@ void QuadPlane::vtol_position_controller(void)
float zero = 0; float zero = 0;
pos_control->input_pos_vel_accel_z(target_z, zero, 0); pos_control->input_pos_vel_accel_z(target_z, zero, 0);
} else { } else {
set_climb_rate_cms(0, false); set_climb_rate_cms(0);
} }
break; break;
} }
@ -2803,7 +2810,7 @@ void QuadPlane::vtol_position_controller(void)
} }
} }
const float descent_rate_cms = landing_descent_rate_cms(height_above_ground); const float descent_rate_cms = landing_descent_rate_cms(height_above_ground);
set_climb_rate_cms(-descent_rate_cms, descent_rate_cms>0); pos_control->land_at_climb_rate_cm(-descent_rate_cms, descent_rate_cms>0);
break; break;
} }
@ -2951,10 +2958,10 @@ void QuadPlane::takeoff_controller(void)
vel_z = 0; vel_z = 0;
pos_control->input_pos_vel_accel_z(pos_z, vel_z, 0); pos_control->input_pos_vel_accel_z(pos_z, vel_z, 0);
} else { } else {
set_climb_rate_cms(vel_z, false); set_climb_rate_cms(vel_z);
} }
} else { } else {
set_climb_rate_cms(vel_z, false); set_climb_rate_cms(vel_z);
} }
run_z_controller(); run_z_controller();
@ -2999,7 +3006,7 @@ void QuadPlane::waypoint_controller(void)
true); true);
// climb based on altitude error // climb based on altitude error
set_climb_rate_cms(assist_climb_rate_cms(), false); set_climb_rate_cms(assist_climb_rate_cms());
run_z_controller(); run_z_controller();
} }
@ -4232,6 +4239,43 @@ MAV_VTOL_STATE SLT_Transition::get_mav_vtol_state() const
return MAV_VTOL_STATE_UNDEFINED; return MAV_VTOL_STATE_UNDEFINED;
} }
// Set FW roll and pitch limits and keep TECS informed
void SLT_Transition::set_FW_roll_pitch(int32_t& nav_pitch_cd, int32_t& nav_roll_cd, bool& allow_stick_mixing)
{
if (quadplane.in_vtol_mode() || quadplane.in_vtol_airbrake()) {
// not in FW flight
return;
}
if (transition_state == TRANSITION_DONE) {
// transition complete, nothing to do
return;
}
if (!plane.control_mode->does_auto_throttle()) {
// don't limit pitch when in manually controlled modes like FBWA, ACRO
return;
}
float max_pitch;
if (transition_state < TRANSITION_TIMER) {
if (plane.ahrs.groundspeed() < 3.0) {
// until we have some ground speed limit to zero pitch
max_pitch = 0.0;
} else {
max_pitch = quadplane.transition_pitch_max;
}
} else {
max_pitch = (quadplane.transition_pitch_max+1.0)*2.0;
}
// set a single loop pitch limit in TECS
plane.TECS_controller.set_pitch_max_limit(max_pitch);
// ensure pitch is constrained to limit
nav_pitch_cd = constrain_int32(nav_pitch_cd, -max_pitch*100.0, max_pitch*100.0);
}
/* /*
see if we are in a VTOL takeoff see if we are in a VTOL takeoff
*/ */
@ -4305,4 +4349,45 @@ bool QuadPlane::landing_with_fixed_wing_spiral_approach(void) const
cmd.p1 == NAV_VTOL_LAND_OPTIONS_FW_SPIRAL_APPROACH)); cmd.p1 == NAV_VTOL_LAND_OPTIONS_FW_SPIRAL_APPROACH));
} }
/*
setup scaling of roll and pitch angle P gains to match fixed wing gains
we setup the angle P gain to match fixed wing at high speed (above
ARSPD_FBW_MIN) where fixed wing surfaces are presumed to
dominate. At lower speeds we use the multicopter angle P gains.
*/
void QuadPlane::setup_rp_fw_angle_gains(void)
{
const float mc_angR = attitude_control->get_angle_roll_p().kP();
const float mc_angP = attitude_control->get_angle_pitch_p().kP();
const float fw_angR = 1.0/plane.rollController.tau();
const float fw_angP = 1.0/plane.pitchController.tau();
if (!is_positive(mc_angR) || !is_positive(mc_angP)) {
// bad configuration, don't scale
return;
}
float aspeed;
if (!ahrs.airspeed_estimate(aspeed)) {
// can't get airspeed, no scaling of VTOL angle gains
return;
}
const float low_airspeed = 3.0;
if (aspeed <= low_airspeed || plane.aparm.airspeed_min <= low_airspeed) {
// no scaling
return;
}
const float angR_scale = linear_interpolate(mc_angR, fw_angR,
aspeed,
low_airspeed, plane.aparm.airspeed_min) / mc_angR;
const float angP_scale = linear_interpolate(mc_angP, fw_angP,
aspeed,
low_airspeed, plane.aparm.airspeed_min) / mc_angP;
const Vector3f gain_scale{angR_scale, angP_scale, 1.0};
attitude_control->set_angle_P_scale(gain_scale);
}
#endif // HAL_QUADPLANE_ENABLED #endif // HAL_QUADPLANE_ENABLED

View File

@ -225,7 +225,7 @@ private:
void hold_stabilize(float throttle_in); void hold_stabilize(float throttle_in);
// set climb rate in position controller // set climb rate in position controller
void set_climb_rate_cms(float target_climb_rate_cms, bool force_descend); void set_climb_rate_cms(float target_climb_rate_cms);
// get pilot desired yaw rate in cd/s // get pilot desired yaw rate in cd/s
float get_pilot_input_yaw_rate_cds(void) const; float get_pilot_input_yaw_rate_cds(void) const;
@ -557,6 +557,7 @@ private:
ONLY_ARM_IN_QMODE_OR_AUTO=(1<<18), ONLY_ARM_IN_QMODE_OR_AUTO=(1<<18),
TRANS_FAIL_TO_FW=(1<<19), TRANS_FAIL_TO_FW=(1<<19),
FS_RTL=(1<<20), FS_RTL=(1<<20),
DISARMED_TILT_UP=(1<<21),
}; };
bool option_is_set(OPTION option) const { bool option_is_set(OPTION option) const {
return (options.get() & int32_t(option)) != 0; return (options.get() & int32_t(option)) != 0;
@ -665,6 +666,11 @@ private:
*/ */
float get_scaled_wp_speed(float target_bearing_deg) const; float get_scaled_wp_speed(float target_bearing_deg) const;
/*
setup scaling of roll and pitch angle P gains to match fixed wing gains
*/
void setup_rp_fw_angle_gains(void);
public: public:
void motor_test_output(); void motor_test_output();
MAV_RESULT mavlink_motor_test_start(mavlink_channel_t chan, uint8_t motor_seq, uint8_t throttle_type, MAV_RESULT mavlink_motor_test_start(mavlink_channel_t chan, uint8_t motor_seq, uint8_t throttle_type,

View File

@ -197,6 +197,26 @@ void Plane::startup_ground(void)
} }
#if AP_FENCE_ENABLED
/*
return true if a mode reason is an automatic mode change due to
landing sequencing.
*/
static bool mode_reason_is_landing_sequence(const ModeReason reason)
{
switch (reason) {
case ModeReason::RTL_COMPLETE_SWITCHING_TO_FIXEDWING_AUTOLAND:
case ModeReason::RTL_COMPLETE_SWITCHING_TO_VTOL_LAND_RTL:
case ModeReason::QRTL_INSTEAD_OF_RTL:
case ModeReason::QLAND_INSTEAD_OF_RTL:
return true;
default:
break;
}
return false;
}
#endif // AP_FENCE_ENABLED
bool Plane::set_mode(Mode &new_mode, const ModeReason reason) bool Plane::set_mode(Mode &new_mode, const ModeReason reason)
{ {
@ -246,8 +266,12 @@ bool Plane::set_mode(Mode &new_mode, const ModeReason reason)
#if AP_FENCE_ENABLED #if AP_FENCE_ENABLED
// may not be allowed to change mode if recovering from fence breach // may not be allowed to change mode if recovering from fence breach
if (hal.util->get_soft_armed() && fence.enabled() && fence.option_enabled(AC_Fence::OPTIONS::DISABLE_MODE_CHANGE) && if (hal.util->get_soft_armed() &&
fence.get_breaches() && in_fence_recovery()) { fence.enabled() &&
fence.option_enabled(AC_Fence::OPTIONS::DISABLE_MODE_CHANGE) &&
fence.get_breaches() &&
in_fence_recovery() &&
!mode_reason_is_landing_sequence(reason)) {
gcs().send_text(MAV_SEVERITY_NOTICE,"Mode change to %s denied, in fence recovery", new_mode.name()); gcs().send_text(MAV_SEVERITY_NOTICE,"Mode change to %s denied, in fence recovery", new_mode.name());
AP_Notify::events.user_mode_change_failed = 1; AP_Notify::events.user_mode_change_failed = 1;
return false; return false;

View File

@ -219,7 +219,10 @@ void Tiltrotor::continuous_update(void)
if (!quadplane.in_vtol_mode() && (!hal.util->get_soft_armed() || !quadplane.assisted_flight)) { if (!quadplane.in_vtol_mode() && (!hal.util->get_soft_armed() || !quadplane.assisted_flight)) {
// we are in pure fixed wing mode. Move the tiltable motors all the way forward and run them as // we are in pure fixed wing mode. Move the tiltable motors all the way forward and run them as
// a forward motor // a forward motor
slew(get_forward_flight_tilt());
// option set then if disarmed move to VTOL position to prevent ground strikes, allow tilt forward in manual mode for testing
const bool disarmed_tilt_up = !hal.util->get_soft_armed() && (plane.control_mode != &plane.mode_manual) && quadplane.option_is_set(QuadPlane::OPTION::DISARMED_TILT_UP);
slew(disarmed_tilt_up ? 0.0 : get_forward_flight_tilt());
max_change = tilt_max_change(false); max_change = tilt_max_change(false);

View File

@ -87,6 +87,8 @@ public:
bool show_vtol_view() const override; bool show_vtol_view() const override;
void set_FW_roll_pitch(int32_t& nav_pitch_cd, int32_t& nav_roll_cd, bool& allow_stick_mixing) override;
bool set_FW_roll_limit(int32_t& roll_limit_cd) override; bool set_FW_roll_limit(int32_t& roll_limit_cd) override;
bool allow_update_throttle_mix() const override; bool allow_update_throttle_mix() const override;

View File

@ -6,14 +6,14 @@
#include "ap_version.h" #include "ap_version.h"
#define THISFIRMWARE "ArduPlane V4.3.0dev" #define THISFIRMWARE "ArduPlane V4.3.8-beta1"
// the following line is parsed by the autotest scripts // the following line is parsed by the autotest scripts
#define FIRMWARE_VERSION 4,3,0,FIRMWARE_VERSION_TYPE_DEV #define FIRMWARE_VERSION 4,3,7,FIRMWARE_VERSION_TYPE_BETA
#define FW_MAJOR 4 #define FW_MAJOR 4
#define FW_MINOR 3 #define FW_MINOR 3
#define FW_PATCH 0 #define FW_PATCH 7
#define FW_TYPE FIRMWARE_VERSION_TYPE_DEV #define FW_TYPE FIRMWARE_VERSION_TYPE_BETA
#include <AP_Common/AP_FWVersionDefine.h> #include <AP_Common/AP_FWVersionDefine.h>

View File

@ -132,9 +132,14 @@ constexpr int8_t Sub::_failsafe_priorities[5];
void Sub::run_rate_controller() void Sub::run_rate_controller()
{ {
const float last_loop_time_s = AP::scheduler().get_last_loop_time_s();
motors.set_dt(last_loop_time_s);
attitude_control.set_dt(last_loop_time_s);
pos_control.set_dt(last_loop_time_s);
//don't run rate controller in manual or motordetection modes //don't run rate controller in manual or motordetection modes
if (control_mode != MANUAL && control_mode != MOTOR_DETECT) { if (control_mode != MANUAL && control_mode != MOTOR_DETECT) {
// run low level rate controllers that only require IMU data // run low level rate controllers that only require IMU data and set loop time
attitude_control.rate_controller_run(); attitude_control.rate_controller_run();
} }
} }

View File

@ -1,6 +1,7 @@
#include "Sub.h" #include "Sub.h"
#include "GCS_Mavlink.h" #include "GCS_Mavlink.h"
#include <AP_RPM/AP_RPM_config.h>
MAV_TYPE GCS_Sub::frame_type() const MAV_TYPE GCS_Sub::frame_type() const
{ {

View File

@ -32,8 +32,8 @@ Sub::Sub()
auto_yaw_mode(AUTO_YAW_LOOK_AT_NEXT_WP), auto_yaw_mode(AUTO_YAW_LOOK_AT_NEXT_WP),
inertial_nav(ahrs), inertial_nav(ahrs),
ahrs_view(ahrs, ROTATION_NONE), ahrs_view(ahrs, ROTATION_NONE),
attitude_control(ahrs_view, aparm, motors, scheduler.get_loop_period_s()), attitude_control(ahrs_view, aparm, motors),
pos_control(ahrs_view, inertial_nav, motors, attitude_control, scheduler.get_loop_period_s()), pos_control(ahrs_view, inertial_nav, motors, attitude_control),
wp_nav(inertial_nav, ahrs_view, pos_control, attitude_control), wp_nav(inertial_nav, ahrs_view, pos_control, attitude_control),
loiter_nav(inertial_nav, ahrs_view, pos_control, attitude_control), loiter_nav(inertial_nav, ahrs_view, pos_control, attitude_control),
circle_nav(inertial_nav, ahrs_view, pos_control), circle_nav(inertial_nav, ahrs_view, pos_control),

View File

@ -50,7 +50,6 @@ void Sub::init_rc_in()
void Sub::init_rc_out() void Sub::init_rc_out()
{ {
motors.set_update_rate(g.rc_speed); motors.set_update_rate(g.rc_speed);
motors.set_loop_rate(scheduler.get_loop_rate_hz());
motors.init((AP_Motors::motor_frame_class)g.frame_configuration.get(), AP_Motors::motor_frame_type::MOTOR_FRAME_TYPE_PLUS); motors.init((AP_Motors::motor_frame_class)g.frame_configuration.get(), AP_Motors::motor_frame_type::MOTOR_FRAME_TYPE_PLUS);
motors.convert_pwm_min_max_param(channel_throttle->get_radio_min(), channel_throttle->get_radio_max()); motors.convert_pwm_min_max_param(channel_throttle->get_radio_min(), channel_throttle->get_radio_max());
motors.update_throttle_range(); motors.update_throttle_range();

View File

@ -224,13 +224,13 @@ private:
AP_InertialNav inertial_nav; AP_InertialNav inertial_nav;
// Vel & pos PIDs // Vel & pos PIDs
AC_PID_2D pid_vel_xy{3, 0.2, 0, 0, 0.2, 3, 3, 0.02}; //These are the defaults - P I D FF IMAX FiltHz FiltDHz DT AC_PID_2D pid_vel_xy{3, 0.2, 0, 0, 0.2, 3, 3}; //These are the defaults - P I D FF IMAX FiltHz FiltDHz DT
AC_PID_Basic pid_vel_z{7, 1.5, 0, 0, 1, 3, 3, 0.02}; AC_PID_Basic pid_vel_z{7, 1.5, 0, 0, 1, 3, 3};
AC_PID_Basic pid_vel_yaw{3, 0.4, 0, 0, 0.2, 3, 3, 0.02}; AC_PID_Basic pid_vel_yaw{3, 0.4, 0, 0, 0.2, 3, 3};
AC_PID_2D pid_pos_xy{1, 0.05, 0, 0, 0.1, 3, 3, 0.02}; AC_PID_2D pid_pos_xy{1, 0.05, 0, 0, 0.1, 3, 3};
AC_PID_Basic pid_pos_z{0.7, 0, 0, 0, 0, 3, 3, 0.02}; AC_PID_Basic pid_pos_z{0.7, 0, 0, 0, 0, 3, 3};
AC_PID pid_pos_yaw{1.2, 0.5, 0, 0, 2, 3, 3, 3, 0.02}; //p, i, d, ff, imax, filt_t, filt_e, filt_d, dt, opt srmax, opt srtau AC_PID pid_pos_yaw{1.2, 0.5, 0, 0, 2, 3, 3, 3}; //p, i, d, ff, imax, filt_t, filt_e, filt_d, dt, opt srmax, opt srtau
// System Timers // System Timers
// -------------- // --------------

View File

@ -1,6 +1,7 @@
#include "Blimp.h" #include "Blimp.h"
#include "GCS_Mavlink.h" #include "GCS_Mavlink.h"
#include <AP_RPM/AP_RPM_config.h>
MAV_TYPE GCS_Blimp::frame_type() const MAV_TYPE GCS_Blimp::frame_type() const
{ {
@ -358,7 +359,9 @@ static const ap_message STREAM_EXTRA3_msgs[] = {
MSG_MAG_CAL_PROGRESS, MSG_MAG_CAL_PROGRESS,
MSG_EKF_STATUS_REPORT, MSG_EKF_STATUS_REPORT,
MSG_VIBRATION, MSG_VIBRATION,
#if AP_RPM_ENABLED
MSG_RPM, MSG_RPM,
#endif
MSG_ESC_TELEMETRY, MSG_ESC_TELEMETRY,
MSG_GENERATOR_STATUS, MSG_GENERATOR_STATUS,
}; };

View File

@ -14,11 +14,13 @@
//Runs the main loiter controller //Runs the main loiter controller
void ModeLoiter::run() void ModeLoiter::run()
{ {
const float dt = blimp.scheduler.get_last_loop_time_s();
Vector3f pilot; Vector3f pilot;
pilot.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_pos_xy * blimp.scheduler.get_loop_period_s(); pilot.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_pos_xy * dt;
pilot.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_pos_xy * blimp.scheduler.get_loop_period_s(); pilot.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_pos_xy * dt;
pilot.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_pos_z * blimp.scheduler.get_loop_period_s(); pilot.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_pos_z * dt;
float pilot_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_pos_yaw * blimp.scheduler.get_loop_period_s(); float pilot_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_pos_yaw * dt;
if (g.simple_mode == 0){ if (g.simple_mode == 0){
//If simple mode is disabled, input is in body-frame, thus needs to be rotated. //If simple mode is disabled, input is in body-frame, thus needs to be rotated.
@ -30,10 +32,10 @@ void ModeLoiter::run()
target_yaw = wrap_PI(target_yaw + pilot_yaw); target_yaw = wrap_PI(target_yaw + pilot_yaw);
//Pos controller's output becomes target for velocity controller //Pos controller's output becomes target for velocity controller
Vector3f target_vel_ef{blimp.pid_pos_xy.update_all(target_pos, blimp.pos_ned, {0,0,0}), 0}; Vector3f target_vel_ef{blimp.pid_pos_xy.update_all(target_pos, blimp.pos_ned, dt, {0,0,0}), 0};
target_vel_ef.z = blimp.pid_pos_z.update_all(target_pos.z, blimp.pos_ned.z); target_vel_ef.z = blimp.pid_pos_z.update_all(target_pos.z, blimp.pos_ned.z, dt);
float yaw_ef = blimp.ahrs.get_yaw(); float yaw_ef = blimp.ahrs.get_yaw();
float target_vel_yaw = blimp.pid_pos_yaw.update_error(wrap_PI(target_yaw - yaw_ef)); float target_vel_yaw = blimp.pid_pos_yaw.update_error(wrap_PI(target_yaw - yaw_ef), dt);
blimp.pid_pos_yaw.set_target_rate(target_yaw); blimp.pid_pos_yaw.set_target_rate(target_yaw);
blimp.pid_pos_yaw.set_actual_rate(yaw_ef); blimp.pid_pos_yaw.set_actual_rate(yaw_ef);
@ -42,10 +44,10 @@ void ModeLoiter::run()
constrain_float(target_vel_ef.z, -g.max_vel_z, g.max_vel_z)}; constrain_float(target_vel_ef.z, -g.max_vel_z, g.max_vel_z)};
float target_vel_yaw_c = constrain_float(target_vel_yaw, -g.max_vel_yaw, g.max_vel_yaw); float target_vel_yaw_c = constrain_float(target_vel_yaw, -g.max_vel_yaw, g.max_vel_yaw);
Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel_ef_c, blimp.vel_ned_filtd, {0,0,0}); Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel_ef_c, blimp.vel_ned_filtd, dt, {0,0,0});
float act_down = blimp.pid_vel_z.update_all(target_vel_ef_c.z, blimp.vel_ned_filtd.z); float act_down = blimp.pid_vel_z.update_all(target_vel_ef_c.z, blimp.vel_ned_filtd.z, dt);
blimp.rotate_NE_to_BF(actuator); blimp.rotate_NE_to_BF(actuator);
float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw_c, blimp.vel_yaw_filtd); float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw_c, blimp.vel_yaw_filtd, dt);
if(!(blimp.g.dis_mask & (1<<(2-1)))){ if(!(blimp.g.dis_mask & (1<<(2-1)))){
motors->front_out = actuator.x; motors->front_out = actuator.x;

View File

@ -6,6 +6,8 @@
// Runs the main velocity controller // Runs the main velocity controller
void ModeVelocity::run() void ModeVelocity::run()
{ {
const float dt = blimp.scheduler.get_last_loop_time_s();
Vector3f target_vel; Vector3f target_vel;
target_vel.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_vel_xy; target_vel.x = channel_front->get_control_in() / float(RC_SCALE) * g.max_vel_xy;
target_vel.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_vel_xy; target_vel.y = channel_right->get_control_in() / float(RC_SCALE) * g.max_vel_xy;
@ -13,10 +15,10 @@ void ModeVelocity::run()
target_vel.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_vel_z; target_vel.z = channel_down->get_control_in() / float(RC_SCALE) * g.max_vel_z;
float target_vel_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_vel_yaw; float target_vel_yaw = channel_yaw->get_control_in() / float(RC_SCALE) * g.max_vel_yaw;
Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel, blimp.vel_ned_filtd, {0,0,0}); Vector2f actuator = blimp.pid_vel_xy.update_all(target_vel, blimp.vel_ned_filtd, dt, {0,0,0});
blimp.rotate_NE_to_BF(actuator); blimp.rotate_NE_to_BF(actuator);
float act_down = blimp.pid_vel_z.update_all(target_vel.z, blimp.vel_ned_filtd.z); float act_down = blimp.pid_vel_z.update_all(target_vel.z, blimp.vel_ned_filtd.z, dt);
float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw, blimp.vel_yaw_filtd); float act_yaw = blimp.pid_vel_yaw.update_all(target_vel_yaw, blimp.vel_yaw_filtd, dt);
if(!(blimp.g.dis_mask & (1<<(2-1)))){ if(!(blimp.g.dis_mask & (1<<(2-1)))){
motors->front_out = actuator.x; motors->front_out = actuator.x;

View File

@ -2,7 +2,9 @@
#include "GCS_Mavlink.h" #include "GCS_Mavlink.h"
#include <AP_RPM/AP_RPM_config.h>
#include <AP_RangeFinder/AP_RangeFinder_Backend.h> #include <AP_RangeFinder/AP_RangeFinder_Backend.h>
#include <AP_EFI/AP_EFI_config.h>
MAV_TYPE GCS_Rover::frame_type() const MAV_TYPE GCS_Rover::frame_type() const
{ {
@ -565,9 +567,14 @@ static const ap_message STREAM_EXTRA3_msgs[] = {
MSG_MAG_CAL_PROGRESS, MSG_MAG_CAL_PROGRESS,
MSG_EKF_STATUS_REPORT, MSG_EKF_STATUS_REPORT,
MSG_VIBRATION, MSG_VIBRATION,
#if AP_RPM_ENABLED
MSG_RPM, MSG_RPM,
#endif
MSG_WHEEL_DISTANCE, MSG_WHEEL_DISTANCE,
MSG_ESC_TELEMETRY, MSG_ESC_TELEMETRY,
#if HAL_EFI_ENABLED
MSG_EFI_STATUS,
#endif
}; };
static const ap_message STREAM_PARAMS_msgs[] = { static const ap_message STREAM_PARAMS_msgs[] = {
MSG_NEXT_PARAM MSG_NEXT_PARAM

View File

@ -500,10 +500,10 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
// @DisplayName: BalanceBot Maximum Pitch // @DisplayName: BalanceBot Maximum Pitch
// @Description: Pitch angle in degrees at 100% throttle // @Description: Pitch angle in degrees at 100% throttle
// @Units: deg // @Units: deg
// @Range: 0 5 // @Range: 0 15
// @Increment: 0.1 // @Increment: 0.1
// @User: Standard // @User: Standard
AP_GROUPINFO("BAL_PITCH_MAX", 21, ParametersG2, bal_pitch_max, 2), AP_GROUPINFO("BAL_PITCH_MAX", 21, ParametersG2, bal_pitch_max, 10),
// @Param: CRASH_ANGLE // @Param: CRASH_ANGLE
// @DisplayName: Crash Angle // @DisplayName: Crash Angle

View File

@ -405,6 +405,9 @@ void Rover::update_logging2(void)
if (should_log(MASK_LOG_IMU)) { if (should_log(MASK_LOG_IMU)) {
AP::ins().Write_Vibration(); AP::ins().Write_Vibration();
#if HAL_GYROFFT_ENABLED
gyro_fft.write_log_messages();
#endif
} }
} }

View File

@ -7,15 +7,8 @@ void Rover::balancebot_pitch_control(float &throttle)
// calculate desired pitch angle // calculate desired pitch angle
const float demanded_pitch = radians(-throttle * 0.01f * g2.bal_pitch_max) + radians(g2.bal_pitch_trim); const float demanded_pitch = radians(-throttle * 0.01f * g2.bal_pitch_max) + radians(g2.bal_pitch_trim);
// calculate speed from wheel encoders
float veh_speed_pct = 0.0f;
if (g2.wheel_encoder.enabled(0) && g2.wheel_encoder.enabled(1) && is_positive(g2.wheel_rate_control.get_rate_max_rads())) {
veh_speed_pct = (g2.wheel_encoder.get_rate(0) + g2.wheel_encoder.get_rate(1)) / (2.0f * g2.wheel_rate_control.get_rate_max_rads()) * 100.0f;
veh_speed_pct = constrain_float(veh_speed_pct, -100.0f, 100.0f);
}
// calculate required throttle using PID controller // calculate required throttle using PID controller
throttle = g2.attitude_control.get_throttle_out_from_pitch(demanded_pitch, veh_speed_pct, g2.motors.limit.throttle_lower, g2.motors.limit.throttle_upper, G_Dt) * 100.0f; throttle = g2.attitude_control.get_throttle_out_from_pitch(demanded_pitch, radians(g2.bal_pitch_max), g2.motors.limit.throttle_lower || g2.motors.limit.throttle_upper, G_Dt) * 100.0f;
} }
// returns true if vehicle is a balance bot // returns true if vehicle is a balance bot

View File

@ -317,7 +317,9 @@ void Mode::calc_throttle(float target_speed, bool avoidance_enabled)
bool stopped; bool stopped;
throttle_out = 100.0f * attitude_control.get_throttle_out_stop(g2.motors.limit.throttle_lower, g2.motors.limit.throttle_upper, g.speed_cruise, g.throttle_cruise * 0.01f, rover.G_Dt, stopped); throttle_out = 100.0f * attitude_control.get_throttle_out_stop(g2.motors.limit.throttle_lower, g2.motors.limit.throttle_upper, g.speed_cruise, g.throttle_cruise * 0.01f, rover.G_Dt, stopped);
} else { } else {
throttle_out = 100.0f * attitude_control.get_throttle_out_speed(target_speed, g2.motors.limit.throttle_lower, g2.motors.limit.throttle_upper, g.speed_cruise, g.throttle_cruise * 0.01f, rover.G_Dt); bool motor_lim_low = g2.motors.limit.throttle_lower || attitude_control.pitch_limited();
bool motor_lim_high = g2.motors.limit.throttle_upper || attitude_control.pitch_limited();
throttle_out = 100.0f * attitude_control.get_throttle_out_speed(target_speed, motor_lim_low, motor_lim_high, g.speed_cruise, g.throttle_cruise * 0.01f, rover.G_Dt);
} }
// if vehicle is balance bot, calculate actual throttle required for balancing // if vehicle is balance bot, calculate actual throttle required for balancing

View File

@ -1,5 +1,267 @@
Rover Release Notes: Rover Release Notes:
------------------------------------------------------------------ ------------------------------------------------------------------
Rover 4.3.0-beta14 12-Aug-2023
Changes from 4.3.0-beta13
1) Bug fixes
- DroneCAN GPS RTK injection fix
- INAxxx battery monitors allow for battery reset remaining
- Notch filter gyro glitch caused by race condition fixed
- Scripting restart memory corruption bug fixed
------------------------------------------------------------------
Rover 4.3.0-beta13 27-Mar-2023
Changes from 4.3.0-beta12
1) Bug fixes
a) EKF3 accel bias calculations bug fix
b) EKF3 accel bias process noise adjusted for greater robustness
c) GSF yaw numerical stability fix caused by compassmot
d) INS batch sampler fix to avoid watchdog if INS_LOG_BAT_CNT changed without rebooting
e) Memory corruption bug in the STM32H757 (very rare)
f) RC input on IOMCU bug fix (RC might not be regained if lost)
------------------------------------------------------------------
Rover 4.3.0-beta11/beta12 27-Mar-2023
Changes from 4.3.0-beta10
1) Bi-directional DShot fix for possible motor stop approx 72min after startup
------------------------------------------------------------------
Rover 4.3.0-beta10 01-Mar-2023
Changes from 4.3.0-beta9
1) Bug fixes
a) GPS unconfigured error fix for non-M10 uBlox GPS
b) Gremsy gimbal fix when attached to autopilot's serial3 (or higher)
c) MambaF405 2022 gets VTX power on support
d) MCU voltage enabled on H757 CPUs (including CubeOrangePlus)
e) PiccoloCAN fix for ESC voltage and current scaling
f) Servo gimbal mount yaw handling fix (only affects 3-axis servo gimbals)
------------------------------------------------------------------
Rover 4.3.0-beta9 14-Feb-2023
Changes from 4.3.0-beta8
1) AutoPilot specific enhancements
a) CubeOrangePlusBG support
b) Foxeer ReaperF745 supports external compass
c) MambaH743v4 supports VTX power
2) Bug fixes
a) Arming check fix if BARO_FIELD_ELEV set
b) Compass calibration diagonals set to 1,1,1 if incorrectly set to 0,0,0
c) Gimbal's yaw feed-forward set to zero when landed (affects Gremsy gimbals)
d) IOMCU double reset and safety disable fix
e) Logging fix for duplicate format messages
f) OpenDroneId sets emergency status on crash or chute deploy
g) Peripheral firmware updates using MAVCAN fixed
h) RC protocol cannot be changed once detected on boards with IOMCU
------------------------------------------------------------------
Rover 4.3.0-beta8 20-Jan-2023
Changes from 4.3.0-beta7
1) Bug fixes
a) MAVFTP fix to terminate session error (could cause FTP failures)
b) IMU fast fifo reset log message max frequency reduced
------------------------------------------------------------------
Rover 4.3.0-beta7 09-Jan-2023
Changes from 4.3.0-beta6
1) Autopilot related changes
a) AIRLink LTE module enable pin and HEAT_ params added
b) CUAV Nora/Nora+ bdshot firmware (allows Bi-directional DShot)
c) CubeOrange, CubeYellow gets fast reset of ICM20602
d) MambaH743v2 with dual ICM42688 supported
e) PixPilot-V6
2) MAVFTP speed improvement including faster param download
3) Bug fixes
a) Analog rangefinder GPIO pin arming check fixed
b) Arming check of AHRS/EKF vs GPS location disabled if GPS disabled
c) CRSF gets RC_OPTIONS for ELRS baudrate to avoid RC failsafes
d) Null pointer checks avoid watchdog when out of memory
e) Servo gimbal yaw jump to opposite side fixed
f) Siyi A8 gimbal driver's record video feature fixed
g) SToRM32 serial gimbal driver actual angle reporting fixed (pitch and yaw angle signs were reversed)
------------------------------------------------------------------
Rover 4.3.0-beta6 10-Dec-2022
Changes from 4.3.0-beta5
1) Arming check that main loop is running at configured speed (e.g. SCHED_LOOP_RATE)
2) uBlox M10 support
3) Autopilot specific changes
a) CubeOrange defaults to using 2nd IMU as primary
b) SIRF and SBP GPS disabled on BeastF7v2, MatekF405-STD, MAtekF405-Wing, omnibusf4pro
4) Bug fixes
a) Camera driver's CAM_MIN_INTERVAL fixed if pilot manually triggers extra picture
b) Main loop slowdown after arming fixed (parameter logging was causing delays)
c) Main loop's fast tasks always run (caused twitches in Loiter on heavily loaded CPUs)
d) MAVLink commands received on private channels checked for valid target sysid
e) ModalAI cameras support fixed (ODOMETRY message frame was consumed incorrectly)
f) Param reset after firmware load fixed on these boards
- BeastF7v2
- CubeYellow-bdshot
- f405-MatekAirspeed
- FlywooF745Nano
- KakuteF4Mini
- KakuteF7-bdshot
- MatekF405-bdshot
- MatekF405-STD
- MatekF405-Wing-bdshot
- MatekF765-SE
- MatekF765-Wing-bdshot
g) Siyi A8 gimbal support fixed
h) Windows builds move to compiling only 64-bit executables
------------------------------------------------------------------
Rover 4.3.0-beta5 17-Nov-2022
Changes from 4.3.0-beta4
1) Autopilot specific enhancements
a) ARKV6X support
b) MatekH743 supports 8 bi-directional dshot channels
c) Pixhawk boards support MS5607 baros
d) SpeedbyBee F405v3 support
2) Balancebot pitch control improvements and pitch limiting
3) DroneCAN Airspeed sensor support including hygrometer (aka water vapour) readings
4) EFI support (electronic fuel injection engines)
5) Harmonic Notch support (Rover only)
6) Pre-arm warning if multiple UARTs with SERIALx_PROTOCOL = RCIN
7) Siyi gimbal support
8) Bug fixes
a) AtomRCF405NAVI bootloader file name fixed
b) BRD_SAFETY_MASK fixed on boards with both FMU safety switch and IOMCU
c) Compass calibration continues even if a single compass's cal fails
d) Gremsy gimbal driver sends autopilot info at lower rate to save bandwidth
e) Invensense 42605 and 42609 IMUs use anti-aliasing filter and notch filter
f) OSD stats screen fix
g) RC input on serial port uses first UART with SERIALx_PROTOCOL = 23 (was using last)
h) RunCam caching fix with enablement and setup on 3-pos switch
i) RTK CAN GPS fix when GPSs conneted to separate CAN ports on autopilot
------------------------------------------------------------------
Rover 4.3.0-beta4 24-Oct-2022
Changes from 4.3.0-beta3
1) Scripting supports implementing AUX functions
2) Bug fixes
a) BMI085 accel scaling fixed
b) Build with gcc 11.3 fixed (developer only)
c) EKF3 alt discrepancy if GPS or baro alt changed soon after startup fixed
d) Harmonic Notch and ESC telem fix when motor outputs are non-contiguous
e) NMEA GPS's KSXT message parsing fixed (affected position accuracy)
f) Scripting random number generator fix
------------------------------------------------------------------
Rover 4.3.0-beta3 14-Oct-2022
Changes from 4.3.0-beta2
1) Pixhawk1-1M, fmuv2, fmuv3 display warning if firmware mismatches board's flash size (1M and 2M)
2) Scripting support for multi-byte i2c reads
3) Bug fixes
a) Airspeed CAN sensor ordering fixed (ordering could change if using multiple airspeed sensors)
b) BRD_SAFETY_MASK fix for enabling outputs when safety is on
c) Defaults.parm file processing fixed when a line has >100 characters and/or no new line (developer only)
d) NMEA serial output precision fixed (was only accurate to 1m, now accurate to 1cm)
------------------------------------------------------------------
Rover 4.3.0-beta2 04-Oct-2022
Changes from 4.3.0-beta1
1) Autopilot specific fixes and enhancements
a) AIRLink autopilot supports UART2
b) CUAV V6X supports CAN battery monitor by default
c) MatekF405-CAN board uses less memory to fix compass calibration issues
d) Pixhawk1-1M only supports uBlox and NMEA GPSs to save flash space
e) SkystarsH7HD-bdshot (allows Bi-directional DShot)
f) SkystarsH7HD supports VTX power by default
2) EFI support
a) Currawong ECU support (added as Electronic Fuel Injection driver)
b) Scripting support for EFI drivers (allows writing EFI drivers in Lua)
c) SkyPower and HFE CAN EFI drivers (via scripting)
3) Safety features
a) Arming check that SPIN_MIN less than 0.3 and greater than SPIN_ARM
b) Arming option to disable itermittant display of pre-arm warnings (see ARMING_OPTIONS)
4) Minor enhancements
a) Autopilot board names max length increased to 23 characters (was 13)
b) CAN actuators can report PWM equivalent values (eases debugging)
c) Log download speed improved for boards with "block" backends
d) Notch filter slew limit reduces chance of notch freq moving incorrectly
e) SLCAN disabled when vehicle is armed to reduce CPU load
5) Bug fixes
a) DO_JUMP mission command fixed if active command changed before changing to Auto mode
b) EKF3 altitude error fix when using dual GPSs and affinity enabled
c) FFT indexing bug fixed
d) Gimbal mount fix to default mode (see MNTx_DEFLT_MODE parameter)
e) MSP fix to report arm status to DJI FPV goggles
f) Notch fix for non-throttle notch (was being incorrectly disabled)
g) OSD fixes for params, font and resolution
h) RPM reporting from harmonic notch fixed
i) "Sending unknown message (50)" warning removed
j) SBF/GSOF/NOVA GPS auto detction of baud rate fixed
k) VideoTX fixes for buffer overruns and Tramp video transmitter support
------------------------------------------------------------------
Rover 4.3.0-beta1 14-Sep-2022
Changes from 4.2.3
1) Rover specific enhancements
a) Aux switch for SaveWP displays, "Mission Cleared" if vehicle not armed
b) Dock mode using modified precision landing library
c) Manual mode steering scaling with speed can be disabled using MANUAL_OPTIONS parameter
d) S-Curves for Auto, Guided, RTL
2) Rover specific bug fixes
a) Wheel encoder timestamp fix (WRC_xx params may need to be changed)
b) Auto mode stick mixing fixed (see STICK_MIXING parameter)
c) Arming check removed to support mixed Ackerman and skid-stering vehicles
3) New autopilot support
a) AtomRCF405
b) CubeOrange-SimOnHardWare
c) DevEBoxH7v2
d) KakuteH7Mini-Nand
e) KakuteH7v2
f) Mamba F405 Mk4
g) SkystarsH7HD
h) bi-directional dshot (aka "bdshot") versions for CubeOrange, CubeYellow, KakuteF7, KakuteH7, MatekF405-Wing, Matek F765, PH4-mini, Pixhawk-1M
4) EKF enhancements and fixes
a) EK3_GPS_VACC_MAX threshold to control when GPS altitude is used as alt source
b) EKF ring buffer fix for very slow sensor updates (those that update once every few seconds)
c) EKF3 source set change captured in Replay logs
5) Gimbal enhancements
a) Angle limit params renamed and scaled to degrees (e.g. MNT1_ROLL_MIN, MNT1_PITCH_MIN, etc)
b) BrushlessPWM driver (set MNT1_TYPE = 7) is unstabilized Servo driver
c) Dual mount support (see MNT1_, MNT2 params)
d) Gremsy driver added (set MNT1_TYPE = 6)
e) MAVLink gimbalv2 support including sending GIMBAL_DEVICE_STATUS_UPDATE (replaces MOUNT_STATUS message)
f) "Mount Lock" auxiliary switch supports follow and lock modes in RC targetting (aka earth-frame and body-frame)
g) RC channels to control gimbal set using RCx_OPTION = 212 (Roll), 213 (Pitch) or 214 (Yaw)
h) RC targetting rotation rate in deg/sec (see MNT1_RC_RATE which replaces MNT_JSTICK_SPD)
i) Yaw can be disabled on 3-axis gimbals (set MNTx_YAW_MIN = MNTx_YAW_MAX)
6) Notch filter enhancements
a) Attitude and filter logging at main loop rate
b) Batch sampler logging both pre and post-filter
c) FFT frame averaging
d) In-flight throttle notch parameter learning using averaged FFTs
e) Triple harmonic notch
7) RemoteId and SecureBoot enhancements
a) Remote update of secure boot's public keys (also allows remote unlocking of bootloader)
8) Safety enhancements
a) crash_dump.bin file saved to SD Card on startup (includes details re cause of software failures)
b) Disabling Fence clears any active breaches (e.g. FENCE_TYPE = 0 will clear breaches)
c) "GPS Glitch" message clarified to "GPS Glitch or Compass error"
d) Pre-arm check that configured AHRS is being used (e.g. checks AHRS_EKF_TYPE not changed since boot)
e) Pre-arm check that gimbals are healthy (currently only for Gremsy gimbals, others in future release)
f) Pre-arm check that scripts are running
g) Pre-arm messages are correctly prefixed with "PreArm:" (instead of "Arm:")
h) RC auxiliary switch option for Arm / Emergency Stop
9) Scripting enhancements
a) CAN2 port bindings to allow scripts to communicate on 2nd CAN bus
b) ESC RPM bindings to allow scripts to report engine RPM
c) Gimbal bingings to allow scripts to control gimbal
d) Pre-arm check bindings (allows scripts to check if pre-arm checks have passed)
e) Semicolon (:) and period (.) supported (e.g both Logger:write() and Logger.write will work)
10) Sensor driver enhancements
a) Benewake H30 radar support
b) BMI270 IMU performance improvements
c) IRC Tramp VTX suppor
d) Logging pause-able with auxiliary switch. see RCx_OPTION = 165 (Pause Stream Logging)
e) Proximity sensor support for up to 3 sensors
f) Precision Landing consumes LANDING_TARGET MAVLink message's PositionX,Y,Z fields
g) RichenPower generator maintenance-required messages can be suppressed using GEN_OPTIONS param
h) TeraRanger Neo rangefinder support
i) GPS support to provide ellipsoid altitude instead of AMSL (see GPS_DRV_OPTIONS)
j) W25N01GV 1Gb flash support
11) Bug fixes
a) Accel calibration throws away queued commands from GCS (avoids commands being run long after they were sent)
b) Cygbot proximity sensor fix to support different orientations (see PRXx_ORIENT)
c) Lutan EFI message flood reduced
d) Missions download to GCS corruption avoided by checking serial buffer has space
e) Safety switch disabled if IOMCU is disabled (see BRD_IO_ENABLE=0)
f) Script restart memory leak fixed
12) Developer items
a) Fast loop task list available in real-time using @SYS/tasks.txt
b) Parameter defaults sent to GCS with param FTP and recorded in onboard logs
c) ROS+ArduPilot environment installation script
d) Sim on Hardware allows simulator to run on autopilot (good for exhibitions)
e) Timer info available in real-time using @SYS/timers.txt
------------------------------------------------------------------
Rover 4.2.3 30-Aug-2022 Rover 4.2.3 30-Aug-2022
Changes from 4.2.3-rc3 Changes from 4.2.3-rc3
1) OpenDroneId bug fix to consume open-drone-id-system-update message 1) OpenDroneId bug fix to consume open-drone-id-system-update message

View File

@ -6,14 +6,14 @@
#include "ap_version.h" #include "ap_version.h"
#define THISFIRMWARE "ArduRover V4.3.0-dev" #define THISFIRMWARE "ArduRover V4.3.0-beta14"
// the following line is parsed by the autotest scripts // the following line is parsed by the autotest scripts
#define FIRMWARE_VERSION 4,3,0,FIRMWARE_VERSION_TYPE_DEV #define FIRMWARE_VERSION 4,3,0,FIRMWARE_VERSION_TYPE_BETA+14
#define FW_MAJOR 4 #define FW_MAJOR 4
#define FW_MINOR 3 #define FW_MINOR 3
#define FW_PATCH 0 #define FW_PATCH 0
#define FW_TYPE FIRMWARE_VERSION_TYPE_DEV #define FW_TYPE FIRMWARE_VERSION_TYPE_BETA
#include <AP_Common/AP_FWVersionDefine.h> #include <AP_Common/AP_FWVersionDefine.h>

View File

@ -43,6 +43,7 @@ TARGET_HW_ARK_CAN_GPS 81
TARGET_HW_ARK_CAN_RTK_GPS 82 TARGET_HW_ARK_CAN_RTK_GPS 82
TARGET_HW_FF_RTK_CAN_GPS 85 TARGET_HW_FF_RTK_CAN_GPS 85
TARGET_HW_ATL_MANTIS_EDU 97 TARGET_HW_ATL_MANTIS_EDU 97
TARGET_HW_ARK_FMU_V6X 57
Reserved PX4 [BL] FMU v5X.x 51 Reserved PX4 [BL] FMU v5X.x 51
@ -178,6 +179,11 @@ AP_HW_SKYSTARSH7HD 1075
AP_HW_PixSurveyA1 1076 AP_HW_PixSurveyA1 1076
AP_HW_AEROFOX_AIRSPEED 1077 AP_HW_AEROFOX_AIRSPEED 1077
AP_HW_ATOMRCF405 1078 AP_HW_ATOMRCF405 1078
AP_HW_CUBEPILOT_CANMOD 1079
AP_HW_AEROFOX_PMU 1080
AP_HW_JHEMCUGF16F405 1081
AP_HW_SPEEDYBEEF4V3 1082
AP_HW_PixPilot-V6 1083
AP_HW_CUBEORANGE_PERIPH 1400 AP_HW_CUBEORANGE_PERIPH 1400
AP_HW_CUBEBLACK_PERIPH 1401 AP_HW_CUBEBLACK_PERIPH 1401

View File

@ -29,12 +29,12 @@ const mcu_des_t mcu_descriptions[] = {
}; };
const mcu_rev_t silicon_revs[] = { const mcu_rev_t silicon_revs[] = {
{MCU_REV_STM32F4_REV_3, '3', false}, /* Revision 3 */ {MCU_REV_STM32F4_REV_3, '3'}, /* Revision 3 */
{MCU_REV_STM32F4_REV_A, 'A', true}, /* Revision A */ {MCU_REV_STM32F4_REV_A, 'A'}, /* Revision A */
{MCU_REV_STM32F4_REV_Z, 'Z', true}, /* Revision Z */ {MCU_REV_STM32F4_REV_Z, 'Z'}, /* Revision Z */
{MCU_REV_STM32F4_REV_Y, 'Y', true}, /* Revision Y */ {MCU_REV_STM32F4_REV_Y, 'Y'}, /* Revision Y */
{MCU_REV_STM32F4_REV_1, '1', true}, /* Revision 1 */ {MCU_REV_STM32F4_REV_1, '1'}, /* Revision 1 */
}; };
#endif // STM32F4 #endif // STM32F4

View File

@ -13,10 +13,10 @@ mcu_des_t mcu_descriptions[] = {
}; };
const mcu_rev_t silicon_revs[] = { const mcu_rev_t silicon_revs[] = {
{0x1001, 'Z', false}, {0x1001, 'Z'},
{0x1003, 'Y', false}, {0x1003, 'Y'},
{0x2001, 'X', false}, {0x2001, 'X'},
{0x2003, 'V', false}, {0x2003, 'V'},
}; };
#endif // STM32H7 #endif // STM32H7

View File

@ -274,24 +274,6 @@ uint32_t get_mcu_desc(uint32_t max, uint8_t *revstr)
return strp - revstr; return strp - revstr;
} }
/*
see if we should limit flash to 1M on devices with older revisions
*/
bool check_limit_flash_1M(void)
{
#ifdef STM32F427xx
uint32_t idcode = (*(uint32_t *)DBGMCU_BASE);
uint16_t revid = ((idcode & REVID_MASK) >> 16);
for (int i = 0; i < ARRAY_SIZE(silicon_revs); i++) {
if (silicon_revs[i].revid == revid) {
return silicon_revs[i].limit_flash_size_1M;
}
}
#endif
return false;
}
void led_on(unsigned led) void led_on(unsigned led)
{ {
#ifdef HAL_GPIO_PIN_LED_BOOTLOADER #ifdef HAL_GPIO_PIN_LED_BOOTLOADER

View File

@ -36,7 +36,6 @@ bool flash_write_buffer(uint32_t address, const uint32_t *v, uint8_t nwords);
uint32_t get_mcu_id(void); uint32_t get_mcu_id(void);
uint32_t get_mcu_desc(uint32_t len, uint8_t *buf); uint32_t get_mcu_desc(uint32_t len, uint8_t *buf);
bool check_limit_flash_1M(void);
uint32_t board_get_rtc_signature(void); uint32_t board_get_rtc_signature(void);
void board_set_rtc_signature(uint32_t sig); void board_set_rtc_signature(uint32_t sig);
@ -62,5 +61,4 @@ typedef struct mcu_des_t {
typedef struct mcu_rev_t { typedef struct mcu_rev_t {
uint16_t revid; uint16_t revid;
char rev; char rev;
bool limit_flash_size_1M;
} mcu_rev_t; } mcu_rev_t;

View File

@ -219,7 +219,8 @@ public:
void rcout_init(); void rcout_init();
void rcout_init_1Hz(); void rcout_init_1Hz();
void rcout_esc(int16_t *rc, uint8_t num_channels); void rcout_esc(int16_t *rc, uint8_t num_channels);
void rcout_srv(const uint8_t actuator_id, const float command_value); void rcout_srv_unitless(const uint8_t actuator_id, const float command_value);
void rcout_srv_PWM(const uint8_t actuator_id, const float command_value);
void rcout_update(); void rcout_update();
void rcout_handle_safety_state(uint8_t safety_state); void rcout_handle_safety_state(uint8_t safety_state);
#endif #endif

View File

@ -796,11 +796,14 @@ static void handle_act_command(CanardInstance* ins, CanardRxTransfer* transfer)
} }
for (uint8_t i=0; i < data_count; i++) { for (uint8_t i=0; i < data_count; i++) {
if (data[i].command_type != UAVCAN_EQUIPMENT_ACTUATOR_COMMAND_COMMAND_TYPE_UNITLESS) { switch (data[i].command_type) {
// this is the only type we support case UAVCAN_EQUIPMENT_ACTUATOR_COMMAND_COMMAND_TYPE_UNITLESS:
continue; periph.rcout_srv_unitless(data[i].actuator_id, data[i].command_value);
break;
case UAVCAN_EQUIPMENT_ACTUATOR_COMMAND_COMMAND_TYPE_PWM:
periph.rcout_srv_PWM(data[i].actuator_id, data[i].command_value);
break;
} }
periph.rcout_srv(data[i].actuator_id, data[i].command_value);
} }
} }
#endif // HAL_PERIPH_ENABLE_RC_OUT #endif // HAL_PERIPH_ENABLE_RC_OUT

View File

@ -99,7 +99,7 @@ void AP_Periph_FW::rcout_esc(int16_t *rc, uint8_t num_channels)
rcout_has_new_data_to_update = true; rcout_has_new_data_to_update = true;
} }
void AP_Periph_FW::rcout_srv(uint8_t actuator_id, const float command_value) void AP_Periph_FW::rcout_srv_unitless(uint8_t actuator_id, const float command_value)
{ {
#if HAL_PWM_COUNT > 0 #if HAL_PWM_COUNT > 0
const SRV_Channel::Aux_servo_function_t function = SRV_Channel::Aux_servo_function_t(SRV_Channel::k_rcin1 + actuator_id - 1); const SRV_Channel::Aux_servo_function_t function = SRV_Channel::Aux_servo_function_t(SRV_Channel::k_rcin1 + actuator_id - 1);
@ -109,6 +109,16 @@ void AP_Periph_FW::rcout_srv(uint8_t actuator_id, const float command_value)
#endif #endif
} }
void AP_Periph_FW::rcout_srv_PWM(uint8_t actuator_id, const float command_value)
{
#if HAL_PWM_COUNT > 0
const SRV_Channel::Aux_servo_function_t function = SRV_Channel::Aux_servo_function_t(SRV_Channel::k_rcin1 + actuator_id - 1);
SRV_Channels::set_output_pwm(function, uint16_t(command_value+0.5));
rcout_has_new_data_to_update = true;
#endif
}
void AP_Periph_FW::rcout_handle_safety_state(uint8_t safety_state) void AP_Periph_FW::rcout_handle_safety_state(uint8_t safety_state)
{ {
if (safety_state == 255) { if (safety_state == 255) {

View File

@ -10,7 +10,6 @@ ATC_BAL_FLTE,0
ATC_BAL_I,7 ATC_BAL_I,7
ATC_BAL_IMAX,1 ATC_BAL_IMAX,1
ATC_BAL_P,5 ATC_BAL_P,5
ATC_BAL_SPD_FF,1.0
ATC_BRAKE,1 ATC_BRAKE,1
ATC_STR_ACC_MAX,120 ATC_STR_ACC_MAX,120
BAL_PITCH_MAX,10 BAL_PITCH_MAX,10

View File

@ -25,6 +25,9 @@ TMODE_TMIN 0.9
RELAY_PIN 54 RELAY_PIN 54
RELAY_PIN2 55 RELAY_PIN2 55
RELAY_DEFAULT 1 RELAY_DEFAULT 1
# Set to GPIO so they are used as RELAY
SERVO5_FUNCTION -1
SERVO6_FUNCTION -1
AHRS_ORIENTATION 12 AHRS_ORIENTATION 12
COMPASS_EXTERNAL 1 COMPASS_EXTERNAL 1

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -114,6 +114,14 @@ class Board:
else: else:
cfg.msg("Enabled firmware ID checking", 'no', color='YELLOW') cfg.msg("Enabled firmware ID checking", 'no', color='YELLOW')
if cfg.options.enable_gps_logging:
env.DEFINES.update(
AP_GPS_DEBUG_LOGGING_ENABLED=1,
)
cfg.msg("GPS Debug Logging", 'yes')
else:
cfg.msg("GPS Debug Logging", 'no', color='YELLOW')
# allow enable of custom controller for any board # allow enable of custom controller for any board
# enabled on sitl by default # enabled on sitl by default
if (cfg.options.enable_custom_controller or self.get_name() == "sitl") and not cfg.options.no_gcs: if (cfg.options.enable_custom_controller or self.get_name() == "sitl") and not cfg.options.no_gcs:
@ -241,6 +249,9 @@ class Board:
env.CXXFLAGS += [ env.CXXFLAGS += [
'-Werror=implicit-fallthrough', '-Werror=implicit-fallthrough',
] ]
env.CXXFLAGS += [
'-fcheck-new',
]
if cfg.env.DEBUG: if cfg.env.DEBUG:
env.CFLAGS += [ env.CFLAGS += [
@ -250,6 +261,10 @@ class Board:
env.DEFINES.update( env.DEFINES.update(
HAL_DEBUG_BUILD = 1, HAL_DEBUG_BUILD = 1,
) )
elif cfg.options.g:
env.CFLAGS += [
'-g',
]
if cfg.env.COVERAGE: if cfg.env.COVERAGE:
env.CFLAGS += [ env.CFLAGS += [
'-fprofile-arcs', '-fprofile-arcs',

View File

@ -235,7 +235,7 @@ def sign_firmware(image, private_keyfile):
try: try:
import monocypher import monocypher
except ImportError: except ImportError:
Logs.error("Please install monocypher with: python3 -m pip install pymonocypher") Logs.error("Please install monocypher with: python3 -m pip install pymonocypher==3.1.3.2")
return None return None
try: try:
key = open(private_keyfile, 'r').read() key = open(private_keyfile, 'r').read()
@ -704,6 +704,7 @@ def build(bld):
'fiprintf','printf', 'fiprintf','printf',
'fopen', 'fflush', 'fwrite', 'fread', 'fputs', 'fgets', 'fopen', 'fflush', 'fwrite', 'fread', 'fputs', 'fgets',
'clearerr', 'fseek', 'ferror', 'fclose', 'tmpfile', 'getc', 'ungetc', 'feof', 'clearerr', 'fseek', 'ferror', 'fclose', 'tmpfile', 'getc', 'ungetc', 'feof',
'ftell', 'freopen', 'remove', 'vfprintf', 'fscanf' ] 'ftell', 'freopen', 'remove', 'vfprintf', 'fscanf',
'_gettimeofday', '_times', '_times_r', '_gettimeofday_r', 'time', 'clock' ]
for w in wraplist: for w in wraplist:
bld.env.LINKFLAGS += ['-Wl,--wrap,%s' % w] bld.env.LINKFLAGS += ['-Wl,--wrap,%s' % w]

View File

@ -264,27 +264,17 @@ class AutoTestCopter(AutoTest):
self.do_RTL() self.do_RTL()
def watch_altitude_maintained(self, min_alt, max_alt, timeout=10):
'''watch alt, relative alt must remain between min_alt and max_alt'''
tstart = self.get_sim_time_cached()
while True:
if self.get_sim_time_cached() - tstart > timeout:
return
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
if m.alt <= min_alt:
raise NotAchievedException("Altitude not maintained: want >%f got=%f" % (min_alt, m.alt))
def ModeAltHold(self): def ModeAltHold(self):
'''Test AltHold Mode''' '''Test AltHold Mode'''
self.takeoff(10, mode="ALT_HOLD") self.takeoff(10, mode="ALT_HOLD")
self.watch_altitude_maintained(9, 11, timeout=5) self.watch_altitude_maintained(altitude_min=9, altitude_max=11)
# feed in full elevator and aileron input and make sure we # feed in full elevator and aileron input and make sure we
# retain altitude: # retain altitude:
self.set_rc_from_map({ self.set_rc_from_map({
1: 1000, 1: 1000,
2: 1000, 2: 1000,
}) })
self.watch_altitude_maintained(9, 11, timeout=5) self.watch_altitude_maintained(altitude_min=9, altitude_max=11)
self.set_rc_from_map({ self.set_rc_from_map({
1: 1500, 1: 1500,
2: 1500, 2: 1500,
@ -1119,7 +1109,7 @@ class AutoTestCopter(AutoTest):
self.change_mode("LAND") self.change_mode("LAND")
# check vehicle descends to 2m or less within 40 seconds # check vehicle descends to 2m or less within 40 seconds
self.wait_altitude(-5, 2, timeout=40, relative=True) self.wait_altitude(-5, 2, timeout=50, relative=True)
# force disarm of vehicle (it will likely not automatically disarm) # force disarm of vehicle (it will likely not automatically disarm)
self.disarm_vehicle(force=True) self.disarm_vehicle(force=True)
@ -2612,6 +2602,54 @@ class AutoTestCopter(AutoTest):
self.wait_disarmed() self.wait_disarmed()
self.progress("MOTORS DISARMED OK") self.progress("MOTORS DISARMED OK")
def GuidedEKFLaneChange(self):
'''test lane change with GPS diff on startup'''
self.set_parameters({
"EK3_SRC1_POSZ": 3,
"EK3_AFFINITY" : 1,
"GPS_TYPE2" : 1,
"SIM_GPS2_DISABLE" : 0,
"SIM_GPS2_GLTCH_Z" : -30
})
self.reboot_sitl()
self.change_mode("GUIDED")
self.wait_ready_to_arm()
self.progress("waiting for both EKF lanes to init")
self.delay_sim_time(10)
self.set_parameters({
"SIM_GPS2_GLTCH_Z" : 0
})
self.progress("waiting for EKF to do a position Z reset")
self.delay_sim_time(20)
self.arm_vehicle()
self.user_takeoff(alt_min=20)
m = self.mav.recv_match(type='GPS_RAW_INT', blocking=True)
gps_alt = m.alt*0.001
self.progress("Initial guided alt=%.1fm" % gps_alt)
self.context_collect('STATUSTEXT')
self.progress("force a lane change")
self.set_parameters({
"INS_ACCOFFS_X" : 5
})
self.wait_statustext("EKF3 lane switch 1", timeout=10, check_context=True)
self.delay_sim_time(10)
m = self.mav.recv_match(type='GPS_RAW_INT', blocking=True)
gps_alt2 = m.alt*0.001
alt_change = gps_alt - gps_alt2
self.progress("GPS Alt change by %.1fm" % abs(alt_change))
if abs(alt_change) > 2:
raise NotAchievedException("Altitude changed on lane switch %.1fm" % alt_change)
self.disarm_vehicle(force=True)
self.reboot_sitl()
def MotorFail(self, fail_servo=0, fail_mul=0.0, holdtime=30): def MotorFail(self, fail_servo=0, fail_mul=0.0, holdtime=30):
"""Test flight with reduced motor efficiency""" """Test flight with reduced motor efficiency"""
@ -4572,7 +4610,7 @@ class AutoTestCopter(AutoTest):
self.change_mode("STABILIZE") self.change_mode("STABILIZE")
self.change_mode("GUIDED") self.change_mode("GUIDED")
self.set_rc(3, 1700) self.set_rc(3, 1700)
self.watch_altitude_maintained(-1, 0.2) # should not take off in guided self.watch_altitude_maintained(altitude_min=-1, altitude_max=0.2) # should not take off in guided
self.run_cmd_do_set_mode( self.run_cmd_do_set_mode(
"ACRO", "ACRO",
want_result=mavutil.mavlink.MAV_RESULT_FAILED) want_result=mavutil.mavlink.MAV_RESULT_FAILED)
@ -9037,6 +9075,7 @@ class AutoTestCopter(AutoTest):
self.DefaultIntervalsFromFiles, self.DefaultIntervalsFromFiles,
self.GPSTypes, self.GPSTypes,
self.MultipleGPS, self.MultipleGPS,
self.GuidedEKFLaneChange,
]) ])
return ret return ret

View File

@ -1723,6 +1723,42 @@ class AutoTestPlane(AutoTest):
self.run_subtest("Mission test", self.run_subtest("Mission test",
lambda: self.fly_mission("ap1.txt", strict=False)) lambda: self.fly_mission("ap1.txt", strict=False))
def PitotBlockage(self):
'''Test detection and isolation of a blocked pitot tube'''
self.set_parameters({
"ARSPD_OPTIONS": 15,
"ARSPD_USE": 1,
"SIM_WIND_SPD": 7,
"SIM_WIND_DIR": 0,
"ARSPD_WIND_MAX": 15,
})
self.change_mode("TAKEOFF")
self.wait_ready_to_arm()
self.arm_vehicle()
# simulate the effect of a blocked pitot tube
self.set_parameter("ARSPD_RATIO", 0.1)
self.delay_sim_time(10)
if (self.get_parameter("ARSPD_USE") == 0):
self.progress("Faulty Sensor Disabled")
else:
raise NotAchievedException("Airspeed Sensor Not Disabled")
self.delay_sim_time(20)
# simulate the effect of blockage partially clearing
self.set_parameter("ARSPD_RATIO", 1.0)
self.delay_sim_time(60)
if (self.get_parameter("ARSPD_USE") == 0):
self.progress("Faulty Sensor Remains Disabled")
else:
raise NotAchievedException("Fault Sensor Re-Enabled")
# simulate the effect of blockage fully clearing
self.set_parameter("ARSPD_RATIO", 2.0)
self.delay_sim_time(60)
if (self.get_parameter("ARSPD_USE") == 1):
self.progress("Sensor Re-Enabled")
else:
raise NotAchievedException("Airspeed Sensor Not Re-Enabled")
self.disarm_vehicle(force=True)
def AIRSPEED_AUTOCAL(self): def AIRSPEED_AUTOCAL(self):
'''Test AIRSPEED_AUTOCAL''' '''Test AIRSPEED_AUTOCAL'''
self.progress("Ensure no AIRSPEED_AUTOCAL on ground") self.progress("Ensure no AIRSPEED_AUTOCAL on ground")
@ -3393,22 +3429,6 @@ class AutoTestPlane(AutoTest):
attempt_fence_breached_disable(start_mode="FBWA", end_mode="FBWA", expected_mode="GUIDED", action=6) attempt_fence_breached_disable(start_mode="FBWA", end_mode="FBWA", expected_mode="GUIDED", action=6)
attempt_fence_breached_disable(start_mode="FBWA", end_mode="FBWA", expected_mode="GUIDED", action=7) attempt_fence_breached_disable(start_mode="FBWA", end_mode="FBWA", expected_mode="GUIDED", action=7)
def run_auxfunc(self,
function,
level,
want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED):
self.run_cmd(
mavutil.mavlink.MAV_CMD_DO_AUX_FUNCTION,
function, # p1
level, # p2
0, # p3
0, # p4
0, # p5
0, # p6
0, # p7
want_result=want_result
)
def MAV_DO_AUX_FUNCTION(self): def MAV_DO_AUX_FUNCTION(self):
'''Test triggering Auxiliary Functions via mavlink''' '''Test triggering Auxiliary Functions via mavlink'''
self.context_collect('STATUSTEXT') self.context_collect('STATUSTEXT')
@ -3925,6 +3945,38 @@ class AutoTestPlane(AutoTest):
self.disarm_vehicle(force=True) self.disarm_vehicle(force=True)
self.reboot_sitl() self.reboot_sitl()
def AltResetBadGPS(self):
'''Tests the handling of poor GPS lock pre-arm alt resets'''
self.set_parameters({
"SIM_GPS_GLITCH_Z": 0,
"SIM_GPS_ACC": 0.3,
})
self.wait_ready_to_arm()
m = self.assert_receive_message('GLOBAL_POSITION_INT')
relalt = m.relative_alt*0.001
if abs(relalt) > 3:
raise NotAchievedException("Bad relative alt %.1f" % relalt)
self.progress("Setting low accuracy, glitching GPS")
self.set_parameter("SIM_GPS_ACC", 40)
self.set_parameter("SIM_GPS_GLITCH_Z", -47)
self.progress("Waiting 10s for height update")
self.delay_sim_time(10)
self.wait_ready_to_arm()
self.arm_vehicle()
m = self.assert_receive_message('GLOBAL_POSITION_INT')
relalt = m.relative_alt*0.001
if abs(relalt) > 3:
raise NotAchievedException("Bad glitching relative alt %.1f" % relalt)
self.disarm_vehicle()
# reboot to clear potentially bad state
self.reboot_sitl()
def tests(self): def tests(self):
'''return list of all tests''' '''return list of all tests'''
ret = super(AutoTestPlane, self).tests() ret = super(AutoTestPlane, self).tests()
@ -3943,6 +3995,7 @@ class AutoTestPlane(AutoTest):
self.TestGripperMission, self.TestGripperMission,
self.Parachute, self.Parachute,
self.ParachuteSinkRate, self.ParachuteSinkRate,
self.PitotBlockage,
self.AIRSPEED_AUTOCAL, self.AIRSPEED_AUTOCAL,
self.RangeFinder, self.RangeFinder,
self.FenceStatic, self.FenceStatic,
@ -4000,6 +4053,7 @@ class AutoTestPlane(AutoTest):
self.GlideSlopeThresh, self.GlideSlopeThresh,
self.HIGH_LATENCY2, self.HIGH_LATENCY2,
self.MidAirDisarmDisallowed, self.MidAirDisarmDisallowed,
self.AltResetBadGPS,
]) ])
return ret return ret

View File

@ -112,10 +112,10 @@ class AutoTestSub(AutoTest):
msg = self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True, timeout=5) msg = self.mav.recv_match(type='GLOBAL_POSITION_INT', blocking=True, timeout=5)
if msg is None: if msg is None:
raise NotAchievedException("Did not get GLOBAL_POSITION_INT") raise NotAchievedException("Did not get GLOBAL_POSITION_INT")
pwm = 1000 pwm = 1300
if msg.relative_alt/1000.0 < -5.5: if msg.relative_alt/1000.0 < -6.0:
# need to g`o up, not down! # need to g`o up, not down!
pwm = 2000 pwm = 1700
self.set_rc(Joystick.Throttle, pwm) self.set_rc(Joystick.Throttle, pwm)
self.wait_altitude(altitude_min=-6, altitude_max=-5) self.wait_altitude(altitude_min=-6, altitude_max=-5)
self.set_rc(Joystick.Throttle, 1500) self.set_rc(Joystick.Throttle, 1500)

View File

@ -10,6 +10,11 @@ from __future__ import print_function
import atexit import atexit
import fnmatch import fnmatch
import copy import copy
try:
import distutils.dir_util
except ImportError:
# we copy with this with try/except in copy_tree, below
pass
import glob import glob
import optparse import optparse
import os import os
@ -20,7 +25,6 @@ import subprocess
import sys import sys
import time import time
import traceback import traceback
from distutils.dir_util import copy_tree
import rover import rover
import arducopter import arducopter
@ -661,6 +665,13 @@ class TestResults(object):
f.write(badge) f.write(badge)
def copy_tree(f, t, dirs_exist_ok=False):
try:
distutils.dir_util.copy_tree(f, t)
except Exception:
shutil.copytree(f, t, dirs_exist_ok=dirs_exist_ok)
def write_webresults(results_to_write): def write_webresults(results_to_write):
"""Write webpage results.""" """Write webpage results."""
t = mavtemplate.MAVTemplate() t = mavtemplate.MAVTemplate()
@ -671,7 +682,7 @@ def write_webresults(results_to_write):
f.close() f.close()
for f in glob.glob(util.reltopdir('Tools/autotest/web/*.png')): for f in glob.glob(util.reltopdir('Tools/autotest/web/*.png')):
shutil.copy(f, buildlogs_path(os.path.basename(f))) shutil.copy(f, buildlogs_path(os.path.basename(f)))
copy_tree(util.reltopdir("Tools/autotest/web/css"), buildlogs_path("css")) copy_tree(util.reltopdir("Tools/autotest/web/css"), buildlogs_path("css"), dirs_exist_ok=True)
results_to_write.generate_badge() results_to_write.generate_badge()

View File

@ -60,7 +60,6 @@ class AutoTestBalanceBot(AutoTestRover):
'''make sure wheel encoders are generally working''' '''make sure wheel encoders are generally working'''
ex = None ex = None
try: try:
self.set_parameter("ATC_BAL_SPD_FF", 0)
self.set_parameter("WENC_TYPE", 10) self.set_parameter("WENC_TYPE", 10)
self.set_parameter("AHRS_EKF_TYPE", 10) self.set_parameter("AHRS_EKF_TYPE", 10)
self.reboot_sitl() self.reboot_sitl()

View File

@ -3398,6 +3398,22 @@ class AutoTest(ABC):
def get_mission_count(self): def get_mission_count(self):
return self.get_parameter("MIS_TOTAL") return self.get_parameter("MIS_TOTAL")
def run_auxfunc(self,
function,
level,
want_result=mavutil.mavlink.MAV_RESULT_ACCEPTED):
self.run_cmd(
mavutil.mavlink.MAV_CMD_DO_AUX_FUNCTION,
function, # p1
level, # p2
0, # p3
0, # p4
0, # p5
0, # p6
0, # p7
want_result=want_result
)
def assert_mission_count(self, expected): def assert_mission_count(self, expected):
count = self.get_mission_count() count = self.get_mission_count()
if count != expected: if count != expected:
@ -5837,6 +5853,14 @@ class AutoTest(ABC):
**kwargs **kwargs
) )
def watch_altitude_maintained(self, altitude_min, altitude_max, minimum_duration=5, relative=True):
"""Watch altitude is maintained or not between altitude_min and altitude_max during minimum_duration"""
return self.wait_altitude(altitude_min=altitude_min,
altitude_max=altitude_max,
relative=relative,
minimum_duration=minimum_duration,
timeout=minimum_duration + 1)
def wait_climbrate(self, speed_min, speed_max, timeout=30, **kwargs): def wait_climbrate(self, speed_min, speed_max, timeout=30, **kwargs):
"""Wait for a given vertical rate.""" """Wait for a given vertical rate."""
assert speed_min <= speed_max, "Minimum speed should be less than maximum speed." assert speed_min <= speed_max, "Minimum speed should be less than maximum speed."
@ -7635,6 +7659,11 @@ Also, ignores heartbeats not from our target system'''
condition='MISSION_ITEM_INT.mission_type==%u' % mission_type) condition='MISSION_ITEM_INT.mission_type==%u' % mission_type)
if m is None: if m is None:
raise NotAchievedException("Did not receive MISSION_ITEM_INT") raise NotAchievedException("Did not receive MISSION_ITEM_INT")
if m.target_system != self.mav.source_system:
raise NotAchievedException("Wrong target system (want=%u got=%u)" %
(self.mav.source_system, m.target_system))
if m.target_component != self.mav.source_component:
raise NotAchievedException("Wrong target component")
self.progress("Got (%s)" % str(m)) self.progress("Got (%s)" % str(m))
if m.mission_type != mission_type: if m.mission_type != mission_type:
raise NotAchievedException("Received waypoint of wrong type") raise NotAchievedException("Received waypoint of wrong type")

View File

@ -1,7 +1,6 @@
ATC_BAL_P 18.0 ATC_BAL_P 3.5
ATC_BAL_I 80.0 ATC_BAL_I 5.0
ATC_BAL_D 0.005 ATC_BAL_D 0.06
ATC_BAL_SPD_FF 0.000000
ATC_SPEED_P 0.9 ATC_SPEED_P 0.9
ATC_SPEED_I 0.5 ATC_SPEED_I 0.5
AHRS_EKF_TYPE 10 AHRS_EKF_TYPE 10

View File

@ -113,6 +113,7 @@ known_units = {
'octal' : 'octal' , 'octal' : 'octal' ,
'RPM' : 'Revolutions Per Minute', 'RPM' : 'Revolutions Per Minute',
'kg/m/m' : 'kilograms per square meter', # metre is the SI unit name, meter is the american spelling of it 'kg/m/m' : 'kilograms per square meter', # metre is the SI unit name, meter is the american spelling of it
'kg/m/m/m': 'kilograms per cubic meter',
} }
required_param_fields = [ required_param_fields = [

View File

@ -21,7 +21,7 @@ import pexpect
from pymavlink.rotmat import Vector3, Matrix3 from pymavlink.rotmat import Vector3, Matrix3
if (sys.version_info[0] >= 3): if sys.version_info[0] >= 3:
ENCODING = 'ascii' ENCODING = 'ascii'
else: else:
ENCODING = None ENCODING = None
@ -53,11 +53,11 @@ def mps2kt(x):
def topdir(): def topdir():
"""Return top of git tree where autotest is running from.""" """Return top of git tree where autotest is running from."""
d = os.path.dirname(os.path.realpath(__file__)) d = os.path.dirname(os.path.realpath(__file__))
assert(os.path.basename(d) == 'pysim') assert os.path.basename(d) == 'pysim'
d = os.path.dirname(d) d = os.path.dirname(d)
assert(os.path.basename(d) == 'autotest') assert os.path.basename(d) == 'autotest'
d = os.path.dirname(d) d = os.path.dirname(d)
assert(os.path.basename(d) == 'Tools') assert os.path.basename(d) == 'Tools'
d = os.path.dirname(d) d = os.path.dirname(d)
return d return d
@ -92,7 +92,7 @@ def rmfile(path):
"""Remove a file if it exists.""" """Remove a file if it exists."""
try: try:
os.unlink(path) os.unlink(path)
except Exception: except (OSError, FileNotFoundError):
pass pass
@ -368,10 +368,10 @@ def kill_mac_terminal():
class FakeMacOSXSpawn(object): class FakeMacOSXSpawn(object):
'''something that looks like a pspawn child so we can ignore attempts """something that looks like a pspawn child so we can ignore attempts
to pause (and otherwise kill(1) SITL. MacOSX using osascript to to pause (and otherwise kill(1) SITL. MacOSX using osascript to
start/stop sitl start/stop sitl
''' """
def __init__(self): def __init__(self):
pass pass
@ -435,8 +435,8 @@ def start_SITL(binary,
# attach gdb to the gdbserver: # attach gdb to the gdbserver:
f = open("/tmp/x.gdb", "w") f = open("/tmp/x.gdb", "w")
f.write("target extended-remote localhost:3333\nc\n") f.write("target extended-remote localhost:3333\nc\n")
for breakpoint in breakpoints: for breakingpoint in breakpoints:
f.write("b %s\n" % (breakpoint,)) f.write("b %s\n" % (breakingpoint,))
if disable_breakpoints: if disable_breakpoints:
f.write("disable\n") f.write("disable\n")
f.close() f.close()
@ -445,8 +445,8 @@ def start_SITL(binary,
elif gdb: elif gdb:
f = open("/tmp/x.gdb", "w") f = open("/tmp/x.gdb", "w")
f.write("set pagination off\n") f.write("set pagination off\n")
for breakpoint in breakpoints: for breakingpoint in breakpoints:
f.write("b %s\n" % (breakpoint,)) f.write("b %s\n" % (breakingpoint,))
if disable_breakpoints: if disable_breakpoints:
f.write("disable\n") f.write("disable\n")
if not gdb_no_tui: if not gdb_no_tui:
@ -466,8 +466,8 @@ def start_SITL(binary,
'gdb', '-x', '/tmp/x.gdb', binary, '--args']) 'gdb', '-x', '/tmp/x.gdb', binary, '--args'])
elif lldb: elif lldb:
f = open("/tmp/x.lldb", "w") f = open("/tmp/x.lldb", "w")
for breakpoint in breakpoints: for breakingpoint in breakpoints:
f.write("b %s\n" % (breakpoint,)) f.write("b %s\n" % (breakingpoint,))
if disable_breakpoints: if disable_breakpoints:
f.write("disable\n") f.write("disable\n")
f.write("settings set target.process.stop-on-exec false\n") f.write("settings set target.process.stop-on-exec false\n")
@ -569,19 +569,19 @@ def start_SITL(binary,
def mavproxy_cmd(): def mavproxy_cmd():
'''return path to which mavproxy to use''' """return path to which mavproxy to use"""
return os.getenv('MAVPROXY_CMD', 'mavproxy.py') return os.getenv('MAVPROXY_CMD', 'mavproxy.py')
def MAVProxy_version(): def MAVProxy_version():
'''return the current version of mavproxy as a tuple e.g. (1,8,8)''' """return the current version of mavproxy as a tuple e.g. (1,8,8)"""
command = "%s --version" % mavproxy_cmd() command = "%s --version" % mavproxy_cmd()
output = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE).communicate()[0] output = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE).communicate()[0]
output = output.decode('ascii') output = output.decode('ascii')
match = re.search("MAVProxy Version: ([0-9]+)[.]([0-9]+)[.]([0-9]+)", output) match = re.search("MAVProxy Version: ([0-9]+)[.]([0-9]+)[.]([0-9]+)", output)
if match is None: if match is None:
raise ValueError("Unable to determine MAVProxy version from (%s)" % output) raise ValueError("Unable to determine MAVProxy version from (%s)" % output)
return (int(match.group(1)), int(match.group(2)), int(match.group(3))) return int(match.group(1)), int(match.group(2)), int(match.group(3))
def start_MAVProxy_SITL(atype, def start_MAVProxy_SITL(atype,
@ -670,7 +670,7 @@ def lock_file(fname):
f = open(fname, mode='w') f = open(fname, mode='w')
try: try:
fcntl.lockf(f, fcntl.LOCK_EX | fcntl.LOCK_NB) fcntl.lockf(f, fcntl.LOCK_EX | fcntl.LOCK_NB)
except Exception: except OSError:
return None return None
return f return f
@ -680,13 +680,13 @@ def check_parent(parent_pid=None):
if parent_pid is None: if parent_pid is None:
try: try:
parent_pid = os.getppid() parent_pid = os.getppid()
except Exception: except OSError:
pass pass
if parent_pid is None: if parent_pid is None:
return return
try: try:
os.kill(parent_pid, 0) os.kill(parent_pid, 0)
except Exception: except OSError:
print("Parent had finished - exiting") print("Parent had finished - exiting")
sys.exit(1) sys.exit(1)
@ -751,7 +751,7 @@ def gps_newpos(lat, lon, bearing, distance):
cos(lat1) * sin(dr) * cos(brng)) cos(lat1) * sin(dr) * cos(brng))
lon2 = lon1 + atan2(sin(brng) * sin(dr) * cos(lat1), lon2 = lon1 + atan2(sin(brng) * sin(dr) * cos(lat1),
cos(dr) - sin(lat1) * sin(lat2)) cos(dr) - sin(lat1) * sin(lat2))
return (degrees(lat2), degrees(lon2)) return degrees(lat2), degrees(lon2)
def gps_distance(lat1, lon1, lat2, lon2): def gps_distance(lat1, lon1, lat2, lon2):
@ -823,7 +823,7 @@ class Wind(object):
w_delta -= (self.turbulance_mul - 1.0) * (deltat / self.turbulance_time_constant) w_delta -= (self.turbulance_mul - 1.0) * (deltat / self.turbulance_time_constant)
self.turbulance_mul += w_delta self.turbulance_mul += w_delta
speed = self.speed * math.fabs(self.turbulance_mul) speed = self.speed * math.fabs(self.turbulance_mul)
return (speed, self.direction) return speed, self.direction
# Calculate drag. # Calculate drag.
def drag(self, velocity, deltat=None): def drag(self, velocity, deltat=None):
@ -877,7 +877,7 @@ def apparent_wind(wind_sp, obj_speed, alpha):
else: else:
beta = acos((delta + obj_speed) / rel_speed) beta = acos((delta + obj_speed) / rel_speed)
return (rel_speed, beta) return rel_speed, beta
def drag_force(wind, sp): def drag_force(wind, sp):
@ -922,7 +922,7 @@ def constrain(value, minv, maxv):
def load_local_module(fname): def load_local_module(fname):
'''load a python module from within the ardupilot tree''' """load a python module from within the ardupilot tree"""
fname = os.path.join(topdir(), fname) fname = os.path.join(topdir(), fname)
if sys.version_info.major >= 3: if sys.version_info.major >= 3:
import importlib.util import importlib.util

View File

@ -258,7 +258,7 @@ class AutoTestQuadPlane(AutoTest):
def TestMotorMask(self): def TestMotorMask(self):
"""Check operation of output_motor_mask""" """Check operation of output_motor_mask"""
"""copter tailsitters will add condition: or (int(self.get_parameter('Q_TAILSIT_MOTMX')) & 1)""" """copter tailsitters will add condition: or (int(self.get_parameter('Q_TAILSIT_MOTMX')) & 1)"""
if not(int(self.get_parameter('Q_TILT_MASK')) & 1): if not (int(self.get_parameter('Q_TILT_MASK')) & 1):
self.progress("output_motor_mask not in use") self.progress("output_motor_mask not in use")
return return
self.progress("Testing output_motor_mask") self.progress("Testing output_motor_mask")
@ -266,7 +266,7 @@ class AutoTestQuadPlane(AutoTest):
"""Default channel for Motor1 is 5""" """Default channel for Motor1 is 5"""
self.progress('Assert that SERVO5 is Motor1') self.progress('Assert that SERVO5 is Motor1')
assert(33 == self.get_parameter('SERVO5_FUNCTION')) assert 33 == self.get_parameter('SERVO5_FUNCTION')
modes = ('MANUAL', 'FBWA', 'QHOVER') modes = ('MANUAL', 'FBWA', 'QHOVER')
for mode in modes: for mode in modes:

BIN
Tools/bootloaders/BeastF7v2_bl.bin generated Normal file → Executable file

Binary file not shown.

Binary file not shown.

BIN
Tools/bootloaders/CUAV-Nora-bdshot_bl.bin generated Normal file

Binary file not shown.

BIN
Tools/bootloaders/CUAV-Nora-bdshot_bl.hex generated Normal file

Binary file not shown.

BIN
Tools/bootloaders/CubeOrangePlus-bdshot_bl.bin generated Executable file

Binary file not shown.

Binary file not shown.

BIN
Tools/bootloaders/CubeYellow-bdshot_bl.bin generated Normal file → Executable file

Binary file not shown.

Binary file not shown.

BIN
Tools/bootloaders/FlywooF745Nano_bl.bin generated Normal file → Executable file

Binary file not shown.

Binary file not shown.

BIN
Tools/bootloaders/KakuteF4Mini_bl.bin generated Normal file → Executable file

Binary file not shown.

Binary file not shown.

BIN
Tools/bootloaders/KakuteF7-bdshot_bl.bin generated Executable file

Binary file not shown.

Binary file not shown.

Some files were not shown because too many files have changed in this diff Show More