Unverified Commit cc99d742 authored by Steven Allen's avatar Steven Allen Committed by GitHub

Merge pull request #17 from ipfs/feat/plus-9

Improve performance of buzhash
parents 21b0c066 79bdab24
...@@ -61,17 +61,33 @@ func (b *Buzhash) NextBytes() ([]byte, error) { ...@@ -61,17 +61,33 @@ func (b *Buzhash) NextBytes() ([]byte, error) {
var state uint32 = 0 var state uint32 = 0
if buzMin > len(b.buf) {
panic("this is impossible")
}
for ; i < buzMin; i++ { for ; i < buzMin; i++ {
state = bits.RotateLeft32(state, 1) state = bits.RotateLeft32(state, 1)
state = state ^ bytehash[b.buf[i]] state = state ^ bytehash[b.buf[i]]
} }
if b.n+n > len(b.buf) { {
panic("this is impossible, but gives +9 to performance") max := b.n + n - 32 - 1
}
for ; state&buzMask != 0 && i < b.n+n; i++ { buf := b.buf
state = bits.RotateLeft32(state, 1) ^ bytehash[b.buf[i-32]] ^ bytehash[b.buf[i]] bufshf := b.buf[32:]
i = buzMin - 32
_ = buf[max]
_ = bufshf[max]
for ; i <= max; i++ {
if state&buzMask == 0 {
break
}
state = bits.RotateLeft32(state, 1) ^
bytehash[buf[i]] ^
bytehash[bufshf[i]]
}
i += 32
} }
res := make([]byte, i) res := make([]byte, i)
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment