summaryrefslogtreecommitdiffstats
path: root/src/core/hle
diff options
context:
space:
mode:
authorChloe Marcec <dmarcecguzman@gmail.com>2021-05-03 06:39:03 +0200
committerChloe Marcec <dmarcecguzman@gmail.com>2021-05-03 06:39:03 +0200
commit7d257ce7bdea11168c7ccf72f69217482e502e85 (patch)
treef632db1cf19fa4f9df34d4435d6c7981ef8dffd8 /src/core/hle
parentMerge pull request #6277 from german77/touchsetting2 (diff)
downloadyuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.tar
yuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.tar.gz
yuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.tar.bz2
yuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.tar.lz
yuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.tar.xz
yuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.tar.zst
yuzu-7d257ce7bdea11168c7ccf72f69217482e502e85.zip
Diffstat (limited to 'src/core/hle')
-rw-r--r--src/core/hle/service/nvdrv/interface.cpp17
1 files changed, 14 insertions, 3 deletions
diff --git a/src/core/hle/service/nvdrv/interface.cpp b/src/core/hle/service/nvdrv/interface.cpp
index 2e1150867..6d1fef382 100644
--- a/src/core/hle/service/nvdrv/interface.cpp
+++ b/src/core/hle/service/nvdrv/interface.cpp
@@ -22,19 +22,30 @@ void NVDRV::SignalGPUInterruptSyncpt(const u32 syncpoint_id, const u32 value) {
void NVDRV::Open(Kernel::HLERequestContext& ctx) {
LOG_DEBUG(Service_NVDRV, "called");
+ IPC::ResponseBuilder rb{ctx, 4};
+ rb.Push(RESULT_SUCCESS);
if (!is_initialized) {
- ServiceError(ctx, NvResult::NotInitialized);
+ rb.Push<DeviceFD>(0);
+ rb.PushEnum(NvResult::NotInitialized);
+
LOG_ERROR(Service_NVDRV, "NvServices is not initalized!");
return;
}
const auto& buffer = ctx.ReadBuffer();
const std::string device_name(buffer.begin(), buffer.end());
+
+ if (device_name == "/dev/nvhost-prof-gpu") {
+ rb.Push<DeviceFD>(0);
+ rb.PushEnum(NvResult::NotSupported);
+
+ LOG_WARNING(Service_NVDRV, "/dev/nvhost-prof-gpu cannot be openned on production");
+ return;
+ }
+
DeviceFD fd = nvdrv->Open(device_name);
- IPC::ResponseBuilder rb{ctx, 4};
- rb.Push(RESULT_SUCCESS);
rb.Push<DeviceFD>(fd);
rb.PushEnum(fd != INVALID_NVDRV_FD ? NvResult::Success : NvResult::FileOperationFailed);
}