mirror of
https://github.com/yuzu-emu/yuzu-android.git
synced 2024-11-27 10:34:22 +01:00
Merge pull request #3004 from ReinUsesLisp/maxwell3d-cleanup
maxwell_3d: Remove unused entries
This commit is contained in:
commit
2ec5b55ee3
@ -50,7 +50,7 @@ void KeplerCompute::CallMethod(const GPU::MethodCall& method_call) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Tegra::Texture::FullTextureInfo KeplerCompute::GetTexture(std::size_t offset) const {
|
Texture::FullTextureInfo KeplerCompute::GetTexture(std::size_t offset) const {
|
||||||
const std::bitset<8> cbuf_mask = launch_description.const_buffer_enable_mask.Value();
|
const std::bitset<8> cbuf_mask = launch_description.const_buffer_enable_mask.Value();
|
||||||
ASSERT(cbuf_mask[regs.tex_cb_index]);
|
ASSERT(cbuf_mask[regs.tex_cb_index]);
|
||||||
|
|
||||||
@ -61,13 +61,11 @@ Tegra::Texture::FullTextureInfo KeplerCompute::GetTexture(std::size_t offset) co
|
|||||||
ASSERT(address < texinfo.Address() + texinfo.size);
|
ASSERT(address < texinfo.Address() + texinfo.size);
|
||||||
|
|
||||||
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(address)};
|
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(address)};
|
||||||
return GetTextureInfo(tex_handle, offset);
|
return GetTextureInfo(tex_handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
Texture::FullTextureInfo KeplerCompute::GetTextureInfo(const Texture::TextureHandle tex_handle,
|
Texture::FullTextureInfo KeplerCompute::GetTextureInfo(Texture::TextureHandle tex_handle) const {
|
||||||
std::size_t offset) const {
|
return Texture::FullTextureInfo{GetTICEntry(tex_handle.tic_id), GetTSCEntry(tex_handle.tsc_id)};
|
||||||
return Texture::FullTextureInfo{static_cast<u32>(offset), GetTICEntry(tex_handle.tic_id),
|
|
||||||
GetTSCEntry(tex_handle.tsc_id)};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 KeplerCompute::AccessConstBuffer32(ShaderType stage, u64 const_buffer, u64 offset) const {
|
u32 KeplerCompute::AccessConstBuffer32(ShaderType stage, u64 const_buffer, u64 offset) const {
|
||||||
@ -89,7 +87,7 @@ SamplerDescriptor KeplerCompute::AccessBindlessSampler(ShaderType stage, u64 con
|
|||||||
const GPUVAddr tex_info_address = tex_info_buffer.Address() + offset;
|
const GPUVAddr tex_info_address = tex_info_buffer.Address() + offset;
|
||||||
|
|
||||||
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(tex_info_address)};
|
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(tex_info_address)};
|
||||||
const Texture::FullTextureInfo tex_info = GetTextureInfo(tex_handle, offset);
|
const Texture::FullTextureInfo tex_info = GetTextureInfo(tex_handle);
|
||||||
SamplerDescriptor result = SamplerDescriptor::FromTicTexture(tex_info.tic.texture_type.Value());
|
SamplerDescriptor result = SamplerDescriptor::FromTicTexture(tex_info.tic.texture_type.Value());
|
||||||
result.is_shadow.Assign(tex_info.tsc.depth_compare_enabled.Value());
|
result.is_shadow.Assign(tex_info.tsc.depth_compare_enabled.Value());
|
||||||
return result;
|
return result;
|
||||||
|
@ -196,11 +196,10 @@ public:
|
|||||||
/// Write the value to the register identified by method.
|
/// Write the value to the register identified by method.
|
||||||
void CallMethod(const GPU::MethodCall& method_call);
|
void CallMethod(const GPU::MethodCall& method_call);
|
||||||
|
|
||||||
Tegra::Texture::FullTextureInfo GetTexture(std::size_t offset) const;
|
Texture::FullTextureInfo GetTexture(std::size_t offset) const;
|
||||||
|
|
||||||
/// Given a Texture Handle, returns the TSC and TIC entries.
|
/// Given a texture handle, returns the TSC and TIC entries.
|
||||||
Texture::FullTextureInfo GetTextureInfo(const Texture::TextureHandle tex_handle,
|
Texture::FullTextureInfo GetTextureInfo(Texture::TextureHandle tex_handle) const;
|
||||||
std::size_t offset) const;
|
|
||||||
|
|
||||||
u32 AccessConstBuffer32(ShaderType stage, u64 const_buffer, u64 offset) const override;
|
u32 AccessConstBuffer32(ShaderType stage, u64 const_buffer, u64 offset) const override;
|
||||||
|
|
||||||
|
@ -760,61 +760,8 @@ Texture::TSCEntry Maxwell3D::GetTSCEntry(u32 tsc_index) const {
|
|||||||
return tsc_entry;
|
return tsc_entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Texture::FullTextureInfo> Maxwell3D::GetStageTextures(Regs::ShaderStage stage) const {
|
Texture::FullTextureInfo Maxwell3D::GetTextureInfo(Texture::TextureHandle tex_handle) const {
|
||||||
std::vector<Texture::FullTextureInfo> textures;
|
return Texture::FullTextureInfo{GetTICEntry(tex_handle.tic_id), GetTSCEntry(tex_handle.tsc_id)};
|
||||||
|
|
||||||
auto& fragment_shader = state.shader_stages[static_cast<std::size_t>(stage)];
|
|
||||||
auto& tex_info_buffer = fragment_shader.const_buffers[regs.tex_cb_index];
|
|
||||||
ASSERT(tex_info_buffer.enabled && tex_info_buffer.address != 0);
|
|
||||||
|
|
||||||
GPUVAddr tex_info_buffer_end = tex_info_buffer.address + tex_info_buffer.size;
|
|
||||||
|
|
||||||
// Offset into the texture constbuffer where the texture info begins.
|
|
||||||
static constexpr std::size_t TextureInfoOffset = 0x20;
|
|
||||||
|
|
||||||
for (GPUVAddr current_texture = tex_info_buffer.address + TextureInfoOffset;
|
|
||||||
current_texture < tex_info_buffer_end; current_texture += sizeof(Texture::TextureHandle)) {
|
|
||||||
|
|
||||||
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(current_texture)};
|
|
||||||
|
|
||||||
Texture::FullTextureInfo tex_info{};
|
|
||||||
// TODO(Subv): Use the shader to determine which textures are actually accessed.
|
|
||||||
tex_info.index =
|
|
||||||
static_cast<u32>(current_texture - tex_info_buffer.address - TextureInfoOffset) /
|
|
||||||
sizeof(Texture::TextureHandle);
|
|
||||||
|
|
||||||
// Load the TIC data.
|
|
||||||
auto tic_entry = GetTICEntry(tex_handle.tic_id);
|
|
||||||
// TODO(Subv): Workaround for BitField's move constructor being deleted.
|
|
||||||
std::memcpy(&tex_info.tic, &tic_entry, sizeof(tic_entry));
|
|
||||||
|
|
||||||
// Load the TSC data
|
|
||||||
auto tsc_entry = GetTSCEntry(tex_handle.tsc_id);
|
|
||||||
// TODO(Subv): Workaround for BitField's move constructor being deleted.
|
|
||||||
std::memcpy(&tex_info.tsc, &tsc_entry, sizeof(tsc_entry));
|
|
||||||
|
|
||||||
textures.push_back(tex_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
return textures;
|
|
||||||
}
|
|
||||||
|
|
||||||
Texture::FullTextureInfo Maxwell3D::GetTextureInfo(const Texture::TextureHandle tex_handle,
|
|
||||||
std::size_t offset) const {
|
|
||||||
Texture::FullTextureInfo tex_info{};
|
|
||||||
tex_info.index = static_cast<u32>(offset);
|
|
||||||
|
|
||||||
// Load the TIC data.
|
|
||||||
auto tic_entry = GetTICEntry(tex_handle.tic_id);
|
|
||||||
// TODO(Subv): Workaround for BitField's move constructor being deleted.
|
|
||||||
std::memcpy(&tex_info.tic, &tic_entry, sizeof(tic_entry));
|
|
||||||
|
|
||||||
// Load the TSC data
|
|
||||||
auto tsc_entry = GetTSCEntry(tex_handle.tsc_id);
|
|
||||||
// TODO(Subv): Workaround for BitField's move constructor being deleted.
|
|
||||||
std::memcpy(&tex_info.tsc, &tsc_entry, sizeof(tsc_entry));
|
|
||||||
|
|
||||||
return tex_info;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Texture::FullTextureInfo Maxwell3D::GetStageTexture(Regs::ShaderStage stage,
|
Texture::FullTextureInfo Maxwell3D::GetStageTexture(Regs::ShaderStage stage,
|
||||||
@ -830,7 +777,7 @@ Texture::FullTextureInfo Maxwell3D::GetStageTexture(Regs::ShaderStage stage,
|
|||||||
|
|
||||||
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(tex_info_address)};
|
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(tex_info_address)};
|
||||||
|
|
||||||
return GetTextureInfo(tex_handle, offset);
|
return GetTextureInfo(tex_handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 Maxwell3D::GetRegisterValue(u32 method) const {
|
u32 Maxwell3D::GetRegisterValue(u32 method) const {
|
||||||
@ -867,7 +814,7 @@ SamplerDescriptor Maxwell3D::AccessBindlessSampler(ShaderType stage, u64 const_b
|
|||||||
const GPUVAddr tex_info_address = tex_info_buffer.address + offset;
|
const GPUVAddr tex_info_address = tex_info_buffer.address + offset;
|
||||||
|
|
||||||
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(tex_info_address)};
|
const Texture::TextureHandle tex_handle{memory_manager.Read<u32>(tex_info_address)};
|
||||||
const Texture::FullTextureInfo tex_info = GetTextureInfo(tex_handle, offset);
|
const Texture::FullTextureInfo tex_info = GetTextureInfo(tex_handle);
|
||||||
SamplerDescriptor result = SamplerDescriptor::FromTicTexture(tex_info.tic.texture_type.Value());
|
SamplerDescriptor result = SamplerDescriptor::FromTicTexture(tex_info.tic.texture_type.Value());
|
||||||
result.is_shadow.Assign(tex_info.tsc.depth_compare_enabled.Value());
|
result.is_shadow.Assign(tex_info.tsc.depth_compare_enabled.Value());
|
||||||
return result;
|
return result;
|
||||||
|
@ -1250,12 +1250,8 @@ public:
|
|||||||
|
|
||||||
void FlushMMEInlineDraw();
|
void FlushMMEInlineDraw();
|
||||||
|
|
||||||
/// Given a Texture Handle, returns the TSC and TIC entries.
|
/// Given a texture handle, returns the TSC and TIC entries.
|
||||||
Texture::FullTextureInfo GetTextureInfo(const Texture::TextureHandle tex_handle,
|
Texture::FullTextureInfo GetTextureInfo(Texture::TextureHandle tex_handle) const;
|
||||||
std::size_t offset) const;
|
|
||||||
|
|
||||||
/// Returns a list of enabled textures for the specified shader stage.
|
|
||||||
std::vector<Texture::FullTextureInfo> GetStageTextures(Regs::ShaderStage stage) const;
|
|
||||||
|
|
||||||
/// Returns the texture information for a specific texture in a specific shader stage.
|
/// Returns the texture information for a specific texture in a specific shader stage.
|
||||||
Texture::FullTextureInfo GetStageTexture(Regs::ShaderStage stage, std::size_t offset) const;
|
Texture::FullTextureInfo GetStageTexture(Regs::ShaderStage stage, std::size_t offset) const;
|
||||||
|
@ -969,7 +969,7 @@ TextureBufferUsage RasterizerOpenGL::SetupDrawTextures(Maxwell::ShaderStage stag
|
|||||||
|
|
||||||
for (u32 bindpoint = 0; bindpoint < entries.size(); ++bindpoint) {
|
for (u32 bindpoint = 0; bindpoint < entries.size(); ++bindpoint) {
|
||||||
const auto& entry = entries[bindpoint];
|
const auto& entry = entries[bindpoint];
|
||||||
const auto texture = [&]() {
|
const auto texture = [&] {
|
||||||
if (!entry.IsBindless()) {
|
if (!entry.IsBindless()) {
|
||||||
return maxwell3d.GetStageTexture(stage, entry.GetOffset());
|
return maxwell3d.GetStageTexture(stage, entry.GetOffset());
|
||||||
}
|
}
|
||||||
@ -977,7 +977,7 @@ TextureBufferUsage RasterizerOpenGL::SetupDrawTextures(Maxwell::ShaderStage stag
|
|||||||
Tegra::Texture::TextureHandle tex_handle;
|
Tegra::Texture::TextureHandle tex_handle;
|
||||||
Tegra::Engines::ShaderType shader_type = static_cast<Tegra::Engines::ShaderType>(stage);
|
Tegra::Engines::ShaderType shader_type = static_cast<Tegra::Engines::ShaderType>(stage);
|
||||||
tex_handle.raw = maxwell3d.AccessConstBuffer32(shader_type, cbuf.first, cbuf.second);
|
tex_handle.raw = maxwell3d.AccessConstBuffer32(shader_type, cbuf.first, cbuf.second);
|
||||||
return maxwell3d.GetTextureInfo(tex_handle, entry.GetOffset());
|
return maxwell3d.GetTextureInfo(tex_handle);
|
||||||
}();
|
}();
|
||||||
|
|
||||||
if (SetupTexture(base_bindings.sampler + bindpoint, texture, entry)) {
|
if (SetupTexture(base_bindings.sampler + bindpoint, texture, entry)) {
|
||||||
@ -1000,7 +1000,7 @@ TextureBufferUsage RasterizerOpenGL::SetupComputeTextures(const Shader& kernel)
|
|||||||
|
|
||||||
for (u32 bindpoint = 0; bindpoint < entries.size(); ++bindpoint) {
|
for (u32 bindpoint = 0; bindpoint < entries.size(); ++bindpoint) {
|
||||||
const auto& entry = entries[bindpoint];
|
const auto& entry = entries[bindpoint];
|
||||||
const auto texture = [&]() {
|
const auto texture = [&] {
|
||||||
if (!entry.IsBindless()) {
|
if (!entry.IsBindless()) {
|
||||||
return compute.GetTexture(entry.GetOffset());
|
return compute.GetTexture(entry.GetOffset());
|
||||||
}
|
}
|
||||||
@ -1008,7 +1008,7 @@ TextureBufferUsage RasterizerOpenGL::SetupComputeTextures(const Shader& kernel)
|
|||||||
Tegra::Texture::TextureHandle tex_handle;
|
Tegra::Texture::TextureHandle tex_handle;
|
||||||
tex_handle.raw = compute.AccessConstBuffer32(Tegra::Engines::ShaderType::Compute,
|
tex_handle.raw = compute.AccessConstBuffer32(Tegra::Engines::ShaderType::Compute,
|
||||||
cbuf.first, cbuf.second);
|
cbuf.first, cbuf.second);
|
||||||
return compute.GetTextureInfo(tex_handle, entry.GetOffset());
|
return compute.GetTextureInfo(tex_handle);
|
||||||
}();
|
}();
|
||||||
|
|
||||||
if (SetupTexture(bindpoint, texture, entry)) {
|
if (SetupTexture(bindpoint, texture, entry)) {
|
||||||
@ -1046,7 +1046,7 @@ void RasterizerOpenGL::SetupComputeImages(const Shader& shader) {
|
|||||||
const auto& entries = shader->GetShaderEntries().images;
|
const auto& entries = shader->GetShaderEntries().images;
|
||||||
for (u32 bindpoint = 0; bindpoint < entries.size(); ++bindpoint) {
|
for (u32 bindpoint = 0; bindpoint < entries.size(); ++bindpoint) {
|
||||||
const auto& entry = entries[bindpoint];
|
const auto& entry = entries[bindpoint];
|
||||||
const auto tic = [&]() {
|
const auto tic = [&] {
|
||||||
if (!entry.IsBindless()) {
|
if (!entry.IsBindless()) {
|
||||||
return compute.GetTexture(entry.GetOffset()).tic;
|
return compute.GetTexture(entry.GetOffset()).tic;
|
||||||
}
|
}
|
||||||
@ -1054,7 +1054,7 @@ void RasterizerOpenGL::SetupComputeImages(const Shader& shader) {
|
|||||||
Tegra::Texture::TextureHandle tex_handle;
|
Tegra::Texture::TextureHandle tex_handle;
|
||||||
tex_handle.raw = compute.AccessConstBuffer32(Tegra::Engines::ShaderType::Compute,
|
tex_handle.raw = compute.AccessConstBuffer32(Tegra::Engines::ShaderType::Compute,
|
||||||
cbuf.first, cbuf.second);
|
cbuf.first, cbuf.second);
|
||||||
return compute.GetTextureInfo(tex_handle, entry.GetOffset()).tic;
|
return compute.GetTextureInfo(tex_handle).tic;
|
||||||
}();
|
}();
|
||||||
SetupImage(bindpoint, tic, entry);
|
SetupImage(bindpoint, tic, entry);
|
||||||
}
|
}
|
||||||
|
@ -354,7 +354,6 @@ struct TSCEntry {
|
|||||||
static_assert(sizeof(TSCEntry) == 0x20, "TSCEntry has wrong size");
|
static_assert(sizeof(TSCEntry) == 0x20, "TSCEntry has wrong size");
|
||||||
|
|
||||||
struct FullTextureInfo {
|
struct FullTextureInfo {
|
||||||
u32 index;
|
|
||||||
TICEntry tic;
|
TICEntry tic;
|
||||||
TSCEntry tsc;
|
TSCEntry tsc;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user