Add OSD_STATE_GROUP_ELEMENTS state to osdUpdate() and optimise DMA vs polled MAX7456...
[betaflight.git] / docs / Blackbox.md
blobe6e12787f96143d7be8a45eb9affb7b41da050d7
1 # Blackbox flight data recorder
3 ![Rendered flight log frame](Screenshots/blackbox-screenshot-1.jpg)
5 ## Introduction
7 This feature transmits your flight data information on every control loop iteration over a serial port to an external
8 logging device like an OpenLog to be recorded, to an onboard dataflash chip which is present on some flight controllers,
9 or to an onboard SD card socket.
11 After your flight, you can view the resulting logs using the interactive log viewer:
13 https://github.com/cleanflight/blackbox-log-viewer
15 You can also use the `blackbox_decode` tool to turn the logs into CSV files for analysis, or render your flight log as a
16 video using the `blackbox_render` tool. Those tools can be found in this repository:
18 https://github.com/cleanflight/blackbox-tools
20 ## Logged data
21 The blackbox records flight data on every iteration of the flight control loop. It records the current time in
22 microseconds, P, I and D corrections for each axis, your RC command stick positions (after applying expo curves),
23 gyroscope data, accelerometer data (after your configured low-pass filtering), barometer and sonar readings, 3-axis
24 magnetometer readings, raw VBAT and current measurements, RSSI, and the command being sent to each motor speed
25 controller. This is all stored without any approximation or loss of precision, so even quite subtle problems should be
26 detectable from the fight data log.
28 GPS data is logged whenever new GPS data is available. Although the CSV decoder will decode this data, the video
29 renderer does not yet show any of the GPS information (this will be added later).
31 ## Supported configurations
33 The maximum data rate that can be recorded to the flight log is fairly restricted, so anything that increases the load
34 can cause the flight log to drop frames and contain errors.
36 The Blackbox is typically used on tricopters and quadcopters. Although it will work on hexacopters and octocopters,
37 because these craft have more motors to record, they must transmit more data to the flight log. This can increase the
38 number of dropped frames. Although the browser-based log viewer supports hexacopters and octocopters, the command-line 
39 `blackbox_render` tool currently only supports tri- and quadcopters.
41 Cleanflight's `looptime` setting decides how frequently an update is saved to the flight log. The default looptime on
42 Cleanflight is 3500. If you're using a looptime smaller than about 2400, you may experience some dropped frames due to
43 the high required data rate. In that case you will need to reduce the sampling rate in the Blackbox settings, or
44 increase your logger's baudrate to 250000. See the later section on configuring the Blackbox feature for details.
46 ## Setting up logging
48 First, you must enable the Blackbox feature. In the [Cleanflight Configurator][] enter the Configuration tab,
49 tick the "BLACKBOX" feature at the bottom of the page, and click "Save and reboot" 
51 Now you must decide which device to store your flight logs on. You can either transmit the log data over a serial port
52 to an external logging device like the [OpenLog serial data logger][] to be recorded to a microSDHC card, or if you have
53 a compatible flight controller you can store the logs on the onboard dataflash storage instead.
55 ### OpenLog serial data logger
57 The OpenLog is a small logging device which attaches to your flight controller using a serial port and logs your
58 flights to a MicroSD card.
60 The OpenLog ships from SparkFun with standard "OpenLog 3" firmware installed. Although this original OpenLog firmware
61 will work with the Blackbox, in order to reduce the number of dropped frames it should be reflashed with the
62 higher performance [OpenLog Blackbox firmware][]. The special Blackbox variant of the OpenLog firmware also ensures that
63 the OpenLog is using Cleanflight compatible settings, and defaults to 115200 baud.
65 You can find the Blackbox version of the OpenLog firmware [here](https://github.com/cleanflight/blackbox-firmware), 
66 along with instructions for installing it onto your OpenLog.
68 [OpenLog serial data logger]: https://www.sparkfun.com/products/9530
69 [OpenLog Blackbox firmware]: https://github.com/cleanflight/blackbox-firmware
71 #### microSDHC
73 Your choice of microSDHC card is very important to the performance of the system. The OpenLog relies on being able to
74 make many small writes to the card with minimal delay, which not every card is good at. A faster SD-card speed rating is
75 not a guarantee of better performance.
77 ##### microSDHC cards known to have poor performance
79  - Generic 4GB Class 4 microSDHC card - the rate of missing frames is about 1%, and is concentrated around the most
80    interesting parts of the log!
81  - Sandisk Ultra 32GB (unlike the smaller 16GB version, this version has poor write latency)
83 ##### microSDHC cards known to have good performance
85  - Transcend 16GB Class 10 UHS-I microSDHC (typical error rate < 0.1%)
86  - Sandisk Extreme 16GB Class 10 UHS-I microSDHC (typical error rate < 0.1%)
87  - Sandisk Ultra 16GB (it performs only half as well as the Extreme in theory, but still very good)
89 You should format any card you use with the [SD Association's special formatting tool][] , as it will give the OpenLog
90 the best chance of writing at high speed. You must format it with either FAT, or with FAT32 (recommended).
92 [SD Association's special formatting tool]: https://www.sdcard.org/downloads/formatter_4/
94 ### Choosing a serial port for the OpenLog
95 First, tell the Blackbox to log using a serial port (rather than to an onboard dataflash chip). Go to the
96 Configurator's CLI tab, enter `set blackbox_device=SERIAL` to switch logging to serial, and
97 save.
99 You need to let Cleanflight know which of [your serial ports][] you connect your OpenLog to (i.e. the Blackbox port),
100 which you can do on the Configurator's Ports tab.
102 You should use a hardware serial port (such as UART1 on the Naze32, the two-pin Tx/Rx header in the center of the
103 board). SoftSerial ports can be used for the Blackbox. However, because they are limited to 19200 baud, your logging 
104 rate will need to be severely reduced to compensate. Therefore the use of SoftSerial is not recommended.
106 When using a hardware serial port, Blackbox should be set to at least 115200 baud on that port. When using fast
107 looptimes (<2500), a baud rate of 250000 should be used instead in order to reduce dropped frames.
109 The serial port used for Blackbox cannot be shared with any other function (e.g. GPS, telemetry) except the MSP
110 protocol. If MSP is used on the same port as Blackbox, then MSP will be active when the board is disarmed, and Blackbox
111 will be active when the board is armed. This will mean that you can't use the Configurator or any other function that
112 requires MSP, such as an OSD or a Bluetooth wireless configuration app, while the board is armed.
114 Connect the "TX" pin of the serial port you've chosen to the OpenLog's "RXI" pin. Don't connect the serial port's RX
115 pin to the OpenLog, as this will cause the OpenLog to interfere with any shared functions on the serial port while
116 disarmed.
118 #### Naze32 serial port choices
120 On the Naze32, the TX/RX pins on top of the board are connected to UART1, and are shared with the USB connector.
121 Therefore, MSP must be enabled on UART1 in order to use the Configurator over USB. If Blackbox is connected to the pins
122 on top of the Naze32, the Configurator will stop working once the board is armed. This configuration is usually a good
123 choice if you don't already have an OSD installed which is using those pins while armed, and aren't using the FrSky
124 telemetry pins.
126 Pin RC3 on the side of the board is UART2's Tx pin. If Blackbox is configured on UART2, MSP can still be used on UART1
127 when the board is armed, which means that the Configurator will continue to work simultaneously with Blackbox logging.
128 Note that in `PARALLEL_PWM` mode this leaves the board with 6 input channels as RC3 and RC4 pins are used by UART2 as Tx and Rx. Cleanflight automatically shifts logical channel mapping for you when UART2 is enabled in `Ports` tab so you'll have to shift receiver pins that are connected to Naze32 pins 3 to 6 by two.
130 The OpenLog tolerates a power supply of between 3.3V and 12V. If you are powering your Naze32 with a standard 5V BEC,
131 then you can use a spare motor header's +5V and GND pins to power the OpenLog with.
133 #### Other flight controller hardware
134 Boards other than the Naze32 may have more accessible hardware serial devices, in which case refer to their
135 documentation to decide how to wire up the logger. The key criteria are:
137 * Should be a hardware serial port rather than SoftSerial.
138 * Cannot be shared with any other function (GPS, telemetry) except MSP.
139 * If MSP is used on the same UART, MSP will stop working when the board is armed.
141 #### OpenLog configuration
143 Power up the OpenLog with a microSD card inside, wait 10 seconds or so, then power it down and plug the microSD card
144 into your computer. You should find a "CONFIG.TXT" file on the card, open it up in a text editor. You should see the
145 baud rate that the OpenLog has been configured for (usually 115200 or 9600 from the factory). Set the baud rate to match
146 the rate you entered for the Blackbox in the Configurator's Port tab (typically 115200 or 250000).
148 Save the file and put the card back into your OpenLog, it will use those settings from now on.
150 If your OpenLog didn't write a CONFIG.TXT file, create a CONFIG.TXT file with these contents and store it in the root
151 of the MicroSD card:
154 115200
155 baud
158 If you are using the original OpenLog firmware, use this configuration instead:
161 115200,26,0,0,1,0,1
162 baud,escape,esc#,mode,verb,echo,ignoreRX
165 #### OpenLog protection
167 The OpenLog can be wrapped in black electrical tape or heat-shrink in order to insulate it from conductive frames (like
168 carbon fiber), but this makes its status LEDs impossible to see. I recommend wrapping it with some clear heatshrink
169 tubing instead.
171 ![OpenLog installed](Wiring/blackbox-installation-1.jpg "OpenLog installed with double-sided tape, SDCard slot pointing outward")
173 ### Onboard dataflash storage
174 Some flight controllers have an onboard SPI NOR dataflash chip which can be used to store flight logs instead of using
175 an OpenLog.
177 The full version of the Naze32 and the CC3D have an onboard "m25p16" 2 megabyte dataflash storage chip. This is a small
178 chip with 8 fat legs, which can be found at the base of the Naze32's direction arrow. This chip is not present on the
179 "Acro" version of the Naze32.
181 The SPRacingF3 has a larger 8 megabyte dataflash chip onboard which allows for longer recording times.
183 These chips are also supported:
185 * Micron/ST M25P16 - 16 Mbit / 2 MByte ([datasheet](http://www.micron.com/~/media/Documents/Products/Data%20Sheet/NOR%20Flash/Serial%20NOR/M25P/M25P16.pdf))
186 * Micron/ST N25Q064 - 64 Mbit / 8 MByte ([datasheet](http://www.micron.com/~/media/documents/products/data-sheet/nor-flash/serial-nor/n25q/n25q_64a_3v_65nm.pdf))
187 * Winbond W25Q64 - 64 Mbit / 8 MByte ([datasheet](http://www.winbond.com/resource-files/w25q64fv_revl1_100713.pdf))
188 * Macronix MX25L64 - 64 Mbit / 8 MByte ([datasheet](http://media.digikey.com/pdf/Data%20Sheets/Macronix/MX25L6406E.pdf))
189 * Micron/ST N25Q128 - 128 Mbit / 16 MByte ([datasheet](http://www.micron.com/~/media/Documents/Products/Data%20Sheet/NOR%20Flash/Serial%20NOR/N25Q/n25q_128mb_3v_65nm.pdf))
190 * Winbond W25Q128 - 128 Mbit / 16 MByte ([datasheet](http://www.winbond.com/resource-files/w25q128fv_revhh1_100913_website1.pdf))
192 #### Enable recording to dataflash
193 On the Configurator's CLI tab, you must enter `set blackbox_device=SPIFLASH` to switch to logging to an onboard dataflash chip,
194 then save.
196 [your serial ports]: https://github.com/cleanflight/cleanflight/blob/master/docs/Serial.md
197 [Cleanflight Configurator]: https://chrome.google.com/webstore/detail/cleanflight-configurator/enacoimjcgeinfnnnpajinjgmkahmfgb?hl=en
199 ### Onboard SD card socket
200 Some flight controllers have an SD or Micro SD card socket on their circuit boards. This allows for very high speed
201 logging (1KHz or faster, which is a looptime of 1000 or lower) on suitable cards.
203 The card can be either Standard (SDSC) or High capacity (SDHC), and must be formatted with the FAT16 or FAT32
204 filesystems. This covers a range of card capacities from 1 to 32GB. Extended capacity cards (SDXC) are not supported.
206 The first time you power up Cleanflight with a new card inserted, the flight controller will spend a few seconds
207 scanning the disk for free space and collecting this space together into a file called "FREESPAC.E". During flight,
208 Cleanflight will carve chunks from this file to create new log files. You must not edit this file on your computer (i.e.
209 open it in a program and save changes) because this may cause it to become fragmented. Don't run any defragmentation
210 tools on the card either.
212 You can delete the FREESPAC.E file if you want to free up space on the card to fit non-Blackbox files (Cleanflight will 
213 recreate the FREESPAC.E file next time it starts, using whatever free space was left over).
215 The maximum size of the FREESPAC.E file is currently 4GB. Once 4GB worth of logs have been recorded, the FREESPAC.E
216 file will be nearly empty and no more logs will be able to be recorded. At this point you should either delete the 
217 FREESPAC.E file (and any logs left on the card to free up space), or just reformat the card. A new FREESPAC.E file 
218 will be created by Cleanflight on its next boot.
220 #### Enable recording to SD card
221 On the Configurator's CLI tab, you must enter `set blackbox_device=SDCARD` to switch to logging to an onboard SD card,
222 then save.
224 ## Configuring the Blackbox
226 The Blackbox currently provides two settings (`blackbox_rate_num` and `blackbox_rate_denom`) that allow you to control 
227 the rate at which data is logged. These two together form a fraction (`blackbox_rate_num / blackbox_rate_denom`) which
228 decides what portion of the flight controller's control loop iterations should be logged. The default is 1/1 which logs 
229 every iteration.
231 If you're using a slower MicroSD card, you may need to reduce your logging rate to reduce the number of corrupted
232 logged frames that `blackbox_decode` complains about. A rate of 1/2 is likely to work for most craft.
234 You can change the logging rate settings by entering the CLI tab in the [Cleanflight Configurator][] and using the `set`
235 command, like so:
238 set blackbox_rate_num = 1
239 set blackbox_rate_denom = 2
242 The data rate for my quadcopter using a looptime of 2400 and a rate of 1/1 is about 10.25kB/s. This allows about 18
243 days of flight logs to fit on my OpenLog's 16GB MicroSD card, which ought to be enough for anybody :).
245 If you are logging using SoftSerial, you will almost certainly need to reduce your logging rate to 1/32. Even at that
246 logging rate, looptimes faster than about 1000 cannot be successfully logged.
248 If you're logging to an onboard dataflash chip instead of an OpenLog, be aware that the 2MB of storage space it offers
249 is pretty small. At the default 1/1 logging rate, and a 2400 looptime, this is only enough for about 3 minutes of
250 flight. This could be long enough for you to investigate some flying problem with your craft, but you may want to reduce
251 the logging rate in order to extend your recording time.
253 To maximize your recording time, you could drop the rate all the way down to 1/32 (the smallest possible rate) which
254 would result in a logging rate of about 10-20Hz and about 650 bytes/second of data. At that logging rate, a 2MB
255 dataflash chip can store around 50 minutes of flight data, though the level of detail is severely reduced and you could
256 not diagnose flight problems like vibration or PID setting issues.
258 ## Usage
260 The Blackbox starts recording data as soon as you arm your craft, and stops when you disarm.
262 If your craft has a buzzer attached, you can use Cleanflight's arming beep to synchronize your Blackbox log with your
263 flight video. Cleanflight's arming beep is a "long, short" pattern. The beginning of the first long beep will be shown 
264 as a blue line in the flight data log, which you can sync against your recorded audio track.
266 You should wait a few seconds after disarming your craft to allow the Blackbox to finish saving its data.
268 ### Usage - OpenLog
269 Each time the OpenLog is power-cycled, it begins a fresh new log file. If you arm and disarm several times without
270 cycling the power (recording several flights), those logs will be combined together into one file. The command line
271 tools will ask you to pick which one of these flights you want to display/decode.
273 Don't insert or remove the SD card while the OpenLog is powered up.
275 ### Usage - Dataflash chip
276 After your flights, you can use the [Cleanflight Configurator][] to download the contents of the dataflash to your
277 computer. Go to the "dataflash" tab and click the "save flash to file..." button. Saving the log can take 2 or 3
278 minutes.
280 ![Dataflash tab in Configurator](Screenshots/blackbox-dataflash.png)
282 After downloading the log, be sure to erase the chip to make it ready for reuse by clicking the "erase flash" button.
284 If you try to start recording a new flight when the dataflash is already full, Blackbox logging will be disabled and
285 nothing will be recorded.
287 ### Usage - Onboard SD card socket
288 You must insert your SD card before powering on your flight controller. You can remove the SD card while the board is
289 powered up, but you must wait 5 seconds after disarming before you do so in order to give Cleanflight a chance to finish
290 saving your log (otherwise the filesystem may become corrupted).
292 Cleanflight will create a new log file in the "LOG" directory each time the craft is armed. If you are using a Blackbox
293 logging switch and you keep it paused for the entire flight, the resulting empty log file will be deleted after disarming.
295 To read your logs, you must remove the SD card and insert it into a card reader on your computer (Cleanflight doesn't
296 support reading these logs directly through the Configurator).
298 ### Usage - Logging switch
299 If you're recording to an onboard flash chip, you probably want to disable Blackbox recording when not required in order
300 to save storage space. To do this, you can add a Blackbox flight mode to one of your AUX channels on the Configurator's 
301 modes tab. Once you've added a mode, Blackbox will only log flight data when the mode is active.
303 A log header will always be recorded at arming time, even if logging is paused. You can freely pause and resume logging 
304 while in flight.
306 ## Viewing recorded logs
307 After your flights, you'll have a series of flight log files with a .TXT extension.
309 You can view these .TXT flight log files interactively using your web browser with the Cleanflight Blackbox Explorer:
311 https://github.com/cleanflight/blackbox-log-viewer
313 This allows you to scroll around a graphed version of your log and examine your log in detail. You can also export a
314 video of your log to share it with others!
316 You can decode your logs with the `blackbox_decode` tool to create CSV (comma-separated values) files for analysis,
317 or render them into a series of PNG frames with `blackbox_render` tool, which you could then convert into a video using
318 another software package.
320 You'll find those tools along with instructions for using them in this repository:
322 https://github.com/cleanflight/blackbox-tools