forked from eden-emu/eden
		
	shader_recompiler,video_core: Cleanup some GCC and Clang errors
Mostly fixing unused *, implicit conversion, braced scalar init, fpermissive, and some others. Some Clang errors likely remain in video_core, and std::ranges is still a pertinent issue in shader_recompiler shader_recompiler: cmake: Force bracket depth to 1024 on Clang Increases the maximum fold expression depth thread_worker: Include condition_variable Don't use list initializers in control flow Co-authored-by: ReinUsesLisp <reinuseslisp@airmail.cc>
This commit is contained in:
		
							parent
							
								
									5cd3d00167
								
							
						
					
					
						commit
						0bb85f6a75
					
				
					 66 changed files with 308 additions and 313 deletions
				
			
		|  | @ -17,7 +17,7 @@ u32 GenericAttributeIndex(Attribute attribute) { | |||
|     if (!IsGeneric(attribute)) { | ||||
|         throw InvalidArgument("Attribute is not generic {}", attribute); | ||||
|     } | ||||
|     return (static_cast<int>(attribute) - static_cast<int>(Attribute::Generic0X)) / 4; | ||||
|     return (static_cast<u32>(attribute) - static_cast<u32>(Attribute::Generic0X)) / 4u; | ||||
| } | ||||
| 
 | ||||
| std::string NameOf(Attribute attribute) { | ||||
|  | @ -444,4 +444,4 @@ std::string NameOf(Attribute attribute) { | |||
|     return fmt::format("<reserved attribute {}>", static_cast<int>(attribute)); | ||||
| } | ||||
| 
 | ||||
| } // namespace Shader::IR
 | ||||
| } // namespace Shader::IR
 | ||||
|  |  | |||
|  | @ -155,7 +155,7 @@ std::string DumpBlock(const Block& block, const std::map<const Block*, size_t>& | |||
|     ret += fmt::format(": begin={:04x} end={:04x}\n", block.LocationBegin(), block.LocationEnd()); | ||||
| 
 | ||||
|     for (const Inst& inst : block) { | ||||
|         const Opcode op{inst.Opcode()}; | ||||
|         const Opcode op{inst.GetOpcode()}; | ||||
|         ret += fmt::format("[{:016x}] ", reinterpret_cast<u64>(&inst)); | ||||
|         if (TypeOf(op) != Type::Void) { | ||||
|             ret += fmt::format("%{:<5} = {}", InstIndex(inst_to_index, inst_index, &inst), op); | ||||
|  |  | |||
|  | @ -12,10 +12,10 @@ namespace Shader::IR { | |||
| 
 | ||||
| std::string NameOf(Condition condition) { | ||||
|     std::string ret; | ||||
|     if (condition.FlowTest() != FlowTest::T) { | ||||
|         ret = fmt::to_string(condition.FlowTest()); | ||||
|     if (condition.GetFlowTest() != FlowTest::T) { | ||||
|         ret = fmt::to_string(condition.GetFlowTest()); | ||||
|     } | ||||
|     const auto [pred, negated]{condition.Pred()}; | ||||
|     const auto [pred, negated]{condition.GetPred()}; | ||||
|     if (!ret.empty()) { | ||||
|         ret += '&'; | ||||
|     } | ||||
|  |  | |||
|  | @ -30,11 +30,11 @@ public: | |||
| 
 | ||||
|     auto operator<=>(const Condition&) const noexcept = default; | ||||
| 
 | ||||
|     [[nodiscard]] IR::FlowTest FlowTest() const noexcept { | ||||
|     [[nodiscard]] IR::FlowTest GetFlowTest() const noexcept { | ||||
|         return static_cast<IR::FlowTest>(flow_test); | ||||
|     } | ||||
| 
 | ||||
|     [[nodiscard]] std::pair<IR::Pred, bool> Pred() const noexcept { | ||||
|     [[nodiscard]] std::pair<IR::Pred, bool> GetPred() const noexcept { | ||||
|         return {static_cast<IR::Pred>(pred), pred_negated != 0}; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -290,8 +290,8 @@ static U1 GetFlowTest(IREmitter& ir, FlowTest flow_test) { | |||
| } | ||||
| 
 | ||||
| U1 IREmitter::Condition(IR::Condition cond) { | ||||
|     const FlowTest flow_test{cond.FlowTest()}; | ||||
|     const auto [pred, is_negated]{cond.Pred()}; | ||||
|     const FlowTest flow_test{cond.GetFlowTest()}; | ||||
|     const auto [pred, is_negated]{cond.GetPred()}; | ||||
|     return LogicalAnd(GetPred(pred, is_negated), GetFlowTest(*this, flow_test)); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ | |||
| namespace Shader::IR { | ||||
| namespace { | ||||
| void CheckPseudoInstruction(IR::Inst* inst, IR::Opcode opcode) { | ||||
|     if (inst && inst->Opcode() != opcode) { | ||||
|     if (inst && inst->GetOpcode() != opcode) { | ||||
|         throw LogicError("Invalid pseudo-instruction"); | ||||
|     } | ||||
| } | ||||
|  | @ -25,11 +25,17 @@ void SetPseudoInstruction(IR::Inst*& dest_inst, IR::Inst* pseudo_inst) { | |||
| } | ||||
| 
 | ||||
| void RemovePseudoInstruction(IR::Inst*& inst, IR::Opcode expected_opcode) { | ||||
|     if (inst->Opcode() != expected_opcode) { | ||||
|     if (inst->GetOpcode() != expected_opcode) { | ||||
|         throw LogicError("Undoing use of invalid pseudo-op"); | ||||
|     } | ||||
|     inst = nullptr; | ||||
| } | ||||
| 
 | ||||
| void AllocAssociatedInsts(std::unique_ptr<AssociatedInsts>& associated_insts) { | ||||
|     if (!associated_insts) { | ||||
|         associated_insts = std::make_unique<AssociatedInsts>(); | ||||
|     } | ||||
| } | ||||
| } // Anonymous namespace
 | ||||
| 
 | ||||
| Inst::Inst(IR::Opcode op_, u32 flags_) noexcept : op{op_}, flags{flags_} { | ||||
|  | @ -249,12 +255,6 @@ void Inst::ReplaceOpcode(IR::Opcode opcode) { | |||
|     op = opcode; | ||||
| } | ||||
| 
 | ||||
| void AllocAssociatedInsts(std::unique_ptr<AssociatedInsts>& associated_insts) { | ||||
|     if (!associated_insts) { | ||||
|         associated_insts = std::make_unique<AssociatedInsts>(); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void Inst::Use(const Value& value) { | ||||
|     Inst* const inst{value.Inst()}; | ||||
|     ++inst->use_count; | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ public: | |||
|     } | ||||
| 
 | ||||
|     /// Get the opcode this microinstruction represents.
 | ||||
|     [[nodiscard]] IR::Opcode Opcode() const noexcept { | ||||
|     [[nodiscard]] IR::Opcode GetOpcode() const noexcept { | ||||
|         return op; | ||||
|     } | ||||
| 
 | ||||
|  | @ -95,7 +95,7 @@ public: | |||
|     requires(sizeof(FlagsType) <= sizeof(u32) && std::is_trivially_copyable_v<FlagsType>) | ||||
|         [[nodiscard]] FlagsType Flags() const noexcept { | ||||
|         FlagsType ret; | ||||
|         std::memcpy(&ret, &flags, sizeof(ret)); | ||||
|         std::memcpy(reinterpret_cast<char*>(&ret), &flags, sizeof(ret)); | ||||
|         return ret; | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -49,7 +49,7 @@ constexpr std::array META_TABLE{ | |||
| #define OPCODE(name_token, type_token, ...)                                                        \ | ||||
|     OpcodeMeta{                                                                                    \ | ||||
|         .name{#name_token},                                                                        \ | ||||
|         .type{type_token},                                                                         \ | ||||
|         .type = type_token,                                                                         \ | ||||
|         .arg_types{__VA_ARGS__},                                                                   \ | ||||
|     }, | ||||
| #include "opcodes.inc" | ||||
|  |  | |||
|  | @ -2,8 +2,6 @@ | |||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include <map> | ||||
| #include <string> | ||||
| 
 | ||||
|  |  | |||
|  | @ -33,11 +33,11 @@ Value::Value(u64 value) noexcept : type{Type::U64}, imm_u64{value} {} | |||
| Value::Value(f64 value) noexcept : type{Type::F64}, imm_f64{value} {} | ||||
| 
 | ||||
| bool Value::IsIdentity() const noexcept { | ||||
|     return type == Type::Opaque && inst->Opcode() == Opcode::Identity; | ||||
|     return type == Type::Opaque && inst->GetOpcode() == Opcode::Identity; | ||||
| } | ||||
| 
 | ||||
| bool Value::IsPhi() const noexcept { | ||||
|     return type == Type::Opaque && inst->Opcode() == Opcode::Phi; | ||||
|     return type == Type::Opaque && inst->GetOpcode() == Opcode::Phi; | ||||
| } | ||||
| 
 | ||||
| bool Value::IsEmpty() const noexcept { | ||||
|  |  | |||
|  | @ -94,7 +94,7 @@ public: | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     explicit TypedValue(IR::Inst* inst) : TypedValue(Value(inst)) {} | ||||
|     explicit TypedValue(IR::Inst* inst_) : TypedValue(Value(inst_)) {} | ||||
| }; | ||||
| 
 | ||||
| using U1 = TypedValue<Type::U1>; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 lat9nq
						lat9nq