summaryrefslogtreecommitdiff
path: root/sdm/libs/hwc2/hwc_callbacks.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'sdm/libs/hwc2/hwc_callbacks.cpp')
-rw-r--r--sdm/libs/hwc2/hwc_callbacks.cpp52
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;