From ec139b3027ce574439c7e95cd1ff2fb780466d84 Mon Sep 17 00:00:00 2001 From: Billy Laws Date: Sun, 30 Oct 2022 16:28:52 +0000 Subject: [PATCH] Fixup CancelBuffer fence handling --- .../hosbinder/GraphicBufferProducer.cpp | 2 +- .../cpp/skyline/services/hosbinder/parcel.h | 21 ++++++++++++------- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/app/src/main/cpp/skyline/services/hosbinder/GraphicBufferProducer.cpp b/app/src/main/cpp/skyline/services/hosbinder/GraphicBufferProducer.cpp index 4722a2c6..ed288eb2 100644 --- a/app/src/main/cpp/skyline/services/hosbinder/GraphicBufferProducer.cpp +++ b/app/src/main/cpp/skyline/services/hosbinder/GraphicBufferProducer.cpp @@ -660,7 +660,7 @@ namespace skyline::service::hosbinder { } case TransactionCode::CancelBuffer: { - CancelBuffer(in.Pop(), in.Pop()); + CancelBuffer(in.Pop(), in.PopFlattenable()); break; } diff --git a/app/src/main/cpp/skyline/services/hosbinder/parcel.h b/app/src/main/cpp/skyline/services/hosbinder/parcel.h index ade71b28..af76ade7 100644 --- a/app/src/main/cpp/skyline/services/hosbinder/parcel.h +++ b/app/src/main/cpp/skyline/services/hosbinder/parcel.h @@ -49,20 +49,27 @@ namespace skyline::service::hosbinder { return value; } + /** + * @return A reference to an item from the top of data + */ + template + ValueType &PopFlattenable() { + auto size{Pop()}; + if (size != sizeof(ValueType)) + throw exception("Popping flattenable of size 0x{:X} with type size 0x{:X}", size, sizeof(ValueType)); + return Pop(); + } + /** * @return A pointer to an optional flattenable from the top of data, nullptr will be returned if the object doesn't exist */ template ValueType *PopOptionalFlattenable() { bool hasObject{Pop() != 0}; - if (hasObject) { - auto size{Pop()}; - if (size != sizeof(ValueType)) - throw exception("Popping flattenable of size 0x{:X} with type size 0x{:X}", size, sizeof(ValueType)); - return &Pop(); - } else { + if (hasObject) + return &PopFlattenable(); + else return nullptr; - } } template