Pip
Architecture-dependent parts of Pip: MAL, IAL and boot
hdef.h
Go to the documentation of this file.
1 /*******************************************************************************/
2 /* © Université de Lille, The Pip Development Team (2015-2021) */
3 /* */
4 /* This software is a computer program whose purpose is to run a minimal, */
5 /* hypervisor relying on proven properties such as memory isolation. */
6 /* */
7 /* This software is governed by the CeCILL license under French law and */
8 /* abiding by the rules of distribution of free software. You can use, */
9 /* modify and/ or redistribute the software under the terms of the CeCILL */
10 /* license as circulated by CEA, CNRS and INRIA at the following URL */
11 /* "http://www.cecill.info". */
12 /* */
13 /* As a counterpart to the access to the source code and rights to copy, */
14 /* modify and redistribute granted by the license, users are provided only */
15 /* with a limited warranty and the software's author, the holder of the */
16 /* economic rights, and the successive licensors have only limited */
17 /* liability. */
18 /* */
19 /* In this respect, the user's attention is drawn to the risks associated */
20 /* with loading, using, modifying and/or developing or reproducing the */
21 /* software by the user in light of its specific status of free software, */
22 /* that may mean that it is complicated to manipulate, and that also */
23 /* therefore means that it is reserved for developers and experienced */
24 /* professionals having in-depth computer knowledge. Users are therefore */
25 /* encouraged to load and test the software's suitability as regards their */
26 /* requirements in conditions enabling the security of their systems and/or */
27 /* data to be ensured and, more generally, to use and operate it in the */
28 /* same conditions as regards security. */
29 /* */
30 /* The fact that you are presently reading this means that you have had */
31 /* knowledge of the CeCILL license and that you accept its terms. */
32 /*******************************************************************************/
33 
34 #ifndef __HDEF__
35 #define __HDEF__
36 
37 #include <stdint.h>
38 
39 #define HSPEC_COUNT 1
40 
41 #define GENERAL_REG(a, c) a->regs.c
42 #define OPTIONAL_REG(a, c) a->c
43 
44 
49 struct hardware_def {
50  const char* name;
51  uintptr_t paddr_base;
52  uintptr_t vaddr_base;
53  uintptr_t limit;
54 };
55 
56 static const struct hardware_def pshw[HSPEC_COUNT] = {
57  { "VGAController", 0xb8000, 0xc00b8000, 0x8000 },
58 };
59 
60 #endif
uintptr_t vaddr_base
Definition: hdef.h:52
Platform-specific hardware memory range definition.
Definition: hdef.h:49
uintptr_t limit
Definition: hdef.h:53
#define HSPEC_COUNT
Definition: hdef.h:39
static const struct hardware_def pshw[HSPEC_COUNT]
Definition: hdef.h:56
const char * name
Definition: hdef.h:50
uintptr_t paddr_base
Definition: hdef.h:51