citra-emu
/
citra
Archived
1
0
Fork 0

Session: Change to a WaitObject.

This commit is contained in:
bunnei 2015-01-18 20:40:53 -05:00
parent d2759c578e
commit 9e6ec3b6cd
3 changed files with 9 additions and 2 deletions

View File

@ -39,7 +39,7 @@ Thread* WaitObject::ReleaseNextThread() {
next_thread->ReleaseWaitObject(this);
return next_thread.get();
return next_thread;
}
void WaitObject::WakeupAllWaitingThreads() {

View File

@ -71,6 +71,7 @@ public:
*/
bool IsWaitable() const {
switch (GetHandleType()) {
case HandleType::Session:
case HandleType::Event:
case HandleType::Mutex:
case HandleType::Thread:

View File

@ -41,7 +41,7 @@ inline static u32* GetCommandBuffer(const int offset=0) {
* CTR-OS so that IPC calls can be optionally handled by the real implementations of processes, as
* opposed to HLE simulations.
*/
class Session : public Object {
class Session : public WaitObject {
public:
std::string GetTypeName() const override { return "Session"; }
@ -53,6 +53,12 @@ public:
* aren't supported yet.
*/
virtual ResultVal<bool> SyncRequest() = 0;
ResultVal<bool> Wait() override {
// TODO(bunnei): This function exists to satisfy a hardware test with a Session object
// passed into WaitSynchronization. Not sure if it's possible for this to ever be false?
return MakeResult<bool>(true);
}
};
}