diff options
author | Lioncash <mathew1800@gmail.com> | 2018-12-03 22:50:16 -0500 |
---|---|---|
committer | Lioncash <mathew1800@gmail.com> | 2018-12-04 02:20:47 -0500 |
commit | 5eb057f422ac316cd1b943f6cd00aabc673dc238 (patch) | |
tree | 837d0d14341f50cda47b73d5128104980eb1afbc /src/core/hle/kernel/object.cpp | |
parent | adc4d332fc1a4054b80cfd575025351b970da689 (diff) |
kernel/object: Amend handle types to distinguish between readable and writable events
Two kernel object should absolutely never have the same handle ID type.
This can cause incorrect behavior when it comes to retrieving object
types from the handle table. In this case it allows converting a
WritableEvent into a ReadableEvent and vice-versa, which is undefined
behavior, since the object types are not the same.
This also corrects ClearEvent() to check both kernel types like the
kernel itself does.
Diffstat (limited to 'src/core/hle/kernel/object.cpp')
-rw-r--r-- | src/core/hle/kernel/object.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/core/hle/kernel/object.cpp b/src/core/hle/kernel/object.cpp index d87a62bb93..bb1b687786 100644 --- a/src/core/hle/kernel/object.cpp +++ b/src/core/hle/kernel/object.cpp @@ -13,7 +13,7 @@ Object::~Object() = default; bool Object::IsWaitable() const { switch (GetHandleType()) { - case HandleType::Event: + case HandleType::ReadableEvent: case HandleType::Thread: case HandleType::Timer: case HandleType::ServerPort: @@ -21,6 +21,7 @@ bool Object::IsWaitable() const { return true; case HandleType::Unknown: + case HandleType::WritableEvent: case HandleType::SharedMemory: case HandleType::Process: case HandleType::AddressArbiter: |