diff options
author | Chloe Marcec <dmarcecguzman@gmail.com> | 2021-05-03 06:39:03 +0200 |
---|---|---|
committer | Chloe Marcec <dmarcecguzman@gmail.com> | 2021-05-03 06:39:03 +0200 |
commit | 7d257ce7bdea11168c7ccf72f69217482e502e85 (patch) | |
tree | f632db1cf19fa4f9df34d4435d6c7981ef8dffd8 /src/core | |
parent | Merge pull request #6277 from german77/touchsetting2 (diff) | |
download | yuzu-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')
-rw-r--r-- | src/core/hle/service/nvdrv/interface.cpp | 17 |
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); } |