From 5f0073dd87c54f53c176047dab9f56e549cf2769 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=97=B1=20PixelyIon?= Date: Thu, 10 Sep 2020 10:00:29 +0530 Subject: [PATCH] Fix Surface Deswizzling OOB writes + Fix PL README --- app/src/main/cpp/skyline/gpu/texture.cpp | 16 ++++++++++++---- .../services/hosbinder/IHOSBinderDriver.cpp | 2 +- .../cpp/skyline/services/pl/resources/README.md | 6 +++--- 3 files changed, 16 insertions(+), 8 deletions(-) diff --git a/app/src/main/cpp/skyline/gpu/texture.cpp b/app/src/main/cpp/skyline/gpu/texture.cpp index ddf0decf..58cceb7a 100644 --- a/app/src/main/cpp/skyline/gpu/texture.cpp +++ b/app/src/main/cpp/skyline/gpu/texture.cpp @@ -3,6 +3,7 @@ #include #include +#include #include "texture.h" namespace skyline::gpu { @@ -25,8 +26,10 @@ namespace skyline::gpu { constexpr u8 gobWidth = 64; // The width of a GOB in bytes constexpr u8 gobHeight = 8; // The height of a GOB in lines - auto robHeight = gobHeight * guest->tileConfig.blockHeight; // The height of a single ROB (Row of Blocks) in lines - auto surfaceHeightRobs = util::AlignUp(dimensions.height / format.blockHeight, robHeight) / robHeight; // The height of the surface in ROBs (Row Of Blocks) + auto blockHeight = guest->tileConfig.blockHeight; // The height of the blocks in GOBs + auto robHeight = gobHeight * blockHeight; // The height of a single ROB (Row of Blocks) in lines + auto surfaceHeight = dimensions.height / format.blockHeight; // The height of the surface in lines + auto surfaceHeightRobs = util::AlignUp(surfaceHeight, robHeight) / robHeight; // The height of the surface in ROBs (Row Of Blocks) auto robWidthBytes = util::AlignUp((guest->tileConfig.surfaceWidth / format.blockWidth) * format.bpb, gobWidth); // The width of a ROB in bytes auto robWidthBlocks = robWidthBytes / gobWidth; // The width of a ROB in blocks (and GOBs because block width == 1 on the Tegra X1) auto robBytes = robWidthBytes * robHeight; // The size of a ROB in bytes @@ -35,11 +38,11 @@ namespace skyline::gpu { auto inputSector = texture; // The address of the input sector auto outputRob = output; // The address of the output block - for (u32 rob = 0; rob < surfaceHeightRobs; rob++) { // Every Surface contains `surfaceHeightRobs` ROBs + for (u32 rob = 0, y = 0, paddingY = 0; rob < surfaceHeightRobs; rob++) { // Every Surface contains `surfaceHeightRobs` ROBs auto outputBlock = outputRob; // We iterate through a block independently of the ROB for (u32 block = 0; block < robWidthBlocks; block++) { // Every ROB contains `surfaceWidthBlocks` Blocks auto outputGob = outputBlock; // We iterate through a GOB independently of the block - for (u32 gobY = 0; gobY < guest->tileConfig.blockHeight; gobY++) { // Every Block contains `blockHeight` Y-axis GOBs + for (u32 gobY = 0; gobY < blockHeight; gobY++) { // Every Block contains `blockHeight` Y-axis GOBs for (u32 index = 0; index < sectorWidth * sectorHeight; index++) { // Every Y-axis GOB contains `sectorWidth * sectorHeight` sectors u32 xT = ((index << 3) & 0b10000) | ((index << 1) & 0b100000); // Morton-Swizzle on the X-axis u32 yT = ((index >> 1) & 0b110) | (index & 0b1); // Morton-Swizzle on the Y-axis @@ -48,9 +51,14 @@ namespace skyline::gpu { } outputGob += gobYOffset; // Increment the output GOB to the next Y-axis GOB } + inputSector += paddingY; // Increment the input sector to the next sector outputBlock += gobWidth; // Increment the output block to the next block (As Block Width = 1 GOB Width) } outputRob += robBytes; // Increment the output block to the next ROB + + y += robHeight; // Increment the Y position to the next ROB + blockHeight = static_cast(std::min(static_cast(blockHeight), (surfaceHeight - y) / gobHeight)); // Calculate the amount of Y GOBs which aren't padding + paddingY = (guest->tileConfig.blockHeight - blockHeight) * (sectorWidth * sectorWidth * sectorHeight); // Calculate the amount of padding between contiguous sectors } } else if (guest->tileMode == texture::TileMode::Pitch) { auto sizeLine = guest->format.GetSize(dimensions.width, 1); // The size of a single line of pixel data diff --git a/app/src/main/cpp/skyline/services/hosbinder/IHOSBinderDriver.cpp b/app/src/main/cpp/skyline/services/hosbinder/IHOSBinderDriver.cpp index 6bef1887..6a68715c 100644 --- a/app/src/main/cpp/skyline/services/hosbinder/IHOSBinderDriver.cpp +++ b/app/src/main/cpp/skyline/services/hosbinder/IHOSBinderDriver.cpp @@ -124,7 +124,7 @@ namespace skyline::service::hosbinder { auto gbpBuffer = reinterpret_cast(pointer); std::shared_ptr nvBuffer{}; - auto nvmap = state.os->serviceManager.GetService("nvdrv")->GetDevice(nvdrv::device::NvDeviceType::nvmap); + auto nvmap = state.os->serviceManager.GetService("nvdrv:a")->GetDevice(nvdrv::device::NvDeviceType::nvmap); if (gbpBuffer->nvmapHandle) { nvBuffer = nvmap->handleTable.at(gbpBuffer->nvmapHandle); diff --git a/app/src/main/cpp/skyline/services/pl/resources/README.md b/app/src/main/cpp/skyline/services/pl/resources/README.md index b48b1fab..eafd5bb1 100644 --- a/app/src/main/cpp/skyline/services/pl/resources/README.md +++ b/app/src/main/cpp/skyline/services/pl/resources/README.md @@ -1,4 +1,4 @@ #### Skyline FOSS Shared Fonts: (Credit to [FearlessTobi/yuzu_system_archives](https://github.com/FearlessTobi/yuzu_system_archives) for font choice) -* [FontStandard](FontStandard.ttf.h), [FontKorean](FontKorean.ttf.h), [FontChineseSimplified](FontChineseSimplified.ttf.h) and [FontChineseTraditional](FontChineseTraditional.ttf.h) are using [Open Sans Regular(https://fonts.google.com/specimen/Open+Sans), which is licensed under (Apache 2.0)[https://www.apache.org/licenses/LICENSE-2.0] -* [FontNintendoExtended](FontNintendoExtended.ttf.h) is using [Roboto](https://fonts.google.com/specimen/Roboto), which is licensed under (Apache 2.0)[https://www.apache.org/licenses/LICENSE-2.0] -* [FontExtendedChineseSimplified](FontExtendedChineseSimplified.ttf.h) is using [Source Sans Pro](https://fonts.google.com/specimen/Source+Sans+Pro), which is licensed under (Open Font License)[https://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&id=OFL] +* [FontStandard](FontStandard.ttf.h), [FontKorean](FontKorean.ttf.h), [FontChineseSimplified](FontChineseSimplified.ttf.h) and [FontChineseTraditional](FontChineseTraditional.ttf.h) are using [Open Sans Regular](https://fonts.google.com/specimen/Open+Sans), which is licensed under [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0) +* [FontNintendoExtended](FontNintendoExtended.ttf.h) is using [Roboto](https://fonts.google.com/specimen/Roboto), which is licensed under [Apache 2.0](https://www.apache.org/licenses/LICENSE-2.0) +* [FontExtendedChineseSimplified](FontExtendedChineseSimplified.ttf.h) is using [Source Sans Pro](https://fonts.google.com/specimen/Source+Sans+Pro), which is licensed under [Open Font License](https://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&id=OFL)