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; }
protected:
void SetParent(SharedPtr<Parent> parent)
{
this->parent = std::move(parent);
}
protected:
SharedPtr<Parent> parent{};
};

View file

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

View file

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

View file

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

View file

@ -16,20 +16,19 @@ class KEvent;
class KReadableEvent final : public KSynchronizationObject, public IClient<KEvent, KReadableEvent, KWritableEvent> {
public:
MESOSPHERE_AUTO_OBJECT_TRAITS(SynchronizationObject, ReadableEvent);
virtual bool IsAlive() const override { return true; }
explicit KReadableEvent() {}
virtual ~KReadableEvent() {}
virtual ~KReadableEvent();
Result Signal();
Result Clear();
Result Reset();
virtual bool IsSignaled() const override;
private:
bool is_signaled = false;
bool isSignaled = false;
};
inline void intrusive_ptr_add_ref(KReadableEvent *obj)

View file

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

View file

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

View file

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

View file

@ -5,12 +5,18 @@
namespace mesosphere
{
Result KWritableEvent::Signal() {
return this->client->Signal();
KWritableEvent::~KWritableEvent()
{
}
Result KWritableEvent::Clear() {
return this->client->Clear();
Result KWritableEvent::Signal()
{
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)
{
KScopedCriticalSection critical_section;
KScopedCriticalSection criticalSection;
size_t count;
KThread *newOwner = owner.RelinquishMutex(&count, (uiptr)this);
native_handle_type newTag;

View file

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