diff options
Diffstat (limited to 'src/video_core/macro')
| -rw-r--r-- | src/video_core/macro/macro_hle.cpp | 6 | ||||
| -rw-r--r-- | src/video_core/macro/macro_hle.h | 2 | ||||
| -rw-r--r-- | src/video_core/macro/macro_interpreter.cpp | 27 | ||||
| -rw-r--r-- | src/video_core/macro/macro_interpreter.h | 10 | ||||
| -rw-r--r-- | src/video_core/macro/macro_jit_x64.cpp | 21 | ||||
| -rw-r--r-- | src/video_core/macro/macro_jit_x64.h | 4 | 
6 files changed, 34 insertions, 36 deletions
| diff --git a/src/video_core/macro/macro_hle.cpp b/src/video_core/macro/macro_hle.cpp index df00b57df..70ac7c620 100644 --- a/src/video_core/macro/macro_hle.cpp +++ b/src/video_core/macro/macro_hle.cpp @@ -85,7 +85,7 @@ constexpr std::array<std::pair<u64, HLEFunction>, 3> hle_funcs{{      {0x0217920100488FF7, &HLE_0217920100488FF7},  }}; -HLEMacro::HLEMacro(Engines::Maxwell3D& maxwell3d) : maxwell3d(maxwell3d) {} +HLEMacro::HLEMacro(Engines::Maxwell3D& maxwell3d_) : maxwell3d{maxwell3d_} {}  HLEMacro::~HLEMacro() = default;  std::optional<std::unique_ptr<CachedMacro>> HLEMacro::GetHLEProgram(u64 hash) const { @@ -99,8 +99,8 @@ std::optional<std::unique_ptr<CachedMacro>> HLEMacro::GetHLEProgram(u64 hash) co  HLEMacroImpl::~HLEMacroImpl() = default; -HLEMacroImpl::HLEMacroImpl(Engines::Maxwell3D& maxwell3d, HLEFunction func) -    : maxwell3d(maxwell3d), func(func) {} +HLEMacroImpl::HLEMacroImpl(Engines::Maxwell3D& maxwell3d_, HLEFunction func_) +    : maxwell3d{maxwell3d_}, func{func_} {}  void HLEMacroImpl::Execute(const std::vector<u32>& parameters, u32 method) {      func(maxwell3d, parameters); diff --git a/src/video_core/macro/macro_hle.h b/src/video_core/macro/macro_hle.h index 37af875a0..cb3bd1600 100644 --- a/src/video_core/macro/macro_hle.h +++ b/src/video_core/macro/macro_hle.h @@ -20,7 +20,7 @@ using HLEFunction = void (*)(Engines::Maxwell3D& maxwell3d, const std::vector<u3  class HLEMacro {  public: -    explicit HLEMacro(Engines::Maxwell3D& maxwell3d); +    explicit HLEMacro(Engines::Maxwell3D& maxwell3d_);      ~HLEMacro();      std::optional<std::unique_ptr<CachedMacro>> GetHLEProgram(u64 hash) const; diff --git a/src/video_core/macro/macro_interpreter.cpp b/src/video_core/macro/macro_interpreter.cpp index bd01fd1f2..8da26fd59 100644 --- a/src/video_core/macro/macro_interpreter.cpp +++ b/src/video_core/macro/macro_interpreter.cpp @@ -11,29 +11,29 @@  MICROPROFILE_DEFINE(MacroInterp, "GPU", "Execute macro interpreter", MP_RGB(128, 128, 192));  namespace Tegra { -MacroInterpreter::MacroInterpreter(Engines::Maxwell3D& maxwell3d) -    : MacroEngine::MacroEngine(maxwell3d), maxwell3d(maxwell3d) {} +MacroInterpreter::MacroInterpreter(Engines::Maxwell3D& maxwell3d_) +    : MacroEngine{maxwell3d_}, maxwell3d{maxwell3d_} {}  std::unique_ptr<CachedMacro> MacroInterpreter::Compile(const std::vector<u32>& code) {      return std::make_unique<MacroInterpreterImpl>(maxwell3d, code);  } -MacroInterpreterImpl::MacroInterpreterImpl(Engines::Maxwell3D& maxwell3d, -                                           const std::vector<u32>& code) -    : maxwell3d(maxwell3d), code(code) {} +MacroInterpreterImpl::MacroInterpreterImpl(Engines::Maxwell3D& maxwell3d_, +                                           const std::vector<u32>& code_) +    : maxwell3d{maxwell3d_}, code{code_} {} -void MacroInterpreterImpl::Execute(const std::vector<u32>& parameters, u32 method) { +void MacroInterpreterImpl::Execute(const std::vector<u32>& params, u32 method) {      MICROPROFILE_SCOPE(MacroInterp);      Reset(); -    registers[1] = parameters[0]; -    num_parameters = parameters.size(); +    registers[1] = params[0]; +    num_parameters = params.size();      if (num_parameters > parameters_capacity) {          parameters_capacity = num_parameters; -        this->parameters = std::make_unique<u32[]>(num_parameters); +        parameters = std::make_unique<u32[]>(num_parameters);      } -    std::memcpy(this->parameters.get(), parameters.data(), num_parameters * sizeof(u32)); +    std::memcpy(parameters.get(), params.data(), num_parameters * sizeof(u32));      // Execute the code until we hit an exit condition.      bool keep_executing = true; @@ -133,8 +133,7 @@ bool MacroInterpreterImpl::Step(bool is_delay_slot) {          break;      }      default: -        UNIMPLEMENTED_MSG("Unimplemented macro operation {}", -                          static_cast<u32>(opcode.operation.Value())); +        UNIMPLEMENTED_MSG("Unimplemented macro operation {}", opcode.operation.Value());      }      // An instruction with the Exit flag will not actually @@ -182,7 +181,7 @@ u32 MacroInterpreterImpl::GetALUResult(Macro::ALUOperation operation, u32 src_a,          return ~(src_a & src_b);      default: -        UNIMPLEMENTED_MSG("Unimplemented ALU operation {}", static_cast<u32>(operation)); +        UNIMPLEMENTED_MSG("Unimplemented ALU operation {}", operation);          return 0;      }  } @@ -230,7 +229,7 @@ void MacroInterpreterImpl::ProcessResult(Macro::ResultOperation operation, u32 r          Send((result >> 12) & 0b111111);          break;      default: -        UNIMPLEMENTED_MSG("Unimplemented result operation {}", static_cast<u32>(operation)); +        UNIMPLEMENTED_MSG("Unimplemented result operation {}", operation);      }  } diff --git a/src/video_core/macro/macro_interpreter.h b/src/video_core/macro/macro_interpreter.h index 90217fc89..d50c619ce 100644 --- a/src/video_core/macro/macro_interpreter.h +++ b/src/video_core/macro/macro_interpreter.h @@ -17,7 +17,7 @@ class Maxwell3D;  class MacroInterpreter final : public MacroEngine {  public: -    explicit MacroInterpreter(Engines::Maxwell3D& maxwell3d); +    explicit MacroInterpreter(Engines::Maxwell3D& maxwell3d_);  protected:      std::unique_ptr<CachedMacro> Compile(const std::vector<u32>& code) override; @@ -28,8 +28,8 @@ private:  class MacroInterpreterImpl : public CachedMacro {  public: -    MacroInterpreterImpl(Engines::Maxwell3D& maxwell3d, const std::vector<u32>& code); -    void Execute(const std::vector<u32>& parameters, u32 method) override; +    explicit MacroInterpreterImpl(Engines::Maxwell3D& maxwell3d_, const std::vector<u32>& code_); +    void Execute(const std::vector<u32>& params, u32 method) override;  private:      /// Resets the execution engine state, zeroing registers, etc. @@ -38,9 +38,9 @@ private:      /**       * Executes a single macro instruction located at the current program counter. Returns whether       * the interpreter should keep running. -     * @param offset Offset to start execution at. +     *       * @param is_delay_slot Whether the current step is being executed due to a delay slot in a -     * previous instruction. +     *                      previous instruction.       */      bool Step(bool is_delay_slot); diff --git a/src/video_core/macro/macro_jit_x64.cpp b/src/video_core/macro/macro_jit_x64.cpp index 954b87515..c6b2b2109 100644 --- a/src/video_core/macro/macro_jit_x64.cpp +++ b/src/video_core/macro/macro_jit_x64.cpp @@ -28,15 +28,15 @@ static const std::bitset<32> PERSISTENT_REGISTERS = Common::X64::BuildRegSet({      BRANCH_HOLDER,  }); -MacroJITx64::MacroJITx64(Engines::Maxwell3D& maxwell3d) -    : MacroEngine::MacroEngine(maxwell3d), maxwell3d(maxwell3d) {} +MacroJITx64::MacroJITx64(Engines::Maxwell3D& maxwell3d_) +    : MacroEngine{maxwell3d_}, maxwell3d{maxwell3d_} {}  std::unique_ptr<CachedMacro> MacroJITx64::Compile(const std::vector<u32>& code) {      return std::make_unique<MacroJITx64Impl>(maxwell3d, code);  } -MacroJITx64Impl::MacroJITx64Impl(Engines::Maxwell3D& maxwell3d, const std::vector<u32>& code) -    : Xbyak::CodeGenerator(MAX_CODE_SIZE), code(code), maxwell3d(maxwell3d) { +MacroJITx64Impl::MacroJITx64Impl(Engines::Maxwell3D& maxwell3d_, const std::vector<u32>& code_) +    : CodeGenerator{MAX_CODE_SIZE}, code{code_}, maxwell3d{maxwell3d_} {      Compile();  } @@ -165,8 +165,7 @@ void MacroJITx64Impl::Compile_ALU(Macro::Opcode opcode) {          }          break;      default: -        UNIMPLEMENTED_MSG("Unimplemented ALU operation {}", -                          static_cast<std::size_t>(opcode.alu_operation.Value())); +        UNIMPLEMENTED_MSG("Unimplemented ALU operation {}", opcode.alu_operation.Value());          break;      }      Compile_ProcessResult(opcode.result_operation, opcode.dst); @@ -553,15 +552,15 @@ Xbyak::Reg32 MacroJITx64Impl::Compile_GetRegister(u32 index, Xbyak::Reg32 dst) {  }  void MacroJITx64Impl::Compile_ProcessResult(Macro::ResultOperation operation, u32 reg) { -    const auto SetRegister = [this](u32 reg, const Xbyak::Reg32& result) { +    const auto SetRegister = [this](u32 reg_index, const Xbyak::Reg32& result) {          // Register 0 is supposed to always return 0. NOP is implemented as a store to the zero          // register. -        if (reg == 0) { +        if (reg_index == 0) {              return;          } -        mov(dword[STATE + offsetof(JITState, registers) + reg * sizeof(u32)], result); +        mov(dword[STATE + offsetof(JITState, registers) + reg_index * sizeof(u32)], result);      }; -    const auto SetMethodAddress = [this](const Xbyak::Reg32& reg) { mov(METHOD_ADDRESS, reg); }; +    const auto SetMethodAddress = [this](const Xbyak::Reg32& reg32) { mov(METHOD_ADDRESS, reg32); };      switch (operation) {      case Macro::ResultOperation::IgnoreAndFetch: @@ -604,7 +603,7 @@ void MacroJITx64Impl::Compile_ProcessResult(Macro::ResultOperation operation, u3          Compile_Send(RESULT);          break;      default: -        UNIMPLEMENTED_MSG("Unimplemented macro operation {}", static_cast<std::size_t>(operation)); +        UNIMPLEMENTED_MSG("Unimplemented macro operation {}", operation);      }  } diff --git a/src/video_core/macro/macro_jit_x64.h b/src/video_core/macro/macro_jit_x64.h index a180e7428..7f50ac2f8 100644 --- a/src/video_core/macro/macro_jit_x64.h +++ b/src/video_core/macro/macro_jit_x64.h @@ -23,7 +23,7 @@ constexpr size_t MAX_CODE_SIZE = 0x10000;  class MacroJITx64 final : public MacroEngine {  public: -    explicit MacroJITx64(Engines::Maxwell3D& maxwell3d); +    explicit MacroJITx64(Engines::Maxwell3D& maxwell3d_);  protected:      std::unique_ptr<CachedMacro> Compile(const std::vector<u32>& code) override; @@ -34,7 +34,7 @@ private:  class MacroJITx64Impl : public Xbyak::CodeGenerator, public CachedMacro {  public: -    MacroJITx64Impl(Engines::Maxwell3D& maxwell3d, const std::vector<u32>& code); +    explicit MacroJITx64Impl(Engines::Maxwell3D& maxwell3d_, const std::vector<u32>& code_);      ~MacroJITx64Impl();      void Execute(const std::vector<u32>& parameters, u32 method) override; | 
