From f4db4e2b535cd722ce0f5ee6cd8094d4ba717c4f Mon Sep 17 00:00:00 2001 From: Brumi-2021 Date: Sat, 23 Oct 2021 22:17:18 +0200 Subject: [PATCH 1/2] Solving Compile error on gcc10 . Keeping same safety protection about the size of the array ,but with slightly different sintax. --- firmware/baseband/spectrum_collector.cpp | 32 +++++++++++++++++------- 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/firmware/baseband/spectrum_collector.cpp b/firmware/baseband/spectrum_collector.cpp index 5d1687b6..4256b362 100644 --- a/firmware/baseband/spectrum_collector.cpp +++ b/firmware/baseband/spectrum_collector.cpp @@ -27,7 +27,7 @@ #include "event_m4.hpp" #include "portapack_shared_memory.hpp" -#include "event_m4.hpp" +/* #include "event_m4.hpp" that line is duplicated, we can delete it .*/ #include @@ -105,24 +105,38 @@ void SpectrumCollector::post_message(const buffer_c16_t& data) { } } -template +/* 3 types of Windowing time domain shapes declaration , but only used Hamming , shapes for FFT + GCC10 compile sintax error c/m (1/2), + The primary diff. between const and constexpr variables is that + the initialization of a const var can be deferred until run time. + A constexpr var. must be initialized at compile time. ... + A var. can be declared with constexpr , when it has a literal type and is initialized. + GCC compile sintax error c/m (2/2) + Static assert --> Tests a software assertion at compile time for debugging. + we keep the same safety compile protection , just changing slightly the sintax checking that the size of the called array is power of 2. + if the bool "constant expression" is TRUE (normal case) , the declaration has no effect. + if the bool "constant expression" is FALSE (abnormal array size) , it is aborted the compile with a msg error. + */ + + +template // Although currently we are not using that Windowing shape, we apply the same GCC10 compile error c/m static typename T::value_type spectrum_window_none(const T& s, const size_t i) { - static_assert(power_of_two(s.size()), "Array size must be power of 2"); + static_assert(power_of_two(sizeof(s)), "Array size must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. return s[i]; }; -template +template // Currently we are calling and using that Window shape. static typename T::value_type spectrum_window_hamming_3(const T& s, const size_t i) { - static_assert(power_of_two(s.size()), "Array size must be power of 2"); - constexpr size_t mask = s.size() - 1; + static_assert(power_of_two(sizeof(s)), "Array size must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. + const size_t mask = s.size() - 1; // c/m compile error GCC10 , constexpr->const // Three point Hamming window. return s[i] * 0.54f + (s[(i-1) & mask] + s[(i+1) & mask]) * -0.23f; }; -template +template // Although currently we are not using that Windowing shape, we apply the same GCC10 compile error c/m static typename T::value_type spectrum_window_blackman_3(const T& s, const size_t i) { - static_assert(power_of_two(s.size()), "Array size must be power of 2"); - constexpr size_t mask = s.size() - 1; + static_assert(power_of_two(sizeof(s)), "Array size must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. + const size_t mask = s.size() - 1; // c/m compile error GCC10 , constexpr->const // Three term Blackman window. constexpr float alpha = 0.42f; constexpr float beta = 0.5f * 0.5f; From ab8f93805d835dfdeb6458d11964dac6f679eb00 Mon Sep 17 00:00:00 2001 From: Brumi-2021 Date: Mon, 25 Oct 2021 18:11:31 +0200 Subject: [PATCH 2/2] Small correction,of previous PR , about New_Feature_GCC_10_Compile_errors_#199 (based on sharebrained indications) --- firmware/baseband/spectrum_collector.cpp | 8 +++----- firmware/baseband/spectrum_collector.hpp | 3 +++ 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/firmware/baseband/spectrum_collector.cpp b/firmware/baseband/spectrum_collector.cpp index 4256b362..bdc5c77f 100644 --- a/firmware/baseband/spectrum_collector.cpp +++ b/firmware/baseband/spectrum_collector.cpp @@ -27,8 +27,6 @@ #include "event_m4.hpp" #include "portapack_shared_memory.hpp" -/* #include "event_m4.hpp" that line is duplicated, we can delete it .*/ - #include void SpectrumCollector::on_message(const Message* const message) { @@ -121,13 +119,13 @@ void SpectrumCollector::post_message(const buffer_c16_t& data) { template // Although currently we are not using that Windowing shape, we apply the same GCC10 compile error c/m static typename T::value_type spectrum_window_none(const T& s, const size_t i) { - static_assert(power_of_two(sizeof(s)), "Array size must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. +static_assert(power_of_two(ARRAY_ELEMENTS(s)), "Array number of elements must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. return s[i]; }; template // Currently we are calling and using that Window shape. static typename T::value_type spectrum_window_hamming_3(const T& s, const size_t i) { - static_assert(power_of_two(sizeof(s)), "Array size must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. + static_assert(power_of_two(ARRAY_ELEMENTS(s)), "Array number of elements must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. const size_t mask = s.size() - 1; // c/m compile error GCC10 , constexpr->const // Three point Hamming window. return s[i] * 0.54f + (s[(i-1) & mask] + s[(i+1) & mask]) * -0.23f; @@ -135,7 +133,7 @@ static typename T::value_type spectrum_window_hamming_3(const T& s, const size_t template // Although currently we are not using that Windowing shape, we apply the same GCC10 compile error c/m static typename T::value_type spectrum_window_blackman_3(const T& s, const size_t i) { - static_assert(power_of_two(sizeof(s)), "Array size must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. + static_assert(power_of_two(ARRAY_ELEMENTS(s)), "Array number of elements must be power of 2"); // c/m compile error GCC10 , OK for all GCC versions. const size_t mask = s.size() - 1; // c/m compile error GCC10 , constexpr->const // Three term Blackman window. constexpr float alpha = 0.42f; diff --git a/firmware/baseband/spectrum_collector.hpp b/firmware/baseband/spectrum_collector.hpp index c751539a..8fe5f745 100644 --- a/firmware/baseband/spectrum_collector.hpp +++ b/firmware/baseband/spectrum_collector.hpp @@ -22,6 +22,9 @@ #ifndef __SPECTRUM_COLLECTOR_H__ #define __SPECTRUM_COLLECTOR_H__ +#define ARRAY_ELEMENTS(x) (sizeof(x) / sizeof(x[0])) +/* sizeof() compile-time operator that returns #bytes of (data type). We used it to get #elements_array */ + #include "dsp_types.hpp" #include "complex.hpp"