Commit 4a0dad21 authored by Michael McLoughlin's avatar Michael McLoughlin Committed by Filippo Valsorda

crypto/cipher: 8K benchmarks for AES stream modes

Some parallelizable cipher modes may achieve peak performance for larger
block sizes. For this reason the AES-GCM mode already has an 8K
benchmark alongside the 1K version. This change introduces 8K benchmarks
for additional AES stream cipher modes.

Updates #20967

Change-Id: If97c6fbf31222602dcc200f8f418d95908ec1202
Reviewed-on: https://go-review.googlesource.com/136897Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
Reviewed-by: default avatarFilippo Valsorda <filippo@golang.org>
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent 699da6bd
...@@ -81,70 +81,49 @@ func BenchmarkAESGCMOpen8K(b *testing.B) { ...@@ -81,70 +81,49 @@ func BenchmarkAESGCMOpen8K(b *testing.B) {
benchmarkAESGCMOpen(b, make([]byte, 8*1024)) benchmarkAESGCMOpen(b, make([]byte, 8*1024))
} }
// If we test exactly 1K blocks, we would generate exact multiples of func benchmarkAESStream(b *testing.B, mode func(cipher.Block, []byte) cipher.Stream, buf []byte) {
// the cipher's block size, and the cipher stream fragments would
// always be wordsize aligned, whereas non-aligned is a more typical
// use-case.
const almost1K = 1024 - 5
func BenchmarkAESCFBEncrypt1K(b *testing.B) {
buf := make([]byte, almost1K)
b.SetBytes(int64(len(buf))) b.SetBytes(int64(len(buf)))
var key [16]byte var key [16]byte
var iv [16]byte var iv [16]byte
aes, _ := aes.NewCipher(key[:]) aes, _ := aes.NewCipher(key[:])
ctr := cipher.NewCFBEncrypter(aes, iv[:]) stream := mode(aes, iv[:])
b.ResetTimer() b.ResetTimer()
for i := 0; i < b.N; i++ { for i := 0; i < b.N; i++ {
ctr.XORKeyStream(buf, buf) stream.XORKeyStream(buf, buf)
} }
} }
func BenchmarkAESCFBDecrypt1K(b *testing.B) { // If we test exactly 1K blocks, we would generate exact multiples of
buf := make([]byte, almost1K) // the cipher's block size, and the cipher stream fragments would
b.SetBytes(int64(len(buf))) // always be wordsize aligned, whereas non-aligned is a more typical
// use-case.
var key [16]byte const almost1K = 1024 - 5
var iv [16]byte const almost8K = 8*1024 - 5
aes, _ := aes.NewCipher(key[:])
ctr := cipher.NewCFBDecrypter(aes, iv[:])
b.ResetTimer() func BenchmarkAESCFBEncrypt1K(b *testing.B) {
for i := 0; i < b.N; i++ { benchmarkAESStream(b, cipher.NewCFBEncrypter, make([]byte, almost1K))
ctr.XORKeyStream(buf, buf)
}
} }
func BenchmarkAESOFB1K(b *testing.B) { func BenchmarkAESCFBDecrypt1K(b *testing.B) {
buf := make([]byte, almost1K) benchmarkAESStream(b, cipher.NewCFBDecrypter, make([]byte, almost1K))
b.SetBytes(int64(len(buf))) }
var key [16]byte func BenchmarkAESCFBDecrypt8K(b *testing.B) {
var iv [16]byte benchmarkAESStream(b, cipher.NewCFBDecrypter, make([]byte, almost8K))
aes, _ := aes.NewCipher(key[:]) }
ctr := cipher.NewOFB(aes, iv[:])
b.ResetTimer() func BenchmarkAESOFB1K(b *testing.B) {
for i := 0; i < b.N; i++ { benchmarkAESStream(b, cipher.NewOFB, make([]byte, almost1K))
ctr.XORKeyStream(buf, buf)
}
} }
func BenchmarkAESCTR1K(b *testing.B) { func BenchmarkAESCTR1K(b *testing.B) {
buf := make([]byte, almost1K) benchmarkAESStream(b, cipher.NewCTR, make([]byte, almost1K))
b.SetBytes(int64(len(buf))) }
var key [16]byte
var iv [16]byte
aes, _ := aes.NewCipher(key[:])
ctr := cipher.NewCTR(aes, iv[:])
b.ResetTimer() func BenchmarkAESCTR8K(b *testing.B) {
for i := 0; i < b.N; i++ { benchmarkAESStream(b, cipher.NewCTR, make([]byte, almost8K))
ctr.XORKeyStream(buf, buf)
}
} }
func BenchmarkAESCBCEncrypt1K(b *testing.B) { func BenchmarkAESCBCEncrypt1K(b *testing.B) {
......
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