diff options
| author | Lioncash <mathew1800@gmail.com> | 2019-11-26 18:34:30 -0500 | 
|---|---|---|
| committer | Lioncash <mathew1800@gmail.com> | 2019-11-26 21:55:39 -0500 | 
| commit | e7e939104bb167babec7b5f7d5d8390c85f3cbf4 (patch) | |
| tree | 47b61e77bf8e0e6798b58716d38679a285e3604b /src/core/hle/kernel | |
| parent | 50a518be69ef871a674afd91caebdf31cbda4485 (diff) | |
core/memory; Migrate over SetCurrentPageTable() to the Memory class
Now that literally every other API function is converted over to the
Memory class, we can just move the file-local page table into the Memory
implementation class, finally getting rid of global state within the
memory code.
Diffstat (limited to 'src/core/hle/kernel')
| -rw-r--r-- | src/core/hle/kernel/kernel.cpp | 18 | 
1 files changed, 11 insertions, 7 deletions
| diff --git a/src/core/hle/kernel/kernel.cpp b/src/core/hle/kernel/kernel.cpp index a9851113a..1c90546a4 100644 --- a/src/core/hle/kernel/kernel.cpp +++ b/src/core/hle/kernel/kernel.cpp @@ -154,6 +154,16 @@ struct KernelCore::Impl {          system.CoreTiming().ScheduleEvent(time_interval, preemption_event);      } +    void MakeCurrentProcess(Process* process) { +        current_process = process; + +        if (process == nullptr) { +            return; +        } + +        system.Memory().SetCurrentPageTable(*process); +    } +      std::atomic<u32> next_object_id{0};      std::atomic<u64> next_kernel_process_id{Process::InitialKIPIDMin};      std::atomic<u64> next_user_process_id{Process::ProcessIDMin}; @@ -208,13 +218,7 @@ void KernelCore::AppendNewProcess(std::shared_ptr<Process> process) {  }  void KernelCore::MakeCurrentProcess(Process* process) { -    impl->current_process = process; - -    if (process == nullptr) { -        return; -    } - -    Memory::SetCurrentPageTable(*process); +    impl->MakeCurrentProcess(process);  }  Process* KernelCore::CurrentProcess() { | 
