Skip to content

Commit

Permalink
hwdef: add YJUAV_A6SE_H743 board support (4.4 backport)
Browse files Browse the repository at this point in the history
  • Loading branch information
yunjiuav committed Nov 6, 2023
1 parent 656c12a commit 4455a08
Show file tree
Hide file tree
Showing 8 changed files with 1,656 additions and 0 deletions.
1 change: 1 addition & 0 deletions Tools/AP_Bootloader/board_types.txt
Original file line number Diff line number Diff line change
Expand Up @@ -229,6 +229,7 @@ AP_HW_ACNS_CM4PILOT 1115
AP_HW_ACNS_F405AIO 1116
AP_HW_BLITZF7 1117
AP_HW_YJUAV_A6SE 1127
AP_HW_YJUAV_A6SE_H743 1141

AP_HW_ESP32_PERIPH 1205
AP_HW_ESP32S3_PERIPH 1206
Expand Down
Binary file added Tools/bootloaders/YJUAV_A6SE_H743_bl.bin
Binary file not shown.
1,094 changes: 1,094 additions & 0 deletions Tools/bootloaders/YJUAV_A6SE_H743_bl.hex

Large diffs are not rendered by default.

266 changes: 266 additions & 0 deletions libraries/AP_HAL_ChibiOS/hwdef/YJUAV_A6SE_H743/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,266 @@
# A6SE_H743 Flight Controller

The A6SE_H743 flight controller is manufactured and sold by [YJUAV](http://www.yjuav.net).

## Features

- STM32H743 microcontroller
- Onboard Flash: 2048Mbits
- Two IMUs: ICM42688, ICM42688
- Internal ITS8310 I2C magnetometer
- Internal DPS310 SPI barometer
- Internal RGB LED
- microSD card slot port
- 1 analog power ports
- 5 UARTs and 1 USB ports
- 3 I2C and 2 CAN ports
- 11 PWM output ports
- Safety switch port
- External SPI port
- Buzzer port
- RC IN port

## Pinout
![YJUAV_A6SE_H743 Board](YJUAV_A6SE_H743-pinout.jpg "YJUAV_A6SE_H743")


## Connectors

**POWER ADC**

| Pin | Signal | Volt |
| :--: | :-------------: | :---: |
| 1 | VCC_IN | +5V |
| 2 | VCC_IN | +5V |
| 3 | BAT_CRRENT_ADC | +3.3V |
| 4 | BAT_VOLTAGE_ADC | +3.3V |
| 5 | GND | GND |
| 6 | GND | GND |

**TELEM1**

| Pin | Signal | Volt |
| :--: | :-----: | :---: |
| 1 | VCC | +5V |
| 2 | UART_TX2 | +3.3V |
| 3 | UART_RX2 | +3.3V |
| 4 | CTS | +3.3V |
| 5 | RTS | +3.3V |
| 6 | GND | GND |

**TELEM2**

| Pin | Signal | Volt |
| :--: | :-----: | :---: |
| 1 | VCC | +5V |
| 2 | UART_TX6 | +3.3V |
| 3 | UART_RX6 | +3.3V |
| 4 | CTS | +3.3V |
| 5 | RTS | +3.3V |
| 6 | GND | GND |

**ADC**

| Pin | Signal | Volt |
| :--: | :-----: | :---: |
| 1 | VCC | +5V |
| 2 | ADC_3V3 | +3.3V |
| 3 | ADC_6V6 | +6.6V |
| 4 | GND | GND |

**SPI**

| Pin | Signal | Volt |
| :--: | :------: | :---: |
| 1 | VCC | +5V |
| 2 | SPI_SCK | +3.3V |
| 3 | SPI_MISO | +3.3V |
| 4 | SPI_MOSI | +3.3V |
| 5 | SPI_CS | +3.3V |
| 6 | GND | GND |

**I2C**

| Pin | Signal | Volt |
| :--: | :-----: | :---: |
| 1 | VCC | +5V |
| 2 | I2C4_SCL | +3.3V |
| 3 | I2C4_SDA | +3.3V |
| 4 | GND | GND |

**CAN1**

| Pin | Signal | Volt |
| :--: | :----: | :---: |
| 1 | VCC | +5V |
| 2 | CAN1_P | +3.3V |
| 3 | CAN1_N | +3.3V |
| 4 | GND | GND |

**CAN2**

| Pin | Signal | Volt |
| :--: | :----: | :---: |
| 1 | VCC | +5V |
| 2 | CAN2_P | +3.3V |
| 3 | CAN2_N | +3.3V |
| 4 | GND | GND |

**GPS1**

| Pin | Signal | Volt |
| :--: | :-----: | :---: |
| 1 | VCC | +5V |
| 2 | UART_TX3 | +3.3V |
| 3 | UART_RX3 | +3.3V |
| 4 | I2C2_SCL | +3.3V |
| 5 | I2C2_SDA | +3.3V |
| 6 | GND | GND |

**GPS2&SAFETY**

| Pin | Signal | Volt |
| :--: | :-----------: | :---: |
| 1 | VCC | +5V |
| 2 | UART_TX1 | +3.3V |
| 3 | UART_RX1 | +3.3V |
| 4 | I2C3_SCL | +3.3V |
| 5 | I2C3_SDA | +3.3V |
| 6 | SAFETY_SW | +3.3V |
| 7 | SAFETY_SW_LED | +3.3V |
| 8 | 3V3_OUT | +3.3V |
| 9 | BUZZER | +3.3V |
| 10 | GND | GND |

**DEBUG**

| Pin | Signal | Volt |
| :--: | :----: | :---: |
| 1 | VCC | +5V |
| 2 | UART_TX7 | +3.3V |
| 3 | UART_RX7 | +3.3V |
| 4 | SWDIO | +3.3V |
| 5 | SWCLK | +3.3V |
| 6 | GND | GND |

**SAFETY**

| Pin | Signal | Volt |
| :--: | :-----------: | :---: |
| 1 | 3V3_OUT | +3.3V |
| 2 | SAFETY_SW | +3.3V |
| 3 | SAFETY_SW_LED | +3.3V |
| 4 | SBUS_OUT | +3.3V |
| 5 | RSSI | +3.3V |
| 6 | GND | GND |

**USB EX**

| Pin | Signal | Volt |
| :--: | :----: | :---: |
| 1 | VCC_IN | +5V |
| 2 | DM | +3.3V |
| 3 | DP | +3.3V |
| 4 | GND | GND |

## UART Mapping

- SERIAL0 -> USB (OTG1)
- SERIAL1 -> USART2 (Telem1)
- SERIAL2 -> USART6 (Telem2)
- SERIAL3 -> USART3 (GPS1), NODMA
- SERIAL4 -> USART1 (GPS2), NODMA
- SERIAL5 -> UART8 (USER) TX only, normally used for SBUS_OUT with protocol change
- SERIAL6 -> UART7 (USER/Debug), NODMA
- SERIAL7 -> USB2 (OTG2)

## RC Input

The RCIN pin is mapped to a timer input instead of the UART, and can be used for all ArduPilot supported receiver protocols, except CRSF/ELRS and SRXL2 which require a true UART connection. However, FPort, when connected in this manner, can provide RC without telemetry.

To allow CRSF and embedded telemetry available in Fport, CRSF, and SRXL2 receivers, a full UART must be used. For example, UART1 can have its protocol changed from the default GPS protocol for GPS2 to RX input protocol:

With this option, SERIAL4_PROTOCOL must be set to “23”, and:

PPM is not supported.

SBUS/DSM/SRXL connects to the RX1 pin.

FPort requires connection to TX1 and RX1. See FPort Receivers.

CRSF also requires a TX1 connection, in addition to RX1, and automatically provides telemetry.

SRXL2 requires a connection to TX1 and automatically provides telemetry. Set SERIAL4_OPTIONS to “4”.

Any UART can be used for RC system connections in ArduPilot also, and is compatible with all protocols except PPM. See Radio Control Systems for details.

## PWM Output

The A6SE_H743 supports up to 11 PWM outputs,support all PWM protocols as well as DShot. All 11 PWM outputs have GND on the bottom row, 5V on the middle row and signal on the top row.

The 11 PWM outputs are in 3 groups:

- PWM 1, 2, 3 and 4 in group1
- PWM 5, 6, 7 and 8 in group2
- PWM 9, 10, 11 in group3

Channels 1-8 support bi-directional Dshot.
Channels within the same group need to use the same output rate. If any channel in a group uses DShot, then all channels in that group need to use DShot.

## GPIOs

All 11 PWM channels can be used for GPIO functions (relays, buttons, RPM etc).

The pin numbers for these PWM channels in ArduPilot are shown below:

| PWM Channels | Pin | PWM Channels | Pin |
| ------------ | ---- | ------------ | ---- |
| PWM1 | 50 | PWM8 | 57 |
| PWM2 | 51 | PWM9 | 58 |
| PWM3 | 52 | PWM10 | 59 |
| PWM4 | 53 | PWM11 | 60 |
| PWM5 | 54 | | |
| PWM6 | 55 | | |
| PWM7 | 56 | | |

## Analog inputs

The A6SE_H743 flight controller has 5 analog inputs

- ADC Pin4 -> Battery Current
- ADC Pin2 -> Battery Voltage
- ADC Pin8 -> ADC 3V3 Sense
- ADC Pin10 -> ADC 6V6 Sense
- ADC Pin11 -> RSSI voltage monitoring

## Battery Monitor Configuration

The board has voltage and current sensor inputs on the POWER_ADC connector.

The correct battery setting parameters are:

Enable Battery monitor.

BATT_MONITOR =4

Then reboot.

BATT_VOLT_PIN 2

BATT_CURR_PIN 4

BATT_VOLT_MULT 21.0 (may need adjustment if supplied monitor is not used)

BATT_AMP_PERVLT 34.0 (may need adjustment if supplied monitor is not used)

## Build the FC

./waf configure --board=YJUAV_A6SE_H743
./waf copter

The compiled firmware is located in folder **"build/YJUAV_A6SE_H743/bin/arducopter.apj"**.


## Loading Firmware

The A6SE_H743 flight controller comes pre-installed with an ArduPilot compatible bootloader, allowing the loading of *.apj firmware files with any ArduPilot compatible ground station.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
4 changes: 4 additions & 0 deletions libraries/AP_HAL_ChibiOS/hwdef/YJUAV_A6SE_H743/defaults.parm
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# setup the heater temperature to 45 degree
BRD_HEAT_TARG 45

CAN_P1_DRIVER 1
51 changes: 51 additions & 0 deletions libraries/AP_HAL_ChibiOS/hwdef/YJUAV_A6SE_H743/hwdef-bl.dat
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
# hw definition file for processing by chibios_hwdef.py
# for YJUAV_A6SE_H743 board

# MCU class and specific type
MCU STM32H7xx STM32H743xx

# crystal frequency
OSCILLATOR_HZ 16000000

# board ID for firmware load
APJ_BOARD_ID 1141

FLASH_SIZE_KB 2048

# bootloader is installed at zero offset
FLASH_RESERVE_START_KB 0

# the location where the bootloader will put the firmware
# the H743 has 128k sectors
FLASH_BOOTLOADER_LOAD_KB 128

# order of UARTs (and USB). Allow bootloading on USB and Debug
SERIAL_ORDER OTG1 UART7

# UART7 DEBUG
PE7 UART7_RX UART7 NODMA
PE8 UART7_TX UART7 NODMA
define BOOTLOADER_DEBUG SD7

# USB
PA11 OTG_FS_DM OTG1
PA12 OTG_FS_DP OTG1

PA13 JTMS-SWDIO SWD
PA14 JTCK-SWCLK SWD

PE15 LED_RED OUTPUT OPENDRAIN HIGH # red
PD10 LED_BOOTLOADER OUTPUT OPENDRAIN HIGH # green
PG0 LED_ACTIVITY OUTPUT OPENDRAIN HIGH # blue
define HAL_LED_ON 0

# Add CS pins to ensure they are high in bootloader
PE4 IMU1_CS CS
PA0 IMU2_CS CS
PE10 FRAM_CS CS
PE9 BAROMETER_CS CS
PE3 COMPASS_CS CS
PC15 RESERVE_CS CS

# Extra SPI CS
PE5 EXT_CS CS
Loading

0 comments on commit 4455a08

Please sign in to comment.