VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-cmn-PagingSetupCanonicalTraps.c@ 106215

Last change on this file since 106215 was 106061, checked in by vboxsync, 3 months ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.7 KB
Line 
1/* $Id: bs3-cmn-PagingSetupCanonicalTraps.c 106061 2024-09-16 14:03:52Z vboxsync $ */
2/** @file
3 * BS3Kit - Bs3PagingSetupCanonicalTraps
4 */
5
6/*
7 * Copyright (C) 2007-2024 Oracle and/or its affiliates.
8 *
9 * This file is part of VirtualBox base platform packages, as
10 * available from https://www.virtualbox.org.
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation, in version 3 of the
15 * License.
16 *
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, see <https://www.gnu.org/licenses>.
24 *
25 * The contents of this file may alternatively be used under the terms
26 * of the Common Development and Distribution License Version 1.0
27 * (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
28 * in the VirtualBox distribution, in which case the provisions of the
29 * CDDL are applicable instead of those of the GPL.
30 *
31 * You may elect to license modified versions of this file under the
32 * terms and conditions of either the GPL or the CDDL or both.
33 *
34 * SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
35 */
36
37
38/*********************************************************************************************************************************
39* Header Files *
40*********************************************************************************************************************************/
41#include "bs3kit-template-header.h"
42#include "bs3-cmn-paging.h"
43#include "iprt/asm-amd64-x86.h"
44
45
46#undef Bs3PagingSetupCanonicalTraps
47BS3_CMN_PROTO_STUB(void BS3_FAR *, Bs3PagingSetupCanonicalTraps,(void))
48{
49 if (g_uBs3CpuDetected & BS3CPU_F_LONG_MODE)
50 {
51#if ARCH_BITS == 16
52 if (!BS3_MODE_IS_RM_OR_V86(g_bBs3CurrentMode))
53#endif
54 {
55 uint8_t BS3_FAR *pb;
56 X86PTEPAE BS3_FAR *paLoPtes;
57 X86PTEPAE BS3_FAR *paHiPtes;
58 int rc;
59
60 /* Already initialized? Likely. */
61 if (g_cbBs3PagingCanonicalTraps != 0)
62 return Bs3XptrFlatToCurrent(g_uBs3PagingCanonicalTrapsAddr);
63
64 /* Initialize AMD64 page tables if necessary (unlikely). */
65 if (g_PhysPagingRootLM == UINT32_MAX)
66 {
67 rc = Bs3PagingInitRootForLM();
68 if (RT_FAILURE(rc))
69 return NULL;
70 }
71
72 /*
73 * Get the page table entries first to avoid having to unmap things.
74 */
75 paLoPtes = bs3PagingGetPaePte(g_PhysPagingRootLM, BS3_MODE_LM64, UINT64_C(0x00007fffffffe000), false, &rc);
76 paHiPtes = bs3PagingGetPaePte(g_PhysPagingRootLM, BS3_MODE_LM64, UINT64_C(0xffff800000000000), false, &rc);
77 if (!paHiPtes || !paLoPtes)
78 {
79 Bs3TestPrintf("warning: Bs3PagingSetupCanonicalTraps - failed to get PTEs!\n");
80 return NULL;
81 }
82
83 /*
84 * Allocate the buffer. Currently using 8KB on each side.
85 */
86 pb = (uint8_t BS3_FAR *)Bs3MemAlloc(BS3MEMKIND_TILED, X86_PAGE_SIZE * 4);
87 if (pb)
88 {
89 RTCCUINTXREG uFlat = Bs3SelPtrToFlat(pb);
90
91 /*
92 * Inject it into the page tables.
93 */
94 paLoPtes[0].u &= ~X86_PTE_PAE_PG_MASK;
95 paLoPtes[0].u |= uFlat + X86_PAGE_SIZE * 0;
96 paLoPtes[1].u &= ~X86_PTE_PAE_PG_MASK;
97 paLoPtes[1].u |= uFlat + X86_PAGE_SIZE * 1;
98
99 paHiPtes[0].u &= ~X86_PTE_PAE_PG_MASK;
100 paHiPtes[0].u |= uFlat + X86_PAGE_SIZE * 2;
101 paHiPtes[1].u &= ~X86_PTE_PAE_PG_MASK;
102 paHiPtes[1].u |= uFlat + X86_PAGE_SIZE * 3;
103 ASMReloadCR3();
104
105 /*
106 * Update globals and return successfully.
107 */
108 g_uBs3PagingCanonicalTrapsAddr = uFlat;
109 g_cbBs3PagingCanonicalTraps = X86_PAGE_SIZE * 4;
110 g_cbBs3PagingOneCanonicalTrap = X86_PAGE_SIZE * 2;
111 return pb;
112 }
113
114 Bs3TestPrintf("warning: Bs3PagingSetupCanonicalTraps - out of memory (mode %#x)\n", g_bBs3CurrentMode);
115 }
116#if ARCH_BITS == 16
117 else
118 Bs3TestPrintf("warning: Bs3PagingSetupCanonicalTraps was called in RM or V86 mode (%#x)!\n", g_bBs3CurrentMode);
119#endif
120 }
121 return NULL;
122}
123
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