1 #ifndef _G_NO_DEVICE_MEM_NVOC_H_
2 #define _G_NO_DEVICE_MEM_NVOC_H_
3 #include "nvoc/runtime.h"
4 
5 #ifdef __cplusplus
6 extern "C" {
7 #endif
8 
9 /*
10  * SPDX-FileCopyrightText: Copyright (c) 2018 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_no_device_mem_nvoc.h"
33 
34 #ifndef _NO_DEVICE_MEMORY_H_
35 #define _NO_DEVICE_MEMORY_H_
36 
37 #include "mem_mgr/mem.h"
38 
39 /**
40  * This class represents contiguous system memory that is associated with a
41  * client instead of a device. This object can be used for memory allocations
42  * that should survive device teardown.
43  */
44 
45 // Private field names are wrapped in PRIVATE_FIELD, which does nothing for
46 // the matching C source file, but causes diagnostics to be issued if another
47 // source file references the field.
48 #ifdef NVOC_NO_DEVICE_MEM_H_PRIVATE_ACCESS_ALLOWED
49 #define PRIVATE_FIELD(x) x
50 #else
51 #define PRIVATE_FIELD(x) NVOC_PRIVATE_FIELD(x)
52 #endif
53 
54 struct NoDeviceMemory {
55     const struct NVOC_RTTI *__nvoc_rtti;
56     struct Memory __nvoc_base_Memory;
57     struct Object *__nvoc_pbase_Object;
58     struct RsResource *__nvoc_pbase_RsResource;
59     struct RmResourceCommon *__nvoc_pbase_RmResourceCommon;
60     struct RmResource *__nvoc_pbase_RmResource;
61     struct Memory *__nvoc_pbase_Memory;
62     struct NoDeviceMemory *__nvoc_pbase_NoDeviceMemory;
63     NV_STATUS (*__nodevicememGetMapAddrSpace__)(struct NoDeviceMemory *, CALL_CONTEXT *, NvU32, NV_ADDRESS_SPACE *);
64     NV_STATUS (*__nodevicememCheckMemInterUnmap__)(struct NoDeviceMemory *, NvBool);
65     NvBool (*__nodevicememShareCallback__)(struct NoDeviceMemory *, struct RsClient *, struct RsResourceRef *, RS_SHARE_POLICY *);
66     NV_STATUS (*__nodevicememMapTo__)(struct NoDeviceMemory *, RS_RES_MAP_TO_PARAMS *);
67     NvBool (*__nodevicememIsExportAllowed__)(struct NoDeviceMemory *);
68     NvU32 (*__nodevicememGetRefCount__)(struct NoDeviceMemory *);
69     void (*__nodevicememAddAdditionalDependants__)(struct RsClient *, struct NoDeviceMemory *, RsResourceRef *);
70     NV_STATUS (*__nodevicememControl_Prologue__)(struct NoDeviceMemory *, CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
71     NvBool (*__nodevicememIsGpuMapAllowed__)(struct NoDeviceMemory *, struct OBJGPU *);
72     NV_STATUS (*__nodevicememUnmapFrom__)(struct NoDeviceMemory *, RS_RES_UNMAP_FROM_PARAMS *);
73     void (*__nodevicememControl_Epilogue__)(struct NoDeviceMemory *, CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
74     NV_STATUS (*__nodevicememControl__)(struct NoDeviceMemory *, CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
75     NV_STATUS (*__nodevicememUnmap__)(struct NoDeviceMemory *, CALL_CONTEXT *, RsCpuMapping *);
76     NV_STATUS (*__nodevicememGetMemInterMapParams__)(struct NoDeviceMemory *, RMRES_MEM_INTER_MAP_PARAMS *);
77     NV_STATUS (*__nodevicememGetMemoryMappingDescriptor__)(struct NoDeviceMemory *, MEMORY_DESCRIPTOR **);
78     NV_STATUS (*__nodevicememControlFilter__)(struct NoDeviceMemory *, struct CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
79     NV_STATUS (*__nodevicememControlSerialization_Prologue__)(struct NoDeviceMemory *, CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
80     NvBool (*__nodevicememCanCopy__)(struct NoDeviceMemory *);
81     NvBool (*__nodevicememIsPartialUnmapSupported__)(struct NoDeviceMemory *);
82     NV_STATUS (*__nodevicememIsReady__)(struct NoDeviceMemory *, NvBool);
83     NV_STATUS (*__nodevicememCheckCopyPermissions__)(struct NoDeviceMemory *, struct OBJGPU *, struct Device *);
84     void (*__nodevicememPreDestruct__)(struct NoDeviceMemory *);
85     NV_STATUS (*__nodevicememIsDuplicate__)(struct NoDeviceMemory *, NvHandle, NvBool *);
86     void (*__nodevicememControlSerialization_Epilogue__)(struct NoDeviceMemory *, CALL_CONTEXT *, struct RS_RES_CONTROL_PARAMS_INTERNAL *);
87     NV_STATUS (*__nodevicememMap__)(struct NoDeviceMemory *, CALL_CONTEXT *, struct RS_CPU_MAP_PARAMS *, RsCpuMapping *);
88     NvBool (*__nodevicememAccessCallback__)(struct NoDeviceMemory *, struct RsClient *, void *, RsAccessRight);
89 };
90 
91 #ifndef __NVOC_CLASS_NoDeviceMemory_TYPEDEF__
92 #define __NVOC_CLASS_NoDeviceMemory_TYPEDEF__
93 typedef struct NoDeviceMemory NoDeviceMemory;
94 #endif /* __NVOC_CLASS_NoDeviceMemory_TYPEDEF__ */
95 
96 #ifndef __nvoc_class_id_NoDeviceMemory
97 #define __nvoc_class_id_NoDeviceMemory 0x6c0832
98 #endif /* __nvoc_class_id_NoDeviceMemory */
99 
100 extern const struct NVOC_CLASS_DEF __nvoc_class_def_NoDeviceMemory;
101 
102 #define __staticCast_NoDeviceMemory(pThis) \
103     ((pThis)->__nvoc_pbase_NoDeviceMemory)
104 
105 #ifdef __nvoc_no_device_mem_h_disabled
106 #define __dynamicCast_NoDeviceMemory(pThis) ((NoDeviceMemory*)NULL)
107 #else //__nvoc_no_device_mem_h_disabled
108 #define __dynamicCast_NoDeviceMemory(pThis) \
109     ((NoDeviceMemory*)__nvoc_dynamicCast(staticCast((pThis), Dynamic), classInfo(NoDeviceMemory)))
110 #endif //__nvoc_no_device_mem_h_disabled
111 
112 
113 NV_STATUS __nvoc_objCreateDynamic_NoDeviceMemory(NoDeviceMemory**, Dynamic*, NvU32, va_list);
114 
115 NV_STATUS __nvoc_objCreate_NoDeviceMemory(NoDeviceMemory**, Dynamic*, NvU32, CALL_CONTEXT * arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL * arg_pParams);
116 #define __objCreate_NoDeviceMemory(ppNewObj, pParent, createFlags, arg_pCallContext, arg_pParams) \
117     __nvoc_objCreate_NoDeviceMemory((ppNewObj), staticCast((pParent), Dynamic), (createFlags), arg_pCallContext, arg_pParams)
118 
119 #define nodevicememGetMapAddrSpace(pNoDeviceMemory, pCallContext, mapFlags, pAddrSpace) nodevicememGetMapAddrSpace_DISPATCH(pNoDeviceMemory, pCallContext, mapFlags, pAddrSpace)
120 #define nodevicememCheckMemInterUnmap(pMemory, bSubdeviceHandleProvided) nodevicememCheckMemInterUnmap_DISPATCH(pMemory, bSubdeviceHandleProvided)
121 #define nodevicememShareCallback(pResource, pInvokingClient, pParentRef, pSharePolicy) nodevicememShareCallback_DISPATCH(pResource, pInvokingClient, pParentRef, pSharePolicy)
122 #define nodevicememMapTo(pResource, pParams) nodevicememMapTo_DISPATCH(pResource, pParams)
123 #define nodevicememIsExportAllowed(pMemory) nodevicememIsExportAllowed_DISPATCH(pMemory)
124 #define nodevicememGetRefCount(pResource) nodevicememGetRefCount_DISPATCH(pResource)
125 #define nodevicememAddAdditionalDependants(pClient, pResource, pReference) nodevicememAddAdditionalDependants_DISPATCH(pClient, pResource, pReference)
126 #define nodevicememControl_Prologue(pResource, pCallContext, pParams) nodevicememControl_Prologue_DISPATCH(pResource, pCallContext, pParams)
127 #define nodevicememIsGpuMapAllowed(pMemory, pGpu) nodevicememIsGpuMapAllowed_DISPATCH(pMemory, pGpu)
128 #define nodevicememUnmapFrom(pResource, pParams) nodevicememUnmapFrom_DISPATCH(pResource, pParams)
129 #define nodevicememControl_Epilogue(pResource, pCallContext, pParams) nodevicememControl_Epilogue_DISPATCH(pResource, pCallContext, pParams)
130 #define nodevicememControl(pMemory, pCallContext, pParams) nodevicememControl_DISPATCH(pMemory, pCallContext, pParams)
131 #define nodevicememUnmap(pMemory, pCallContext, pCpuMapping) nodevicememUnmap_DISPATCH(pMemory, pCallContext, pCpuMapping)
132 #define nodevicememGetMemInterMapParams(pMemory, pParams) nodevicememGetMemInterMapParams_DISPATCH(pMemory, pParams)
133 #define nodevicememGetMemoryMappingDescriptor(pMemory, ppMemDesc) nodevicememGetMemoryMappingDescriptor_DISPATCH(pMemory, ppMemDesc)
134 #define nodevicememControlFilter(pResource, pCallContext, pParams) nodevicememControlFilter_DISPATCH(pResource, pCallContext, pParams)
135 #define nodevicememControlSerialization_Prologue(pResource, pCallContext, pParams) nodevicememControlSerialization_Prologue_DISPATCH(pResource, pCallContext, pParams)
136 #define nodevicememCanCopy(pResource) nodevicememCanCopy_DISPATCH(pResource)
137 #define nodevicememIsPartialUnmapSupported(pResource) nodevicememIsPartialUnmapSupported_DISPATCH(pResource)
138 #define nodevicememIsReady(pMemory, bCopyConstructorContext) nodevicememIsReady_DISPATCH(pMemory, bCopyConstructorContext)
139 #define nodevicememCheckCopyPermissions(pMemory, pDstGpu, pDstDevice) nodevicememCheckCopyPermissions_DISPATCH(pMemory, pDstGpu, pDstDevice)
140 #define nodevicememPreDestruct(pResource) nodevicememPreDestruct_DISPATCH(pResource)
141 #define nodevicememIsDuplicate(pMemory, hMemory, pDuplicate) nodevicememIsDuplicate_DISPATCH(pMemory, hMemory, pDuplicate)
142 #define nodevicememControlSerialization_Epilogue(pResource, pCallContext, pParams) nodevicememControlSerialization_Epilogue_DISPATCH(pResource, pCallContext, pParams)
143 #define nodevicememMap(pMemory, pCallContext, pParams, pCpuMapping) nodevicememMap_DISPATCH(pMemory, pCallContext, pParams, pCpuMapping)
144 #define nodevicememAccessCallback(pResource, pInvokingClient, pAllocParams, accessRight) nodevicememAccessCallback_DISPATCH(pResource, pInvokingClient, pAllocParams, accessRight)
145 NV_STATUS nodevicememGetMapAddrSpace_IMPL(struct NoDeviceMemory *pNoDeviceMemory, CALL_CONTEXT *pCallContext, NvU32 mapFlags, NV_ADDRESS_SPACE *pAddrSpace);
146 
nodevicememGetMapAddrSpace_DISPATCH(struct NoDeviceMemory * pNoDeviceMemory,CALL_CONTEXT * pCallContext,NvU32 mapFlags,NV_ADDRESS_SPACE * pAddrSpace)147 static inline NV_STATUS nodevicememGetMapAddrSpace_DISPATCH(struct NoDeviceMemory *pNoDeviceMemory, CALL_CONTEXT *pCallContext, NvU32 mapFlags, NV_ADDRESS_SPACE *pAddrSpace) {
148     return pNoDeviceMemory->__nodevicememGetMapAddrSpace__(pNoDeviceMemory, pCallContext, mapFlags, pAddrSpace);
149 }
150 
nodevicememCheckMemInterUnmap_DISPATCH(struct NoDeviceMemory * pMemory,NvBool bSubdeviceHandleProvided)151 static inline NV_STATUS nodevicememCheckMemInterUnmap_DISPATCH(struct NoDeviceMemory *pMemory, NvBool bSubdeviceHandleProvided) {
152     return pMemory->__nodevicememCheckMemInterUnmap__(pMemory, bSubdeviceHandleProvided);
153 }
154 
nodevicememShareCallback_DISPATCH(struct NoDeviceMemory * pResource,struct RsClient * pInvokingClient,struct RsResourceRef * pParentRef,RS_SHARE_POLICY * pSharePolicy)155 static inline NvBool nodevicememShareCallback_DISPATCH(struct NoDeviceMemory *pResource, struct RsClient *pInvokingClient, struct RsResourceRef *pParentRef, RS_SHARE_POLICY *pSharePolicy) {
156     return pResource->__nodevicememShareCallback__(pResource, pInvokingClient, pParentRef, pSharePolicy);
157 }
158 
nodevicememMapTo_DISPATCH(struct NoDeviceMemory * pResource,RS_RES_MAP_TO_PARAMS * pParams)159 static inline NV_STATUS nodevicememMapTo_DISPATCH(struct NoDeviceMemory *pResource, RS_RES_MAP_TO_PARAMS *pParams) {
160     return pResource->__nodevicememMapTo__(pResource, pParams);
161 }
162 
nodevicememIsExportAllowed_DISPATCH(struct NoDeviceMemory * pMemory)163 static inline NvBool nodevicememIsExportAllowed_DISPATCH(struct NoDeviceMemory *pMemory) {
164     return pMemory->__nodevicememIsExportAllowed__(pMemory);
165 }
166 
nodevicememGetRefCount_DISPATCH(struct NoDeviceMemory * pResource)167 static inline NvU32 nodevicememGetRefCount_DISPATCH(struct NoDeviceMemory *pResource) {
168     return pResource->__nodevicememGetRefCount__(pResource);
169 }
170 
nodevicememAddAdditionalDependants_DISPATCH(struct RsClient * pClient,struct NoDeviceMemory * pResource,RsResourceRef * pReference)171 static inline void nodevicememAddAdditionalDependants_DISPATCH(struct RsClient *pClient, struct NoDeviceMemory *pResource, RsResourceRef *pReference) {
172     pResource->__nodevicememAddAdditionalDependants__(pClient, pResource, pReference);
173 }
174 
nodevicememControl_Prologue_DISPATCH(struct NoDeviceMemory * pResource,CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)175 static inline NV_STATUS nodevicememControl_Prologue_DISPATCH(struct NoDeviceMemory *pResource, CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
176     return pResource->__nodevicememControl_Prologue__(pResource, pCallContext, pParams);
177 }
178 
nodevicememIsGpuMapAllowed_DISPATCH(struct NoDeviceMemory * pMemory,struct OBJGPU * pGpu)179 static inline NvBool nodevicememIsGpuMapAllowed_DISPATCH(struct NoDeviceMemory *pMemory, struct OBJGPU *pGpu) {
180     return pMemory->__nodevicememIsGpuMapAllowed__(pMemory, pGpu);
181 }
182 
nodevicememUnmapFrom_DISPATCH(struct NoDeviceMemory * pResource,RS_RES_UNMAP_FROM_PARAMS * pParams)183 static inline NV_STATUS nodevicememUnmapFrom_DISPATCH(struct NoDeviceMemory *pResource, RS_RES_UNMAP_FROM_PARAMS *pParams) {
184     return pResource->__nodevicememUnmapFrom__(pResource, pParams);
185 }
186 
nodevicememControl_Epilogue_DISPATCH(struct NoDeviceMemory * pResource,CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)187 static inline void nodevicememControl_Epilogue_DISPATCH(struct NoDeviceMemory *pResource, CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
188     pResource->__nodevicememControl_Epilogue__(pResource, pCallContext, pParams);
189 }
190 
nodevicememControl_DISPATCH(struct NoDeviceMemory * pMemory,CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)191 static inline NV_STATUS nodevicememControl_DISPATCH(struct NoDeviceMemory *pMemory, CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
192     return pMemory->__nodevicememControl__(pMemory, pCallContext, pParams);
193 }
194 
nodevicememUnmap_DISPATCH(struct NoDeviceMemory * pMemory,CALL_CONTEXT * pCallContext,RsCpuMapping * pCpuMapping)195 static inline NV_STATUS nodevicememUnmap_DISPATCH(struct NoDeviceMemory *pMemory, CALL_CONTEXT *pCallContext, RsCpuMapping *pCpuMapping) {
196     return pMemory->__nodevicememUnmap__(pMemory, pCallContext, pCpuMapping);
197 }
198 
nodevicememGetMemInterMapParams_DISPATCH(struct NoDeviceMemory * pMemory,RMRES_MEM_INTER_MAP_PARAMS * pParams)199 static inline NV_STATUS nodevicememGetMemInterMapParams_DISPATCH(struct NoDeviceMemory *pMemory, RMRES_MEM_INTER_MAP_PARAMS *pParams) {
200     return pMemory->__nodevicememGetMemInterMapParams__(pMemory, pParams);
201 }
202 
nodevicememGetMemoryMappingDescriptor_DISPATCH(struct NoDeviceMemory * pMemory,MEMORY_DESCRIPTOR ** ppMemDesc)203 static inline NV_STATUS nodevicememGetMemoryMappingDescriptor_DISPATCH(struct NoDeviceMemory *pMemory, MEMORY_DESCRIPTOR **ppMemDesc) {
204     return pMemory->__nodevicememGetMemoryMappingDescriptor__(pMemory, ppMemDesc);
205 }
206 
nodevicememControlFilter_DISPATCH(struct NoDeviceMemory * pResource,struct CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)207 static inline NV_STATUS nodevicememControlFilter_DISPATCH(struct NoDeviceMemory *pResource, struct CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
208     return pResource->__nodevicememControlFilter__(pResource, pCallContext, pParams);
209 }
210 
nodevicememControlSerialization_Prologue_DISPATCH(struct NoDeviceMemory * pResource,CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)211 static inline NV_STATUS nodevicememControlSerialization_Prologue_DISPATCH(struct NoDeviceMemory *pResource, CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
212     return pResource->__nodevicememControlSerialization_Prologue__(pResource, pCallContext, pParams);
213 }
214 
nodevicememCanCopy_DISPATCH(struct NoDeviceMemory * pResource)215 static inline NvBool nodevicememCanCopy_DISPATCH(struct NoDeviceMemory *pResource) {
216     return pResource->__nodevicememCanCopy__(pResource);
217 }
218 
nodevicememIsPartialUnmapSupported_DISPATCH(struct NoDeviceMemory * pResource)219 static inline NvBool nodevicememIsPartialUnmapSupported_DISPATCH(struct NoDeviceMemory *pResource) {
220     return pResource->__nodevicememIsPartialUnmapSupported__(pResource);
221 }
222 
nodevicememIsReady_DISPATCH(struct NoDeviceMemory * pMemory,NvBool bCopyConstructorContext)223 static inline NV_STATUS nodevicememIsReady_DISPATCH(struct NoDeviceMemory *pMemory, NvBool bCopyConstructorContext) {
224     return pMemory->__nodevicememIsReady__(pMemory, bCopyConstructorContext);
225 }
226 
nodevicememCheckCopyPermissions_DISPATCH(struct NoDeviceMemory * pMemory,struct OBJGPU * pDstGpu,struct Device * pDstDevice)227 static inline NV_STATUS nodevicememCheckCopyPermissions_DISPATCH(struct NoDeviceMemory *pMemory, struct OBJGPU *pDstGpu, struct Device *pDstDevice) {
228     return pMemory->__nodevicememCheckCopyPermissions__(pMemory, pDstGpu, pDstDevice);
229 }
230 
nodevicememPreDestruct_DISPATCH(struct NoDeviceMemory * pResource)231 static inline void nodevicememPreDestruct_DISPATCH(struct NoDeviceMemory *pResource) {
232     pResource->__nodevicememPreDestruct__(pResource);
233 }
234 
nodevicememIsDuplicate_DISPATCH(struct NoDeviceMemory * pMemory,NvHandle hMemory,NvBool * pDuplicate)235 static inline NV_STATUS nodevicememIsDuplicate_DISPATCH(struct NoDeviceMemory *pMemory, NvHandle hMemory, NvBool *pDuplicate) {
236     return pMemory->__nodevicememIsDuplicate__(pMemory, hMemory, pDuplicate);
237 }
238 
nodevicememControlSerialization_Epilogue_DISPATCH(struct NoDeviceMemory * pResource,CALL_CONTEXT * pCallContext,struct RS_RES_CONTROL_PARAMS_INTERNAL * pParams)239 static inline void nodevicememControlSerialization_Epilogue_DISPATCH(struct NoDeviceMemory *pResource, CALL_CONTEXT *pCallContext, struct RS_RES_CONTROL_PARAMS_INTERNAL *pParams) {
240     pResource->__nodevicememControlSerialization_Epilogue__(pResource, pCallContext, pParams);
241 }
242 
nodevicememMap_DISPATCH(struct NoDeviceMemory * pMemory,CALL_CONTEXT * pCallContext,struct RS_CPU_MAP_PARAMS * pParams,RsCpuMapping * pCpuMapping)243 static inline NV_STATUS nodevicememMap_DISPATCH(struct NoDeviceMemory *pMemory, CALL_CONTEXT *pCallContext, struct RS_CPU_MAP_PARAMS *pParams, RsCpuMapping *pCpuMapping) {
244     return pMemory->__nodevicememMap__(pMemory, pCallContext, pParams, pCpuMapping);
245 }
246 
nodevicememAccessCallback_DISPATCH(struct NoDeviceMemory * pResource,struct RsClient * pInvokingClient,void * pAllocParams,RsAccessRight accessRight)247 static inline NvBool nodevicememAccessCallback_DISPATCH(struct NoDeviceMemory *pResource, struct RsClient *pInvokingClient, void *pAllocParams, RsAccessRight accessRight) {
248     return pResource->__nodevicememAccessCallback__(pResource, pInvokingClient, pAllocParams, accessRight);
249 }
250 
251 NV_STATUS nodevicememConstruct_IMPL(struct NoDeviceMemory *arg_pNoDeviceMemory, CALL_CONTEXT *arg_pCallContext, struct RS_RES_ALLOC_PARAMS_INTERNAL *arg_pParams);
252 
253 #define __nvoc_nodevicememConstruct(arg_pNoDeviceMemory, arg_pCallContext, arg_pParams) nodevicememConstruct_IMPL(arg_pNoDeviceMemory, arg_pCallContext, arg_pParams)
254 void nodevicememDestruct_IMPL(struct NoDeviceMemory *pNoDeviceMemory);
255 
256 #define __nvoc_nodevicememDestruct(pNoDeviceMemory) nodevicememDestruct_IMPL(pNoDeviceMemory)
257 #undef PRIVATE_FIELD
258 
259 
260 #endif
261 
262 #ifdef __cplusplus
263 } // extern "C"
264 #endif
265 
266 #endif // _G_NO_DEVICE_MEM_NVOC_H_
267