From b1b8e257128a8cb7539d80287bbf5f4d9cb9b1ac Mon Sep 17 00:00:00 2001 From: Drahoslav Date: Wed, 6 Jun 2018 00:28:17 +0200 Subject: [PATCH] Improve performance of WritePin --- rpio.go | 2 +- rpio_test.go | 69 +++++++++++++++++++++++++++++++++++++++++++--------- 2 files changed, 59 insertions(+), 12 deletions(-) diff --git a/rpio.go b/rpio.go index e9abf79..e453c80 100644 --- a/rpio.go +++ b/rpio.go @@ -290,13 +290,13 @@ func WritePin(pin Pin, state State) { clearReg := p/32 + 10 memlock.Lock() - defer memlock.Unlock() if state == Low { gpioMem[clearReg] = 1 << (p & 31) } else { gpioMem[setReg] = 1 << (p & 31) } + memlock.Unlock() // not deferring saves ~600ns } // Read the state of a pin diff --git a/rpio_test.go b/rpio_test.go index 5aef4c4..bd98eb2 100644 --- a/rpio_test.go +++ b/rpio_test.go @@ -129,25 +129,72 @@ func BenchmarkToggle(b *testing.B) { pin.Mode(Input) pin.PullDown() - oldToggle := func(pin Pin) { - switch ReadPin(pin) { - case Low: - pin.High() - case High: - pin.Low() - } - } - - b.Run("old toggle", func(b *testing.B) { + b.Run("old", func(b *testing.B) { for i := 0; i < b.N; i++ { oldToggle(src) } }) - b.Run("current toggle", func(b *testing.B) { + b.Run("current", func(b *testing.B) { for i := 0; i < b.N; i++ { TogglePin(src) } }) } + +func BenchmarkWrite(b *testing.B) { + src := Pin(3) + src.Mode(Output) + src.Low() + + pin := Pin(2) + pin.Mode(Input) + pin.PullDown() + + b.Run("old", func(b *testing.B) { + for i := 0; i < b.N; i++ { + if i%2 == 0 { + oldWrite(src, High) + } else { + oldWrite(src, Low) + } + } + }) + + b.Run("current", func(b *testing.B) { + for i := 0; i < b.N; i++ { + if i%2 == 0 { + WritePin(src, High) + } else { + WritePin(src, Low) + } + } + }) + +} + +func oldToggle(pin Pin) { + switch ReadPin(pin) { + case Low: + oldWrite(pin, High) + case High: + oldWrite(pin, Low) + } +} + +func oldWrite(pin Pin, state State) { + p := uint8(pin) + + setReg := p/32 + 7 + clearReg := p/32 + 10 + + memlock.Lock() + defer memlock.Unlock() + + if state == Low { + gpioMem[clearReg] = 1 << (p & 31) + } else { + gpioMem[setReg] = 1 << (p & 31) + } +}