summaryrefslogtreecommitdiff
path: root/vendor/github.com/klauspost/cpuid/cpuid_amd64.s
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2019-01-03 12:14:24 -0800
committerGitHub <noreply@github.com>2019-01-03 12:14:24 -0800
commit9ffd4806163e410d51d0f0cbece45b7405ff9fee (patch)
tree1748445c0302747d963e30013e5b76ce73d43bf5 /vendor/github.com/klauspost/cpuid/cpuid_amd64.s
parent133469681486788591f6979f853c662ccf7f9118 (diff)
parent561e65969f89c6f60193cf1755752b571a1149f5 (diff)
downloadpodman-9ffd4806163e410d51d0f0cbece45b7405ff9fee.tar.gz
podman-9ffd4806163e410d51d0f0cbece45b7405ff9fee.tar.bz2
podman-9ffd4806163e410d51d0f0cbece45b7405ff9fee.zip
Merge pull request #2071 from baude/vendorcs
vendor in new containers/storage
Diffstat (limited to 'vendor/github.com/klauspost/cpuid/cpuid_amd64.s')
-rw-r--r--vendor/github.com/klauspost/cpuid/cpuid_amd64.s42
1 files changed, 42 insertions, 0 deletions
diff --git a/vendor/github.com/klauspost/cpuid/cpuid_amd64.s b/vendor/github.com/klauspost/cpuid/cpuid_amd64.s
new file mode 100644
index 000000000..3c1d60e42
--- /dev/null
+++ b/vendor/github.com/klauspost/cpuid/cpuid_amd64.s
@@ -0,0 +1,42 @@
+// Copyright (c) 2015 Klaus Post, released under MIT License. See LICENSE file.
+
+//+build amd64,!gccgo
+
+// func asmCpuid(op uint32) (eax, ebx, ecx, edx uint32)
+TEXT ·asmCpuid(SB), 7, $0
+ XORQ CX, CX
+ MOVL op+0(FP), AX
+ CPUID
+ MOVL AX, eax+8(FP)
+ MOVL BX, ebx+12(FP)
+ MOVL CX, ecx+16(FP)
+ MOVL DX, edx+20(FP)
+ RET
+
+// func asmCpuidex(op, op2 uint32) (eax, ebx, ecx, edx uint32)
+TEXT ·asmCpuidex(SB), 7, $0
+ MOVL op+0(FP), AX
+ MOVL op2+4(FP), CX
+ CPUID
+ MOVL AX, eax+8(FP)
+ MOVL BX, ebx+12(FP)
+ MOVL CX, ecx+16(FP)
+ MOVL DX, edx+20(FP)
+ RET
+
+// func asmXgetbv(index uint32) (eax, edx uint32)
+TEXT ·asmXgetbv(SB), 7, $0
+ MOVL index+0(FP), CX
+ BYTE $0x0f; BYTE $0x01; BYTE $0xd0 // XGETBV
+ MOVL AX, eax+8(FP)
+ MOVL DX, edx+12(FP)
+ RET
+
+// func asmRdtscpAsm() (eax, ebx, ecx, edx uint32)
+TEXT ·asmRdtscpAsm(SB), 7, $0
+ BYTE $0x0F; BYTE $0x01; BYTE $0xF9 // RDTSCP
+ MOVL AX, eax+0(FP)
+ MOVL BX, ebx+4(FP)
+ MOVL CX, ecx+8(FP)
+ MOVL DX, edx+12(FP)
+ RET