Merge pull request #5151 from Faduf/CypressFlashSupport
[betaflight.git] / docs / Serial.md
blob6c64ce35e0094ad90737819137d357c80dec51ae
1 # Serial
3 Cleanflight has enhanced serial port flexibility but configuration is slightly more complex as a result.
5 Cleanflight has the concept of a function (MSP, GPS, Serial RX, etc) and a port (VCP, UARTx, SoftSerial x).
6 Not all functions can be used on all ports due to hardware pin mapping, conflicting features, hardware, and software
7 constraints.
9 ## Serial port types
11 * USB Virtual Com Port (VCP) - USB pins on a USB port connected directly to the processor without requiring
12 a dedicated USB to UART adapter.  VCP does not 'use' a physical UART port.
13 * UART - A pair of dedicated hardware transmit and receive pins with signal detection and generation done in hardware.
14 * SoftSerial - A pair of hardware transmit and receive pins with signal detection and generation done in software.
16 UART is the most efficient in terms of CPU usage.
17 SoftSerial is the least efficient and slowest, SoftSerial should only be used for low-bandwidth usages, such as telemetry transmission.
19 UART ports are sometimes exposed via on-board USB to UART converters, such as the CP2102 as found on the Naze and Flip32 boards.
20 If the flight controller does not have an on-board USB to UART converter and doesn't support VCP then an external USB to UART board is required.
21 These are sometimes referred to as FTDI boards.  FTDI is just a common manufacturer of a chip (the FT232RL) used on USB to UART boards.
23 When selecting a USB to UART converter choose one that has DTR exposed as well as a selector for 3.3v and 5v since they are more useful.
25 Examples:
27  * [FT232RL FTDI USB To TTL Serial Converter Adapter](http://www.banggood.com/FT232RL-FTDI-USB-To-TTL-Serial-Converter-Adapter-Module-For-Arduino-p-917226.html)
28  * [USB To TTL / COM Converter Module buildin-in CP2102](http://www.banggood.com/Wholesale-USB-To-TTL-Or-COM-Converter-Module-Buildin-in-CP2102-New-p-27989.html)
30 Both SoftSerial and UART ports can be connected to your computer via USB to UART converter boards. 
32 ## Serial Configuration
34 Serial port configuration is best done via the configurator.
36 Configure serial ports first, then enable/disable features that use the ports.  To configure SoftSerial ports the SOFTSERIAL feature must be also be enabled. 
38 ### Constraints
40 If the configuration is invalid the serial port configuration will reset to its defaults and features may be disabled.
42 * There must always be a port available to use for MSP/CLI.
43 * There is a maximum of 2 MSP ports.
44 * To use a port for a function, the function's corresponding feature must be also be enabled.
45 e.g. after configuring a port for GPS enable the GPS feature.
46 * If SoftSerial is used, then all SoftSerial ports must use the same baudrate.
47 * Softserial is limited to 19200 baud.
48 * All telemetry systems except MSP will ignore any attempts to override the baudrate.
49 * MSP/CLI can be shared with EITHER Blackbox OR telemetry.  In shared mode blackbox or telemetry will be output only when armed.
50 * Smartport telemetry cannot be shared with MSP.
51 * No other serial port sharing combinations are valid.
52 * You can use as many different telemetry systems as you like at the same time.
53 * You can only use each telemetry system once.  e.g.  FrSky telemetry cannot be used on two port, but MSP Telemetry + FrSky on different ports is fine.
55 ### Configuration via CLI
57 You can use the CLI for configuration but the commands are reserved for developers and advanced users.
59 The `serial` CLI command takes 6 arguments.
61 1. Identifier (see serialPortIdentifier_e in the source)
62 1. Function bitmask (see serialPortFunction_e in the source)
63 1. MSP baud rate
64 1. GPS baud rate
65 1. Telemetry baud rate (auto baud allowed)
66 1. Blackbox baud rate
69 ### Baud Rates
71 The allowable baud rates are as follows:
73 | Identifier | Baud rate |
74 | ---------- | --------- |
75 | 0          | Auto      |
76 | 1          | 9600      |
77 | 2          | 19200     |
78 | 3          | 38400     |
79 | 4          | 57600     |
80 | 5          | 115200    |
81 | 6          | 230400    |
82 | 7          | 250000    |
86 ### Passthrough
88 Cleanflight can enter a special passthrough mode whereby it passes serial data through to a device connected to a UART/SoftSerial port. This is useful to change the configuration of a Cleanflight peripheral such as an OSD, bluetooth dongle, serial RX etc.
90 To initiate passthrough mode, use the CLI command `serialpassthrough` This command takes three arguments.
92     serialpassthrough <id> [baud] [mode]
94 ID is the internal identifier of the serial port from Cleanflight source code (see serialPortIdentifier_e in the source). For instance UART1-UART4 are 0-3 and SoftSerial1/SoftSerial2 are 30/31 respectively. Baud is the desired baud rate, and mode is a combination of the keywords rx and tx (rxtx is full duplex). The baud and mode parameters can be used to override the configured values for the specified port.
96 For example. If you have your MWOSD connected to UART 2, you could enable communicaton to this device using the following command. This command does not specify the baud rate or mode, using the one configured for the port (see above).
98     serialpassthrough 1
100 _To use a tool such as the MWOSD GUI, it is necessary to disconnect or exit Cleanflight configurator._
102 **To exit serial passthrough mode, power cycle your flight control board.**