mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-16 03:45:13 +00:00
shader_recompiler: Add asserts for get/set register bounds. (#1336)
This commit is contained in:
parent
dcc4057dd8
commit
21eb175aa1
|
@ -130,19 +130,23 @@ void IREmitter::DeviceMemoryBarrier() {
|
||||||
}
|
}
|
||||||
|
|
||||||
U32 IREmitter::GetUserData(IR::ScalarReg reg) {
|
U32 IREmitter::GetUserData(IR::ScalarReg reg) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumScalarRegs);
|
||||||
return Inst<U32>(Opcode::GetUserData, reg);
|
return Inst<U32>(Opcode::GetUserData, reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
U1 IREmitter::GetThreadBitScalarReg(IR::ScalarReg reg) {
|
U1 IREmitter::GetThreadBitScalarReg(IR::ScalarReg reg) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumScalarRegs);
|
||||||
return Inst<U1>(Opcode::GetThreadBitScalarReg, reg);
|
return Inst<U1>(Opcode::GetThreadBitScalarReg, reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IREmitter::SetThreadBitScalarReg(IR::ScalarReg reg, const U1& value) {
|
void IREmitter::SetThreadBitScalarReg(IR::ScalarReg reg, const U1& value) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumScalarRegs);
|
||||||
Inst(Opcode::SetThreadBitScalarReg, reg, value);
|
Inst(Opcode::SetThreadBitScalarReg, reg, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
U32 IREmitter::GetScalarReg(IR::ScalarReg reg) {
|
U32 IREmitter::GetScalarReg(IR::ScalarReg reg) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumScalarRegs);
|
||||||
return Inst<U32>(Opcode::GetScalarRegister, reg);
|
return Inst<U32>(Opcode::GetScalarRegister, reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,6 +157,7 @@ F32 IREmitter::GetScalarReg(IR::ScalarReg reg) {
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
U32 IREmitter::GetVectorReg(IR::VectorReg reg) {
|
U32 IREmitter::GetVectorReg(IR::VectorReg reg) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumVectorRegs);
|
||||||
return Inst<U32>(Opcode::GetVectorRegister, reg);
|
return Inst<U32>(Opcode::GetVectorRegister, reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,11 +167,13 @@ F32 IREmitter::GetVectorReg(IR::VectorReg reg) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void IREmitter::SetScalarReg(IR::ScalarReg reg, const U32F32& value) {
|
void IREmitter::SetScalarReg(IR::ScalarReg reg, const U32F32& value) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumScalarRegs);
|
||||||
const U32 value_typed = value.Type() == Type::F32 ? BitCast<U32>(F32{value}) : U32{value};
|
const U32 value_typed = value.Type() == Type::F32 ? BitCast<U32>(F32{value}) : U32{value};
|
||||||
Inst(Opcode::SetScalarRegister, reg, value_typed);
|
Inst(Opcode::SetScalarRegister, reg, value_typed);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IREmitter::SetVectorReg(IR::VectorReg reg, const U32F32& value) {
|
void IREmitter::SetVectorReg(IR::VectorReg reg, const U32F32& value) {
|
||||||
|
ASSERT(static_cast<u32>(reg) < IR::NumVectorRegs);
|
||||||
const U32 value_typed = value.Type() == Type::F32 ? BitCast<U32>(F32{value}) : U32{value};
|
const U32 value_typed = value.Type() == Type::F32 ? BitCast<U32>(F32{value}) : U32{value};
|
||||||
Inst(Opcode::SetVectorRegister, reg, value_typed);
|
Inst(Opcode::SetVectorRegister, reg, value_typed);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue