Commit Graph

52295 Commits

Author SHA1 Message Date
Andrew Tridgell e7ceb359a7 SITL: update for changed INS_NOTCH parameter name 2022-04-29 07:54:06 +09:00
Andrew Tridgell a9556cc2f7 Tools: update for changed INS_NOTCH parameter name 2022-04-29 07:54:06 +09:00
Andrew Tridgell 053e9d7c19 AP_HAL_ChibiOS: update for changed INS_NOTCH parameter name 2022-04-29 07:54:06 +09:00
Andrew Tridgell 6a3c36bfd2 Plane: param conversion for INS_NOTCH to INS_HNTC2 2022-04-29 07:54:06 +09:00
Andrew Tridgell 55ff12b7cf Copter: param conversion for INS_NOTCH to INS_HNTC2 2022-04-29 07:54:06 +09:00
Andrew Tridgell b06ee3f4b5 AP_InertialSensor: move INS_HNTC2 to a new parameter table ID 2022-04-29 07:54:06 +09:00
QioTek d56c6b6249 AP_HAL_ChibiOS: ICM4 series sensors as an alternative with IMU3.
AP_HAL_ChibiOS:  ICM4 series sensors as an alternative with IMU3.
2022-04-29 07:54:06 +09:00
mateksys d51dd75ba0 AP_HAL_ChibiOS:add icm42688p as substitution 2022-04-29 07:54:06 +09:00
Andrew Tridgell 7b7eea4c84 AP_Scripting: increase default heap size in SITL and on F7/H7
if we have 500k or more memory then use 100k heap for Lua, making
setup easier
2022-04-29 07:54:06 +09:00
Andrew Tridgell 946c7196c2 AC_AttitudeControl: use deadzone for pitch
when pitch for nose-in and tail-in is enabled we should use the
deadzone
2022-04-29 07:54:06 +09:00
Andrew Tridgell eb60f29088 AC_AttitudeControl: added an option for pitch weathervaning
when nose-in or tail-in, if the aircraft has significant pitch
asymmetry in hover then we would spin around in no wind if we use
pitch as an input

this makes pitch input for nose-in and tail-in optional and off by
default to preserve existing behaviour
2022-04-29 07:54:06 +09:00
Andrew Tridgell 41f56d8d87 HAL_ChibiOS: disable fatal exceptions for DMA errors
this zeros-watchdog was caused by a SPI DMA error on STM32F405:

  https://discuss.ardupilot.org/t/crash-with-4-2-0-beta-and-4-3-0-daily-bdshot/83297

we had incorrectly left these internal errors enabled when asserts
were not enabled. That led to a osalSysHalt()

without these we get an spi_fail internal error, caught by the
SPIDevice code
2022-04-29 07:54:06 +09:00
Peter Barker 9e45882340 Plane: do not use guided waypoint for loiter location
Currently this waypoint is set 10,000m away by the avoidance behaviour

Instead, immediately enter loiter mode
2022-04-29 07:54:06 +09:00
Andrew Tridgell 07d0336334 AP_InertialSensor: catch FIFO overruns on BMI088
we have seen errors where the BMI088 gets out of sync, so that the 3
axes are rotated. The data is shifted by 4 bytes, so that X=Z, Y=X
and Z=Y

this changes the BMI088 to "stop on full" mode, which is what Bosch
use in their example drivers, and also catches FIFO overrun events and
triggers a full FIFO reset. This should fix the problem with the FIFO
sync
2022-04-29 07:54:06 +09:00
Andrew Tridgell 48c33dc3df autotest: fixed annoying gdb pagination on reboot 2022-04-29 07:54:06 +09:00
Randy Mackay be3057e414 Rover: version to 4.2.0-rc1 2022-04-09 17:04:26 +09:00
Randy Mackay 712709fcf1 Rover: 4.2.0-rc1 release notes 2022-04-09 17:04:26 +09:00
Randy Mackay dd9d840e44 Copter: version to 4.2.0-rc1 2022-04-09 17:04:26 +09:00
Randy Mackay c3e4394c92 Copter: 4.2.0-rc1 release notes 2022-04-09 17:04:26 +09:00
Andrew Tridgell 35fbea927d Plane: prepare for 4.2.0beta5 2022-04-09 17:04:26 +09:00
Andrew Tridgell ce532197d6 Plane: release notes for 4.2.0beta5 2022-04-09 17:04:26 +09:00
李孟晓 f497e8639d AP_HAL_ChibiOS: CUAV-Nora: add usart3 support 2022-04-09 17:04:26 +09:00
Andy Piper 0e78bdbb19 AP_HAL_ChibiOS: fix dshot timeout bug where the elapsed pulse is longer than the send time
dshot timeouts should be no longer than the pulse interval
use correct timestamp for dmar send time
2022-04-09 17:04:26 +09:00
Andrew Tridgell f8c3b4be5d HAL_ChibiOS: incorrect class of class in uart TX timeout
need to call chEvtGetAndClearEventsI() as we are in a system lock
state
2022-04-09 17:04:26 +09:00
Andrew Tridgell e50f893a7e HAL_ChibiOS: fixed H7 flash storage
this fixes the flash re-init problem when flash storage fills on
H7. It was caused by rejecting writes where one or more of the 32 byte
chunks was not all 0xff but was equal to the current data. That
happens when writing to the sector header in AP_FlashStorage

it also moves the interrupt disable inside the loop to allow for
other interrupts to run between blocks
2022-04-09 17:04:26 +09:00
Andrew Tridgell e1c74ee6e5 HAL_ChibiOS: use 16 byte lines for flash storage on H7
this halves the number of flash writes needed, and makes flash storage
twice as space efficient on H7

On H7 we need to write 32 bytes at a time to flash, which corresponds
to 30 bytes of data in AP_FlashStorage. By using a 16 byte storage
line we don't waste as much space
2022-04-09 17:04:26 +09:00
Andrew Tridgell 0a3ca205eb HAL_ChibiOS: increase monitor thread stack by 512
this is needed to ensure that the log writes of MON and WDOG don't
overflow monitor thread stack
2022-04-09 17:04:26 +09:00
Andrew Tridgell a03b9ec034 HAL_ChibiOS: added expected delays on flash writes
this prevents a long loop internal error on disarm after a large
amount of flash writes when armed on a board with flash storage
2022-04-09 17:04:26 +09:00
Andrew Tridgell 86f7365c1c HAL_ChibiOS: disable interrupts during flash operations
we have now shown that interrupts being enabled during flash
operations can cause the infamous "68ms" bug, or watchdog when using a
32 bit timer on boards using flash for storage

The issue is quite repeatable with a load of a very large waypoint
file (over 500 waypoints) using "wp ftpload" in MAVProxy. This puts a
huge load on flash storage.

Our current working theory is that while doing flash writes for
storage on dual-bank we block access to only one bank, so if another
thread uses a timeout function with a short timeout while the flash
write is happening and chVTDoTickI calls code which crosses the flash
bank boundary then it can cause chVTDoTickI to violate the assumption
that no more than CH_CFG_ST_DELTA ticks pass while it is calculating
the value to set in the system timer. In that case we get a delay of a
full timer wrap, which is 68ms on boards with 16 bit timer and 70
minutes on boards with 32 bit timer
2022-04-09 17:04:26 +09:00
Andrew Tridgell 8d4130ee11 Revert "hwdef: changed MatekH743 to a 32 bit timer"
This reverts commit 7dc5911572.
2022-04-09 17:04:26 +09:00
Andrew Tridgell 0c2041d415 HAL_ChibiOS: constrain more timer timeouts 2022-04-09 17:04:26 +09:00
Andrew Tridgell ce1fc5406c HAL_ChibiOS: prevent long timeouts in DShot
this prevents bad calculated timeouts in DShot. The timeout would
sometimes come out as 0xFFFFFFFF, which led to an assert and could
block the thread

This fix is meant to be minimilistic to allow it to be merged easily
into 4.2. A better fix would fix all the uint32_t wrap handling in
DShot
2022-04-09 17:04:26 +09:00
Andrew Tridgell 1f30cf93cf AP_Math: added unsigned versions of constrain functions
sometimes it really does matter that we use constrain_uint32() instead
of constrain_int32(). For example, if we have a value like 0xFFFFFFFF
then the result will be very different

we should use unsigned constrain when dealing with unsigned values
2022-04-09 17:04:26 +09:00
Andrew Tridgell 2ad485bb09 AP_Logger: fixed @SYS file logging
the key fix is the reset of the fd to -1. Without that fix we only
ever log @SYS/uarts.txt

The timing change is needed to get the files out in a reasonable
time. The function is actually getting called at 100Hz or less, not
1kHz (measured on MatekH743 copter at 400Hz). So we need to run it
faster to get the files logged in a reasonable time
2022-04-09 17:04:26 +09:00
Andy Piper a71cdf43a6 bootloaders: update spracing h7 extreme bootloader 2022-04-09 17:04:26 +09:00
Andy Piper b3bd0d3fbb AP_HAL_ChibiOS: spro H7 extreme updates.
cannot currently use both IMUs on spro H7 extreme due to CPU load
2022-04-09 17:04:26 +09:00
Peter Barker da97462385 AP_AHRS: subtract accel bias from correct ins accel instance
In the case that you have INS_USE indicating IMUs should be used, but
EK3_IMU_MASK leaving some IMUs unused, we subtract the bias from the
wrong INS data
2022-04-09 17:04:26 +09:00
Andrew Tridgell eb20c90e4a Plane: fixed rudder control when ARMING_RUDDER != 2
when rudder disarm is disabled we should allow full yaw control
regardless of throttle level. We should also only disable left yaw
when throttle is at zero, as right yaw does not indicate pilot may be
trying to disarm
2022-04-09 17:04:26 +09:00
Andrew Tridgell a039500e53 AP_Logger: increase stack of log_io thread by 256
This was seem on omnibusf4pro, it is a bit too close:

  log_io PRI= 59 sp=0x20015CC0 STACK=144/1656
2022-04-09 17:04:26 +09:00
Randy Mackay 0124abfc9b Rover: version to 4.2.0-beta3 2022-03-30 11:37:41 +09:00
Randy Mackay f87fc8741c Rover: 4.2.0-beta3 release notes 2022-03-30 11:37:41 +09:00
Randy Mackay 4e72bfcea3 Copter: version to 4.2.0-beta3 2022-03-30 11:37:41 +09:00
Randy Mackay 88efa52c4f Copter: 4.2.0-beta3 release notes 2022-03-30 11:37:41 +09:00
Bill Geyer cfaef178f4 AP_Math: add chirp function to support frequency sweeps in systemid and autotune 2022-03-30 11:37:41 +09:00
Bill Geyer 53b91b0c67 AC_Autotune: clean up variable init for dwell 2022-03-30 11:37:41 +09:00
Bill Geyer f3fba7d844 AC_AutoTune: use chirp function in AP_Math for frequency sweeps 2022-03-30 11:37:41 +09:00
Bill Geyer 937f22d708 Copter: make systemid use new chirp math function 2022-03-30 11:37:41 +09:00
Bill Geyer 74db41806b AC_AutoTune: combine dwell_run_test for angle and rate 2022-03-30 11:37:41 +09:00
Bill Geyer 4680f73715 AC_AutoTune: combine dwell_init methods 2022-03-30 11:37:41 +09:00
Bill Geyer 8156831e0e AC_AutoTune:tradheli-streamline gcs messages 2022-03-30 11:37:41 +09:00