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