Peter Barker
3a38aeda59
AP_HAL_ChibiOS: set scheduler task to -4 when running callback tasks
2024-02-21 18:56:50 +11:00
Peter Barker
4113290153
AP_HAL_ChibiOS: remove HerePro
...
to be replaced by a HereProAP
2024-02-15 13:42:14 +11:00
Peter Barker
5d421e8ee3
AP_HAL_ChibiOS: allow AP_Periph to use mavlink library
2024-02-15 12:17:07 +11:00
Peter Barker
1862b5dc27
chibios_hwdef.py: allow re-use of bootloader from other boards
2024-02-10 21:41:30 +11:00
Andrew Tridgell
e8b4010899
HAL_ChibiOS: fixed CANFD timings (again!)
...
the timing table was not correct, thanks to APD for pointing this out.
This is recalculated from
https://www.kvaser.com/support/calculators/can-fd-bit-timing-calculator ,
with transmitter timing delay compensation added and tested with Salae
captures to ensure we are getting the right bit rates
2024-02-09 18:55:08 +11:00
bugobliterator
9919af69bc
AP_HAL_ChibiOS: add config to enable sccripting on CANMod
2024-02-07 18:31:02 +11:00
Henry Wurzburg
2729b11b2f
hwdef: add ASP5033 airspeed in minimal builds
2024-02-06 11:27:18 +11:00
Peter Barker
4c272d21ee
AP_HAL_ChibiOS: make compass.mag_cal_fixed_yaw return boolean
...
this method could be used from a transmitter without GCS enabled, for example
2024-02-06 11:11:27 +11:00
Peter Barker
9961e8c49d
hwdef: remove bad hwdef lines
...
these have no effect
2024-02-06 10:58:44 +11:00
Peter Barker
0d26118b12
hwdef: tidy AP_Radio includes
2024-02-05 09:26:14 +11:00
Andrew Tridgell
85439360d7
HAL_ChibiOS: fixed I2C4 on STM32G4
2024-02-05 07:36:14 +11:00
Andrew Tridgell
1e4f597e02
HAL_ChibiOS: fixed support for STM32H7A3
...
need to tell ChibiOS this is a newer H7
2024-02-03 08:36:18 +11:00
Peter Barker
a82b7f20c9
AP_HAL_ChibiOS: use HAL_LOGGING_ENABLED in place of HAL_BOOTLOADER_BUILD
...
bootloader already disables GCS, so we can rely on HAL_GCS_ENABLED in place of HAL_BOOTLOADER_BUILD
2024-02-02 19:21:58 +11:00
David O'Connor
078697c825
hwdef: add AnyLeaf H7 board
2024-02-01 11:43:57 +11:00
Leonardo Garcia
5749bd5074
AP_HAL_ChibiOS: mRo KitCAN revC board fix
...
Add RM3100 reversal mask to deal with M10025C board changes.
2024-02-01 11:43:35 +11:00
Andrew Tridgell
33f6a1d87e
hwdef: added MatekH7A3 support
2024-02-01 11:43:24 +11:00
Andrew Tridgell
054fb94e9a
HAL_ChibiOS: added support for STM32H7A3
...
interesting MCU as it is the first H7 we support that doesn't have a
128k flash sector size
2024-02-01 11:43:24 +11:00
Andrew Tridgell
3171b5321a
HAL_ChibiOS: support flash storage with 8k sectors
...
this allows for doubling up sectors to give an effective sector size
of 16k, allowing for flash storage with a useful storage size
2024-02-01 11:43:24 +11:00
Andrew Tridgell
07d0418cf9
HAL_ChibiOS: fixed flash support on H7 with 8k page size
...
the STM32H7A3xx has 8k pages
2024-02-01 11:43:24 +11:00
yjuav
8e71cf83cd
hwdef: add YJUAV_A6Ultra board support
2024-02-01 11:29:11 +11:00
Andrew Tridgell
30497244d9
HAL_ChibiOS: whitespace fixes
2024-01-30 12:32:23 +11:00
Andrew Tridgell
0a6057f2b3
HAL_ChibiOS: adjust clocks for H723 and H730
...
FDCAN clock must be 80MHz, and also align no-crystal clocks with
clocks for boards with crystals
2024-01-30 12:32:23 +11:00
Andrew Tridgell
aea2863141
hwdef: Added BotBloxSwitch
2024-01-30 12:32:23 +11:00
Andrew Tridgell
967af533b9
HAL_ChibiOS: fixed flash page count on H723
...
single bank H7 has 8 pages
2024-01-30 12:32:23 +11:00
Andrew Tridgell
4eaf5ef247
HAL_ChibiOS: support STM32H723 boards
2024-01-30 12:32:23 +11:00
Andrew Tridgell
e772012e01
HAL_ChibiOS: raise SDMMC clock limit on H7
...
this allows for faster log download on ethernet
2024-01-29 06:51:11 +11:00
Andrew Tridgell
a2707b48c5
HAL_ChibiOS: enable clock management on G4
...
this allows for a different clock tree in the main fw from the
bootloader
2024-01-25 11:44:02 +11:00
Andrew Tridgell
2d031a4d20
HAL_ChibiOS: switched G4 FDCAN clock to 80MHz
...
this requires main CPU clock at 160 MHz instead of 168 MHz
2024-01-25 11:44:02 +11:00
Andrew Tridgell
1c8048df8f
HAL_ChibiOS: fixed CANFD timings
...
our CANFD timings were resulting in a lot of busoff errors. Here is an
example of master at 1Mbit/5MBit:
Getting @SYS/can0_stats.txt as -
------- Clock Config -------
CAN_CLK_FREQ: 80MHz
Std Timings: bitrate=1000000 presc=7
sjw=0 bs1=7 bs2=0 sample_point=90.00000%
FD Timings: bitrate=5000000 presc=1
sjw=0 bs1=5 bs2=0 sample_point=90.00000%
------- CAN Interface Stats -------
tx_requests: 2689
tx_rejected: 0
tx_overflow: 443
tx_success: 7
tx_timedout: 2232
tx_abort: 0
rx_received: 18470
rx_overflow: 0
rx_errors: 0
num_busoff_err: 34439
num_events: 18477
ECR: F8
fdf_rx: 18467
fdf_tx_req: 2182
fdf_tx: 0
here is an example with the new timings:
------- Clock Config -------
CAN_CLK_FREQ: 80MHz
Std Timings: bitrate=1000000 presc=8
sjw=1 bs1=8 bs2=1 sample_point=90.00000%
FD Timings: bitrate=8000000 presc=2
sjw=3 bs1=8 bs2=3 sample_point=80.00000%
------- CAN Interface Stats -------
tx_requests: 3023
tx_rejected: 0
tx_overflow: 0
tx_success: 3023
tx_timedout: 0
tx_abort: 0
rx_received: 27865
rx_overflow: 0
rx_errors: 0
num_busoff_err: 0
num_events: 30888
ECR: 0
fdf_rx: 27862
fdf_tx_req: 3016
fdf_tx: 3016
I am testing between a CubeOrange and a Pixhawk6X. I tested 1, 2, 4, 5
and 8 MBit (which are the only valid FD bitrates in our parameters)
Many thanks to Kai from Salient Motion for finding this issue and
providing the corrected timing table
2024-01-25 11:44:02 +11:00
Hayden Donald
a81f2785aa
AP_HAL_ChibiOS: Use correct pin config for ADC2 and ADC3
2024-01-24 08:03:24 +11:00
MallikarjunSE
873e2eac7d
AP_HAL_ChibiOS: update truenav hwdef
2024-01-24 07:58:09 +11:00
Andrew Tridgell
e714f0a7a3
AP_HAL_ChibiOS: fixed name of pitch limit parameters
2024-01-23 15:00:30 +11:00
Andrew Tridgell
a6bceccd82
AP_HAL_ChibiOS: convert param files LIM_ROLL_CD -> ROLL_LIMIT_DEG
2024-01-23 15:00:30 +11:00
Andrew Tridgell
862b0ed8d6
AP_HAL_ChibiOS: convert param files for pitch limits
2024-01-23 15:00:30 +11:00
Andrew Tridgell
e5199a71d6
AP_HAL_ChibiOS: convert ALT_HOLD_RTL to RTL_ALTITUDE
2024-01-23 15:00:30 +11:00
Andrew Tridgell
f935cbaead
AP_HAL_ChibiOS: convert ARSPD_FBW_MIN/MAX to AIRSPEED_MIN and AIRSPEED_MAX
2024-01-23 15:00:30 +11:00
Andrew Tridgell
98d40d0e58
AP_HAL_ChibiOS: converted TRIM_ARSPD_CM to AIRSPEED_CRUISE
2024-01-23 15:00:30 +11:00
Andy Piper
6c634ebc00
AP_HAL_ChibiOS: allow dshot beeps to play on all dshot ESC types
2024-01-23 11:58:55 +11:00
Peter Barker
331110639e
AP_HAL_ChibiOS: rename COMPASS_TYPEMASK to COMPASS_DISBLMSK
...
this is a very confusingly named parameter. I've seen several instances of people treating this as an enable mask rather than a disable mask
2024-01-23 11:54:49 +11:00
Andrew Tridgell
140518da3c
hwdef: added support for Holybro6X-45686
2024-01-23 11:49:14 +11:00
bugobliterator
9de1b6164b
AP_HAL_ChibiOS: add more pins to STM32H757 ADC channel map
2024-01-22 20:35:16 +11:00
bugobliterator
b17d864d1a
AP_HAL_ChibiOS: fix set_pin and _pin_scalar methods for ADC2 and ADC3
2024-01-22 20:35:16 +11:00
MallikarjunSE
f71fc58767
AP_HAL_ChibiOS: Add hwdef for TrueNavPro-G4
2024-01-21 13:10:10 +11:00
MallikarjunSE
6231a5edfd
AP_HAL_ChibiOS: add TrueNavIC hwdef
2024-01-21 13:10:10 +11:00
Andrew Tridgell
f7c7ee00e9
HAL_ChibiOS: added a delete_next thread field for cleanup
...
allows for cleanup of web server threads in bootloader
2024-01-21 12:30:08 +11:00
Andrew Tridgell
5e7b211b79
HAL_ChibiOS: moved M4 disable into H757 script
...
this fixes assert checking in the bootloader and for boards other than
CubeRedPrimary
2024-01-21 12:30:08 +11:00
Andrew Tridgell
b49a7da32a
hwdef: disable use of external flash in PPPGW
...
we cannot upload new firmware on CAN or network with external flash
2024-01-21 12:30:08 +11:00
Andrew Tridgell
855a5d28c0
hwdef: use a common PPPGW include
...
and fixed missing RTC bindings in web server
2024-01-21 12:30:08 +11:00
Andrew Tridgell
3a84f35593
HAL_ChibiOS: support building with no GPIOs
2024-01-21 12:30:08 +11:00
Andrew Tridgell
f225d797d2
hwdef: use common include for network bootloader
2024-01-21 12:30:08 +11:00
Andrew Tridgell
4e49481d3a
hwdef: enable USB for bootloader on Pixhawk6X-PPPGW
2024-01-21 12:30:08 +11:00
Andrew Tridgell
91cc0d7dba
HAL_ChibiOS: ensure periph uses same RAM0 address as bootloader
...
this fixes passing of addresses for boards that use an ALT_RAM_MAP
2024-01-21 12:30:08 +11:00
Andrew Tridgell
82dea9c037
HAL_ChibiOS: ensure our reserved ram is not in available ram regions
...
this prevents a fault when the ram0 region is filled in by the periph
code on boards that do dynamic memory allocation
2024-01-21 12:30:08 +11:00
Andrew Tridgell
a155f592a4
hwdef: added CubePilot PPPGW builds
2024-01-21 12:30:08 +11:00
Andrew Tridgell
2fee9e69db
HAL_ChibiOS: support ROMFS_DIRECTORY in hwdef.dat
2024-01-21 12:30:08 +11:00
Andrew Tridgell
46f65aec4e
AP_Periph: moved web UI script to Tools/AP_Periph
...
for use in multiple boards
2024-01-21 12:30:08 +11:00
Andrew Tridgell
69f23edd4a
hwdef: added bootloader web server for Pixhawk6X-PPPGW
2024-01-21 12:30:08 +11:00
Andrew Tridgell
654b70da67
HAL_ChibiOS: allow HAL_Semaphore in the bootloader
2024-01-21 12:30:08 +11:00
Peter Barker
8e2a634c72
hwdef: don't enable filesystem-romfs just because we have a defaults file
2024-01-18 21:44:15 +11:00
Peter Barker
e958e7b720
hwdef: enable ROMFS if we have a defaults filepath to embed
2024-01-18 21:44:15 +11:00
Peter Barker
3aab3bac52
Tools/AP_HAL_ChibiOS: move defaults from tools to hwdef directory
...
Tools: move defaults from tools to hwdef directory
2024-01-17 18:28:48 +11:00
Peter Barker
c4a342f0af
AP_HAL_ChibiOS: use @ROMFS/defaults.parm rather than apj_tool for defaul parms
2024-01-17 18:28:48 +11:00
Peter Barker
29f1953ad7
AP_HAL_ChibiOS: remove bad default from kha_eth hwdef
...
off is the default, but you have to use 0 not FALSE or it's a redefinition error
2024-01-17 18:25:55 +11:00
Peter Barker
2e23fa7612
hwdef: remove ghost telemetry from peripherals
2024-01-16 09:46:57 +11:00
Peter Barker
f7365556d0
AP_HAL_ChibiOS: tidy disabling of GHST on iomcu
2024-01-16 09:46:57 +11:00
Thomas Watson
5f5673b58f
AP_HAL_ChibiOS: match thread stack pointer types to ChibiOS
...
`__main_thread_stack_base__` and `__main_thread_stack_end__` are
variables whose address is defined to be the corresponding part of the
stack. These are declared as `extern stkalign_t` in ChibiOS code, and
being declared as `extern uint32_t` in ArduPilot code creates a warning
at link time when using LTO. Correct the declaration to eliminate this
warning.
Also update `__main_stack_base__` and `__main_stack_end__` which don't
currently trigger this warning but serve similar purposes and so might
in the future.
The hardware expects an alignment of `stkalign_t` (which is 8 bytes) and
the linker script defines the variable values with this alignment as
well, so this is safe.
No code size or functional change.
2024-01-16 09:24:34 +11:00
Peter Barker
d0e7039b68
hwdef: remove un-needed AP_PARAM_MAX_EMBEDDED_PARAM default
...
these boards have <= 1024, and we have code in place which defaults this value tto 1024
2024-01-15 20:25:59 +11:00
Peter Barker
7cf66d917c
hwdef: correct compilation of revo-mini-sd
...
this isn't built on the firmware server, so we won't notice when it dies
In this case the SMBUS batter define was being set differently
Also remove some redundant defines which come from includes anyway
2024-01-15 20:24:37 +11:00
Peter Barker
d4f59cbe5f
hwdef: remove HAL_NO_LOGGING from Here4FC-bl.dat
...
this was removed from master a long time ago
2024-01-15 09:40:35 +11:00
Peter Barker
ad90e37f21
hwdef: remove bad AP_PERIPH_HAVE_LED lines from bootloaders
...
this define is only used within the AP_Periph directory
2024-01-15 09:40:35 +11:00
Andrew Tridgell
60c69d052b
hwdef: added scripting to CubePilot-PPPGW
2024-01-12 19:06:49 -08:00
Andrew Tridgell
faea203af6
hwdef: added web UI to PPPGW example
2024-01-12 19:06:49 -08:00
Andrew Tridgell
2c946b92e9
hwdef: added Pixhawk6X-PPPGW
2024-01-12 14:23:34 -08:00
Andrew Tridgell
280d7c6d15
hwdef: added CubePilot-PPPGW
2024-01-12 14:23:34 -08:00
Davide_Lentini
5fdcd876ee
AP_HAL_ChibiOS: Update defaults.parm of luminousbee5 board
2024-01-12 20:45:11 +09:00
Andy Piper
3caf336b0f
AP_HAL_ChibiOS: switch BetaFPV-F405, BeastF7 and BeastF7v2 to minimize_fpv
2024-01-10 18:32:53 +11:00
Iampete1
416a41e756
AP_HAL_ChibiOS: Only test SPI clock if SPI is enabled
2024-01-10 13:46:40 +11:00
Maxim Buzdalov
809e15acf4
hwdef: Add pinout for Flywoo GOKU F745 AIO v1.2
2024-01-09 10:57:29 +11:00
bugobliterator
57ccac308d
AP_HAL_ChibiOS: Add readme file to Here4 FC
2024-01-08 07:05:34 +11:00
bugobliterator
ec15951b06
AP_HAL_ChibiOS: add hwdef for Here4FC
2024-01-08 07:05:34 +11:00
bugobliterator
bea8b25c5d
AP_HAL_ChibiOS: add support for early initialisation of WATCHDOG
...
This is needed for Ardupilot Vehicle builds running on AP_Periph bootloaders
2024-01-08 07:05:34 +11:00
Andrew Tridgell
6ea2c28a4d
HAL_ChibiOS: fixed DMA on SPI on H743
...
this fixes DMA failures affecting IMUs on H743. The reason for the
failure is not yet clear, but this reverts back to our old stragegy of
always using the bouncebuffer on H7 as a quick workaround
2024-01-07 19:10:25 +11:00
Andrew Tridgell
c54aa0241a
HAL_ChibiOS: added mem_is_dma_safe() function
...
used for bouncebuffer code and in FATFS code
2024-01-05 06:52:11 -08:00
Peter Barker
c557e67aff
chibios_hwdef.py: populate intdefines as part of parsing, not output
2024-01-04 20:29:14 +11:00
jamming
6fe7a1408e
hwdef: Add support for BMI088 on Pixhawk6c
2024-01-04 07:17:24 +11:00
Peter Barker
ed1ae3b5f1
chibios_hwdef.py: add quiet option to remove parsing debug output
2024-01-03 18:04:37 +11:00
Andrew Tridgell
cc8c671cb7
HAL_ChibiOS: don't link evtimer in chibios_board.mk
2024-01-03 12:14:47 +11:00
Andrew Tridgell
418897c443
HAL_ChibiOS: removed old lwip options
2024-01-03 12:14:47 +11:00
Andrew Tridgell
936bbeda88
AP_HAL_ChibiOS: added PRIORITY_NET
2024-01-03 12:14:47 +11:00
Andrew Tridgell
9456b585fa
HAL_ChibiOS: don't link lwip bindings from ChibiOS
2024-01-03 12:14:47 +11:00
Andrew Tridgell
5748adbf44
HAL_ChibiOS: allow for networking without ethernet
2024-01-03 12:14:47 +11:00
Peter Barker
d5ddbad27f
HAL_ChibiOS_Class: adjust for dsp disappearing from HAL constructor
2024-01-03 11:45:31 +11:00
Andrew Tridgell
c0d0aeee86
HAL_ChibiOS: reimplement CAN with BinarySemaphore
2024-01-03 07:37:05 +11:00
Andrew Tridgell
8a027eddb0
HAL_ChibiOS: implement BinarySemaphore
...
and removed event handles
2024-01-03 07:37:05 +11:00
Andrew Tridgell
c2011570f7
HAL_ChibiOS: use chSysLock for CAN critical section
...
this avoids an assert in some code paths that combine with hrt
functions
2024-01-03 07:37:05 +11:00
Peter Barker
467daeb4a6
hwdef: tidy checking of is-bootloader-build
2024-01-02 13:00:15 +11:00
alexklimaj
c53d3ae09b
hwdef: ARK_CANNODE add rangefinder
2024-01-02 11:58:35 +11:00
Andrew Tridgell
0a8faa83d9
HAL_ChibiOS: allow for up to 12.5MBps on H7 UARTs
...
use 8x oversampling instead of 16x oversampling
2024-01-02 08:12:37 +11:00
alexklimaj
e9f51a96cb
hwdef: ARKV6X add USART6 to serial list
2024-01-01 13:17:06 +11:00
Andrew Tridgell
1e626a70cb
hwdef: added MatekL431-Serial
2023-12-27 05:13:14 -07:00