Merge pull request #1921 from ogniK5377/no-unit

Fixed uninitialized memory due to missing returns in canary
This commit is contained in:
bunnei 2018-12-21 14:12:54 -05:00 committed by GitHub
commit e75e8b9580
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
14 changed files with 34 additions and 3 deletions

View file

@ -128,6 +128,7 @@ std::string SaveDataFactory::GetFullPath(SaveDataSpaceId space, SaveDataType typ
return fmt::format("{}save/cache/{:016X}", out, title_id); return fmt::format("{}save/cache/{:016X}", out, title_id);
default: default:
ASSERT_MSG(false, "Unrecognized SaveDataType: {:02X}", static_cast<u8>(type)); ASSERT_MSG(false, "Unrecognized SaveDataType: {:02X}", static_cast<u8>(type));
return fmt::format("{}save/unknown_{:X}/{:016X}", out, static_cast<u8>(type), title_id);
} }
} }

View file

@ -32,6 +32,7 @@ bool Object::IsWaitable() const {
} }
UNREACHABLE(); UNREACHABLE();
return false;
} }
} // namespace Kernel } // namespace Kernel

View file

@ -187,6 +187,7 @@ T Read(const VAddr vaddr) {
default: default:
UNREACHABLE(); UNREACHABLE();
} }
return {};
} }
template <typename T> template <typename T>

View file

@ -164,6 +164,7 @@ public:
return 3; return 3;
default: default:
UNREACHABLE(); UNREACHABLE();
return 1;
} }
} }
@ -871,6 +872,7 @@ public:
return 4; return 4;
} }
UNREACHABLE(); UNREACHABLE();
return 1;
} }
GPUVAddr StartAddress() const { GPUVAddr StartAddress() const {

View file

@ -1065,6 +1065,7 @@ union Instruction {
LOG_CRITICAL(HW_GPU, "Unhandled texture_info: {}", LOG_CRITICAL(HW_GPU, "Unhandled texture_info: {}",
static_cast<u32>(texture_info.Value())); static_cast<u32>(texture_info.Value()));
UNREACHABLE(); UNREACHABLE();
return TextureType::Texture1D;
} }
TextureProcessMode GetTextureProcessMode() const { TextureProcessMode GetTextureProcessMode() const {
@ -1145,6 +1146,7 @@ union Instruction {
LOG_CRITICAL(HW_GPU, "Unhandled texture_info: {}", LOG_CRITICAL(HW_GPU, "Unhandled texture_info: {}",
static_cast<u32>(texture_info.Value())); static_cast<u32>(texture_info.Value()));
UNREACHABLE(); UNREACHABLE();
return TextureType::Texture1D;
} }
TextureProcessMode GetTextureProcessMode() const { TextureProcessMode GetTextureProcessMode() const {

View file

@ -102,6 +102,7 @@ u32 RenderTargetBytesPerPixel(RenderTargetFormat format) {
return 1; return 1;
default: default:
UNIMPLEMENTED_MSG("Unimplemented render target format {}", static_cast<u32>(format)); UNIMPLEMENTED_MSG("Unimplemented render target format {}", static_cast<u32>(format));
return 1;
} }
} }
@ -119,6 +120,7 @@ u32 DepthFormatBytesPerPixel(DepthFormat format) {
return 2; return 2;
default: default:
UNIMPLEMENTED_MSG("Unimplemented Depth format {}", static_cast<u32>(format)); UNIMPLEMENTED_MSG("Unimplemented Depth format {}", static_cast<u32>(format));
return 1;
} }
} }

View file

@ -171,6 +171,7 @@ u32 MacroInterpreter::GetALUResult(ALUOperation operation, u32 src_a, u32 src_b)
default: default:
UNIMPLEMENTED_MSG("Unimplemented ALU operation {}", static_cast<u32>(operation)); UNIMPLEMENTED_MSG("Unimplemented ALU operation {}", static_cast<u32>(operation));
return 0;
} }
} }
@ -268,6 +269,7 @@ bool MacroInterpreter::EvaluateBranchCondition(BranchCondition cond, u32 value)
return value != 0; return value != 0;
} }
UNREACHABLE(); UNREACHABLE();
return true;
} }
} // namespace Tegra } // namespace Tegra

View file

@ -192,6 +192,7 @@ static MortonCopyFn GetSwizzleFunction(MortonSwizzleMode mode, Surface::PixelFor
return linear_to_morton_fns[static_cast<std::size_t>(format)]; return linear_to_morton_fns[static_cast<std::size_t>(format)];
} }
UNREACHABLE(); UNREACHABLE();
return morton_to_linear_fns[static_cast<std::size_t>(format)];
} }
/// 8x8 Z-Order coordinate from 2D coordinates /// 8x8 Z-Order coordinate from 2D coordinates

View file

@ -67,6 +67,7 @@ public:
6, "ShaderTrianglesAdjacency"); 6, "ShaderTrianglesAdjacency");
default: default:
UNREACHABLE_MSG("Unknown primitive mode."); UNREACHABLE_MSG("Unknown primitive mode.");
return LazyGeometryProgram(geometry_programs.points, "points", 1, "ShaderPoints");
} }
} }

View file

@ -364,6 +364,7 @@ public:
return value; return value;
default: default:
UNREACHABLE_MSG("Unimplemented conversion size: {}", static_cast<u32>(size)); UNREACHABLE_MSG("Unimplemented conversion size: {}", static_cast<u32>(size));
return value;
} }
} }
@ -626,6 +627,7 @@ public:
return "floatBitsToInt(" + value + ')'; return "floatBitsToInt(" + value + ')';
} else { } else {
UNREACHABLE(); UNREACHABLE();
return value;
} }
} }
@ -2062,6 +2064,8 @@ private:
std::to_string(instr.alu.GetSignedImm20_20())}; std::to_string(instr.alu.GetSignedImm20_20())};
default: default:
UNREACHABLE(); UNREACHABLE();
return {regs.GetRegisterAsInteger(instr.gpr39, 0, false),
std::to_string(instr.alu.GetSignedImm20_20())};
} }
}(); }();
const std::string offset = '(' + packed_shift + " & 0xff)"; const std::string offset = '(' + packed_shift + " & 0xff)";
@ -3312,6 +3316,7 @@ private:
return std::to_string(instr.r2p.immediate_mask); return std::to_string(instr.r2p.immediate_mask);
default: default:
UNREACHABLE(); UNREACHABLE();
return std::to_string(instr.r2p.immediate_mask);
} }
}(); }();
const std::string mask = '(' + regs.GetRegisterAsInteger(instr.gpr8, 0, false) + const std::string mask = '(' + regs.GetRegisterAsInteger(instr.gpr8, 0, false) +
@ -3775,7 +3780,10 @@ private:
} }
break; break;
} }
default: { UNIMPLEMENTED_MSG("Unhandled instruction: {}", opcode->get().GetName()); } default: {
UNIMPLEMENTED_MSG("Unhandled instruction: {}", opcode->get().GetName());
break;
}
} }
break; break;
@ -3930,4 +3938,4 @@ std::optional<ProgramResult> DecompileProgram(const ProgramCode& program_code, u
return {}; return {};
} }
} // namespace OpenGL::GLShader::Decompiler } // namespace OpenGL::GLShader::Decompiler

View file

@ -427,6 +427,7 @@ static const char* GetSource(GLenum source) {
RET(OTHER); RET(OTHER);
default: default:
UNREACHABLE(); UNREACHABLE();
return "Unknown source";
} }
#undef RET #undef RET
} }
@ -445,6 +446,7 @@ static const char* GetType(GLenum type) {
RET(MARKER); RET(MARKER);
default: default:
UNREACHABLE(); UNREACHABLE();
return "Unknown type";
} }
#undef RET #undef RET
} }

View file

@ -65,6 +65,7 @@ PixelFormat PixelFormatFromDepthFormat(Tegra::DepthFormat format) {
default: default:
LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format));
UNREACHABLE(); UNREACHABLE();
return PixelFormat::S8Z24;
} }
} }
@ -141,6 +142,7 @@ PixelFormat PixelFormatFromRenderTargetFormat(Tegra::RenderTargetFormat format)
default: default:
LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format));
UNREACHABLE(); UNREACHABLE();
return PixelFormat::RGBA8_SRGB;
} }
} }
@ -327,6 +329,7 @@ PixelFormat PixelFormatFromTextureFormat(Tegra::Texture::TextureFormat format,
LOG_CRITICAL(HW_GPU, "Unimplemented format={}, component_type={}", static_cast<u32>(format), LOG_CRITICAL(HW_GPU, "Unimplemented format={}, component_type={}", static_cast<u32>(format),
static_cast<u32>(component_type)); static_cast<u32>(component_type));
UNREACHABLE(); UNREACHABLE();
return PixelFormat::ABGR8U;
} }
} }
@ -346,6 +349,7 @@ ComponentType ComponentTypeFromTexture(Tegra::Texture::ComponentType type) {
default: default:
LOG_CRITICAL(HW_GPU, "Unimplemented component type={}", static_cast<u32>(type)); LOG_CRITICAL(HW_GPU, "Unimplemented component type={}", static_cast<u32>(type));
UNREACHABLE(); UNREACHABLE();
return ComponentType::UNorm;
} }
} }
@ -393,6 +397,7 @@ ComponentType ComponentTypeFromRenderTarget(Tegra::RenderTargetFormat format) {
default: default:
LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format));
UNREACHABLE(); UNREACHABLE();
return ComponentType::UNorm;
} }
} }
@ -403,6 +408,7 @@ PixelFormat PixelFormatFromGPUPixelFormat(Tegra::FramebufferConfig::PixelFormat
default: default:
LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format));
UNREACHABLE(); UNREACHABLE();
return PixelFormat::ABGR8U;
} }
} }
@ -418,6 +424,7 @@ ComponentType ComponentTypeFromDepthFormat(Tegra::DepthFormat format) {
default: default:
LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format)); LOG_CRITICAL(HW_GPU, "Unimplemented format={}", static_cast<u32>(format));
UNREACHABLE(); UNREACHABLE();
return ComponentType::UNorm;
} }
} }

View file

@ -226,7 +226,7 @@ u32 BytesPerPixel(TextureFormat format) {
return 8; return 8;
default: default:
UNIMPLEMENTED_MSG("Format not implemented"); UNIMPLEMENTED_MSG("Format not implemented");
break; return 1;
} }
} }

View file

@ -30,6 +30,7 @@ static Tegra::Texture::TextureFormat ConvertToTextureFormat(
return Tegra::Texture::TextureFormat::A2B10G10R10; return Tegra::Texture::TextureFormat::A2B10G10R10;
default: default:
UNIMPLEMENTED_MSG("Unimplemented RT format"); UNIMPLEMENTED_MSG("Unimplemented RT format");
return Tegra::Texture::TextureFormat::A8R8G8B8;
} }
} }