mirror of
https://github.com/golang/sys.git
synced 2026-02-08 11:46:04 +03:00
Use the MRS instruction with the corresponding system register instead of encoding the instructions using a WORD directive. This was missed in CL 583135. Change-Id: Ifcbbd81baa903f1da442eae2e49c06284db9c37d Reviewed-on: https://go-review.googlesource.com/c/sys/+/717681 Auto-Submit: Tobias Klauser <tobias.klauser@gmail.com> Reviewed-by: Florian Lehner <lehner.florian86@gmail.com> Reviewed-by: Michael Knyszek <mknyszek@google.com> Reviewed-by: Michael Pratt <mpratt@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
43 lines
968 B
ArmAsm
43 lines
968 B
ArmAsm
// Copyright 2019 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.
|
|
|
|
//go:build gc
|
|
|
|
#include "textflag.h"
|
|
|
|
// func getisar0() uint64
|
|
TEXT ·getisar0(SB),NOSPLIT,$0-8
|
|
// get Instruction Set Attributes 0 into x0
|
|
MRS ID_AA64ISAR0_EL1, R0
|
|
MOVD R0, ret+0(FP)
|
|
RET
|
|
|
|
// func getisar1() uint64
|
|
TEXT ·getisar1(SB),NOSPLIT,$0-8
|
|
// get Instruction Set Attributes 1 into x0
|
|
MRS ID_AA64ISAR1_EL1, R0
|
|
MOVD R0, ret+0(FP)
|
|
RET
|
|
|
|
// func getmmfr1() uint64
|
|
TEXT ·getmmfr1(SB),NOSPLIT,$0-8
|
|
// get Memory Model Feature Register 1 into x0
|
|
MRS ID_AA64MMFR1_EL1, R0
|
|
MOVD R0, ret+0(FP)
|
|
RET
|
|
|
|
// func getpfr0() uint64
|
|
TEXT ·getpfr0(SB),NOSPLIT,$0-8
|
|
// get Processor Feature Register 0 into x0
|
|
MRS ID_AA64PFR0_EL1, R0
|
|
MOVD R0, ret+0(FP)
|
|
RET
|
|
|
|
// func getzfr0() uint64
|
|
TEXT ·getzfr0(SB),NOSPLIT,$0-8
|
|
// get SVE Feature Register 0 into x0
|
|
MRS ID_AA64ZFR0_EL1, R0
|
|
MOVD R0, ret+0(FP)
|
|
RET
|