mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 20:27:45 +00:00
Kernel: Print current CPU exception level after booting on Aarch64
This is a first step to switch to exception level 1. This is also my first patch for SerenityOS :)
This commit is contained in:
parent
7beccaf41b
commit
18eb4a59d6
4 changed files with 29 additions and 0 deletions
12
Kernel/Prekernel/Arch/aarch64/Aarch64_asm_utils.S
Normal file
12
Kernel/Prekernel/Arch/aarch64/Aarch64_asm_utils.S
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2021, Marcin Undak <mcinek@gmail.com>
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*/
|
||||||
|
|
||||||
|
.global get_current_exception_level
|
||||||
|
get_current_exception_level:
|
||||||
|
mrs x0, CurrentEL
|
||||||
|
lsr x0, x0, #2
|
||||||
|
and x0, x0, #0x3
|
||||||
|
ret
|
9
Kernel/Prekernel/Arch/aarch64/Aarch64_asm_utils.h
Normal file
9
Kernel/Prekernel/Arch/aarch64/Aarch64_asm_utils.h
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2021, Marcin Undak <mcinek@gmail.com>
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
extern "C" uint8_t get_current_exception_level();
|
|
@ -1,10 +1,12 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2021, Nico Weber <thakis@chromium.org>
|
* Copyright (c) 2021, Nico Weber <thakis@chromium.org>
|
||||||
|
* Copyright (c) 2021, Marcin Undak <mcinek@gmail.com>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <AK/Types.h>
|
#include <AK/Types.h>
|
||||||
|
#include <Kernel/Prekernel/Arch/aarch64/Aarch64_asm_utils.h>
|
||||||
#include <Kernel/Prekernel/Arch/aarch64/Mailbox.h>
|
#include <Kernel/Prekernel/Arch/aarch64/Mailbox.h>
|
||||||
#include <Kernel/Prekernel/Arch/aarch64/Timer.h>
|
#include <Kernel/Prekernel/Arch/aarch64/Timer.h>
|
||||||
#include <Kernel/Prekernel/Arch/aarch64/UART.h>
|
#include <Kernel/Prekernel/Arch/aarch64/UART.h>
|
||||||
|
@ -25,6 +27,11 @@ extern "C" [[noreturn]] void init()
|
||||||
uart.print_num(firmware_version);
|
uart.print_num(firmware_version);
|
||||||
uart.print_str("\r\n");
|
uart.print_str("\r\n");
|
||||||
|
|
||||||
|
auto exception_level = get_current_exception_level();
|
||||||
|
uart.print_str("Current CPU exception level: EL");
|
||||||
|
uart.print_num(exception_level);
|
||||||
|
uart.print_str("\r\n");
|
||||||
|
|
||||||
auto& timer = Prekernel::Timer::the();
|
auto& timer = Prekernel::Timer::the();
|
||||||
u64 start_musec = 0;
|
u64 start_musec = 0;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
|
|
@ -11,6 +11,7 @@ if ("${SERENITY_ARCH}" STREQUAL "aarch64")
|
||||||
Arch/aarch64/MMIO.cpp
|
Arch/aarch64/MMIO.cpp
|
||||||
Arch/aarch64/Timer.cpp
|
Arch/aarch64/Timer.cpp
|
||||||
Arch/aarch64/UART.cpp
|
Arch/aarch64/UART.cpp
|
||||||
|
Arch/aarch64/Aarch64_asm_utils.S
|
||||||
Arch/aarch64/boot.S
|
Arch/aarch64/boot.S
|
||||||
Arch/aarch64/init.cpp
|
Arch/aarch64/init.cpp
|
||||||
)
|
)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue