VirtualBox

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

Last change on this file since 60774 was 60527, checked in by vboxsync, 9 years ago

bs3kit: Far updates.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.3 KB
Line 
1/* $Id: bs3-cmn-PagingInitRootForPP.c 60527 2016-04-18 09:11:04Z vboxsync $ */
2/** @file
3 * BS3Kit - Bs3PagingInitRootForPP
4 */
5
6/*
7 * Copyright (C) 2007-2015 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 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27/*********************************************************************************************************************************
28* Header Files *
29*********************************************************************************************************************************/
30#include "bs3kit-template-header.h"
31#include "bs3-cmn-paging.h"
32#include "bs3-cmn-memory.h" /* bad bird */
33#include <iprt/param.h>
34
35
36/**
37 * Creates page tables for a section of the page directory.
38 *
39 * @returns VINF_SUCCESS or VERR_NO_MEMORY.
40 * @param pPgDir The page directory.
41 * @param iFirst The first PD entry.
42 * @param cEntries How many PD entries to create pages tables for.
43 */
44static int Bs3PagingInitPageTablesForPgDir(X86PD BS3_FAR *pPgDir, unsigned iFirst, unsigned cEntries)
45{
46 uint32_t uCurPhys = (uint32_t)iFirst << X86_PD_SHIFT;
47
48 while (cEntries--)
49 {
50 X86PT BS3_FAR *pPt = (X86PT BS3_FAR *)Bs3MemAlloc(BS3MEMKIND_TILED, _4K);
51 if (pPt)
52 {
53 unsigned j = 0;
54 for (j = 0; j < RT_ELEMENTS(pPt->a); j++, uCurPhys += PAGE_SIZE)
55 {
56 pPt->a[j].u = uCurPhys;
57 pPt->a[j].u |= X86_PTE_P | X86_PTE_RW | X86_PTE_US | X86_PTE_A | X86_PTE_D;
58 }
59 pPgDir->a[iFirst].u = Bs3SelPtrToFlat(pPt);
60 pPgDir->a[iFirst].u |= X86_PDE_P | X86_PDE_RW | X86_PDE_US | X86_PDE_A;
61 iFirst++;
62 }
63 else
64 return VERR_NO_MEMORY;
65 }
66 return VINF_SUCCESS;
67}
68
69
70#undef Bs3PagingInitRootForPP
71BS3_CMN_DEF(int, Bs3PagingInitRootForPP,(void))
72{
73 X86PD BS3_FAR *pPgDir;
74
75 BS3_ASSERT(g_PhysPagingRootPP == UINT32_MAX);
76
77
78 /*
79 * By default we do a identity mapping of the entire address space
80 * using 4 GB pages. So, we only really need one page directory,
81 * that's all.
82 *
83 * ASSUMES page size extension available, i.e. pentium+.
84 */
85 pPgDir = (X86PD BS3_FAR *)Bs3MemAllocZ(BS3MEMKIND_TILED, _4K);
86 if (pPgDir)
87 {
88 BS3_XPTR_AUTO(X86PD, XptrPgDir);
89 unsigned i;
90 int rc = VINF_SUCCESS;
91
92 if (g_uBs3CpuDetected & BS3CPU_F_PSE)
93 {
94 for (i = 0; i < RT_ELEMENTS(pPgDir->a); i++)
95 {
96 pPgDir->a[i].u = (uint32_t)i << X86_PD_SHIFT;
97 pPgDir->a[i].u |= X86_PDE4M_P | X86_PDE4M_RW | X86_PDE4M_US | X86_PDE4M_PS | X86_PDE4M_A | X86_PDE4M_D;
98 }
99 }
100 else
101 {
102 /*
103 * This requires 4MB of page tables if we map everything.
104 * So, we check how much memory we have available and make sure we
105 * don't use all of it for page tables.
106 */
107 unsigned cMax = RT_ELEMENTS(pPgDir->a);
108 uint32_t cFreePages = g_Bs3Mem4KUpperTiled.Core.cFreeChunks + g_Bs3Mem4KLow.Core.cFreeChunks;
109 if (cFreePages >= cMax + 128)
110 Bs3PagingInitPageTablesForPgDir(pPgDir, 0, cMax);
111 else
112 {
113 unsigned cTop;
114 if (cMax >= 256 /*1MB*/)
115 {
116 cMax = cFreePages - 128;
117 cTop = 32;
118 }
119 else if (cMax >= 128)
120 {
121 cMax = cFreePages - 48;
122 cTop = 16;
123 }
124 else
125 {
126 cMax = cFreePages - 16;
127 cTop = RT_MIN(16, cMax / 4);
128 }
129 Bs3TestPrintf("Bs3PagingInitRootForPP: Warning! insufficient memory for mapping all 4GB!\n"
130 " Will only map 0x00000000-%#010RX32 and %#010RX32-0xffffffff.\n",
131 (uint32_t)(cMax - cTop) << PAGE_SHIFT, UINT32_MAX - ((uint32_t)cTop << PAGE_SHIFT) + 1);
132 rc = Bs3PagingInitPageTablesForPgDir(pPgDir, 0, cMax - cTop);
133 if (RT_SUCCESS(rc))
134 rc = Bs3PagingInitPageTablesForPgDir(pPgDir, RT_ELEMENTS(pPgDir->a) - cTop, cTop);
135 }
136 }
137
138 BS3_XPTR_SET(X86PD, XptrPgDir, pPgDir);
139 g_PhysPagingRootPP = BS3_XPTR_GET_FLAT(X86PD, XptrPgDir);
140 return rc;
141 }
142
143 Bs3Printf("Bs3PagingInitRootForPP: No memory!\n");
144 BS3_ASSERT(false);
145 return VERR_NO_MEMORY;
146}
147
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