1
0
Fork 0
mirror of https://github.com/betaflight/betaflight.git synced 2025-07-15 12:25:20 +03:00

Removed 'slots' from the adjustment range configuration. (#8369)

Removed 'slots' from the adjustment range configuration.
This commit is contained in:
Michael Keller 2019-06-05 18:51:02 +12:00 committed by GitHub
commit d486c47bc1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 252 additions and 351 deletions

View file

@ -1368,7 +1368,7 @@ static void cliSerialPassthrough(char *cmdline)
static void printAdjustmentRange(dumpFlags_t dumpMask, const adjustmentRange_t *adjustmentRanges, const adjustmentRange_t *defaultAdjustmentRanges, const char *headingStr) static void printAdjustmentRange(dumpFlags_t dumpMask, const adjustmentRange_t *adjustmentRanges, const adjustmentRange_t *defaultAdjustmentRanges, const char *headingStr)
{ {
const char *format = "adjrange %u %u %u %u %u %u %u %u %u"; const char *format = "adjrange %u 0 %u %u %u %u %u %u %u";
// print out adjustment ranges channel settings // print out adjustment ranges channel settings
headingStr = cliPrintSectionHeading(dumpMask, false, headingStr); headingStr = cliPrintSectionHeading(dumpMask, false, headingStr);
for (uint32_t i = 0; i < MAX_ADJUSTMENT_RANGE_COUNT; i++) { for (uint32_t i = 0; i < MAX_ADJUSTMENT_RANGE_COUNT; i++) {
@ -1380,7 +1380,6 @@ static void printAdjustmentRange(dumpFlags_t dumpMask, const adjustmentRange_t *
headingStr = cliPrintSectionHeading(dumpMask, !equalsDefault, headingStr); headingStr = cliPrintSectionHeading(dumpMask, !equalsDefault, headingStr);
cliDefaultPrintLinef(dumpMask, equalsDefault, format, cliDefaultPrintLinef(dumpMask, equalsDefault, format,
i, i,
arDefault->adjustmentIndex,
arDefault->auxChannelIndex, arDefault->auxChannelIndex,
MODE_STEP_TO_CHANNEL_VALUE(arDefault->range.startStep), MODE_STEP_TO_CHANNEL_VALUE(arDefault->range.startStep),
MODE_STEP_TO_CHANNEL_VALUE(arDefault->range.endStep), MODE_STEP_TO_CHANNEL_VALUE(arDefault->range.endStep),
@ -1392,7 +1391,6 @@ static void printAdjustmentRange(dumpFlags_t dumpMask, const adjustmentRange_t *
} }
cliDumpPrintLinef(dumpMask, equalsDefault, format, cliDumpPrintLinef(dumpMask, equalsDefault, format,
i, i,
ar->adjustmentIndex,
ar->auxChannelIndex, ar->auxChannelIndex,
MODE_STEP_TO_CHANNEL_VALUE(ar->range.startStep), MODE_STEP_TO_CHANNEL_VALUE(ar->range.startStep),
MODE_STEP_TO_CHANNEL_VALUE(ar->range.endStep), MODE_STEP_TO_CHANNEL_VALUE(ar->range.endStep),
@ -1406,7 +1404,7 @@ static void printAdjustmentRange(dumpFlags_t dumpMask, const adjustmentRange_t *
static void cliAdjustmentRange(char *cmdline) static void cliAdjustmentRange(char *cmdline)
{ {
const char *format = "adjrange %u %u %u %u %u %u %u %u %u"; const char *format = "adjrange %u 0 %u %u %u %u %u %u %u";
int i, val = 0; int i, val = 0;
const char *ptr; const char *ptr;
@ -1422,11 +1420,10 @@ static void cliAdjustmentRange(char *cmdline)
ptr = nextArg(ptr); ptr = nextArg(ptr);
if (ptr) { if (ptr) {
val = atoi(ptr); val = atoi(ptr);
if (val >= 0 && val < MAX_SIMULTANEOUS_ADJUSTMENT_COUNT) { // Was: slot
ar->adjustmentIndex = val; // Keeping the parameter to retain backwards compatibility for the command format.
validArgumentCount++; validArgumentCount++;
} }
}
ptr = nextArg(ptr); ptr = nextArg(ptr);
if (ptr) { if (ptr) {
val = atoi(ptr); val = atoi(ptr);
@ -1482,7 +1479,6 @@ static void cliAdjustmentRange(char *cmdline)
cliDumpPrintLinef(0, false, format, cliDumpPrintLinef(0, false, format,
i, i,
ar->adjustmentIndex,
ar->auxChannelIndex, ar->auxChannelIndex,
MODE_STEP_TO_CHANNEL_VALUE(ar->range.startStep), MODE_STEP_TO_CHANNEL_VALUE(ar->range.startStep),
MODE_STEP_TO_CHANNEL_VALUE(ar->range.endStep), MODE_STEP_TO_CHANNEL_VALUE(ar->range.endStep),
@ -5806,7 +5802,7 @@ static void cliHelp(char *cmdline);
// should be sorted a..z for bsearch() // should be sorted a..z for bsearch()
const clicmd_t cmdTable[] = { const clicmd_t cmdTable[] = {
CLI_COMMAND_DEF("adjrange", "configure adjustment ranges", NULL, cliAdjustmentRange), CLI_COMMAND_DEF("adjrange", "configure adjustment ranges", "<index> <unused> <range channel> <start> <end> <function> <select channel> [<center> <scale>]", cliAdjustmentRange),
CLI_COMMAND_DEF("aux", "configure modes", "<index> <mode> <aux> <start> <end> <logic>", cliAux), CLI_COMMAND_DEF("aux", "configure modes", "<index> <mode> <aux> <start> <end> <logic>", cliAux),
#ifdef USE_CLI_BATCH #ifdef USE_CLI_BATCH
CLI_COMMAND_DEF("batch", "start or end a batch of commands", "start | end", cliBatch), CLI_COMMAND_DEF("batch", "start or end a batch of commands", "start | end", cliBatch),

View file

@ -142,7 +142,7 @@ static void activateConfig(void)
initRcProcessing(); initRcProcessing();
resetAdjustmentStates(); activeAdjustmentRangeReset();
pidInit(currentPidProfile); pidInit(currentPidProfile);

View file

@ -63,7 +63,7 @@
#define ADJUSTMENT_RANGE_COUNT_INVALID -1 #define ADJUSTMENT_RANGE_COUNT_INVALID -1
PG_REGISTER_ARRAY(adjustmentRange_t, MAX_ADJUSTMENT_RANGE_COUNT, adjustmentRanges, PG_ADJUSTMENT_RANGE_CONFIG, 1); PG_REGISTER_ARRAY(adjustmentRange_t, MAX_ADJUSTMENT_RANGE_COUNT, adjustmentRanges, PG_ADJUSTMENT_RANGE_CONFIG, 2);
uint8_t pidAudioPositionToModeMap[7] = { uint8_t pidAudioPositionToModeMap[7] = {
// on a pot with a center detent, it's easy to have center area for off/default, then three positions to the left and three to the right. // on a pot with a center detent, it's easy to have center area for off/default, then three positions to the left and three to the right.
@ -80,10 +80,11 @@ uint8_t pidAudioPositionToModeMap[7] = {
// Note: Last 3 positions are currently pending implementations and use PID_AUDIO_OFF for now. // Note: Last 3 positions are currently pending implementations and use PID_AUDIO_OFF for now.
}; };
static int activeAdjustmentCount = ADJUSTMENT_RANGE_COUNT_INVALID; STATIC_UNIT_TESTED int stepwiseAdjustmentCount = ADJUSTMENT_RANGE_COUNT_INVALID;
static uint8_t activeAdjustmentArray[MAX_ADJUSTMENT_RANGE_COUNT]; STATIC_UNIT_TESTED timedAdjustmentState_t stepwiseAdjustments[MAX_ADJUSTMENT_RANGE_COUNT];
static int activeAbsoluteAdjustmentCount;
static uint8_t activeAbsoluteAdjustmentArray[MAX_ADJUSTMENT_RANGE_COUNT]; STATIC_UNIT_TESTED int continuosAdjustmentCount;
STATIC_UNIT_TESTED continuosAdjustmentState_t continuosAdjustments[MAX_ADJUSTMENT_RANGE_COUNT];
static void blackboxLogInflightAdjustmentEvent(adjustmentFunction_e adjustmentFunction, int32_t newValue) static void blackboxLogInflightAdjustmentEvent(adjustmentFunction_e adjustmentFunction, int32_t newValue)
{ {
@ -101,13 +102,6 @@ static void blackboxLogInflightAdjustmentEvent(adjustmentFunction_e adjustmentFu
#endif #endif
} }
STATIC_UNIT_TESTED uint8_t adjustmentStateMask = 0;
#define MARK_ADJUSTMENT_FUNCTION_AS_BUSY(adjustmentIndex) adjustmentStateMask |= (1 << adjustmentIndex)
#define MARK_ADJUSTMENT_FUNCTION_AS_READY(adjustmentIndex) adjustmentStateMask &= ~(1 << adjustmentIndex)
#define IS_ADJUSTMENT_FUNCTION_BUSY(adjustmentIndex) (adjustmentStateMask & (1 << adjustmentIndex))
// sync with adjustmentFunction_e // sync with adjustmentFunction_e
static const adjustmentConfig_t defaultAdjustmentConfigs[ADJUSTMENT_FUNCTION_COUNT - 1] = { static const adjustmentConfig_t defaultAdjustmentConfigs[ADJUSTMENT_FUNCTION_COUNT - 1] = {
{ {
@ -274,25 +268,6 @@ static int adjustmentRangeNameIndex = 0;
static int adjustmentRangeValue = -1; static int adjustmentRangeValue = -1;
#endif #endif
#define ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET 1
STATIC_UNIT_TESTED adjustmentState_t adjustmentStates[MAX_SIMULTANEOUS_ADJUSTMENT_COUNT];
STATIC_UNIT_TESTED void configureAdjustment(uint8_t index, uint8_t auxSwitchChannelIndex, const adjustmentConfig_t *adjustmentConfig)
{
adjustmentState_t *adjustmentState = &adjustmentStates[index];
if (adjustmentState->config == adjustmentConfig) {
// already configured
return;
}
adjustmentState->auxChannelIndex = auxSwitchChannelIndex;
adjustmentState->config = adjustmentConfig;
adjustmentState->timeoutAt = 0;
MARK_ADJUSTMENT_FUNCTION_AS_READY(index);
}
static int applyStepAdjustment(controlRateConfig_t *controlRateConfig, uint8_t adjustmentFunction, int delta) static int applyStepAdjustment(controlRateConfig_t *controlRateConfig, uint8_t adjustmentFunction, int delta)
{ {
@ -682,154 +657,184 @@ static uint8_t applySelectAdjustment(adjustmentFunction_e adjustmentFunction, ui
return position; return position;
} }
#define ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET 1
static void calcActiveAdjustmentRanges(void) static void calcActiveAdjustmentRanges(void)
{ {
adjustmentRange_t defaultAdjustmentRange; adjustmentRange_t defaultAdjustmentRange;
memset(&defaultAdjustmentRange, 0, sizeof(defaultAdjustmentRange)); memset(&defaultAdjustmentRange, 0, sizeof(defaultAdjustmentRange));
activeAdjustmentCount = 0; stepwiseAdjustmentCount = 0;
activeAbsoluteAdjustmentCount = 0; continuosAdjustmentCount = 0;
for (int i = 0; i < MAX_ADJUSTMENT_RANGE_COUNT; i++) { for (int i = 0; i < MAX_ADJUSTMENT_RANGE_COUNT; i++) {
const adjustmentRange_t * const adjustmentRange = adjustmentRanges(i); const adjustmentRange_t * const adjustmentRange = adjustmentRanges(i);
if (memcmp(adjustmentRange, &defaultAdjustmentRange, sizeof(defaultAdjustmentRange)) != 0) { if (memcmp(adjustmentRange, &defaultAdjustmentRange, sizeof(defaultAdjustmentRange)) != 0) {
if (adjustmentRange->adjustmentCenter == 0) { const adjustmentConfig_t *adjustmentConfig = &defaultAdjustmentConfigs[adjustmentRange->adjustmentConfig - ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET];
activeAdjustmentArray[activeAdjustmentCount++] = i; if (adjustmentRange->adjustmentCenter == 0 && adjustmentConfig->mode != ADJUSTMENT_MODE_SELECT) {
timedAdjustmentState_t *adjustmentState = &stepwiseAdjustments[stepwiseAdjustmentCount++];
adjustmentState->adjustmentRangeIndex = i;
adjustmentState->timeoutAt = 0;
adjustmentState->ready = true;
} else { } else {
activeAbsoluteAdjustmentArray[activeAbsoluteAdjustmentCount++] = i; continuosAdjustmentState_t *adjustmentState = &continuosAdjustments[continuosAdjustmentCount++];
adjustmentState->adjustmentRangeIndex = i;
adjustmentState->lastRcData = 0;
} }
} }
} }
} }
static void updateAdjustmentStates(void) #define VALUE_DISPLAY_LATENCY_MS 2000
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
static void updateOsdAdjustmentData(int newValue, adjustmentFunction_e adjustmentFunction)
{ {
for (int index = 0; index < activeAdjustmentCount; index++) { static timeMs_t lastValueChangeMs;
const adjustmentRange_t * const adjustmentRange = adjustmentRanges(activeAdjustmentArray[index]);
// Only use slots if center value has not been specified, otherwise apply values directly (scaled) from aux channel timeMs_t currentTimeMs = millis();
if (isRangeActive(adjustmentRange->auxChannelIndex, &adjustmentRange->range) && if (newValue != -1
(adjustmentRange->adjustmentCenter == 0)) { && adjustmentFunction != ADJUSTMENT_RATE_PROFILE // Rate profile already has an OSD element
const adjustmentConfig_t *adjustmentConfig = &defaultAdjustmentConfigs[adjustmentRange->adjustmentConfig - ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET]; #ifdef USE_OSD_PROFILES
configureAdjustment(adjustmentRange->adjustmentIndex, adjustmentRange->auxSwitchChannelIndex, adjustmentConfig); && adjustmentFunction != ADJUSTMENT_OSD_PROFILE
} #endif
) {
adjustmentRangeNameIndex = adjustmentFunction;
adjustmentRangeValue = newValue;
lastValueChangeMs = currentTimeMs;
}
if (cmp32(currentTimeMs, lastValueChangeMs + VALUE_DISPLAY_LATENCY_MS) >= 0) {
adjustmentRangeNameIndex = 0;
} }
} }
#endif
#define RESET_FREQUENCY_2HZ (1000 / 2) #define RESET_FREQUENCY_2HZ (1000 / 2)
void processRcAdjustments(controlRateConfig_t *controlRateConfig) static void processStepwiseAdjustments(controlRateConfig_t *controlRateConfig, const bool canUseRxData)
{ {
const uint32_t now = millis(); const timeMs_t now = millis();
int newValue = -1; for (int index = 0; index < stepwiseAdjustmentCount; index++) {
timedAdjustmentState_t *adjustmentState = &stepwiseAdjustments[index];
const adjustmentRange_t *const adjustmentRange = adjustmentRanges(adjustmentState->adjustmentRangeIndex);
const adjustmentConfig_t *adjustmentConfig = &defaultAdjustmentConfigs[adjustmentRange->adjustmentConfig - ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET];
const adjustmentFunction_e adjustmentFunction = adjustmentConfig->adjustmentFunction;
const bool canUseRxData = rxIsReceivingSignal(); if (!isRangeActive(adjustmentRange->auxChannelIndex, &adjustmentRange->range) ||
adjustmentFunction == ADJUSTMENT_NONE) {
adjustmentState->timeoutAt = 0;
// Recalculate the new active adjustments if required
if (activeAdjustmentCount == ADJUSTMENT_RANGE_COUNT_INVALID) {
calcActiveAdjustmentRanges();
}
updateAdjustmentStates();
// Process Increment/Decrement adjustments
for (int adjustmentIndex = 0; adjustmentIndex < MAX_SIMULTANEOUS_ADJUSTMENT_COUNT; adjustmentIndex++) {
adjustmentState_t *adjustmentState = &adjustmentStates[adjustmentIndex];
if (!adjustmentState->config) {
continue;
}
const adjustmentFunction_e adjustmentFunction = adjustmentState->config->adjustmentFunction;
if (adjustmentFunction == ADJUSTMENT_NONE) {
continue; continue;
} }
if (cmp32(now, adjustmentState->timeoutAt) >= 0) { if (cmp32(now, adjustmentState->timeoutAt) >= 0) {
adjustmentState->timeoutAt = now + RESET_FREQUENCY_2HZ; adjustmentState->timeoutAt = now + RESET_FREQUENCY_2HZ;
MARK_ADJUSTMENT_FUNCTION_AS_READY(adjustmentIndex); adjustmentState->ready = true;
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
adjustmentRangeValue = -1;
#endif
} }
if (!canUseRxData) { if (!canUseRxData) {
continue; continue;
} }
const uint8_t channelIndex = NON_AUX_CHANNEL_COUNT + adjustmentState->auxChannelIndex; const uint8_t channelIndex = NON_AUX_CHANNEL_COUNT + adjustmentRange->auxSwitchChannelIndex;
if (adjustmentState->config->mode == ADJUSTMENT_MODE_STEP) { if (adjustmentConfig->mode == ADJUSTMENT_MODE_STEP) {
int delta; int delta;
if (rcData[channelIndex] > rxConfig()->midrc + 200) { if (rcData[channelIndex] > rxConfig()->midrc + 200) {
delta = adjustmentState->config->data.step; delta = adjustmentConfig->data.step;
} else if (rcData[channelIndex] < rxConfig()->midrc - 200) { } else if (rcData[channelIndex] < rxConfig()->midrc - 200) {
delta = -adjustmentState->config->data.step; delta = -adjustmentConfig->data.step;
} else { } else {
// returning the switch to the middle immediately resets the ready state // returning the switch to the middle immediately resets the ready state
MARK_ADJUSTMENT_FUNCTION_AS_READY(adjustmentIndex); adjustmentState->ready = true;
adjustmentState->timeoutAt = now + RESET_FREQUENCY_2HZ; adjustmentState->timeoutAt = now + RESET_FREQUENCY_2HZ;
continue; continue;
} }
if (IS_ADJUSTMENT_FUNCTION_BUSY(adjustmentIndex)) { if (!adjustmentState->ready) {
continue; continue;
} }
newValue = applyStepAdjustment(controlRateConfig, adjustmentFunction, delta); int newValue = applyStepAdjustment(controlRateConfig, adjustmentFunction, delta);
pidInitConfig(currentPidProfile); pidInitConfig(currentPidProfile);
} else if (adjustmentState->config->mode == ADJUSTMENT_MODE_SELECT) {
int switchPositions = adjustmentState->config->data.switchPositions; adjustmentState->ready = false;
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
updateOsdAdjustmentData(newValue, adjustmentConfig->adjustmentFunction);
#else
UNUSED(newValue);
#endif
}
}
}
static void processContinuosAdjustments(controlRateConfig_t *controlRateConfig)
{
for (int i = 0; i < continuosAdjustmentCount; i++) {
continuosAdjustmentState_t *adjustmentState = &continuosAdjustments[i];
const adjustmentRange_t * const adjustmentRange = adjustmentRanges(adjustmentState->adjustmentRangeIndex);
const uint8_t channelIndex = NON_AUX_CHANNEL_COUNT + adjustmentRange->auxSwitchChannelIndex;
const adjustmentConfig_t *adjustmentConfig = &defaultAdjustmentConfigs[adjustmentRange->adjustmentConfig - ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET];
const adjustmentFunction_e adjustmentFunction = adjustmentConfig->adjustmentFunction;
if (!isRangeActive(adjustmentRange->auxChannelIndex, &adjustmentRange->range) ||
adjustmentFunction == ADJUSTMENT_NONE ||
rcData[channelIndex] == adjustmentState->lastRcData) {
continue;
}
adjustmentState->lastRcData = rcData[channelIndex];
int newValue = -1;
if (adjustmentConfig->mode == ADJUSTMENT_MODE_SELECT) {
int switchPositions = adjustmentConfig->data.switchPositions;
if (adjustmentFunction == ADJUSTMENT_RATE_PROFILE && systemConfig()->rateProfile6PosSwitch) { if (adjustmentFunction == ADJUSTMENT_RATE_PROFILE && systemConfig()->rateProfile6PosSwitch) {
switchPositions = 6; switchPositions = 6;
} }
const uint16_t rangeWidth = (2100 - 900) / switchPositions; const uint16_t rangeWidth = (2100 - 900) / switchPositions;
const uint8_t position = (constrain(rcData[channelIndex], 900, 2100 - 1) - 900) / rangeWidth; const uint8_t position = (constrain(rcData[channelIndex], 900, 2100 - 1) - 900) / rangeWidth;
newValue = applySelectAdjustment(adjustmentFunction, position); newValue = applySelectAdjustment(adjustmentFunction, position);
} } else {
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
if (newValue != -1
&& adjustmentState->config->adjustmentFunction != ADJUSTMENT_RATE_PROFILE // Rate profile already has an OSD element
#ifdef USE_OSD_PROFILES
&& adjustmentState->config->adjustmentFunction != ADJUSTMENT_OSD_PROFILE
#endif
#ifdef USE_LED_STRIP
&& adjustmentState->config->adjustmentFunction != ADJUSTMENT_LED_PROFILE
#endif
) {
adjustmentRangeNameIndex = adjustmentFunction;
adjustmentRangeValue = newValue;
}
#else
UNUSED(newValue);
#endif
MARK_ADJUSTMENT_FUNCTION_AS_BUSY(adjustmentIndex);
}
// Process Absolute adjustments
for (int i = 0; i < activeAbsoluteAdjustmentCount; i++) {
static int16_t lastRcData[MAX_ADJUSTMENT_RANGE_COUNT] = { 0 };
int index = activeAbsoluteAdjustmentArray[i];
const adjustmentRange_t * const adjustmentRange = adjustmentRanges(index);
const uint8_t channelIndex = NON_AUX_CHANNEL_COUNT + adjustmentRange->auxSwitchChannelIndex;
const adjustmentConfig_t *adjustmentConfig = &defaultAdjustmentConfigs[adjustmentRange->adjustmentConfig - ADJUSTMENT_FUNCTION_CONFIG_INDEX_OFFSET];
// If setting is defined for step adjustment and center value has been specified, apply values directly (scaled) from aux channel // If setting is defined for step adjustment and center value has been specified, apply values directly (scaled) from aux channel
if ((rcData[channelIndex] != lastRcData[index]) && if (adjustmentRange->adjustmentCenter &&
adjustmentRange->adjustmentCenter && (adjustmentConfig->mode == ADJUSTMENT_MODE_STEP)) {
(adjustmentConfig->mode == ADJUSTMENT_MODE_STEP) &&
isRangeActive(adjustmentRange->auxChannelIndex, &adjustmentRange->range)) {
int value = (((rcData[channelIndex] - PWM_RANGE_MIDDLE) * adjustmentRange->adjustmentScale) / (PWM_RANGE_MIDDLE - PWM_RANGE_MIN)) + adjustmentRange->adjustmentCenter; int value = (((rcData[channelIndex] - PWM_RANGE_MIDDLE) * adjustmentRange->adjustmentScale) / (PWM_RANGE_MIDDLE - PWM_RANGE_MIN)) + adjustmentRange->adjustmentCenter;
lastRcData[index] = rcData[channelIndex]; newValue = applyAbsoluteAdjustment(controlRateConfig, adjustmentFunction, value);
applyAbsoluteAdjustment(controlRateConfig, adjustmentConfig->adjustmentFunction, value);
pidInitConfig(currentPidProfile); pidInitConfig(currentPidProfile);
} }
} }
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
updateOsdAdjustmentData(newValue, adjustmentConfig->adjustmentFunction);
#else
UNUSED(newValue);
#endif
}
} }
void resetAdjustmentStates(void) void processRcAdjustments(controlRateConfig_t *controlRateConfig)
{ {
memset(adjustmentStates, 0, sizeof(adjustmentStates)); const bool canUseRxData = rxIsReceivingSignal();
// Recalculate the new active adjustments if required
if (stepwiseAdjustmentCount == ADJUSTMENT_RANGE_COUNT_INVALID) {
calcActiveAdjustmentRanges();
}
processStepwiseAdjustments(controlRateConfig, canUseRxData);
if (canUseRxData) {
processContinuosAdjustments(controlRateConfig);
}
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
// Hide the element if there is no change
updateOsdAdjustmentData(-1, 0);
#endif
} }
#if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS) #if defined(USE_OSD) && defined(USE_OSD_ADJUSTMENTS)
@ -850,5 +855,5 @@ int getAdjustmentsRangeValue(void)
void activeAdjustmentRangeReset(void) void activeAdjustmentRangeReset(void)
{ {
activeAdjustmentCount = ADJUSTMENT_RANGE_COUNT_INVALID; stepwiseAdjustmentCount = ADJUSTMENT_RANGE_COUNT_INVALID;
} }

View file

@ -21,9 +21,11 @@
#pragma once #pragma once
#include <stdbool.h> #include <stdbool.h>
#include "pg/pg.h"
#include "fc/rc_modes.h" #include "fc/rc_modes.h"
#include "pg/pg.h"
typedef enum { typedef enum {
ADJUSTMENT_NONE = 0, ADJUSTMENT_NONE = 0,
ADJUSTMENT_RC_RATE, ADJUSTMENT_RC_RATE,
@ -90,27 +92,23 @@ typedef struct adjustmentRange_s {
uint8_t adjustmentConfig; uint8_t adjustmentConfig;
uint8_t auxSwitchChannelIndex; uint8_t auxSwitchChannelIndex;
// ... via slot
uint8_t adjustmentIndex;
uint16_t adjustmentCenter; uint16_t adjustmentCenter;
uint16_t adjustmentScale; uint16_t adjustmentScale;
} adjustmentRange_t; } adjustmentRange_t;
PG_DECLARE_ARRAY(adjustmentRange_t, MAX_ADJUSTMENT_RANGE_COUNT, adjustmentRanges); PG_DECLARE_ARRAY(adjustmentRange_t, MAX_ADJUSTMENT_RANGE_COUNT, adjustmentRanges);
#define ADJUSTMENT_INDEX_OFFSET 1 typedef struct timedAdjustmentState_s {
typedef struct adjustmentState_s {
uint8_t auxChannelIndex;
const adjustmentConfig_t *config;
uint32_t timeoutAt; uint32_t timeoutAt;
} adjustmentState_t; uint8_t adjustmentRangeIndex;
bool ready;
} timedAdjustmentState_t;
#ifndef MAX_SIMULTANEOUS_ADJUSTMENT_COUNT typedef struct continuosAdjustmentState_s {
#define MAX_SIMULTANEOUS_ADJUSTMENT_COUNT 4 // enough for 4 x 3position switches / 4 aux channel uint8_t adjustmentRangeIndex;
#endif int16_t lastRcData;
} continuosAdjustmentState_t;
void resetAdjustmentStates(void);
struct controlRateConfig_s; struct controlRateConfig_s;
void processRcAdjustments(struct controlRateConfig_s *controlRateConfig); void processRcAdjustments(struct controlRateConfig_s *controlRateConfig);
const char *getAdjustmentsRangeName(void); const char *getAdjustmentsRangeName(void);

View file

@ -1082,7 +1082,7 @@ static bool mspProcessOutCommand(uint8_t cmdMSP, sbuf_t *dst)
case MSP_ADJUSTMENT_RANGES: case MSP_ADJUSTMENT_RANGES:
for (int i = 0; i < MAX_ADJUSTMENT_RANGE_COUNT; i++) { for (int i = 0; i < MAX_ADJUSTMENT_RANGE_COUNT; i++) {
const adjustmentRange_t *adjRange = adjustmentRanges(i); const adjustmentRange_t *adjRange = adjustmentRanges(i);
sbufWriteU8(dst, adjRange->adjustmentIndex); sbufWriteU8(dst, 0); // was adjRange->adjustmentIndex
sbufWriteU8(dst, adjRange->auxChannelIndex); sbufWriteU8(dst, adjRange->auxChannelIndex);
sbufWriteU8(dst, adjRange->range.startStep); sbufWriteU8(dst, adjRange->range.startStep);
sbufWriteU8(dst, adjRange->range.endStep); sbufWriteU8(dst, adjRange->range.endStep);
@ -1826,17 +1826,13 @@ static mspResult_e mspProcessInCommand(uint8_t cmdMSP, sbuf_t *src)
i = sbufReadU8(src); i = sbufReadU8(src);
if (i < MAX_ADJUSTMENT_RANGE_COUNT) { if (i < MAX_ADJUSTMENT_RANGE_COUNT) {
adjustmentRange_t *adjRange = adjustmentRangesMutable(i); adjustmentRange_t *adjRange = adjustmentRangesMutable(i);
i = sbufReadU8(src); sbufReadU8(src); // was adjRange->adjustmentIndex
if (i < MAX_SIMULTANEOUS_ADJUSTMENT_COUNT) {
adjRange->adjustmentIndex = i;
adjRange->auxChannelIndex = sbufReadU8(src); adjRange->auxChannelIndex = sbufReadU8(src);
adjRange->range.startStep = sbufReadU8(src); adjRange->range.startStep = sbufReadU8(src);
adjRange->range.endStep = sbufReadU8(src); adjRange->range.endStep = sbufReadU8(src);
adjRange->adjustmentConfig = sbufReadU8(src); adjRange->adjustmentConfig = sbufReadU8(src);
adjRange->auxSwitchChannelIndex = sbufReadU8(src); adjRange->auxSwitchChannelIndex = sbufReadU8(src);
} else {
return MSP_RESULT_ERROR;
}
activeAdjustmentRangeReset(); activeAdjustmentRangeReset();
} else { } else {
return MSP_RESULT_ERROR; return MSP_RESULT_ERROR;

View file

@ -455,8 +455,9 @@ char osdGetTemperatureSymbolForSelectedUnit(void)
#ifdef USE_OSD_ADJUSTMENTS #ifdef USE_OSD_ADJUSTMENTS
static void osdElementAdjustmentRange(osdElementParms_t *element) static void osdElementAdjustmentRange(osdElementParms_t *element)
{ {
if (getAdjustmentsRangeName()) { const char *name = getAdjustmentsRangeName();
tfp_sprintf(element->buff, "%s: %3d", getAdjustmentsRangeName(), getAdjustmentsRangeValue()); if (name) {
tfp_sprintf(element->buff, "%s: %3d", name, getAdjustmentsRangeValue());
} }
} }
#endif // USE_OSD_ADJUSTMENTS #endif // USE_OSD_ADJUSTMENTS

View file

@ -241,17 +241,14 @@ void resetMillis(void) {
extern "C" { extern "C" {
PG_REGISTER(rxConfig_t, rxConfig, PG_RX_CONFIG, 0); PG_REGISTER(rxConfig_t, rxConfig, PG_RX_CONFIG, 0);
void configureAdjustment(uint8_t index, uint8_t auxSwitchChannelIndex, const adjustmentConfig_t *adjustmentConfig);
extern uint8_t adjustmentStateMask; extern int stepwiseAdjustmentCount;
extern adjustmentState_t adjustmentStates[MAX_SIMULTANEOUS_ADJUSTMENT_COUNT]; extern timedAdjustmentState_t stepwiseAdjustments[MAX_ADJUSTMENT_RANGE_COUNT];
static const adjustmentConfig_t rateAdjustmentConfig = { extern int continuosAdjustmentCount;
.adjustmentFunction = ADJUSTMENT_RC_RATE, extern continuosAdjustmentState_t continuosAdjustments[MAX_ADJUSTMENT_RANGE_COUNT];
.mode = ADJUSTMENT_MODE_STEP,
.data = { 1 }
};
} }
class RcControlsAdjustmentsTest : public ::testing::Test { class RcControlsAdjustmentsTest : public ::testing::Test {
protected: protected:
controlRateConfig_t controlRateConfig = { controlRateConfig_t controlRateConfig = {
@ -267,10 +264,14 @@ protected:
.tpa_breakpoint = 0 .tpa_breakpoint = 0
}; };
virtual void SetUp() { channelRange_t fullRange = {
adjustmentStateMask = 0; .startStep = MIN_MODE_RANGE_STEP,
memset(&adjustmentStates, 0, sizeof(adjustmentStates)); .endStep = MAX_MODE_RANGE_STEP
};
int adjustmentRangesIndex;
virtual void SetUp() {
PG_RESET(rxConfig); PG_RESET(rxConfig);
rxConfigMutable()->mincheck = DEFAULT_MIN_CHECK; rxConfigMutable()->mincheck = DEFAULT_MIN_CHECK;
rxConfigMutable()->maxcheck = DEFAULT_MAX_CHECK; rxConfigMutable()->maxcheck = DEFAULT_MAX_CHECK;
@ -289,13 +290,50 @@ protected:
controlRateConfig.dynThrPID = 0; controlRateConfig.dynThrPID = 0;
controlRateConfig.tpa_breakpoint = 0; controlRateConfig.tpa_breakpoint = 0;
PG_RESET(adjustmentRanges);
adjustmentRangesIndex = 0;
stepwiseAdjustmentCount = 0;
continuosAdjustmentCount = 0;
}
int configureAdjustmentRange(uint8_t switchChannelIndex, uint8_t adjustmentConfigIndex) {
adjustmentRange_t *adjustmentRange = adjustmentRangesMutable(adjustmentRangesIndex);
adjustmentRange->auxChannelIndex = AUX1 - NON_AUX_CHANNEL_COUNT;
adjustmentRange->range = fullRange;
adjustmentRange->adjustmentConfig = adjustmentConfigIndex;
adjustmentRange->auxSwitchChannelIndex = switchChannelIndex;
return adjustmentRangesIndex++;
}
timedAdjustmentState_t *configureStepwiseAdjustment(uint8_t switchChannelIndex, uint8_t adjustmentConfigIndex) {
int adjustmentRangeIndex = configureAdjustmentRange(switchChannelIndex, adjustmentConfigIndex);
timedAdjustmentState_t *adjustmentState = &stepwiseAdjustments[stepwiseAdjustmentCount++];
adjustmentState->adjustmentRangeIndex = adjustmentRangeIndex;
adjustmentState->timeoutAt = 0;
adjustmentState->ready = true;
return adjustmentState;
}
void configureContinuosAdjustment(uint8_t switchChannelIndex, uint8_t adjustmentConfigIndex) {
int adjustmentRangeIndex = configureAdjustmentRange(switchChannelIndex, adjustmentConfigIndex);
continuosAdjustmentState_t *adjustmentState = &continuosAdjustments[continuosAdjustmentCount++];
adjustmentState->adjustmentRangeIndex = adjustmentRangeIndex;
adjustmentState->lastRcData = 0;
} }
}; };
#define ADJUSTMENT_CONFIG_RATE_INDEX 1
TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsSticksInMiddle) TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsSticksInMiddle)
{ {
// given // given
configureAdjustment(0, AUX3 - NON_AUX_CHANNEL_COUNT, &rateAdjustmentConfig); const timedAdjustmentState_t *adjustmentState = configureStepwiseAdjustment(AUX3 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_CONFIG_RATE_INDEX);
// and // and
for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) { for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) {
@ -310,10 +348,10 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsSticksInMiddle)
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 90); EXPECT_EQ(90, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 90); EXPECT_EQ(90, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 0); EXPECT_EQ(0, CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP));
EXPECT_EQ(adjustmentStateMask, 0); EXPECT_EQ(true, adjustmentState->ready);
} }
TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp) TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp)
@ -339,9 +377,7 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
rxConfigMutable()->midrc = 1500; rxConfigMutable()->midrc = 1500;
// and // and
adjustmentStateMask = 0; const timedAdjustmentState_t *adjustmentState = configureStepwiseAdjustment(AUX3 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_CONFIG_RATE_INDEX);
memset(&adjustmentStates, 0, sizeof(adjustmentStates));
configureAdjustment(0, AUX3 - NON_AUX_CHANNEL_COUNT, &rateAdjustmentConfig);
// and // and
for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) { for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) {
@ -355,10 +391,6 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
// and // and
rcData[AUX3] = PWM_RANGE_MAX; rcData[AUX3] = PWM_RANGE_MAX;
// and
uint8_t expectedAdjustmentStateMask =
(1 << 0);
// and // and
fixedMillis = 496; fixedMillis = 496;
@ -366,10 +398,10 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 91); EXPECT_EQ(91, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 91); EXPECT_EQ(91, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 1); EXPECT_EQ(1, CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP));
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState->ready);
// //
// now pretend a short amount of time has passed, but not enough time to allow the value to have been increased // now pretend a short amount of time has passed, but not enough time to allow the value to have been increased
@ -381,9 +413,9 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
// when // when
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 91); EXPECT_EQ(91, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 91); EXPECT_EQ(91, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState->ready);
// //
@ -397,16 +429,12 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
// and // and
fixedMillis = 498; fixedMillis = 498;
// and
expectedAdjustmentStateMask = adjustmentStateMask &
~(1 << 0);
// when // when
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 91); EXPECT_EQ(91, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 91); EXPECT_EQ(91, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(true, adjustmentState->ready);
// //
@ -415,10 +443,6 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
// given // given
rcData[AUX3] = PWM_RANGE_MAX; rcData[AUX3] = PWM_RANGE_MAX;
// and
expectedAdjustmentStateMask =
(1 << 0);
// and // and
fixedMillis = 499; fixedMillis = 499;
@ -426,10 +450,10 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 92); EXPECT_EQ(92, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 92); EXPECT_EQ(92, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 2); EXPECT_EQ(2, CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP));
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState->ready);
// //
// leaving the switch up, after the original timer would have reset the state should now NOT cause // leaving the switch up, after the original timer would have reset the state should now NOT cause
@ -443,9 +467,9 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 92); EXPECT_EQ(92, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 92); EXPECT_EQ(92, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState->ready);
// //
// should still not be able to be increased // should still not be able to be increased
@ -458,9 +482,9 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 92); EXPECT_EQ(92, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 92); EXPECT_EQ(92, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState->ready);
// //
// 500ms has now passed since the switch was returned to the middle, now that // 500ms has now passed since the switch was returned to the middle, now that
@ -475,23 +499,18 @@ TEST_F(RcControlsAdjustmentsTest, processRcAdjustmentsWithRcRateFunctionSwitchUp
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(controlRateConfig.rcRates[FD_ROLL], 93); EXPECT_EQ(93, controlRateConfig.rcRates[FD_ROLL]);
EXPECT_EQ(controlRateConfig.rcRates[FD_PITCH], 93); EXPECT_EQ(93, controlRateConfig.rcRates[FD_PITCH]);
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 3); EXPECT_EQ(3, CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP));
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState->ready);
} }
static const adjustmentConfig_t rateProfileAdjustmentConfig = { #define ADJUSTMENT_RATE_PROFILE_INDEX 12
.adjustmentFunction = ADJUSTMENT_RATE_PROFILE,
.mode = ADJUSTMENT_MODE_SELECT,
.data = { 3 }
};
TEST_F(RcControlsAdjustmentsTest, processRcRateProfileAdjustments) TEST_F(RcControlsAdjustmentsTest, processRcRateProfileAdjustments)
{ {
// given // given
int adjustmentIndex = 3; configureContinuosAdjustment(AUX4 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_RATE_PROFILE_INDEX);
configureAdjustment(adjustmentIndex, AUX4 - NON_AUX_CHANNEL_COUNT, &rateProfileAdjustmentConfig);
// and // and
for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) { for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) {
@ -505,54 +524,20 @@ TEST_F(RcControlsAdjustmentsTest, processRcRateProfileAdjustments)
// and // and
rcData[AUX4] = PWM_RANGE_MAX; rcData[AUX4] = PWM_RANGE_MAX;
// and
uint8_t expectedAdjustmentStateMask =
(1 << adjustmentIndex);
// when // when
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 1); EXPECT_EQ(1, CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP));
EXPECT_EQ(CALL_COUNTER(COUNTER_CHANGE_CONTROL_RATE_PROFILE), 1); EXPECT_EQ(1, CALL_COUNTER(COUNTER_CHANGE_CONTROL_RATE_PROFILE));
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask);
} }
static const adjustmentConfig_t pidPitchAndRollPAdjustmentConfig = { #define ADJUSTMENT_PITCH_ROLL_P_INDEX 6
.adjustmentFunction = ADJUSTMENT_PITCH_ROLL_P, #define ADJUSTMENT_PITCH_ROLL_I_INDEX 7
.mode = ADJUSTMENT_MODE_STEP, #define ADJUSTMENT_PITCH_ROLL_D_INDEX 8
.data = { 1 } #define ADJUSTMENT_YAW_P_INDEX 9
}; #define ADJUSTMENT_YAW_I_INDEX 10
#define ADJUSTMENT_YAW_D_INDEX 11
static const adjustmentConfig_t pidPitchAndRollIAdjustmentConfig = {
.adjustmentFunction = ADJUSTMENT_PITCH_ROLL_I,
.mode = ADJUSTMENT_MODE_STEP,
.data = { 1 }
};
static const adjustmentConfig_t pidPitchAndRollDAdjustmentConfig = {
.adjustmentFunction = ADJUSTMENT_PITCH_ROLL_D,
.mode = ADJUSTMENT_MODE_STEP,
.data = { 1 }
};
static const adjustmentConfig_t pidYawPAdjustmentConfig = {
.adjustmentFunction = ADJUSTMENT_YAW_P,
.mode = ADJUSTMENT_MODE_STEP,
.data = { 1 }
};
static const adjustmentConfig_t pidYawIAdjustmentConfig = {
.adjustmentFunction = ADJUSTMENT_YAW_I,
.mode = ADJUSTMENT_MODE_STEP,
.data = { 1 }
};
static const adjustmentConfig_t pidYawDAdjustmentConfig = {
.adjustmentFunction = ADJUSTMENT_YAW_D,
.mode = ADJUSTMENT_MODE_STEP,
.data = { 1 }
};
TEST_F(RcControlsAdjustmentsTest, processPIDIncreasePidController0) TEST_F(RcControlsAdjustmentsTest, processPIDIncreasePidController0)
{ {
@ -572,12 +557,12 @@ TEST_F(RcControlsAdjustmentsTest, processPIDIncreasePidController0)
controlRateConfig_t controlRateConfig; controlRateConfig_t controlRateConfig;
memset(&controlRateConfig, 0, sizeof (controlRateConfig)); memset(&controlRateConfig, 0, sizeof (controlRateConfig));
configureAdjustment(0, AUX1 - NON_AUX_CHANNEL_COUNT, &pidPitchAndRollPAdjustmentConfig); const timedAdjustmentState_t *adjustmentState1 = configureStepwiseAdjustment(AUX1 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_PITCH_ROLL_P_INDEX);
configureAdjustment(1, AUX2 - NON_AUX_CHANNEL_COUNT, &pidPitchAndRollIAdjustmentConfig); const timedAdjustmentState_t *adjustmentState2 = configureStepwiseAdjustment(AUX2 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_PITCH_ROLL_I_INDEX);
configureAdjustment(2, AUX3 - NON_AUX_CHANNEL_COUNT, &pidPitchAndRollDAdjustmentConfig); const timedAdjustmentState_t *adjustmentState3 = configureStepwiseAdjustment(AUX3 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_PITCH_ROLL_D_INDEX);
configureAdjustment(3, AUX1 - NON_AUX_CHANNEL_COUNT, &pidYawPAdjustmentConfig); const timedAdjustmentState_t *adjustmentState4 = configureStepwiseAdjustment(AUX1 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_YAW_P_INDEX);
configureAdjustment(4, AUX2 - NON_AUX_CHANNEL_COUNT, &pidYawIAdjustmentConfig); const timedAdjustmentState_t *adjustmentState5 = configureStepwiseAdjustment(AUX2 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_YAW_I_INDEX);
configureAdjustment(5, AUX3 - NON_AUX_CHANNEL_COUNT, &pidYawDAdjustmentConfig); const timedAdjustmentState_t *adjustmentState6 = configureStepwiseAdjustment(AUX3 - NON_AUX_CHANNEL_COUNT, ADJUSTMENT_YAW_D_INDEX);
// and // and
for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) { for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) {
@ -593,23 +578,19 @@ TEST_F(RcControlsAdjustmentsTest, processPIDIncreasePidController0)
rcData[AUX2] = PWM_RANGE_MAX; rcData[AUX2] = PWM_RANGE_MAX;
rcData[AUX3] = PWM_RANGE_MAX; rcData[AUX3] = PWM_RANGE_MAX;
// and
uint8_t expectedAdjustmentStateMask =
(1 << 0) |
(1 << 1) |
(1 << 2) |
(1 << 3) |
(1 << 4) |
(1 << 5);
// when // when
currentPidProfile = &pidProfile; currentPidProfile = &pidProfile;
rcControlsInit(); rcControlsInit();
processRcAdjustments(&controlRateConfig); processRcAdjustments(&controlRateConfig);
// then // then
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 6); EXPECT_EQ(6, CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP));
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask); EXPECT_EQ(false, adjustmentState1->ready);
EXPECT_EQ(false, adjustmentState2->ready);
EXPECT_EQ(false, adjustmentState3->ready);
EXPECT_EQ(false, adjustmentState4->ready);
EXPECT_EQ(false, adjustmentState5->ready);
EXPECT_EQ(false, adjustmentState6->ready);
// and // and
EXPECT_EQ(1, pidProfile.pid[PID_PITCH].P); EXPECT_EQ(1, pidProfile.pid[PID_PITCH].P);
@ -623,82 +604,6 @@ TEST_F(RcControlsAdjustmentsTest, processPIDIncreasePidController0)
EXPECT_EQ(28, pidProfile.pid[PID_YAW].D); EXPECT_EQ(28, pidProfile.pid[PID_YAW].D);
} }
#if 0 // only one PID controller
TEST_F(RcControlsAdjustmentsTest, processPIDIncreasePidController2)
{
// given
pidProfile_t pidProfile;
memset(&pidProfile, 0, sizeof (pidProfile));
pidProfile.pidController = 2;
pidProfile.P_f[PIDPITCH] = 0.0f;
pidProfile.P_f[PIDROLL] = 5.0f;
pidProfile.P_f[PIDYAW] = 7.0f;
pidProfile.I_f[PIDPITCH] = 10.0f;
pidProfile.I_f[PIDROLL] = 15.0f;
pidProfile.I_f[PIDYAW] = 17.0f;
pidProfile.D_f[PIDPITCH] = 20.0f;
pidProfile.D_f[PIDROLL] = 25.0f;
pidProfile.D_f[PIDYAW] = 27.0f;
// and
controlRateConfig_t controlRateConfig;
memset(&controlRateConfig, 0, sizeof (controlRateConfig));
configureAdjustment(0, AUX1 - NON_AUX_CHANNEL_COUNT, &pidPitchAndRollPAdjustmentConfig);
configureAdjustment(1, AUX2 - NON_AUX_CHANNEL_COUNT, &pidPitchAndRollIAdjustmentConfig);
configureAdjustment(2, AUX3 - NON_AUX_CHANNEL_COUNT, &pidPitchAndRollDAdjustmentConfig);
configureAdjustment(3, AUX1 - NON_AUX_CHANNEL_COUNT, &pidYawPAdjustmentConfig);
configureAdjustment(4, AUX2 - NON_AUX_CHANNEL_COUNT, &pidYawIAdjustmentConfig);
configureAdjustment(5, AUX3 - NON_AUX_CHANNEL_COUNT, &pidYawDAdjustmentConfig);
// and
for (int index = AUX1; index < MAX_SUPPORTED_RC_CHANNEL_COUNT; index++) {
rcData[index] = PWM_RANGE_MIDDLE;
}
// and
resetCallCounters();
resetMillis();
// and
rcData[AUX1] = PWM_RANGE_MAX;
rcData[AUX2] = PWM_RANGE_MAX;
rcData[AUX3] = PWM_RANGE_MAX;
// and
uint8_t expectedAdjustmentStateMask =
(1 << 0) |
(1 << 1) |
(1 << 2) |
(1 << 3) |
(1 << 4) |
(1 << 5);
// when
currentPidProfile = &pidProfile;
rcControlsInit();
processRcAdjustments(&controlRateConfig, &rxConfig);
// then
EXPECT_EQ(CALL_COUNTER(COUNTER_QUEUE_CONFIRMATION_BEEP), 6);
EXPECT_EQ(adjustmentStateMask, expectedAdjustmentStateMask);
// and
EXPECT_EQ(0.01f, pidProfile.P_f[PIDPITCH]);
EXPECT_EQ(5.01f, pidProfile.P_f[PIDROLL]);
EXPECT_EQ(7.01f, pidProfile.P_f[PIDYAW]);
EXPECT_EQ(10.01f, pidProfile.I_f[PIDPITCH]);
EXPECT_EQ(15.01f, pidProfile.I_f[PIDROLL]);
EXPECT_EQ(17.01f, pidProfile.I_f[PIDYAW]);
EXPECT_EQ(20.001f, pidProfile.D_f[PIDPITCH]);
EXPECT_EQ(25.001f, pidProfile.D_f[PIDROLL]);
EXPECT_EQ(27.001f, pidProfile.D_f[PIDYAW]);
}
#endif
extern "C" { extern "C" {
void setConfigDirty(void) {} void setConfigDirty(void) {}
void saveConfigAndNotify(void) {} void saveConfigAndNotify(void) {}