Write KEvent::Initialize, fix build issues

This commit is contained in:
TuxSH 2018-11-05 13:57:50 +01:00 committed by Michael Scire
parent a4419dfc41
commit 698fa9fcb0
12 changed files with 100 additions and 58 deletions

View file

@ -21,12 +21,12 @@ class IClient {
ParentType *GetParent() const { return parent; } ParentType *GetParent() const { return parent; }
protected:
void SetParent(SharedPtr<Parent> parent) void SetParent(SharedPtr<Parent> parent)
{ {
this->parent = std::move(parent); this->parent = std::move(parent);
} }
protected:
SharedPtr<Parent> parent{}; SharedPtr<Parent> parent{};
}; };

View file

@ -12,14 +12,15 @@ class IClientServerParent {
using ClientType = Client; using ClientType = Client;
using ServerType = Server; using ServerType = Server;
protected:
void SetClientServerParent() void SetClientServerParent()
{ {
Parent par = (Parent *)this; Parent *par = (Parent *)this;
client.SetParent(par); client.SetParent(par);
server.SetParent(par); server.SetParentAndClient(par, &client);
} }
protected:
ClientType client{}; ClientType client{};
ServerType server{}; ServerType server{};
}; };

View file

@ -21,13 +21,14 @@ class IServer {
ParentType *GetParent() const { return parent; } ParentType *GetParent() const { return parent; }
protected: void SetParentAndClient(SharedPtr<Parent> parent, SharedPtr<Client> client)
void SetParent(SharedPtr<Parent> parent)
{ {
this->parent = std::move(parent); this->parent = std::move(parent);
this->client = &this->parent->client; this->client = std::move(client);
} }
protected:
SharedPtr<Parent> parent{}; SharedPtr<Parent> parent{};
SharedPtr<Client> client{}; SharedPtr<Client> client{};
}; };

View file

@ -6,6 +6,7 @@ class KProcess;
#include <mesosphere/core/Result.hpp> #include <mesosphere/core/Result.hpp>
#include <mesosphere/core/KAutoObject.hpp> #include <mesosphere/core/KAutoObject.hpp>
#include <mesosphere/interfaces/ISetAllocated.hpp> #include <mesosphere/interfaces/ISetAllocated.hpp>
#include <mesosphere/interfaces/ILimitedResource.hpp>
#include <mesosphere/interfaces/IClientServerParent.hpp> #include <mesosphere/interfaces/IClientServerParent.hpp>
#include <mesosphere/processes/KReadableEvent.hpp> #include <mesosphere/processes/KReadableEvent.hpp>
#include <mesosphere/processes/KWritableEvent.hpp> #include <mesosphere/processes/KWritableEvent.hpp>
@ -13,26 +14,27 @@ class KProcess;
namespace mesosphere namespace mesosphere
{ {
class KEvent final : public KAutoObject, IClientServerParent<KEvent, KReadableEvent, KWritableEvent> { class KEvent final :
public KAutoObject,
public IClientServerParent<KEvent, KReadableEvent, KWritableEvent>,
public ISetAllocated<KEvent>,
public ILimitedResource<KEvent> {
public: public:
MESOSPHERE_AUTO_OBJECT_TRAITS(AutoObject, Event); MESOSPHERE_AUTO_OBJECT_TRAITS(AutoObject, Event);
explicit KEvent() : owner(nullptr), is_initialized(false) {} virtual ~KEvent();
virtual ~KEvent() {}
KProcess *GetOwner() const { return this->owner; } Result Initialize();
void Initialize();
/* KAutoObject */ /* KAutoObject */
virtual bool IsAlive() const override { return is_initialized; } virtual bool IsAlive() const override;
/* IClientServerParent */ /* IClientServerParent */
void HandleServerDestroyed() { } void HandleServerDestroyed() { }
void HandleClientDestroyed() { } void HandleClientDestroyed() { }
private: private:
KProcess *owner; bool isInitialized = false;
bool is_initialized;
}; };
inline void intrusive_ptr_add_ref(KEvent *obj) inline void intrusive_ptr_add_ref(KEvent *obj)

View file

@ -19,8 +19,7 @@ class KReadableEvent final : public KSynchronizationObject, public IClient<KEven
virtual bool IsAlive() const override { return true; } virtual bool IsAlive() const override { return true; }
explicit KReadableEvent() {} virtual ~KReadableEvent();
virtual ~KReadableEvent() {}
Result Signal(); Result Signal();
Result Clear(); Result Clear();
@ -29,7 +28,7 @@ class KReadableEvent final : public KSynchronizationObject, public IClient<KEven
virtual bool IsSignaled() const override; virtual bool IsSignaled() const override;
private: private:
bool is_signaled = false; bool isSignaled = false;
}; };
inline void intrusive_ptr_add_ref(KReadableEvent *obj) inline void intrusive_ptr_add_ref(KReadableEvent *obj)

View file

@ -18,8 +18,7 @@ class KWritableEvent final : public KAutoObject, public IServer<KEvent, KReadabl
virtual bool IsAlive() const override { return true; } virtual bool IsAlive() const override { return true; }
explicit KWritableEvent() {} virtual ~KWritableEvent();
virtual ~KWritableEvent() {}
Result Signal(); Result Signal();
Result Clear(); Result Clear();

View file

@ -15,7 +15,7 @@ KSynchronizationObject::~KSynchronizationObject()
void KSynchronizationObject::NotifyWaiters() void KSynchronizationObject::NotifyWaiters()
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
if (IsSignaled()) { if (IsSignaled()) {
for (auto &&waiter : waiters) { for (auto &&waiter : waiters) {

View file

@ -6,35 +6,43 @@
namespace mesosphere namespace mesosphere
{ {
bool KReadableEvent::IsSignaled() const { bool KReadableEvent::IsSignaled() const
return this->is_signaled; {
return this->isSignaled;
} }
Result KReadableEvent::Signal() { KReadableEvent::~KReadableEvent()
KScopedCriticalSection critical_section; {
if (!this->is_signaled) {
this->is_signaled = true;
this->NotifyWaiters();
} }
return ResultSuccess(); Result KReadableEvent::Signal()
{
KScopedCriticalSection criticalSection{};
if (!this->isSignaled) {
this->isSignaled = true;
NotifyWaiters();
} }
Result KReadableEvent::Clear() { return ResultSuccess{};
this->Reset();
return ResultSuccess();
} }
Result KReadableEvent::Reset() { Result KReadableEvent::Clear()
KScopedCriticalSection critical_section; {
Reset();
if (this->is_signaled) { return ResultSuccess{};
this->is_signaled = false;
return ResultSuccess();
} }
return ResultKernelInvalidState();
Result KReadableEvent::Reset()
{
KScopedCriticalSection criticalSection{};
if (this->isSignaled) {
this->isSignaled = false;
return ResultSuccess{};
}
return ResultKernelInvalidState{};
} }
} }

View file

@ -5,12 +5,18 @@
namespace mesosphere namespace mesosphere
{ {
Result KWritableEvent::Signal() { KWritableEvent::~KWritableEvent()
return this->client->Signal(); {
} }
Result KWritableEvent::Clear() { Result KWritableEvent::Signal()
return this->client->Clear(); {
return client->Signal();
}
Result KWritableEvent::Clear()
{
return client->Clear();
} }
} }

View file

@ -0,0 +1,26 @@
#include <mesosphere/processes/KEvent.hpp>
#include <mesosphere/core/KCoreContext.hpp>
#include <mesosphere/processes/KProcess.hpp>
namespace mesosphere
{
KEvent::~KEvent()
{
}
bool KEvent::IsAlive() const
{
return isInitialized;
}
Result KEvent::Initialize()
{
SetClientServerParent();
SetResourceOwner(KCoreContext::GetCurrentInstance().GetCurrentProcess());
isInitialized = true;
return ResultSuccess{};
}
}

View file

@ -36,7 +36,7 @@ void KMutex::lock_slow_path(KThread &owner, KThread &requester)
void KMutex::unlock_slow_path(KThread &owner) void KMutex::unlock_slow_path(KThread &owner)
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
size_t count; size_t count;
KThread *newOwner = owner.RelinquishMutex(&count, (uiptr)this); KThread *newOwner = owner.RelinquishMutex(&count, (uiptr)this);
native_handle_type newTag; native_handle_type newTag;

View file

@ -46,7 +46,7 @@ void KThread::RescheduleIfStatusEquals(SchedulingStatus expectedStatus, Scheduli
void KThread::AddForcePauseReason(KThread::ForcePauseReason reason) void KThread::AddForcePauseReason(KThread::ForcePauseReason reason)
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
if (!IsDying()) { if (!IsDying()) {
AddForcePauseReasonToField(reason); AddForcePauseReasonToField(reason);
@ -58,7 +58,7 @@ void KThread::AddForcePauseReason(KThread::ForcePauseReason reason)
void KThread::RemoveForcePauseReason(KThread::ForcePauseReason reason) void KThread::RemoveForcePauseReason(KThread::ForcePauseReason reason)
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
if (!IsDying()) { if (!IsDying()) {
RemoveForcePauseReasonToField(reason); RemoveForcePauseReasonToField(reason);
@ -104,7 +104,7 @@ void KThread::ResumeAllFromKernelSync(KThread::WaitList &waitList)
void KThread::CancelKernelSync() void KThread::CancelKernelSync()
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
if (GetSchedulingStatus() == SchedulingStatus::Paused) { if (GetSchedulingStatus() == SchedulingStatus::Paused) {
// Note: transparent to force-pause // Note: transparent to force-pause
if (currentWaitList != nullptr) { if (currentWaitList != nullptr) {
@ -136,7 +136,7 @@ Result KThread::WaitSynchronizationImpl(int &outId, KSynchronizationObject **syn
outId = -1; outId = -1;
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
// Try to find an already signaled object. // Try to find an already signaled object.
if (numSyncObjs >= 1) { if (numSyncObjs >= 1) {
@ -178,7 +178,7 @@ Result KThread::WaitSynchronizationImpl(int &outId, KSynchronizationObject **syn
// Now waiting... // Now waiting...
{ {
KScopedCriticalSection critical_section; KScopedCriticalSection criticalSection;
isWaitingSync = false; isWaitingSync = false;
if (timeoutTime > KSystemClock::time_point{}) { if (timeoutTime > KSystemClock::time_point{}) {