Ardupilot2/libraries/AP_HAL_ChibiOS/hwdef/Durandal/README.md
2021-02-09 07:14:02 +11:00

583 lines
10 KiB
Markdown

# Durandal Flight Controller
The Holybro Durandal flight controller is sold by a range of
resellers, linked from https://www.holybro.com
The full schematics of the board are available here:
https://github.com/ArduPilot/Schematics/tree/master/Holybro/Durandal
## Features
- STM32H743 microcontroller
- ICM20689 and BMI088 IMUs
- internal heater for IMU temperature control
- internal vibration isolation for IMUs
- MS5611 SPI barometer
- builtin IST8310 compass
- microSD card slot
- 6 UARTs plus dual USB
- 16 PWM outputs
- I2C and dual CAN ports
- DSM and RCIN ports
- external safety Switch
- voltage monitoring for servo rail and Vcc
- dual power input ports for external power bricks
- external USB connectors (micro USB and JST GH)
## Pinout
![Durandal Top](Durandal-top.png "Durandal Top")
![Durandal Front](Durandal-front.png "Durandal Front")
![Durandal Back](Durandal-back.png "Durandal Back")
![Durandal Left](Durandal-left.png "Durandal Left")
![Durandal Right](Durandal-right.png "Durandal Right")
## UART Mapping
- SERIAL0 -> USB
- SERIAL1 -> UART2 (Telem1)
- SERIAL2 -> UART3 (Telem2)
- SERIAL3 -> UART1 (GPS)
- SERIAL4 -> UART4 (GPS2, Telem4/I2C)
- SERIAL5 -> UART6 (Telem3)
- SERIAL6 -> UART7 (debug port)
- SERIAL7 -> USB2
The Telem1, Telem2 and Telem3 ports have RTS/CTS pins, the other UARTs do not
have RTS/CTS.
## Connectors
Unless noted otherwise all connectors are JST GH
### TELEM1, TELEM2, TELEM3 ports
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin </th>
<th>Signal </th>
<th>Volt </th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>TX (OUT)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>RX (IN)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>CTS</td>
<td>+3.3V</td>
</tr>
<tr>
<td>5 (blk)</td>
<td>RTS</td>
<td>+3.3V</td>
</tr>
<tr>
<td>6 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### GPS1 port
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>TX (OUT)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>RX (IN)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>SCL I2C1</td>
<td>+3.3V</td>
</tr>
<tr>
<td>5 (blk)</td>
<td>SDA I2C1</td>
<td>+3.3V</td>
</tr>
<tr>
<td>6 (blk)</td>
<td>Button</td>
<td>GND</td>
</tr>
<tr>
<td>7 (blk)</td>
<td>button LED</td>
<td>GND</td>
</tr>
<tr>
<td>8 (blk)</td>
<td>3.3V</td>
<td>3.3</td>
</tr>
<tr>
<td>9 (blk)</td>
<td>buzzer</td>
<td>GND</td>
</tr>
<tr>
<td> (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### GPS2, Telem4/I2C port
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>TX (OUT)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>RX (IN)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>SCL I2C2</td>
<td>+3.3V</td>
</tr>
<tr>
<td>5 (blk)</td>
<td>SDA I2C2</td>
<td>+3.3V</td>
</tr>
<tr>
<td>6 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### SBUS Out port
The SBUS out port is a port attached to the IO processor which can be
used to output all servo channels via SBUS. It is enabled by setting
the BRD_SBUS_OUT parameter.
When SBUS output is disabled (by setting BRD_SBUS_OUT to 0) you can
use the port for analog RSSI input from receivers. To enable for RSSI
input you need to set:
- BRD_SBUS_OUT 0
- RSSI_TYPE 1
- RSSI_PIN 103
You cannot have both SBUS output and analog RSSI input at the same time.
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1</td>
<td>GND</td>
<td>GND</td>
</tr>
<tr>
<td>2</td>
<td>5v(Vservo)</td>
<td>+5.0V</td>
</tr>
<tr>
<td>3</td>
<td>TX (OUT)</td>
<td>+3.3V</td>
</tr>
</tbody>
</table>
### DSM/SPKT port
The SPKT port provides a connector for Spektrum satellite
receivers. It is needed to allow for software controlled binding of
satellite receivers.
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1</td>
<td>RX (IN)</td>
<td>+3.3V</td>
</tr>
<tr>
<td>2</td>
<td>GND</td>
<td>GND</td>
</tr>
<tr>
<td>3</td>
<td>3.3v</td>
<td>+3.3V</td>
</tr>
</tbody>
</table>
### ADC / CAPTURE
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>FMU_CAP6, AUX6, GPIO 55</td>
<td></td>
</tr>
<tr>
<td>3 (blk)</td>
<td>FMU_CAP5, AUX7, GPIO 56</td>
<td></td>
</tr>
<tr>
<td>4 (blk)</td>
<td>FMU_CAP4, AUX8, GPIO 57</td>
<td></td>
</tr>
<tr>
<td>5 (blk)</td>
<td>FMU_CAP3, GPIO 60</td>
<td></td>
</tr>
<tr>
<td>6 (blk)</td>
<td>FMU_CAP2, GPIO 59</td>
<td></td>
</tr>
<tr>
<td>7 (blk)</td>
<td>FMU_CAP1, GPIO 58</td>
<td></td>
</tr>
<tr>
<td>8 (blk)</td>
<td>ADC1_3V3 (ADC pin 4)</td>
<td></td>
</tr>
<tr>
<td>9 (blk)</td>
<td>ADC1_6V6 (ADC pin 18)</td>
<td></td>
</tr>
<tr>
<td>10 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### I2C
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>SCL</td>
<td>+3.3 (pullups)</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>SDA</td>
<td>+3.3 (pullups)</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### CAN1&2
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>CAN_H</td>
<td>+12V</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>CAN_L</td>
<td>+12V</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### POWER1&2
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin</th>
<th>Signal</th>
<th>Volt</th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>CURRENT</td>
<td>up to +3.3V</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>VOLTAGE</td>
<td>up to +3.3V</td>
</tr>
<td>5 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
<td>6 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
### USB
<table border="1" class="docutils">
<tbody>
<tr>
<th>Pin </th>
<th>Signal </th>
<th>Volt </th>
</tr>
<tr>
<td>1 (red)</td>
<td>VCC</td>
<td>+5V</td>
</tr>
<tr>
<td>2 (blk)</td>
<td>D_minus</td>
<td>+3.3V</td>
</tr>
<tr>
<td>3 (blk)</td>
<td>D_plus</td>
<td>+3.3V</td>
</tr>
<tr>
<td>4 (blk)</td>
<td>GND</td>
<td>GND</td>
</tr>
</tbody>
</table>
## RC Input
RC input is configured on the RCIN pin, at one end of the servo rail,
marked RCIN in the above diagram. This pin supports all RC
protocols. In addition there is a dedicated Spektrum satellite port
which supports software power control, allowing for binding of
Spektrum satellite receivers.
## PWM Output
The Durandal supports up to 16 PWM outputs. First first 8 outputs (labelled
"MAIN") are controlled by a dedicated STM32F100 IO controller. These 8
outputs support all PWM output formats, but not DShot.
The remaining 6 outputs (labelled AUX1 to AUX6) are the "auxillary"
outputs. These are directly attached to the STM32F427 and support all
PWM protocols as well as DShot.
All 14 PWM outputs have GND on the top row, 5V on the middle row and
signal on the bottom row.
The 8 main PWM outputs are in 3 groups:
- PWM 1 and 2 in group1
- PWM 3 and 4 in group2
- PWM 5, 6, 7 and 8 in group3
The 8 auxillary PWM outputs are in 2 groups:
- PWM 1, 2, 3 and 4 in group4
- PWM 5 and 6 in group5
- PWM 7 and 8 in group6 (no DMA, no 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 the group need
to use DShot.
## Battery Monitoring
The board has two dedicated power monitor ports on 6 pin
connectors. The correct battery setting parameters are dependent on
the type of power brick which is connected.
## Compass
The Durandal has one builtin IST8310 compass.
## GPIOs
The 8 PWM ports can be used as GPIOs (relays, buttons, RPM etc). To
use them you need to limit the number of these pins that is used for
PWM by setting the BRD_PWM_COUNT to a number less than 8. For example
if you set BRD_PWM_COUNT to 6 then PWM7 and PWM8 will be available for
use as GPIOs.
The numbering of the GPIOs for PIN variables in ArduPilot is:
- PWM1 50
- PWM2 51
- PWM3 52
- PWM4 53
- PWM5 54
- PWM6 55
- PWM7 56
- PWM8 57
## Analog inputs
The Durandal has 7 analog inputs
- ADC Pin16 -> Battery Voltage
- ADC Pin17 -> Battery Current Sensor
- ADC Pin14 -> Battery2 Voltage
- ADC Pin15 -> Battery2 Current Sensor
- ADC Pin4 -> ADC port pin 8 (3.3V limit)
- ADC Pin18 -> ADC port pin 9 (6.6V limit)
- ADC Pin9 -> RSSI in
- ADC Pin10 -> 5V Sense
- ADC Pin11 -> 3.3V Sense
## IMU Heater
The IMU heater in the Durandal can be controlled with the
BRD_IMU_TARGTEMP parameter, which is in degrees C.
## Loading Firmware
The board comes pre-installed with an ArduPilot compatible bootloader,
allowing the loading of *.apj firmware files with any ArduPilot
compatible ground station.
## Acknowledgements
Thanks to [Holybro](http://www.holybro.com) for images