mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-22 17:31:58 -05:00
e7b8eed005
This makes Processor::capture_stack_trace() work on all our architectures. For this function to work on AArch64 and RISC-V, the frame pointer has to be saved during context switches. AArch64 and RISC-V don't support SMP yet, so the code for getting a backtrace for processes running on other cores is guarded behind a '#if ARCH(X86_64)'.
34 lines
1.8 KiB
Text
34 lines
1.8 KiB
Text
/*
|
|
* Copyright (c) 2023, kleines Filmröllchen <filmroellchen@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <Kernel/Arch/Processor.h>
|
|
|
|
// This header instantiates all functions of ProcessorBase that are architecture-specific.
|
|
namespace Kernel {
|
|
template bool ProcessorBase<Processor>::is_smp_enabled();
|
|
template void ProcessorBase<Processor>::idle_begin() const;
|
|
template void ProcessorBase<Processor>::idle_end() const;
|
|
template void ProcessorBase<Processor>::smp_enable();
|
|
template void ProcessorBase<Processor>::flush_tlb_local(VirtualAddress vaddr, size_t page_count);
|
|
template void ProcessorBase<Processor>::flush_entire_tlb_local();
|
|
template void ProcessorBase<Processor>::flush_tlb(Memory::PageDirectory const*, VirtualAddress, size_t);
|
|
template void ProcessorBase<Processor>::early_initialize(u32 cpu);
|
|
template void ProcessorBase<Processor>::initialize(u32 cpu);
|
|
template void ProcessorBase<Processor>::halt();
|
|
template void ProcessorBase<Processor>::exit_trap(TrapFrame& trap);
|
|
template u32 ProcessorBase<Processor>::clear_critical();
|
|
template bool ProcessorBase<Processor>::are_interrupts_enabled();
|
|
template void ProcessorBase<Processor>::wait_for_interrupt() const;
|
|
template Processor& ProcessorBase<Processor>::by_id(u32 id);
|
|
template StringView ProcessorBase<Processor>::platform_string();
|
|
template void ProcessorBase<Processor>::initialize_context_switching(Thread& initial_thread);
|
|
template void ProcessorBase<Processor>::switch_context(Thread*& from_thread, Thread*& to_thread);
|
|
template void ProcessorBase<Processor>::assume_context(Thread& thread, InterruptsState new_interrupts_state);
|
|
template FlatPtr ProcessorBase<Processor>::init_context(Thread& thread, bool leave_crit);
|
|
template u32 ProcessorBase<Processor>::smp_wake_n_idle_processors(u32 wake_count);
|
|
}
|