summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2018-02-13 03:17:04 +0100
committerbunnei <bunneidev@gmail.com>2018-02-13 03:24:40 +0100
commit91e19deb3931dcb1ee2b692b3d9b039bc601e2c3 (patch)
tree26791a4cc08964cda60a24921aa1cebc581a0781
parentvi: Stub TransactParcel CancelBuffer. (diff)
downloadyuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.tar
yuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.tar.gz
yuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.tar.bz2
yuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.tar.lz
yuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.tar.xz
yuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.tar.zst
yuzu-91e19deb3931dcb1ee2b692b3d9b039bc601e2c3.zip
-rw-r--r--src/core/hle/service/vi/vi.cpp28
1 files changed, 21 insertions, 7 deletions
diff --git a/src/core/hle/service/vi/vi.cpp b/src/core/hle/service/vi/vi.cpp
index cfdd4bf2a..8b4ed30d2 100644
--- a/src/core/hle/service/vi/vi.cpp
+++ b/src/core/hle/service/vi/vi.cpp
@@ -262,6 +262,11 @@ public:
Data data;
};
+// TODO(bunnei): Remove this. When set to 1, games will think a fence is valid and boot further.
+// This will break libnx and potentially other apps that more stringently check this. This is here
+// purely as a convenience, and should go away once we implement fences.
+static constexpr u32 FENCE_HACK = 0;
+
class IGBPDequeueBufferResponseParcel : public Parcel {
public:
explicit IGBPDequeueBufferResponseParcel(u32 slot) : Parcel(), slot(slot) {}
@@ -269,11 +274,20 @@ public:
protected:
void SerializeData() override {
- Write(slot);
- // TODO(Subv): Find out how this Fence is used.
- std::array<u32_le, 11> fence = {};
- Write(fence);
- Write<u32_le>(0);
+ // TODO(bunnei): Find out what this all means. Writing anything non-zero here breaks libnx.
+ Write<u32>(0);
+ Write<u32>(FENCE_HACK);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
+ Write<u32>(0);
}
u32_le slot;
@@ -304,7 +318,7 @@ protected:
void SerializeData() override {
// TODO(bunnei): Find out what this all means. Writing anything non-zero here breaks libnx.
Write<u32_le>(0);
- Write<u32_le>(0);
+ Write<u32_le>(FENCE_HACK);
Write<u32_le>(0);
Write(buffer);
Write<u32_le>(0);
@@ -560,7 +574,7 @@ private:
}
std::shared_ptr<NVFlinger::NVFlinger> nv_flinger;
-};
+}; // namespace VI
class ISystemDisplayService final : public ServiceFramework<ISystemDisplayService> {
public: