mirror of
https://github.com/projectacrn/acrn-hypervisor.git
synced 2025-05-12 10:24:21 +00:00
clean up a few MISRA C violations that can be fixed by code change in vboot files Tracked-On: #861 Signed-off-by: Jason Chen CJ <jason.cj.chen@intel.com>
97 lines
2.3 KiB
C
97 lines
2.3 KiB
C
/*
|
|
* Copyright (C) 2019 Intel Corporation. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
/* this is for de-privilege guest vboot method */
|
|
|
|
#include <types.h>
|
|
#include <acrn_common.h>
|
|
#include <pgtable.h>
|
|
#include <logmsg.h>
|
|
#include <rtl.h>
|
|
#include <vlapic.h>
|
|
#include <lapic.h>
|
|
#include <per_cpu.h>
|
|
#include <multiboot.h>
|
|
#include <deprivilege_boot.h>
|
|
|
|
static struct depri_boot_context depri_boot_ctx;
|
|
static struct lapic_regs depri_boot_lapic_regs;
|
|
|
|
static void init_depri_boot(void)
|
|
{
|
|
static bool depri_initialized = false;
|
|
struct multiboot_info *mbi = NULL;
|
|
|
|
if (!depri_initialized) {
|
|
(void)parse_hv_cmdline();
|
|
|
|
mbi = (struct multiboot_info *) hpa2hva(((uint64_t)(uint32_t)boot_regs[1]));
|
|
if ((mbi == NULL) || ((mbi->mi_flags & MULTIBOOT_INFO_HAS_DRIVES) == 0U)) {
|
|
pr_err("no multiboot drivers for depri_boot found");
|
|
} else {
|
|
(void)memcpy_s(&depri_boot_ctx, sizeof(struct depri_boot_context),
|
|
hpa2hva((uint64_t)mbi->mi_drives_addr),
|
|
sizeof(struct depri_boot_context));
|
|
save_lapic(&depri_boot_lapic_regs);
|
|
}
|
|
depri_initialized = true;
|
|
}
|
|
}
|
|
|
|
const struct depri_boot_context *get_depri_boot_ctx(void)
|
|
{
|
|
init_depri_boot();
|
|
return &depri_boot_ctx;
|
|
}
|
|
|
|
const struct lapic_regs *get_depri_boot_lapic_regs(void)
|
|
{
|
|
init_depri_boot();
|
|
return &depri_boot_lapic_regs;
|
|
}
|
|
|
|
static uint64_t get_depri_boot_ap_trampoline(void)
|
|
{
|
|
return depri_boot_ctx.ap_trampoline_buf;
|
|
}
|
|
|
|
static void* get_depri_boot_rsdp(void)
|
|
{
|
|
return hpa2hva((uint64_t)(depri_boot_ctx.rsdp));
|
|
}
|
|
|
|
static void depri_boot_spurious_handler(uint32_t vector)
|
|
{
|
|
if (get_pcpu_id() == BOOT_CPU_ID) {
|
|
struct acrn_vcpu *vcpu = per_cpu(vcpu, BOOT_CPU_ID);
|
|
|
|
if (vcpu != NULL) {
|
|
vlapic_set_intr(vcpu, vector, LAPIC_TRIG_EDGE);
|
|
} else {
|
|
pr_err("%s vcpu or vlapic is not ready, interrupt lost\n", __func__);
|
|
}
|
|
}
|
|
}
|
|
|
|
static void init_depri_boot_irq(void)
|
|
{
|
|
spurious_handler = (spurious_handler_t)depri_boot_spurious_handler;
|
|
/* we defer irq enabling till vlapic is ready */
|
|
}
|
|
|
|
static struct vboot_operations depri_boot_ops = {
|
|
.init = init_depri_boot,
|
|
.get_ap_trampoline = get_depri_boot_ap_trampoline,
|
|
.get_rsdp = get_depri_boot_rsdp,
|
|
.init_irq = init_depri_boot_irq,
|
|
.init_vboot_info = init_depri_vboot_info,
|
|
};
|
|
|
|
struct vboot_operations* get_deprivilege_boot_ops(void)
|
|
{
|
|
return &depri_boot_ops;
|
|
}
|