From 6f5ea5a5e997c968747b94249e183c6894937c3d Mon Sep 17 00:00:00 2001 From: Peter Barker Date: Thu, 25 Jul 2024 15:55:54 +1000 Subject: [PATCH] RC_Channel: rework duplicate-rc-options check to use a Bitmask just for the memory saving. Co-authored-by: muramura --- libraries/RC_Channel/RC_Channel.cpp | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/libraries/RC_Channel/RC_Channel.cpp b/libraries/RC_Channel/RC_Channel.cpp index e0bdfed8e4..88ba857515 100644 --- a/libraries/RC_Channel/RC_Channel.cpp +++ b/libraries/RC_Channel/RC_Channel.cpp @@ -1859,7 +1859,7 @@ RC_Channel *RC_Channels::find_channel_for_option(const RC_Channel::AUX_FUNC opti // duplicate_options_exist - returns true if any options are duplicated bool RC_Channels::duplicate_options_exist() { - uint8_t auxsw_option_counts[512] = {}; + Bitmask<(uint16_t)RC_Channel::AUX_FUNC::AUX_FUNCTION_MAX> used_auxsw_options; for (uint8_t i=0; ioption.get(); - if (option >= sizeof(auxsw_option_counts)) { + if (option == (uint16_t)RC_Channel::AUX_FUNC::DO_NOTHING) { continue; } - auxsw_option_counts[option]++; - } - - for (uint16_t i=0; i= used_auxsw_options.size()) { continue; } - if (auxsw_option_counts[i] > 1) { + if (used_auxsw_options.get(option)) { return true; } + used_auxsw_options.set(option); } return false; }