Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
74a18b7c18 | ||
|
74fe814329 | ||
|
d1a093e5ca |
@@ -486,20 +486,6 @@ namespace Ryujinx.Graphics.Vulkan
|
|||||||
pExtendedFeatures = &featuresFragmentShaderInterlock;
|
pExtendedFeatures = &featuresFragmentShaderInterlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
PhysicalDeviceSubgroupSizeControlFeaturesEXT featuresSubgroupSizeControl;
|
|
||||||
|
|
||||||
if (physicalDevice.IsDeviceExtensionPresent("VK_EXT_subgroup_size_control"))
|
|
||||||
{
|
|
||||||
featuresSubgroupSizeControl = new PhysicalDeviceSubgroupSizeControlFeaturesEXT
|
|
||||||
{
|
|
||||||
SType = StructureType.PhysicalDeviceSubgroupSizeControlFeaturesExt,
|
|
||||||
PNext = pExtendedFeatures,
|
|
||||||
SubgroupSizeControl = true,
|
|
||||||
};
|
|
||||||
|
|
||||||
pExtendedFeatures = &featuresSubgroupSizeControl;
|
|
||||||
}
|
|
||||||
|
|
||||||
PhysicalDeviceCustomBorderColorFeaturesEXT featuresCustomBorderColor;
|
PhysicalDeviceCustomBorderColorFeaturesEXT featuresCustomBorderColor;
|
||||||
|
|
||||||
if (physicalDevice.IsDeviceExtensionPresent("VK_EXT_custom_border_color") &&
|
if (physicalDevice.IsDeviceExtensionPresent("VK_EXT_custom_border_color") &&
|
||||||
|
@@ -673,9 +673,9 @@ namespace Ryujinx.HLE.HOS.Kernel.Memory
|
|||||||
MemoryState.UnmapProcessCodeMemoryAllowed,
|
MemoryState.UnmapProcessCodeMemoryAllowed,
|
||||||
KMemoryPermission.None,
|
KMemoryPermission.None,
|
||||||
KMemoryPermission.None,
|
KMemoryPermission.None,
|
||||||
MemoryAttribute.Mask,
|
MemoryAttribute.Mask & ~MemoryAttribute.PermissionLocked,
|
||||||
MemoryAttribute.None,
|
MemoryAttribute.None,
|
||||||
MemoryAttribute.IpcAndDeviceMapped | MemoryAttribute.PermissionLocked,
|
MemoryAttribute.IpcAndDeviceMapped,
|
||||||
out MemoryState state,
|
out MemoryState state,
|
||||||
out _,
|
out _,
|
||||||
out _);
|
out _);
|
||||||
|
@@ -50,6 +50,12 @@ namespace Ryujinx.HLE.HOS.Services.Nv.NvDrvServices.NvHostCtrlGpu
|
|||||||
case 0x06:
|
case 0x06:
|
||||||
result = CallIoctlMethod<GetTpcMasksArguments>(GetTpcMasks, arguments);
|
result = CallIoctlMethod<GetTpcMasksArguments>(GetTpcMasks, arguments);
|
||||||
break;
|
break;
|
||||||
|
case 0x12:
|
||||||
|
result = CallIoctlMethod<NumVsmsArguments>(NumVsms, arguments);
|
||||||
|
break;
|
||||||
|
case 0x13:
|
||||||
|
result = CallIoctlMethod<VsmsMappingArguments>(VsmsMapping, arguments);
|
||||||
|
break;
|
||||||
case 0x14:
|
case 0x14:
|
||||||
result = CallIoctlMethod<GetActiveSlotMaskArguments>(GetActiveSlotMask, arguments);
|
result = CallIoctlMethod<GetActiveSlotMaskArguments>(GetActiveSlotMask, arguments);
|
||||||
break;
|
break;
|
||||||
@@ -76,6 +82,12 @@ namespace Ryujinx.HLE.HOS.Services.Nv.NvDrvServices.NvHostCtrlGpu
|
|||||||
case 0x06:
|
case 0x06:
|
||||||
result = CallIoctlMethod<GetTpcMasksArguments, int>(GetTpcMasks, arguments, inlineOutBuffer);
|
result = CallIoctlMethod<GetTpcMasksArguments, int>(GetTpcMasks, arguments, inlineOutBuffer);
|
||||||
break;
|
break;
|
||||||
|
case 0x12:
|
||||||
|
result = CallIoctlMethod<NumVsmsArguments>(NumVsms, arguments);
|
||||||
|
break;
|
||||||
|
case 0x13:
|
||||||
|
result = CallIoctlMethod<VsmsMappingArguments>(VsmsMapping, arguments);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -216,6 +228,27 @@ namespace Ryujinx.HLE.HOS.Services.Nv.NvDrvServices.NvHostCtrlGpu
|
|||||||
return NvInternalResult.Success;
|
return NvInternalResult.Success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private NvInternalResult NumVsms(ref NumVsmsArguments arguments)
|
||||||
|
{
|
||||||
|
Logger.Stub?.PrintStub(LogClass.ServiceNv);
|
||||||
|
|
||||||
|
arguments.NumVsms = 2;
|
||||||
|
|
||||||
|
return NvInternalResult.Success;
|
||||||
|
}
|
||||||
|
|
||||||
|
private NvInternalResult VsmsMapping(ref VsmsMappingArguments arguments)
|
||||||
|
{
|
||||||
|
Logger.Stub?.PrintStub(LogClass.ServiceNv);
|
||||||
|
|
||||||
|
arguments.Sm0GpcIndex = 0;
|
||||||
|
arguments.Sm0TpcIndex = 0;
|
||||||
|
arguments.Sm1GpcIndex = 0;
|
||||||
|
arguments.Sm1TpcIndex = 1;
|
||||||
|
|
||||||
|
return NvInternalResult.Success;
|
||||||
|
}
|
||||||
|
|
||||||
private NvInternalResult GetActiveSlotMask(ref GetActiveSlotMaskArguments arguments)
|
private NvInternalResult GetActiveSlotMask(ref GetActiveSlotMaskArguments arguments)
|
||||||
{
|
{
|
||||||
Logger.Stub?.PrintStub(LogClass.ServiceNv);
|
Logger.Stub?.PrintStub(LogClass.ServiceNv);
|
||||||
|
@@ -0,0 +1,11 @@
|
|||||||
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
|
namespace Ryujinx.HLE.HOS.Services.Nv.NvDrvServices.NvHostCtrlGpu.Types
|
||||||
|
{
|
||||||
|
[StructLayout(LayoutKind.Sequential)]
|
||||||
|
struct NumVsmsArguments
|
||||||
|
{
|
||||||
|
public uint NumVsms;
|
||||||
|
public uint Reserved;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,13 @@
|
|||||||
|
using System.Runtime.InteropServices;
|
||||||
|
|
||||||
|
namespace Ryujinx.HLE.HOS.Services.Nv.NvDrvServices.NvHostCtrlGpu.Types
|
||||||
|
{
|
||||||
|
[StructLayout(LayoutKind.Sequential)]
|
||||||
|
struct VsmsMappingArguments
|
||||||
|
{
|
||||||
|
public byte Sm0GpcIndex;
|
||||||
|
public byte Sm0TpcIndex;
|
||||||
|
public byte Sm1GpcIndex;
|
||||||
|
public byte Sm1TpcIndex;
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user