summaryrefslogtreecommitdiffhomepage
path: root/pkg/sentry/arch/fpu/fpu.go
diff options
context:
space:
mode:
authorJamie Liu <jamieliu@google.com>2021-09-01 14:04:50 -0700
committergVisor bot <gvisor-bot@google.com>2021-09-01 14:07:57 -0700
commitb4de26d6b1bbb0e75187690da6d3fe120f53656b (patch)
treef34266f08c7ea44369231969b48aacc733910399 /pkg/sentry/arch/fpu/fpu.go
parent702fe7d60da4d38344f00200187fe1f0766bef8d (diff)
Don't use reflection in fpu.alignedBytes.
reflect.ValueOf takes an interface{}, so when passed a slice the compiler emits a call to runtime.convTslice to heap-allocate a copy of the slice header. PiperOrigin-RevId: 394310052
Diffstat (limited to 'pkg/sentry/arch/fpu/fpu.go')
-rw-r--r--pkg/sentry/arch/fpu/fpu.go13
1 files changed, 0 insertions, 13 deletions
diff --git a/pkg/sentry/arch/fpu/fpu.go b/pkg/sentry/arch/fpu/fpu.go
index 867d309a3..62bde19d3 100644
--- a/pkg/sentry/arch/fpu/fpu.go
+++ b/pkg/sentry/arch/fpu/fpu.go
@@ -17,7 +17,6 @@ package fpu
import (
"fmt"
- "reflect"
)
// State represents floating point state.
@@ -40,15 +39,3 @@ type ErrLoadingState struct {
func (e ErrLoadingState) Error() string {
return fmt.Sprintf("floating point state contains unsupported features; supported: %#x saved: %#x", e.supportedFeatures, e.savedFeatures)
}
-
-// alignedBytes returns a slice of size bytes, aligned in memory to the given
-// alignment. This is used because we require certain structures to be aligned
-// in a specific way (for example, the X86 floating point data).
-func alignedBytes(size, alignment uint) []byte {
- data := make([]byte, size+alignment-1)
- offset := uint(reflect.ValueOf(data).Index(0).Addr().Pointer() % uintptr(alignment))
- if offset == 0 {
- return data[:size:size]
- }
- return data[alignment-offset:][:size:size]
-}