1 #ifndef _G_RESOURCE_NVOC_H_
2 #define _G_RESOURCE_NVOC_H_
3 #include "nvoc/runtime.h"
4
5 #ifdef __cplusplus
6 extern "C" {
7 #endif
8
9 /*
10 * SPDX-FileCopyrightText: Copyright (c) 2018-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 #include "g_resource_nvoc.h"
33
34 #ifndef _RESOURCE_H_
35 #define _RESOURCE_H_
36
37 #include "core/core.h"
38 #include "resserv/rs_resource.h"
39 #include "rmapi/control.h"
40
41 /* Forward declarations */
42 struct MEMORY_DESCRIPTOR;
43 struct OBJVASPACE;
44
45 struct RMRES_MEM_INTER_MAP_PARAMS
46 {
47 /// [in]
48 OBJGPU *pGpu;
49 RsResourceRef *pMemoryRef;
50 NvBool bSubdeviceHandleProvided;
51
52 /// [out]
53 OBJGPU *pSrcGpu;
54 struct MEMORY_DESCRIPTOR *pSrcMemDesc;
55 NvHandle hMemoryDevice;
56 // This flag will be set when this is FLA mapping
57 NvBool bFlaMapping;
58 };
59
60 struct RS_RES_MAP_TO_PARAMS
61 {
62 OBJGPU *pGpu; ///< [in]
63 OBJGPU *pSrcGpu; ///< [in]
64 struct MEMORY_DESCRIPTOR *pSrcMemDesc; ///< [in]
65 struct MEMORY_DESCRIPTOR **ppMemDesc; ///< [out]
66 RsResourceRef *pMemoryRef; ///< [in]
67 NvHandle hBroadcastDevice; ///< [in]
68 NvHandle hMemoryDevice; ///< [in]
69 NvU32 gpuMask; ///< [in]
70 NvU64 offset; ///< [in]
71 NvU64 length; ///< [in]
72 NvU32 flags; ///< [in]
73 NvU64 *pDmaOffset; ///< [inout]
74 NvBool bSubdeviceHandleProvided; ///< [in]
75 NvBool bFlaMapping; ///< [in]
76 };
77
78 struct RS_RES_UNMAP_FROM_PARAMS
79 {
80 OBJGPU *pGpu; ///< [in]
81 NvHandle hMemory; ///< [in]
82 NvHandle hBroadcastDevice; ///< [in]
83 NvU32 gpuMask; ///< [in]
84 NvU32 flags; ///< [in]
85 NvU64 dmaOffset; ///< [in]
86 NvU64 size; ///< [in]
87 struct MEMORY_DESCRIPTOR *pMemDesc; ///< [in]
88 NvBool bSubdeviceHandleProvided; ///< [in]
89 };
90
91 struct RS_INTER_MAP_PRIVATE
92 {
93 OBJGPU *pGpu;
94 OBJGPU *pSrcGpu;
95 struct MEMORY_DESCRIPTOR *pSrcMemDesc;
96 NvHandle hBroadcastDevice;
97 NvHandle hMemoryDevice;
98 NvU32 gpuMask;
99 NvBool bSubdeviceHandleProvided;
100 NvBool bFlaMapping;
101 };
102
103 struct RS_INTER_UNMAP_PRIVATE
104 {
105 OBJGPU *pGpu;
106 NvHandle hBroadcastDevice;
107 NvU32 gpuMask;
108 NvBool bSubdeviceHandleProvided;
109 NvBool bcState;
110 NvBool bAllocated; ///< This struct has been allocated and must be freed
111 };
112
113 struct RS_CPU_MAPPING_PRIVATE
114 {
115 NvU64 gpuAddress;
116 NvU64 gpuMapLength;
117 OBJGPU *pGpu;
118 NvP64 pPriv;
119 NvU32 protect;
120 NvBool bKernel;
121 };
122
123 typedef struct RMRES_MEM_INTER_MAP_PARAMS RMRES_MEM_INTER_MAP_PARAMS;
124
125 /*!
126 * All RsResource subclasses in RM must inherit from this class
127 */
128
129 // Private field names are wrapped in PRIVATE_FIELD, which does nothing for
130 // the matching C source file, but causes diagnostics to be issued if another
131 // source file references the field.
132 #ifdef NVOC_RESOURCE_H_PRIVATE_ACCESS_ALLOWED
133 #define PRIVATE_FIELD(x) x
134 #else
135 #define PRIVATE_FIELD(x) NVOC_PRIVATE_FIELD(x)
136 #endif
137
138 struct RmResourceCommon {
139 const struct NVOC_RTTI *__nvoc_rtti;
140 struct RmResourceCommon *__nvoc_pbase_RmResourceCommon;
141 };
142
143 #ifndef __NVOC_CLASS_RmResourceCommon_TYPEDEF__
144 #define __NVOC_CLASS_RmResourceCommon_TYPEDEF__
145 typedef struct RmResourceCommon RmResourceCommon;
146 #endif /* __NVOC_CLASS_RmResourceCommon_TYPEDEF__ */
147
148 #ifndef __nvoc_class_id_RmResourceCommon
149 #define __nvoc_class_id_RmResourceCommon 0x8ef259
150 #endif /* __nvoc_class_id_RmResourceCommon */
151
152 extern const struct NVOC_CLASS_DEF __nvoc_class_def_RmResourceCommon;
153
154 #define __staticCast_RmResourceCommon(pThis) \
155 ((pThis)->__nvoc_pbase_RmResourceCommon)
156
157 #ifdef __nvoc_resource_h_disabled
158 #define __dynamicCast_RmResourceCommon(pThis) ((RmResourceCommon*)NULL)
159 #else //__nvoc_resource_h_disabled
160 #define __dynamicCast_RmResourceCommon(pThis) \
161 ((RmResourceCommon*)__nvoc_dynamicCast(staticCast((pThis), Dynamic), classInfo(RmResourceCommon)))
162 #endif //__nvoc_resource_h_disabled
163
164
165 NV_STATUS __nvoc_objCreateDynamic_RmResourceCommon(RmResourceCommon**, Dynamic*, NvU32, va_list);
166
167 NV_STATUS __nvoc_objCreate_RmResourceCommon(RmResourceCommon**, Dynamic*, NvU32);
168 #define __objCreate_RmResourceCommon(ppNewObj, pParent, createFlags) \
169 __nvoc_objCreate_RmResourceCommon((ppNewObj), staticCast((pParent), Dynamic), (createFlags))
170
171 NV_STATUS rmrescmnConstruct_IMPL(struct RmResourceCommon *arg_pResourceCommmon);
172
173 #define __nvoc_rmrescmnConstruct(arg_pResourceCommmon) rmrescmnConstruct_IMPL(arg_pResourceCommmon)
174 #undef PRIVATE_FIELD
175
176
177 /*!
178 * Utility base class for all RsResource subclasses in by RM. Doesn't have to be
179 * used but if it isn't used RmResourceCommon must be inherited manually
180 */
181
182 // Private field names are wrapped in PRIVATE_FIELD, which does nothing for
183 // the matching C source file, but causes diagnostics to be issued if another
184 // source file references the field.
185 #ifdef NVOC_RESOURCE_H_PRIVATE_ACCESS_ALLOWED
186 #define PRIVATE_FIELD(x) x
187 #else
188 #define PRIVATE_FIELD(x) NVOC_PRIVATE_FIELD(x)
189 #endif
190
191 struct RmResource {
192 const struct NVOC_RTTI *__nvoc_rtti;
193 struct RsResource __nvoc_base_RsResource;
194 struct RmResourceCommon __nvoc_base_RmResourceCommon;
195 struct Object *__nvoc_pbase_Object;
196 struct RsResource *__nvoc_pbase_RsResource;
197 struct RmResourceCommon *__nvoc_pbase_RmResourceCommon;
198 struct RmResource *__nvoc_pbase_RmResource;
199 NvBool (*__rmresAccessCallback__)(struct RmResource *, struct RsClient *, void *, RsAccessRight);
200 NvBool (*__rmresShareCallback__)(struct RmResource *, struct RsClient *, struct RsResourceRef *, RS_SHARE_POLICY *);
201 NV_STATUS (*__rmresGetMemInterMapParams__)(struct RmResource *, RMRES_MEM_INTER_MAP_PARAMS *);
202 NV_STATUS (*__rmresCheckMemInterUnmap__)(struct RmResource *, NvBool);
203 NV_STATUS (*__rmresGetMemoryMappingDescriptor__)(struct RmResource *, struct MEMORY_DESCRIPTOR **);
204 NV_STATUS (*__rmresControlSerialization_Prologue__)(struct RmResource *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
205 void (*__rmresControlSerialization_Epilogue__)(struct RmResource *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
206 NV_STATUS (*__rmresControl_Prologue__)(struct RmResource *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
207 void (*__rmresControl_Epilogue__)(struct RmResource *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
208 NV_STATUS (*__rmresControl__)(struct RmResource *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
209 NV_STATUS (*__rmresUnmap__)(struct RmResource *, struct CALL_CONTEXT *, RsCpuMapping *);
210 NV_STATUS (*__rmresMapTo__)(struct RmResource *, RS_RES_MAP_TO_PARAMS *);
211 NvU32 (*__rmresGetRefCount__)(struct RmResource *);
212 NV_STATUS (*__rmresControlFilter__)(struct RmResource *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
213 void (*__rmresAddAdditionalDependants__)(struct RsClient *, struct RmResource *, RsResourceRef *);
214 NvBool (*__rmresCanCopy__)(struct RmResource *);
215 NvBool (*__rmresIsPartialUnmapSupported__)(struct RmResource *);
216 void (*__rmresPreDestruct__)(struct RmResource *);
217 NV_STATUS (*__rmresUnmapFrom__)(struct RmResource *, RS_RES_UNMAP_FROM_PARAMS *);
218 NV_STATUS (*__rmresIsDuplicate__)(struct RmResource *, NvHandle, NvBool *);
219 NV_STATUS (*__rmresMap__)(struct RmResource *, struct CALL_CONTEXT *, RS_CPU_MAP_PARAMS *, RsCpuMapping *);
220 NvU32 rpcGpuInstance;
221 NvBool bRpcFree;
222 };
223
224 #ifndef __NVOC_CLASS_RmResource_TYPEDEF__
225 #define __NVOC_CLASS_RmResource_TYPEDEF__
226 typedef struct RmResource RmResource;
227 #endif /* __NVOC_CLASS_RmResource_TYPEDEF__ */
228
229 #ifndef __nvoc_class_id_RmResource
230 #define __nvoc_class_id_RmResource 0x03610d
231 #endif /* __nvoc_class_id_RmResource */
232
233 extern const struct NVOC_CLASS_DEF __nvoc_class_def_RmResource;
234
235 #define __staticCast_RmResource(pThis) \
236 ((pThis)->__nvoc_pbase_RmResource)
237
238 #ifdef __nvoc_resource_h_disabled
239 #define __dynamicCast_RmResource(pThis) ((RmResource*)NULL)
240 #else //__nvoc_resource_h_disabled
241 #define __dynamicCast_RmResource(pThis) \
242 ((RmResource*)__nvoc_dynamicCast(staticCast((pThis), Dynamic), classInfo(RmResource)))
243 #endif //__nvoc_resource_h_disabled
244
245
246 NV_STATUS __nvoc_objCreateDynamic_RmResource(RmResource**, Dynamic*, NvU32, va_list);
247
248 NV_STATUS __nvoc_objCreate_RmResource(RmResource**, Dynamic*, NvU32, struct CALL_CONTEXT * arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams);
249 #define __objCreate_RmResource(ppNewObj, pParent, createFlags, arg_pCallContext, arg_pParams) \
250 __nvoc_objCreate_RmResource((ppNewObj), staticCast((pParent), Dynamic), (createFlags), arg_pCallContext, arg_pParams)
251
252 #define rmresAccessCallback(pResource, pInvokingClient, pAllocParams, accessRight) rmresAccessCallback_DISPATCH(pResource, pInvokingClient, pAllocParams, accessRight)
253 #define rmresShareCallback(pResource, pInvokingClient, pParentRef, pSharePolicy) rmresShareCallback_DISPATCH(pResource, pInvokingClient, pParentRef, pSharePolicy)
254 #define rmresGetMemInterMapParams(pRmResource, pParams) rmresGetMemInterMapParams_DISPATCH(pRmResource, pParams)
255 #define rmresCheckMemInterUnmap(pRmResource, bSubdeviceHandleProvided) rmresCheckMemInterUnmap_DISPATCH(pRmResource, bSubdeviceHandleProvided)
256 #define rmresGetMemoryMappingDescriptor(pRmResource, ppMemDesc) rmresGetMemoryMappingDescriptor_DISPATCH(pRmResource, ppMemDesc)
257 #define rmresControlSerialization_Prologue(pResource, pCallContext, pParams) rmresControlSerialization_Prologue_DISPATCH(pResource, pCallContext, pParams)
258 #define rmresControlSerialization_Epilogue(pResource, pCallContext, pParams) rmresControlSerialization_Epilogue_DISPATCH(pResource, pCallContext, pParams)
259 #define rmresControl_Prologue(pResource, pCallContext, pParams) rmresControl_Prologue_DISPATCH(pResource, pCallContext, pParams)
260 #define rmresControl_Epilogue(pResource, pCallContext, pParams) rmresControl_Epilogue_DISPATCH(pResource, pCallContext, pParams)
261 #define rmresControl(pResource, pCallContext, pParams) rmresControl_DISPATCH(pResource, pCallContext, pParams)
262 #define rmresUnmap(pResource, pCallContext, pCpuMapping) rmresUnmap_DISPATCH(pResource, pCallContext, pCpuMapping)
263 #define rmresMapTo(pResource, pParams) rmresMapTo_DISPATCH(pResource, pParams)
264 #define rmresGetRefCount(pResource) rmresGetRefCount_DISPATCH(pResource)
265 #define rmresControlFilter(pResource, pCallContext, pParams) rmresControlFilter_DISPATCH(pResource, pCallContext, pParams)
266 #define rmresAddAdditionalDependants(pClient, pResource, pReference) rmresAddAdditionalDependants_DISPATCH(pClient, pResource, pReference)
267 #define rmresCanCopy(pResource) rmresCanCopy_DISPATCH(pResource)
268 #define rmresIsPartialUnmapSupported(pResource) rmresIsPartialUnmapSupported_DISPATCH(pResource)
269 #define rmresPreDestruct(pResource) rmresPreDestruct_DISPATCH(pResource)
270 #define rmresUnmapFrom(pResource, pParams) rmresUnmapFrom_DISPATCH(pResource, pParams)
271 #define rmresIsDuplicate(pResource, hMemory, pDuplicate) rmresIsDuplicate_DISPATCH(pResource, hMemory, pDuplicate)
272 #define rmresMap(pResource, pCallContext, pParams, pCpuMapping) rmresMap_DISPATCH(pResource, pCallContext, pParams, pCpuMapping)
273 NvBool rmresAccessCallback_IMPL(struct RmResource *pResource, struct RsClient *pInvokingClient, void *pAllocParams, RsAccessRight accessRight);
274
rmresAccessCallback_DISPATCH(struct RmResource * pResource,struct RsClient * pInvokingClient,void * pAllocParams,RsAccessRight accessRight)275 static inline NvBool rmresAccessCallback_DISPATCH(struct RmResource *pResource, struct RsClient *pInvokingClient, void *pAllocParams, RsAccessRight accessRight) {
276 return pResource->__rmresAccessCallback__(pResource, pInvokingClient, pAllocParams, accessRight);
277 }
278
279 NvBool rmresShareCallback_IMPL(struct RmResource *pResource, struct RsClient *pInvokingClient, struct RsResourceRef *pParentRef, RS_SHARE_POLICY *pSharePolicy);
280
rmresShareCallback_DISPATCH(struct RmResource * pResource,struct RsClient * pInvokingClient,struct RsResourceRef * pParentRef,RS_SHARE_POLICY * pSharePolicy)281 static inline NvBool rmresShareCallback_DISPATCH(struct RmResource *pResource, struct RsClient *pInvokingClient, struct RsResourceRef *pParentRef, RS_SHARE_POLICY *pSharePolicy) {
282 return pResource->__rmresShareCallback__(pResource, pInvokingClient, pParentRef, pSharePolicy);
283 }
284
285 NV_STATUS rmresGetMemInterMapParams_IMPL(struct RmResource *pRmResource, RMRES_MEM_INTER_MAP_PARAMS *pParams);
286
rmresGetMemInterMapParams_DISPATCH(struct RmResource * pRmResource,RMRES_MEM_INTER_MAP_PARAMS * pParams)287 static inline NV_STATUS rmresGetMemInterMapParams_DISPATCH(struct RmResource *pRmResource, RMRES_MEM_INTER_MAP_PARAMS *pParams) {
288 return pRmResource->__rmresGetMemInterMapParams__(pRmResource, pParams);
289 }
290
291 NV_STATUS rmresCheckMemInterUnmap_IMPL(struct RmResource *pRmResource, NvBool bSubdeviceHandleProvided);
292
rmresCheckMemInterUnmap_DISPATCH(struct RmResource * pRmResource,NvBool bSubdeviceHandleProvided)293 static inline NV_STATUS rmresCheckMemInterUnmap_DISPATCH(struct RmResource *pRmResource, NvBool bSubdeviceHandleProvided) {
294 return pRmResource->__rmresCheckMemInterUnmap__(pRmResource, bSubdeviceHandleProvided);
295 }
296
297 NV_STATUS rmresGetMemoryMappingDescriptor_IMPL(struct RmResource *pRmResource, struct MEMORY_DESCRIPTOR **ppMemDesc);
298
rmresGetMemoryMappingDescriptor_DISPATCH(struct RmResource * pRmResource,struct MEMORY_DESCRIPTOR ** ppMemDesc)299 static inline NV_STATUS rmresGetMemoryMappingDescriptor_DISPATCH(struct RmResource *pRmResource, struct MEMORY_DESCRIPTOR **ppMemDesc) {
300 return pRmResource->__rmresGetMemoryMappingDescriptor__(pRmResource, ppMemDesc);
301 }
302
303 NV_STATUS rmresControlSerialization_Prologue_IMPL(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams);
304
rmresControlSerialization_Prologue_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)305 static inline NV_STATUS rmresControlSerialization_Prologue_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
306 return pResource->__rmresControlSerialization_Prologue__(pResource, pCallContext, pParams);
307 }
308
309 void rmresControlSerialization_Epilogue_IMPL(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams);
310
rmresControlSerialization_Epilogue_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)311 static inline void rmresControlSerialization_Epilogue_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
312 pResource->__rmresControlSerialization_Epilogue__(pResource, pCallContext, pParams);
313 }
314
315 NV_STATUS rmresControl_Prologue_IMPL(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams);
316
rmresControl_Prologue_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)317 static inline NV_STATUS rmresControl_Prologue_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
318 return pResource->__rmresControl_Prologue__(pResource, pCallContext, pParams);
319 }
320
321 void rmresControl_Epilogue_IMPL(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams);
322
rmresControl_Epilogue_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)323 static inline void rmresControl_Epilogue_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
324 pResource->__rmresControl_Epilogue__(pResource, pCallContext, pParams);
325 }
326
rmresControl_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)327 static inline NV_STATUS rmresControl_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
328 return pResource->__rmresControl__(pResource, pCallContext, pParams);
329 }
330
rmresUnmap_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,RsCpuMapping * pCpuMapping)331 static inline NV_STATUS rmresUnmap_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, RsCpuMapping *pCpuMapping) {
332 return pResource->__rmresUnmap__(pResource, pCallContext, pCpuMapping);
333 }
334
rmresMapTo_DISPATCH(struct RmResource * pResource,RS_RES_MAP_TO_PARAMS * pParams)335 static inline NV_STATUS rmresMapTo_DISPATCH(struct RmResource *pResource, RS_RES_MAP_TO_PARAMS *pParams) {
336 return pResource->__rmresMapTo__(pResource, pParams);
337 }
338
rmresGetRefCount_DISPATCH(struct RmResource * pResource)339 static inline NvU32 rmresGetRefCount_DISPATCH(struct RmResource *pResource) {
340 return pResource->__rmresGetRefCount__(pResource);
341 }
342
rmresControlFilter_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)343 static inline NV_STATUS rmresControlFilter_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
344 return pResource->__rmresControlFilter__(pResource, pCallContext, pParams);
345 }
346
rmresAddAdditionalDependants_DISPATCH(struct RsClient * pClient,struct RmResource * pResource,RsResourceRef * pReference)347 static inline void rmresAddAdditionalDependants_DISPATCH(struct RsClient *pClient, struct RmResource *pResource, RsResourceRef *pReference) {
348 pResource->__rmresAddAdditionalDependants__(pClient, pResource, pReference);
349 }
350
rmresCanCopy_DISPATCH(struct RmResource * pResource)351 static inline NvBool rmresCanCopy_DISPATCH(struct RmResource *pResource) {
352 return pResource->__rmresCanCopy__(pResource);
353 }
354
rmresIsPartialUnmapSupported_DISPATCH(struct RmResource * pResource)355 static inline NvBool rmresIsPartialUnmapSupported_DISPATCH(struct RmResource *pResource) {
356 return pResource->__rmresIsPartialUnmapSupported__(pResource);
357 }
358
rmresPreDestruct_DISPATCH(struct RmResource * pResource)359 static inline void rmresPreDestruct_DISPATCH(struct RmResource *pResource) {
360 pResource->__rmresPreDestruct__(pResource);
361 }
362
rmresUnmapFrom_DISPATCH(struct RmResource * pResource,RS_RES_UNMAP_FROM_PARAMS * pParams)363 static inline NV_STATUS rmresUnmapFrom_DISPATCH(struct RmResource *pResource, RS_RES_UNMAP_FROM_PARAMS *pParams) {
364 return pResource->__rmresUnmapFrom__(pResource, pParams);
365 }
366
rmresIsDuplicate_DISPATCH(struct RmResource * pResource,NvHandle hMemory,NvBool * pDuplicate)367 static inline NV_STATUS rmresIsDuplicate_DISPATCH(struct RmResource *pResource, NvHandle hMemory, NvBool *pDuplicate) {
368 return pResource->__rmresIsDuplicate__(pResource, hMemory, pDuplicate);
369 }
370
rmresMap_DISPATCH(struct RmResource * pResource,struct CALL_CONTEXT * pCallContext,RS_CPU_MAP_PARAMS * pParams,RsCpuMapping * pCpuMapping)371 static inline NV_STATUS rmresMap_DISPATCH(struct RmResource *pResource, struct CALL_CONTEXT *pCallContext, RS_CPU_MAP_PARAMS *pParams, RsCpuMapping *pCpuMapping) {
372 return pResource->__rmresMap__(pResource, pCallContext, pParams, pCpuMapping);
373 }
374
375 NV_STATUS rmresConstruct_IMPL(struct RmResource *arg_pResource, struct CALL_CONTEXT *arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL *arg_pParams);
376
377 #define __nvoc_rmresConstruct(arg_pResource, arg_pCallContext, arg_pParams) rmresConstruct_IMPL(arg_pResource, arg_pCallContext, arg_pParams)
378 #undef PRIVATE_FIELD
379
380
381 #endif // _RESOURCE_H_
382
383
384 #ifdef __cplusplus
385 } // extern "C"
386 #endif
387
388 #endif // _G_RESOURCE_NVOC_H_
389