From 1c9e5598ce801204ac9024d35fcea64ab511fa4e Mon Sep 17 00:00:00 2001 From: Martin Budden Date: Mon, 1 May 2017 09:43:01 +0100 Subject: [PATCH] Allow high serial baudrates for OpenLager blackbox logging --- src/main/blackbox/blackbox_io.c | 23 +++++++++++++--- src/main/fc/cli.c | 48 ++++++++++++++++----------------- 2 files changed, 44 insertions(+), 27 deletions(-) diff --git a/src/main/blackbox/blackbox_io.c b/src/main/blackbox/blackbox_io.c index 101878507..41ee6a909 100644 --- a/src/main/blackbox/blackbox_io.c +++ b/src/main/blackbox/blackbox_io.c @@ -206,16 +206,33 @@ bool blackboxDeviceOpen(void) BLACKBOX_SERIAL_PORT_MODE, portOptions); /* - * The slowest MicroSD cards have a write latency approaching 150ms. The OpenLog's buffer is about 900 + * The slowest MicroSD cards have a write latency approaching 400ms. The OpenLog's buffer is about 900 * bytes. In order for its buffer to be able to absorb this latency we must write slower than 6000 B/s. * - * So: + * The OpenLager has a 125KB buffer for when the the MicroSD card is busy, so when the user configures + * high baud rates, assume the OpenLager is in use and so there is no need to constrain the writes. + * + * In all other cases, constrain the writes as follows: + * * Bytes per loop iteration = floor((looptime_ns / 1000000.0) * 6000) * = floor((looptime_ns * 6000) / 1000000.0) * = floor((looptime_ns * 3) / 500.0) * = (looptime_ns * 3) / 500 */ - blackboxMaxHeaderBytesPerIteration = constrain((targetPidLooptime * 3) / 500, 1, BLACKBOX_TARGET_HEADER_BUDGET_PER_ITERATION); + + + switch(baudRateIndex) { + case BAUD_1000000: + case BAUD_1500000: + case BAUD_2000000: + case BAUD_2470000: + // assume OpenLager in use, so do not constrain writes + blackboxMaxHeaderBytesPerIteration = BLACKBOX_TARGET_HEADER_BUDGET_PER_ITERATION; + break; + default: + blackboxMaxHeaderBytesPerIteration = constrain((targetPidLooptime * 3) / 500, 1, BLACKBOX_TARGET_HEADER_BUDGET_PER_ITERATION); + break; + }; return blackboxPort != NULL; } diff --git a/src/main/fc/cli.c b/src/main/fc/cli.c index e4343edf2..7f9fd7427 100755 --- a/src/main/fc/cli.c +++ b/src/main/fc/cli.c @@ -779,30 +779,30 @@ static void cliSerial(char *cmdline) } switch(i) { - case 0: - if (baudRateIndex < BAUD_9600 || baudRateIndex > BAUD_1000000) { - continue; - } - portConfig.msp_baudrateIndex = baudRateIndex; - break; - case 1: - if (baudRateIndex < BAUD_9600 || baudRateIndex > BAUD_115200) { - continue; - } - portConfig.gps_baudrateIndex = baudRateIndex; - break; - case 2: - if (baudRateIndex != BAUD_AUTO && baudRateIndex > BAUD_115200) { - continue; - } - portConfig.telemetry_baudrateIndex = baudRateIndex; - break; - case 3: - if (baudRateIndex < BAUD_19200 || baudRateIndex > BAUD_250000) { - continue; - } - portConfig.blackbox_baudrateIndex = baudRateIndex; - break; + case 0: + if (baudRateIndex < BAUD_9600 || baudRateIndex > BAUD_1000000) { + continue; + } + portConfig.msp_baudrateIndex = baudRateIndex; + break; + case 1: + if (baudRateIndex < BAUD_9600 || baudRateIndex > BAUD_115200) { + continue; + } + portConfig.gps_baudrateIndex = baudRateIndex; + break; + case 2: + if (baudRateIndex != BAUD_AUTO && baudRateIndex > BAUD_115200) { + continue; + } + portConfig.telemetry_baudrateIndex = baudRateIndex; + break; + case 3: + if (baudRateIndex < BAUD_19200 || baudRateIndex > BAUD_2470000) { + continue; + } + portConfig.blackbox_baudrateIndex = baudRateIndex; + break; } validArgumentCount++;