1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-19 05:52:11 +01:00

[spirv] Add OpUndef and more subgroup instructions

This commit is contained in:
Philip Rebohle 2019-05-15 19:31:43 +02:00
parent d94d89c3ef
commit dfa3caa946
No known key found for this signature in database
GPG Key ID: C8CC613427A31C99
2 changed files with 36 additions and 18 deletions

View File

@ -354,6 +354,13 @@ namespace dxvk {
} }
uint32_t SpirvModule::constUndef(
uint32_t typeId) {
return this->defConst(spv::OpUndef,
typeId, 0, nullptr);
}
uint32_t SpirvModule::specConstBool( uint32_t SpirvModule::specConstBool(
bool v) { bool v) {
uint32_t typeId = this->defBoolType(); uint32_t typeId = this->defBoolType();
@ -767,8 +774,8 @@ namespace dxvk {
void SpirvModule::functionEnd() { void SpirvModule::functionEnd() {
m_code.putIns (spv::OpFunctionEnd, 1); m_code.putIns (spv::OpFunctionEnd, 1);
} }
uint32_t SpirvModule::opAccessChain( uint32_t SpirvModule::opAccessChain(
uint32_t resultType, uint32_t resultType,
uint32_t composite, uint32_t composite,
@ -3059,24 +3066,30 @@ namespace dxvk {
} }
uint32_t SpirvModule::opGroupNonUniformLogicalAnd( uint32_t SpirvModule::opGroupNonUniformElect(
uint32_t resultType, uint32_t resultType,
uint32_t execution, uint32_t execution) {
uint32_t operation,
uint32_t value,
uint32_t clusterSize) {
uint32_t resultId = this->allocateId(); uint32_t resultId = this->allocateId();
m_code.putIns(spv::OpGroupNonUniformLogicalAnd, m_code.putIns(spv::OpGroupNonUniformElect, 4);
6 + (clusterSize ? 1 : 0));
m_code.putWord(resultType); m_code.putWord(resultType);
m_code.putWord(resultId); m_code.putWord(resultId);
m_code.putWord(execution); m_code.putWord(execution);
m_code.putWord(operation); return resultId;
m_code.putWord(value); }
if (clusterSize)
m_code.putWord(clusterSize); uint32_t SpirvModule::opGroupNonUniformBroadcastFirst(
uint32_t resultType,
uint32_t execution,
uint32_t value) {
uint32_t resultId = this->allocateId();
m_code.putIns(spv::OpGroupNonUniformBroadcastFirst, 5);
m_code.putWord(resultType);
m_code.putWord(resultId);
m_code.putWord(execution);
m_code.putWord(value);
return resultId; return resultId;
} }

View File

@ -164,6 +164,9 @@ namespace dxvk {
uint32_t constCount, uint32_t constCount,
const uint32_t* constIds); const uint32_t* constIds);
uint32_t constUndef(
uint32_t typeId);
uint32_t specConstBool( uint32_t specConstBool(
bool v); bool v);
@ -310,7 +313,7 @@ namespace dxvk {
uint32_t parameterType); uint32_t parameterType);
void functionEnd(); void functionEnd();
uint32_t opAccessChain( uint32_t opAccessChain(
uint32_t resultType, uint32_t resultType,
uint32_t composite, uint32_t composite,
@ -1053,12 +1056,14 @@ namespace dxvk {
uint32_t operation, uint32_t operation,
uint32_t ballot); uint32_t ballot);
uint32_t opGroupNonUniformLogicalAnd( uint32_t opGroupNonUniformElect(
uint32_t resultType,
uint32_t execution);
uint32_t opGroupNonUniformBroadcastFirst(
uint32_t resultType, uint32_t resultType,
uint32_t execution, uint32_t execution,
uint32_t operation, uint32_t value);
uint32_t value,
uint32_t clusterSize);
void opControlBarrier( void opControlBarrier(
uint32_t execution, uint32_t execution,