mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-05-14 08:12:16 +00:00
shader_recompiler: Few fixes for buffer number conversions. (#2869)
* liverpool: Pass correct color buffer number type for conversion mapping. * shader_recompiler: Apply number conversion to vertex inputs.
This commit is contained in:
parent
10b24d04bc
commit
5fd5b62539
2 changed files with 12 additions and 7 deletions
|
@ -517,7 +517,9 @@ void Translator::EmitFetch(const GcnInst& inst) {
|
||||||
const auto values =
|
const auto values =
|
||||||
ir.CompositeConstruct(ir.GetAttribute(attr, 0), ir.GetAttribute(attr, 1),
|
ir.CompositeConstruct(ir.GetAttribute(attr, 0), ir.GetAttribute(attr, 1),
|
||||||
ir.GetAttribute(attr, 2), ir.GetAttribute(attr, 3));
|
ir.GetAttribute(attr, 2), ir.GetAttribute(attr, 3));
|
||||||
const auto swizzled = ApplySwizzle(ir, values, buffer.DstSelect());
|
const auto converted =
|
||||||
|
IR::ApplyReadNumberConversionVec4(ir, values, buffer.GetNumberConversion());
|
||||||
|
const auto swizzled = ApplySwizzle(ir, converted, buffer.DstSelect());
|
||||||
for (u32 i = 0; i < 4; i++) {
|
for (u32 i = 0; i < 4; i++) {
|
||||||
ir.SetVectorReg(dst_reg++, IR::F32{ir.CompositeExtract(swizzled, i)});
|
ir.SetVectorReg(dst_reg++, IR::F32{ir.CompositeExtract(swizzled, i)});
|
||||||
}
|
}
|
||||||
|
|
|
@ -924,15 +924,11 @@ struct Liverpool {
|
||||||
}
|
}
|
||||||
|
|
||||||
[[nodiscard]] NumberFormat GetNumberFmt() const {
|
[[nodiscard]] NumberFormat GetNumberFmt() const {
|
||||||
// There is a small difference between T# and CB number types, account for it.
|
return RemapNumberFormat(GetFixedNumberFormat(), info.format);
|
||||||
return RemapNumberFormat(info.number_type == NumberFormat::SnormNz
|
|
||||||
? NumberFormat::Srgb
|
|
||||||
: info.number_type.Value(),
|
|
||||||
info.format);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[[nodiscard]] NumberConversion GetNumberConversion() const {
|
[[nodiscard]] NumberConversion GetNumberConversion() const {
|
||||||
return MapNumberConversion(info.number_type);
|
return MapNumberConversion(GetFixedNumberFormat());
|
||||||
}
|
}
|
||||||
|
|
||||||
[[nodiscard]] CompMapping Swizzle() const {
|
[[nodiscard]] CompMapping Swizzle() const {
|
||||||
|
@ -973,6 +969,13 @@ struct Liverpool {
|
||||||
const auto mrt_swizzle = mrt_swizzles[swap_idx][components_idx];
|
const auto mrt_swizzle = mrt_swizzles[swap_idx][components_idx];
|
||||||
return RemapSwizzle(info.format, mrt_swizzle);
|
return RemapSwizzle(info.format, mrt_swizzle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
[[nodiscard]] NumberFormat GetFixedNumberFormat() const {
|
||||||
|
// There is a small difference between T# and CB number types, account for it.
|
||||||
|
return info.number_type == NumberFormat::SnormNz ? NumberFormat::Srgb
|
||||||
|
: info.number_type.Value();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ContextRegs : u32 {
|
enum ContextRegs : u32 {
|
||||||
|
|
Loading…
Add table
Reference in a new issue