mirror of
https://github.com/Atmosphere-NX/Atmosphere.git
synced 2025-01-10 03:16:29 +00:00
Implement KSynchronizationObject
This commit is contained in:
parent
1684e1d35c
commit
7fde5fbe40
6 changed files with 82 additions and 3 deletions
|
@ -6,7 +6,7 @@
|
||||||
#include <initializer_list>
|
#include <initializer_list>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <mesosphere/core/util.h>
|
#include <mesosphere/core/util.hpp>
|
||||||
#include <mesosphere/interfaces/ISlabAllocated.hpp>
|
#include <mesosphere/interfaces/ISlabAllocated.hpp>
|
||||||
|
|
||||||
namespace mesosphere
|
namespace mesosphere
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <mesosphere/core/KAutoObject.hpp>
|
||||||
|
#include <mesosphere/core/KLinkedList.hpp>
|
||||||
|
|
||||||
|
namespace mesosphere
|
||||||
|
{
|
||||||
|
|
||||||
|
class KSynchronizationObject : public KAutoObject {
|
||||||
|
public:
|
||||||
|
|
||||||
|
MESOSPHERE_AUTO_OBJECT_TRAITS(AutoObject, SynchronizationObject);
|
||||||
|
|
||||||
|
virtual ~KSynchronizationObject();
|
||||||
|
virtual bool IsSignaled() const = 0;
|
||||||
|
|
||||||
|
void Signal(); // Note: Signal() with !IsSignaled() is no-op
|
||||||
|
|
||||||
|
KLinkedList<KThread *>::const_iterator AddWaiter(KThread &thread);
|
||||||
|
void RemoveWaiter(KLinkedList<KThread *>::const_iterator it);
|
||||||
|
|
||||||
|
private:
|
||||||
|
KLinkedList<KThread *> waiters{};
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
|
@ -3,6 +3,7 @@
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <climits>
|
#include <climits>
|
||||||
|
#include <chrono>
|
||||||
#include <boost/smart_ptr/intrusive_ptr.hpp>
|
#include <boost/smart_ptr/intrusive_ptr.hpp>
|
||||||
|
|
||||||
#define MAX_CORES 4
|
#define MAX_CORES 4
|
||||||
|
@ -10,6 +11,8 @@
|
||||||
namespace mesosphere
|
namespace mesosphere
|
||||||
{
|
{
|
||||||
|
|
||||||
|
using namespace std::chrono_literals;
|
||||||
|
|
||||||
using ushort = unsigned short;
|
using ushort = unsigned short;
|
||||||
using uint = unsigned int;
|
using uint = unsigned int;
|
||||||
using ulong = unsigned long;
|
using ulong = unsigned long;
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <mesosphere/core/util.hpp>
|
#include <mesosphere/core/util.hpp>
|
||||||
#include <mesosphere/core/Handle.hpp>
|
#include <mesosphere/core/Handle.hpp>
|
||||||
#include <mesosphere/core/Result.hpp>
|
#include <mesosphere/core/Result.hpp>
|
||||||
|
#include <mesosphere/core/KSynchronizationObject.hpp>
|
||||||
#include <mesosphere/processes/KProcess.hpp>
|
#include <mesosphere/processes/KProcess.hpp>
|
||||||
#include <mesosphere/interfaces/IAlarmable.hpp>
|
#include <mesosphere/interfaces/IAlarmable.hpp>
|
||||||
#include <mesosphere/interfaces/ILimitedResource.hpp>
|
#include <mesosphere/interfaces/ILimitedResource.hpp>
|
||||||
|
@ -206,6 +207,9 @@ class KThread final :
|
||||||
/// Takes effect immediately
|
/// Takes effect immediately
|
||||||
void CancelKernelSync(Result res);
|
void CancelKernelSync(Result res);
|
||||||
|
|
||||||
|
/// Takes effect when critical section is left
|
||||||
|
void HandleSyncObjectSignaled(KSynchronizationObject *syncObj);
|
||||||
|
|
||||||
constexpr size_t GetNumberOfKMutexWaiters() const { return numKernelMutexWaiters; }
|
constexpr size_t GetNumberOfKMutexWaiters() const { return numKernelMutexWaiters; }
|
||||||
constexpr uiptr GetWantedMutex() const { return wantedMutex; }
|
constexpr uiptr GetWantedMutex() const { return wantedMutex; }
|
||||||
void SetWantedMutex(uiptr mtx) { wantedMutex = mtx; }
|
void SetWantedMutex(uiptr mtx) { wantedMutex = mtx; }
|
||||||
|
@ -244,8 +248,8 @@ private:
|
||||||
MutexWaitList mutexWaitList{};
|
MutexWaitList mutexWaitList{};
|
||||||
size_t numKernelMutexWaiters = 0;
|
size_t numKernelMutexWaiters = 0;
|
||||||
|
|
||||||
Handle syncResultHandle{};
|
KSynchronizationObject *signaledSyncObject = nullptr;
|
||||||
Result syncResult = ResultSuccess();
|
Result syncResult = ResultSuccess{};
|
||||||
|
|
||||||
u64 lastScheduledTime = 0;
|
u64 lastScheduledTime = 0;
|
||||||
};
|
};
|
||||||
|
|
37
mesosphere/source/core/KSynchronizationObject.cpp
Normal file
37
mesosphere/source/core/KSynchronizationObject.cpp
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
#include <mesosphere/core/KSynchronizationObject.hpp>
|
||||||
|
#include <mesosphere/core/Result.hpp>
|
||||||
|
#include <mesosphere/core/KCoreContext.hpp>
|
||||||
|
#include <mesosphere/threading/KScheduler.hpp>
|
||||||
|
#include <mesosphere/threading/KThread.hpp>
|
||||||
|
|
||||||
|
#include <mutex>
|
||||||
|
|
||||||
|
namespace mesosphere
|
||||||
|
{
|
||||||
|
|
||||||
|
KSynchronizationObject::~KSynchronizationObject()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void KSynchronizationObject::Signal()
|
||||||
|
{
|
||||||
|
std::lock_guard criticalSection{KScheduler::GetCriticalSection()};
|
||||||
|
|
||||||
|
if (IsSignaled()) {
|
||||||
|
for (auto &&waiter : waiters) {
|
||||||
|
waiter->HandleSyncObjectSignaled(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
KLinkedList<KThread *>::const_iterator KSynchronizationObject::AddWaiter(KThread &thread)
|
||||||
|
{
|
||||||
|
return waiters.insert(waiters.end(), &thread);
|
||||||
|
}
|
||||||
|
|
||||||
|
void KSynchronizationObject::RemoveWaiter(KLinkedList<KThread *>::const_iterator it)
|
||||||
|
{
|
||||||
|
waiters.erase(it);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -120,6 +120,15 @@ void KThread::CancelKernelSync(Result res)
|
||||||
CancelKernelSync();
|
CancelKernelSync();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void KThread::HandleSyncObjectSignaled(KSynchronizationObject *syncObj)
|
||||||
|
{
|
||||||
|
if (GetSchedulingStatus() == SchedulingStatus::Paused) {
|
||||||
|
signaledSyncObject = syncObj;
|
||||||
|
syncResult = ResultSuccess{};
|
||||||
|
Reschedule(SchedulingStatus::Running);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void KThread::AddToMutexWaitList(KThread &thread)
|
void KThread::AddToMutexWaitList(KThread &thread)
|
||||||
{
|
{
|
||||||
// TODO: check&increment numKernelMutexWaiters
|
// TODO: check&increment numKernelMutexWaiters
|
||||||
|
|
Loading…
Reference in a new issue