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
|
/* $Id: Intel_80386.h $ */
/** @file
* CPU database entry "Intel 80386".
* Handcrafted.
*/
/*
* Copyright (C) 2013-2023 Oracle and/or its affiliates.
*
* This file is part of VirtualBox base platform packages, as
* available from https://www.virtualbox.org.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation, in version 3 of the
* License.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see <https://www.gnu.org/licenses>.
*
* SPDX-License-Identifier: GPL-3.0-only
*/
#ifndef VBOX_CPUDB_Intel_80386_h
#define VBOX_CPUDB_Intel_80386_h
#ifndef RT_WITHOUT_PRAGMA_ONCE
# pragma once
#endif
#ifndef CPUM_DB_STANDALONE
/**
* Fake CPUID leaves for Intel(R) 80386.
*
* We fake these to keep the CPUM ignorant of CPUs withou CPUID leaves
* and avoid having to seed CPUM::GuestFeatures filling with bits from the
* CPUMDBENTRY.
*/
static CPUMCPUIDLEAF const g_aCpuIdLeaves_Intel_80386[] =
{
{ 0x00000000, 0x00000000, 0x00000000, 0x00000001, 0x756e6547, 0x6c65746e, 0x49656e69, 0 },
{ 0x00000001, 0x00000000, 0x00000000, 0x00000300, 0x00000100, 0x00000000, 0x00000000, 0 },
{ 0x80000000, 0x00000000, 0x00000000, 0x80000008, 0x00000000, 0x00000000, 0x00000000, 0 },
{ 0x80000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0 },
{ 0x80000002, 0x00000000, 0x00000000, 0x65746e49, 0x2952286c, 0x33303820, 0x20203638, 0 },
{ 0x80000003, 0x00000000, 0x00000000, 0x20202020, 0x20202020, 0x20202020, 0x20202020, 0 },
{ 0x80000004, 0x00000000, 0x00000000, 0x20202020, 0x20202020, 0x20202020, 0x20202020, 0 },
{ 0x80000005, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0 },
{ 0x80000006, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0 },
{ 0x80000007, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0 },
{ 0x80000008, 0x00000000, 0x00000000, 0x00001818, 0x00000000, 0x00000000, 0x00000000, 0 },
};
#endif /* !CPUM_DB_STANDALONE */
/**
* Database entry for Intel(R) 80386.
*/
static CPUMDBENTRY const g_Entry_Intel_80386 =
{
/*.pszName = */ "Intel 80386",
/*.pszFullName = */ "Intel(R) 80386",
/*.enmVendor = */ CPUMCPUVENDOR_INTEL,
/*.uFamily = */ 3,
/*.uModel = */ 0,
/*.uStepping = */ 0,
/*.enmMicroarch = */ kCpumMicroarch_Intel_80386,
/*.uScalableBusFreq = */ CPUM_SBUSFREQ_UNKNOWN,
/*.fFlags = */ CPUMDB_F_EXECUTE_ALL_IN_IEM,
/*.cMaxPhysAddrWidth= */ 24,
/*.fMxCsrMask = */ 0,
/*.paCpuIdLeaves = */ NULL_ALONE(g_aCpuIdLeaves_Intel_80386),
/*.cCpuIdLeaves = */ ZERO_ALONE(RT_ELEMENTS(g_aCpuIdLeaves_Intel_80386)),
/*.enmUnknownCpuId = */ CPUMUNKNOWNCPUID_DEFAULTS,
/*.DefUnknownCpuId = */ { 0x00000000, 0x00000000, 0x00000000, 0x00000000 },
/*.fMsrMask = */ 0,
/*.cMsrRanges = */ 0,
/*.paMsrRanges = */ NULL,
};
#endif /* !VBOX_CPUDB_Intel_80386_h */
|