vaseboot/VasEBoot-core/kern/riscv/efi/init.c

79 lines
2.1 KiB
C

/* init.c - initialize a riscv-based EFI system */
/*
* VAS_EBOOT -- GRand Unified Bootloader
* Copyright (C) 2018 Free Software Foundation, Inc.
*
* VAS_EBOOT is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* VAS_EBOOT is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with VAS_EBOOT. If not, see <http://www.gnu.org/licenses/>.
*/
#include <VasEBoot/env.h>
#include <VasEBoot/kernel.h>
#include <VasEBoot/misc.h>
#include <VasEBoot/mm.h>
#include <VasEBoot/time.h>
#include <VasEBoot/efi/efi.h>
#include <VasEBoot/loader.h>
static VasEBoot_uint64_t timer_frequency_in_khz;
static VasEBoot_uint64_t
VasEBoot_efi_get_time_ms (void)
{
VasEBoot_uint64_t tmr;
#if __riscv_xlen == 64
asm volatile ("rdtime %0" : "=r"(tmr));
#else
VasEBoot_uint32_t lo, hi, tmp;
asm volatile ("1:\n"
"rdtimeh %0\n"
"rdtime %1\n"
"rdtimeh %2\n"
"bne %0, %2, 1b"
: "=&r" (hi), "=&r" (lo), "=&r" (tmp));
tmr = ((VasEBoot_uint64_t)hi << 32) | lo;
#endif
return tmr / timer_frequency_in_khz;
}
void
VasEBoot_machine_init (void)
{
VasEBoot_uint64_t time_before, time_after;
VasEBoot_efi_init ();
/* Calculate timer frequency */
timer_frequency_in_khz = 1;
time_before = VasEBoot_efi_get_time_ms();
VasEBoot_efi_stall(1000);
time_after = VasEBoot_efi_get_time_ms();
timer_frequency_in_khz = time_after - time_before;
VasEBoot_install_get_time_ms (VasEBoot_efi_get_time_ms);
}
void
VasEBoot_machine_fini (int flags)
{
if (!(flags & VAS_EBOOT_LOADER_FLAG_NORETURN))
return;
VasEBoot_efi_fini ();
if (!(flags & VAS_EBOOT_LOADER_FLAG_EFI_KEEP_ALLOCATED_MEMORY))
VasEBoot_efi_memory_fini ();
}