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
|
/* $Id: Intel_80286.h $ */
/** @file
* CPU database entry "Intel 80286".
* Handcrafted.
*/
/*
* Copyright (C) 2013-2019 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.
*/
#ifndef VBOX_CPUDB_Intel_80286_h
#define VBOX_CPUDB_Intel_80286_h
#ifndef RT_WITHOUT_PRAGMA_ONCE
# pragma once
#endif
#ifndef CPUM_DB_STANDALONE
/**
* Fake CPUID leaves for Intel(R) 80286.
*
* We fake these to keep the CPUM ignorant of CPUs wihtout CPUID leaves
* and avoid having to seed CPUM::GuestFeatures filling with bits from the
* CPUMDBENTRY.
*/
static CPUMCPUIDLEAF const g_aCpuIdLeaves_Intel_80286[] =
{
{ 0x00000000, 0x00000000, 0x00000000, 0x00000001, 0x756e6547, 0x6c65746e, 0x49656e69, 0 },
{ 0x00000001, 0x00000000, 0x00000000, 0x00000200, 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, 0x32303820, 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) 80286.
*/
static CPUMDBENTRY const g_Entry_Intel_80286 =
{
/*.pszName = */ "Intel 80286",
/*.pszFullName = */ "Intel(R) 80286",
/*.enmVendor = */ CPUMCPUVENDOR_INTEL,
/*.uFamily = */ 2,
/*.uModel = */ 0,
/*.uStepping = */ 0,
/*.enmMicroarch = */ kCpumMicroarch_Intel_80286,
/*.uScalableBusFreq = */ CPUM_SBUSFREQ_UNKNOWN,
/*.fFlags = */ CPUDB_F_EXECUTE_ALL_IN_IEM,
/*.cMaxPhysAddrWidth= */ 24,
/*.fMxCsrMask = */ 0,
/*.paCpuIdLeaves = */ NULL_ALONE(g_aCpuIdLeaves_Intel_80286),
/*.cCpuIdLeaves = */ ZERO_ALONE(RT_ELEMENTS(g_aCpuIdLeaves_Intel_80286)),
/*.enmUnknownCpuId = */ CPUMUNKNOWNCPUID_DEFAULTS,
/*.DefUnknownCpuId = */ { 0x00000000, 0x00000000, 0x00000000, 0x00000000 },
/*.fMsrMask = */ 0,
/*.cMsrRanges = */ 0,
/*.paMsrRanges = */ NULL,
};
#endif /* !VBOX_CPUDB_Intel_80286_h */
|