Browse Source
Merge pull request #2104 from ReinUsesLisp/compute-assert
Merge pull request #2104 from ReinUsesLisp/compute-assert
kepler_compute: Fixup assert and rename the enginence_cpp
committed by
GitHub
6 changed files with 59 additions and 52 deletions
-
4src/video_core/CMakeLists.txt
-
34src/video_core/engines/kepler_compute.cpp
-
31src/video_core/engines/kepler_compute.h
-
28src/video_core/engines/maxwell_compute.cpp
-
8src/video_core/gpu.cpp
-
6src/video_core/gpu.h
@ -0,0 +1,34 @@ |
|||
// Copyright 2018 yuzu Emulator Project
|
|||
// Licensed under GPLv2 or any later version
|
|||
// Refer to the license.txt file included.
|
|||
|
|||
#include "common/logging/log.h"
|
|||
#include "core/core.h"
|
|||
#include "core/memory.h"
|
|||
#include "video_core/engines/kepler_compute.h"
|
|||
#include "video_core/memory_manager.h"
|
|||
|
|||
namespace Tegra::Engines { |
|||
|
|||
KeplerCompute::KeplerCompute(MemoryManager& memory_manager) : memory_manager{memory_manager} {} |
|||
|
|||
KeplerCompute::~KeplerCompute() = default; |
|||
|
|||
void KeplerCompute::CallMethod(const GPU::MethodCall& method_call) { |
|||
ASSERT_MSG(method_call.method < Regs::NUM_REGS, |
|||
"Invalid KeplerCompute register, increase the size of the Regs structure"); |
|||
|
|||
regs.reg_array[method_call.method] = method_call.argument; |
|||
|
|||
switch (method_call.method) { |
|||
case KEPLER_COMPUTE_REG_INDEX(launch): |
|||
// Abort execution since compute shaders can be used to alter game memory (e.g. CUDA
|
|||
// kernels)
|
|||
UNREACHABLE_MSG("Compute shaders are not implemented"); |
|||
break; |
|||
default: |
|||
break; |
|||
} |
|||
} |
|||
|
|||
} // namespace Tegra::Engines
|
|||
@ -1,28 +0,0 @@ |
|||
// Copyright 2018 yuzu Emulator Project
|
|||
// Licensed under GPLv2 or any later version
|
|||
// Refer to the license.txt file included.
|
|||
|
|||
#include "common/logging/log.h"
|
|||
#include "core/core.h"
|
|||
#include "video_core/engines/maxwell_compute.h"
|
|||
|
|||
namespace Tegra::Engines { |
|||
|
|||
void MaxwellCompute::CallMethod(const GPU::MethodCall& method_call) { |
|||
ASSERT_MSG(method_call.method < Regs::NUM_REGS, |
|||
"Invalid MaxwellCompute register, increase the size of the Regs structure"); |
|||
|
|||
regs.reg_array[method_call.method] = method_call.argument; |
|||
|
|||
switch (method_call.method) { |
|||
case MAXWELL_COMPUTE_REG_INDEX(compute): { |
|||
LOG_CRITICAL(HW_GPU, "Compute shaders are not implemented"); |
|||
UNREACHABLE(); |
|||
break; |
|||
} |
|||
default: |
|||
break; |
|||
} |
|||
} |
|||
|
|||
} // namespace Tegra::Engines
|
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue