vi: check layer state before opening or closing
This commit is contained in:
		| @@ -174,24 +174,28 @@ void Nvnflinger::CreateLayerAtId(VI::Display& display, u64 layer_id) { | ||||
|     display.CreateLayer(layer_id, buffer_id, nvdrv->container); | ||||
| } | ||||
|  | ||||
| void Nvnflinger::OpenLayer(u64 layer_id) { | ||||
| bool Nvnflinger::OpenLayer(u64 layer_id) { | ||||
|     const auto lock_guard = Lock(); | ||||
|  | ||||
|     for (auto& display : displays) { | ||||
|         if (auto* layer = display.FindLayer(layer_id); layer) { | ||||
|             layer->Open(); | ||||
|         } | ||||
|             return layer->Open(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| void Nvnflinger::CloseLayer(u64 layer_id) { | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| bool Nvnflinger::CloseLayer(u64 layer_id) { | ||||
|     const auto lock_guard = Lock(); | ||||
|  | ||||
|     for (auto& display : displays) { | ||||
|         if (auto* layer = display.FindLayer(layer_id); layer) { | ||||
|             layer->Close(); | ||||
|             return layer->Close(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| void Nvnflinger::DestroyLayer(u64 layer_id) { | ||||
|   | ||||
| @@ -74,10 +74,10 @@ public: | ||||
|     [[nodiscard]] std::optional<u64> CreateLayer(u64 display_id); | ||||
|  | ||||
|     /// Opens a layer on all displays for the given layer ID. | ||||
|     void OpenLayer(u64 layer_id); | ||||
|     bool OpenLayer(u64 layer_id); | ||||
|  | ||||
|     /// Closes a layer on all displays for the given layer ID. | ||||
|     void CloseLayer(u64 layer_id); | ||||
|     bool CloseLayer(u64 layer_id); | ||||
|  | ||||
|     /// Destroys the given layer ID. | ||||
|     void DestroyLayer(u64 layer_id); | ||||
|   | ||||
| @@ -4,6 +4,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <memory> | ||||
| #include <utility> | ||||
|  | ||||
| #include "common/common_types.h" | ||||
|  | ||||
| @@ -75,12 +76,12 @@ public: | ||||
|         return open; | ||||
|     } | ||||
|  | ||||
|     void Close() { | ||||
|         open = false; | ||||
|     bool Close() { | ||||
|         return std::exchange(open, false); | ||||
|     } | ||||
|  | ||||
|     void Open() { | ||||
|         open = true; | ||||
|     bool Open() { | ||||
|         return !std::exchange(open, true); | ||||
|     } | ||||
|  | ||||
| private: | ||||
|   | ||||
| @@ -719,7 +719,12 @@ private: | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         nvnflinger.OpenLayer(layer_id); | ||||
|         if (!nvnflinger.OpenLayer(layer_id)) { | ||||
|             LOG_WARNING(Service_VI, "Tried to open layer which was already open"); | ||||
|             IPC::ResponseBuilder rb{ctx, 2}; | ||||
|             rb.Push(ResultOperationFailed); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         android::OutputParcel parcel; | ||||
|         parcel.WriteInterface(NativeWindow{*buffer_queue_id}); | ||||
| @@ -737,7 +742,12 @@ private: | ||||
|  | ||||
|         LOG_DEBUG(Service_VI, "called. layer_id=0x{:016X}", layer_id); | ||||
|  | ||||
|         nvnflinger.CloseLayer(layer_id); | ||||
|         if (!nvnflinger.CloseLayer(layer_id)) { | ||||
|             LOG_WARNING(Service_VI, "Tried to close layer which was not open"); | ||||
|             IPC::ResponseBuilder rb{ctx, 2}; | ||||
|             rb.Push(ResultOperationFailed); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         IPC::ResponseBuilder rb{ctx, 2}; | ||||
|         rb.Push(ResultSuccess); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user