mirror of
https://github.com/starr-dusT/yuzu-mainline
synced 2024-03-05 21:12:25 -08:00
Stubbed NVGPU_GPU_IOCTL_ZBC_SET_TABLE (#463)
We have no clue on what this actually does yet so stubbing it since it's just input only should be fine for now
This commit is contained in:
parent
55e6296e71
commit
e3a92b09ba
@ -24,6 +24,8 @@ u32 nvhost_ctrl_gpu::ioctl(Ioctl command, const std::vector<u8>& input, std::vec
|
|||||||
return ZCullGetCtxSize(input, output);
|
return ZCullGetCtxSize(input, output);
|
||||||
case IoctlCommand::IocZcullGetInfo:
|
case IoctlCommand::IocZcullGetInfo:
|
||||||
return ZCullGetInfo(input, output);
|
return ZCullGetInfo(input, output);
|
||||||
|
case IoctlCommand::IocZbcSetTable:
|
||||||
|
return ZBCSetTable(input, output);
|
||||||
}
|
}
|
||||||
UNIMPLEMENTED_MSG("Unimplemented ioctl");
|
UNIMPLEMENTED_MSG("Unimplemented ioctl");
|
||||||
return 0;
|
return 0;
|
||||||
@ -125,4 +127,13 @@ u32 nvhost_ctrl_gpu::ZCullGetInfo(const std::vector<u8>& input, std::vector<u8>&
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u32 nvhost_ctrl_gpu::ZBCSetTable(const std::vector<u8>& input, std::vector<u8>& output) {
|
||||||
|
NGLOG_WARNING(Service_NVDRV, "(STUBBED) called");
|
||||||
|
IoctlZbcSetTable params{};
|
||||||
|
std::memcpy(¶ms, input.data(), input.size());
|
||||||
|
// TODO(ogniK): What does this even actually do?
|
||||||
|
std::memcpy(output.data(), ¶ms, output.size());
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Service::Nvidia::Devices
|
} // namespace Service::Nvidia::Devices
|
||||||
|
@ -25,6 +25,7 @@ private:
|
|||||||
IocGetActiveSlotMaskCommand = 0x80084714,
|
IocGetActiveSlotMaskCommand = 0x80084714,
|
||||||
IocZcullGetCtxSizeCommand = 0x80044701,
|
IocZcullGetCtxSizeCommand = 0x80044701,
|
||||||
IocZcullGetInfo = 0x80284702,
|
IocZcullGetInfo = 0x80284702,
|
||||||
|
IocZbcSetTable = 0x402C4703,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct IoctlGpuCharacteristics {
|
struct IoctlGpuCharacteristics {
|
||||||
@ -117,11 +118,21 @@ private:
|
|||||||
static_assert(sizeof(IoctlNvgpuGpuZcullGetInfoArgs) == 40,
|
static_assert(sizeof(IoctlNvgpuGpuZcullGetInfoArgs) == 40,
|
||||||
"IoctlNvgpuGpuZcullGetInfoArgs is incorrect size");
|
"IoctlNvgpuGpuZcullGetInfoArgs is incorrect size");
|
||||||
|
|
||||||
|
struct IoctlZbcSetTable {
|
||||||
|
u32_le color_ds[4];
|
||||||
|
u32_le color_l2[4];
|
||||||
|
u32_le depth;
|
||||||
|
u32_le format;
|
||||||
|
u32_le type;
|
||||||
|
};
|
||||||
|
static_assert(sizeof(IoctlZbcSetTable) == 44, "IoctlZbcSetTable is incorrect size");
|
||||||
|
|
||||||
u32 GetCharacteristics(const std::vector<u8>& input, std::vector<u8>& output);
|
u32 GetCharacteristics(const std::vector<u8>& input, std::vector<u8>& output);
|
||||||
u32 GetTPCMasks(const std::vector<u8>& input, std::vector<u8>& output);
|
u32 GetTPCMasks(const std::vector<u8>& input, std::vector<u8>& output);
|
||||||
u32 GetActiveSlotMask(const std::vector<u8>& input, std::vector<u8>& output);
|
u32 GetActiveSlotMask(const std::vector<u8>& input, std::vector<u8>& output);
|
||||||
u32 ZCullGetCtxSize(const std::vector<u8>& input, std::vector<u8>& output);
|
u32 ZCullGetCtxSize(const std::vector<u8>& input, std::vector<u8>& output);
|
||||||
u32 ZCullGetInfo(const std::vector<u8>& input, std::vector<u8>& output);
|
u32 ZCullGetInfo(const std::vector<u8>& input, std::vector<u8>& output);
|
||||||
|
u32 ZBCSetTable(const std::vector<u8>& input, std::vector<u8>& output);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Service::Nvidia::Devices
|
} // namespace Service::Nvidia::Devices
|
||||||
|
Loading…
Reference in New Issue
Block a user