diff --git a/src/core/hw/gpu.cpp b/src/core/hw/gpu.cpp index b7102b8741f87bb87b50c40b2d330da6135fba7c..e529bb2e8b9f8350d4e0520ec38d5260293fd957 100644 --- a/src/core/hw/gpu.cpp +++ b/src/core/hw/gpu.cpp @@ -116,9 +116,9 @@ inline void Write(u32 addr, const T data) { u8* src_pointer = Memory::GetPointer(Memory::PhysicalToVirtualAddress(config.GetPhysicalInputAddress())); u8* dst_pointer = Memory::GetPointer(Memory::PhysicalToVirtualAddress(config.GetPhysicalOutputAddress())); - unsigned horizontal_scale = (config.scale_horizontally != 0) ? 2 : 1; - unsigned vertical_scale = (config.scale_vertically != 0) ? 2 : 1; - + unsigned horizontal_scale = (config.scale_x != 0 || config.scale_xy != 0) ? 2 : 1; + unsigned vertical_scale = (config.scale_xy != 0) ? 2 : 1; + u32 output_width = config.output_width / horizontal_scale; u32 output_height = config.output_height / vertical_scale; diff --git a/src/core/hw/gpu.h b/src/core/hw/gpu.h index 3e81f03ef49e5debbcfc1be1e47d3e34280d8b1f..3158738f03af0f3c3f313ef0ce4a50cc19a428cf 100644 --- a/src/core/hw/gpu.h +++ b/src/core/hw/gpu.h @@ -197,8 +197,8 @@ struct Regs { BitField< 8, 3, PixelFormat> input_format; BitField<12, 3, PixelFormat> output_format; - BitField<24, 1, u32> scale_horizontally; - BitField<25, 1, u32> scale_vertically; + BitField<24, 1, u32> scale_x; // Shrinks the image in half horizontally, blending the extra pixels + BitField<25, 1, u32> scale_xy; // Shrinks the image horizontally and vertically, blending the extra pixels }; INSERT_PADDING_WORDS(0x1);