1 | /* $Id: GVMMR0Internal.h 93115 2022-01-01 11:31:46Z vboxsync $ */
|
---|
2 | /** @file
|
---|
3 | * GVMM - The Global VM Manager, Internal header.
|
---|
4 | */
|
---|
5 |
|
---|
6 | /*
|
---|
7 | * Copyright (C) 2007-2022 Oracle Corporation
|
---|
8 | *
|
---|
9 | * This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
10 | * available from http://www.virtualbox.org. This file is free software;
|
---|
11 | * you can redistribute it and/or modify it under the terms of the GNU
|
---|
12 | * General Public License (GPL) as published by the Free Software
|
---|
13 | * Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
14 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
15 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
16 | */
|
---|
17 |
|
---|
18 | #ifndef VMM_INCLUDED_SRC_VMMR0_GVMMR0Internal_h
|
---|
19 | #define VMM_INCLUDED_SRC_VMMR0_GVMMR0Internal_h
|
---|
20 | #ifndef RT_WITHOUT_PRAGMA_ONCE
|
---|
21 | # pragma once
|
---|
22 | #endif
|
---|
23 |
|
---|
24 | #include <iprt/mem.h>
|
---|
25 | #include <iprt/timer.h>
|
---|
26 |
|
---|
27 |
|
---|
28 | /**
|
---|
29 | * The GVMM per VM data.
|
---|
30 | */
|
---|
31 | typedef struct GVMMPERVCPU
|
---|
32 | {
|
---|
33 | /** The time the halted EMT thread expires.
|
---|
34 | * 0 if the EMT thread is blocked here. */
|
---|
35 | uint64_t volatile u64HaltExpire;
|
---|
36 | /** The event semaphore the EMT thread is blocking on. */
|
---|
37 | RTSEMEVENTMULTI HaltEventMulti;
|
---|
38 | /** High resolution wake-up timer, NIL_RTTIMER if not used. */
|
---|
39 | PRTTIMER hHrWakeUpTimer;
|
---|
40 | /** The ID of the CPU we ran on when halting (debug only). */
|
---|
41 | RTCPUID idHaltedOnCpu;
|
---|
42 | /** Set if hHrWakeUpTimer is armed. */
|
---|
43 | bool volatile fHrWakeUptimerArmed;
|
---|
44 | uint8_t abPadding[1];
|
---|
45 | /** The EMT hash table index for this VCpu. */
|
---|
46 | uint16_t idxEmtHash;
|
---|
47 | /** The ring-3 mapping of the VMCPU structure. */
|
---|
48 | RTR0MEMOBJ VMCpuMapObj;
|
---|
49 | /** Statistics. */
|
---|
50 | GVMMSTATSVMCPU Stats;
|
---|
51 | } GVMMPERVCPU;
|
---|
52 | /** Pointer to the GVMM per VCPU data. */
|
---|
53 | typedef GVMMPERVCPU *PGVMMPERVCPU;
|
---|
54 |
|
---|
55 |
|
---|
56 | /**
|
---|
57 | * EMT hash table entry.
|
---|
58 | */
|
---|
59 | typedef struct GVMMEMTHASHENTRY
|
---|
60 | {
|
---|
61 | /** The key. */
|
---|
62 | RTNATIVETHREAD hNativeEmt;
|
---|
63 | /** The VCpu index. */
|
---|
64 | VMCPUID idVCpu;
|
---|
65 | #if HC_ARCH_BITS == 64
|
---|
66 | uint32_t u32Padding;
|
---|
67 | #endif
|
---|
68 | } GVMMEMTHASHENTRY;
|
---|
69 | AssertCompileSize(GVMMEMTHASHENTRY, sizeof(void *) * 2);
|
---|
70 |
|
---|
71 | /** The EMT hash table size. */
|
---|
72 | #define GVMM_EMT_HASH_SIZE (VMM_MAX_CPU_COUNT * 4)
|
---|
73 | /** Primary EMT hash table hash function, sans range limit.
|
---|
74 | * @note We assume the native ring-0 thread handle is a pointer to a pretty big
|
---|
75 | * structure of at least 1 KiB.
|
---|
76 | * - NT AMD64 6.0 ETHREAD: 0x450. See
|
---|
77 | * https://www.geoffchappell.com/studies/windows/km/ntoskrnl/inc/ntos/ps/ethread/index.htm
|
---|
78 | * for more details.
|
---|
79 | * - Solaris kthread_t is at least 0x370 in Solaris 10.
|
---|
80 | * - Linux task_struct looks pretty big too.
|
---|
81 | * - As does struct thread in xnu.
|
---|
82 | * @todo Make platform specific adjustment as needed. */
|
---|
83 | #define GVMM_EMT_HASH_CORE(a_hNativeSelf) ( (uintptr_t)(a_hNativeSelf) >> 10 )
|
---|
84 | /** Primary EMT hash table function. */
|
---|
85 | #define GVMM_EMT_HASH_1(a_hNativeSelf) ( GVMM_EMT_HASH_CORE(a_hNativeSelf) % GVMM_EMT_HASH_SIZE )
|
---|
86 | /** Secondary EMT hash table function, added to the primary one on collision.
|
---|
87 | * This uses the bits above the primary hash.
|
---|
88 | * @note It is always odd, which guarantees that we'll visit all hash table
|
---|
89 | * entries in case of a collision. */
|
---|
90 | #define GVMM_EMT_HASH_2(a_hNativeSelf) ( ((GVMM_EMT_HASH_CORE(a_hNativeSelf) / GVMM_EMT_HASH_SIZE) | 1) % GVMM_EMT_HASH_SIZE )
|
---|
91 |
|
---|
92 | /**
|
---|
93 | * The GVMM per VM data.
|
---|
94 | */
|
---|
95 | typedef struct GVMMPERVM
|
---|
96 | {
|
---|
97 | /** The shared VM data structure allocation object (PVMR0). */
|
---|
98 | RTR0MEMOBJ VMMemObj;
|
---|
99 | /** The Ring-3 mapping of the shared VM data structure (PVMR3). */
|
---|
100 | RTR0MEMOBJ VMMapObj;
|
---|
101 | /** The allocation object for the VM pages. */
|
---|
102 | RTR0MEMOBJ VMPagesMemObj;
|
---|
103 | /** The ring-3 mapping of the VM pages. */
|
---|
104 | RTR0MEMOBJ VMPagesMapObj;
|
---|
105 |
|
---|
106 | /** The scheduler statistics. */
|
---|
107 | GVMMSTATSSCHED StatsSched;
|
---|
108 |
|
---|
109 | /** Whether the per-VM ring-0 initialization has been performed. */
|
---|
110 | bool fDoneVMMR0Init;
|
---|
111 | /** Whether the per-VM ring-0 termination is being or has been performed. */
|
---|
112 | bool fDoneVMMR0Term;
|
---|
113 | bool afPadding[6];
|
---|
114 |
|
---|
115 | /** Worker thread registrations. */
|
---|
116 | struct
|
---|
117 | {
|
---|
118 | /** The native ring-0 thread handle. */
|
---|
119 | RTNATIVETHREAD hNativeThread;
|
---|
120 | /** The native ring-3 thread handle. */
|
---|
121 | RTNATIVETHREAD hNativeThreadR3;
|
---|
122 | } aWorkerThreads[GVMMWORKERTHREAD_END];
|
---|
123 |
|
---|
124 | /** EMT lookup hash table. */
|
---|
125 | GVMMEMTHASHENTRY aEmtHash[GVMM_EMT_HASH_SIZE];
|
---|
126 | } GVMMPERVM;
|
---|
127 | /** Pointer to the GVMM per VM data. */
|
---|
128 | typedef GVMMPERVM *PGVMMPERVM;
|
---|
129 |
|
---|
130 |
|
---|
131 | #endif /* !VMM_INCLUDED_SRC_VMMR0_GVMMR0Internal_h */
|
---|
132 |
|
---|