VirtualBox

source: vbox/trunk/src/VBox/VMM/VMMR0/GVMMR0Internal.h@ 92892

Last change on this file since 92892 was 92892, checked in by vboxsync, 3 years ago

GVMMR0: Experimental code (disabled) for using HR host timers to wake up EMTs.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 4.6 KB
Line 
1/* $Id: GVMMR0Internal.h 92892 2021-12-14 08:57:53Z vboxsync $ */
2/** @file
3 * GVMM - The Global VM Manager, Internal header.
4 */
5
6/*
7 * Copyright (C) 2007-2020 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 */
31typedef 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. */
53typedef GVMMPERVCPU *PGVMMPERVCPU;
54
55
56/**
57 * EMT hash table entry.
58 */
59typedef 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;
69AssertCompileSize(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 */
95typedef 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. */
128typedef GVMMPERVM *PGVMMPERVM;
129
130
131#endif /* !VMM_INCLUDED_SRC_VMMR0_GVMMR0Internal_h */
132
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette