// Copyright 2024 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 subtle_test import ( "crypto/subtle" "syscall" "testing" ) // dangerousSlice returns a slice which is immediately // preceded and followed by a faulting page. // Copied from the bytes package tests. func dangerousSlice(t *testing.T) []byte { pagesize := syscall.Getpagesize() b, err := syscall.Mmap(0, 0, 3*pagesize, syscall.PROT_READ|syscall.PROT_WRITE, syscall.MAP_ANONYMOUS|syscall.MAP_PRIVATE) if err != nil { t.Fatalf("mmap failed %s", err) } err = syscall.Mprotect(b[:pagesize], syscall.PROT_NONE) if err != nil { t.Fatalf("mprotect low failed %s\n", err) } err = syscall.Mprotect(b[2*pagesize:], syscall.PROT_NONE) if err != nil { t.Fatalf("mprotect high failed %s\n", err) } return b[pagesize : 2*pagesize] } func TestXORBytesBoundary(t *testing.T) { safe := make([]byte, syscall.Getpagesize()*2) spicy := dangerousSlice(t) for i := 1; i <= syscall.Getpagesize(); i++ { start := spicy[:i] end := spicy[len(spicy)-i:] subtle.XORBytes(end, safe, safe[:i]) subtle.XORBytes(start, safe, safe[:i]) subtle.XORBytes(safe, start, safe) subtle.XORBytes(safe, end, safe) subtle.XORBytes(safe, safe, start) subtle.XORBytes(safe, safe, end) } }