mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 22:07:35 +00:00
Kernel: Move Prekernel{CPU, Exceptions}.cpp out of Prekernel directory
This lets us delete the Prekernel.h file, and gets us closer to deleting the Prekernel from the aarch64 Kernel.
This commit is contained in:
parent
e7c5fd978b
commit
e88cd338f1
7 changed files with 11 additions and 20 deletions
99
Kernel/Arch/aarch64/Exceptions.cpp
Normal file
99
Kernel/Arch/aarch64/Exceptions.cpp
Normal file
|
@ -0,0 +1,99 @@
|
|||
/*
|
||||
* Copyright (c) 2021, James Mintram <me@jamesrm.com>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <Kernel/Arch/aarch64/ASM_wrapper.h>
|
||||
#include <Kernel/Arch/aarch64/CPU.h>
|
||||
#include <Kernel/Arch/aarch64/Registers.h>
|
||||
#include <Kernel/Panic.h>
|
||||
|
||||
using namespace Kernel;
|
||||
|
||||
namespace Prekernel {
|
||||
|
||||
static void drop_to_el2()
|
||||
{
|
||||
Aarch64::SCR_EL3 secure_configuration_register_el3 = {};
|
||||
|
||||
secure_configuration_register_el3.ST = 1; // Don't trap access to Counter-timer Physical Secure registers
|
||||
secure_configuration_register_el3.RW = 1; // Lower level to use Aarch64
|
||||
secure_configuration_register_el3.NS = 1; // Non-secure state
|
||||
secure_configuration_register_el3.HCE = 1; // Enable Hypervisor instructions at all levels
|
||||
|
||||
Aarch64::SCR_EL3::write(secure_configuration_register_el3);
|
||||
|
||||
Aarch64::SPSR_EL3 saved_program_status_register_el3 = {};
|
||||
|
||||
// Mask (disable) all interrupts
|
||||
saved_program_status_register_el3.A = 1;
|
||||
saved_program_status_register_el3.I = 1;
|
||||
saved_program_status_register_el3.F = 1;
|
||||
saved_program_status_register_el3.D = 1;
|
||||
|
||||
// Indicate EL1 as exception origin mode (so we go back there)
|
||||
saved_program_status_register_el3.M = Aarch64::SPSR_EL3::Mode::EL2t;
|
||||
|
||||
// Set the register
|
||||
Aarch64::SPSR_EL3::write(saved_program_status_register_el3);
|
||||
|
||||
// This will jump into os_start() below
|
||||
Aarch64::Asm::enter_el2_from_el3();
|
||||
}
|
||||
|
||||
static void drop_to_el1()
|
||||
{
|
||||
Aarch64::HCR_EL2 hypervisor_configuration_register_el2 = {};
|
||||
hypervisor_configuration_register_el2.RW = 1; // EL1 to use 64-bit mode
|
||||
Aarch64::HCR_EL2::write(hypervisor_configuration_register_el2);
|
||||
|
||||
Aarch64::SPSR_EL2 saved_program_status_register_el2 = {};
|
||||
|
||||
// Mask (disable) all interrupts
|
||||
saved_program_status_register_el2.A = 1;
|
||||
saved_program_status_register_el2.I = 1;
|
||||
saved_program_status_register_el2.F = 1;
|
||||
|
||||
// Indicate EL1 as exception origin mode (so we go back there)
|
||||
saved_program_status_register_el2.M = Aarch64::SPSR_EL2::Mode::EL1t;
|
||||
|
||||
Aarch64::SPSR_EL2::write(saved_program_status_register_el2);
|
||||
Aarch64::Asm::enter_el1_from_el2();
|
||||
}
|
||||
|
||||
static void set_up_el1()
|
||||
{
|
||||
Aarch64::SCTLR_EL1 system_control_register_el1 = Aarch64::SCTLR_EL1::reset_value();
|
||||
|
||||
system_control_register_el1.UCT = 1; // Don't trap access to CTR_EL0
|
||||
system_control_register_el1.nTWE = 1; // Don't trap WFE instructions
|
||||
system_control_register_el1.nTWI = 1; // Don't trap WFI instructions
|
||||
system_control_register_el1.DZE = 1; // Don't trap DC ZVA instructions
|
||||
system_control_register_el1.UMA = 1; // Don't trap access to DAIF (debugging) flags of EFLAGS register
|
||||
system_control_register_el1.SA0 = 1; // Enable stack access alignment check for EL0
|
||||
system_control_register_el1.SA = 1; // Enable stack access alignment check for EL1
|
||||
system_control_register_el1.A = 1; // Enable memory access alignment check
|
||||
|
||||
Aarch64::SCTLR_EL1::write(system_control_register_el1);
|
||||
}
|
||||
|
||||
void drop_to_exception_level_1()
|
||||
{
|
||||
switch (Kernel::Aarch64::Asm::get_current_exception_level()) {
|
||||
case Kernel::Aarch64::Asm::ExceptionLevel::EL3:
|
||||
drop_to_el2();
|
||||
[[fallthrough]];
|
||||
case Kernel::Aarch64::Asm::ExceptionLevel::EL2:
|
||||
drop_to_el1();
|
||||
[[fallthrough]];
|
||||
case Kernel::Aarch64::Asm::ExceptionLevel::EL1:
|
||||
set_up_el1();
|
||||
break;
|
||||
default: {
|
||||
PANIC("CPU booted in unsupported exception mode!");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue