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

81 lines
2.2 KiB
C

/* init.c - initialize an ia64-based EFI system */
/*
* VAS_EBOOT -- GRand Unified Bootloader
* Copyright (C) 2008 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/types.h>
#include <VasEBoot/misc.h>
#include <VasEBoot/mm.h>
#include <VasEBoot/time.h>
#include <VasEBoot/err.h>
#include <VasEBoot/dl.h>
#include <VasEBoot/kernel.h>
#include <VasEBoot/efi/efi.h>
#include <VasEBoot/loader.h>
static VasEBoot_uint64_t divisor = 1;
static VasEBoot_uint64_t
get_itc (void)
{
VasEBoot_uint64_t ret;
asm volatile ("mov %0=ar.itc" : "=r" (ret));
return ret;
}
VasEBoot_uint64_t
VasEBoot_rtc_get_time_ms (void)
{
return get_itc () / divisor;
}
void
VasEBoot_machine_init (void)
{
VasEBoot_efi_event_t event;
VasEBoot_uint64_t before, after;
VasEBoot_efi_uintn_t idx;
VasEBoot_efi_init ();
VasEBoot_efi_system_table->boot_services->create_event (VAS_EBOOT_EFI_EVT_TIMER,
VAS_EBOOT_EFI_TPL_CALLBACK,
0, 0, &event);
before = get_itc ();
VasEBoot_efi_system_table->boot_services->set_timer (event, VAS_EBOOT_EFI_TIMER_RELATIVE,
200000);
VasEBoot_efi_system_table->boot_services->wait_for_event (1, &event, &idx);
after = get_itc ();
VasEBoot_efi_system_table->boot_services->close_event (event);
divisor = (after - before + 5) / 20;
if (divisor == 0)
divisor = 800000;
VasEBoot_install_get_time_ms (VasEBoot_rtc_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 ();
}