mirror of
https://github.com/NVIDIA/open-gpu-kernel-modules.git
synced 2026-02-01 05:59:48 +00:00
1224 lines
57 KiB
C
1224 lines
57 KiB
C
#define NVOC_KERNEL_CHANNEL_H_PRIVATE_ACCESS_ALLOWED
|
|
#include "nvoc/runtime.h"
|
|
#include "nvoc/rtti.h"
|
|
#include "nvtypes.h"
|
|
#include "nvport/nvport.h"
|
|
#include "nvport/inline/util_valist.h"
|
|
#include "utils/nvassert.h"
|
|
#include "g_kernel_channel_nvoc.h"
|
|
|
|
#ifdef DEBUG
|
|
char __nvoc_class_id_uniqueness_check_0x5d8d70 = 1;
|
|
#endif
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_KernelChannel;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_Object;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_RsResource;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_RmResourceCommon;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_RmResource;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_GpuResource;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_INotifier;
|
|
|
|
extern const struct NVOC_CLASS_DEF __nvoc_class_def_Notifier;
|
|
|
|
void __nvoc_init_KernelChannel(KernelChannel*, RmHalspecOwner* );
|
|
void __nvoc_init_funcTable_KernelChannel(KernelChannel*, RmHalspecOwner* );
|
|
NV_STATUS __nvoc_ctor_KernelChannel(KernelChannel*, RmHalspecOwner* , CALL_CONTEXT * arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams);
|
|
void __nvoc_init_dataField_KernelChannel(KernelChannel*, RmHalspecOwner* );
|
|
void __nvoc_dtor_KernelChannel(KernelChannel*);
|
|
extern const struct NVOC_EXPORT_INFO __nvoc_export_info_KernelChannel;
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_KernelChannel = {
|
|
/*pClassDef=*/ &__nvoc_class_def_KernelChannel,
|
|
/*dtor=*/ (NVOC_DYNAMIC_DTOR) &__nvoc_dtor_KernelChannel,
|
|
/*offset=*/ 0,
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_Object = {
|
|
/*pClassDef=*/ &__nvoc_class_def_Object,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource.__nvoc_base_Object),
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_RsResource = {
|
|
/*pClassDef=*/ &__nvoc_class_def_RsResource,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource),
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_RmResourceCommon = {
|
|
/*pClassDef=*/ &__nvoc_class_def_RmResourceCommon,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RmResourceCommon),
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_RmResource = {
|
|
/*pClassDef=*/ &__nvoc_class_def_RmResource,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_GpuResource.__nvoc_base_RmResource),
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_GpuResource = {
|
|
/*pClassDef=*/ &__nvoc_class_def_GpuResource,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_GpuResource),
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_INotifier = {
|
|
/*pClassDef=*/ &__nvoc_class_def_INotifier,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_Notifier.__nvoc_base_INotifier),
|
|
};
|
|
|
|
static const struct NVOC_RTTI __nvoc_rtti_KernelChannel_Notifier = {
|
|
/*pClassDef=*/ &__nvoc_class_def_Notifier,
|
|
/*dtor=*/ &__nvoc_destructFromBase,
|
|
/*offset=*/ NV_OFFSETOF(KernelChannel, __nvoc_base_Notifier),
|
|
};
|
|
|
|
static const struct NVOC_CASTINFO __nvoc_castinfo_KernelChannel = {
|
|
/*numRelatives=*/ 8,
|
|
/*relatives=*/ {
|
|
&__nvoc_rtti_KernelChannel_KernelChannel,
|
|
&__nvoc_rtti_KernelChannel_Notifier,
|
|
&__nvoc_rtti_KernelChannel_INotifier,
|
|
&__nvoc_rtti_KernelChannel_GpuResource,
|
|
&__nvoc_rtti_KernelChannel_RmResource,
|
|
&__nvoc_rtti_KernelChannel_RmResourceCommon,
|
|
&__nvoc_rtti_KernelChannel_RsResource,
|
|
&__nvoc_rtti_KernelChannel_Object,
|
|
},
|
|
};
|
|
|
|
const struct NVOC_CLASS_DEF __nvoc_class_def_KernelChannel =
|
|
{
|
|
/*classInfo=*/ {
|
|
/*size=*/ sizeof(KernelChannel),
|
|
/*classId=*/ classId(KernelChannel),
|
|
/*providerId=*/ &__nvoc_rtti_provider,
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*name=*/ "KernelChannel",
|
|
#endif
|
|
},
|
|
/*objCreatefn=*/ (NVOC_DYNAMIC_OBJ_CREATE) &__nvoc_objCreateDynamic_KernelChannel,
|
|
/*pCastInfo=*/ &__nvoc_castinfo_KernelChannel,
|
|
/*pExportInfo=*/ &__nvoc_export_info_KernelChannel
|
|
};
|
|
|
|
#if !defined(NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG)
|
|
#define NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(x) (0)
|
|
#endif
|
|
|
|
static const struct NVOC_EXPORTED_METHOD_DEF __nvoc_exported_method_def_KernelChannel[] =
|
|
{
|
|
{ /* [0] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlSetTpcPartitionMode_a094e1,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x900101u,
|
|
/*paramSize=*/ sizeof(NV0090_CTRL_TPC_PARTITION_MODE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlSetTpcPartitionMode"
|
|
#endif
|
|
},
|
|
{ /* [1] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlGetTpcPartitionMode_a094e1,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x900103u,
|
|
/*paramSize=*/ sizeof(NV0090_CTRL_TPC_PARTITION_MODE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlGetTpcPartitionMode"
|
|
#endif
|
|
},
|
|
{ /* [2] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlGetMMUDebugMode_a094e1,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x900105u,
|
|
/*paramSize=*/ sizeof(NV0090_CTRL_GET_MMU_DEBUG_MODE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlGetMMUDebugMode"
|
|
#endif
|
|
},
|
|
{ /* [3] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlProgramVidmemPromote_a094e1,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x900107u,
|
|
/*paramSize=*/ sizeof(NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlProgramVidmemPromote"
|
|
#endif
|
|
},
|
|
{ /* [4] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdResetIsolatedChannel_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x506f0105u,
|
|
/*paramSize=*/ sizeof(NV506F_CTRL_CMD_RESET_ISOLATED_CHANNEL_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdResetIsolatedChannel"
|
|
#endif
|
|
},
|
|
{ /* [5] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0xc8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdInternalResetIsolatedChannel_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0xc8u)
|
|
/*flags=*/ 0xc8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x506f0106u,
|
|
/*paramSize=*/ sizeof(NV506F_CTRL_CMD_INTERNAL_RESET_ISOLATED_CHANNEL_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdInternalResetIsolatedChannel"
|
|
#endif
|
|
},
|
|
{ /* [6] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetClassEngineid_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x906f0101u,
|
|
/*paramSize=*/ sizeof(NV906F_CTRL_GET_CLASS_ENGINEID_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetClassEngineid"
|
|
#endif
|
|
},
|
|
{ /* [7] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdResetChannel_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x906f0102u,
|
|
/*paramSize=*/ sizeof(NV906F_CTRL_CMD_RESET_CHANNEL_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdResetChannel"
|
|
#endif
|
|
},
|
|
{ /* [8] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetDeferRCState_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x906f0105u,
|
|
/*paramSize=*/ sizeof(NV906F_CTRL_CMD_GET_DEFER_RC_STATE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetDeferRCState"
|
|
#endif
|
|
},
|
|
{ /* [9] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetMmuFaultInfo_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x906f0106u,
|
|
/*paramSize=*/ sizeof(NV906F_CTRL_GET_MMU_FAULT_INFO_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetMmuFaultInfo"
|
|
#endif
|
|
},
|
|
{ /* [10] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdEventSetNotification_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0x906f0203u,
|
|
/*paramSize=*/ sizeof(NV906F_CTRL_EVENT_SET_NOTIFICATION_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdEventSetNotification"
|
|
#endif
|
|
},
|
|
{ /* [11] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGpFifoSchedule_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xa06f0103u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_GPFIFO_SCHEDULE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGpFifoSchedule"
|
|
#endif
|
|
},
|
|
{ /* [12] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdBind_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xa06f0104u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_BIND_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdBind"
|
|
#endif
|
|
},
|
|
{ /* [13] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdSetErrorNotifier_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xa06f0108u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_SET_ERROR_NOTIFIER_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdSetErrorNotifier"
|
|
#endif
|
|
},
|
|
{ /* [14] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x28u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdSetInterleaveLevel_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x28u)
|
|
/*flags=*/ 0x28u,
|
|
/*accessRight=*/0x2u,
|
|
/*methodId=*/ 0xa06f0109u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_INTERLEAVE_LEVEL_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdSetInterleaveLevel"
|
|
#endif
|
|
},
|
|
{ /* [15] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdRestartRunlist_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x2u,
|
|
/*methodId=*/ 0xa06f0111u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_RESTART_RUNLIST_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdRestartRunlist"
|
|
#endif
|
|
},
|
|
{ /* [16] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdStopChannel_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xa06f0112u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_STOP_CHANNEL_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdStopChannel"
|
|
#endif
|
|
},
|
|
{ /* [17] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetContextId_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xa06f0113u,
|
|
/*paramSize=*/ sizeof(NVA06F_CTRL_GET_CONTEXT_ID_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetContextId"
|
|
#endif
|
|
},
|
|
{ /* [18] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetEngineCtxSize_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f010bu,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_GET_ENGINE_CTX_SIZE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetEngineCtxSize"
|
|
#endif
|
|
},
|
|
{ /* [19] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetEngineCtxData_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f010cu,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_GET_ENGINE_CTX_DATA_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetEngineCtxData"
|
|
#endif
|
|
},
|
|
{ /* [20] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x4044u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdMigrateEngineCtxData_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x4044u)
|
|
/*flags=*/ 0x4044u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f010du,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_MIGRATE_ENGINE_CTX_DATA_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdMigrateEngineCtxData"
|
|
#endif
|
|
},
|
|
{ /* [21] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetEngineCtxState_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f010eu,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_GET_ENGINE_CTX_STATE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetEngineCtxState"
|
|
#endif
|
|
},
|
|
{ /* [22] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetChannelHwState_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f010fu,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_GET_CHANNEL_HW_STATE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetChannelHwState"
|
|
#endif
|
|
},
|
|
{ /* [23] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x14044u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdSetChannelHwState_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x14044u)
|
|
/*flags=*/ 0x14044u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f0110u,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_SET_CHANNEL_HW_STATE_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdSetChannelHwState"
|
|
#endif
|
|
},
|
|
{ /* [24] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdSaveEngineCtxData_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
/*flags=*/ 0x48u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f0111u,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_SAVE_ENGINE_CTX_DATA_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdSaveEngineCtxData"
|
|
#endif
|
|
},
|
|
{ /* [25] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x14044u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdRestoreEngineCtxData_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x14044u)
|
|
/*flags=*/ 0x14044u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xb06f0112u,
|
|
/*paramSize=*/ sizeof(NVB06F_CTRL_RESTORE_ENGINE_CTX_DATA_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdRestoreEngineCtxData"
|
|
#endif
|
|
},
|
|
{ /* [26] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGpfifoGetWorkSubmitToken_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xc36f0108u,
|
|
/*paramSize=*/ sizeof(NVC36F_CTRL_CMD_GPFIFO_GET_WORK_SUBMIT_TOKEN_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGpfifoGetWorkSubmitToken"
|
|
#endif
|
|
},
|
|
{ /* [27] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x244u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGpfifoUpdateFaultMethodBuffer_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x244u)
|
|
/*flags=*/ 0x244u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xc36f0109u,
|
|
/*paramSize=*/ sizeof(NVC36F_CTRL_GPFIFO_UPDATE_FAULT_METHOD_BUFFER_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGpfifoUpdateFaultMethodBuffer"
|
|
#endif
|
|
},
|
|
{ /* [28] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGpfifoSetWorkSubmitTokenNotifIndex_IMPL,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xc36f010au,
|
|
/*paramSize=*/ sizeof(NVC36F_CTRL_GPFIFO_SET_WORK_SUBMIT_TOKEN_NOTIF_INDEX_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGpfifoSetWorkSubmitTokenNotifIndex"
|
|
#endif
|
|
},
|
|
{ /* [29] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlCmdGetKmb_DISPATCH,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xc56f010bu,
|
|
/*paramSize=*/ sizeof(NVC56F_CTRL_CMD_GET_KMB_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlCmdGetKmb"
|
|
#endif
|
|
},
|
|
{ /* [30] */
|
|
#if NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*pFunc=*/ (void (*)(void)) NULL,
|
|
#else
|
|
/*pFunc=*/ (void (*)(void)) kchannelCtrlRotateSecureChannelIv_DISPATCH,
|
|
#endif // NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
/*flags=*/ 0x8u,
|
|
/*accessRight=*/0x0u,
|
|
/*methodId=*/ 0xc56f010cu,
|
|
/*paramSize=*/ sizeof(NVC56F_CTRL_ROTATE_SECURE_CHANNEL_IV_PARAMS),
|
|
/*pClassInfo=*/ &(__nvoc_class_def_KernelChannel.classInfo),
|
|
#if NV_PRINTF_STRINGS_ALLOWED
|
|
/*func=*/ "kchannelCtrlRotateSecureChannelIv"
|
|
#endif
|
|
},
|
|
|
|
};
|
|
|
|
// 5 down-thunk(s) defined to bridge methods in KernelChannel from superclasses
|
|
|
|
// kchannelMap: virtual override (res) base (gpures)
|
|
static NV_STATUS __nvoc_down_thunk_KernelChannel_gpuresMap(struct GpuResource *pKernelChannel, CALL_CONTEXT *pCallContext, struct RS_CPU_MAP_PARAMS *pParams, RsCpuMapping *pCpuMapping) {
|
|
return kchannelMap((struct KernelChannel *)(((unsigned char *) pKernelChannel) - __nvoc_rtti_KernelChannel_GpuResource.offset), pCallContext, pParams, pCpuMapping);
|
|
}
|
|
|
|
// kchannelUnmap: virtual override (res) base (gpures)
|
|
static NV_STATUS __nvoc_down_thunk_KernelChannel_gpuresUnmap(struct GpuResource *pKernelChannel, CALL_CONTEXT *pCallContext, RsCpuMapping *pCpuMapping) {
|
|
return kchannelUnmap((struct KernelChannel *)(((unsigned char *) pKernelChannel) - __nvoc_rtti_KernelChannel_GpuResource.offset), pCallContext, pCpuMapping);
|
|
}
|
|
|
|
// kchannelGetMapAddrSpace: virtual override (gpures) base (gpures)
|
|
static NV_STATUS __nvoc_down_thunk_KernelChannel_gpuresGetMapAddrSpace(struct GpuResource *pKernelChannel, CALL_CONTEXT *pCallContext, NvU32 mapFlags, NV_ADDRESS_SPACE *pAddrSpace) {
|
|
return kchannelGetMapAddrSpace((struct KernelChannel *)(((unsigned char *) pKernelChannel) - __nvoc_rtti_KernelChannel_GpuResource.offset), pCallContext, mapFlags, pAddrSpace);
|
|
}
|
|
|
|
// kchannelGetMemInterMapParams: virtual override (rmres) base (gpures)
|
|
static NV_STATUS __nvoc_down_thunk_KernelChannel_rmresGetMemInterMapParams(struct RmResource *pKernelChannel, RMRES_MEM_INTER_MAP_PARAMS *pParams) {
|
|
return kchannelGetMemInterMapParams((struct KernelChannel *)(((unsigned char *) pKernelChannel) - __nvoc_rtti_KernelChannel_RmResource.offset), pParams);
|
|
}
|
|
|
|
// kchannelCheckMemInterUnmap: virtual override (rmres) base (gpures)
|
|
static NV_STATUS __nvoc_down_thunk_KernelChannel_rmresCheckMemInterUnmap(struct RmResource *pKernelChannel, NvBool bSubdeviceHandleProvided) {
|
|
return kchannelCheckMemInterUnmap((struct KernelChannel *)(((unsigned char *) pKernelChannel) - __nvoc_rtti_KernelChannel_RmResource.offset), bSubdeviceHandleProvided);
|
|
}
|
|
|
|
|
|
// 25 up-thunk(s) defined to bridge methods in KernelChannel to superclasses
|
|
|
|
// kchannelControl: virtual inherited (gpures) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_GpuResource_kchannelControl(struct KernelChannel *pGpuResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
|
|
return gpuresControl((struct GpuResource *)(((unsigned char *) pGpuResource) + __nvoc_rtti_KernelChannel_GpuResource.offset), pCallContext, pParams);
|
|
}
|
|
|
|
// kchannelShareCallback: virtual inherited (gpures) base (gpures)
|
|
static NvBool __nvoc_up_thunk_GpuResource_kchannelShareCallback(struct KernelChannel *pGpuResource, struct RsClient *pInvokingClient, struct RsResourceRef *pParentRef, RS_SHARE_POLICY *pSharePolicy) {
|
|
return gpuresShareCallback((struct GpuResource *)(((unsigned char *) pGpuResource) + __nvoc_rtti_KernelChannel_GpuResource.offset), pInvokingClient, pParentRef, pSharePolicy);
|
|
}
|
|
|
|
// kchannelGetRegBaseOffsetAndSize: virtual inherited (gpures) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_GpuResource_kchannelGetRegBaseOffsetAndSize(struct KernelChannel *pGpuResource, struct OBJGPU *pGpu, NvU32 *pOffset, NvU32 *pSize) {
|
|
return gpuresGetRegBaseOffsetAndSize((struct GpuResource *)(((unsigned char *) pGpuResource) + __nvoc_rtti_KernelChannel_GpuResource.offset), pGpu, pOffset, pSize);
|
|
}
|
|
|
|
// kchannelInternalControlForward: virtual inherited (gpures) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_GpuResource_kchannelInternalControlForward(struct KernelChannel *pGpuResource, NvU32 command, void *pParams, NvU32 size) {
|
|
return gpuresInternalControlForward((struct GpuResource *)(((unsigned char *) pGpuResource) + __nvoc_rtti_KernelChannel_GpuResource.offset), command, pParams, size);
|
|
}
|
|
|
|
// kchannelGetInternalObjectHandle: virtual inherited (gpures) base (gpures)
|
|
static NvHandle __nvoc_up_thunk_GpuResource_kchannelGetInternalObjectHandle(struct KernelChannel *pGpuResource) {
|
|
return gpuresGetInternalObjectHandle((struct GpuResource *)(((unsigned char *) pGpuResource) + __nvoc_rtti_KernelChannel_GpuResource.offset));
|
|
}
|
|
|
|
// kchannelAccessCallback: virtual inherited (rmres) base (gpures)
|
|
static NvBool __nvoc_up_thunk_RmResource_kchannelAccessCallback(struct KernelChannel *pResource, struct RsClient *pInvokingClient, void *pAllocParams, RsAccessRight accessRight) {
|
|
return rmresAccessCallback((struct RmResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RmResource.offset), pInvokingClient, pAllocParams, accessRight);
|
|
}
|
|
|
|
// kchannelGetMemoryMappingDescriptor: virtual inherited (rmres) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RmResource_kchannelGetMemoryMappingDescriptor(struct KernelChannel *pRmResource, struct MEMORY_DESCRIPTOR **ppMemDesc) {
|
|
return rmresGetMemoryMappingDescriptor((struct RmResource *)(((unsigned char *) pRmResource) + __nvoc_rtti_KernelChannel_RmResource.offset), ppMemDesc);
|
|
}
|
|
|
|
// kchannelControlSerialization_Prologue: virtual inherited (rmres) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RmResource_kchannelControlSerialization_Prologue(struct KernelChannel *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
|
|
return rmresControlSerialization_Prologue((struct RmResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RmResource.offset), pCallContext, pParams);
|
|
}
|
|
|
|
// kchannelControlSerialization_Epilogue: virtual inherited (rmres) base (gpures)
|
|
static void __nvoc_up_thunk_RmResource_kchannelControlSerialization_Epilogue(struct KernelChannel *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
|
|
rmresControlSerialization_Epilogue((struct RmResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RmResource.offset), pCallContext, pParams);
|
|
}
|
|
|
|
// kchannelControl_Prologue: virtual inherited (rmres) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RmResource_kchannelControl_Prologue(struct KernelChannel *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
|
|
return rmresControl_Prologue((struct RmResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RmResource.offset), pCallContext, pParams);
|
|
}
|
|
|
|
// kchannelControl_Epilogue: virtual inherited (rmres) base (gpures)
|
|
static void __nvoc_up_thunk_RmResource_kchannelControl_Epilogue(struct KernelChannel *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
|
|
rmresControl_Epilogue((struct RmResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RmResource.offset), pCallContext, pParams);
|
|
}
|
|
|
|
// kchannelCanCopy: virtual inherited (res) base (gpures)
|
|
static NvBool __nvoc_up_thunk_RsResource_kchannelCanCopy(struct KernelChannel *pResource) {
|
|
return resCanCopy((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset));
|
|
}
|
|
|
|
// kchannelIsDuplicate: virtual inherited (res) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RsResource_kchannelIsDuplicate(struct KernelChannel *pResource, NvHandle hMemory, NvBool *pDuplicate) {
|
|
return resIsDuplicate((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset), hMemory, pDuplicate);
|
|
}
|
|
|
|
// kchannelPreDestruct: virtual inherited (res) base (gpures)
|
|
static void __nvoc_up_thunk_RsResource_kchannelPreDestruct(struct KernelChannel *pResource) {
|
|
resPreDestruct((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset));
|
|
}
|
|
|
|
// kchannelControlFilter: virtual inherited (res) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RsResource_kchannelControlFilter(struct KernelChannel *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
|
|
return resControlFilter((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset), pCallContext, pParams);
|
|
}
|
|
|
|
// kchannelIsPartialUnmapSupported: inline virtual inherited (res) base (gpures) body
|
|
static NvBool __nvoc_up_thunk_RsResource_kchannelIsPartialUnmapSupported(struct KernelChannel *pResource) {
|
|
return resIsPartialUnmapSupported((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset));
|
|
}
|
|
|
|
// kchannelMapTo: virtual inherited (res) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RsResource_kchannelMapTo(struct KernelChannel *pResource, RS_RES_MAP_TO_PARAMS *pParams) {
|
|
return resMapTo((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset), pParams);
|
|
}
|
|
|
|
// kchannelUnmapFrom: virtual inherited (res) base (gpures)
|
|
static NV_STATUS __nvoc_up_thunk_RsResource_kchannelUnmapFrom(struct KernelChannel *pResource, RS_RES_UNMAP_FROM_PARAMS *pParams) {
|
|
return resUnmapFrom((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset), pParams);
|
|
}
|
|
|
|
// kchannelGetRefCount: virtual inherited (res) base (gpures)
|
|
static NvU32 __nvoc_up_thunk_RsResource_kchannelGetRefCount(struct KernelChannel *pResource) {
|
|
return resGetRefCount((struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset));
|
|
}
|
|
|
|
// kchannelAddAdditionalDependants: virtual inherited (res) base (gpures)
|
|
static void __nvoc_up_thunk_RsResource_kchannelAddAdditionalDependants(struct RsClient *pClient, struct KernelChannel *pResource, RsResourceRef *pReference) {
|
|
resAddAdditionalDependants(pClient, (struct RsResource *)(((unsigned char *) pResource) + __nvoc_rtti_KernelChannel_RsResource.offset), pReference);
|
|
}
|
|
|
|
// kchannelGetNotificationListPtr: virtual inherited (notify) base (notify)
|
|
static PEVENTNOTIFICATION * __nvoc_up_thunk_Notifier_kchannelGetNotificationListPtr(struct KernelChannel *pNotifier) {
|
|
return notifyGetNotificationListPtr((struct Notifier *)(((unsigned char *) pNotifier) + __nvoc_rtti_KernelChannel_Notifier.offset));
|
|
}
|
|
|
|
// kchannelGetNotificationShare: virtual inherited (notify) base (notify)
|
|
static struct NotifShare * __nvoc_up_thunk_Notifier_kchannelGetNotificationShare(struct KernelChannel *pNotifier) {
|
|
return notifyGetNotificationShare((struct Notifier *)(((unsigned char *) pNotifier) + __nvoc_rtti_KernelChannel_Notifier.offset));
|
|
}
|
|
|
|
// kchannelSetNotificationShare: virtual inherited (notify) base (notify)
|
|
static void __nvoc_up_thunk_Notifier_kchannelSetNotificationShare(struct KernelChannel *pNotifier, struct NotifShare *pNotifShare) {
|
|
notifySetNotificationShare((struct Notifier *)(((unsigned char *) pNotifier) + __nvoc_rtti_KernelChannel_Notifier.offset), pNotifShare);
|
|
}
|
|
|
|
// kchannelUnregisterEvent: virtual inherited (notify) base (notify)
|
|
static NV_STATUS __nvoc_up_thunk_Notifier_kchannelUnregisterEvent(struct KernelChannel *pNotifier, NvHandle hNotifierClient, NvHandle hNotifierResource, NvHandle hEventClient, NvHandle hEvent) {
|
|
return notifyUnregisterEvent((struct Notifier *)(((unsigned char *) pNotifier) + __nvoc_rtti_KernelChannel_Notifier.offset), hNotifierClient, hNotifierResource, hEventClient, hEvent);
|
|
}
|
|
|
|
// kchannelGetOrAllocNotifShare: virtual inherited (notify) base (notify)
|
|
static NV_STATUS __nvoc_up_thunk_Notifier_kchannelGetOrAllocNotifShare(struct KernelChannel *pNotifier, NvHandle hNotifierClient, NvHandle hNotifierResource, struct NotifShare **ppNotifShare) {
|
|
return notifyGetOrAllocNotifShare((struct Notifier *)(((unsigned char *) pNotifier) + __nvoc_rtti_KernelChannel_Notifier.offset), hNotifierClient, hNotifierResource, ppNotifShare);
|
|
}
|
|
|
|
|
|
const struct NVOC_EXPORT_INFO __nvoc_export_info_KernelChannel =
|
|
{
|
|
/*numEntries=*/ 31,
|
|
/*pExportEntries=*/ __nvoc_exported_method_def_KernelChannel
|
|
};
|
|
|
|
void __nvoc_dtor_GpuResource(GpuResource*);
|
|
void __nvoc_dtor_Notifier(Notifier*);
|
|
void __nvoc_dtor_KernelChannel(KernelChannel *pThis) {
|
|
__nvoc_kchannelDestruct(pThis);
|
|
__nvoc_dtor_GpuResource(&pThis->__nvoc_base_GpuResource);
|
|
__nvoc_dtor_Notifier(&pThis->__nvoc_base_Notifier);
|
|
PORT_UNREFERENCED_VARIABLE(pThis);
|
|
}
|
|
|
|
void __nvoc_init_dataField_KernelChannel(KernelChannel *pThis, RmHalspecOwner *pRmhalspecowner) {
|
|
RmVariantHal *rmVariantHal = &pRmhalspecowner->rmVariantHal;
|
|
const unsigned long rmVariantHal_HalVarIdx = (unsigned long)rmVariantHal->__nvoc_HalVarIdx;
|
|
ChipHal *chipHal = &pRmhalspecowner->chipHal;
|
|
const unsigned long chipHal_HalVarIdx = (unsigned long)chipHal->__nvoc_HalVarIdx;
|
|
PORT_UNREFERENCED_VARIABLE(pThis);
|
|
PORT_UNREFERENCED_VARIABLE(pRmhalspecowner);
|
|
PORT_UNREFERENCED_VARIABLE(rmVariantHal);
|
|
PORT_UNREFERENCED_VARIABLE(rmVariantHal_HalVarIdx);
|
|
PORT_UNREFERENCED_VARIABLE(chipHal);
|
|
PORT_UNREFERENCED_VARIABLE(chipHal_HalVarIdx);
|
|
}
|
|
|
|
NV_STATUS __nvoc_ctor_GpuResource(GpuResource* , CALL_CONTEXT *, struct RS_RES_ALLOC_PARAMS_INTERNAL *);
|
|
NV_STATUS __nvoc_ctor_Notifier(Notifier* , CALL_CONTEXT *);
|
|
NV_STATUS __nvoc_ctor_KernelChannel(KernelChannel *pThis, RmHalspecOwner *pRmhalspecowner, CALL_CONTEXT * arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams) {
|
|
NV_STATUS status = NV_OK;
|
|
status = __nvoc_ctor_GpuResource(&pThis->__nvoc_base_GpuResource, arg_pCallContext, arg_pParams);
|
|
if (status != NV_OK) goto __nvoc_ctor_KernelChannel_fail_GpuResource;
|
|
status = __nvoc_ctor_Notifier(&pThis->__nvoc_base_Notifier, arg_pCallContext);
|
|
if (status != NV_OK) goto __nvoc_ctor_KernelChannel_fail_Notifier;
|
|
__nvoc_init_dataField_KernelChannel(pThis, pRmhalspecowner);
|
|
|
|
status = __nvoc_kchannelConstruct(pThis, arg_pCallContext, arg_pParams);
|
|
if (status != NV_OK) goto __nvoc_ctor_KernelChannel_fail__init;
|
|
goto __nvoc_ctor_KernelChannel_exit; // Success
|
|
|
|
__nvoc_ctor_KernelChannel_fail__init:
|
|
__nvoc_dtor_Notifier(&pThis->__nvoc_base_Notifier);
|
|
__nvoc_ctor_KernelChannel_fail_Notifier:
|
|
__nvoc_dtor_GpuResource(&pThis->__nvoc_base_GpuResource);
|
|
__nvoc_ctor_KernelChannel_fail_GpuResource:
|
|
__nvoc_ctor_KernelChannel_exit:
|
|
|
|
return status;
|
|
}
|
|
|
|
// Vtable initialization
|
|
static void __nvoc_init_funcTable_KernelChannel_1(KernelChannel *pThis, RmHalspecOwner *pRmhalspecowner) {
|
|
RmVariantHal *rmVariantHal = &pRmhalspecowner->rmVariantHal;
|
|
const unsigned long rmVariantHal_HalVarIdx = (unsigned long)rmVariantHal->__nvoc_HalVarIdx;
|
|
ChipHal *chipHal = &pRmhalspecowner->chipHal;
|
|
const unsigned long chipHal_HalVarIdx = (unsigned long)chipHal->__nvoc_HalVarIdx;
|
|
PORT_UNREFERENCED_VARIABLE(pThis);
|
|
PORT_UNREFERENCED_VARIABLE(pRmhalspecowner);
|
|
PORT_UNREFERENCED_VARIABLE(rmVariantHal);
|
|
PORT_UNREFERENCED_VARIABLE(rmVariantHal_HalVarIdx);
|
|
PORT_UNREFERENCED_VARIABLE(chipHal);
|
|
PORT_UNREFERENCED_VARIABLE(chipHal_HalVarIdx);
|
|
|
|
// kchannelMap -- virtual override (res) base (gpures)
|
|
pThis->__kchannelMap__ = &kchannelMap_IMPL;
|
|
pThis->__nvoc_base_GpuResource.__gpuresMap__ = &__nvoc_down_thunk_KernelChannel_gpuresMap;
|
|
|
|
// kchannelUnmap -- virtual override (res) base (gpures)
|
|
pThis->__kchannelUnmap__ = &kchannelUnmap_IMPL;
|
|
pThis->__nvoc_base_GpuResource.__gpuresUnmap__ = &__nvoc_down_thunk_KernelChannel_gpuresUnmap;
|
|
|
|
// kchannelGetMapAddrSpace -- virtual override (gpures) base (gpures)
|
|
pThis->__kchannelGetMapAddrSpace__ = &kchannelGetMapAddrSpace_IMPL;
|
|
pThis->__nvoc_base_GpuResource.__gpuresGetMapAddrSpace__ = &__nvoc_down_thunk_KernelChannel_gpuresGetMapAddrSpace;
|
|
|
|
// kchannelGetMemInterMapParams -- virtual override (rmres) base (gpures)
|
|
pThis->__kchannelGetMemInterMapParams__ = &kchannelGetMemInterMapParams_IMPL;
|
|
pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__rmresGetMemInterMapParams__ = &__nvoc_down_thunk_KernelChannel_rmresGetMemInterMapParams;
|
|
|
|
// kchannelCheckMemInterUnmap -- virtual override (rmres) base (gpures)
|
|
pThis->__kchannelCheckMemInterUnmap__ = &kchannelCheckMemInterUnmap_IMPL;
|
|
pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__rmresCheckMemInterUnmap__ = &__nvoc_down_thunk_KernelChannel_rmresCheckMemInterUnmap;
|
|
|
|
// kchannelCreateUserMemDesc -- halified (2 hals)
|
|
if (( ((chipHal_HalVarIdx >> 5) == 1UL) && ((1UL << (chipHal_HalVarIdx & 0x1f)) & 0xd0000000UL) )) /* ChipHal: GH100 | GB100 | GB102 */
|
|
{
|
|
pThis->__kchannelCreateUserMemDesc__ = &kchannelCreateUserMemDesc_GA10B;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelCreateUserMemDesc__ = &kchannelCreateUserMemDesc_GM107;
|
|
}
|
|
|
|
// kchannelIsUserdAddrSizeValid -- halified (3 hals) body
|
|
if (( ((chipHal_HalVarIdx >> 5) == 1UL) && ((1UL << (chipHal_HalVarIdx & 0x1f)) & 0xd0000000UL) )) /* ChipHal: GH100 | GB100 | GB102 */
|
|
{
|
|
pThis->__kchannelIsUserdAddrSizeValid__ = &kchannelIsUserdAddrSizeValid_GH100;
|
|
}
|
|
else if (( ((chipHal_HalVarIdx >> 5) == 1UL) && ((1UL << (chipHal_HalVarIdx & 0x1f)) & 0x000003e0UL) )) /* ChipHal: TU102 | TU104 | TU106 | TU116 | TU117 */
|
|
{
|
|
pThis->__kchannelIsUserdAddrSizeValid__ = &kchannelIsUserdAddrSizeValid_GV100;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelIsUserdAddrSizeValid__ = &kchannelIsUserdAddrSizeValid_GA100;
|
|
}
|
|
|
|
// kchannelCtrlCmdResetIsolatedChannel -- exported (id=0x506f0105)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdResetIsolatedChannel__ = &kchannelCtrlCmdResetIsolatedChannel_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdInternalResetIsolatedChannel -- exported (id=0x506f0106)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0xc8u)
|
|
pThis->__kchannelCtrlCmdInternalResetIsolatedChannel__ = &kchannelCtrlCmdInternalResetIsolatedChannel_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetClassEngineid -- exported (id=0x906f0101)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdGetClassEngineid__ = &kchannelCtrlCmdGetClassEngineid_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdResetChannel -- exported (id=0x906f0102)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdResetChannel__ = &kchannelCtrlCmdResetChannel_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetDeferRCState -- exported (id=0x906f0105)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdGetDeferRCState__ = &kchannelCtrlCmdGetDeferRCState_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetMmuFaultInfo -- exported (id=0x906f0106)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdGetMmuFaultInfo__ = &kchannelCtrlCmdGetMmuFaultInfo_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdEventSetNotification -- exported (id=0x906f0203)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdEventSetNotification__ = &kchannelCtrlCmdEventSetNotification_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGpFifoSchedule -- exported (id=0xa06f0103)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdGpFifoSchedule__ = &kchannelCtrlCmdGpFifoSchedule_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdBind -- exported (id=0xa06f0104)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdBind__ = &kchannelCtrlCmdBind_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdSetErrorNotifier -- exported (id=0xa06f0108)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdSetErrorNotifier__ = &kchannelCtrlCmdSetErrorNotifier_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdSetInterleaveLevel -- exported (id=0xa06f0109)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x28u)
|
|
pThis->__kchannelCtrlCmdSetInterleaveLevel__ = &kchannelCtrlCmdSetInterleaveLevel_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetContextId -- exported (id=0xa06f0113)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdGetContextId__ = &kchannelCtrlCmdGetContextId_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdRestartRunlist -- exported (id=0xa06f0111)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdRestartRunlist__ = &kchannelCtrlCmdRestartRunlist_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetEngineCtxSize -- exported (id=0xb06f010b)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdGetEngineCtxSize__ = &kchannelCtrlCmdGetEngineCtxSize_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetEngineCtxData -- exported (id=0xb06f010c)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdGetEngineCtxData__ = &kchannelCtrlCmdGetEngineCtxData_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdMigrateEngineCtxData -- exported (id=0xb06f010d)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x4044u)
|
|
pThis->__kchannelCtrlCmdMigrateEngineCtxData__ = &kchannelCtrlCmdMigrateEngineCtxData_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetEngineCtxState -- exported (id=0xb06f010e)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdGetEngineCtxState__ = &kchannelCtrlCmdGetEngineCtxState_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetChannelHwState -- exported (id=0xb06f010f)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdGetChannelHwState__ = &kchannelCtrlCmdGetChannelHwState_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdSetChannelHwState -- exported (id=0xb06f0110)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x14044u)
|
|
pThis->__kchannelCtrlCmdSetChannelHwState__ = &kchannelCtrlCmdSetChannelHwState_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdSaveEngineCtxData -- exported (id=0xb06f0111)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x48u)
|
|
pThis->__kchannelCtrlCmdSaveEngineCtxData__ = &kchannelCtrlCmdSaveEngineCtxData_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdRestoreEngineCtxData -- exported (id=0xb06f0112)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x14044u)
|
|
pThis->__kchannelCtrlCmdRestoreEngineCtxData__ = &kchannelCtrlCmdRestoreEngineCtxData_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGpfifoGetWorkSubmitToken -- exported (id=0xc36f0108)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdGpfifoGetWorkSubmitToken__ = &kchannelCtrlCmdGpfifoGetWorkSubmitToken_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGpfifoUpdateFaultMethodBuffer -- exported (id=0xc36f0109)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x244u)
|
|
pThis->__kchannelCtrlCmdGpfifoUpdateFaultMethodBuffer__ = &kchannelCtrlCmdGpfifoUpdateFaultMethodBuffer_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGpfifoSetWorkSubmitTokenNotifIndex -- exported (id=0xc36f010a)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdGpfifoSetWorkSubmitTokenNotifIndex__ = &kchannelCtrlCmdGpfifoSetWorkSubmitTokenNotifIndex_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdStopChannel -- exported (id=0xa06f0112)
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlCmdStopChannel__ = &kchannelCtrlCmdStopChannel_IMPL;
|
|
#endif
|
|
|
|
// kchannelCtrlCmdGetKmb -- halified (2 hals) exported (id=0xc56f010b) body
|
|
if (( ((rmVariantHal_HalVarIdx >> 5) == 0UL) && ((1UL << (rmVariantHal_HalVarIdx & 0x1f)) & 0x00000001UL) )) /* RmVariantHal: VF */
|
|
{
|
|
pThis->__kchannelCtrlCmdGetKmb__ = &kchannelCtrlCmdGetKmb_46f6a7;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelCtrlCmdGetKmb__ = &kchannelCtrlCmdGetKmb_KERNEL;
|
|
}
|
|
|
|
// kchannelCtrlRotateSecureChannelIv -- halified (2 hals) exported (id=0xc56f010c) body
|
|
if (( ((rmVariantHal_HalVarIdx >> 5) == 0UL) && ((1UL << (rmVariantHal_HalVarIdx & 0x1f)) & 0x00000001UL) )) /* RmVariantHal: VF */
|
|
{
|
|
pThis->__kchannelCtrlRotateSecureChannelIv__ = &kchannelCtrlRotateSecureChannelIv_46f6a7;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelCtrlRotateSecureChannelIv__ = &kchannelCtrlRotateSecureChannelIv_KERNEL;
|
|
}
|
|
|
|
// kchannelSetEncryptionStatsBuffer -- halified (2 hals) body
|
|
if (( ((rmVariantHal_HalVarIdx >> 5) == 0UL) && ((1UL << (rmVariantHal_HalVarIdx & 0x1f)) & 0x00000001UL) )) /* RmVariantHal: VF */
|
|
{
|
|
pThis->__kchannelSetEncryptionStatsBuffer__ = &kchannelSetEncryptionStatsBuffer_56cd7a;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelSetEncryptionStatsBuffer__ = &kchannelSetEncryptionStatsBuffer_KERNEL;
|
|
}
|
|
|
|
// kchannelCtrlGetTpcPartitionMode -- inline exported (id=0x900103) body
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlGetTpcPartitionMode__ = &kchannelCtrlGetTpcPartitionMode_a094e1;
|
|
#endif
|
|
|
|
// kchannelCtrlSetTpcPartitionMode -- inline exported (id=0x900101) body
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlSetTpcPartitionMode__ = &kchannelCtrlSetTpcPartitionMode_a094e1;
|
|
#endif
|
|
|
|
// kchannelCtrlGetMMUDebugMode -- inline exported (id=0x900105) body
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlGetMMUDebugMode__ = &kchannelCtrlGetMMUDebugMode_a094e1;
|
|
#endif
|
|
|
|
// kchannelCtrlProgramVidmemPromote -- inline exported (id=0x900107) body
|
|
#if !NVOC_EXPORTED_METHOD_DISABLED_BY_FLAG(0x8u)
|
|
pThis->__kchannelCtrlProgramVidmemPromote__ = &kchannelCtrlProgramVidmemPromote_a094e1;
|
|
#endif
|
|
|
|
// kchannelRetrieveKmb -- halified (2 hals) body
|
|
if (( ((rmVariantHal_HalVarIdx >> 5) == 0UL) && ((1UL << (rmVariantHal_HalVarIdx & 0x1f)) & 0x00000001UL) )) /* RmVariantHal: VF */
|
|
{
|
|
pThis->__kchannelRetrieveKmb__ = &kchannelRetrieveKmb_56cd7a;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelRetrieveKmb__ = &kchannelRetrieveKmb_KERNEL;
|
|
}
|
|
|
|
// kchannelSetKeyRotationNotifier -- halified (2 hals) body
|
|
if (( ((rmVariantHal_HalVarIdx >> 5) == 0UL) && ((1UL << (rmVariantHal_HalVarIdx & 0x1f)) & 0x00000001UL) )) /* RmVariantHal: VF */
|
|
{
|
|
pThis->__kchannelSetKeyRotationNotifier__ = &kchannelSetKeyRotationNotifier_56cd7a;
|
|
}
|
|
else
|
|
{
|
|
pThis->__kchannelSetKeyRotationNotifier__ = &kchannelSetKeyRotationNotifier_KERNEL;
|
|
}
|
|
|
|
// kchannelControl -- virtual inherited (gpures) base (gpures)
|
|
pThis->__kchannelControl__ = &__nvoc_up_thunk_GpuResource_kchannelControl;
|
|
|
|
// kchannelShareCallback -- virtual inherited (gpures) base (gpures)
|
|
pThis->__kchannelShareCallback__ = &__nvoc_up_thunk_GpuResource_kchannelShareCallback;
|
|
|
|
// kchannelGetRegBaseOffsetAndSize -- virtual inherited (gpures) base (gpures)
|
|
pThis->__kchannelGetRegBaseOffsetAndSize__ = &__nvoc_up_thunk_GpuResource_kchannelGetRegBaseOffsetAndSize;
|
|
|
|
// kchannelInternalControlForward -- virtual inherited (gpures) base (gpures)
|
|
pThis->__kchannelInternalControlForward__ = &__nvoc_up_thunk_GpuResource_kchannelInternalControlForward;
|
|
|
|
// kchannelGetInternalObjectHandle -- virtual inherited (gpures) base (gpures)
|
|
pThis->__kchannelGetInternalObjectHandle__ = &__nvoc_up_thunk_GpuResource_kchannelGetInternalObjectHandle;
|
|
|
|
// kchannelAccessCallback -- virtual inherited (rmres) base (gpures)
|
|
pThis->__kchannelAccessCallback__ = &__nvoc_up_thunk_RmResource_kchannelAccessCallback;
|
|
|
|
// kchannelGetMemoryMappingDescriptor -- virtual inherited (rmres) base (gpures)
|
|
pThis->__kchannelGetMemoryMappingDescriptor__ = &__nvoc_up_thunk_RmResource_kchannelGetMemoryMappingDescriptor;
|
|
|
|
// kchannelControlSerialization_Prologue -- virtual inherited (rmres) base (gpures)
|
|
pThis->__kchannelControlSerialization_Prologue__ = &__nvoc_up_thunk_RmResource_kchannelControlSerialization_Prologue;
|
|
|
|
// kchannelControlSerialization_Epilogue -- virtual inherited (rmres) base (gpures)
|
|
pThis->__kchannelControlSerialization_Epilogue__ = &__nvoc_up_thunk_RmResource_kchannelControlSerialization_Epilogue;
|
|
|
|
// kchannelControl_Prologue -- virtual inherited (rmres) base (gpures)
|
|
pThis->__kchannelControl_Prologue__ = &__nvoc_up_thunk_RmResource_kchannelControl_Prologue;
|
|
|
|
// kchannelControl_Epilogue -- virtual inherited (rmres) base (gpures)
|
|
pThis->__kchannelControl_Epilogue__ = &__nvoc_up_thunk_RmResource_kchannelControl_Epilogue;
|
|
|
|
// kchannelCanCopy -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelCanCopy__ = &__nvoc_up_thunk_RsResource_kchannelCanCopy;
|
|
|
|
// kchannelIsDuplicate -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelIsDuplicate__ = &__nvoc_up_thunk_RsResource_kchannelIsDuplicate;
|
|
|
|
// kchannelPreDestruct -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelPreDestruct__ = &__nvoc_up_thunk_RsResource_kchannelPreDestruct;
|
|
|
|
// kchannelControlFilter -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelControlFilter__ = &__nvoc_up_thunk_RsResource_kchannelControlFilter;
|
|
|
|
// kchannelIsPartialUnmapSupported -- inline virtual inherited (res) base (gpures) body
|
|
pThis->__kchannelIsPartialUnmapSupported__ = &__nvoc_up_thunk_RsResource_kchannelIsPartialUnmapSupported;
|
|
|
|
// kchannelMapTo -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelMapTo__ = &__nvoc_up_thunk_RsResource_kchannelMapTo;
|
|
|
|
// kchannelUnmapFrom -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelUnmapFrom__ = &__nvoc_up_thunk_RsResource_kchannelUnmapFrom;
|
|
|
|
// kchannelGetRefCount -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelGetRefCount__ = &__nvoc_up_thunk_RsResource_kchannelGetRefCount;
|
|
|
|
// kchannelAddAdditionalDependants -- virtual inherited (res) base (gpures)
|
|
pThis->__kchannelAddAdditionalDependants__ = &__nvoc_up_thunk_RsResource_kchannelAddAdditionalDependants;
|
|
|
|
// kchannelGetNotificationListPtr -- virtual inherited (notify) base (notify)
|
|
pThis->__kchannelGetNotificationListPtr__ = &__nvoc_up_thunk_Notifier_kchannelGetNotificationListPtr;
|
|
|
|
// kchannelGetNotificationShare -- virtual inherited (notify) base (notify)
|
|
pThis->__kchannelGetNotificationShare__ = &__nvoc_up_thunk_Notifier_kchannelGetNotificationShare;
|
|
|
|
// kchannelSetNotificationShare -- virtual inherited (notify) base (notify)
|
|
pThis->__kchannelSetNotificationShare__ = &__nvoc_up_thunk_Notifier_kchannelSetNotificationShare;
|
|
|
|
// kchannelUnregisterEvent -- virtual inherited (notify) base (notify)
|
|
pThis->__kchannelUnregisterEvent__ = &__nvoc_up_thunk_Notifier_kchannelUnregisterEvent;
|
|
|
|
// kchannelGetOrAllocNotifShare -- virtual inherited (notify) base (notify)
|
|
pThis->__kchannelGetOrAllocNotifShare__ = &__nvoc_up_thunk_Notifier_kchannelGetOrAllocNotifShare;
|
|
} // End __nvoc_init_funcTable_KernelChannel_1 with approximately 79 basic block(s).
|
|
|
|
|
|
// Initialize vtable(s) for 66 virtual method(s).
|
|
void __nvoc_init_funcTable_KernelChannel(KernelChannel *pThis, RmHalspecOwner *pRmhalspecowner) {
|
|
|
|
// Initialize vtable(s) with 66 per-object function pointer(s).
|
|
__nvoc_init_funcTable_KernelChannel_1(pThis, pRmhalspecowner);
|
|
}
|
|
|
|
void __nvoc_init_GpuResource(GpuResource*);
|
|
void __nvoc_init_Notifier(Notifier*);
|
|
void __nvoc_init_KernelChannel(KernelChannel *pThis, RmHalspecOwner *pRmhalspecowner) {
|
|
pThis->__nvoc_pbase_KernelChannel = pThis;
|
|
pThis->__nvoc_pbase_Object = &pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource.__nvoc_base_Object;
|
|
pThis->__nvoc_pbase_RsResource = &pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource;
|
|
pThis->__nvoc_pbase_RmResourceCommon = &pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RmResourceCommon;
|
|
pThis->__nvoc_pbase_RmResource = &pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource;
|
|
pThis->__nvoc_pbase_GpuResource = &pThis->__nvoc_base_GpuResource;
|
|
pThis->__nvoc_pbase_INotifier = &pThis->__nvoc_base_Notifier.__nvoc_base_INotifier;
|
|
pThis->__nvoc_pbase_Notifier = &pThis->__nvoc_base_Notifier;
|
|
__nvoc_init_GpuResource(&pThis->__nvoc_base_GpuResource);
|
|
__nvoc_init_Notifier(&pThis->__nvoc_base_Notifier);
|
|
__nvoc_init_funcTable_KernelChannel(pThis, pRmhalspecowner);
|
|
}
|
|
|
|
NV_STATUS __nvoc_objCreate_KernelChannel(KernelChannel **ppThis, Dynamic *pParent, NvU32 createFlags, CALL_CONTEXT * arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams)
|
|
{
|
|
NV_STATUS status;
|
|
Object *pParentObj = NULL;
|
|
KernelChannel *pThis;
|
|
RmHalspecOwner *pRmhalspecowner;
|
|
|
|
// Assign `pThis`, allocating memory unless suppressed by flag.
|
|
status = __nvoc_handleObjCreateMemAlloc(createFlags, sizeof(KernelChannel), (void**)&pThis, (void**)ppThis);
|
|
if (status != NV_OK)
|
|
return status;
|
|
|
|
// Zero is the initial value for everything.
|
|
portMemSet(pThis, 0, sizeof(KernelChannel));
|
|
|
|
// Initialize runtime type information.
|
|
__nvoc_initRtti(staticCast(pThis, Dynamic), &__nvoc_class_def_KernelChannel);
|
|
|
|
pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource.__nvoc_base_Object.createFlags = createFlags;
|
|
|
|
// pParent must be a valid object that derives from a halspec owner class.
|
|
NV_ASSERT_OR_RETURN(pParent != NULL, NV_ERR_INVALID_ARGUMENT);
|
|
|
|
// Link the child into the parent unless flagged not to do so.
|
|
if (!(createFlags & NVOC_OBJ_CREATE_FLAGS_PARENT_HALSPEC_ONLY))
|
|
{
|
|
pParentObj = dynamicCast(pParent, Object);
|
|
objAddChild(pParentObj, &pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource.__nvoc_base_Object);
|
|
}
|
|
else
|
|
{
|
|
pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource.__nvoc_base_Object.pParent = NULL;
|
|
}
|
|
|
|
if ((pRmhalspecowner = dynamicCast(pParent, RmHalspecOwner)) == NULL)
|
|
pRmhalspecowner = objFindAncestorOfType(RmHalspecOwner, pParent);
|
|
NV_ASSERT_OR_RETURN(pRmhalspecowner != NULL, NV_ERR_INVALID_ARGUMENT);
|
|
|
|
__nvoc_init_KernelChannel(pThis, pRmhalspecowner);
|
|
status = __nvoc_ctor_KernelChannel(pThis, pRmhalspecowner, arg_pCallContext, arg_pParams);
|
|
if (status != NV_OK) goto __nvoc_objCreate_KernelChannel_cleanup;
|
|
|
|
// Assignment has no effect if NVOC_OBJ_CREATE_FLAGS_IN_PLACE_CONSTRUCT is set.
|
|
*ppThis = pThis;
|
|
|
|
return NV_OK;
|
|
|
|
__nvoc_objCreate_KernelChannel_cleanup:
|
|
|
|
// Unlink the child from the parent if it was linked above.
|
|
if (pParentObj != NULL)
|
|
objRemoveChild(pParentObj, &pThis->__nvoc_base_GpuResource.__nvoc_base_RmResource.__nvoc_base_RsResource.__nvoc_base_Object);
|
|
|
|
// Do not call destructors here since the constructor already called them.
|
|
if (createFlags & NVOC_OBJ_CREATE_FLAGS_IN_PLACE_CONSTRUCT)
|
|
portMemSet(pThis, 0, sizeof(KernelChannel));
|
|
else
|
|
{
|
|
portMemFree(pThis);
|
|
*ppThis = NULL;
|
|
}
|
|
|
|
// coverity[leaked_storage:FALSE]
|
|
return status;
|
|
}
|
|
|
|
NV_STATUS __nvoc_objCreateDynamic_KernelChannel(KernelChannel **ppThis, Dynamic *pParent, NvU32 createFlags, va_list args) {
|
|
NV_STATUS status;
|
|
CALL_CONTEXT * arg_pCallContext = va_arg(args, CALL_CONTEXT *);
|
|
struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams = va_arg(args, struct RS_RES_ALLOC_PARAMS_INTERNAL *);
|
|
|
|
status = __nvoc_objCreate_KernelChannel(ppThis, pParent, createFlags, arg_pCallContext, arg_pParams);
|
|
|
|
return status;
|
|
}
|
|
|