diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 12:36:04 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 12:36:04 +0000 |
commit | b09c6d56832eb1718c07d74abf3bc6ae3fe4e030 (patch) | |
tree | d2caec2610d4ea887803ec9e9c3cd77136c448ba /dependencies/pkg/mod/golang.org/x/sys@v0.1.0/cpu/cpu_s390x_test.go | |
parent | Initial commit. (diff) | |
download | icingadb-upstream.tar.xz icingadb-upstream.zip |
Adding upstream version 1.1.0.upstream/1.1.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | dependencies/pkg/mod/golang.org/x/sys@v0.1.0/cpu/cpu_s390x_test.go | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/dependencies/pkg/mod/golang.org/x/sys@v0.1.0/cpu/cpu_s390x_test.go b/dependencies/pkg/mod/golang.org/x/sys@v0.1.0/cpu/cpu_s390x_test.go new file mode 100644 index 0000000..9bee163 --- /dev/null +++ b/dependencies/pkg/mod/golang.org/x/sys@v0.1.0/cpu/cpu_s390x_test.go @@ -0,0 +1,75 @@ +// Copyright 2020 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 cpu_test + +import ( + "runtime" + "testing" + "unsafe" + + "golang.org/x/sys/cpu" +) + +var s390xTests = []struct { + name string + feature bool + facility uint + mandatory bool +}{ + {"ZARCH", cpu.S390X.HasZARCH, 1, true}, + {"STFLE", cpu.S390X.HasSTFLE, 7, true}, + {"LDISP", cpu.S390X.HasLDISP, 18, true}, + {"EIMM", cpu.S390X.HasEIMM, 21, true}, + {"DFP", cpu.S390X.HasDFP, 42, false}, + {"MSA", cpu.S390X.HasMSA, 17, false}, + {"VX", cpu.S390X.HasVX, 129, false}, + {"VXE", cpu.S390X.HasVXE, 135, false}, +} + +// bitIsSet reports whether the bit at index is set. The bit index +// is in big endian order, so bit index 0 is the leftmost bit. +func bitIsSet(bits [4]uint64, i uint) bool { + return bits[i/64]&((1<<63)>>(i%64)) != 0 +} + +// facilityList contains the contents of location 200 on zos. +// Bits are numbered in big endian order so the +// leftmost bit (the MSB) is at index 0. +type facilityList struct { + bits [4]uint64 +} + +func TestS390XVectorFacilityFeatures(t *testing.T) { + // vector-enhancements require vector facility to be enabled + if cpu.S390X.HasVXE && !cpu.S390X.HasVX { + t.Error("HasVX expected true, got false (VXE is true)") + } +} + +func TestS390XMandatoryFeatures(t *testing.T) { + for _, tc := range s390xTests { + if tc.mandatory && !tc.feature { + t.Errorf("Feature %s is mandatory but is not present", tc.name) + } + } +} + +func TestS390XFeatures(t *testing.T) { + if runtime.GOOS != "zos" { + return + } + // Read available facilities from address 200. + facilitiesAddress := uintptr(200) + var facilities facilityList + for i := 0; i < 4; i++ { + facilities.bits[i] = *(*uint64)(unsafe.Pointer(facilitiesAddress + uintptr(8*i))) + } + + for _, tc := range s390xTests { + if want := bitIsSet(facilities.bits, tc.facility); want != tc.feature { + t.Errorf("Feature %s expected %v, got %v", tc.name, want, tc.feature) + } + } +} |