forked from eden-emu/eden
		
	Addressed issues
This commit is contained in:
		
							parent
							
								
									74b4334d51
								
							
						
					
					
						commit
						fabdf5d385
					
				
					 5 changed files with 17 additions and 13 deletions
				
			
		|  | @ -1422,6 +1422,10 @@ public: | |||
|         return rasterizer; | ||||
|     } | ||||
| 
 | ||||
|     const VideoCore::RasterizerInterface& GetRasterizer() const { | ||||
|         return rasterizer; | ||||
|     } | ||||
| 
 | ||||
|     /// Notify a memory write has happened.
 | ||||
|     void OnMemoryWrite() { | ||||
|         dirty.flags |= dirty.on_write_stores; | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ namespace Tegra { | |||
| MacroEngine::MacroEngine(Engines::Maxwell3D& maxwell3d) | ||||
|     : hle_macros{std::make_unique<Tegra::HLEMacro>(maxwell3d)} {} | ||||
| 
 | ||||
| MacroEngine::~MacroEngine() {} | ||||
| MacroEngine::~MacroEngine() = default; | ||||
| 
 | ||||
| void MacroEngine::AddCode(u32 method, u32 data) { | ||||
|     uploaded_macro_code[method].push_back(data); | ||||
|  |  | |||
|  | @ -111,7 +111,7 @@ public: | |||
| 
 | ||||
| class MacroEngine { | ||||
| public: | ||||
|     MacroEngine(Engines::Maxwell3D& maxwell3d); | ||||
|     explicit MacroEngine(Engines::Maxwell3D& maxwell3d); | ||||
|     virtual ~MacroEngine(); | ||||
| 
 | ||||
|     // Store the uploaded macro code to compile them when they're called.
 | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include <unordered_map> | ||||
| #include <array> | ||||
| #include <vector> | ||||
| #include "video_core/engines/maxwell_3d.h" | ||||
| #include "video_core/macro/macro_hle.h" | ||||
|  | @ -78,22 +78,22 @@ static void HLE_0217920100488FF7(Engines::Maxwell3D& maxwell3d, | |||
|     maxwell3d.CallMethodFromMME(0x8e5, 0x0); | ||||
| } | ||||
| 
 | ||||
| static const std::unordered_map<u64, HLEFunction> hle_funcs{ | ||||
|     {0x771BB18C62444DA0, &HLE_771BB18C62444DA0}, | ||||
|     {0x0D61FC9FAAC9FCAD, &HLE_0D61FC9FAAC9FCAD}, | ||||
|     {0x0217920100488FF7, &HLE_0217920100488FF7}, | ||||
| static const std::array<std::pair<u64, HLEFunction>, 3> hle_funcs{ | ||||
|     std::make_pair<u64, HLEFunction>(0x771BB18C62444DA0, &HLE_771BB18C62444DA0), | ||||
|     std::make_pair<u64, HLEFunction>(0x0D61FC9FAAC9FCAD, &HLE_0D61FC9FAAC9FCAD), | ||||
|     std::make_pair<u64, HLEFunction>(0x0217920100488FF7, &HLE_0217920100488FF7), | ||||
| }; | ||||
| 
 | ||||
| HLEMacro::HLEMacro(Engines::Maxwell3D& maxwell3d) : maxwell3d(maxwell3d) {} | ||||
| HLEMacro::~HLEMacro() = default; | ||||
| 
 | ||||
| std::optional<std::unique_ptr<CachedMacro>> HLEMacro::GetHLEProgram(u64 hash) const { | ||||
|     auto it = hle_funcs.find(hash); | ||||
|     if (it != hle_funcs.end()) { | ||||
|         return std::make_unique<HLEMacroImpl>(maxwell3d, it->second); | ||||
|     } else { | ||||
|         return {}; | ||||
|     const auto it = std::find_if(hle_funcs.begin(), hle_funcs.end(), | ||||
|                                  [hash](auto& pair) { return pair.first == hash; }); | ||||
|     if (it == hle_funcs.end()) { | ||||
|         return std::nullopt; | ||||
|     } | ||||
|     return std::make_unique<HLEMacroImpl>(maxwell3d, it->second); | ||||
| } | ||||
| 
 | ||||
| HLEMacroImpl::~HLEMacroImpl() = default; | ||||
|  |  | |||
|  | @ -20,7 +20,7 @@ using HLEFunction = void (*)(Engines::Maxwell3D& maxwell3d, const std::vector<u3 | |||
| 
 | ||||
| class HLEMacro { | ||||
| public: | ||||
|     HLEMacro(Engines::Maxwell3D& maxwell3d); | ||||
|     explicit HLEMacro(Engines::Maxwell3D& maxwell3d); | ||||
|     ~HLEMacro(); | ||||
|     std::optional<std::unique_ptr<CachedMacro>> GetHLEProgram(u64 hash) const; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Marcec
						David Marcec