mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-08 21:47:57 +00:00
Add KInterruptBottomHalfGuard
This commit is contained in:
parent
40b860c239
commit
7b726c3184
7 changed files with 47 additions and 11 deletions
|
@ -0,0 +1,32 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <mesosphere/core/KCoreContext.hpp>
|
||||||
|
|
||||||
|
namespace mesosphere
|
||||||
|
{
|
||||||
|
|
||||||
|
class KThread;
|
||||||
|
inline void IncrementThreadInterruptBottomHalfLockCount(KThread &thread);
|
||||||
|
inline void DecrementThreadInterruptBottomHalfLockCount(KThread &thread);
|
||||||
|
|
||||||
|
class KInterruptBottomHalfGuard final {
|
||||||
|
public:
|
||||||
|
KInterruptBottomHalfGuard()
|
||||||
|
{
|
||||||
|
KThread *curThread = KCoreContext::GetCurrentInstance().GetCurrentThread();
|
||||||
|
IncrementInterruptBottomHalfLockCount(*curThread);
|
||||||
|
}
|
||||||
|
|
||||||
|
~KInterruptBottomHalfGuard()
|
||||||
|
{
|
||||||
|
KThread *curThread = KCoreContext::GetCurrentInstance().GetCurrentThread();
|
||||||
|
DecrementInterruptBottomHalfLockCount(*curThread);
|
||||||
|
}
|
||||||
|
|
||||||
|
KInterruptBottomHalfGuard(const KInterruptBottomHalfGuard &) = delete;
|
||||||
|
KInterruptBottomHalfGuard(KInterruptBottomHalfGuard &&) = delete;
|
||||||
|
KInterruptBottomHalfGuard &operator=(const KInterruptBottomHalfGuard &) = delete;
|
||||||
|
KInterruptBottomHalfGuard &operator=(KInterruptBottomHalfGuard &&) = delete;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
|
@ -33,7 +33,7 @@ class KThread final :
|
||||||
MESOSPHERE_AUTO_OBJECT_TRAITS(AutoObject, Thread);
|
MESOSPHERE_AUTO_OBJECT_TRAITS(AutoObject, Thread);
|
||||||
MESOSPHERE_LIMITED_RESOURCE_TRAITS(100ms);
|
MESOSPHERE_LIMITED_RESOURCE_TRAITS(100ms);
|
||||||
|
|
||||||
class StackParameters {
|
class StackParameters final {
|
||||||
public:
|
public:
|
||||||
StackParameters(std::array<u64, 4> svcPermissionMask, KThreadContext *threadCtx) :
|
StackParameters(std::array<u64, 4> svcPermissionMask, KThreadContext *threadCtx) :
|
||||||
svcPermissionMask{svcPermissionMask}, threadCtx{threadCtx} {}
|
svcPermissionMask{svcPermissionMask}, threadCtx{threadCtx} {}
|
||||||
|
@ -46,19 +46,19 @@ class KThread final :
|
||||||
constexpr bool IsExecutingSvc() const { return isExecutingSvc; }
|
constexpr bool IsExecutingSvc() const { return isExecutingSvc; }
|
||||||
constexpr u8 GetCurrentSvcId() const { return currentSvcId; }
|
constexpr u8 GetCurrentSvcId() const { return currentSvcId; }
|
||||||
|
|
||||||
constexpr uint GetBottomHalfLockCount() const { return bottomHalfLockCount; }
|
constexpr uint GetInterruptBottomHalfLockCount() const { return interruptBottomHalfLockCount; }
|
||||||
void IncrementBottomHalfLockCount() { ++bottomHalfLockCount; }
|
void IncrementInterruptBottomHalfLockCount() { ++interruptBottomHalfLockCount; }
|
||||||
void DecrementBottomHalfLockCount() { --bottomHalfLockCount; }
|
void DecrementInterruptBottomHalfLockCount() { --interruptBottomHalfLockCount; }
|
||||||
|
|
||||||
KThreadContext *GetThreadContext() const { return threadCtx; }
|
KThreadContext *GetThreadContext() const { return threadCtx; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::array<u64, 4> svcPermissionMask[256/64]{};
|
std::array<u64, 4> svcPermissionMask[256/64]{};
|
||||||
u8 stateFlags = 0;
|
u8 stateFlags = 0;
|
||||||
u8 currentSvcId = 0;
|
u8 currentSvcId = 0;
|
||||||
bool isExecutingSvc = false;
|
bool isExecutingSvc = false;
|
||||||
bool isNotStarted = true;
|
bool isNotStarted = true;
|
||||||
uint bottomHalfLockCount = 1;
|
uint interruptBottomHalfLockCount = 1;
|
||||||
KThreadContext *threadCtx = nullptr;
|
KThreadContext *threadCtx = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -265,6 +265,15 @@ class KThread final :
|
||||||
KThread(KProcess *owner, u64 id, uint priority) : KAutoObject(), owner(owner), schedulerNodes(),
|
KThread(KProcess *owner, u64 id, uint priority) : KAutoObject(), owner(owner), schedulerNodes(),
|
||||||
id(id), basePriority(priority), priority(priority),
|
id(id), basePriority(priority), priority(priority),
|
||||||
currentCoreId(0), affinityMask(15) {};
|
currentCoreId(0), affinityMask(15) {};
|
||||||
|
|
||||||
|
friend void IncrementThreadInterruptBottomHalfLockCount(KThread &thread)
|
||||||
|
{
|
||||||
|
thread.GetStackParameters().IncrementInterruptBottomHalfLockCount();
|
||||||
|
}
|
||||||
|
friend void DecrementThreadInterruptBottomHalfLockCount(KThread &thread)
|
||||||
|
{
|
||||||
|
thread.GetStackParameters().DecrementInterruptBottomHalfLockCount();
|
||||||
|
}
|
||||||
private:
|
private:
|
||||||
Result WaitSynchronizationImpl(int &outId, KSynchronizationObject **syncObjs, int numSyncObjs, const KSystemClock::time_point &timeoutTime);
|
Result WaitSynchronizationImpl(int &outId, KSynchronizationObject **syncObjs, int numSyncObjs, const KSystemClock::time_point &timeoutTime);
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
#include <mesosphere/core/KSynchronizationObject.hpp>
|
#include <mesosphere/core/KSynchronizationObject.hpp>
|
||||||
#include <mesosphere/core/Result.hpp>
|
#include <mesosphere/core/Result.hpp>
|
||||||
#include <mesosphere/core/KCoreContext.hpp>
|
|
||||||
#include <mesosphere/threading/KScheduler.hpp>
|
#include <mesosphere/threading/KScheduler.hpp>
|
||||||
#include <mesosphere/threading/KThread.hpp>
|
#include <mesosphere/threading/KThread.hpp>
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
#include <mesosphere/interrupts/KAlarm.hpp>
|
#include <mesosphere/interrupts/KAlarm.hpp>
|
||||||
#include <mesosphere/core/KCoreContext.hpp>
|
|
||||||
#include <mesosphere/threading/KScheduler.hpp>
|
#include <mesosphere/threading/KScheduler.hpp>
|
||||||
#include <mesosphere/arch/KInterruptMaskGuard.hpp>
|
#include <mesosphere/arch/KInterruptMaskGuard.hpp>
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
#include <mesosphere/processes/KEvent.hpp>
|
#include <mesosphere/processes/KEvent.hpp>
|
||||||
#include <mesosphere/core/KCoreContext.hpp>
|
|
||||||
#include <mesosphere/processes/KProcess.hpp>
|
#include <mesosphere/processes/KProcess.hpp>
|
||||||
|
|
||||||
namespace mesosphere
|
namespace mesosphere
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <mesosphere/processes/KHandleTable.hpp>
|
#include <mesosphere/processes/KHandleTable.hpp>
|
||||||
#include <mesosphere/core/KCoreContext.hpp>
|
|
||||||
#include <mesosphere/threading/KThread.hpp>
|
#include <mesosphere/threading/KThread.hpp>
|
||||||
|
|
||||||
namespace mesosphere
|
namespace mesosphere
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
|
|
||||||
#include <mesosphere/threading/KThread.hpp>
|
#include <mesosphere/threading/KThread.hpp>
|
||||||
#include <mesosphere/threading/KScheduler.hpp>
|
#include <mesosphere/threading/KScheduler.hpp>
|
||||||
#include <mesosphere/core/KCoreContext.hpp>
|
|
||||||
|
|
||||||
namespace mesosphere
|
namespace mesosphere
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue