blob: 054684909512c51f073260055cf4a02ae484da46 [file] [log] [blame]
// Copyright 2017 The Fuchsia Authors
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file or at
#pragma once
#if ARCH_ARM64
#include <arch/arm64/hypervisor.h>
#if ARCH_X86_64
#include <arch/x86/hypervisor.h>
#include <magenta/compiler.h>
#include <magenta/types.h>
#include <mxtl/ref_ptr.h>
#include <mxtl/unique_ptr.h>
class FifoDispatcher;
class VmObject;
/* Create a hypervisor context.
* This setups up the CPUs to allow a hypervisor to be run.
status_t arch_hypervisor_create(mxtl::unique_ptr<HypervisorContext>* context);
/* Create a guest context.
* This creates the structures to allow a guest to be run.
status_t arch_guest_create(mxtl::RefPtr<VmObject> guest_phys_mem,
mxtl::RefPtr<FifoDispatcher> serial_fifo,
mxtl::unique_ptr<GuestContext>* context);
/* Enter a guest context.
status_t arch_guest_enter(const mxtl::unique_ptr<GuestContext>& context);
/* Set the entry of the guest context.
status_t arch_guest_set_entry(const mxtl::unique_ptr<GuestContext>& context, uintptr_t guest_entry);