blob: 83c5ac66dda4bd15ec52fdf4c787c3980f96822c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
|
; $Id: sup.mac $
;; @file
; SUP - Support Library, assembly definitions.
;
;
; Copyright (C) 2006-2020 Oracle Corporation
;
; This file is part of VirtualBox Open Source Edition (OSE), as
; available from http://www.virtualbox.org. This file is free software;
; you can redistribute it and/or modify it under the terms of the GNU
; General Public License (GPL) as published by the Free Software
; Foundation, in version 2 as it comes in the "COPYING" file of the
; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
;
; The contents of this file may alternatively be used under the terms
; of the Common Development and Distribution License Version 1.0
; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
; VirtualBox OSE distribution, in which case the provisions of the
; CDDL are applicable instead of those of the GPL.
;
; You may elect to license modified versions of this file under the
; terms and conditions of either the GPL or the CDDL or both.
;
%ifndef ___VBox_sup_mac
%define ___VBox_sup_mac
struc SUPGIPCPU
.u32TransactionId resd 1
.u32UpdateIntervalTSC resd 1
.u64NanoTS resq 1
.u64TSC resq 1
.u64CpuHz resq 1
.i64TSCDelta resq 1
.cErrors resd 1
.iTSCHistoryHead resd 1
.au32TSCHistory resd 8
.u32PrevUpdateIntervalNS resd 1
.u32Reserved resd 1
.u64TSCSample resq 1
.au32Reserved1 resd 3
.enmState resd 1
.idCpu resd 1
.iCpuSet resw 1
.iCpuGroup resw 1
.iCpuGroupMember resw 1
.idApic resw 1
.iReservedForNumaNode resd 1
endstruc
%define SUPGIPUSETSCDELTA_NOT_APPLICABLE 0
%define SUPGIPUSETSCDELTA_ZERO_CLAIMED 1
%define SUPGIPUSETSCDELTA_PRACTICALLY_ZERO 2
%define SUPGIPUSETSCDELTA_ROUGHLY_ZERO 3
%define SUPGIPUSETSCDELTA_NOT_ZERO 4
%define SUPGIPGETCPU_APIC_ID 1
%define SUPGIPGETCPU_RDTSCP_MASK_MAX_SET_CPUS 2
%define SUPGIPGETCPU_IDTR_LIMIT_MASK_MAX_SET_CPUS 4
%define SUPGIPGETCPU_RDTSCP_GROUP_IN_CH_NUMBER_IN_CL 8
%define SUPGIPGETCPU_APIC_ID_EXT_0B 16
%define SUPGIPGETCPU_APIC_ID_EXT_8000001E 32
%define SUPGLOBALINFOPAGE_MAGIC 0x19590106
struc SUPGLOBALINFOPAGE
.u32Magic resd 1
.u32Version resd 1
.u32Mode resd 1
.cCpus resw 1
.cPages resw 1
.u32UpdateHz resd 1
.u32UpdateIntervalNS resd 1
.u64NanoTSLastUpdateHz resq 1
.u64CpuHz resq 1
.cOnlineCpus resw 1
.cPresentCpus resw 1
.cPossibleCpus resw 1
.cPossibleCpuGroups resw 1
.idCpuMax resd 1
.enmUseTscDelta resd 1
.fGetGipCpu resd 1
.fFlags resd 1
.OnlineCpuSet resq 16
.PresentCpuSet resq 16
.PossibleCpuSet resq 16
.au32Padding1 resd 48
.aiCpuFromApicId resw 4096
.aiCpuFromCpuSetIdx resw 1024
.aoffCpuGroup resd 256
.aCPUs resb SUPGIPCPU_size
endstruc
struc SUPDRVTRACERUSRCTX32
.idProbe resd 1
.cBits resb 1
.abReserved resb 3
.u.X86.uVtgProbeLoc resd 1
.u.X86.aArgs resd 20
.u.X86.eip resd 1
.u.X86.eflags resd 1
.u.X86.eax resd 1
.u.X86.ecx resd 1
.u.X86.edx resd 1
.u.X86.ebx resd 1
.u.X86.esp resd 1
.u.X86.ebp resd 1
.u.X86.esi resd 1
.u.X86.edi resd 1
.u.X86.cs resw 1
.u.X86.ss resw 1
.u.X86.ds resw 1
.u.X86.es resw 1
.u.X86.fs resw 1
.u.X86.gs resw 1
endstruc
struc SUPDRVTRACERUSRCTX64
.idProbe resd 1
.cBits resb 1
.abReserved resb 3
.u.Amd64.uVtgProbeLoc resq 1
.u.Amd64.aArgs resq 10
.u.Amd64.rip resq 1
.u.Amd64.rflags resq 1
.u.Amd64.rax resq 1
.u.Amd64.rcx resq 1
.u.Amd64.rdx resq 1
.u.Amd64.rbx resq 1
.u.Amd64.rsp resq 1
.u.Amd64.rbp resq 1
.u.Amd64.rsi resq 1
.u.Amd64.rdi resq 1
.u.Amd64.r8 resq 1
.u.Amd64.r9 resq 1
.u.Amd64.r10 resq 1
.u.Amd64.r11 resq 1
.u.Amd64.r12 resq 1
.u.Amd64.r13 resq 1
.u.Amd64.r14 resq 1
.u.Amd64.r15 resq 1
endstruc
%endif
|