mirror of
https://github.com/yuzu-emu/yuzu.git
synced 2025-01-12 22:50:35 +00:00
NVMAP: Fix the Free return parameters.
This commit is contained in:
parent
af35dbcf63
commit
68d9504a04
@ -11,7 +11,9 @@
|
|||||||
using Core::Memory::YUZU_PAGESIZE;
|
using Core::Memory::YUZU_PAGESIZE;
|
||||||
|
|
||||||
namespace Service::Nvidia::NvCore {
|
namespace Service::Nvidia::NvCore {
|
||||||
NvMap::Handle::Handle(u64 size, Id id) : size(size), aligned_size(size), orig_size(size), id(id) {}
|
NvMap::Handle::Handle(u64 size, Id id) : size(size), aligned_size(size), orig_size(size), id(id) {
|
||||||
|
flags.raw = 0;
|
||||||
|
}
|
||||||
|
|
||||||
NvResult NvMap::Handle::Alloc(Flags pFlags, u32 pAlign, u8 pKind, u64 pAddress) {
|
NvResult NvMap::Handle::Alloc(Flags pFlags, u32 pAlign, u8 pKind, u64 pAddress) {
|
||||||
std::scoped_lock lock(mutex);
|
std::scoped_lock lock(mutex);
|
||||||
|
@ -44,6 +44,7 @@ public:
|
|||||||
std::optional<typename std::list<std::shared_ptr<Handle>>::iterator> unmap_queue_entry{};
|
std::optional<typename std::list<std::shared_ptr<Handle>>::iterator> unmap_queue_entry{};
|
||||||
|
|
||||||
union Flags {
|
union Flags {
|
||||||
|
u32 raw;
|
||||||
BitField<0, 1, u32> map_uncached; //!< If the handle should be mapped as uncached
|
BitField<0, 1, u32> map_uncached; //!< If the handle should be mapped as uncached
|
||||||
BitField<2, 1, u32> keep_uncached_after_free; //!< Only applicable when the handle was
|
BitField<2, 1, u32> keep_uncached_after_free; //!< Only applicable when the handle was
|
||||||
//!< allocated with a fixed address
|
//!< allocated with a fixed address
|
||||||
|
@ -82,7 +82,7 @@ std::shared_ptr<NvCore::NvMap::Handle> nvmap::GetObject(u32 handle) const {
|
|||||||
NvResult nvmap::IocCreate(const std::vector<u8>& input, std::vector<u8>& output) {
|
NvResult nvmap::IocCreate(const std::vector<u8>& input, std::vector<u8>& output) {
|
||||||
IocCreateParams params;
|
IocCreateParams params;
|
||||||
std::memcpy(¶ms, input.data(), sizeof(params));
|
std::memcpy(¶ms, input.data(), sizeof(params));
|
||||||
LOG_WARNING(Service_NVDRV, "called, size=0x{:08X}", params.size);
|
LOG_DEBUG(Service_NVDRV, "called, size=0x{:08X}", params.size);
|
||||||
|
|
||||||
std::shared_ptr<NvCore::NvMap::Handle> handle_description{};
|
std::shared_ptr<NvCore::NvMap::Handle> handle_description{};
|
||||||
auto result =
|
auto result =
|
||||||
@ -102,7 +102,7 @@ NvResult nvmap::IocCreate(const std::vector<u8>& input, std::vector<u8>& output)
|
|||||||
NvResult nvmap::IocAlloc(const std::vector<u8>& input, std::vector<u8>& output) {
|
NvResult nvmap::IocAlloc(const std::vector<u8>& input, std::vector<u8>& output) {
|
||||||
IocAllocParams params;
|
IocAllocParams params;
|
||||||
std::memcpy(¶ms, input.data(), sizeof(params));
|
std::memcpy(¶ms, input.data(), sizeof(params));
|
||||||
LOG_WARNING(Service_NVDRV, "called, addr={:X}", params.address);
|
LOG_DEBUG(Service_NVDRV, "called, addr={:X}", params.address);
|
||||||
|
|
||||||
if (!params.handle) {
|
if (!params.handle) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Handle is 0");
|
LOG_CRITICAL(Service_NVDRV, "Handle is 0");
|
||||||
@ -144,7 +144,7 @@ NvResult nvmap::IocGetId(const std::vector<u8>& input, std::vector<u8>& output)
|
|||||||
IocGetIdParams params;
|
IocGetIdParams params;
|
||||||
std::memcpy(¶ms, input.data(), sizeof(params));
|
std::memcpy(¶ms, input.data(), sizeof(params));
|
||||||
|
|
||||||
LOG_WARNING(Service_NVDRV, "called");
|
LOG_DEBUG(Service_NVDRV, "called");
|
||||||
|
|
||||||
// See the comment in FromId for extra info on this function
|
// See the comment in FromId for extra info on this function
|
||||||
if (!params.handle) {
|
if (!params.handle) {
|
||||||
@ -168,26 +168,26 @@ NvResult nvmap::IocFromId(const std::vector<u8>& input, std::vector<u8>& output)
|
|||||||
IocFromIdParams params;
|
IocFromIdParams params;
|
||||||
std::memcpy(¶ms, input.data(), sizeof(params));
|
std::memcpy(¶ms, input.data(), sizeof(params));
|
||||||
|
|
||||||
LOG_WARNING(Service_NVDRV, "called, id:{}");
|
LOG_DEBUG(Service_NVDRV, "called, id:{}");
|
||||||
|
|
||||||
// Handles and IDs are always the same value in nvmap however IDs can be used globally given the
|
// Handles and IDs are always the same value in nvmap however IDs can be used globally given the
|
||||||
// right permissions.
|
// right permissions.
|
||||||
// Since we don't plan on ever supporting multiprocess we can skip implementing handle refs and
|
// Since we don't plan on ever supporting multiprocess we can skip implementing handle refs and
|
||||||
// so this function just does simple validation and passes through the handle id.
|
// so this function just does simple validation and passes through the handle id.
|
||||||
if (!params.id) {
|
if (!params.id) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Error!");
|
LOG_CRITICAL(Service_NVDRV, "Zero Id is invalid!");
|
||||||
return NvResult::BadValue;
|
return NvResult::BadValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto handle_description{file.GetHandle(params.id)};
|
auto handle_description{file.GetHandle(params.id)};
|
||||||
if (!handle_description) {
|
if (!handle_description) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Error!");
|
LOG_CRITICAL(Service_NVDRV, "Unregistered handle!");
|
||||||
return NvResult::BadValue;
|
return NvResult::BadValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto result = handle_description->Duplicate(false);
|
auto result = handle_description->Duplicate(false);
|
||||||
if (result != NvResult::Success) {
|
if (result != NvResult::Success) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Error!");
|
LOG_CRITICAL(Service_NVDRV, "Could not duplicate handle!");
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
params.handle = handle_description->id;
|
params.handle = handle_description->id;
|
||||||
@ -201,16 +201,16 @@ NvResult nvmap::IocParam(const std::vector<u8>& input, std::vector<u8>& output)
|
|||||||
IocParamParams params;
|
IocParamParams params;
|
||||||
std::memcpy(¶ms, input.data(), sizeof(params));
|
std::memcpy(¶ms, input.data(), sizeof(params));
|
||||||
|
|
||||||
LOG_WARNING(Service_NVDRV, "called type={}", params.param);
|
LOG_DEBUG(Service_NVDRV, "called type={}", params.param);
|
||||||
|
|
||||||
if (!params.handle) {
|
if (!params.handle) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Error!");
|
LOG_CRITICAL(Service_NVDRV, "Invalid handle!");
|
||||||
return NvResult::BadValue;
|
return NvResult::BadValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto handle_description{file.GetHandle(params.handle)};
|
auto handle_description{file.GetHandle(params.handle)};
|
||||||
if (!handle_description) {
|
if (!handle_description) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Error!");
|
LOG_CRITICAL(Service_NVDRV, "Not registered handle!");
|
||||||
return NvResult::BadValue;
|
return NvResult::BadValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -228,7 +228,7 @@ NvResult nvmap::IocParam(const std::vector<u8>& input, std::vector<u8>& output)
|
|||||||
if (handle_description->allocated)
|
if (handle_description->allocated)
|
||||||
params.result = 0x40000000;
|
params.result = 0x40000000;
|
||||||
else
|
else
|
||||||
params.result = 0x40000000;
|
params.result = 0;
|
||||||
break;
|
break;
|
||||||
case HandleParameterType::Kind:
|
case HandleParameterType::Kind:
|
||||||
params.result = handle_description->kind;
|
params.result = handle_description->kind;
|
||||||
@ -248,7 +248,7 @@ NvResult nvmap::IocFree(const std::vector<u8>& input, std::vector<u8>& output) {
|
|||||||
IocFreeParams params;
|
IocFreeParams params;
|
||||||
std::memcpy(¶ms, input.data(), sizeof(params));
|
std::memcpy(¶ms, input.data(), sizeof(params));
|
||||||
|
|
||||||
LOG_WARNING(Service_NVDRV, "called");
|
LOG_DEBUG(Service_NVDRV, "called");
|
||||||
|
|
||||||
if (!params.handle) {
|
if (!params.handle) {
|
||||||
LOG_CRITICAL(Service_NVDRV, "Handle null freed?");
|
LOG_CRITICAL(Service_NVDRV, "Handle null freed?");
|
||||||
@ -258,10 +258,10 @@ NvResult nvmap::IocFree(const std::vector<u8>& input, std::vector<u8>& output) {
|
|||||||
if (auto freeInfo{file.FreeHandle(params.handle, false)}) {
|
if (auto freeInfo{file.FreeHandle(params.handle, false)}) {
|
||||||
params.address = freeInfo->address;
|
params.address = freeInfo->address;
|
||||||
params.size = static_cast<u32>(freeInfo->size);
|
params.size = static_cast<u32>(freeInfo->size);
|
||||||
params.flags = NvCore::NvMap::Handle::Flags{.map_uncached = freeInfo->was_uncached};
|
params.flags.raw = 0;
|
||||||
|
params.flags.map_uncached = freeInfo->was_uncached;
|
||||||
} else {
|
} else {
|
||||||
// This is possible when there's internel dups or other duplicates.
|
// This is possible when there's internel dups or other duplicates.
|
||||||
LOG_CRITICAL(Service_NVDRV, "Not freed");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::memcpy(output.data(), ¶ms, sizeof(params));
|
std::memcpy(output.data(), ¶ms, sizeof(params));
|
||||||
|
Loading…
Reference in New Issue
Block a user