From 09c59f11b9ce7a54d37cb9bf0ef74e472003ed3a Mon Sep 17 00:00:00 2001 From: Todd Stellanova Date: Wed, 9 Dec 2020 08:06:12 -0800 Subject: [PATCH] Always inline fastPinGetPinmap to speed pin sets Use separate pinSetFast benchmark for Gen3 Separate timing benchmarks for pinSet and pinReset --- user/tests/wiring/no_fixture/fastpin.cpp | 68 ++++++++++++++++++++++++ wiring/inc/fast_pin.h | 4 +- 2 files changed, 70 insertions(+), 2 deletions(-) create mode 100644 user/tests/wiring/no_fixture/fastpin.cpp diff --git a/user/tests/wiring/no_fixture/fastpin.cpp b/user/tests/wiring/no_fixture/fastpin.cpp new file mode 100644 index 0000000000..14a0309ea3 --- /dev/null +++ b/user/tests/wiring/no_fixture/fastpin.cpp @@ -0,0 +1,68 @@ + +#include "application.h" +#include "unit-test/unit-test.h" + + + +test(FASTPIN_01_MaxDuration_PinSet) { + // Attempt pinSetFast and pinResetFast numerous times and check speed. + // Duration went from about 62 -> 24 ticks per set on Gen2 with this change list + +#if HAL_PLATFORM_GEN == 3 + // expected max ticks of pinSetFast / pinResetFast on Gen3 + const uint32_t MAX_DURATION_PINSET_TICKS = 61; +#elif HAL_PLATFORM_GEN == 2 + // expected max ticks of pinSetFast / pinResetFast on Gen2 + const uint32_t MAX_DURATION_PINSET_TICKS = 24; +#else +#error "No gpio fastpin timing benchmark yet measured for this platform" +#endif + + const uint32_t NUM_ITERATIONS = 100; + uint32_t start, finish; + + ATOMIC_BLOCK() { + start = System.ticks(); + for (uint32_t i = 0; i < NUM_ITERATIONS; i++) { + pinSetFast(D7); + //pinResetFast(D7); + } + finish = System.ticks(); + } + uint32_t duration = finish - start; +// Serial.print("Set duration:"); +// Serial.println(duration); + assertLessOrEqual(duration, NUM_ITERATIONS*MAX_DURATION_PINSET_TICKS); +} + +test(FASTPIN_02_MaxDuration_PinReset) { + // Attempt pinResetFast numerous times and check speed. + +#if HAL_PLATFORM_GEN == 3 + // expected max ticks of pinResetFast on Gen3 + const uint32_t MAX_DURATION_PINRESET_TICKS = 60; +#elif HAL_PLATFORM_GEN == 2 + // expected max ticks of pinResetFast on Gen2 + const uint32_t MAX_DURATION_PINRESET_TICKS = 25; +#else +#error "No gpio fastpin timing benchmark yet measured for this platform" +#endif + + const uint32_t NUM_ITERATIONS = 100; + uint32_t start, finish; + + ATOMIC_BLOCK() { + start = System.ticks(); + for (uint32_t i = 0; i < NUM_ITERATIONS; i++) { + pinResetFast(D7); + } + finish = System.ticks(); + } + uint32_t duration = finish - start; +// Serial.print("Reset duration:"); +// Serial.println(duration); + assertLessOrEqual(duration, NUM_ITERATIONS*MAX_DURATION_PINRESET_TICKS); +} + + + diff --git a/wiring/inc/fast_pin.h b/wiring/inc/fast_pin.h index 607ba5d09f..a6261de4ea 100644 --- a/wiring/inc/fast_pin.h +++ b/wiring/inc/fast_pin.h @@ -32,8 +32,8 @@ extern "C" { * by @pkourany on PR: https://github.com/spark/firmware/pull/556 */ #define USE_BIT_BAND 0 -inline const Hal_Pin_Info* fastPinGetPinmap() { - static Hal_Pin_Info* pinMap = HAL_Pin_Map(); +__attribute__((always_inline)) inline const Hal_Pin_Info* fastPinGetPinmap() { + static const Hal_Pin_Info* pinMap = HAL_Pin_Map(); return pinMap; }