1 #ifndef _G_COMPUTE_INSTANCE_SUBSCRIPTION_NVOC_H_
2 #define _G_COMPUTE_INSTANCE_SUBSCRIPTION_NVOC_H_
3 #include "nvoc/runtime.h"
4 
5 #ifdef __cplusplus
6 extern "C" {
7 #endif
8 
9 /*
10  * SPDX-FileCopyrightText: Copyright (c) 2019-2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
11  * SPDX-License-Identifier: MIT
12  *
13  * Permission is hereby granted, free of charge, to any person obtaining a
14  * copy of this software and associated documentation files (the "Software"),
15  * to deal in the Software without restriction, including without limitation
16  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
17  * and/or sell copies of the Software, and to permit persons to whom the
18  * Software is furnished to do so, subject to the following conditions:
19  *
20  * The above copyright notice and this permission notice shall be included in
21  * all copies or substantial portions of the Software.
22  *
23  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
29  * DEALINGS IN THE SOFTWARE.
30  */
31 
32 /******************************************************************************
33  *
34  *   Description:
35  *       This file contains the functions managing MIG compute instance subscriptions
36  *
37  *****************************************************************************/
38 
39 #include "g_compute_instance_subscription_nvoc.h"
40 
41 #ifndef COMPUTE_INSTANCE_SUBSCRIPTION_H
42 #define COMPUTE_INSTANCE_SUBSCRIPTION_H
43 
44 #include "class/clc638.h"
45 #include "ctrl/ctrlc638.h"
46 #include "gpu/gpu_resource.h"
47 #include "kernel/gpu/mig_mgr/kernel_mig_manager.h"
48 
49 // ****************************************************************************
50 //                          Type Definitions
51 // ****************************************************************************
52 
53 
54 // Private field names are wrapped in PRIVATE_FIELD, which does nothing for
55 // the matching C source file, but causes diagnostics to be issued if another
56 // source file references the field.
57 #ifdef NVOC_COMPUTE_INSTANCE_SUBSCRIPTION_H_PRIVATE_ACCESS_ALLOWED
58 #define PRIVATE_FIELD(x) x
59 #else
60 #define PRIVATE_FIELD(x) NVOC_PRIVATE_FIELD(x)
61 #endif
62 
63 struct ComputeInstanceSubscription {
64     const struct NVOC_RTTI *__nvoc_rtti;
65     struct GpuResource __nvoc_base_GpuResource;
66     struct Object *__nvoc_pbase_Object;
67     struct RsResource *__nvoc_pbase_RsResource;
68     struct RmResourceCommon *__nvoc_pbase_RmResourceCommon;
69     struct RmResource *__nvoc_pbase_RmResource;
70     struct GpuResource *__nvoc_pbase_GpuResource;
71     struct ComputeInstanceSubscription *__nvoc_pbase_ComputeInstanceSubscription;
72     NvBool (*__cisubscriptionCanCopy__)(struct ComputeInstanceSubscription *);
73     NV_STATUS (*__cisubscriptionCtrlCmdGetUuid__)(struct ComputeInstanceSubscription *, NVC638_CTRL_GET_UUID_PARAMS *);
74     NvBool (*__cisubscriptionShareCallback__)(struct ComputeInstanceSubscription *, struct RsClient *, struct RsResourceRef *, RS_SHARE_POLICY *);
75     NV_STATUS (*__cisubscriptionCheckMemInterUnmap__)(struct ComputeInstanceSubscription *, NvBool);
76     NV_STATUS (*__cisubscriptionMapTo__)(struct ComputeInstanceSubscription *, RS_RES_MAP_TO_PARAMS *);
77     NV_STATUS (*__cisubscriptionGetMapAddrSpace__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, NvU32, NV_ADDRESS_SPACE *);
78     NvU32 (*__cisubscriptionGetRefCount__)(struct ComputeInstanceSubscription *);
79     void (*__cisubscriptionAddAdditionalDependants__)(struct RsClient *, struct ComputeInstanceSubscription *, RsResourceRef *);
80     NV_STATUS (*__cisubscriptionControl_Prologue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
81     NV_STATUS (*__cisubscriptionGetRegBaseOffsetAndSize__)(struct ComputeInstanceSubscription *, struct OBJGPU *, NvU32 *, NvU32 *);
82     NV_STATUS (*__cisubscriptionInternalControlForward__)(struct ComputeInstanceSubscription *, NvU32, void *, NvU32);
83     NV_STATUS (*__cisubscriptionUnmapFrom__)(struct ComputeInstanceSubscription *, RS_RES_UNMAP_FROM_PARAMS *);
84     void (*__cisubscriptionControl_Epilogue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
85     NvHandle (*__cisubscriptionGetInternalObjectHandle__)(struct ComputeInstanceSubscription *);
86     NV_STATUS (*__cisubscriptionControl__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
87     NV_STATUS (*__cisubscriptionUnmap__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RsCpuMapping *);
88     NV_STATUS (*__cisubscriptionGetMemInterMapParams__)(struct ComputeInstanceSubscription *, RMRES_MEM_INTER_MAP_PARAMS *);
89     NV_STATUS (*__cisubscriptionGetMemoryMappingDescriptor__)(struct ComputeInstanceSubscription *, struct MEMORY_DESCRIPTOR **);
90     NV_STATUS (*__cisubscriptionControlFilter__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
91     NV_STATUS (*__cisubscriptionControlSerialization_Prologue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
92     NvBool (*__cisubscriptionIsPartialUnmapSupported__)(struct ComputeInstanceSubscription *);
93     void (*__cisubscriptionPreDestruct__)(struct ComputeInstanceSubscription *);
94     NV_STATUS (*__cisubscriptionIsDuplicate__)(struct ComputeInstanceSubscription *, NvHandle, NvBool *);
95     void (*__cisubscriptionControlSerialization_Epilogue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
96     NV_STATUS (*__cisubscriptionMap__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_CPU_MAP_PARAMS *, struct RsCpuMapping *);
97     NvBool (*__cisubscriptionAccessCallback__)(struct ComputeInstanceSubscription *, struct RsClient *, void *, RsAccessRight);
98     MIG_COMPUTE_INSTANCE *PRIVATE_FIELD(pMIGComputeInstance);
99     NvU64 PRIVATE_FIELD(dupedCapDescriptor);
100 };
101 
102 struct ComputeInstanceSubscription_PRIVATE {
103     const struct NVOC_RTTI *__nvoc_rtti;
104     struct GpuResource __nvoc_base_GpuResource;
105     struct Object *__nvoc_pbase_Object;
106     struct RsResource *__nvoc_pbase_RsResource;
107     struct RmResourceCommon *__nvoc_pbase_RmResourceCommon;
108     struct RmResource *__nvoc_pbase_RmResource;
109     struct GpuResource *__nvoc_pbase_GpuResource;
110     struct ComputeInstanceSubscription *__nvoc_pbase_ComputeInstanceSubscription;
111     NvBool (*__cisubscriptionCanCopy__)(struct ComputeInstanceSubscription *);
112     NV_STATUS (*__cisubscriptionCtrlCmdGetUuid__)(struct ComputeInstanceSubscription *, NVC638_CTRL_GET_UUID_PARAMS *);
113     NvBool (*__cisubscriptionShareCallback__)(struct ComputeInstanceSubscription *, struct RsClient *, struct RsResourceRef *, RS_SHARE_POLICY *);
114     NV_STATUS (*__cisubscriptionCheckMemInterUnmap__)(struct ComputeInstanceSubscription *, NvBool);
115     NV_STATUS (*__cisubscriptionMapTo__)(struct ComputeInstanceSubscription *, RS_RES_MAP_TO_PARAMS *);
116     NV_STATUS (*__cisubscriptionGetMapAddrSpace__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, NvU32, NV_ADDRESS_SPACE *);
117     NvU32 (*__cisubscriptionGetRefCount__)(struct ComputeInstanceSubscription *);
118     void (*__cisubscriptionAddAdditionalDependants__)(struct RsClient *, struct ComputeInstanceSubscription *, RsResourceRef *);
119     NV_STATUS (*__cisubscriptionControl_Prologue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
120     NV_STATUS (*__cisubscriptionGetRegBaseOffsetAndSize__)(struct ComputeInstanceSubscription *, struct OBJGPU *, NvU32 *, NvU32 *);
121     NV_STATUS (*__cisubscriptionInternalControlForward__)(struct ComputeInstanceSubscription *, NvU32, void *, NvU32);
122     NV_STATUS (*__cisubscriptionUnmapFrom__)(struct ComputeInstanceSubscription *, RS_RES_UNMAP_FROM_PARAMS *);
123     void (*__cisubscriptionControl_Epilogue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
124     NvHandle (*__cisubscriptionGetInternalObjectHandle__)(struct ComputeInstanceSubscription *);
125     NV_STATUS (*__cisubscriptionControl__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
126     NV_STATUS (*__cisubscriptionUnmap__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RsCpuMapping *);
127     NV_STATUS (*__cisubscriptionGetMemInterMapParams__)(struct ComputeInstanceSubscription *, RMRES_MEM_INTER_MAP_PARAMS *);
128     NV_STATUS (*__cisubscriptionGetMemoryMappingDescriptor__)(struct ComputeInstanceSubscription *, struct MEMORY_DESCRIPTOR **);
129     NV_STATUS (*__cisubscriptionControlFilter__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
130     NV_STATUS (*__cisubscriptionControlSerialization_Prologue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
131     NvBool (*__cisubscriptionIsPartialUnmapSupported__)(struct ComputeInstanceSubscription *);
132     void (*__cisubscriptionPreDestruct__)(struct ComputeInstanceSubscription *);
133     NV_STATUS (*__cisubscriptionIsDuplicate__)(struct ComputeInstanceSubscription *, NvHandle, NvBool *);
134     void (*__cisubscriptionControlSerialization_Epilogue__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
135     NV_STATUS (*__cisubscriptionMap__)(struct ComputeInstanceSubscription *, struct CALL_CONTEXT *, struct RS_CPU_MAP_PARAMS *, struct RsCpuMapping *);
136     NvBool (*__cisubscriptionAccessCallback__)(struct ComputeInstanceSubscription *, struct RsClient *, void *, RsAccessRight);
137     MIG_COMPUTE_INSTANCE *pMIGComputeInstance;
138     NvU64 dupedCapDescriptor;
139 };
140 
141 #ifndef __NVOC_CLASS_ComputeInstanceSubscription_TYPEDEF__
142 #define __NVOC_CLASS_ComputeInstanceSubscription_TYPEDEF__
143 typedef struct ComputeInstanceSubscription ComputeInstanceSubscription;
144 #endif /* __NVOC_CLASS_ComputeInstanceSubscription_TYPEDEF__ */
145 
146 #ifndef __nvoc_class_id_ComputeInstanceSubscription
147 #define __nvoc_class_id_ComputeInstanceSubscription 0xd1f238
148 #endif /* __nvoc_class_id_ComputeInstanceSubscription */
149 
150 extern const struct NVOC_CLASS_DEF __nvoc_class_def_ComputeInstanceSubscription;
151 
152 #define __staticCast_ComputeInstanceSubscription(pThis) \
153     ((pThis)->__nvoc_pbase_ComputeInstanceSubscription)
154 
155 #ifdef __nvoc_compute_instance_subscription_h_disabled
156 #define __dynamicCast_ComputeInstanceSubscription(pThis) ((ComputeInstanceSubscription*)NULL)
157 #else //__nvoc_compute_instance_subscription_h_disabled
158 #define __dynamicCast_ComputeInstanceSubscription(pThis) \
159     ((ComputeInstanceSubscription*)__nvoc_dynamicCast(staticCast((pThis), Dynamic), classInfo(ComputeInstanceSubscription)))
160 #endif //__nvoc_compute_instance_subscription_h_disabled
161 
162 
163 NV_STATUS __nvoc_objCreateDynamic_ComputeInstanceSubscription(ComputeInstanceSubscription**, Dynamic*, NvU32, va_list);
164 
165 NV_STATUS __nvoc_objCreate_ComputeInstanceSubscription(ComputeInstanceSubscription**, Dynamic*, NvU32, CALL_CONTEXT * arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams);
166 #define __objCreate_ComputeInstanceSubscription(ppNewObj, pParent, createFlags, arg_pCallContext, arg_pParams) \
167     __nvoc_objCreate_ComputeInstanceSubscription((ppNewObj), staticCast((pParent), Dynamic), (createFlags), arg_pCallContext, arg_pParams)
168 
169 #define cisubscriptionCanCopy(arg0) cisubscriptionCanCopy_DISPATCH(arg0)
170 #define cisubscriptionCtrlCmdGetUuid(arg0, arg1) cisubscriptionCtrlCmdGetUuid_DISPATCH(arg0, arg1)
171 #define cisubscriptionShareCallback(pGpuResource, pInvokingClient, pParentRef, pSharePolicy) cisubscriptionShareCallback_DISPATCH(pGpuResource, pInvokingClient, pParentRef, pSharePolicy)
172 #define cisubscriptionCheckMemInterUnmap(pRmResource, bSubdeviceHandleProvided) cisubscriptionCheckMemInterUnmap_DISPATCH(pRmResource, bSubdeviceHandleProvided)
173 #define cisubscriptionMapTo(pResource, pParams) cisubscriptionMapTo_DISPATCH(pResource, pParams)
174 #define cisubscriptionGetMapAddrSpace(pGpuResource, pCallContext, mapFlags, pAddrSpace) cisubscriptionGetMapAddrSpace_DISPATCH(pGpuResource, pCallContext, mapFlags, pAddrSpace)
175 #define cisubscriptionGetRefCount(pResource) cisubscriptionGetRefCount_DISPATCH(pResource)
176 #define cisubscriptionAddAdditionalDependants(pClient, pResource, pReference) cisubscriptionAddAdditionalDependants_DISPATCH(pClient, pResource, pReference)
177 #define cisubscriptionControl_Prologue(pResource, pCallContext, pParams) cisubscriptionControl_Prologue_DISPATCH(pResource, pCallContext, pParams)
178 #define cisubscriptionGetRegBaseOffsetAndSize(pGpuResource, pGpu, pOffset, pSize) cisubscriptionGetRegBaseOffsetAndSize_DISPATCH(pGpuResource, pGpu, pOffset, pSize)
179 #define cisubscriptionInternalControlForward(pGpuResource, command, pParams, size) cisubscriptionInternalControlForward_DISPATCH(pGpuResource, command, pParams, size)
180 #define cisubscriptionUnmapFrom(pResource, pParams) cisubscriptionUnmapFrom_DISPATCH(pResource, pParams)
181 #define cisubscriptionControl_Epilogue(pResource, pCallContext, pParams) cisubscriptionControl_Epilogue_DISPATCH(pResource, pCallContext, pParams)
182 #define cisubscriptionGetInternalObjectHandle(pGpuResource) cisubscriptionGetInternalObjectHandle_DISPATCH(pGpuResource)
183 #define cisubscriptionControl(pGpuResource, pCallContext, pParams) cisubscriptionControl_DISPATCH(pGpuResource, pCallContext, pParams)
184 #define cisubscriptionUnmap(pGpuResource, pCallContext, pCpuMapping) cisubscriptionUnmap_DISPATCH(pGpuResource, pCallContext, pCpuMapping)
185 #define cisubscriptionGetMemInterMapParams(pRmResource, pParams) cisubscriptionGetMemInterMapParams_DISPATCH(pRmResource, pParams)
186 #define cisubscriptionGetMemoryMappingDescriptor(pRmResource, ppMemDesc) cisubscriptionGetMemoryMappingDescriptor_DISPATCH(pRmResource, ppMemDesc)
187 #define cisubscriptionControlFilter(pResource, pCallContext, pParams) cisubscriptionControlFilter_DISPATCH(pResource, pCallContext, pParams)
188 #define cisubscriptionControlSerialization_Prologue(pResource, pCallContext, pParams) cisubscriptionControlSerialization_Prologue_DISPATCH(pResource, pCallContext, pParams)
189 #define cisubscriptionIsPartialUnmapSupported(pResource) cisubscriptionIsPartialUnmapSupported_DISPATCH(pResource)
190 #define cisubscriptionPreDestruct(pResource) cisubscriptionPreDestruct_DISPATCH(pResource)
191 #define cisubscriptionIsDuplicate(pResource, hMemory, pDuplicate) cisubscriptionIsDuplicate_DISPATCH(pResource, hMemory, pDuplicate)
192 #define cisubscriptionControlSerialization_Epilogue(pResource, pCallContext, pParams) cisubscriptionControlSerialization_Epilogue_DISPATCH(pResource, pCallContext, pParams)
193 #define cisubscriptionMap(pGpuResource, pCallContext, pParams, pCpuMapping) cisubscriptionMap_DISPATCH(pGpuResource, pCallContext, pParams, pCpuMapping)
194 #define cisubscriptionAccessCallback(pResource, pInvokingClient, pAllocParams, accessRight) cisubscriptionAccessCallback_DISPATCH(pResource, pInvokingClient, pAllocParams, accessRight)
195 NvBool cisubscriptionCanCopy_IMPL(struct ComputeInstanceSubscription *arg0);
196 
cisubscriptionCanCopy_DISPATCH(struct ComputeInstanceSubscription * arg0)197 static inline NvBool cisubscriptionCanCopy_DISPATCH(struct ComputeInstanceSubscription *arg0) {
198     return arg0->__cisubscriptionCanCopy__(arg0);
199 }
200 
201 NV_STATUS cisubscriptionCtrlCmdGetUuid_IMPL(struct ComputeInstanceSubscription *arg0, NVC638_CTRL_GET_UUID_PARAMS *arg1);
202 
cisubscriptionCtrlCmdGetUuid_DISPATCH(struct ComputeInstanceSubscription * arg0,NVC638_CTRL_GET_UUID_PARAMS * arg1)203 static inline NV_STATUS cisubscriptionCtrlCmdGetUuid_DISPATCH(struct ComputeInstanceSubscription *arg0, NVC638_CTRL_GET_UUID_PARAMS *arg1) {
204     return arg0->__cisubscriptionCtrlCmdGetUuid__(arg0, arg1);
205 }
206 
cisubscriptionShareCallback_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,struct RsClient * pInvokingClient,struct RsResourceRef * pParentRef,RS_SHARE_POLICY * pSharePolicy)207 static inline NvBool cisubscriptionShareCallback_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, struct RsClient *pInvokingClient, struct RsResourceRef *pParentRef, RS_SHARE_POLICY *pSharePolicy) {
208     return pGpuResource->__cisubscriptionShareCallback__(pGpuResource, pInvokingClient, pParentRef, pSharePolicy);
209 }
210 
cisubscriptionCheckMemInterUnmap_DISPATCH(struct ComputeInstanceSubscription * pRmResource,NvBool bSubdeviceHandleProvided)211 static inline NV_STATUS cisubscriptionCheckMemInterUnmap_DISPATCH(struct ComputeInstanceSubscription *pRmResource, NvBool bSubdeviceHandleProvided) {
212     return pRmResource->__cisubscriptionCheckMemInterUnmap__(pRmResource, bSubdeviceHandleProvided);
213 }
214 
cisubscriptionMapTo_DISPATCH(struct ComputeInstanceSubscription * pResource,RS_RES_MAP_TO_PARAMS * pParams)215 static inline NV_STATUS cisubscriptionMapTo_DISPATCH(struct ComputeInstanceSubscription *pResource, RS_RES_MAP_TO_PARAMS *pParams) {
216     return pResource->__cisubscriptionMapTo__(pResource, pParams);
217 }
218 
cisubscriptionGetMapAddrSpace_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,struct CALL_CONTEXT * pCallContext,NvU32 mapFlags,NV_ADDRESS_SPACE * pAddrSpace)219 static inline NV_STATUS cisubscriptionGetMapAddrSpace_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, struct CALL_CONTEXT *pCallContext, NvU32 mapFlags, NV_ADDRESS_SPACE *pAddrSpace) {
220     return pGpuResource->__cisubscriptionGetMapAddrSpace__(pGpuResource, pCallContext, mapFlags, pAddrSpace);
221 }
222 
cisubscriptionGetRefCount_DISPATCH(struct ComputeInstanceSubscription * pResource)223 static inline NvU32 cisubscriptionGetRefCount_DISPATCH(struct ComputeInstanceSubscription *pResource) {
224     return pResource->__cisubscriptionGetRefCount__(pResource);
225 }
226 
cisubscriptionAddAdditionalDependants_DISPATCH(struct RsClient * pClient,struct ComputeInstanceSubscription * pResource,RsResourceRef * pReference)227 static inline void cisubscriptionAddAdditionalDependants_DISPATCH(struct RsClient *pClient, struct ComputeInstanceSubscription *pResource, RsResourceRef *pReference) {
228     pResource->__cisubscriptionAddAdditionalDependants__(pClient, pResource, pReference);
229 }
230 
cisubscriptionControl_Prologue_DISPATCH(struct ComputeInstanceSubscription * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)231 static inline NV_STATUS cisubscriptionControl_Prologue_DISPATCH(struct ComputeInstanceSubscription *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
232     return pResource->__cisubscriptionControl_Prologue__(pResource, pCallContext, pParams);
233 }
234 
cisubscriptionGetRegBaseOffsetAndSize_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,struct OBJGPU * pGpu,NvU32 * pOffset,NvU32 * pSize)235 static inline NV_STATUS cisubscriptionGetRegBaseOffsetAndSize_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, struct OBJGPU *pGpu, NvU32 *pOffset, NvU32 *pSize) {
236     return pGpuResource->__cisubscriptionGetRegBaseOffsetAndSize__(pGpuResource, pGpu, pOffset, pSize);
237 }
238 
cisubscriptionInternalControlForward_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,NvU32 command,void * pParams,NvU32 size)239 static inline NV_STATUS cisubscriptionInternalControlForward_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, NvU32 command, void *pParams, NvU32 size) {
240     return pGpuResource->__cisubscriptionInternalControlForward__(pGpuResource, command, pParams, size);
241 }
242 
cisubscriptionUnmapFrom_DISPATCH(struct ComputeInstanceSubscription * pResource,RS_RES_UNMAP_FROM_PARAMS * pParams)243 static inline NV_STATUS cisubscriptionUnmapFrom_DISPATCH(struct ComputeInstanceSubscription *pResource, RS_RES_UNMAP_FROM_PARAMS *pParams) {
244     return pResource->__cisubscriptionUnmapFrom__(pResource, pParams);
245 }
246 
cisubscriptionControl_Epilogue_DISPATCH(struct ComputeInstanceSubscription * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)247 static inline void cisubscriptionControl_Epilogue_DISPATCH(struct ComputeInstanceSubscription *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
248     pResource->__cisubscriptionControl_Epilogue__(pResource, pCallContext, pParams);
249 }
250 
cisubscriptionGetInternalObjectHandle_DISPATCH(struct ComputeInstanceSubscription * pGpuResource)251 static inline NvHandle cisubscriptionGetInternalObjectHandle_DISPATCH(struct ComputeInstanceSubscription *pGpuResource) {
252     return pGpuResource->__cisubscriptionGetInternalObjectHandle__(pGpuResource);
253 }
254 
cisubscriptionControl_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)255 static inline NV_STATUS cisubscriptionControl_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
256     return pGpuResource->__cisubscriptionControl__(pGpuResource, pCallContext, pParams);
257 }
258 
cisubscriptionUnmap_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,struct CALL_CONTEXT * pCallContext,struct RsCpuMapping * pCpuMapping)259 static inline NV_STATUS cisubscriptionUnmap_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, struct CALL_CONTEXT *pCallContext, struct RsCpuMapping *pCpuMapping) {
260     return pGpuResource->__cisubscriptionUnmap__(pGpuResource, pCallContext, pCpuMapping);
261 }
262 
cisubscriptionGetMemInterMapParams_DISPATCH(struct ComputeInstanceSubscription * pRmResource,RMRES_MEM_INTER_MAP_PARAMS * pParams)263 static inline NV_STATUS cisubscriptionGetMemInterMapParams_DISPATCH(struct ComputeInstanceSubscription *pRmResource, RMRES_MEM_INTER_MAP_PARAMS *pParams) {
264     return pRmResource->__cisubscriptionGetMemInterMapParams__(pRmResource, pParams);
265 }
266 
cisubscriptionGetMemoryMappingDescriptor_DISPATCH(struct ComputeInstanceSubscription * pRmResource,struct MEMORY_DESCRIPTOR ** ppMemDesc)267 static inline NV_STATUS cisubscriptionGetMemoryMappingDescriptor_DISPATCH(struct ComputeInstanceSubscription *pRmResource, struct MEMORY_DESCRIPTOR **ppMemDesc) {
268     return pRmResource->__cisubscriptionGetMemoryMappingDescriptor__(pRmResource, ppMemDesc);
269 }
270 
cisubscriptionControlFilter_DISPATCH(struct ComputeInstanceSubscription * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)271 static inline NV_STATUS cisubscriptionControlFilter_DISPATCH(struct ComputeInstanceSubscription *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
272     return pResource->__cisubscriptionControlFilter__(pResource, pCallContext, pParams);
273 }
274 
cisubscriptionControlSerialization_Prologue_DISPATCH(struct ComputeInstanceSubscription * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)275 static inline NV_STATUS cisubscriptionControlSerialization_Prologue_DISPATCH(struct ComputeInstanceSubscription *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
276     return pResource->__cisubscriptionControlSerialization_Prologue__(pResource, pCallContext, pParams);
277 }
278 
cisubscriptionIsPartialUnmapSupported_DISPATCH(struct ComputeInstanceSubscription * pResource)279 static inline NvBool cisubscriptionIsPartialUnmapSupported_DISPATCH(struct ComputeInstanceSubscription *pResource) {
280     return pResource->__cisubscriptionIsPartialUnmapSupported__(pResource);
281 }
282 
cisubscriptionPreDestruct_DISPATCH(struct ComputeInstanceSubscription * pResource)283 static inline void cisubscriptionPreDestruct_DISPATCH(struct ComputeInstanceSubscription *pResource) {
284     pResource->__cisubscriptionPreDestruct__(pResource);
285 }
286 
cisubscriptionIsDuplicate_DISPATCH(struct ComputeInstanceSubscription * pResource,NvHandle hMemory,NvBool * pDuplicate)287 static inline NV_STATUS cisubscriptionIsDuplicate_DISPATCH(struct ComputeInstanceSubscription *pResource, NvHandle hMemory, NvBool *pDuplicate) {
288     return pResource->__cisubscriptionIsDuplicate__(pResource, hMemory, pDuplicate);
289 }
290 
cisubscriptionControlSerialization_Epilogue_DISPATCH(struct ComputeInstanceSubscription * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)291 static inline void cisubscriptionControlSerialization_Epilogue_DISPATCH(struct ComputeInstanceSubscription *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
292     pResource->__cisubscriptionControlSerialization_Epilogue__(pResource, pCallContext, pParams);
293 }
294 
cisubscriptionMap_DISPATCH(struct ComputeInstanceSubscription * pGpuResource,struct CALL_CONTEXT * pCallContext,struct RS_CPU_MAP_PARAMS * pParams,struct RsCpuMapping * pCpuMapping)295 static inline NV_STATUS cisubscriptionMap_DISPATCH(struct ComputeInstanceSubscription *pGpuResource, struct CALL_CONTEXT *pCallContext, struct RS_CPU_MAP_PARAMS *pParams, struct RsCpuMapping *pCpuMapping) {
296     return pGpuResource->__cisubscriptionMap__(pGpuResource, pCallContext, pParams, pCpuMapping);
297 }
298 
cisubscriptionAccessCallback_DISPATCH(struct ComputeInstanceSubscription * pResource,struct RsClient * pInvokingClient,void * pAllocParams,RsAccessRight accessRight)299 static inline NvBool cisubscriptionAccessCallback_DISPATCH(struct ComputeInstanceSubscription *pResource, struct RsClient *pInvokingClient, void *pAllocParams, RsAccessRight accessRight) {
300     return pResource->__cisubscriptionAccessCallback__(pResource, pInvokingClient, pAllocParams, accessRight);
301 }
302 
cisubscriptionGetMIGComputeInstance(struct ComputeInstanceSubscription * pComputeInstanceSubscription)303 static inline MIG_COMPUTE_INSTANCE *cisubscriptionGetMIGComputeInstance(struct ComputeInstanceSubscription *pComputeInstanceSubscription) {
304     struct ComputeInstanceSubscription_PRIVATE *pComputeInstanceSubscription_PRIVATE = (struct ComputeInstanceSubscription_PRIVATE *)pComputeInstanceSubscription;
305     return pComputeInstanceSubscription_PRIVATE->pMIGComputeInstance;
306 }
307 
308 NV_STATUS cisubscriptionGetComputeInstanceSubscription_IMPL(struct RsClient *arg0, NvHandle arg1, struct ComputeInstanceSubscription **arg2);
309 
310 #define cisubscriptionGetComputeInstanceSubscription(arg0, arg1, arg2) cisubscriptionGetComputeInstanceSubscription_IMPL(arg0, arg1, arg2)
311 NV_STATUS cisubscriptionConstruct_IMPL(struct ComputeInstanceSubscription *arg_pComputeInstanceSubscription, CALL_CONTEXT *arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL *arg_pParams);
312 
313 #define __nvoc_cisubscriptionConstruct(arg_pComputeInstanceSubscription, arg_pCallContext, arg_pParams) cisubscriptionConstruct_IMPL(arg_pComputeInstanceSubscription, arg_pCallContext, arg_pParams)
314 NV_STATUS cisubscriptionCopyConstruct_IMPL(struct ComputeInstanceSubscription *arg0, CALL_CONTEXT *arg1, struct RS_RES_ALLOC_PARAMS_INTERNAL *arg2);
315 
316 #ifdef __nvoc_compute_instance_subscription_h_disabled
cisubscriptionCopyConstruct(struct ComputeInstanceSubscription * arg0,CALL_CONTEXT * arg1,struct RS_RES_ALLOC_PARAMS_INTERNAL * arg2)317 static inline NV_STATUS cisubscriptionCopyConstruct(struct ComputeInstanceSubscription *arg0, CALL_CONTEXT *arg1, struct RS_RES_ALLOC_PARAMS_INTERNAL *arg2) {
318     NV_ASSERT_FAILED_PRECOMP("ComputeInstanceSubscription was disabled!");
319     return NV_ERR_NOT_SUPPORTED;
320 }
321 #else //__nvoc_compute_instance_subscription_h_disabled
322 #define cisubscriptionCopyConstruct(arg0, arg1, arg2) cisubscriptionCopyConstruct_IMPL(arg0, arg1, arg2)
323 #endif //__nvoc_compute_instance_subscription_h_disabled
324 
325 void cisubscriptionDestruct_IMPL(struct ComputeInstanceSubscription *arg0);
326 
327 #define __nvoc_cisubscriptionDestruct(arg0) cisubscriptionDestruct_IMPL(arg0)
328 #undef PRIVATE_FIELD
329 
330 
331 #endif // COMPUTE_INSTANCE_SUBSCRIPTION_H
332 
333 
334 #ifdef __cplusplus
335 } // extern "C"
336 #endif
337 
338 #endif // _G_COMPUTE_INSTANCE_SUBSCRIPTION_NVOC_H_
339