// Copyright 2013 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package runtime_test import ( . "runtime" "testing" ) func TestMemmove(t *testing.T) { size := 256 if testing.Short() { size = 128 + 16 } src := make([]byte, size) dst := make([]byte, size) for i := 0; i < size; i++ { src[i] = byte(128 + (i & 127)) } for i := 0; i < size; i++ { dst[i] = byte(i & 127) } for n := 0; n <= size; n++ { for x := 0; x <= size-n; x++ { // offset in src for y := 0; y <= size-n; y++ { // offset in dst copy(dst[y:y+n], src[x:x+n]) for i := 0; i < y; i++ { if dst[i] != byte(i&127) { t.Fatalf("prefix dst[%d] = %d", i, dst[i]) } } for i := y; i < y+n; i++ { if dst[i] != byte(128+((i-y+x)&127)) { t.Fatalf("copied dst[%d] = %d", i, dst[i]) } dst[i] = byte(i & 127) // reset dst } for i := y + n; i < size; i++ { if dst[i] != byte(i&127) { t.Fatalf("suffix dst[%d] = %d", i, dst[i]) } } } } } } func TestMemmoveAlias(t *testing.T) { size := 256 if testing.Short() { size = 128 + 16 } buf := make([]byte, size) for i := 0; i < size; i++ { buf[i] = byte(i) } for n := 0; n <= size; n++ { for x := 0; x <= size-n; x++ { // src offset for y := 0; y <= size-n; y++ { // dst offset copy(buf[y:y+n], buf[x:x+n]) for i := 0; i < y; i++ { if buf[i] != byte(i) { t.Fatalf("prefix buf[%d] = %d", i, buf[i]) } } for i := y; i < y+n; i++ { if buf[i] != byte(i-y+x) { t.Fatalf("copied buf[%d] = %d", i, buf[i]) } buf[i] = byte(i) // reset buf } for i := y + n; i < size; i++ { if buf[i] != byte(i) { t.Fatalf("suffix buf[%d] = %d", i, buf[i]) } } } } } } func bmMemmove(b *testing.B, n int) { x := make([]byte, n) y := make([]byte, n) b.SetBytes(int64(n)) for i := 0; i < b.N; i++ { copy(x, y) } } func BenchmarkMemmove0(b *testing.B) { bmMemmove(b, 0) } func BenchmarkMemmove1(b *testing.B) { bmMemmove(b, 1) } func BenchmarkMemmove2(b *testing.B) { bmMemmove(b, 2) } func BenchmarkMemmove3(b *testing.B) { bmMemmove(b, 3) } func BenchmarkMemmove4(b *testing.B) { bmMemmove(b, 4) } func BenchmarkMemmove5(b *testing.B) { bmMemmove(b, 5) } func BenchmarkMemmove6(b *testing.B) { bmMemmove(b, 6) } func BenchmarkMemmove7(b *testing.B) { bmMemmove(b, 7) } func BenchmarkMemmove8(b *testing.B) { bmMemmove(b, 8) } func BenchmarkMemmove9(b *testing.B) { bmMemmove(b, 9) } func BenchmarkMemmove10(b *testing.B) { bmMemmove(b, 10) } func BenchmarkMemmove11(b *testing.B) { bmMemmove(b, 11) } func BenchmarkMemmove12(b *testing.B) { bmMemmove(b, 12) } func BenchmarkMemmove13(b *testing.B) { bmMemmove(b, 13) } func BenchmarkMemmove14(b *testing.B) { bmMemmove(b, 14) } func BenchmarkMemmove15(b *testing.B) { bmMemmove(b, 15) } func BenchmarkMemmove16(b *testing.B) { bmMemmove(b, 16) } func BenchmarkMemmove32(b *testing.B) { bmMemmove(b, 32) } func BenchmarkMemmove64(b *testing.B) { bmMemmove(b, 64) } func BenchmarkMemmove128(b *testing.B) { bmMemmove(b, 128) } func BenchmarkMemmove256(b *testing.B) { bmMemmove(b, 256) } func BenchmarkMemmove512(b *testing.B) { bmMemmove(b, 512) } func BenchmarkMemmove1024(b *testing.B) { bmMemmove(b, 1024) } func BenchmarkMemmove2048(b *testing.B) { bmMemmove(b, 2048) } func BenchmarkMemmove4096(b *testing.B) { bmMemmove(b, 4096) } func TestMemclr(t *testing.T) { size := 512 if testing.Short() { size = 128 + 16 } mem := make([]byte, size) for i := 0; i < size; i++ { mem[i] = 0xee } for n := 0; n < size; n++ { for x := 0; x <= size-n; x++ { // offset in mem MemclrBytes(mem[x : x+n]) for i := 0; i < x; i++ { if mem[i] != 0xee { t.Fatalf("overwrite prefix mem[%d] = %d", i, mem[i]) } } for i := x; i < x+n; i++ { if mem[i] != 0 { t.Fatalf("failed clear mem[%d] = %d", i, mem[i]) } mem[i] = 0xee } for i := x + n; i < size; i++ { if mem[i] != 0xee { t.Fatalf("overwrite suffix mem[%d] = %d", i, mem[i]) } } } } } func bmMemclr(b *testing.B, n int) { x := make([]byte, n) b.SetBytes(int64(n)) for i := 0; i < b.N; i++ { MemclrBytes(x) } } func BenchmarkMemclr5(b *testing.B) { bmMemclr(b, 5) } func BenchmarkMemclr16(b *testing.B) { bmMemclr(b, 16) } func BenchmarkMemclr64(b *testing.B) { bmMemclr(b, 64) } func BenchmarkMemclr256(b *testing.B) { bmMemclr(b, 256) } func BenchmarkMemclr4096(b *testing.B) { bmMemclr(b, 4096) } func BenchmarkMemclr65536(b *testing.B) { bmMemclr(b, 65536) } func bmGoMemclr(b *testing.B, n int) { x := make([]byte, n) b.SetBytes(int64(n)) for i := 0; i < b.N; i++ { for j := range x { x[j] = 0 } } } func BenchmarkGoMemclr5(b *testing.B) { bmGoMemclr(b, 5) } func BenchmarkGoMemclr16(b *testing.B) { bmGoMemclr(b, 16) } func BenchmarkGoMemclr64(b *testing.B) { bmGoMemclr(b, 64) } func BenchmarkGoMemclr256(b *testing.B) { bmGoMemclr(b, 256) } func BenchmarkClearFat8(b *testing.B) { for i := 0; i < b.N; i++ { var x [8 / 4]uint32 _ = x } } func BenchmarkClearFat12(b *testing.B) { for i := 0; i < b.N; i++ { var x [12 / 4]uint32 _ = x } } func BenchmarkClearFat16(b *testing.B) { for i := 0; i < b.N; i++ { var x [16 / 4]uint32 _ = x } } func BenchmarkClearFat24(b *testing.B) { for i := 0; i < b.N; i++ { var x [24 / 4]uint32 _ = x } } func BenchmarkClearFat32(b *testing.B) { for i := 0; i < b.N; i++ { var x [32 / 4]uint32 _ = x } } func BenchmarkClearFat64(b *testing.B) { for i := 0; i < b.N; i++ { var x [64 / 4]uint32 _ = x } } func BenchmarkClearFat128(b *testing.B) { for i := 0; i < b.N; i++ { var x [128 / 4]uint32 _ = x } } func BenchmarkClearFat256(b *testing.B) { for i := 0; i < b.N; i++ { var x [256 / 4]uint32 _ = x } } func BenchmarkClearFat512(b *testing.B) { for i := 0; i < b.N; i++ { var x [512 / 4]uint32 _ = x } } func BenchmarkClearFat1024(b *testing.B) { for i := 0; i < b.N; i++ { var x [1024 / 4]uint32 _ = x } } func BenchmarkCopyFat8(b *testing.B) { var x [8 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat12(b *testing.B) { var x [12 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat16(b *testing.B) { var x [16 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat24(b *testing.B) { var x [24 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat32(b *testing.B) { var x [32 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat64(b *testing.B) { var x [64 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat128(b *testing.B) { var x [128 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat256(b *testing.B) { var x [256 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat512(b *testing.B) { var x [512 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } } func BenchmarkCopyFat1024(b *testing.B) { var x [1024 / 4]uint32 for i := 0; i < b.N; i++ { y := x _ = y } }