VirtualBox

source: vbox/trunk/include/VBox/types.h@ 28764

Last change on this file since 28764 was 28037, checked in by vboxsync, 15 years ago

DevE1000,GSO: coding.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 27.1 KB
Line 
1/** @file
2 * VirtualBox - Types.
3 */
4
5/*
6 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 *
25 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
26 * Clara, CA 95054 USA or visit http://www.sun.com if you need
27 * additional information or have any questions.
28 */
29
30#ifndef ___VBox_types_h
31#define ___VBox_types_h
32
33#include <VBox/cdefs.h>
34#include <iprt/types.h>
35
36
37/** @defgroup grp_types Basic VBox Types
38 * @{
39 */
40
41
42/** @defgroup grp_types_both Common Guest and Host Context Basic Types
43 * @ingroup grp_types
44 * @{
45 */
46
47
48/** @defgroup grp_types_hc Host Context Basic Types
49 * @ingroup grp_types_both
50 * @{
51 */
52
53/** @} */
54
55
56/** @defgroup grp_types_gc Guest Context Basic Types
57 * @ingroup grp_types_both
58 * @{
59 */
60
61/** @} */
62
63
64/** Pointer to per support driver session data.
65 * (The data is a R0 entity and private to the the R0 SUP part. All
66 * other should consider this a sort of handle.) */
67typedef R0PTRTYPE(struct SUPDRVSESSION *) PSUPDRVSESSION;
68
69/** Pointer to a VM. */
70typedef struct VM *PVM;
71/** Pointer to a VM - Ring-0 Ptr. */
72typedef R0PTRTYPE(struct VM *) PVMR0;
73/** Pointer to a VM - Ring-3 Ptr. */
74typedef R3PTRTYPE(struct VM *) PVMR3;
75/** Pointer to a VM - RC Ptr. */
76typedef RCPTRTYPE(struct VM *) PVMRC;
77
78/** Pointer to a virtual CPU structure. */
79typedef struct VMCPU * PVMCPU;
80/** Pointer to a virtual CPU structure - Ring-3 Ptr. */
81typedef R3PTRTYPE(struct VMCPU *) PVMCPUR3;
82/** Pointer to a virtual CPU structure - Ring-0 Ptr. */
83typedef R0PTRTYPE(struct VMCPU *) PVMCPUR0;
84/** Pointer to a virtual CPU structure - RC Ptr. */
85typedef RCPTRTYPE(struct VMCPU *) PVMCPURC;
86
87/** Pointer to a ring-0 (global) VM structure. */
88typedef R0PTRTYPE(struct GVM *) PGVM;
89
90/** Pointer to a ring-3 (user mode) VM structure. */
91typedef R3PTRTYPE(struct UVM *) PUVM;
92
93/** Pointer to a ring-3 (user mode) VMCPU structure. */
94typedef R3PTRTYPE(struct UVMCPU *) PUVMCPU;
95
96/** Virtual CPU ID. */
97typedef uint32_t VMCPUID;
98/** Pointer to a virtual CPU ID. */
99typedef VMCPUID *PVMCPUID;
100/** @name Special CPU ID values.
101 * Most of these are for request scheduling.
102 *
103 * @{ */
104/** All virtual CPUs. */
105#define VMCPUID_ALL UINT32_C(0xfffffff2)
106/** All virtual CPUs, descending order. */
107#define VMCPUID_ALL_REVERSE UINT32_C(0xfffffff3)
108/** Any virtual CPU.
109 * Intended for scheduling a VM request or some other task. */
110#define VMCPUID_ANY UINT32_C(0xfffffff4)
111/** Any virtual CPU; always queue for future execution.
112 * Intended for scheduling a VM request or some other task. */
113#define VMCPUID_ANY_QUEUE UINT32_C(0xfffffff5)
114/** The NIL value. */
115#define NIL_VMCPUID UINT32_C(0xfffffffd)
116/** @} */
117
118/**
119 * Virtual CPU set.
120 */
121typedef struct VMCPUSET
122{
123 /** The bitmap data. */
124 uint32_t au32Bitmap[256/32];
125} VMCPUSET;
126/** Pointer to a Virtual CPU set. */
127typedef VMCPUSET *PVMCPUSET;
128/** Pointer to a const Virtual CPU set. */
129typedef VMCPUSET const *PCVMCPUSET;
130
131/** Tests if a valid CPU ID is present in the set.. */
132#define VMCPUSET_IS_PRESENT(pSet, idCpu) ASMBitTest( &(pSet)->au32Bitmap, (idCpu))
133/** Adds a CPU to the set. */
134#define VMCPUSET_ADD(pSet, idCpu) ASMBitSet( &(pSet)->au32Bitmap, (idCpu))
135/** Deletes a CPU from the set. */
136#define VMCPUSET_DEL(pSet, idCpu) ASMBitClear(&(pSet)->au32Bitmap, (idCpu))
137/** Empties the set. */
138#define VMCPUSET_EMPTY(pSet) memset(&(pSet)->au32Bitmap[0], '\0', sizeof((pSet)->au32Bitmap))
139/** Filles the set. */
140#define VMCPUSET_FILL(pSet) memset(&(pSet)->au32Bitmap[0], 0xff, sizeof((pSet)->au32Bitmap))
141/** Filles the set. */
142#define VMCPUSET_IS_EQUAL(pSet1, pSet2) (memcmp(&(pSet1)->au32Bitmap[0], &(pSet2)->au32Bitmap[0], sizeof((pSet1)->au32Bitmap)) == 0)
143
144
145/**
146 * VM State
147 */
148typedef enum VMSTATE
149{
150 /** The VM is being created. */
151 VMSTATE_CREATING = 0,
152 /** The VM is created. */
153 VMSTATE_CREATED,
154 /** The VM state is being loaded from file. */
155 VMSTATE_LOADING,
156 /** The VM is being powered on */
157 VMSTATE_POWERING_ON,
158 /** The VM is being resumed. */
159 VMSTATE_RESUMING,
160 /** The VM is runnning. */
161 VMSTATE_RUNNING,
162 /** Live save: The VM is running and the state is being saved. */
163 VMSTATE_RUNNING_LS,
164 /** The VM is being reset. */
165 VMSTATE_RESETTING,
166 /** Live save: The VM is being reset and immediately suspended. */
167 VMSTATE_RESETTING_LS,
168 /** The VM is being suspended. */
169 VMSTATE_SUSPENDING,
170 /** Live save: The VM is being suspended during a live save operation, either as
171 * part of the normal flow or VMR3Reset. */
172 VMSTATE_SUSPENDING_LS,
173 /** Live save: The VM is being suspended by VMR3Suspend during live save. */
174 VMSTATE_SUSPENDING_EXT_LS,
175 /** The VM is suspended. */
176 VMSTATE_SUSPENDED,
177 /** Live save: The VM has been suspended and is waiting for the live save
178 * operation to move on. */
179 VMSTATE_SUSPENDED_LS,
180 /** Live save: The VM has been suspended by VMR3Suspend during a live save. */
181 VMSTATE_SUSPENDED_EXT_LS,
182 /** The VM is suspended and its state is being saved by EMT(0). (See SSM) */
183 VMSTATE_SAVING,
184 /** The VM is being debugged. (See DBGF.) */
185 VMSTATE_DEBUGGING,
186 /** Live save: The VM is being debugged while the live phase is going on. */
187 VMSTATE_DEBUGGING_LS,
188 /** The VM is being powered off. */
189 VMSTATE_POWERING_OFF,
190 /** Live save: The VM is being powered off and the save cancelled. */
191 VMSTATE_POWERING_OFF_LS,
192 /** The VM is switched off, awaiting destruction. */
193 VMSTATE_OFF,
194 /** Live save: Waiting for cancellation and transition to VMSTATE_OFF. */
195 VMSTATE_OFF_LS,
196 /** The VM is powered off because of a fatal error. */
197 VMSTATE_FATAL_ERROR,
198 /** Live save: Waiting for cancellation and transition to FatalError. */
199 VMSTATE_FATAL_ERROR_LS,
200 /** The VM is in guru meditation over a fatal failure. */
201 VMSTATE_GURU_MEDITATION,
202 /** Live save: Waiting for cancellation and transition to GuruMeditation. */
203 VMSTATE_GURU_MEDITATION_LS,
204 /** The VM is screwed because of a failed state loading. */
205 VMSTATE_LOAD_FAILURE,
206 /** The VM is being destroyed. */
207 VMSTATE_DESTROYING,
208 /** Terminated. */
209 VMSTATE_TERMINATED,
210 /** hack forcing the size of the enum to 32-bits. */
211 VMSTATE_MAKE_32BIT_HACK = 0x7fffffff
212} VMSTATE;
213
214/** @def VBOXSTRICTRC_STRICT_ENABLED
215 * Indicates that VBOXSTRICTRC is in strict mode.
216 */
217#if defined(__cplusplus) \
218 && ARCH_BITS == 64 /* cdecl requires classes and structs as hidden params. */ \
219 && !defined(_MSC_VER) /* trouble similar to 32-bit gcc. */ \
220 && ( defined(RT_STRICT) \
221 || defined(VBOX_STRICT) \
222 || defined(DEBUG) \
223 || defined(DOXYGEN_RUNNING) )
224# define VBOXSTRICTRC_STRICT_ENABLED 1
225# ifdef _MSC_VER
226# pragma warning(disable:4190)
227# endif
228#endif
229
230/** We need RTERR_STRICT_RC. */
231#if defined(VBOXSTRICTRC_STRICT_ENABLED) && !defined(RTERR_STRICT_RC)
232# define RTERR_STRICT_RC 1
233#endif
234
235/**
236 * Strict VirtualBox status code.
237 *
238 * This is normally an 32-bit integer and the only purpose of the type is to
239 * highlight the special handling that is required. But in strict build it is a
240 * class that causes compilation and runtime errors for some of the incorrect
241 * handling.
242 */
243#ifdef VBOXSTRICTRC_STRICT_ENABLED
244struct VBOXSTRICTRC
245{
246protected:
247 /** The status code. */
248 int32_t m_rc;
249
250public:
251 /** Default constructor setting the status to VERR_IPE_UNINITIALIZED_STATUS. */
252 VBOXSTRICTRC()
253#ifdef VERR_IPE_UNINITIALIZED_STATUS
254 : m_rc(VERR_IPE_UNINITIALIZED_STATUS)
255#else
256 : m_rc(-233 /*VERR_IPE_UNINITIALIZED_STATUS*/)
257#endif
258 {
259 }
260
261 /** Constructor for normal integer status codes. */
262 VBOXSTRICTRC(int32_t const rc)
263 : m_rc(rc)
264 {
265 }
266
267 /** Getter that VBOXSTRICTRC_VAL can use. */
268 int32_t getValue() const { return m_rc; }
269
270 /** @name Comparison operators
271 * @{ */
272 bool operator==(int32_t rc) const { return m_rc == rc; }
273 bool operator!=(int32_t rc) const { return m_rc != rc; }
274 bool operator<=(int32_t rc) const { return m_rc <= rc; }
275 bool operator>=(int32_t rc) const { return m_rc >= rc; }
276 bool operator<(int32_t rc) const { return m_rc < rc; }
277 bool operator>(int32_t rc) const { return m_rc > rc; }
278 /** @} */
279
280 /** Special automatic cast for RT_SUCCESS_NP. */
281 operator RTErrStrictType2() const { return RTErrStrictType2(m_rc); }
282
283private:
284 /** @name Constructors that will prevent some of the bad types.
285 * @{ */
286 VBOXSTRICTRC(uint8_t rc) : m_rc(-999) { NOREF(rc); }
287 VBOXSTRICTRC(uint16_t rc) : m_rc(-999) { NOREF(rc); }
288 VBOXSTRICTRC(uint32_t rc) : m_rc(-999) { NOREF(rc); }
289 VBOXSTRICTRC(uint64_t rc) : m_rc(-999) { NOREF(rc); }
290
291 VBOXSTRICTRC(int8_t rc) : m_rc(-999) { NOREF(rc); }
292 VBOXSTRICTRC(int16_t rc) : m_rc(-999) { NOREF(rc); }
293 VBOXSTRICTRC(int64_t rc) : m_rc(-999) { NOREF(rc); }
294 /** @} */
295};
296#else
297typedef int32_t VBOXSTRICTRC;
298#endif
299
300/** @def VBOXSTRICTRC_VAL
301 * Explicit getter.
302 * @param rcStrict The strict VirtualBox status code.
303 */
304#ifdef VBOXSTRICTRC_STRICT_ENABLED
305# define VBOXSTRICTRC_VAL(rcStrict) ( (rcStrict).getValue() )
306#else
307# define VBOXSTRICTRC_VAL(rcStrict) (rcStrict)
308#endif
309
310/** @def VBOXSTRICTRC_TODO
311 * Returns that needs dealing with.
312 * @param rcStrict The strict VirtualBox status code.
313 */
314#define VBOXSTRICTRC_TODO(rcStrict) VBOXSTRICTRC_VAL(rcStrict)
315
316
317/** Pointer to a PDM Base Interface. */
318typedef struct PDMIBASE *PPDMIBASE;
319/** Pointer to a pointer to a PDM Base Interface. */
320typedef PPDMIBASE *PPPDMIBASE;
321
322/** Pointer to a PDM Device Instance. */
323typedef struct PDMDEVINS *PPDMDEVINS;
324/** Pointer to a pointer to a PDM Device Instance. */
325typedef PPDMDEVINS *PPPDMDEVINS;
326/** R3 pointer to a PDM Device Instance. */
327typedef R3PTRTYPE(PPDMDEVINS) PPDMDEVINSR3;
328/** R0 pointer to a PDM Device Instance. */
329typedef R0PTRTYPE(PPDMDEVINS) PPDMDEVINSR0;
330/** RC pointer to a PDM Device Instance. */
331typedef RCPTRTYPE(PPDMDEVINS) PPDMDEVINSRC;
332
333/** Pointer to a PDM USB Device Instance. */
334typedef struct PDMUSBINS *PPDMUSBINS;
335/** Pointer to a pointer to a PDM USB Device Instance. */
336typedef PPDMUSBINS *PPPDMUSBINS;
337
338/** Pointer to a PDM Driver Instance. */
339typedef struct PDMDRVINS *PPDMDRVINS;
340/** Pointer to a pointer to a PDM Driver Instance. */
341typedef PPDMDRVINS *PPPDMDRVINS;
342/** R3 pointer to a PDM Driver Instance. */
343typedef R3PTRTYPE(PPDMDRVINS) PPDMDRVINSR3;
344/** R0 pointer to a PDM Driver Instance. */
345typedef R0PTRTYPE(PPDMDRVINS) PPDMDRVINSR0;
346/** RC pointer to a PDM Driver Instance. */
347typedef RCPTRTYPE(PPDMDRVINS) PPDMDRVINSRC;
348
349/** Pointer to a PDM Service Instance. */
350typedef struct PDMSRVINS *PPDMSRVINS;
351/** Pointer to a pointer to a PDM Service Instance. */
352typedef PPDMSRVINS *PPPDMSRVINS;
353
354/** Pointer to a PDM critical section. */
355typedef union PDMCRITSECT *PPDMCRITSECT;
356/** Pointer to a const PDM critical section. */
357typedef const union PDMCRITSECT *PCPDMCRITSECT;
358
359/** R3 pointer to a timer. */
360typedef R3PTRTYPE(struct TMTIMER *) PTMTIMERR3;
361/** Pointer to a R3 pointer to a timer. */
362typedef PTMTIMERR3 *PPTMTIMERR3;
363
364/** R0 pointer to a timer. */
365typedef R0PTRTYPE(struct TMTIMER *) PTMTIMERR0;
366/** Pointer to a R3 pointer to a timer. */
367typedef PTMTIMERR0 *PPTMTIMERR0;
368
369/** RC pointer to a timer. */
370typedef RCPTRTYPE(struct TMTIMER *) PTMTIMERRC;
371/** Pointer to a RC pointer to a timer. */
372typedef PTMTIMERRC *PPTMTIMERRC;
373
374/** Pointer to a timer. */
375typedef CTX_SUFF(PTMTIMER) PTMTIMER;
376/** Pointer to a pointer to a timer. */
377typedef PTMTIMER *PPTMTIMER;
378
379/** SSM Operation handle. */
380typedef struct SSMHANDLE *PSSMHANDLE;
381/** Pointer to a const SSM stream method table. */
382typedef struct SSMSTRMOPS const *PCSSMSTRMOPS;
383
384/** Pointer to a CPUMCTX. */
385typedef struct CPUMCTX *PCPUMCTX;
386/** Pointer to a const CPUMCTX. */
387typedef const struct CPUMCTX *PCCPUMCTX;
388
389/** Pointer to a CPU context core. */
390typedef struct CPUMCTXCORE *PCPUMCTXCORE;
391/** Pointer to a const CPU context core. */
392typedef const struct CPUMCTXCORE *PCCPUMCTXCORE;
393
394/** Pointer to selector hidden registers. */
395typedef struct CPUMSELREGHID *PCPUMSELREGHID;
396/** Pointer to const selector hidden registers. */
397typedef const struct CPUMSELREGHID *PCCPUMSELREGHID;
398
399/** @} */
400
401
402/** @defgroup grp_types_idt Interrupt Descriptor Table Entry.
403 * @ingroup grp_types
404 * @todo This all belongs in x86.h!
405 * @{ */
406
407/** @todo VBOXIDT -> VBOXDESCIDT, skip the complex variations. We'll never use them. */
408
409/** IDT Entry, Task Gate view. */
410#pragma pack(1) /* paranoia */
411typedef struct VBOXIDTE_TASKGATE
412{
413 /** Reserved. */
414 unsigned u16Reserved1 : 16;
415 /** Task Segment Selector. */
416 unsigned u16TSS : 16;
417 /** More reserved. */
418 unsigned u8Reserved2 : 8;
419 /** Fixed value bit 0 - Set to 1. */
420 unsigned u1Fixed0 : 1;
421 /** Busy bit. */
422 unsigned u1Busy : 1;
423 /** Fixed value bit 2 - Set to 1. */
424 unsigned u1Fixed1 : 1;
425 /** Fixed value bit 3 - Set to 0. */
426 unsigned u1Fixed2: 1;
427 /** Fixed value bit 4 - Set to 0. */
428 unsigned u1Fixed3 : 1;
429 /** Descriptor Privilege level. */
430 unsigned u2DPL : 2;
431 /** Present flag. */
432 unsigned u1Present : 1;
433 /** Reserved. */
434 unsigned u16Reserved3 : 16;
435} VBOXIDTE_TASKGATE;
436#pragma pack()
437/** Pointer to IDT Entry, Task gate view. */
438typedef VBOXIDTE_TASKGATE *PVBOXIDTE_TASKGATE;
439
440
441/** IDT Entry, Intertupt gate view. */
442#pragma pack(1) /* paranoia */
443typedef struct VBOXIDTE_INTERRUPTGATE
444{
445 /** Low offset word. */
446 unsigned u16OffsetLow : 16;
447 /** Segment Selector. */
448 unsigned u16SegSel : 16;
449 /** Reserved. */
450 unsigned u5Reserved2 : 5;
451 /** Fixed value bit 0 - Set to 0. */
452 unsigned u1Fixed0 : 1;
453 /** Fixed value bit 1 - Set to 0. */
454 unsigned u1Fixed1 : 1;
455 /** Fixed value bit 2 - Set to 0. */
456 unsigned u1Fixed2 : 1;
457 /** Fixed value bit 3 - Set to 0. */
458 unsigned u1Fixed3: 1;
459 /** Fixed value bit 4 - Set to 1. */
460 unsigned u1Fixed4 : 1;
461 /** Fixed value bit 5 - Set to 1. */
462 unsigned u1Fixed5 : 1;
463 /** Gate size, 1 = 32 bits, 0 = 16 bits. */
464 unsigned u132BitGate : 1;
465 /** Fixed value bit 5 - Set to 0. */
466 unsigned u1Fixed6 : 1;
467 /** Descriptor Privilege level. */
468 unsigned u2DPL : 2;
469 /** Present flag. */
470 unsigned u1Present : 1;
471 /** High offset word. */
472 unsigned u16OffsetHigh : 16;
473} VBOXIDTE_INTERRUPTGATE;
474#pragma pack()
475/** Pointer to IDT Entry, Interrupt gate view. */
476typedef VBOXIDTE_INTERRUPTGATE *PVBOXIDTE_INTERRUPTGATE;
477
478/** IDT Entry, Trap Gate view. */
479#pragma pack(1) /* paranoia */
480typedef struct VBOXIDTE_TRAPGATE
481{
482 /** Low offset word. */
483 unsigned u16OffsetLow : 16;
484 /** Segment Selector. */
485 unsigned u16SegSel : 16;
486 /** Reserved. */
487 unsigned u5Reserved2 : 5;
488 /** Fixed value bit 0 - Set to 0. */
489 unsigned u1Fixed0 : 1;
490 /** Fixed value bit 1 - Set to 0. */
491 unsigned u1Fixed1 : 1;
492 /** Fixed value bit 2 - Set to 0. */
493 unsigned u1Fixed2 : 1;
494 /** Fixed value bit 3 - Set to 1. */
495 unsigned u1Fixed3: 1;
496 /** Fixed value bit 4 - Set to 1. */
497 unsigned u1Fixed4 : 1;
498 /** Fixed value bit 5 - Set to 1. */
499 unsigned u1Fixed5 : 1;
500 /** Gate size, 1 = 32 bits, 0 = 16 bits. */
501 unsigned u132BitGate : 1;
502 /** Fixed value bit 5 - Set to 0. */
503 unsigned u1Fixed6 : 1;
504 /** Descriptor Privilege level. */
505 unsigned u2DPL : 2;
506 /** Present flag. */
507 unsigned u1Present : 1;
508 /** High offset word. */
509 unsigned u16OffsetHigh : 16;
510} VBOXIDTE_TRAPGATE;
511#pragma pack()
512/** Pointer to IDT Entry, Trap Gate view. */
513typedef VBOXIDTE_TRAPGATE *PVBOXIDTE_TRAPGATE;
514
515/** IDT Entry Generic view. */
516#pragma pack(1) /* paranoia */
517typedef struct VBOXIDTE_GENERIC
518{
519 /** Low offset word. */
520 unsigned u16OffsetLow : 16;
521 /** Segment Selector. */
522 unsigned u16SegSel : 16;
523 /** Reserved. */
524 unsigned u5Reserved : 5;
525 /** IDT Type part one (not used for task gate). */
526 unsigned u3Type1 : 3;
527 /** IDT Type part two. */
528 unsigned u5Type2 : 5;
529 /** Descriptor Privilege level. */
530 unsigned u2DPL : 2;
531 /** Present flag. */
532 unsigned u1Present : 1;
533 /** High offset word. */
534 unsigned u16OffsetHigh : 16;
535} VBOXIDTE_GENERIC;
536#pragma pack()
537/** Pointer to IDT Entry Generic view. */
538typedef VBOXIDTE_GENERIC *PVBOXIDTE_GENERIC;
539
540/** IDT Type1 value. (Reserved for task gate!) */
541#define VBOX_IDTE_TYPE1 0
542/** IDT Type2 value - Task gate. */
543#define VBOX_IDTE_TYPE2_TASK 0x5
544/** IDT Type2 value - 16 bit interrupt gate. */
545#define VBOX_IDTE_TYPE2_INT_16 0x6
546/** IDT Type2 value - 32 bit interrupt gate. */
547#define VBOX_IDTE_TYPE2_INT_32 0xe
548/** IDT Type2 value - 16 bit trap gate. */
549#define VBOX_IDTE_TYPE2_TRAP_16 0x7
550/** IDT Type2 value - 32 bit trap gate. */
551#define VBOX_IDTE_TYPE2_TRAP_32 0xf
552
553/** IDT Entry. */
554#pragma pack(1) /* paranoia */
555typedef union VBOXIDTE
556{
557 /** Task gate view. */
558 VBOXIDTE_TASKGATE Task;
559 /** Trap gate view. */
560 VBOXIDTE_TRAPGATE Trap;
561 /** Interrupt gate view. */
562 VBOXIDTE_INTERRUPTGATE Int;
563 /** Generic IDT view. */
564 VBOXIDTE_GENERIC Gen;
565
566 /** 8 bit unsigned integer view. */
567 uint8_t au8[8];
568 /** 16 bit unsigned integer view. */
569 uint16_t au16[4];
570 /** 32 bit unsigned integer view. */
571 uint32_t au32[2];
572 /** 64 bit unsigned integer view. */
573 uint64_t au64;
574} VBOXIDTE;
575#pragma pack()
576/** Pointer to IDT Entry. */
577typedef VBOXIDTE *PVBOXIDTE;
578/** Pointer to IDT Entry. */
579typedef VBOXIDTE const *PCVBOXIDTE;
580
581#pragma pack(1)
582/** IDTR */
583typedef struct VBOXIDTR
584{
585 /** Size of the IDT. */
586 uint16_t cbIdt;
587 /** Address of the IDT. */
588 uint64_t pIdt;
589} VBOXIDTR, *PVBOXIDTR;
590#pragma pack()
591
592#pragma pack(1)
593/** IDTR from version 1.6 */
594typedef struct VBOXIDTR_VER1_6
595{
596 /** Size of the IDT. */
597 uint16_t cbIdt;
598 /** Address of the IDT. */
599 uint32_t pIdt;
600} VBOXIDTR_VER1_6, *PVBOXIDTR_VER1_6;
601#pragma pack()
602
603/** @} */
604
605
606/** @def VBOXIDTE_OFFSET
607 * Return the offset of an IDT entry.
608 */
609#define VBOXIDTE_OFFSET(desc) \
610 ( ((uint32_t)((desc).Gen.u16OffsetHigh) << 16) \
611 | ( (desc).Gen.u16OffsetLow ) )
612
613#pragma pack(1)
614/** GDTR */
615typedef struct VBOXGDTR
616{
617 /** Size of the GDT. */
618 uint16_t cbGdt;
619 /** Address of the GDT. */
620 uint64_t pGdt;
621} VBOXGDTR;
622#pragma pack()
623/** Pointer to GDTR. */
624typedef VBOXGDTR *PVBOXGDTR;
625
626#pragma pack(1)
627/** GDTR from version 1.6 */
628typedef struct VBOXGDTR_VER1_6
629{
630 /** Size of the GDT. */
631 uint16_t cbGdt;
632 /** Address of the GDT. */
633 uint32_t pGdt;
634} VBOXGDTR_VER1_6;
635#pragma pack()
636
637/** @} */
638
639
640/**
641 * 32-bit Task Segment used in raw mode.
642 * @todo Move this to SELM! Use X86TSS32 instead.
643 */
644#pragma pack(1)
645typedef struct VBOXTSS
646{
647 /** 0x00 - Back link to previous task. (static) */
648 RTSEL selPrev;
649 uint16_t padding1;
650 /** 0x04 - Ring-0 stack pointer. (static) */
651 uint32_t esp0;
652 /** 0x08 - Ring-0 stack segment. (static) */
653 RTSEL ss0;
654 uint16_t padding_ss0;
655 /** 0x0c - Ring-1 stack pointer. (static) */
656 uint32_t esp1;
657 /** 0x10 - Ring-1 stack segment. (static) */
658 RTSEL ss1;
659 uint16_t padding_ss1;
660 /** 0x14 - Ring-2 stack pointer. (static) */
661 uint32_t esp2;
662 /** 0x18 - Ring-2 stack segment. (static) */
663 RTSEL ss2;
664 uint16_t padding_ss2;
665 /** 0x1c - Page directory for the task. (static) */
666 uint32_t cr3;
667 /** 0x20 - EIP before task switch. */
668 uint32_t eip;
669 /** 0x24 - EFLAGS before task switch. */
670 uint32_t eflags;
671 /** 0x28 - EAX before task switch. */
672 uint32_t eax;
673 /** 0x2c - ECX before task switch. */
674 uint32_t ecx;
675 /** 0x30 - EDX before task switch. */
676 uint32_t edx;
677 /** 0x34 - EBX before task switch. */
678 uint32_t ebx;
679 /** 0x38 - ESP before task switch. */
680 uint32_t esp;
681 /** 0x3c - EBP before task switch. */
682 uint32_t ebp;
683 /** 0x40 - ESI before task switch. */
684 uint32_t esi;
685 /** 0x44 - EDI before task switch. */
686 uint32_t edi;
687 /** 0x48 - ES before task switch. */
688 RTSEL es;
689 uint16_t padding_es;
690 /** 0x4c - CS before task switch. */
691 RTSEL cs;
692 uint16_t padding_cs;
693 /** 0x50 - SS before task switch. */
694 RTSEL ss;
695 uint16_t padding_ss;
696 /** 0x54 - DS before task switch. */
697 RTSEL ds;
698 uint16_t padding_ds;
699 /** 0x58 - FS before task switch. */
700 RTSEL fs;
701 uint16_t padding_fs;
702 /** 0x5c - GS before task switch. */
703 RTSEL gs;
704 uint16_t padding_gs;
705 /** 0x60 - LDTR before task switch. */
706 RTSEL selLdt;
707 uint16_t padding_ldt;
708 /** 0x64 - Debug trap flag */
709 uint16_t fDebugTrap;
710 /** 0x66 - Offset relative to the TSS of the start of the I/O Bitmap
711 * and the end of the interrupt redirection bitmap. */
712 uint16_t offIoBitmap;
713 /** 0x68 - 32 bytes for the virtual interrupt redirection bitmap. (VME) */
714 uint8_t IntRedirBitmap[32];
715} VBOXTSS;
716#pragma pack()
717/** Pointer to task segment. */
718typedef VBOXTSS *PVBOXTSS;
719/** Pointer to const task segment. */
720typedef const VBOXTSS *PCVBOXTSS;
721
722
723/**
724 * Data transport buffer (scatter/gather)
725 */
726typedef struct PDMDATASEG
727{
728 /** Length of buffer in entry. */
729 size_t cbSeg;
730 /** Pointer to the start of the buffer. */
731 void *pvSeg;
732} PDMDATASEG;
733/** Pointer to a data transport segment. */
734typedef PDMDATASEG *PPDMDATASEG;
735/** Pointer to a const data transport segment. */
736typedef PDMDATASEG const *PCPDMDATASEG;
737
738
739/**
740 * Forms of generic segment offloading.
741 */
742typedef enum PDMNETWORKGSOTYPE
743{
744 /** Invalid zero value. */
745 PDMNETWORKGSOTYPE_INVALID = 0,
746 /** TCP/IPv4 - no CWR/ECE encoding. */
747 PDMNETWORKGSOTYPE_IPV4_TCP,
748 /** TCP/IPv6 - no CWR/ECE encoding. */
749 PDMNETWORKGSOTYPE_IPV6_TCP,
750 /** UDP/IPv4. */
751 PDMNETWORKGSOTYPE_IPV4_UDP,
752 /** UDP/IPv6. */
753 PDMNETWORKGSOTYPE_IPV6_UDP,
754 /** TCP/IPv6 over IPv4 tunneling - no CWR/ECE encoding.
755 * The header offsets and sizes relates to IPv4 and TCP, the IPv6 header is
756 * figured out as needed.
757 * @todo Needs checking against facts, this is just an outline of the idea. */
758 PDMNETWORKGSOTYPE_IPV4_IPV6_TCP,
759 /** UDP/IPv6 over IPv4 tunneling.
760 * The header offsets and sizes relates to IPv4 and UDP, the IPv6 header is
761 * figured out as needed.
762 * @todo Needs checking against facts, this is just an outline of the idea. */
763 PDMNETWORKGSOTYPE_IPV4_IPV6_UDP,
764 /** The end of valid GSO types. */
765 PDMNETWORKGSOTYPE_END
766} PDMNETWORKGSOTYPE;
767
768
769/**
770 * Generic segment offloading context.
771 *
772 * We generally follow the E1000 specs wrt to which header fields we change.
773 * However the GSO type implies where the checksum fields are and that they are
774 * always updated from scratch (no half done pseudo checksums).
775 *
776 * @remarks This is part of the internal network GSO packets. Take great care
777 * when making changes. The size is expected to be exactly 8 bytes.
778 */
779typedef struct PDMNETWORKGSO
780{
781 /** The type of segmentation offloading we're performing (PDMNETWORKGSOTYPE). */
782 uint8_t u8Type;
783 /** The total header size. */
784 uint8_t cbHdrs;
785 /** The max segment size (MSS) to apply. */
786 uint16_t cbMaxSeg;
787
788 /** Offset of the first header (IPv4 / IPv6). 0 if not not needed. */
789 uint8_t offHdr1;
790 /** Offset of the second header (TCP / UDP). 0 if not not needed. */
791 uint8_t offHdr2;
792 /** Unused. */
793 uint8_t au8Unused[2];
794} PDMNETWORKGSO;
795/** Pointer to a GSO context. */
796typedef PDMNETWORKGSO *PPDMNETWORKGSO;
797/** Pointer to a const GSO context. */
798typedef PDMNETWORKGSO const *PCPDMNETWORKGSO;
799
800
801/**
802 * The current ROM page protection.
803 *
804 * @remarks This is part of the saved state.
805 */
806typedef enum PGMROMPROT
807{
808 /** The customary invalid value. */
809 PGMROMPROT_INVALID = 0,
810 /** Read from the virgin ROM page, ignore writes.
811 * Map the virgin page, use write access handler to ignore writes. */
812 PGMROMPROT_READ_ROM_WRITE_IGNORE,
813 /** Read from the virgin ROM page, write to the shadow RAM.
814 * Map the virgin page, use write access handler change the RAM. */
815 PGMROMPROT_READ_ROM_WRITE_RAM,
816 /** Read from the shadow ROM page, ignore writes.
817 * Map the shadow page read-only, use write access handler to ignore writes. */
818 PGMROMPROT_READ_RAM_WRITE_IGNORE,
819 /** Read from the shadow ROM page, ignore writes.
820 * Map the shadow page read-write, disabled write access handler. */
821 PGMROMPROT_READ_RAM_WRITE_RAM,
822 /** The end of valid values. */
823 PGMROMPROT_END,
824 /** The usual 32-bit type size hack. */
825 PGMROMPROT_32BIT_HACK = 0x7fffffff
826} PGMROMPROT;
827
828
829/**
830 * Page mapping lock.
831 *
832 * @remarks This doesn't work in structures shared between
833 * ring-3, ring-0 and/or GC.
834 */
835typedef struct PGMPAGEMAPLOCK
836{
837 /** @todo see PGMPhysIsPageMappingLockValid for possibly incorrect assumptions */
838#if defined(IN_RC) || defined(VBOX_WITH_2X_4GB_ADDR_SPACE_IN_R0)
839 /** Just a dummy for the time being. */
840 uint32_t u32Dummy;
841#else
842 /** Pointer to the PGMPAGE and lock type.
843 * bit-0 abuse: set=write, clear=read. */
844 uintptr_t uPageAndType;
845/** Read lock type value. */
846# define PGMPAGEMAPLOCK_TYPE_READ ((uintptr_t)0)
847/** Write lock type value. */
848# define PGMPAGEMAPLOCK_TYPE_WRITE ((uintptr_t)1)
849/** Lock type mask. */
850# define PGMPAGEMAPLOCK_TYPE_MASK ((uintptr_t)1)
851 /** Pointer to the PGMCHUNKR3MAP. */
852 void *pvMap;
853#endif
854} PGMPAGEMAPLOCK;
855/** Pointer to a page mapping lock. */
856typedef PGMPAGEMAPLOCK *PPGMPAGEMAPLOCK;
857
858
859/** Configuration manager tree node - A key. */
860typedef struct CFGMNODE *PCFGMNODE;
861
862/** Configuration manager tree leaf - A value. */
863typedef struct CFGMLEAF *PCFGMLEAF;
864
865/**
866 * CPU modes.
867 */
868typedef enum CPUMMODE
869{
870 /** The usual invalid zero entry. */
871 CPUMMODE_INVALID = 0,
872 /** Real mode. */
873 CPUMMODE_REAL,
874 /** Protected mode (32-bit). */
875 CPUMMODE_PROTECTED,
876 /** Long mode (64-bit). */
877 CPUMMODE_LONG
878} CPUMMODE;
879
880/** @} */
881
882#endif
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