diff options
Diffstat (limited to 'sdm/libs/hwc2/hwc_callbacks.cpp')
-rw-r--r-- | sdm/libs/hwc2/hwc_callbacks.cpp | 52 |
1 files changed, 39 insertions, 13 deletions
diff --git a/sdm/libs/hwc2/hwc_callbacks.cpp b/sdm/libs/hwc2/hwc_callbacks.cpp index aec1d327..065a1940 100644 --- a/sdm/libs/hwc2/hwc_callbacks.cpp +++ b/sdm/libs/hwc2/hwc_callbacks.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016-2017, 2019 The Linux Foundation. All rights reserved. + * Copyright (c) 2016-2017, 2019-2020 The Linux Foundation. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are @@ -35,6 +35,7 @@ namespace sdm { HWC2::Error HWCCallbacks::Hotplug(hwc2_display_t display, HWC2::Connection state) { + std::lock_guard<std::mutex> hotplug_lock(hotplug_mutex_); if (!hotplug_) { return HWC2::Error::NoResources; } @@ -43,6 +44,7 @@ HWC2::Error HWCCallbacks::Hotplug(hwc2_display_t display, HWC2::Connection state } HWC2::Error HWCCallbacks::Refresh(hwc2_display_t display) { + std::lock_guard<std::mutex> refresh_lock(refresh_mutex_); if (!refresh_) { return HWC2::Error::NoResources; } @@ -52,6 +54,7 @@ HWC2::Error HWCCallbacks::Refresh(hwc2_display_t display) { } HWC2::Error HWCCallbacks::Vsync(hwc2_display_t display, int64_t timestamp) { + std::lock_guard<std::mutex> vsync_lock(vsync_mutex_); if (!vsync_) { return HWC2::Error::NoResources; } @@ -61,6 +64,7 @@ HWC2::Error HWCCallbacks::Vsync(hwc2_display_t display, int64_t timestamp) { } HWC2::Error HWCCallbacks::Vsync_2_4(hwc2_display_t display, int64_t timestamp, uint32_t period) { + std::lock_guard<std::mutex> vsync_2_4_lock(vsync_2_4_mutex_); DTRACE_SCOPED(); if (!vsync_2_4_) { return HWC2::Error::NoResources; @@ -72,6 +76,8 @@ HWC2::Error HWCCallbacks::Vsync_2_4(hwc2_display_t display, int64_t timestamp, u HWC2::Error HWCCallbacks::VsyncPeriodTimingChanged( hwc2_display_t display, hwc_vsync_period_change_timeline_t *updated_timeline) { + std::lock_guard<std::mutex> + vsyncPeriodTimingChanged_lock(vsync_period_timing_changed_mutex_); DTRACE_SCOPED(); if (!vsync_period_timing_changed_) { return HWC2::Error::NoResources; @@ -82,6 +88,7 @@ HWC2::Error HWCCallbacks::VsyncPeriodTimingChanged( } HWC2::Error HWCCallbacks::SeamlessPossible(hwc2_display_t display) { + std::lock_guard<std::mutex> seamlessPossible_lock(seamless_possible_mutex_); DTRACE_SCOPED(); if (!seamless_possible_) { return HWC2::Error::NoResources; @@ -95,29 +102,48 @@ HWC2::Error HWCCallbacks::Register(HWC2::Callback descriptor, hwc2_callback_data hwc2_function_pointer_t pointer) { switch (descriptor) { case HWC2::Callback::Hotplug: - hotplug_data_ = callback_data; - hotplug_ = reinterpret_cast<HWC2_PFN_HOTPLUG>(pointer); + { + std::lock_guard<std::mutex> hotplug_lock(hotplug_mutex_); + hotplug_data_ = callback_data; + hotplug_ = reinterpret_cast<HWC2_PFN_HOTPLUG>(pointer); + } break; case HWC2::Callback::Refresh: - refresh_data_ = callback_data; - refresh_ = reinterpret_cast<HWC2_PFN_REFRESH>(pointer); + { + std::lock_guard<std::mutex> refresh_lock(refresh_mutex_); + refresh_data_ = callback_data; + refresh_ = reinterpret_cast<HWC2_PFN_REFRESH>(pointer); + } break; case HWC2::Callback::Vsync: - vsync_data_ = callback_data; - vsync_ = reinterpret_cast<HWC2_PFN_VSYNC>(pointer); + { + std::lock_guard<std::mutex> vsync_lock(vsync_mutex_); + vsync_data_ = callback_data; + vsync_ = reinterpret_cast<HWC2_PFN_VSYNC>(pointer); + } break; case HWC2::Callback::Vsync_2_4: - vsync_2_4_data_ = callback_data; - vsync_2_4_ = reinterpret_cast<HWC2_PFN_VSYNC_2_4>(pointer); + { + std::lock_guard<std::mutex> vsync_2_4_lock(vsync_2_4_mutex_); + vsync_2_4_data_ = callback_data; + vsync_2_4_ = reinterpret_cast<HWC2_PFN_VSYNC_2_4>(pointer); + } break; case HWC2::Callback::VsyncPeriodTimingChanged: - vsync_period_timing_changed_data_ = callback_data; - vsync_period_timing_changed_ = + { + std::lock_guard<std::mutex> + vsyncPeriodTimingChanged_lock(vsync_period_timing_changed_mutex_); + vsync_period_timing_changed_data_ = callback_data; + vsync_period_timing_changed_ = reinterpret_cast<HWC2_PFN_VSYNC_PERIOD_TIMING_CHANGED>(pointer); + } break; case HWC2::Callback::SeamlessPossible: - seamless_possible_data_ = callback_data; - seamless_possible_ = reinterpret_cast<HWC2_PFN_SEAMLESS_POSSIBLE>(pointer); + { + std::lock_guard<std::mutex> seamlessPossible_lock(seamless_possible_mutex_); + seamless_possible_data_ = callback_data; + seamless_possible_ = reinterpret_cast<HWC2_PFN_SEAMLESS_POSSIBLE>(pointer); + } break; default: return HWC2::Error::BadParameter; |