mirror of
https://github.com/stianeikeland/go-rpio.git
synced 2025-01-23 10:41:03 +01:00
Improve performance of WritePin
This commit is contained in:
parent
a69ebca5ea
commit
b1b8e25712
2
rpio.go
2
rpio.go
|
@ -290,13 +290,13 @@ func WritePin(pin Pin, state State) {
|
||||||
clearReg := p/32 + 10
|
clearReg := p/32 + 10
|
||||||
|
|
||||||
memlock.Lock()
|
memlock.Lock()
|
||||||
defer memlock.Unlock()
|
|
||||||
|
|
||||||
if state == Low {
|
if state == Low {
|
||||||
gpioMem[clearReg] = 1 << (p & 31)
|
gpioMem[clearReg] = 1 << (p & 31)
|
||||||
} else {
|
} else {
|
||||||
gpioMem[setReg] = 1 << (p & 31)
|
gpioMem[setReg] = 1 << (p & 31)
|
||||||
}
|
}
|
||||||
|
memlock.Unlock() // not deferring saves ~600ns
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read the state of a pin
|
// Read the state of a pin
|
||||||
|
|
69
rpio_test.go
69
rpio_test.go
|
@ -129,25 +129,72 @@ func BenchmarkToggle(b *testing.B) {
|
||||||
pin.Mode(Input)
|
pin.Mode(Input)
|
||||||
pin.PullDown()
|
pin.PullDown()
|
||||||
|
|
||||||
oldToggle := func(pin Pin) {
|
b.Run("old", func(b *testing.B) {
|
||||||
switch ReadPin(pin) {
|
|
||||||
case Low:
|
|
||||||
pin.High()
|
|
||||||
case High:
|
|
||||||
pin.Low()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
b.Run("old toggle", func(b *testing.B) {
|
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
oldToggle(src)
|
oldToggle(src)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
b.Run("current toggle", func(b *testing.B) {
|
b.Run("current", func(b *testing.B) {
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
TogglePin(src)
|
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)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user