mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-06-26 04:16:18 +00:00
Implement PM4CondExec (#3046)
Some checks failed
Build and Release / reuse (push) Has been cancelled
Build and Release / clang-format (push) Has been cancelled
Build and Release / get-info (push) Has been cancelled
Build and Release / windows-sdl (push) Has been cancelled
Build and Release / linux-sdl-gcc (push) Has been cancelled
Build and Release / windows-qt (push) Has been cancelled
Build and Release / macos-sdl (push) Has been cancelled
Build and Release / macos-qt (push) Has been cancelled
Build and Release / linux-sdl (push) Has been cancelled
Build and Release / linux-qt (push) Has been cancelled
Build and Release / linux-qt-gcc (push) Has been cancelled
Build and Release / pre-release (push) Has been cancelled
Some checks failed
Build and Release / reuse (push) Has been cancelled
Build and Release / clang-format (push) Has been cancelled
Build and Release / get-info (push) Has been cancelled
Build and Release / windows-sdl (push) Has been cancelled
Build and Release / linux-sdl-gcc (push) Has been cancelled
Build and Release / windows-qt (push) Has been cancelled
Build and Release / macos-sdl (push) Has been cancelled
Build and Release / macos-qt (push) Has been cancelled
Build and Release / linux-sdl (push) Has been cancelled
Build and Release / linux-qt (push) Has been cancelled
Build and Release / linux-qt-gcc (push) Has been cancelled
Build and Release / pre-release (push) Has been cancelled
This commit is contained in:
parent
fff3bf9917
commit
91d29459fb
2 changed files with 34 additions and 0 deletions
|
@ -765,6 +765,19 @@ Liverpool::Task Liverpool::ProcessGraphics(std::span<const u32> dcb, std::span<c
|
|||
LOG_WARNING(Render_Vulkan, "Unimplemented IT_GET_LOD_STATS");
|
||||
break;
|
||||
}
|
||||
case PM4ItOpcode::CondExec: {
|
||||
const auto* cond_exec = reinterpret_cast<const PM4CmdCondExec*>(header);
|
||||
if (cond_exec->command.Value() != 0) {
|
||||
LOG_WARNING(Render, "IT_COND_EXEC used a reserved command");
|
||||
}
|
||||
const auto skip = *cond_exec->Address() == false;
|
||||
if (skip) {
|
||||
dcb = NextPacket(dcb,
|
||||
header->type3.NumWords() + 1 + cond_exec->exec_count.Value());
|
||||
continue;
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
UNREACHABLE_MSG("Unknown PM4 type 3 opcode {:#x} with count {}",
|
||||
static_cast<u32>(opcode), count);
|
||||
|
|
|
@ -1159,4 +1159,25 @@ struct PM4CmdMemSemaphore {
|
|||
}
|
||||
};
|
||||
|
||||
struct PM4CmdCondExec {
|
||||
PM4Type3Header header;
|
||||
union {
|
||||
BitField<2, 30, u32> bool_addr_lo; ///< low 32 address bits for the block in memory from
|
||||
///< where the CP will fetch the condition
|
||||
};
|
||||
union {
|
||||
BitField<0, 16, u32> bool_addr_hi; ///< high address bits for the condition
|
||||
BitField<28, 4, u32> command;
|
||||
};
|
||||
union {
|
||||
BitField<0, 14, u32> exec_count; ///< Number of DWords that the CP will skip
|
||||
///< if bool pointed to is zero
|
||||
};
|
||||
|
||||
bool* Address() const {
|
||||
return std::bit_cast<bool*>(u64(bool_addr_hi.Value()) << 32 | u64(bool_addr_lo.Value())
|
||||
<< 2);
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace AmdGpu
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue