mirror of
https://github.com/NVIDIA/open-gpu-kernel-modules.git
synced 2026-01-30 13:09:47 +00:00
525.89.02
This commit is contained in:
@@ -301,6 +301,8 @@ MAKE_LIST(RmClientList, RmClient*);
|
||||
extern RmClientList g_clientListBehindGpusLock;
|
||||
MAKE_LIST(UserInfoList, UserInfo*);
|
||||
extern UserInfoList g_userInfoList;
|
||||
MAKE_MULTIMAP(OsInfoMap, RmClient*);
|
||||
extern OsInfoMap g_osInfoList;
|
||||
|
||||
|
||||
//
|
||||
|
||||
@@ -338,6 +338,7 @@ struct KernelGsp {
|
||||
NvU64 logElfDataSize;
|
||||
NvBool bLibosLogsPollingEnabled;
|
||||
NvBool bInInit;
|
||||
NvBool bInLockdown;
|
||||
NvBool bPollingForRpcResponse;
|
||||
NvBool bXid119Printed;
|
||||
MEMORY_DESCRIPTOR *pMemDesc_simAccessBuf;
|
||||
|
||||
@@ -974,7 +974,17 @@ static const CHIPS_RELEASED sChipsReleased[] = {
|
||||
{ 0x26B1, 0x16a1, 0x17aa, "NVIDIA RTX 6000 Ada Generation" },
|
||||
{ 0x26B5, 0x169d, 0x10de, "NVIDIA L40" },
|
||||
{ 0x2704, 0x0000, 0x0000, "NVIDIA GeForce RTX 4080" },
|
||||
{ 0x2717, 0x0000, 0x0000, "NVIDIA GeForce RTX 4090 Laptop GPU" },
|
||||
{ 0x2757, 0x0000, 0x0000, "NVIDIA GeForce RTX 4090 Laptop GPU" },
|
||||
{ 0x2782, 0x0000, 0x0000, "NVIDIA GeForce RTX 4070 Ti" },
|
||||
{ 0x27A0, 0x0000, 0x0000, "NVIDIA GeForce RTX 4080 Laptop GPU" },
|
||||
{ 0x27E0, 0x0000, 0x0000, "NVIDIA GeForce RTX 4080 Laptop GPU" },
|
||||
{ 0x2820, 0x0000, 0x0000, "NVIDIA GeForce RTX 4070 Laptop GPU" },
|
||||
{ 0x2860, 0x0000, 0x0000, "NVIDIA GeForce RTX 4070 Laptop GPU" },
|
||||
{ 0x28A0, 0x0000, 0x0000, "NVIDIA GeForce RTX 4060 Laptop GPU" },
|
||||
{ 0x28A1, 0x0000, 0x0000, "NVIDIA GeForce RTX 4050 Laptop GPU" },
|
||||
{ 0x28E0, 0x0000, 0x0000, "NVIDIA GeForce RTX 4060 Laptop GPU" },
|
||||
{ 0x28E1, 0x0000, 0x0000, "NVIDIA GeForce RTX 4050 Laptop GPU" },
|
||||
{ 0x13BD, 0x11cc, 0x10DE, "GRID M10-0B" },
|
||||
{ 0x13BD, 0x11cd, 0x10DE, "GRID M10-1B" },
|
||||
{ 0x13BD, 0x11ce, 0x10DE, "GRID M10-0Q" },
|
||||
|
||||
@@ -506,6 +506,13 @@ typedef struct rpc_pfm_req_hndlr_state_sync_callback_v21_04
|
||||
|
||||
typedef rpc_pfm_req_hndlr_state_sync_callback_v21_04 rpc_pfm_req_hndlr_state_sync_callback_v;
|
||||
|
||||
typedef struct rpc_gsp_lockdown_notice_v17_00
|
||||
{
|
||||
NvBool bLockdownEngaging;
|
||||
} rpc_gsp_lockdown_notice_v17_00;
|
||||
|
||||
typedef rpc_gsp_lockdown_notice_v17_00 rpc_gsp_lockdown_notice_v;
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
@@ -2133,6 +2140,25 @@ static vmiopd_mdesc_t vmiopd_mdesc_t_rpc_pfm_req_hndlr_state_sync_callback_v21_0
|
||||
};
|
||||
#endif
|
||||
|
||||
#ifndef SKIP_PRINT_rpc_gsp_lockdown_notice_v17_00
|
||||
static vmiopd_fdesc_t vmiopd_fdesc_t_rpc_gsp_lockdown_notice_v17_00[] = {
|
||||
{
|
||||
.vtype = vtype_NvBool,
|
||||
.offset = NV_OFFSETOF(rpc_gsp_lockdown_notice_v17_00, bLockdownEngaging),
|
||||
.name = "bLockdownEngaging"
|
||||
},
|
||||
{
|
||||
.vtype = vt_end
|
||||
}
|
||||
};
|
||||
|
||||
static vmiopd_mdesc_t vmiopd_mdesc_t_rpc_gsp_lockdown_notice_v17_00 = {
|
||||
.name = "rpc_gsp_lockdown_notice",
|
||||
.header_length = NV_SIZEOF32(rpc_gsp_lockdown_notice_v17_00),
|
||||
.fdesc = vmiopd_fdesc_t_rpc_gsp_lockdown_notice_v17_00
|
||||
};
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
#ifdef RPC_DEBUG_PRINT_FUNCTIONS
|
||||
@@ -2546,6 +2572,13 @@ vmiopd_mdesc_t *rpcdebugPfmReqHndlrStateSyncCallback_v21_04(void)
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifndef SKIP_PRINT_rpc_gsp_lockdown_notice_v17_00
|
||||
vmiopd_mdesc_t *rpcdebugGspLockdownNotice_v17_00(void)
|
||||
{
|
||||
return &vmiopd_mdesc_t_rpc_gsp_lockdown_notice_v17_00;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#endif
|
||||
|
||||
@@ -2656,6 +2689,8 @@ typedef union rpc_generic_union {
|
||||
rpc_extdev_intr_service_v extdev_intr_service_v;
|
||||
rpc_pfm_req_hndlr_state_sync_callback_v21_04 pfm_req_hndlr_state_sync_callback_v21_04;
|
||||
rpc_pfm_req_hndlr_state_sync_callback_v pfm_req_hndlr_state_sync_callback_v;
|
||||
rpc_gsp_lockdown_notice_v17_00 gsp_lockdown_notice_v17_00;
|
||||
rpc_gsp_lockdown_notice_v gsp_lockdown_notice_v;
|
||||
} rpc_generic_union;
|
||||
|
||||
#endif
|
||||
|
||||
@@ -604,7 +604,7 @@ struct Subdevice {
|
||||
struct Device *pDevice;
|
||||
NvBool bMaxGrTickFreqRequested;
|
||||
NvU64 P2PfbMappedBytes;
|
||||
NvU32 notifyActions[177];
|
||||
NvU32 notifyActions[178];
|
||||
NvHandle hNotifierMemory;
|
||||
struct Memory *pNotifierMemory;
|
||||
NvHandle hSemMemory;
|
||||
|
||||
@@ -90,6 +90,7 @@ void __nvoc_init_dataField_OBJSYS(OBJSYS *pThis) {
|
||||
pThis->setProperty(pThis, PDB_PROP_SYS_IS_AGGRESSIVE_GC6_ENABLED, (0));
|
||||
pThis->setProperty(pThis, PDB_PROP_SYS_PRIORITY_BOOST, (0));
|
||||
pThis->setProperty(pThis, PDB_PROP_SYS_PRIORITY_THROTTLE_DELAY_US, 16 * 1000);
|
||||
pThis->setProperty(pThis, PDB_PROP_SYS_CLIENT_HANDLE_LOOKUP, ((NvBool)(0 != 0)));
|
||||
pThis->setProperty(pThis, PDB_PROP_SYS_ROUTE_TO_PHYSICAL_LOCK_BYPASS, ((NvBool)(0 == 0)));
|
||||
}
|
||||
|
||||
|
||||
@@ -395,6 +395,7 @@ struct OBJSYS {
|
||||
NvBool PDB_PROP_SYS_PRIORITY_BOOST;
|
||||
NvU32 PDB_PROP_SYS_PRIORITY_THROTTLE_DELAY_US;
|
||||
NvBool PDB_PROP_SYS_BUGCHECK_ON_TIMEOUT;
|
||||
NvBool PDB_PROP_SYS_CLIENT_HANDLE_LOOKUP;
|
||||
NvU32 apiLockMask;
|
||||
NvU32 apiLockModuleMask;
|
||||
NvU32 gpuLockModuleMask;
|
||||
@@ -485,6 +486,8 @@ extern const struct NVOC_CLASS_DEF __nvoc_class_def_OBJSYS;
|
||||
#define PDB_PROP_SYS_SBIOS_NVIF_POWERMIZER_LIMIT_BASE_NAME PDB_PROP_SYS_SBIOS_NVIF_POWERMIZER_LIMIT
|
||||
#define PDB_PROP_SYS_IS_UEFI_BASE_CAST
|
||||
#define PDB_PROP_SYS_IS_UEFI_BASE_NAME PDB_PROP_SYS_IS_UEFI
|
||||
#define PDB_PROP_SYS_CLIENT_HANDLE_LOOKUP_BASE_CAST
|
||||
#define PDB_PROP_SYS_CLIENT_HANDLE_LOOKUP_BASE_NAME PDB_PROP_SYS_CLIENT_HANDLE_LOOKUP
|
||||
#define PDB_PROP_SYS_INTERNAL_EVENT_BUFFER_ALLOC_ALLOWED_BASE_CAST
|
||||
#define PDB_PROP_SYS_INTERNAL_EVENT_BUFFER_ALLOC_ALLOWED_BASE_NAME PDB_PROP_SYS_INTERNAL_EVENT_BUFFER_ALLOC_ALLOWED
|
||||
#define PDB_PROP_SYS_IS_GSYNC_ENABLED_BASE_CAST
|
||||
|
||||
@@ -7,6 +7,161 @@
|
||||
#include "utils/nvassert.h"
|
||||
#include "g_third_party_p2p_nvoc.h"
|
||||
|
||||
#ifdef DEBUG
|
||||
char __nvoc_class_id_uniqueness_check_0x3e3a6a = 1;
|
||||
#endif
|
||||
|
||||
extern const struct NVOC_CLASS_DEF __nvoc_class_def_P2PTokenShare;
|
||||
|
||||
extern const struct NVOC_CLASS_DEF __nvoc_class_def_Object;
|
||||
|
||||
extern const struct NVOC_CLASS_DEF __nvoc_class_def_RsShared;
|
||||
|
||||
void __nvoc_init_P2PTokenShare(P2PTokenShare*);
|
||||
void __nvoc_init_funcTable_P2PTokenShare(P2PTokenShare*);
|
||||
NV_STATUS __nvoc_ctor_P2PTokenShare(P2PTokenShare*);
|
||||
void __nvoc_init_dataField_P2PTokenShare(P2PTokenShare*);
|
||||
void __nvoc_dtor_P2PTokenShare(P2PTokenShare*);
|
||||
extern const struct NVOC_EXPORT_INFO __nvoc_export_info_P2PTokenShare;
|
||||
|
||||
static const struct NVOC_RTTI __nvoc_rtti_P2PTokenShare_P2PTokenShare = {
|
||||
/*pClassDef=*/ &__nvoc_class_def_P2PTokenShare,
|
||||
/*dtor=*/ (NVOC_DYNAMIC_DTOR) &__nvoc_dtor_P2PTokenShare,
|
||||
/*offset=*/ 0,
|
||||
};
|
||||
|
||||
static const struct NVOC_RTTI __nvoc_rtti_P2PTokenShare_Object = {
|
||||
/*pClassDef=*/ &__nvoc_class_def_Object,
|
||||
/*dtor=*/ &__nvoc_destructFromBase,
|
||||
/*offset=*/ NV_OFFSETOF(P2PTokenShare, __nvoc_base_RsShared.__nvoc_base_Object),
|
||||
};
|
||||
|
||||
static const struct NVOC_RTTI __nvoc_rtti_P2PTokenShare_RsShared = {
|
||||
/*pClassDef=*/ &__nvoc_class_def_RsShared,
|
||||
/*dtor=*/ &__nvoc_destructFromBase,
|
||||
/*offset=*/ NV_OFFSETOF(P2PTokenShare, __nvoc_base_RsShared),
|
||||
};
|
||||
|
||||
static const struct NVOC_CASTINFO __nvoc_castinfo_P2PTokenShare = {
|
||||
/*numRelatives=*/ 3,
|
||||
/*relatives=*/ {
|
||||
&__nvoc_rtti_P2PTokenShare_P2PTokenShare,
|
||||
&__nvoc_rtti_P2PTokenShare_RsShared,
|
||||
&__nvoc_rtti_P2PTokenShare_Object,
|
||||
},
|
||||
};
|
||||
|
||||
const struct NVOC_CLASS_DEF __nvoc_class_def_P2PTokenShare =
|
||||
{
|
||||
/*classInfo=*/ {
|
||||
/*size=*/ sizeof(P2PTokenShare),
|
||||
/*classId=*/ classId(P2PTokenShare),
|
||||
/*providerId=*/ &__nvoc_rtti_provider,
|
||||
#if NV_PRINTF_STRINGS_ALLOWED
|
||||
/*name=*/ "P2PTokenShare",
|
||||
#endif
|
||||
},
|
||||
/*objCreatefn=*/ (NVOC_DYNAMIC_OBJ_CREATE) &__nvoc_objCreateDynamic_P2PTokenShare,
|
||||
/*pCastInfo=*/ &__nvoc_castinfo_P2PTokenShare,
|
||||
/*pExportInfo=*/ &__nvoc_export_info_P2PTokenShare
|
||||
};
|
||||
|
||||
const struct NVOC_EXPORT_INFO __nvoc_export_info_P2PTokenShare =
|
||||
{
|
||||
/*numEntries=*/ 0,
|
||||
/*pExportEntries=*/ 0
|
||||
};
|
||||
|
||||
void __nvoc_dtor_RsShared(RsShared*);
|
||||
void __nvoc_dtor_P2PTokenShare(P2PTokenShare *pThis) {
|
||||
__nvoc_shrp2pDestruct(pThis);
|
||||
__nvoc_dtor_RsShared(&pThis->__nvoc_base_RsShared);
|
||||
PORT_UNREFERENCED_VARIABLE(pThis);
|
||||
}
|
||||
|
||||
void __nvoc_init_dataField_P2PTokenShare(P2PTokenShare *pThis) {
|
||||
PORT_UNREFERENCED_VARIABLE(pThis);
|
||||
}
|
||||
|
||||
NV_STATUS __nvoc_ctor_RsShared(RsShared* );
|
||||
NV_STATUS __nvoc_ctor_P2PTokenShare(P2PTokenShare *pThis) {
|
||||
NV_STATUS status = NV_OK;
|
||||
status = __nvoc_ctor_RsShared(&pThis->__nvoc_base_RsShared);
|
||||
if (status != NV_OK) goto __nvoc_ctor_P2PTokenShare_fail_RsShared;
|
||||
__nvoc_init_dataField_P2PTokenShare(pThis);
|
||||
|
||||
status = __nvoc_shrp2pConstruct(pThis);
|
||||
if (status != NV_OK) goto __nvoc_ctor_P2PTokenShare_fail__init;
|
||||
goto __nvoc_ctor_P2PTokenShare_exit; // Success
|
||||
|
||||
__nvoc_ctor_P2PTokenShare_fail__init:
|
||||
__nvoc_dtor_RsShared(&pThis->__nvoc_base_RsShared);
|
||||
__nvoc_ctor_P2PTokenShare_fail_RsShared:
|
||||
__nvoc_ctor_P2PTokenShare_exit:
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
static void __nvoc_init_funcTable_P2PTokenShare_1(P2PTokenShare *pThis) {
|
||||
PORT_UNREFERENCED_VARIABLE(pThis);
|
||||
}
|
||||
|
||||
void __nvoc_init_funcTable_P2PTokenShare(P2PTokenShare *pThis) {
|
||||
__nvoc_init_funcTable_P2PTokenShare_1(pThis);
|
||||
}
|
||||
|
||||
void __nvoc_init_RsShared(RsShared*);
|
||||
void __nvoc_init_P2PTokenShare(P2PTokenShare *pThis) {
|
||||
pThis->__nvoc_pbase_P2PTokenShare = pThis;
|
||||
pThis->__nvoc_pbase_Object = &pThis->__nvoc_base_RsShared.__nvoc_base_Object;
|
||||
pThis->__nvoc_pbase_RsShared = &pThis->__nvoc_base_RsShared;
|
||||
__nvoc_init_RsShared(&pThis->__nvoc_base_RsShared);
|
||||
__nvoc_init_funcTable_P2PTokenShare(pThis);
|
||||
}
|
||||
|
||||
NV_STATUS __nvoc_objCreate_P2PTokenShare(P2PTokenShare **ppThis, Dynamic *pParent, NvU32 createFlags) {
|
||||
NV_STATUS status;
|
||||
Object *pParentObj;
|
||||
P2PTokenShare *pThis;
|
||||
|
||||
pThis = portMemAllocNonPaged(sizeof(P2PTokenShare));
|
||||
if (pThis == NULL) return NV_ERR_NO_MEMORY;
|
||||
|
||||
portMemSet(pThis, 0, sizeof(P2PTokenShare));
|
||||
|
||||
__nvoc_initRtti(staticCast(pThis, Dynamic), &__nvoc_class_def_P2PTokenShare);
|
||||
|
||||
if (pParent != NULL && !(createFlags & NVOC_OBJ_CREATE_FLAGS_PARENT_HALSPEC_ONLY))
|
||||
{
|
||||
pParentObj = dynamicCast(pParent, Object);
|
||||
objAddChild(pParentObj, &pThis->__nvoc_base_RsShared.__nvoc_base_Object);
|
||||
}
|
||||
else
|
||||
{
|
||||
pThis->__nvoc_base_RsShared.__nvoc_base_Object.pParent = NULL;
|
||||
}
|
||||
|
||||
__nvoc_init_P2PTokenShare(pThis);
|
||||
status = __nvoc_ctor_P2PTokenShare(pThis);
|
||||
if (status != NV_OK) goto __nvoc_objCreate_P2PTokenShare_cleanup;
|
||||
|
||||
*ppThis = pThis;
|
||||
return NV_OK;
|
||||
|
||||
__nvoc_objCreate_P2PTokenShare_cleanup:
|
||||
// do not call destructors here since the constructor already called them
|
||||
portMemFree(pThis);
|
||||
return status;
|
||||
}
|
||||
|
||||
NV_STATUS __nvoc_objCreateDynamic_P2PTokenShare(P2PTokenShare **ppThis, Dynamic *pParent, NvU32 createFlags, va_list args) {
|
||||
NV_STATUS status;
|
||||
|
||||
status = __nvoc_objCreate_P2PTokenShare(ppThis, pParent, createFlags);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
||||
#ifdef DEBUG
|
||||
char __nvoc_class_id_uniqueness_check_0x34d08b = 1;
|
||||
#endif
|
||||
|
||||
@@ -179,6 +179,68 @@ struct _def_client_third_party_p2p_pid_client_mapping_info
|
||||
};
|
||||
typedef struct _def_client_third_party_p2p_pid_client_mapping_info CLI_THIRD_PARTY_P2P_PID_CLIENT_INFO, *PCLI_THIRD_PARTY_P2P_PID_CLIENT_INFO;
|
||||
|
||||
struct ThirdPartyP2P;
|
||||
|
||||
#ifndef __NVOC_CLASS_ThirdPartyP2P_TYPEDEF__
|
||||
#define __NVOC_CLASS_ThirdPartyP2P_TYPEDEF__
|
||||
typedef struct ThirdPartyP2P ThirdPartyP2P;
|
||||
#endif /* __NVOC_CLASS_ThirdPartyP2P_TYPEDEF__ */
|
||||
|
||||
#ifndef __nvoc_class_id_ThirdPartyP2P
|
||||
#define __nvoc_class_id_ThirdPartyP2P 0x34d08b
|
||||
#endif /* __nvoc_class_id_ThirdPartyP2P */
|
||||
|
||||
|
||||
#ifdef NVOC_THIRD_PARTY_P2P_H_PRIVATE_ACCESS_ALLOWED
|
||||
#define PRIVATE_FIELD(x) x
|
||||
#else
|
||||
#define PRIVATE_FIELD(x) NVOC_PRIVATE_FIELD(x)
|
||||
#endif
|
||||
struct P2PTokenShare {
|
||||
const struct NVOC_RTTI *__nvoc_rtti;
|
||||
struct RsShared __nvoc_base_RsShared;
|
||||
struct Object *__nvoc_pbase_Object;
|
||||
struct RsShared *__nvoc_pbase_RsShared;
|
||||
struct P2PTokenShare *__nvoc_pbase_P2PTokenShare;
|
||||
struct ThirdPartyP2P *pThirdPartyP2P;
|
||||
};
|
||||
|
||||
#ifndef __NVOC_CLASS_P2PTokenShare_TYPEDEF__
|
||||
#define __NVOC_CLASS_P2PTokenShare_TYPEDEF__
|
||||
typedef struct P2PTokenShare P2PTokenShare;
|
||||
#endif /* __NVOC_CLASS_P2PTokenShare_TYPEDEF__ */
|
||||
|
||||
#ifndef __nvoc_class_id_P2PTokenShare
|
||||
#define __nvoc_class_id_P2PTokenShare 0x3e3a6a
|
||||
#endif /* __nvoc_class_id_P2PTokenShare */
|
||||
|
||||
extern const struct NVOC_CLASS_DEF __nvoc_class_def_P2PTokenShare;
|
||||
|
||||
#define __staticCast_P2PTokenShare(pThis) \
|
||||
((pThis)->__nvoc_pbase_P2PTokenShare)
|
||||
|
||||
#ifdef __nvoc_third_party_p2p_h_disabled
|
||||
#define __dynamicCast_P2PTokenShare(pThis) ((P2PTokenShare*)NULL)
|
||||
#else //__nvoc_third_party_p2p_h_disabled
|
||||
#define __dynamicCast_P2PTokenShare(pThis) \
|
||||
((P2PTokenShare*)__nvoc_dynamicCast(staticCast((pThis), Dynamic), classInfo(P2PTokenShare)))
|
||||
#endif //__nvoc_third_party_p2p_h_disabled
|
||||
|
||||
|
||||
NV_STATUS __nvoc_objCreateDynamic_P2PTokenShare(P2PTokenShare**, Dynamic*, NvU32, va_list);
|
||||
|
||||
NV_STATUS __nvoc_objCreate_P2PTokenShare(P2PTokenShare**, Dynamic*, NvU32);
|
||||
#define __objCreate_P2PTokenShare(ppNewObj, pParent, createFlags) \
|
||||
__nvoc_objCreate_P2PTokenShare((ppNewObj), staticCast((pParent), Dynamic), (createFlags))
|
||||
|
||||
NV_STATUS shrp2pConstruct_IMPL(struct P2PTokenShare *arg_pP2PTokenShare);
|
||||
|
||||
#define __nvoc_shrp2pConstruct(arg_pP2PTokenShare) shrp2pConstruct_IMPL(arg_pP2PTokenShare)
|
||||
void shrp2pDestruct_IMPL(struct P2PTokenShare *pP2PTokenShare);
|
||||
|
||||
#define __nvoc_shrp2pDestruct(pP2PTokenShare) shrp2pDestruct_IMPL(pP2PTokenShare)
|
||||
#undef PRIVATE_FIELD
|
||||
|
||||
|
||||
#ifdef NVOC_THIRD_PARTY_P2P_H_PRIVATE_ACCESS_ALLOWED
|
||||
#define PRIVATE_FIELD(x) x
|
||||
@@ -235,6 +297,7 @@ struct ThirdPartyP2P {
|
||||
THIRD_PARTY_P2P_DESTROY_CALLBACK *pDestroyCallback;
|
||||
void *pData;
|
||||
CLI_THIRD_PARTY_P2P_VIDMEM_INFO_MAP vidmemInfoMap;
|
||||
struct P2PTokenShare *pTokenShare;
|
||||
PNODE pAddressRangeTree;
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user