video_core: Fix SNORM texture buffer emulating error (#9001)
This commit is contained in:
		| @@ -43,6 +43,10 @@ void EmitBitCastU64F64(EmitContext&, IR::Inst& inst, const IR::Value& value) { | ||||
|     Alias(inst, value); | ||||
| } | ||||
|  | ||||
| void EmitBitCastS32F32(EmitContext&, IR::Inst& inst, const IR::Value& value) { | ||||
|     Alias(inst, value); | ||||
| } | ||||
|  | ||||
| void EmitBitCastF16U16(EmitContext&, IR::Inst& inst, const IR::Value& value) { | ||||
|     Alias(inst, value); | ||||
| } | ||||
|   | ||||
| @@ -196,6 +196,7 @@ void EmitSelectF64(EmitContext& ctx, ScalarS32 cond, Register true_value, Regist | ||||
| void EmitBitCastU16F16(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
| void EmitBitCastU32F32(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
| void EmitBitCastU64F64(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
| void EmitBitCastS32F32(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
| void EmitBitCastF16U16(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
| void EmitBitCastF32U32(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
| void EmitBitCastF64U64(EmitContext& ctx, IR::Inst& inst, const IR::Value& value); | ||||
|   | ||||
| @@ -48,6 +48,10 @@ void EmitBitCastU64F64(EmitContext& ctx, IR::Inst& inst, std::string_view value) | ||||
|     ctx.AddU64("{}=doubleBitsToUint64({});", inst, value); | ||||
| } | ||||
|  | ||||
| void EmitBitCastS32F32(EmitContext& ctx, IR::Inst& inst, std::string_view value) { | ||||
|     ctx.AddF32("{}=ftoi({});", inst, value); | ||||
| } | ||||
|  | ||||
| void EmitBitCastF16U16([[maybe_unused]] EmitContext& ctx, [[maybe_unused]] IR::Inst& inst) { | ||||
|     NotImplemented(); | ||||
| } | ||||
|   | ||||
| @@ -230,6 +230,7 @@ void EmitSelectF64(EmitContext& ctx, IR::Inst& inst, std::string_view cond, | ||||
| void EmitBitCastU16F16(EmitContext& ctx, IR::Inst& inst); | ||||
| void EmitBitCastU32F32(EmitContext& ctx, IR::Inst& inst, std::string_view value); | ||||
| void EmitBitCastU64F64(EmitContext& ctx, IR::Inst& inst, std::string_view value); | ||||
| void EmitBitCastS32F32(EmitContext& ctx, IR::Inst& inst, std::string_view value); | ||||
| void EmitBitCastF16U16(EmitContext& ctx, IR::Inst& inst); | ||||
| void EmitBitCastF32U32(EmitContext& ctx, IR::Inst& inst, std::string_view value); | ||||
| void EmitBitCastF64U64(EmitContext& ctx, IR::Inst& inst, std::string_view value); | ||||
|   | ||||
| @@ -18,6 +18,10 @@ void EmitBitCastU64F64(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
|  | ||||
| void EmitBitCastS32F32(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
|  | ||||
| void EmitBitCastF16U16(EmitContext&) { | ||||
|     throw NotImplementedException("SPIR-V Instruction"); | ||||
| } | ||||
|   | ||||
| @@ -178,7 +178,8 @@ Id EmitSelectF64(EmitContext& ctx, Id cond, Id true_value, Id false_value); | ||||
| void EmitBitCastU16F16(EmitContext& ctx); | ||||
| Id EmitBitCastU32F32(EmitContext& ctx, Id value); | ||||
| void EmitBitCastU64F64(EmitContext& ctx); | ||||
| void EmitBitCastF16U16(EmitContext& ctx); | ||||
| void EmitBitCastS32F32(EmitContext& ctx); | ||||
| void EmitBitCastF16U16(EmitContext&); | ||||
| Id EmitBitCastF32U32(EmitContext& ctx, Id value); | ||||
| void EmitBitCastF64U64(EmitContext& ctx); | ||||
| Id EmitPackUint2x32(EmitContext& ctx, Id value); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user