summaryrefslogtreecommitdiffstats
path: root/src/video_core
diff options
context:
space:
mode:
authorLiam <byteslice@airmail.cc>2022-10-11 01:22:26 +0200
committerLiam <byteslice@airmail.cc>2022-10-11 01:22:26 +0200
commitb1cd6cec19de46540db497137e2b93fee5c9ff17 (patch)
tree55b7a5b7583763fb58ab6e2bba965aacee70928d /src/video_core
parentMerge pull request #9043 from german77/vector_data (diff)
downloadyuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.tar
yuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.tar.gz
yuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.tar.bz2
yuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.tar.lz
yuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.tar.xz
yuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.tar.zst
yuzu-b1cd6cec19de46540db497137e2b93fee5c9ff17.zip
Diffstat (limited to 'src/video_core')
-rw-r--r--src/video_core/host1x/syncpoint_manager.cpp12
1 files changed, 11 insertions, 1 deletions
diff --git a/src/video_core/host1x/syncpoint_manager.cpp b/src/video_core/host1x/syncpoint_manager.cpp
index 326e8355a..a44fc83d3 100644
--- a/src/video_core/host1x/syncpoint_manager.cpp
+++ b/src/video_core/host1x/syncpoint_manager.cpp
@@ -36,7 +36,17 @@ SyncpointManager::ActionHandle SyncpointManager::RegisterAction(
void SyncpointManager::DeregisterAction(std::list<RegisteredAction>& action_storage,
ActionHandle& handle) {
std::unique_lock lk(guard);
- action_storage.erase(handle);
+
+ // We want to ensure the iterator still exists prior to erasing it
+ // Otherwise, if an invalid iterator was passed in then it could lead to UB
+ // It is important to avoid UB in that case since the deregister isn't called from a locked
+ // context
+ for (auto it = action_storage.begin(); it != action_storage.end(); it++) {
+ if (it == handle) {
+ action_storage.erase(it);
+ return;
+ }
+ }
}
void SyncpointManager::DeregisterGuestAction(u32 syncpoint_id, ActionHandle& handle) {