mirror of
https://github.com/golang/sys.git
synced 2026-02-08 11:46:04 +03:00
This allows to detect ARM64 CPU features on non-Linux systems. On Linux, this is used in case /proc/self/auxv cannot be read. Change-Id: I67d55e989f2beda0c05a97ca5e55781840a8e01c Reviewed-on: https://go-review.googlesource.com/c/sys/+/209478 Run-TryBot: Tobias Klauser <tobias.klauser@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
44 lines
1.2 KiB
C
44 lines
1.2 KiB
C
// Copyright 2018 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.
|
|
|
|
// +build 386 amd64 amd64p32
|
|
// +build gccgo
|
|
|
|
#include <cpuid.h>
|
|
#include <stdint.h>
|
|
|
|
// Need to wrap __get_cpuid_count because it's declared as static.
|
|
int
|
|
gccgoGetCpuidCount(uint32_t leaf, uint32_t subleaf,
|
|
uint32_t *eax, uint32_t *ebx,
|
|
uint32_t *ecx, uint32_t *edx)
|
|
{
|
|
return __get_cpuid_count(leaf, subleaf, eax, ebx, ecx, edx);
|
|
}
|
|
|
|
// xgetbv reads the contents of an XCR (Extended Control Register)
|
|
// specified in the ECX register into registers EDX:EAX.
|
|
// Currently, the only supported value for XCR is 0.
|
|
//
|
|
// TODO: Replace with a better alternative:
|
|
//
|
|
// #include <xsaveintrin.h>
|
|
//
|
|
// #pragma GCC target("xsave")
|
|
//
|
|
// void gccgoXgetbv(uint32_t *eax, uint32_t *edx) {
|
|
// unsigned long long x = _xgetbv(0);
|
|
// *eax = x & 0xffffffff;
|
|
// *edx = (x >> 32) & 0xffffffff;
|
|
// }
|
|
//
|
|
// Note that _xgetbv is defined starting with GCC 8.
|
|
void
|
|
gccgoXgetbv(uint32_t *eax, uint32_t *edx)
|
|
{
|
|
__asm(" xorl %%ecx, %%ecx\n"
|
|
" xgetbv"
|
|
: "=a"(*eax), "=d"(*edx));
|
|
}
|