/* * \brief CPU context of a virtual machine for x86 * \author Alexander Boettcher * \date 2018-10-09 */ /* * Copyright (C) 2018 Genode Labs GmbH * * This file is part of the Genode OS framework, which is distributed * under the terms of the GNU Affero General Public License version 3. */ #ifndef _INCLUDE__SPEC__X86__CPU__VM_STATE_H_ #define _INCLUDE__SPEC__X86__CPU__VM_STATE_H_ #include namespace Genode { struct Vm_state; } struct Genode::Vm_state { template class Register { private: bool _valid; T _value { }; public: Register() : _valid(false) { } Register(T value) : _valid(true), _value(value) { } T value() const { return _value; } void value(T value) { _value = value; _valid = true; } bool valid() const { return _valid; } void invalid() { _valid = false; } Register &operator = (Register const &other) { _valid = other._valid; /* keep original _value if other._valid is not valid */ if (_valid) _value = other._value; return *this; } }; struct Range { addr_t base; uint32_t limit; }; struct Segment { uint16_t sel, ar; uint32_t limit; addr_t base; }; Register ax; Register cx; Register dx; Register bx; Register bp; Register si; Register di; Register sp; Register ip; Register ip_len; Register flags; Register es; Register ds; Register fs; Register gs; Register cs; Register ss; Register tr; Register ldtr; Register gdtr; Register idtr; Register cr0; Register cr2; Register cr3; Register cr4; Register dr7; Register sysenter_ip; Register sysenter_sp; Register sysenter_cs; Register qual_primary; Register qual_secondary; Register ctrl_primary; Register ctrl_secondary; Register inj_info; Register inj_error; Register intr_state; Register actv_state; Register tsc; Register tsc_offset; Register efer; Register pdpte_0; Register pdpte_1; Register pdpte_2; Register pdpte_3; Register r8; Register r9; Register r10; Register r11; Register r12; Register r13; Register r14; Register r15; Register star; Register lstar; Register cstar; Register fmask; Register kernel_gs_base; Register tpr; Register tpr_threshold; unsigned exit_reason; class Fpu { private : uint8_t _value[512] { }; bool _valid { false }; public: bool valid() const { return _valid; } void invalid() { _valid = false; } template void value(FUNC const &fn) { _valid = true; fn(_value, sizeof(_value)); }; Fpu &operator = (Fpu const &) { _valid = false; return *this; } } fpu __attribute__((aligned(16))); }; #endif /* _INCLUDE__SPEC__X86__CPU__VM_STATE_H_ */