sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget/translations/zh_CN/gpu/drm-mmmodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget/translations/zh_TW/gpu/drm-mmmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget/translations/it_IT/gpu/drm-mmmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget/translations/ja_JP/gpu/drm-mmmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget/translations/ko_KR/gpu/drm-mmmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget/translations/sp_SP/gpu/drm-mmmodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhsection)}(hhh](htitle)}(hDRM Memory Managementh]hDRM Memory Management}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhh8/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm.rsthKubh paragraph)}(hX<Modern Linux systems require large amount of graphics memory to store frame buffers, textures, vertices and other graphics-related data. Given the very dynamic nature of many of that data, managing graphics memory efficiently is thus crucial for the graphics stack and plays a central role in the DRM infrastructure.h]hX<Modern Linux systems require large amount of graphics memory to store frame buffers, textures, vertices and other graphics-related data. Given the very dynamic nature of many of that data, managing graphics memory efficiently is thus crucial for the graphics stack and plays a central role in the DRM infrastructure.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhhhubh)}(hXThe DRM core includes two memory managers, namely Translation Table Manager (TTM) and Graphics Execution Manager (GEM). TTM was the first DRM memory manager to be developed and tried to be a one-size-fits-them all solution. It provides a single userspace API to accommodate the need of all hardware, supporting both Unified Memory Architecture (UMA) devices and devices with dedicated video RAM (i.e. most discrete video cards). This resulted in a large, complex piece of code that turned out to be hard to use for driver development.h]hXThe DRM core includes two memory managers, namely Translation Table Manager (TTM) and Graphics Execution Manager (GEM). TTM was the first DRM memory manager to be developed and tried to be a one-size-fits-them all solution. It provides a single userspace API to accommodate the need of all hardware, supporting both Unified Memory Architecture (UMA) devices and devices with dedicated video RAM (i.e. most discrete video cards). This resulted in a large, complex piece of code that turned out to be hard to use for driver development.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK hhhhubh)}(hXGEM started as an Intel-sponsored project in reaction to TTM's complexity. Its design philosophy is completely different: instead of providing a solution to every graphics memory-related problems, GEM identified common code between drivers and created a support library to share it. GEM has simpler initialization and execution requirements than TTM, but has no video RAM management capabilities and is thus limited to UMA devices.h]hXGEM started as an Intel-sponsored project in reaction to TTM’s complexity. Its design philosophy is completely different: instead of providing a solution to every graphics memory-related problems, GEM identified common code between drivers and created a support library to share it. GEM has simpler initialization and execution requirements than TTM, but has no video RAM management capabilities and is thus limited to UMA devices.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhhhubh)}(hhh](h)}(h#The Translation Table Manager (TTM)h]h#The Translation Table Manager (TTM)}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhhhhKubh)}(hFTTM is a memory manager for accelerator devices with dedicated memory.h]hFTTM is a memory manager for accelerator devices with dedicated memory.}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:31: ./drivers/gpu/drm/ttm/ttm_module.chK+hhhhubh)}(hThe basic idea is that resources are grouped together in buffer objects of certain size and TTM handles lifetime, movement and CPU mappings of those objects.h]hThe basic idea is that resources are grouped together in buffer objects of certain size and TTM handles lifetime, movement and CPU mappings of those objects.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:31: ./drivers/gpu/drm/ttm/ttm_module.chK-hhhhubh)}(h6TODO: Add more design background and information here.h]h6TODO: Add more design background and information here.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:31: ./drivers/gpu/drm/ttm/ttm_module.chK1hhhhubhindex)}(hhh]h}(h]h ]h"]h$]h&]entries](singlettm_caching (C enum) c.ttm_cachinghNtauh1j!hhhhhNhNubhdesc)}(hhh](hdesc_signature)}(h ttm_cachingh]hdesc_signature_line)}(henum ttm_cachingh](hdesc_sig_keyword)}(henumh]henum}(hjEhhhNhNubah}(h]h ]kah"]h$]h&]uh1jChj?hhhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhKubhdesc_sig_space)}(h h]h }(hjWhhhNhNubah}(h]h ]wah"]h$]h&]uh1jUhj?hhhjThKubh desc_name)}(h ttm_cachingh]h desc_sig_name)}(hj;h]h ttm_caching}(hjnhhhNhNubah}(h]h ]nah"]h$]h&]uh1jlhjhubah}(h]h ](sig-namedescnameeh"]h$]h&] xml:spacepreserveuh1jfhj?hhhjThKubeh}(h]h ]h"]h$]h&]jj add_permalinkuh1j=sphinx_line_type declaratorhj9hhhjThKubah}(h]j0ah ](sig sig-objecteh"]h$]h&] is_multiline _toc_parts) _toc_namehuh1j7hjThKhj4hhubh desc_content)}(hhh]h)}(h&CPU caching and BUS snooping behavior.h]h&CPU caching and BUS snooping behavior.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK!hjhhubah}(h]h ]h"]h$]h&]uh1jhj4hhhjThKubeh}(h]h ](cenumeh"]h$]h&]domainjobjtypejdesctypejnoindex noindexentrynocontentsentryuh1j2hhhhhNhNubh container)}(hXD**Constants** ``ttm_uncached`` Most defensive option for device mappings, don't even allow write combining. ``ttm_write_combined`` Don't cache read accesses, but allow at least writes to be combined. ``ttm_cached`` Fully cached like normal system memory, requires that devices snoop the CPU cache on accesses.h](h)}(h **Constants**h]hstrong)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK%hjubhdefinition_list)}(hhh](hdefinition_list_item)}(h^``ttm_uncached`` Most defensive option for device mappings, don't even allow write combining. h](hterm)}(h``ttm_uncached``h]hliteral)}(hjh]h ttm_uncached}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK)hjubh definition)}(hhh]h)}(hLMost defensive option for device mappings, don't even allow write combining.h]hNMost defensive option for device mappings, don’t even allow write combining.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK(hj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK)hjubj)}(h\``ttm_write_combined`` Don't cache read accesses, but allow at least writes to be combined. h](j)}(h``ttm_write_combined``h]j)}(hj/h]httm_write_combined}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK-hj)ubj )}(hhh]h)}(hDDon't cache read accesses, but allow at least writes to be combined.h]hFDon’t cache read accesses, but allow at least writes to be combined.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK,hjEubah}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhK-hjubj)}(hm``ttm_cached`` Fully cached like normal system memory, requires that devices snoop the CPU cache on accesses.h](j)}(h``ttm_cached``h]j)}(hjih]h ttm_cached}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jhX/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:34: ./include/drm/ttm/ttm_caching.hhK0hjcubj )}(hhh]h)}(h^Fully cached like normal system memory, requires that devices snoop the CPU cache on accesses.h]h^Fully cached like normal system memory, requires that devices snoop the CPU cache on accesses.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hK0hjubah}(h]h ]h"]h$]h&]uh1j hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hK0hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhhhhhNhNubh)}(hhh](h)}(hTTM device object referenceh]hTTM device object reference}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhK&ubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_global (C struct) c.ttm_globalhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h ttm_globalh]j>)}(hstruct ttm_globalh](jD)}(hstructh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(h ttm_globalh]jm)}(hjh]h ttm_global}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h!Buffer object driver global data.h]h!Buffer object driver global data.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK(hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjj.jj.jjjuh1j2hhhjhNhNubj)}(hX**Definition**:: struct ttm_global { struct page *dummy_read_page; struct list_head device_list; atomic_t bo_count; }; **Members** ``dummy_read_page`` Pointer to a dummy page used for mapping requests of unpopulated pages. Constant after init. ``device_list`` List of buffer object devices. Protected by ttm_global_mutex. ``bo_count`` Number of buffer objects allocated by devices.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubh:}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK,hj2ubh literal_block)}(hqstruct ttm_global { struct page *dummy_read_page; struct list_head device_list; atomic_t bo_count; };h]hqstruct ttm_global { struct page *dummy_read_page; struct list_head device_list; atomic_t bo_count; };}hjUsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK.hj2ubh)}(h **Members**h]j)}(hjfh]hMembers}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK4hj2ubj)}(hhh](j)}(hq``dummy_read_page`` Pointer to a dummy page used for mapping requests of unpopulated pages. Constant after init. h](j)}(h``dummy_read_page``h]j)}(hjh]hdummy_read_page}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK/hjubj )}(hhh]h)}(h\Pointer to a dummy page used for mapping requests of unpopulated pages. Constant after init.h]h\Pointer to a dummy page used for mapping requests of unpopulated pages. Constant after init.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK.hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK/hj|ubj)}(hN``device_list`` List of buffer object devices. Protected by ttm_global_mutex. h](j)}(h``device_list``h]j)}(hjh]h device_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK5hjubj )}(hhh]h)}(h=List of buffer object devices. Protected by ttm_global_mutex.h]h=List of buffer object devices. Protected by ttm_global_mutex.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK4hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK5hj|ubj)}(h;``bo_count`` Number of buffer objects allocated by devices.h](j)}(h ``bo_count``h]j)}(hjh]hbo_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK9hjubj )}(hhh]h)}(h.Number of buffer objects allocated by devices.h]h.Number of buffer objects allocated by devices.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK:hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK9hj|ubeh}(h]h ]h"]h$]h&]uh1jhj2ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_device (C struct) c.ttm_devicehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h ttm_deviceh]j>)}(hstruct ttm_deviceh](jD)}(hjh]hstruct}(hjShhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjOhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhK@ubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjOhhhj`hK@ubjg)}(h ttm_deviceh]jm)}(hjMh]h ttm_device}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjOhhhj`hK@ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjKhhhj`hK@ubah}(h]jFah ](jjeh"]h$]h&]jj)jhuh1j7hj`hK@hjHhhubj)}(hhh]h)}(h*Buffer object driver device-specific data.h]h*Buffer object driver device-specific data.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhj`hK@ubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX,**Definition**:: struct ttm_device { struct list_head device_list; unsigned int alloc_flags; const struct ttm_device_funcs *funcs; struct ttm_resource_manager sysman; struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES]; struct drm_vma_offset_manager *vma_manager; struct ttm_pool pool; spinlock_t lru_lock; struct list_head unevictable; struct address_space *dev_mapping; struct workqueue_struct *wq; }; **Members** ``device_list`` Our entry in the global device list. Constant after bo device init ``alloc_flags`` TTM_ALLOCATION_* flags. ``funcs`` Function table for the device. Constant after bo device init ``sysman`` Resource manager for the system domain. Access via ttm_manager_type. ``man_drv`` An array of resource_managers, one per resource type. ``vma_manager`` Address space manager for finding BOs to mmap. ``pool`` page pool for the device. ``lru_lock`` Protection for the per manager LRU and ddestroy lists. ``unevictable`` Buffer objects which are pinned or swapped and as such not on an LRU list. ``dev_mapping`` A pointer to the struct address_space for invalidating CPU mappings on buffer move. Protected by load/unload sync. ``wq`` Work queue structure for the delayed delete workqueue.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjubjT)}(hXstruct ttm_device { struct list_head device_list; unsigned int alloc_flags; const struct ttm_device_funcs *funcs; struct ttm_resource_manager sysman; struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES]; struct drm_vma_offset_manager *vma_manager; struct ttm_pool pool; spinlock_t lru_lock; struct list_head unevictable; struct address_space *dev_mapping; struct workqueue_struct *wq; };h]hXstruct ttm_device { struct list_head device_list; unsigned int alloc_flags; const struct ttm_device_funcs *funcs; struct ttm_resource_manager sysman; struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES]; struct drm_vma_offset_manager *vma_manager; struct ttm_pool pool; spinlock_t lru_lock; struct list_head unevictable; struct address_space *dev_mapping; struct workqueue_struct *wq; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjubj)}(hhh](j)}(hS``device_list`` Our entry in the global device list. Constant after bo device init h](j)}(h``device_list``h]j)}(hjh]h device_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjubj )}(hhh]h)}(hBOur entry in the global device list. Constant after bo device inith]hBOur entry in the global device list. Constant after bo device init}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h(``alloc_flags`` TTM_ALLOCATION_* flags. h](j)}(h``alloc_flags``h]j)}(hj<h]h alloc_flags}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhj6ubj )}(hhh]h)}(hTTM_ALLOCATION_* flags.h]hTTM_ALLOCATION_* flags.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhKhjRubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhKhjubj)}(hG``funcs`` Function table for the device. Constant after bo device init h](j)}(h ``funcs``h]j)}(hjuh]hfuncs}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:40: ./include/drm/ttm/ttm_device.hhKhjoubj )}(hhh]h)}(h)}(h;int ttm_device_prepare_hibernation(struct ttm_device *bdev)h](hdesc_sig_keyword_type)}(hinth]hint}(hjhhhNhNubah}(h]h ]ktah"]h$]h&]uh1jhjhhh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(httm_device_prepare_hibernationh]jm)}(httm_device_prepare_hibernationh]httm_device_prepare_hibernation}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubhdesc_parameterlist)}(h(struct ttm_device *bdev)h]hdesc_parameter)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftype identifier reftargetjmodnameN classnameN c:parent_keysphinx.domains.c LookupKey)}data]j ASTIdentifier)}jjsb c.ttm_device_prepare_hibernationasbuh1hhjubjV)}(h h]h }(hj%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubhdesc_sig_punctuation)}(h*h]h*}(hj5hhhNhNubah}(h]h ]pah"]h$]h&]uh1j3hjubjm)}(hbdevh]hbdev}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h&move GTT BOs to shmem for hibernation.h]h&move GTT BOs to shmem for hibernation.}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhjkhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct ttm_device *bdev`` A pointer to a struct ttm_device to prepare hibernation for. **Return** 0 on success, negative number on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhjubj)}(hhh]j)}(hY``struct ttm_device *bdev`` A pointer to a struct ttm_device to prepare hibernation for. h](j)}(h``struct ttm_device *bdev``h]j)}(hjh]hstruct ttm_device *bdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhjubj )}(hhh]h)}(h)}(hint ttm_device_init(struct ttm_device *bdev, const struct ttm_device_funcs *funcs, struct device *dev, struct address_space *mapping, struct drm_vma_offset_manager *vma_manager, unsigned int alloc_flags)h](j)}(hinth]hint}(hj/ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj+ hhh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKubjV)}(h h]h }(hj> hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+ hhhj= hKubjg)}(httm_device_inith]jm)}(httm_device_inith]httm_device_init}(hjP hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjL ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj+ hhhj= hKubj)}(h(struct ttm_device *bdev, const struct ttm_device_funcs *funcs, struct device *dev, struct address_space *mapping, struct drm_vma_offset_manager *vma_manager, unsigned int alloc_flags)h](j)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hjl hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjh ubjV)}(h h]h }(hjy hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjh ubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jjR sbc.ttm_device_initasbuh1hhjh ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjh ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjh ubjm)}(hbdevh]hbdev}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjh ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd ubj)}(h$const struct ttm_device_funcs *funcsh](jD)}(hconsth]hconst}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(httm_device_funcsh]httm_device_funcs}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j c.ttm_device_initasbuh1hhj ubjV)}(h h]h }(hj6 hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjD hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hfuncsh]hfuncs}(hjQ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd ubj)}(hstruct device *devh](jD)}(hjh]hstruct}(hjj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjf ubjV)}(h h]h }(hjw hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjf ubh)}(hhh]jm)}(hdeviceh]hdevice}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j c.ttm_device_initasbuh1hhjf ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjf ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjf ubjm)}(hdevh]hdev}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjf ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd ubj)}(hstruct address_space *mappingh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h address_spaceh]h address_space}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j c.ttm_device_initasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj$ hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hmappingh]hmapping}(hj1 hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd ubj)}(h*struct drm_vma_offset_manager *vma_managerh](jD)}(hjh]hstruct}(hjJ hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjF ubjV)}(h h]h }(hjW hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjF ubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjh hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhje ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjj modnameN classnameNjj)}j]j c.ttm_device_initasbuh1hhjF ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjF ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjF ubjm)}(h vma_managerh]h vma_manager}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjF ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd ubj)}(hunsigned int alloc_flagsh](j)}(hunsignedh]hunsigned}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(h alloc_flagsh]h alloc_flags}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjd ubeh}(h]h ]h"]h$]h&]jjuh1jhj+ hhhj= hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj' hhhj= hKubah}(h]j" ah ](jjeh"]h$]h&]jj)jhuh1j7hj= hKhj$ hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj$ hhhj= hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj% jj% jjjuh1j2hhhjhNhNubj)}(hX!**Parameters** ``struct ttm_device *bdev`` A pointer to a struct ttm_device to initialize. ``const struct ttm_device_funcs *funcs`` Function table for the device. ``struct device *dev`` The core kernel device pointer for DMA mappings and allocations. ``struct address_space *mapping`` The address space to use for this bo. ``struct drm_vma_offset_manager *vma_manager`` A pointer to a vma manager. ``unsigned int alloc_flags`` TTM_ALLOCATION_* flags. **Description** Initializes a struct ttm_device: **Return** !0: Failure.h](h)}(h**Parameters**h]j)}(hj/ h]h Parameters}(hj1 hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj- ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj) ubj)}(hhh](j)}(hL``struct ttm_device *bdev`` A pointer to a struct ttm_device to initialize. h](j)}(h``struct ttm_device *bdev``h]j)}(hjN h]hstruct ttm_device *bdev}(hjP hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjL ubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhjH ubj )}(hhh]h)}(h/A pointer to a struct ttm_device to initialize.h]h/A pointer to a struct ttm_device to initialize.}(hjg hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjc hKhjd ubah}(h]h ]h"]h$]h&]uh1j hjH ubeh}(h]h ]h"]h$]h&]uh1jhjc hKhjE ubj)}(hH``const struct ttm_device_funcs *funcs`` Function table for the device. h](j)}(h(``const struct ttm_device_funcs *funcs``h]j)}(hj h]h$const struct ttm_device_funcs *funcs}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj ubj )}(hhh]h)}(hFunction table for the device.h]hFunction table for the device.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjE ubj)}(hX``struct device *dev`` The core kernel device pointer for DMA mappings and allocations. h](j)}(h``struct device *dev``h]j)}(hj h]hstruct device *dev}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj ubj )}(hhh]h)}(h@The core kernel device pointer for DMA mappings and allocations.h]h@The core kernel device pointer for DMA mappings and allocations.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjE ubj)}(hH``struct address_space *mapping`` The address space to use for this bo. h](j)}(h!``struct address_space *mapping``h]j)}(hj h]hstruct address_space *mapping}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj ubj )}(hhh]h)}(h%The address space to use for this bo.h]h%The address space to use for this bo.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjE ubj)}(hK``struct drm_vma_offset_manager *vma_manager`` A pointer to a vma manager. h](j)}(h.``struct drm_vma_offset_manager *vma_manager``h]j)}(hj2 h]h*struct drm_vma_offset_manager *vma_manager}(hj4 hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0 ubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj, ubj )}(hhh]h)}(hA pointer to a vma manager.h]hA pointer to a vma manager.}(hjK hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjG hKhjH ubah}(h]h ]h"]h$]h&]uh1j hj, ubeh}(h]h ]h"]h$]h&]uh1jhjG hKhjE ubj)}(h5``unsigned int alloc_flags`` TTM_ALLOCATION_* flags. h](j)}(h``unsigned int alloc_flags``h]j)}(hjk h]hunsigned int alloc_flags}(hjm hhhNhNubah}(h]h ]h"]h$]h&]uh1jhji ubah}(h]h ]h"]h$]h&]uh1jh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhje ubj )}(hhh]h)}(hTTM_ALLOCATION_* flags.h]hTTM_ALLOCATION_* flags.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j hje ubeh}(h]h ]h"]h$]h&]uh1jhj hKhjE ubeh}(h]h ]h"]h$]h&]uh1jhj) ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj) ubh)}(h Initializes a struct ttm_device:h]h Initializes a struct ttm_device:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj) ubh)}(h **Return**h]j)}(hj h]hReturn}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj) ubh)}(h !0: Failure.h]h !0: Failure.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh[/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:43: ./drivers/gpu/drm/ttm/ttm_device.chKhj) ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]ttm-device-object-referenceah ]h"]ttm device object referenceah$]h&]uh1hhhhhhhhK&ubh)}(hhh](h)}(h TTM resource placement referenceh]h TTM resource placement reference}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhK/ubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_place (C struct) c.ttm_placehNtauh1j!hjhhhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhNubj3)}(hhh](j8)}(h ttm_placeh]j>)}(hstruct ttm_placeh](jD)}(hjh]hstruct}(hj,hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj(hhhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(hhhj9hKubjg)}(h ttm_placeh]jm)}(hj&h]h ttm_place}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj(hhhj9hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj$hhhj9hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj9hKhj!hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj!hhhj9hKubeh}(h]h ](jstructeh"]h$]h&]jjjjwjjwjjjuh1j2hhhjhj hNubj)}(hX**Definition**:: struct ttm_place { unsigned fpfn; unsigned lpfn; uint32_t mem_type; uint32_t flags; }; **Members** ``fpfn`` first valid page frame number to put the object ``lpfn`` last valid page frame number to put the object ``mem_type`` One of TTM_PL_* where the resource should be allocated from. ``flags`` memory domain and caching flags for the objecth](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKNhj{ubjT)}(hfstruct ttm_place { unsigned fpfn; unsigned lpfn; uint32_t mem_type; uint32_t flags; };h]hfstruct ttm_place { unsigned fpfn; unsigned lpfn; uint32_t mem_type; uint32_t flags; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKPhj{ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKWhj{ubj)}(hhh](j)}(h9``fpfn`` first valid page frame number to put the object h](j)}(h``fpfn``h]j)}(hjh]hfpfn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKMhjubj )}(hhh]h)}(h/first valid page frame number to put the objecth]h/first valid page frame number to put the object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKMhjubj)}(h8``lpfn`` last valid page frame number to put the object h](j)}(h``lpfn``h]j)}(hjh]hlpfn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKNhjubj )}(hhh]h)}(h.last valid page frame number to put the objecth]h.last valid page frame number to put the object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKNhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKNhjubj)}(hJ``mem_type`` One of TTM_PL_* where the resource should be allocated from. h](j)}(h ``mem_type``h]j)}(hj>h]hmem_type}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKOhj8ubj )}(hhh]h)}(h)}(hstruct ttm_placementh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKPubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKPubjg)}(h ttm_placementh]jm)}(hjh]h ttm_placement}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKPubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKPubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKPhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhKPubeh}(h]h ](jstructeh"]h$]h&]jjjjCjjCjjjuh1j2hhhjhj hNubj)}(h**Definition**:: struct ttm_placement { unsigned num_placement; const struct ttm_place *placement; }; **Members** ``num_placement`` number of preferred placements ``placement`` preferred placementsh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubh:}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhK_hjGubjT)}(h]struct ttm_placement { unsigned num_placement; const struct ttm_place *placement; };h]h]struct ttm_placement { unsigned num_placement; const struct ttm_place *placement; };}hjhsbah}(h]h ]h"]h$]h&]jjuh1jShZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKahjGubh)}(h **Members**h]j)}(hjyh]hMembers}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKfhjGubj)}(hhh](j)}(h1``num_placement`` number of preferred placements h](j)}(h``num_placement``h]j)}(hjh]h num_placement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhK^hjubj )}(hhh]h)}(hnumber of preferred placementsh]hnumber of preferred placements}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK^hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK^hjubj)}(h"``placement`` preferred placementsh](j)}(h ``placement``h]j)}(hjh]h placement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhK^hjubj )}(hhh]h)}(hpreferred placementsh]hpreferred placements}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhK_hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK^hjubeh}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhj hNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhKbhjhhubh)}(h=Structure indicating the placement you request for an object.h]h=Structure indicating the placement you request for an object.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhZ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:49: ./include/drm/ttm/ttm_placement.hhK\hjhhubeh}(h] ttm-resource-placement-referenceah ]h"] ttm resource placement referenceah$]h&]uh1hhhhhhhhK/ubh)}(hhh](h)}(hTTM resource object referenceh]hTTM resource object reference}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjAhhhhhK5ubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.TTM_NUM_MOVE_FENCES (C macro)c.TTM_NUM_MOVE_FENCEShNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hTTM_NUM_MOVE_FENCESh]j>)}(hTTM_NUM_MOVE_FENCESh]jg)}(hTTM_NUM_MOVE_FENCESh]jm)}(hjeh]hTTM_NUM_MOVE_FENCES}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjghhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK7ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjhK7ubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hjhK7hj`hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj`hhhjhK7ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjAhNhNubh)}(h``TTM_NUM_MOVE_FENCES``h]j)}(hjh]hTTM_NUM_MOVE_FENCES}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK9hjAhhubh block_quote)}(h How many entities can be used for evictions **Description** Pipelined evictions can be spread on multiple entities. This is the max number of entities that can be used by the driver for that purpose. h](j)}(h,How many entities can be used for evictions h]h)}(h+How many entities can be used for evictionsh]h+How many entities can be used for evictions}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK7hjubah}(h]h ]h"]h$]h&]uh1jhjhK7hjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK9hjubh)}(hPipelined evictions can be spread on multiple entities. This is the max number of entities that can be used by the driver for that purpose.h]hPipelined evictions can be spread on multiple entities. This is the max number of entities that can be used by the driver for that purpose.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK8hjubeh}(h]h ]h"]h$]h&]uh1jhjhK7hjAhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_lru_item_type (C enum)c.ttm_lru_item_typehNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_lru_item_typeh]j>)}(henum ttm_lru_item_typeh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK?ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj)hK?ubjg)}(httm_lru_item_typeh]jm)}(hjh]httm_lru_item_type}(hj<hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj)hK?ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj)hK?ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj)hK?hjhhubj)}(hhh]h)}(h!enumerate ttm_lru_item subclassesh]h!enumerate ttm_lru_item subclasses}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK@hj[hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj)hK?ubeh}(h]h ](jenumeh"]h$]h&]jjjjvjjvjjjuh1j2hhhjAhNhNubj)}(hl**Constants** ``TTM_LRU_RESOURCE`` The resource subclass ``TTM_LRU_HITCH`` The iterator hitch subclassh](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKDhjzubj)}(hhh](j)}(h+``TTM_LRU_RESOURCE`` The resource subclass h](j)}(h``TTM_LRU_RESOURCE``h]j)}(hjh]hTTM_LRU_RESOURCE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKGhjubj )}(hhh]h)}(hThe resource subclassh]hThe resource subclass}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKGhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKGhjubj)}(h-``TTM_LRU_HITCH`` The iterator hitch subclassh](j)}(h``TTM_LRU_HITCH``h]j)}(hjh]h TTM_LRU_HITCH}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKIhjubj )}(hhh]h)}(hThe iterator hitch subclassh]hThe iterator hitch subclass}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKJhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKIhjubeh}(h]h ]h"]h$]h&]uh1jhjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_lru_item (C struct)c.ttm_lru_itemhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(h ttm_lru_itemh]j>)}(hstruct ttm_lru_itemh](jD)}(hjh]hstruct}(hj2hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj.hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKOubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.hhhj?hKOubjg)}(h ttm_lru_itemh]jm)}(hj,h]h ttm_lru_item}(hjRhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj.Vhhhj?hKOubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj*hhhj?hKOubah}(h]j%ah ](jjeh"]h$]h&]jj)jhuh1j7hj?hKOhj'hhubj)}(hhh]h)}(h The TTM lru list node base classh]h The TTM lru list node base class}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKJhjqhhubah}(h]h ]h"]h$]h&]uh1jhj'hhhj?hKOubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjAhNhNubj)}(h**Definition**:: struct ttm_lru_item { struct list_head link; enum ttm_lru_item_type type; }; **Members** ``link`` The list link ``type`` The subclass typeh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKNhjubjT)}(hTstruct ttm_lru_item { struct list_head link; enum ttm_lru_item_type type; };h]hTstruct ttm_lru_item { struct list_head link; enum ttm_lru_item_type type; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKPhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKUhjubj)}(hhh](j)}(h``link`` The list link h](j)}(h``link``h]j)}(hjh]hlink}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKLhjubj )}(hhh]h)}(h The list linkh]h The list link}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKLhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKLhjubj)}(h``type`` The subclass typeh](j)}(h``type``h]j)}(hjh]htype}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKLhjubj )}(hhh]h)}(hThe subclass typeh]hThe subclass type}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKMhj0ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj/hKLhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_lru_item_init (C function)c.ttm_lru_item_inithNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hOvoid ttm_lru_item_init (struct ttm_lru_item *item, enum ttm_lru_item_type type)h]j>)}(hNvoid ttm_lru_item_init(struct ttm_lru_item *item, enum ttm_lru_item_type type)h](j)}(hvoidh]hvoid}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjphhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKTubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjphhhjhKTubjg)}(httm_lru_item_inith]jm)}(httm_lru_item_inith]httm_lru_item_init}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjphhhjhKTubj)}(h8(struct ttm_lru_item *item, enum ttm_lru_item_type type)h](j)}(hstruct ttm_lru_item *itemh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h ttm_lru_itemh]h ttm_lru_item}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.ttm_lru_item_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hitemh]hitem}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum ttm_lru_item_type typeh](jD)}(hjGh]henum}(hj#hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(httm_lru_item_typeh]httm_lru_item_type}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjCmodnameN classnameNjj)}j]jc.ttm_lru_item_initasbuh1hhjubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(htypeh]htype}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjphhhjhKTubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjlhhhjhKTubah}(h]jgah ](jjeh"]h$]h&]jj)jhuh1j7hjhKThjihhubj)}(hhh]h)}(h initialize a struct ttm_lru_itemh]h initialize a struct ttm_lru_item}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKThjhhubah}(h]h ]h"]h$]h&]uh1jhjihhhjhKTubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjAhNhNubj)}(h{**Parameters** ``struct ttm_lru_item *item`` The item to initialize ``enum ttm_lru_item_type type`` The subclass typeh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKXhjubj)}(hhh](j)}(h5``struct ttm_lru_item *item`` The item to initialize h](j)}(h``struct ttm_lru_item *item``h]j)}(hjh]hstruct ttm_lru_item *item}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKUhjubj )}(hhh]h)}(hThe item to initializeh]hThe item to initialize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKUhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKUhjubj)}(h1``enum ttm_lru_item_type type`` The subclass typeh](j)}(h``enum ttm_lru_item_type type``h]j)}(hjh]henum ttm_lru_item_type type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKWhj ubj )}(hhh]h)}(hThe subclass typeh]hThe subclass type}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKVhj'ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hKWhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_resource_manager (C struct)c.ttm_resource_managerhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_resource_managerh]j>)}(hstruct ttm_resource_managerh](jD)}(hjh]hstruct}(hjkhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjghhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhK[ubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjghhhjxhK[ubjg)}(httm_resource_managerh]jm)}(hjeh]httm_resource_manager}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjghhhjxhK[ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjxhK[ubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hjxhK[hj`hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj`hhhjxhK[ubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjAhNhNubj)}(hX**Definition**:: struct ttm_resource_manager { bool use_type; bool use_tt; struct ttm_device *bdev; uint64_t size; const struct ttm_resource_manager_func *func; spinlock_t eviction_lock; struct dma_fence *eviction_fences[TTM_NUM_MOVE_FENCES]; struct list_head lru[TTM_MAX_BO_PRIORITY]; uint64_t usage; struct dmem_cgroup_region *cg; }; **Members** ``use_type`` The memory type is enabled. ``use_tt`` If a TT object should be used for the backing store. ``bdev`` ttm device this manager belongs to ``size`` Size of the managed region. ``func`` structure pointer implementing the range manager. See above ``eviction_lock`` lock for eviction fences ``eviction_fences`` The fences of the last pipelined move operation. ``lru`` The lru list for this memory type. ``usage`` How much of the resources are used, protected by the bdev->lru_lock. ``cg`` :c:type:`dmem_cgroup_region` used for memory accounting, if not NULL.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubjT)}(hXfstruct ttm_resource_manager { bool use_type; bool use_tt; struct ttm_device *bdev; uint64_t size; const struct ttm_resource_manager_func *func; spinlock_t eviction_lock; struct dma_fence *eviction_fences[TTM_NUM_MOVE_FENCES]; struct list_head lru[TTM_MAX_BO_PRIORITY]; uint64_t usage; struct dmem_cgroup_region *cg; };h]hXfstruct ttm_resource_manager { bool use_type; bool use_tt; struct ttm_device *bdev; uint64_t size; const struct ttm_resource_manager_func *func; spinlock_t eviction_lock; struct dma_fence *eviction_fences[TTM_NUM_MOVE_FENCES]; struct list_head lru[TTM_MAX_BO_PRIORITY]; uint64_t usage; struct dmem_cgroup_region *cg; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj)}(hhh](j)}(h)``use_type`` The memory type is enabled. h](j)}(h ``use_type``h]j)}(hj h]huse_type}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(hThe memory type is enabled.h]hThe memory type is enabled.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj!ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hKhjubj)}(h@``use_tt`` If a TT object should be used for the backing store. h](j)}(h ``use_tt``h]j)}(hjDh]huse_tt}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhj>ubj )}(hhh]h)}(h4If a TT object should be used for the backing store.h]h4If a TT object should be used for the backing store.}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhKhjZubah}(h]h ]h"]h$]h&]uh1j hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhKhjubj)}(h,``bdev`` ttm device this manager belongs to h](j)}(h``bdev``h]j)}(hj}h]hbdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjwubj )}(hhh]h)}(h"ttm device this manager belongs toh]h"ttm device this manager belongs to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjwubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h%``size`` Size of the managed region. h](j)}(h``size``h]j)}(hjh]hsize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(hSize of the managed region.h]hSize of the managed region.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hE``func`` structure pointer implementing the range manager. See above h](j)}(h``func``h]j)}(hjh]hfunc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(h;structure pointer implementing the range manager. See aboveh]h;structure pointer implementing the range manager. See above}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h+``eviction_lock`` lock for eviction fences h](j)}(h``eviction_lock``h]j)}(hj(h]h eviction_lock}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhj"ubj )}(hhh]h)}(hlock for eviction fencesh]hlock for eviction fences}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj=hKhj>ubah}(h]h ]h"]h$]h&]uh1j hj"ubeh}(h]h ]h"]h$]h&]uh1jhj=hKhjubj)}(hE``eviction_fences`` The fences of the last pipelined move operation. h](j)}(h``eviction_fences``h]j)}(hjah]heviction_fences}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhj[ubj )}(hhh]h)}(h0The fences of the last pipelined move operation.h]h0The fences of the last pipelined move operation.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjvhKhjwubah}(h]h ]h"]h$]h&]uh1j hj[ubeh}(h]h ]h"]h$]h&]uh1jhjvhKhjubj)}(h+``lru`` The lru list for this memory type. h](j)}(h``lru``h]j)}(hjh]hlru}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(h"The lru list for this memory type.h]h"The lru list for this memory type.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hO``usage`` How much of the resources are used, protected by the bdev->lru_lock. h](j)}(h ``usage``h]j)}(hjh]husage}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(hDHow much of the resources are used, protected by the bdev->lru_lock.h]hDHow much of the resources are used, protected by the bdev->lru_lock.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hL``cg`` :c:type:`dmem_cgroup_region` used for memory accounting, if not NULL.h](j)}(h``cg``h]j)}(hj h]hcg}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(hE:c:type:`dmem_cgroup_region` used for memory accounting, if not NULL.h](h)}(h:c:type:`dmem_cgroup_region`h]j)}(hj,h]hdmem_cgroup_region}(hj.hhhNhNubah}(h]h ](xrefjc-typeeh"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]refdoc gpu/drm-mm refdomainjreftypetype refexplicitrefwarnjj)}j]sb reftargetdmem_cgroup_regionuh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhj&ubh) used for memory accounting, if not NULL.}(hj&hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjOhKhj#ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj"hKhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubh)}(h**Description**h]j)}(hjuh]h Description}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjAhhubh)}(hHThis structure is used to identify and manage memory types for a device.h]hHThis structure is used to identify and manage memory types for a device.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjAhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_bus_placement (C struct)c.ttm_bus_placementhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_bus_placementh]j>)}(hstruct ttm_bus_placementh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(httm_bus_placementh]jm)}(hjh]httm_bus_placement}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjAhNhNubj)}(hX/**Definition**:: struct ttm_bus_placement { void *addr; phys_addr_t offset; bool is_iomem; enum ttm_caching caching; }; **Members** ``addr`` mapped virtual address ``offset`` physical addr ``is_iomem`` is this io memory ? ``caching`` See enum ttm_cachingh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubjT)}(h}struct ttm_bus_placement { void *addr; phys_addr_t offset; bool is_iomem; enum ttm_caching caching; };h]h}struct ttm_bus_placement { void *addr; phys_addr_t offset; bool is_iomem; enum ttm_caching caching; };}hj#sbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubh)}(h **Members**h]j)}(hj4h]hMembers}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj)}(hhh](j)}(h ``addr`` mapped virtual address h](j)}(h``addr``h]j)}(hjSh]haddr}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjMubj )}(hhh]h)}(hmapped virtual addressh]hmapped virtual address}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhKhjiubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhKhjJubj)}(h``offset`` physical addr h](j)}(h ``offset``h]j)}(hjh]hoffset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(h physical addrh]h physical addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjJubj)}(h!``is_iomem`` is this io memory ? h](j)}(h ``is_iomem``h]j)}(hjh]his_iomem}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(his this io memory ?h]his this io memory ?}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjJubj)}(h ``caching`` See enum ttm_cachingh](j)}(h ``caching``h]j)}(hjh]hcaching}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(hSee enum ttm_cachingh]hSee enum ttm_caching}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjJubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubh)}(h**Description**h]j)}(hjAh]h Description}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjAhhubh)}(h4Structure indicating the bus placement of an object.h]h4Structure indicating the bus placement of an object.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjAhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_resource (C struct)c.ttm_resourcehNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(h ttm_resourceh]j>)}(hstruct ttm_resourceh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{hhhjhKubjg)}(h ttm_resourceh]jm)}(hjyh]h ttm_resource}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj{hhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjwhhhjhKubah}(h]jrah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjthhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjthhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjAhNhNubj)}(hX**Definition**:: struct ttm_resource { unsigned long start; size_t size; uint32_t mem_type; uint32_t placement; struct ttm_bus_placement bus; struct ttm_buffer_object *bo; struct dmem_cgroup_pool_state *css; struct ttm_lru_item lru; }; **Members** ``start`` Start of the allocation. ``size`` Actual size of resource in bytes. ``mem_type`` Resource type of the allocation. ``placement`` Placement flags. ``bus`` Placement on io bus accessible to the CPU ``bo`` weak reference to the BO, protected by ttm_device::lru_lock ``css`` cgroup state this resource is charged to ``lru`` Least recently used list, see :c:type:`ttm_resource_manager.lru `h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubjT)}(hstruct ttm_resource { unsigned long start; size_t size; uint32_t mem_type; uint32_t placement; struct ttm_bus_placement bus; struct ttm_buffer_object *bo; struct dmem_cgroup_pool_state *css; struct ttm_lru_item lru; };h]hstruct ttm_resource { unsigned long start; size_t size; uint32_t mem_type; uint32_t placement; struct ttm_bus_placement bus; struct ttm_buffer_object *bo; struct dmem_cgroup_pool_state *css; struct ttm_lru_item lru; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM hjubj)}(hhh](j)}(h#``start`` Start of the allocation. h](j)}(h ``start``h]j)}(hjh]hstart}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(hStart of the allocation.h]hStart of the allocation.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hKhj5ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj4hKhjubj)}(h+``size`` Actual size of resource in bytes. h](j)}(h``size``h]j)}(hjXh]hsize}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjRubj )}(hhh]h)}(h!Actual size of resource in bytes.h]h!Actual size of resource in bytes.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhKhjnubah}(h]h ]h"]h$]h&]uh1j hjRubeh}(h]h ]h"]h$]h&]uh1jhjmhKhjubj)}(h.``mem_type`` Resource type of the allocation. h](j)}(h ``mem_type``h]j)}(hjh]hmem_type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjubj )}(hhh]h)}(h Resource type of the allocation.h]h Resource type of the allocation.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``placement`` Placement flags. h](j)}(h ``placement``h]j)}(hjh]h placement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjubj )}(hhh]h)}(hPlacement flags.h]hPlacement flags.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h2``bus`` Placement on io bus accessible to the CPU h](j)}(h``bus``h]j)}(hjh]hbus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjubj )}(hhh]h)}(h)Placement on io bus accessible to the CPUh]h)Placement on io bus accessible to the CPU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hC``bo`` weak reference to the BO, protected by ttm_device::lru_lock h](j)}(h``bo``h]j)}(hj<h]hbo}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj6ubj )}(hhh]h)}(h;weak reference to the BO, protected by ttm_device::lru_lockh]h;weak reference to the BO, protected by ttm_device::lru_lock}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhMhjRubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhMhjubj)}(h1``css`` cgroup state this resource is charged to h](j)}(h``css``h]j)}(hjuh]hcss}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjoubj )}(hhh]h)}(h(cgroup state this resource is charged toh]h(cgroup state this resource is charged to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h_``lru`` Least recently used list, see :c:type:`ttm_resource_manager.lru `h](j)}(h``lru``h]j)}(hjh]hlru}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjubj )}(hhh]h)}(hWLeast recently used list, see :c:type:`ttm_resource_manager.lru `h](hLeast recently used list, see }(hjhhhNhNubh)}(h9:c:type:`ttm_resource_manager.lru `h]j)}(hjh]httm_resource_manager.lru}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMttm_resource_manageruh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjAhhubh)}(hOStructure indicating the placement and space resources used by a buffer object.h]hOStructure indicating the placement and space resources used by a buffer object.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhKhjAhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. ttm_lru_item_to_res (C function)c.ttm_lru_item_to_reshNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hEstruct ttm_resource * ttm_lru_item_to_res (struct ttm_lru_item *item)h]j>)}(hCstruct ttm_resource *ttm_lru_item_to_res(struct ttm_lru_item *item)h](jD)}(hjh]hstruct}(hjNhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjJhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhj[hMubh)}(hhh]jm)}(h ttm_resourceh]h ttm_resource}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjomodnameN classnameNjj)}j]j )}jttm_lru_item_to_ressbc.ttm_lru_item_to_resasbuh1hhjJhhhj[hMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhj[hMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjJhhhj[hMubjg)}(httm_lru_item_to_resh]jm)}(hjh]httm_lru_item_to_res}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjJhhhj[hMubj)}(h(struct ttm_lru_item *item)h]j)}(hstruct ttm_lru_item *itemh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h ttm_lru_itemh]h ttm_lru_item}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.ttm_lru_item_to_resasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hitemh]hitem}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjJhhhj[hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjFhhhj[hMubah}(h]jAah ](jjeh"]h$]h&]jj)jhuh1j7hj[hMhjChhubj)}(hhh]h)}(h7Downcast a struct ttm_lru_item to a struct ttm_resourceh]h7Downcast a struct ttm_lru_item to a struct ttm_resource}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjFhhubah}(h]h ]h"]h$]h&]uh1jhjChhhj[hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjajjajjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_lru_item *item`` The struct ttm_lru_item to downcast **Return** Pointer to the embedding struct ttm_resourceh](h)}(h**Parameters**h]j)}(hjkh]h Parameters}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjeubj)}(hhh]j)}(hB``struct ttm_lru_item *item`` The struct ttm_lru_item to downcast h](j)}(h``struct ttm_lru_item *item``h]j)}(hjh]hstruct ttm_lru_item *item}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjubj )}(hhh]h)}(h#The struct ttm_lru_item to downcasth]h#The struct ttm_lru_item to downcast}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjeubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjeubh)}(h,Pointer to the embedding struct ttm_resourceh]h,Pointer to the embedding struct ttm_resource}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. ttm_lru_bulk_move_pos (C struct)c.ttm_lru_bulk_move_poshNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_lru_bulk_move_posh]j>)}(hstruct ttm_lru_bulk_move_posh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hM ubjg)}(httm_lru_bulk_move_posh]jm)}(hj h]httm_lru_bulk_move_pos}(hj* hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj& ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj hM hjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhj hM ubeh}(h]h ](jstructeh"]h$]h&]jjjjU jjU jjjuh1j2hhhjAhNhNubj)}(h**Definition**:: struct ttm_lru_bulk_move_pos { struct ttm_resource *first; struct ttm_resource *last; }; **Members** ``first`` first res in the bulk move range ``last`` last res in the bulk move rangeh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hja hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj] ubh:}(hj] hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM(hjY ubjT)}(h`struct ttm_lru_bulk_move_pos { struct ttm_resource *first; struct ttm_resource *last; };h]h`struct ttm_lru_bulk_move_pos { struct ttm_resource *first; struct ttm_resource *last; };}hjz sbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM*hjY ubh)}(h **Members**h]j)}(hj h]hMembers}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM/hjY ubj)}(hhh](j)}(h+``first`` first res in the bulk move range h](j)}(h ``first``h]j)}(hj h]hfirst}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM'hj ubj )}(hhh]h)}(h first res in the bulk move rangeh]h first res in the bulk move range}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hM'hj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM'hj ubj)}(h(``last`` last res in the bulk move rangeh](j)}(h``last``h]j)}(hj h]hlast}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM'hj ubj )}(hhh]h)}(hlast res in the bulk move rangeh]hlast res in the bulk move range}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM(hj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hM'hj ubeh}(h]h ]h"]h$]h&]uh1jhjY ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubh)}(h**Description**h]j)}(hj&!h]h Description}(hj(!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$!ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM+hjAhhubh)}(h'Range of resources for a lru bulk move.h]h'Range of resources for a lru bulk move.}(hj)}(hstruct ttm_lru_bulk_moveh](jD)}(hjh]hstruct}(hjd!hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj`!hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM*ubjV)}(h h]h }(hjr!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`!hhhjq!hM*ubjg)}(httm_lru_bulk_moveh]jm)}(hj^!h]httm_lru_bulk_move}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj`!hhhjq!hM*ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj\!hhhjq!hM*ubah}(h]jW!ah ](jjeh"]h$]h&]jj)jhuh1j7hjq!hM*hjY!hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjY!hhhjq!hM*ubeh}(h]h ](jstructeh"]h$]h&]jjjj!jj!jjjuh1j2hhhjAhNhNubj)}(hX**Definition**:: struct ttm_lru_bulk_move { struct ttm_lru_bulk_move_pos pos[TTM_NUM_MEM_TYPES][TTM_MAX_BO_PRIORITY]; struct list_head cursor_list; }; **Members** ``pos`` first/last lru entry for resources in the each domain/priority ``cursor_list`` The list of cursors currently traversing any of the sublists of **pos**. Protected by the ttm device's lru_lock.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubh:}(hj!hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM5hj!ubjT)}(hstruct ttm_lru_bulk_move { struct ttm_lru_bulk_move_pos pos[TTM_NUM_MEM_TYPES][TTM_MAX_BO_PRIORITY]; struct list_head cursor_list; };h]hstruct ttm_lru_bulk_move { struct ttm_lru_bulk_move_pos pos[TTM_NUM_MEM_TYPES][TTM_MAX_BO_PRIORITY]; struct list_head cursor_list; };}hj!sbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM7hj!ubh)}(h **Members**h]j)}(hj!h]hMembers}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM<hj!ubj)}(hhh](j)}(hG``pos`` first/last lru entry for resources in the each domain/priority h](j)}(h``pos``h]j)}(hj"h]hpos}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM3hj!ubj )}(hhh]h)}(h>first/last lru entry for resources in the each domain/priorityh]h>first/last lru entry for resources in the each domain/priority}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hM3hj"ubah}(h]h ]h"]h$]h&]uh1j hj!ubeh}(h]h ]h"]h$]h&]uh1jhj"hM3hj!ubj)}(h``cursor_list`` The list of cursors currently traversing any of the sublists of **pos**. Protected by the ttm device's lru_lock.h](j)}(h``cursor_list``h]j)}(hj="h]h cursor_list}(hj?"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;"ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM4hj7"ubj )}(hhh]h)}(hpThe list of cursors currently traversing any of the sublists of **pos**. Protected by the ttm device's lru_lock.h](h@The list of cursors currently traversing any of the sublists of }(hjV"hhhNhNubj)}(h**pos**h]hpos}(hj^"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV"ubh+. Protected by the ttm device’s lru_lock.}(hjV"hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjR"hM4hjS"ubah}(h]h ]h"]h$]h&]uh1j hj7"ubeh}(h]h ]h"]h$]h&]uh1jhjR"hM4hj!ubeh}(h]h ]h"]h$]h&]uh1jhj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubh)}(h**Description**h]j)}(hj"h]h Description}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM8hjAhhubh)}(hX$Container for the current bulk move state. Should be used with ttm_lru_bulk_move_init() and ttm_bo_set_bulk_move(). All BOs in a bulk_move structure need to share the same reservation object to ensure that the bulk as a whole is locked for eviction even if only one BO of the bulk is evicted.h]hX$Container for the current bulk move state. Should be used with ttm_lru_bulk_move_init() and ttm_bo_set_bulk_move(). All BOs in a bulk_move structure need to share the same reservation object to ensure that the bulk as a whole is locked for eviction even if only one BO of the bulk is evicted.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM5hjAhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_resource_cursor (C struct)c.ttm_resource_cursorhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_resource_cursorh]j>)}(hstruct ttm_resource_cursorh](jD)}(hjh]hstruct}(hj"hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj"hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM>ubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"hhhj"hM>ubjg)}(httm_resource_cursorh]jm)}(hj"h]httm_resource_cursor}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj"hhhj"hM>ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj"hhhj"hM>ubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1j7hj"hM>hj"hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj"hhhj"hM>ubeh}(h]h ](jstructeh"]h$]h&]jjjj#jj#jjjuh1j2hhhjAhNhNubj)}(hX**Definition**:: struct ttm_resource_cursor { struct ttm_resource_manager *man; struct ttm_lru_item hitch; struct list_head bulk_link; struct ttm_lru_bulk_move *bulk; unsigned int mem_type; unsigned int priority; }; **Members** ``man`` The resource manager currently being iterated over ``hitch`` A hitch list node inserted before the next resource to iterate over. ``bulk_link`` A list link for the list of cursors traversing the bulk sublist of **bulk**. Protected by the ttm device's lru_lock. ``bulk`` Pointer to struct ttm_lru_bulk_move whose subrange **hitch** is inserted to. NULL if none. Never dereference this pointer since the struct ttm_lru_bulk_move object pointed to might have been freed. The pointer is only for comparison. ``mem_type`` The memory type of the LRU list being traversed. This field is valid iff **bulk** != NULL. ``priority`` the current priorityh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj&#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"#ubh:}(hj"#hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMFhj#ubjT)}(hstruct ttm_resource_cursor { struct ttm_resource_manager *man; struct ttm_lru_item hitch; struct list_head bulk_link; struct ttm_lru_bulk_move *bulk; unsigned int mem_type; unsigned int priority; };h]hstruct ttm_resource_cursor { struct ttm_resource_manager *man; struct ttm_lru_item hitch; struct list_head bulk_link; struct ttm_lru_bulk_move *bulk; unsigned int mem_type; unsigned int priority; };}hj?#sbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMHhj#ubh)}(h **Members**h]j)}(hjP#h]hMembers}(hjR#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjN#ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMQhj#ubj)}(hhh](j)}(h;``man`` The resource manager currently being iterated over h](j)}(h``man``h]j)}(hjo#h]hman}(hjq#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm#ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMDhji#ubj )}(hhh]h)}(h2The resource manager currently being iterated overh]h2The resource manager currently being iterated over}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMDhj#ubah}(h]h ]h"]h$]h&]uh1j hji#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMDhjf#ubj)}(hO``hitch`` A hitch list node inserted before the next resource to iterate over. h](j)}(h ``hitch``h]j)}(hj#h]hhitch}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMFhj#ubj )}(hhh]h)}(hDA hitch list node inserted before the next resource to iterate over.h]hDA hitch list node inserted before the next resource to iterate over.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMEhj#ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMFhjf#ubj)}(h``bulk_link`` A list link for the list of cursors traversing the bulk sublist of **bulk**. Protected by the ttm device's lru_lock. h](j)}(h ``bulk_link``h]j)}(hj#h]h bulk_link}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMHhj#ubj )}(hhh]h)}(htA list link for the list of cursors traversing the bulk sublist of **bulk**. Protected by the ttm device's lru_lock.h](hCA list link for the list of cursors traversing the bulk sublist of }(hj#hhhNhNubj)}(h**bulk**h]hbulk}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubh+. Protected by the ttm device’s lru_lock.}(hj#hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMGhj#ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj#hMHhjf#ubj)}(h``bulk`` Pointer to struct ttm_lru_bulk_move whose subrange **hitch** is inserted to. NULL if none. Never dereference this pointer since the struct ttm_lru_bulk_move object pointed to might have been freed. The pointer is only for comparison. h](j)}(h``bulk``h]j)}(hj.$h]hbulk}(hj0$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,$ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMLhj($ubj )}(hhh]h)}(hPointer to struct ttm_lru_bulk_move whose subrange **hitch** is inserted to. NULL if none. Never dereference this pointer since the struct ttm_lru_bulk_move object pointed to might have been freed. The pointer is only for comparison.h](h3Pointer to struct ttm_lru_bulk_move whose subrange }(hjG$hhhNhNubj)}(h **hitch**h]hhitch}(hjO$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjG$ubh is inserted to. NULL if none. Never dereference this pointer since the struct ttm_lru_bulk_move object pointed to might have been freed. The pointer is only for comparison.}(hjG$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMIhjD$ubah}(h]h ]h"]h$]h&]uh1j hj($ubeh}(h]h ]h"]h$]h&]uh1jhjC$hMLhjf#ubj)}(hh``mem_type`` The memory type of the LRU list being traversed. This field is valid iff **bulk** != NULL. h](j)}(h ``mem_type``h]j)}(hjz$h]hmem_type}(hj|$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjx$ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMNhjt$ubj )}(hhh]h)}(hZThe memory type of the LRU list being traversed. This field is valid iff **bulk** != NULL.h](hIThe memory type of the LRU list being traversed. This field is valid iff }(hj$hhhNhNubj)}(h**bulk**h]hbulk}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubh != NULL.}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMMhj$ubah}(h]h ]h"]h$]h&]uh1j hjt$ubeh}(h]h ]h"]h$]h&]uh1jhj$hMNhjf#ubj)}(h!``priority`` the current priorityh](j)}(h ``priority``h]j)}(hj$h]hpriority}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMNhj$ubj )}(hhh]h)}(hthe current priorityh]hthe current priority}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMOhj$ubah}(h]h ]h"]h$]h&]uh1j hj$ubeh}(h]h ]h"]h$]h&]uh1jhj$hMNhjf#ubeh}(h]h ]h"]h$]h&]uh1jhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubh)}(h**Description**h]j)}(hj %h]h Description}(hj %hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMRhjAhhubh)}(h2Cursor to iterate over the resources in a manager.h]h2Cursor to iterate over the resources in a manager.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMOhjAhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_kmap_iter_iomap (C struct)c.ttm_kmap_iter_iomaphNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_kmap_iter_iomaph]j>)}(hstruct ttm_kmap_iter_iomaph](jD)}(hjh]hstruct}(hjG%hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjC%hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMTubjV)}(h h]h }(hjU%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjC%hhhjT%hMTubjg)}(httm_kmap_iter_iomaph]jm)}(hjA%h]httm_kmap_iter_iomap}(hjg%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjc%ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjC%hhhjT%hMTubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj?%hhhjT%hMTubah}(h]j:%ah ](jjeh"]h$]h&]jj)jhuh1j7hjT%hMThj<%hhubj)}(hhh]h)}(hTSpecialization for a struct io_mapping + struct sg_table backed struct ttm_resource.h]hTSpecialization for a struct io_mapping + struct sg_table backed struct ttm_resource.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMahj%hhubah}(h]h ]h"]h$]h&]uh1jhj<%hhhjT%hMTubeh}(h]h ](jstructeh"]h$]h&]jjjj%jj%jjjuh1j2hhhjAhNhNubj)}(hX**Definition**:: struct ttm_kmap_iter_iomap { struct ttm_kmap_iter base; struct io_mapping *iomap; struct sg_table *st; resource_size_t start; struct { struct scatterlist *sg; pgoff_t i; pgoff_t end; pgoff_t offs; } cache; }; **Members** ``base`` Embedded struct ttm_kmap_iter providing the usage interface. ``iomap`` struct io_mapping representing the underlying linear io_memory. ``st`` sg_table into **iomap**, representing the memory of the struct ttm_resource. ``start`` Offset that needs to be subtracted from **st** to make sg_dma_address(st->sgl) - **start** == 0 for **iomap** start. ``cache`` Scatterlist traversal cache for fast lookups. ``cache.sg`` Pointer to the currently cached scatterlist segment. ``cache.i`` First index of **sg**. PAGE_SIZE granularity. ``cache.end`` Last index + 1 of **sg**. PAGE_SIZE granularity. ``cache.offs`` First offset into **iomap** of **sg**. PAGE_SIZE granularity.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubh:}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMehj%ubjT)}(hXstruct ttm_kmap_iter_iomap { struct ttm_kmap_iter base; struct io_mapping *iomap; struct sg_table *st; resource_size_t start; struct { struct scatterlist *sg; pgoff_t i; pgoff_t end; pgoff_t offs; } cache; };h]hXstruct ttm_kmap_iter_iomap { struct ttm_kmap_iter base; struct io_mapping *iomap; struct sg_table *st; resource_size_t start; struct { struct scatterlist *sg; pgoff_t i; pgoff_t end; pgoff_t offs; } cache; };}hj%sbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMghj%ubh)}(h **Members**h]j)}(hj%h]hMembers}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMthj%ubj)}(hhh](j)}(hF``base`` Embedded struct ttm_kmap_iter providing the usage interface. h](j)}(h``base``h]j)}(hj%h]hbase}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMdhj%ubj )}(hhh]h)}(hsgl) - **start** == 0 for **iomap** start. h](j)}(h ``start``h]j)}(hj&h]hstart}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhhj&ubj )}(hhh]h)}(htOffset that needs to be subtracted from **st** to make sg_dma_address(st->sgl) - **start** == 0 for **iomap** start.h](h(Offset that needs to be subtracted from }(hj&hhhNhNubj)}(h**st**h]hst}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubh# to make sg_dma_address(st->sgl) - }(hj&hhhNhNubj)}(h **start**h]hstart}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubh == 0 for }(hj&hhhNhNubj)}(h **iomap**h]hiomap}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubh start.}(hj&hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMghj&ubah}(h]h ]h"]h$]h&]uh1j hj&ubeh}(h]h ]h"]h$]h&]uh1jhj&hMhhj%ubj)}(h8``cache`` Scatterlist traversal cache for fast lookups. h](j)}(h ``cache``h]j)}(hj#'h]hcache}(hj%'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!'ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMihj'ubj )}(hhh]h)}(h-Scatterlist traversal cache for fast lookups.h]h-Scatterlist traversal cache for fast lookups.}(hj<'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8'hMihj9'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj8'hMihj%ubj)}(hB``cache.sg`` Pointer to the currently cached scatterlist segment. h](j)}(h ``cache.sg``h]j)}(hj\'h]hcache.sg}(hj^'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZ'ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMjhjV'ubj )}(hhh]h)}(h4Pointer to the currently cached scatterlist segment.h]h4Pointer to the currently cached scatterlist segment.}(hju'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjq'hMjhjr'ubah}(h]h ]h"]h$]h&]uh1j hjV'ubeh}(h]h ]h"]h$]h&]uh1jhjq'hMjhj%ubj)}(h:``cache.i`` First index of **sg**. PAGE_SIZE granularity. h](j)}(h ``cache.i``h]j)}(hj'h]hcache.i}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMkhj'ubj )}(hhh]h)}(h-First index of **sg**. PAGE_SIZE granularity.h](hFirst index of }(hj'hhhNhNubj)}(h**sg**h]hsg}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubh. PAGE_SIZE granularity.}(hj'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj'hMkhj'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMkhj%ubj)}(h?``cache.end`` Last index + 1 of **sg**. PAGE_SIZE granularity. h](j)}(h ``cache.end``h]j)}(hj'h]h cache.end}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMlhj'ubj )}(hhh]h)}(h0Last index + 1 of **sg**. PAGE_SIZE granularity.h](hLast index + 1 of }(hj'hhhNhNubj)}(h**sg**h]hsg}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubh. PAGE_SIZE granularity.}(hj'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj'hMlhj'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMlhj%ubj)}(hL``cache.offs`` First offset into **iomap** of **sg**. PAGE_SIZE granularity.h](j)}(h``cache.offs``h]j)}(hj+(h]h cache.offs}(hj-(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)(ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMlhj%(ubj )}(hhh]h)}(h=First offset into **iomap** of **sg**. PAGE_SIZE granularity.h](hFirst offset into }(hjD(hhhNhNubj)}(h **iomap**h]hiomap}(hjL(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjD(ubh of }(hjD(hhhNhNubj)}(h**sg**h]hsg}(hj^(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjD(ubh. PAGE_SIZE granularity.}(hjD(hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMmhjA(ubah}(h]h ]h"]h$]h&]uh1j hj%(ubeh}(h]h ]h"]h$]h&]uh1jhj@(hMlhj%ubeh}(h]h ]h"]h$]h&]uh1jhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."ttm_kmap_iter_linear_io (C struct)c.ttm_kmap_iter_linear_iohNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(httm_kmap_iter_linear_ioh]j>)}(hstruct ttm_kmap_iter_linear_ioh](jD)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj(hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMsubjV)}(h h]h }(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(hhhj(hMsubjg)}(httm_kmap_iter_linear_ioh]jm)}(hj(h]httm_kmap_iter_linear_io}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj(hhhj(hMsubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj(hhhj(hMsubah}(h]j(ah ](jjeh"]h$]h&]jj)jhuh1j7hj(hMshj(hhubj)}(hhh]h)}(h%Iterator specialization for linear ioh]h%Iterator specialization for linear io}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM|hj(hhubah}(h]h ]h"]h$]h&]uh1jhj(hhhj(hMsubeh}(h]h ](jstructeh"]h$]h&]jjjj)jj)jjjuh1j2hhhjAhNhNubj)}(hX'**Definition**:: struct ttm_kmap_iter_linear_io { struct ttm_kmap_iter base; struct iosys_map dmap; bool needs_unmap; }; **Members** ``base`` The base iterator ``dmap`` Points to the starting address of the region ``needs_unmap`` Whether we need to unmap on finih](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj )ubh:}(hj )hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj)ubjT)}(hsstruct ttm_kmap_iter_linear_io { struct ttm_kmap_iter base; struct iosys_map dmap; bool needs_unmap; };h]hsstruct ttm_kmap_iter_linear_io { struct ttm_kmap_iter base; struct iosys_map dmap; bool needs_unmap; };}hj()sbah}(h]h ]h"]h$]h&]jjuh1jShY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj)ubh)}(h **Members**h]j)}(hj9)h]hMembers}(hj;)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7)ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj)ubj)}(hhh](j)}(h``base`` The base iterator h](j)}(h``base``h]j)}(hjX)h]hbase}(hjZ)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV)ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhM~hjR)ubj )}(hhh]h)}(hThe base iteratorh]hThe base iterator}(hjq)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjm)hM~hjn)ubah}(h]h ]h"]h$]h&]uh1j hjR)ubeh}(h]h ]h"]h$]h&]uh1jhjm)hM~hjO)ubj)}(h6``dmap`` Points to the starting address of the region h](j)}(h``dmap``h]j)}(hj)h]hdmap}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj)ubj )}(hhh]h)}(h,Points to the starting address of the regionh]h,Points to the starting address of the region}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMhj)ubah}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMhjO)ubj)}(h0``needs_unmap`` Whether we need to unmap on finih](j)}(h``needs_unmap``h]j)}(hj)h]h needs_unmap}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj)ubj )}(hhh]h)}(h Whether we need to unmap on finih]h Whether we need to unmap on fini}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj)ubah}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMhjO)ubeh}(h]h ]h"]h$]h&]uh1jhj)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*ttm_resource_manager_set_used (C function)c.ttm_resource_manager_set_usedhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hPvoid ttm_resource_manager_set_used (struct ttm_resource_manager *man, bool used)h]j>)}(hOvoid ttm_resource_manager_set_used(struct ttm_resource_manager *man, bool used)h](j)}(hvoidh]hvoid}(hj$*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj *hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMubjV)}(h h]h }(hj3*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj *hhhj2*hMubjg)}(httm_resource_manager_set_usedh]jm)}(httm_resource_manager_set_usedh]httm_resource_manager_set_used}(hjE*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjA*ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj *hhhj2*hMubj)}(h-(struct ttm_resource_manager *man, bool used)h](j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hja*hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj]*ubjV)}(h h]h }(hjn*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]*ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j )}jjG*sbc.ttm_resource_manager_set_usedasbuh1hhj]*ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]*ubj4)}(hj7h]h*}(hj*hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj]*ubjm)}(hmanh]hman}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjY*ubj)}(h bool usedh](j)}(hboolh]hbool}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*ubjm)}(husedh]hused}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjY*ubeh}(h]h ]h"]h$]h&]jjuh1jhj *hhhj2*hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj*hhhj2*hMubah}(h]j*ah ](jjeh"]h$]h&]jj)jhuh1j7hj2*hMhj*hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj*hhhj2*hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj"+jj"+jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_resource_manager *man`` A memory manager object. ``bool used`` usage state to set. **Description** Set the manager in use flag. If disabled the manager is no longer used for object placement.h](h)}(h**Parameters**h]j)}(hj,+h]h Parameters}(hj.+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*+ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj&+ubj)}(hhh](j)}(h>``struct ttm_resource_manager *man`` A memory manager object. h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hjK+h]h struct ttm_resource_manager *man}(hjM+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjI+ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjE+ubj )}(hhh]h)}(hA memory manager object.h]hA memory manager object.}(hjd+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`+hMhja+ubah}(h]h ]h"]h$]h&]uh1j hjE+ubeh}(h]h ]h"]h$]h&]uh1jhj`+hMhjB+ubj)}(h"``bool used`` usage state to set. h](j)}(h ``bool used``h]j)}(hj+h]h bool used}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj~+ubj )}(hhh]h)}(husage state to set.h]husage state to set.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hMhj+ubah}(h]h ]h"]h$]h&]uh1j hj~+ubeh}(h]h ]h"]h$]h&]uh1jhj+hMhjB+ubeh}(h]h ]h"]h$]h&]uh1jhj&+ubh)}(h**Description**h]j)}(hj+h]h Description}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj&+ubh)}(h\Set the manager in use flag. If disabled the manager is no longer used for object placement.h]h\Set the manager in use flag. If disabled the manager is no longer used for object placement.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj&+ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&ttm_resource_manager_used (C function)c.ttm_resource_manager_usedhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hAbool ttm_resource_manager_used (struct ttm_resource_manager *man)h]j>)}(h@bool ttm_resource_manager_used(struct ttm_resource_manager *man)h](j)}(hj*h]hbool}(hj,hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMubjV)}(h h]h }(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,hhhj,hMubjg)}(httm_resource_manager_usedh]jm)}(httm_resource_manager_usedh]httm_resource_manager_used}(hj$,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ,ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj,hhhj,hMubj)}(h"(struct ttm_resource_manager *man)h]j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hj@,hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj<,ubjV)}(h h]h }(hjM,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<,ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj^,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj`,modnameN classnameNjj)}j]j )}jj&,sbc.ttm_resource_manager_usedasbuh1hhj<,ubjV)}(h h]h }(hj~,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<,ubj4)}(hj7h]h*}(hj,hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj<,ubjm)}(hmanh]hman}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj<,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8,ubah}(h]h ]h"]h$]h&]jjuh1jhj,hhhj,hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj+hhhj,hMubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1j7hj,hMhj+hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj+hhhj,hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj,jj,jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_resource_manager *man`` Manager to get used state for **Description** Get the in use flag for a manager. **Return** true is used, false if not.h](h)}(h**Parameters**h]j)}(hj,h]h Parameters}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj,ubj)}(hhh]j)}(hC``struct ttm_resource_manager *man`` Manager to get used state for h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hj,h]h struct ttm_resource_manager *man}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj,ubj )}(hhh]h)}(hManager to get used state forh]hManager to get used state for}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj -hMhj -ubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhj -hMhj,ubah}(h]h ]h"]h$]h&]uh1jhj,ubh)}(h**Description**h]j)}(hj0-h]h Description}(hj2-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.-ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj,ubh)}(h"Get the in use flag for a manager.h]h"Get the in use flag for a manager.}(hjF-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj,ubh)}(h **Return**h]j)}(hjW-h]hReturn}(hjY-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjU-ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj,ubh)}(htrue is used, false if not.h]htrue is used, false if not.}(hjm-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj,ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)ttm_resource_manager_cleanup (C function)c.ttm_resource_manager_cleanuphNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hDvoid ttm_resource_manager_cleanup (struct ttm_resource_manager *man)h]j>)}(hCvoid ttm_resource_manager_cleanup(struct ttm_resource_manager *man)h](j)}(hvoidh]hvoid}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-hhhj-hMubjg)}(httm_resource_manager_cleanuph]jm)}(httm_resource_manager_cleanuph]httm_resource_manager_cleanup}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj-hhhj-hMubj)}(h"(struct ttm_resource_manager *man)h]j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hj-hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj-ubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]j )}jj-sbc.ttm_resource_manager_cleanupasbuh1hhj-ubjV)}(h h]h }(hj.hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubj4)}(hj7h]h*}(hj%.hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj-ubjm)}(hmanh]hman}(hj2.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj-ubah}(h]h ]h"]h$]h&]jjuh1jhj-hhhj-hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj-hhhj-hMubah}(h]j-ah ](jjeh"]h$]h&]jj)jhuh1j7hj-hMhj-hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj-hhhj-hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjje.jje.jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_resource_manager *man`` A memory manager object. **Description** Cleanup the move fences from the memory manager object.h](h)}(h**Parameters**h]j)}(hjo.h]h Parameters}(hjq.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjm.ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhji.ubj)}(hhh]j)}(h>``struct ttm_resource_manager *man`` A memory manager object. h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hj.h]h struct ttm_resource_manager *man}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj.ubj )}(hhh]h)}(hA memory manager object.h]hA memory manager object.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.hMhj.ubah}(h]h ]h"]h$]h&]uh1j hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hMhj.ubah}(h]h ]h"]h$]h&]uh1jhji.ubh)}(h**Description**h]j)}(hj.h]h Description}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhji.ubh)}(h7Cleanup the move fences from the memory manager object.h]h7Cleanup the move fences from the memory manager object.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhji.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.+ttm_resource_manager_for_each_res (C macro)#c.ttm_resource_manager_for_each_reshNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(h!ttm_resource_manager_for_each_resh]j>)}(h!ttm_resource_manager_for_each_resh]jg)}(h!ttm_resource_manager_for_each_resh]jm)}(hj/h]h!ttm_resource_manager_for_each_res}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj /hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj/hhhj%/hMubah}(h]j/ah ](jjeh"]h$]h&]jj)jhuh1j7hj%/hMhj/hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj/hhhj%/hMubeh}(h]h ](jmacroeh"]h$]h&]jjjj>/jj>/jjjuh1j2hhhjAhNhNubh)}(h3``ttm_resource_manager_for_each_res (cursor, res)``h]j)}(hjD/h]h/ttm_resource_manager_for_each_res (cursor, res)}(hjF/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjB/ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjAhhubj)}(hiterate over all resources h]h)}(hiterate over all resourcesh]hiterate over all resources}(hj^/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjZ/ubah}(h]h ]h"]h$]h&]uh1jhjl/hMhjAhhubj)}(h**Parameters** ``cursor`` struct ttm_resource_cursor for the current position ``res`` the current resource **Description** Iterate over all the evictable resources in a resource manager.h](h)}(h**Parameters**h]j)}(hjy/h]h Parameters}(hj{/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjw/ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjs/ubj)}(hhh](j)}(h?``cursor`` struct ttm_resource_cursor for the current position h](j)}(h ``cursor``h]j)}(hj/h]hcursor}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj/ubj )}(hhh]h)}(h3struct ttm_resource_cursor for the current positionh]h3struct ttm_resource_cursor for the current position}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMhj/ubah}(h]h ]h"]h$]h&]uh1j hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hMhj/ubj)}(h``res`` the current resource h](j)}(h``res``h]j)}(hj/h]hres}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhj/ubj )}(hhh]h)}(hthe current resourceh]hthe current resource}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hMhj/ubah}(h]h ]h"]h$]h&]uh1j hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hMhj/ubeh}(h]h ]h"]h$]h&]uh1jhjs/ubh)}(h**Description**h]j)}(hj 0h]h Description}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 0ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjs/ubh)}(h?Iterate over all the evictable resources in a resource manager.h]h?Iterate over all the evictable resources in a resource manager.}(hj"0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:55: ./include/drm/ttm/ttm_resource.hhMhjs/ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#ttm_lru_bulk_move_init (C function)c.ttm_lru_bulk_move_inithNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(h)}(h;void ttm_lru_bulk_move_init(struct ttm_lru_bulk_move *bulk)h](j)}(hvoidh]hvoid}(hjQ0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjM0hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKxubjV)}(h h]h }(hj`0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjM0hhhj_0hKxubjg)}(httm_lru_bulk_move_inith]jm)}(httm_lru_bulk_move_inith]httm_lru_bulk_move_init}(hjr0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjn0ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjM0hhhj_0hKxubj)}(h (struct ttm_lru_bulk_move *bulk)h]j)}(hstruct ttm_lru_bulk_move *bulkh](jD)}(hjh]hstruct}(hj0hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj0ubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0ubh)}(hhh]jm)}(httm_lru_bulk_moveh]httm_lru_bulk_move}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j )}jjt0sbc.ttm_lru_bulk_move_initasbuh1hhj0ubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0ubj4)}(hj7h]h*}(hj0hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj0ubjm)}(hbulkh]hbulk}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj0ubah}(h]h ]h"]h$]h&]jjuh1jhjM0hhhj_0hKxubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjI0hhhj_0hKxubah}(h]jD0ah ](jjeh"]h$]h&]jj)jhuh1j7hj_0hKxhjF0hhubj)}(hhh]h)}(h initialize a bulk move structureh]h initialize a bulk move structure}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKxhj1hhubah}(h]h ]h"]h$]h&]uh1jhjF0hhhj_0hKxubeh}(h]h ](jfunctioneh"]h$]h&]jjjj)1jj)1jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_lru_bulk_move *bulk`` the structure to init **Description** For now just memset the structure to zero.h](h)}(h**Parameters**h]j)}(hj31h]h Parameters}(hj51hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj11ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chK|hj-1ubj)}(hhh]j)}(h9``struct ttm_lru_bulk_move *bulk`` the structure to init h](j)}(h"``struct ttm_lru_bulk_move *bulk``h]j)}(hjR1h]hstruct ttm_lru_bulk_move *bulk}(hjT1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP1ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKyhjL1ubj )}(hhh]h)}(hthe structure to inith]hthe structure to init}(hjk1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjg1hKyhjh1ubah}(h]h ]h"]h$]h&]uh1j hjL1ubeh}(h]h ]h"]h$]h&]uh1jhjg1hKyhjI1ubah}(h]h ]h"]h$]h&]uh1jhj-1ubh)}(h**Description**h]j)}(hj1h]h Description}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chK{hj-1ubh)}(h*For now just memset the structure to zero.h]h*For now just memset the structure to zero.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKzhj-1ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#ttm_lru_bulk_move_fini (C function)c.ttm_lru_bulk_move_finihNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hUvoid ttm_lru_bulk_move_fini (struct ttm_device *bdev, struct ttm_lru_bulk_move *bulk)h]j>)}(hTvoid ttm_lru_bulk_move_fini(struct ttm_device *bdev, struct ttm_lru_bulk_move *bulk)h](j)}(hvoidh]hvoid}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1hhhj1hKubjg)}(httm_lru_bulk_move_finih]jm)}(httm_lru_bulk_move_finih]httm_lru_bulk_move_fini}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj1hhhj1hKubj)}(h9(struct ttm_device *bdev, struct ttm_lru_bulk_move *bulk)h](j)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hj2hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj 2ubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj 2ubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hj-2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*2ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj/2modnameN classnameNjj)}j]j )}jj1sbc.ttm_lru_bulk_move_finiasbuh1hhj 2ubjV)}(h h]h }(hjM2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj 2ubj4)}(hj7h]h*}(hj[2hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj 2ubjm)}(hbdevh]hbdev}(hjh2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj 2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2ubj)}(hstruct ttm_lru_bulk_move *bulkh](jD)}(hjh]hstruct}(hj2hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj}2ubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj}2ubh)}(hhh]jm)}(httm_lru_bulk_moveh]httm_lru_bulk_move}(hj2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj2ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj2modnameN classnameNjj)}j]jI2c.ttm_lru_bulk_move_finiasbuh1hhj}2ubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj}2ubj4)}(hj7h]h*}(hj2hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj}2ubjm)}(hbulkh]hbulk}(hj2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj2ubeh}(h]h ]h"]h$]h&]jjuh1jhj1hhhj1hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj1hhhj1hKubah}(h]j1ah ](jjeh"]h$]h&]jj)jhuh1j7hj1hKhj1hhubj)}(hhh]h)}(hfinalize a bulk move structureh]hfinalize a bulk move structure}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj2hhubah}(h]h ]h"]h$]h&]uh1jhj1hhhj1hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj3jj3jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_device *bdev`` The struct ttm_device ``struct ttm_lru_bulk_move *bulk`` the structure to finalize **Description** Sanity checks that bulk moves don't have any resources left and hence no cursors attached.h](h)}(h**Parameters**h]j)}(hj$3h]h Parameters}(hj&3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"3ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj3ubj)}(hhh](j)}(h2``struct ttm_device *bdev`` The struct ttm_device h](j)}(h``struct ttm_device *bdev``h]j)}(hjC3h]hstruct ttm_device *bdev}(hjE3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjA3ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj=3ubj )}(hhh]h)}(hThe struct ttm_deviceh]hThe struct ttm_device}(hj\3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjX3hKhjY3ubah}(h]h ]h"]h$]h&]uh1j hj=3ubeh}(h]h ]h"]h$]h&]uh1jhjX3hKhj:3ubj)}(h=``struct ttm_lru_bulk_move *bulk`` the structure to finalize h](j)}(h"``struct ttm_lru_bulk_move *bulk``h]j)}(hj|3h]hstruct ttm_lru_bulk_move *bulk}(hj~3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz3ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhjv3ubj )}(hhh]h)}(hthe structure to finalizeh]hthe structure to finalize}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hKhj3ubah}(h]h ]h"]h$]h&]uh1j hjv3ubeh}(h]h ]h"]h$]h&]uh1jhj3hKhj:3ubeh}(h]h ]h"]h$]h&]uh1jhj3ubh)}(h**Description**h]j)}(hj3h]h Description}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj3ubh)}(hZSanity checks that bulk moves don't have any resources left and hence no cursors attached.h]h\Sanity checks that bulk moves don’t have any resources left and hence no cursors attached.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj3ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#ttm_lru_bulk_move_tail (C function)c.ttm_lru_bulk_move_tailhNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(h)}(h;void ttm_lru_bulk_move_tail(struct ttm_lru_bulk_move *bulk)h](j)}(hvoidh]hvoid}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKubjV)}(h h]h }(hj 4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj3hhhj 4hKubjg)}(httm_lru_bulk_move_tailh]jm)}(httm_lru_bulk_move_tailh]httm_lru_bulk_move_tail}(hj4hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj3hhhj 4hKubj)}(h (struct ttm_lru_bulk_move *bulk)h]j)}(hstruct ttm_lru_bulk_move *bulkh](jD)}(hjh]hstruct}(hj94hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj54ubjV)}(h h]h }(hjF4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj54ubh)}(hhh]jm)}(httm_lru_bulk_moveh]httm_lru_bulk_move}(hjW4hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjT4ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjY4modnameN classnameNjj)}j]j )}jj4sbc.ttm_lru_bulk_move_tailasbuh1hhj54ubjV)}(h h]h }(hjw4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj54ubj4)}(hj7h]h*}(hj4hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj54ubjm)}(hbulkh]hbulk}(hj4hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj54ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj14ubah}(h]h ]h"]h$]h&]jjuh1jhj3hhhj 4hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj3hhhj 4hKubah}(h]j3ah ](jjeh"]h$]h&]jj)jhuh1j7hj 4hKhj3hhubj)}(hhh]h)}(h-bulk move range of resources to the LRU tail.h]h-bulk move range of resources to the LRU tail.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj4hhubah}(h]h ]h"]h$]h&]uh1jhj3hhhj 4hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj4jj4jjjuh1j2hhhjAhNhNubj)}(hX **Parameters** ``struct ttm_lru_bulk_move *bulk`` bulk move structure **Description** Bulk move BOs to the LRU tail, only valid to use when driver makes sure that resource order never changes. Should be called with :c:type:`ttm_device.lru_lock ` held.h](h)}(h**Parameters**h]j)}(hj4h]h Parameters}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj4ubj)}(hhh]j)}(h7``struct ttm_lru_bulk_move *bulk`` bulk move structure h](j)}(h"``struct ttm_lru_bulk_move *bulk``h]j)}(hj4h]hstruct ttm_lru_bulk_move *bulk}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj4ubj )}(hhh]h)}(hbulk move structureh]hbulk move structure}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hKhj5ubah}(h]h ]h"]h$]h&]uh1j hj4ubeh}(h]h ]h"]h$]h&]uh1jhj5hKhj4ubah}(h]h ]h"]h$]h&]uh1jhj4ubh)}(h**Description**h]j)}(hj85h]h Description}(hj:5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj65ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhj4ubh)}(hBulk move BOs to the LRU tail, only valid to use when driver makes sure that resource order never changes. Should be called with :c:type:`ttm_device.lru_lock ` held.h](hBulk move BOs to the LRU tail, only valid to use when driver makes sure that resource order never changes. Should be called with }(hjN5hhhNhNubh)}(h*:c:type:`ttm_device.lru_lock `h]j)}(hjX5h]httm_device.lru_lock}(hjZ5hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjV5ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM ttm_deviceuh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chKhjN5ubh held.}(hjN5hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhju5hKhj4ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_resource_init (C function)c.ttm_resource_inithNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hnvoid ttm_resource_init (struct ttm_buffer_object *bo, const struct ttm_place *place, struct ttm_resource *res)h]j>)}(hmvoid ttm_resource_init(struct ttm_buffer_object *bo, const struct ttm_place *place, struct ttm_resource *res)h](j)}(hvoidh]hvoid}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM@ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5hhhj5hM@ubjg)}(httm_resource_inith]jm)}(httm_resource_inith]httm_resource_init}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj5hhhj5hM@ubj)}(hW(struct ttm_buffer_object *bo, const struct ttm_place *place, struct ttm_resource *res)h](j)}(hstruct ttm_buffer_object *boh](jD)}(hjh]hstruct}(hj5hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj5ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubh)}(hhh]jm)}(httm_buffer_objecth]httm_buffer_object}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j )}jj5sbc.ttm_resource_initasbuh1hhj5ubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubj4)}(hj7h]h*}(hj)6hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj5ubjm)}(hboh]hbo}(hj66hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(hconst struct ttm_place *placeh](jD)}(hj h]hconst}(hjO6hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjK6ubjV)}(h h]h }(hj\6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjK6ubjD)}(hjh]hstruct}(hjj6hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjK6ubjV)}(h h]h }(hjw6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjK6ubh)}(hhh]jm)}(h ttm_placeh]h ttm_place}(hj6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj6modnameN classnameNjj)}j]j6c.ttm_resource_initasbuh1hhjK6ubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjK6ubj4)}(hj7h]h*}(hj6hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjK6ubjm)}(hplaceh]hplace}(hj6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjK6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(hstruct ttm_resource *resh](jD)}(hjh]hstruct}(hj6hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj6ubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6ubh)}(hhh]jm)}(h ttm_resourceh]h ttm_resource}(hj6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj6modnameN classnameNjj)}j]j6c.ttm_resource_initasbuh1hhj6ubjV)}(h h]h }(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6ubj4)}(hj7h]h*}(hj$7hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj6ubjm)}(hresh]hres}(hj17hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubeh}(h]h ]h"]h$]h&]jjuh1jhj5hhhj5hM@ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj5hhhj5hM@ubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1j7hj5hM@hj5hhubj)}(hhh]h)}(hresource object constructureh]hresource object constructure}(hj[7hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM@hjX7hhubah}(h]h ]h"]h$]h&]uh1jhj5hhhj5hM@ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjs7jjs7jjjuh1j2hhhjAhNhNubj)}(hX9**Parameters** ``struct ttm_buffer_object *bo`` buffer object this resources is allocated for ``const struct ttm_place *place`` placement of the resource ``struct ttm_resource *res`` the resource object to inistilize **Description** Initialize a new resource object. Counterpart of ttm_resource_fini().h](h)}(h**Parameters**h]j)}(hj}7h]h Parameters}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{7ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMDhjw7ubj)}(hhh](j)}(hO``struct ttm_buffer_object *bo`` buffer object this resources is allocated for h](j)}(h ``struct ttm_buffer_object *bo``h]j)}(hj7h]hstruct ttm_buffer_object *bo}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMAhj7ubj )}(hhh]h)}(h-buffer object this resources is allocated forh]h-buffer object this resources is allocated for}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMAhj7ubah}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMAhj7ubj)}(h<``const struct ttm_place *place`` placement of the resource h](j)}(h!``const struct ttm_place *place``h]j)}(hj7h]hconst struct ttm_place *place}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMBhj7ubj )}(hhh]h)}(hplacement of the resourceh]hplacement of the resource}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMBhj7ubah}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMBhj7ubj)}(h?``struct ttm_resource *res`` the resource object to inistilize h](j)}(h``struct ttm_resource *res``h]j)}(hj8h]hstruct ttm_resource *res}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 8ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMChj8ubj )}(hhh]h)}(h!the resource object to inistilizeh]h!the resource object to inistilize}(hj'8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#8hMChj$8ubah}(h]h ]h"]h$]h&]uh1j hj8ubeh}(h]h ]h"]h$]h&]uh1jhj#8hMChj7ubeh}(h]h ]h"]h$]h&]uh1jhjw7ubh)}(h**Description**h]j)}(hjI8h]h Description}(hjK8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjG8ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMEhjw7ubh)}(hEInitialize a new resource object. Counterpart of ttm_resource_fini().h]hEInitialize a new resource object. Counterpart of ttm_resource_fini().}(hj_8hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMDhjw7ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_resource_fini (C function)c.ttm_resource_finihNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hSvoid ttm_resource_fini (struct ttm_resource_manager *man, struct ttm_resource *res)h]j>)}(hRvoid ttm_resource_fini(struct ttm_resource_manager *man, struct ttm_resource *res)h](j)}(hvoidh]hvoid}(hj8hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj8hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMcubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8hhhj8hMcubjg)}(httm_resource_finih]jm)}(httm_resource_finih]httm_resource_fini}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj8hhhj8hMcubj)}(h<(struct ttm_resource_manager *man, struct ttm_resource *res)h](j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj8ubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj8modnameN classnameNjj)}j]j )}jj8sbc.ttm_resource_finiasbuh1hhj8ubjV)}(h h]h }(hj 9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8ubj4)}(hj7h]h*}(hj9hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj8ubjm)}(hmanh]hman}(hj$9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubj)}(hstruct ttm_resource *resh](jD)}(hjh]hstruct}(hj=9hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj99ubjV)}(h h]h }(hjJ9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj99ubh)}(hhh]jm)}(h ttm_resourceh]h ttm_resource}(hj[9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjX9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]9modnameN classnameNjj)}j]j9c.ttm_resource_finiasbuh1hhj99ubjV)}(h h]h }(hjy9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj99ubj4)}(hj7h]h*}(hj9hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj99ubjm)}(hresh]hres}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj99ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubeh}(h]h ]h"]h$]h&]jjuh1jhj8hhhj8hMcubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj8hhhj8hMcubah}(h]j8ah ](jjeh"]h$]h&]jj)jhuh1j7hj8hMchj8hhubj)}(hhh]h)}(hresource destructorh]hresource destructor}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMchj9hhubah}(h]h ]h"]h$]h&]uh1jhj8hhhj8hMcubeh}(h]h ](jfunctioneh"]h$]h&]jjjj9jj9jjjuh1j2hhhjAhNhNubj)}(hX**Parameters** ``struct ttm_resource_manager *man`` the resource manager this resource belongs to ``struct ttm_resource *res`` the resource to clean up **Description** Should be used by resource manager backends to clean up the TTM resource objects before freeing the underlying structure. Makes sure the resource is removed from the LRU before destruction. Counterpart of ttm_resource_init().h](h)}(h**Parameters**h]j)}(hj9h]h Parameters}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMghj9ubj)}(hhh](j)}(hS``struct ttm_resource_manager *man`` the resource manager this resource belongs to h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hj9h]h struct ttm_resource_manager *man}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMdhj9ubj )}(hhh]h)}(h-the resource manager this resource belongs toh]h-the resource manager this resource belongs to}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMdhj:ubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhj:hMdhj9ubj)}(h6``struct ttm_resource *res`` the resource to clean up h](j)}(h``struct ttm_resource *res``h]j)}(hj8:h]hstruct ttm_resource *res}(hj::hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6:ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMehj2:ubj )}(hhh]h)}(hthe resource to clean uph]hthe resource to clean up}(hjQ:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM:hMehjN:ubah}(h]h ]h"]h$]h&]uh1j hj2:ubeh}(h]h ]h"]h$]h&]uh1jhjM:hMehj9ubeh}(h]h ]h"]h$]h&]uh1jhj9ubh)}(h**Description**h]j)}(hjs:h]h Description}(hju:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjq:ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMghj9ubh)}(hShould be used by resource manager backends to clean up the TTM resource objects before freeing the underlying structure. Makes sure the resource is removed from the LRU before destruction. Counterpart of ttm_resource_init().h]hShould be used by resource manager backends to clean up the TTM resource objects before freeing the underlying structure. Makes sure the resource is removed from the LRU before destruction. Counterpart of ttm_resource_init().}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMfhj9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&ttm_resource_manager_init (C function)c.ttm_resource_manager_inithNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hivoid ttm_resource_manager_init (struct ttm_resource_manager *man, struct ttm_device *bdev, uint64_t size)h]j>)}(hhvoid ttm_resource_manager_init(struct ttm_resource_manager *man, struct ttm_device *bdev, uint64_t size)h](j)}(hvoidh]hvoid}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:hhhj:hMubjg)}(httm_resource_manager_inith]jm)}(httm_resource_manager_inith]httm_resource_manager_init}(hj:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj:hhhj:hMubj)}(hJ(struct ttm_resource_manager *man, struct ttm_device *bdev, uint64_t size)h](j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hj:hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj:ubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj;modnameN classnameNjj)}j]j )}jj:sbc.ttm_resource_manager_initasbuh1hhj:ubjV)}(h h]h }(hj3;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubj4)}(hj7h]h*}(hjA;hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj:ubjm)}(hmanh]hman}(hjN;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubj)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hjg;hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjc;ubjV)}(h h]h }(hjt;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjc;ubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj;modnameN classnameNjj)}j]j/;c.ttm_resource_manager_initasbuh1hhjc;ubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjc;ubj4)}(hj7h]h*}(hj;hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjc;ubjm)}(hbdevh]hbdev}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjc;ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubj)}(h uint64_t sizeh](h)}(hhh]jm)}(huint64_th]huint64_t}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj;modnameN classnameNjj)}j]j/;c.ttm_resource_manager_initasbuh1hhj;ubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;ubjm)}(hsizeh]hsize}(hj<hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubeh}(h]h ]h"]h$]h&]jjuh1jhj:hhhj:hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj:hhhj:hMubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1j7hj:hMhj:hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj:hhhj:hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj9<jj9<jjjuh1j2hhhjAhNhNubj)}(hX**Parameters** ``struct ttm_resource_manager *man`` memory manager object to init ``struct ttm_device *bdev`` ttm device this manager belongs to ``uint64_t size`` size of managed resources in arbitrary units **Description** Initialise core parts of a manager object.h](h)}(h**Parameters**h]j)}(hjC<h]h Parameters}(hjE<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjA<ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj=<ubj)}(hhh](j)}(hC``struct ttm_resource_manager *man`` memory manager object to init h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hjb<h]h struct ttm_resource_manager *man}(hjd<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`<ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj\<ubj )}(hhh]h)}(hmemory manager object to inith]hmemory manager object to init}(hj{<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjw<hMhjx<ubah}(h]h ]h"]h$]h&]uh1j hj\<ubeh}(h]h ]h"]h$]h&]uh1jhjw<hMhjY<ubj)}(h?``struct ttm_device *bdev`` ttm device this manager belongs to h](j)}(h``struct ttm_device *bdev``h]j)}(hj<h]hstruct ttm_device *bdev}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj<ubj )}(hhh]h)}(h"ttm device this manager belongs toh]h"ttm device this manager belongs to}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1j hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhjY<ubj)}(h?``uint64_t size`` size of managed resources in arbitrary units h](j)}(h``uint64_t size``h]j)}(hj<h]h uint64_t size}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj<ubj )}(hhh]h)}(h,size of managed resources in arbitrary unitsh]h,size of managed resources in arbitrary units}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1j hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhjY<ubeh}(h]h ]h"]h$]h&]uh1jhj=<ubh)}(h**Description**h]j)}(hj=h]h Description}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj =ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj=<ubh)}(h*Initialise core parts of a manager object.h]h*Initialise core parts of a manager object.}(hj%=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj=<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'ttm_resource_manager_usage (C function)c.ttm_resource_manager_usagehNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hFuint64_t ttm_resource_manager_usage (struct ttm_resource_manager *man)h]j>)}(hEuint64_t ttm_resource_manager_usage(struct ttm_resource_manager *man)h](h)}(hhh]jm)}(huint64_th]huint64_t}(hjW=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjT=ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjY=modnameN classnameNjj)}j]j )}jttm_resource_manager_usagesbc.ttm_resource_manager_usageasbuh1hhjP=hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMFubjV)}(h h]h }(hjy=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjP=hhhjx=hMFubjg)}(httm_resource_manager_usageh]jm)}(hju=h]httm_resource_manager_usage}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjP=hhhjx=hMFubj)}(h"(struct ttm_resource_manager *man)h]j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hj=hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj=ubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=modnameN classnameNjj)}j]js=c.ttm_resource_manager_usageasbuh1hhj=ubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubj4)}(hj7h]h*}(hj=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj=ubjm)}(hmanh]hman}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj=ubah}(h]h ]h"]h$]h&]jjuh1jhjP=hhhjx=hMFubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjL=hhhjx=hMFubah}(h]jG=ah ](jjeh"]h$]h&]jj)jhuh1j7hjx=hMFhjI=hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjI=hhhjx=hMFubeh}(h]h ](jfunctioneh"]h$]h&]jjjj0>jj0>jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_resource_manager *man`` A memory manager object. **Description** Return how many resources are currently used.h](h)}(h**Parameters**h]j)}(hj:>h]h Parameters}(hj<>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8>ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMJhj4>ubj)}(hhh]j)}(h>``struct ttm_resource_manager *man`` A memory manager object. h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hjY>h]h struct ttm_resource_manager *man}(hj[>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjW>ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMHhjS>ubj )}(hhh]h)}(hA memory manager object.h]hA memory manager object.}(hjr>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjn>hMHhjo>ubah}(h]h ]h"]h$]h&]uh1j hjS>ubeh}(h]h ]h"]h$]h&]uh1jhjn>hMHhjP>ubah}(h]h ]h"]h$]h&]uh1jhj4>ubh)}(h**Description**h]j)}(hj>h]h Description}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMJhj4>ubh)}(h-Return how many resources are currently used.h]h-Return how many resources are currently used.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMGhj4>ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'ttm_resource_manager_debug (C function)c.ttm_resource_manager_debughNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hYvoid ttm_resource_manager_debug (struct ttm_resource_manager *man, struct drm_printer *p)h]j>)}(hXvoid ttm_resource_manager_debug(struct ttm_resource_manager *man, struct drm_printer *p)h](j)}(hvoidh]hvoid}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM[ubjV)}(h h]h }(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhj>hM[ubjg)}(httm_resource_manager_debugh]jm)}(httm_resource_manager_debugh]httm_resource_manager_debug}(hj>hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj>hhhj>hM[ubj)}(h9(struct ttm_resource_manager *man, struct drm_printer *p)h](j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hj?hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj?ubjV)}(h h]h }(hj#?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hj4?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1?ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj6?modnameN classnameNjj)}j]j )}jj>sbc.ttm_resource_manager_debugasbuh1hhj?ubjV)}(h h]h }(hjT?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubj4)}(hj7h]h*}(hjb?hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj?ubjm)}(hmanh]hman}(hjo?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubj)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hj?hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj?ubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj?modnameN classnameNjj)}j]jP?c.ttm_resource_manager_debugasbuh1hhj?ubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubj4)}(hj7h]h*}(hj?hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj?ubjm)}(hj@h]hp}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubeh}(h]h ]h"]h$]h&]jjuh1jhj>hhhj>hM[ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj>hhhj>hM[ubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1j7hj>hM[hj>hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj>hhhj>hM[ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj@jj@jjjuh1j2hhhjAhNhNubj)}(h**Parameters** ``struct ttm_resource_manager *man`` manager type to dump. ``struct drm_printer *p`` printer to use for debug.h](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM_hj@ubj)}(hhh](j)}(h;``struct ttm_resource_manager *man`` manager type to dump. h](j)}(h$``struct ttm_resource_manager *man``h]j)}(hj:@h]h struct ttm_resource_manager *man}(hj<@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8@ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM]hj4@ubj )}(hhh]h)}(hmanager type to dump.h]hmanager type to dump.}(hjS@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjO@hM]hjP@ubah}(h]h ]h"]h$]h&]uh1j hj4@ubeh}(h]h ]h"]h$]h&]uh1jhjO@hM]hj1@ubj)}(h3``struct drm_printer *p`` printer to use for debug.h](j)}(h``struct drm_printer *p``h]j)}(hjs@h]hstruct drm_printer *p}(hju@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjq@ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM_hjm@ubj )}(hhh]h)}(hprinter to use for debug.h]hprinter to use for debug.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chM^hj@ubah}(h]h ]h"]h$]h&]uh1j hjm@ubeh}(h]h ]h"]h$]h&]uh1jhj@hM_hj1@ubeh}(h]h ]h"]h$]h&]uh1jhj@ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%ttm_kmap_iter_iomap_init (C function)c.ttm_kmap_iter_iomap_inithNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(hstruct ttm_kmap_iter * ttm_kmap_iter_iomap_init (struct ttm_kmap_iter_iomap *iter_io, struct io_mapping *iomap, struct sg_table *st, resource_size_t start)h]j>)}(hstruct ttm_kmap_iter *ttm_kmap_iter_iomap_init(struct ttm_kmap_iter_iomap *iter_io, struct io_mapping *iomap, struct sg_table *st, resource_size_t start)h](jD)}(hjh]hstruct}(hj@hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj@hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@hhhj@hMubh)}(hhh]jm)}(h ttm_kmap_iterh]h ttm_kmap_iter}(hj@hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@modnameN classnameNjj)}j]j )}jttm_kmap_iter_iomap_initsbc.ttm_kmap_iter_iomap_initasbuh1hhj@hhhj@hMubjV)}(h h]h }(hj AhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@hhhj@hMubj4)}(hj7h]h*}(hjAhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj@hhhj@hMubjg)}(httm_kmap_iter_iomap_inith]jm)}(hj Ah]httm_kmap_iter_iomap_init}(hj,AhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(Aubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj@hhhj@hMubj)}(hk(struct ttm_kmap_iter_iomap *iter_io, struct io_mapping *iomap, struct sg_table *st, resource_size_t start)h](j)}(h#struct ttm_kmap_iter_iomap *iter_ioh](jD)}(hjh]hstruct}(hjGAhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjCAubjV)}(h h]h }(hjTAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCAubh)}(hhh]jm)}(httm_kmap_iter_iomaph]httm_kmap_iter_iomap}(hjeAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgAmodnameN classnameNjj)}j]jAc.ttm_kmap_iter_iomap_initasbuh1hhjCAubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCAubj4)}(hj7h]h*}(hjAhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjCAubjm)}(hiter_ioh]hiter_io}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?Aubj)}(hstruct io_mapping *iomaph](jD)}(hjh]hstruct}(hjAhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjAubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubh)}(hhh]jm)}(h io_mappingh]h io_mapping}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]jAc.ttm_kmap_iter_iomap_initasbuh1hhjAubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubj4)}(hj7h]h*}(hjBhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjAubjm)}(hiomaph]hiomap}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?Aubj)}(hstruct sg_table *sth](jD)}(hjh]hstruct}(hj'BhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj#BubjV)}(h h]h }(hj4BhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#Bubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjEBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBBubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjGBmodnameN classnameNjj)}j]jAc.ttm_kmap_iter_iomap_initasbuh1hhj#BubjV)}(h h]h }(hjcBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#Bubj4)}(hj7h]h*}(hjqBhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj#Bubjm)}(hsth]hst}(hj~BhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj#Bubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?Aubj)}(hresource_size_t starth](h)}(hhh]jm)}(hresource_size_th]hresource_size_t}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjBmodnameN classnameNjj)}j]jAc.ttm_kmap_iter_iomap_initasbuh1hhjBubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubjm)}(hstarth]hstart}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?Aubeh}(h]h ]h"]h$]h&]jjuh1jhj@hhhj@hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj@hhhj@hMubah}(h]j@ah ](jjeh"]h$]h&]jj)jhuh1j7hj@hMhj@hhubj)}(hhh]h)}(h'Initialize a struct ttm_kmap_iter_iomaph]h'Initialize a struct ttm_kmap_iter_iomap}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhjBhhubah}(h]h ]h"]h$]h&]uh1jhj@hhhj@hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjCjjCjjjuh1j2hhhjAhNhNubj)}(hX**Parameters** ``struct ttm_kmap_iter_iomap *iter_io`` The struct ttm_kmap_iter_iomap to initialize. ``struct io_mapping *iomap`` The struct io_mapping representing the underlying linear io_memory. ``struct sg_table *st`` sg_table into **iomap**, representing the memory of the struct ttm_resource. ``resource_size_t start`` Offset that needs to be subtracted from **st** to make sg_dma_address(st->sgl) - **start** == 0 for **iomap** start. **Return** Pointer to the embedded struct ttm_kmap_iter.h](h)}(h**Parameters**h]j)}(hjCh]h Parameters}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj Cubj)}(hhh](j)}(hV``struct ttm_kmap_iter_iomap *iter_io`` The struct ttm_kmap_iter_iomap to initialize. h](j)}(h'``struct ttm_kmap_iter_iomap *iter_io``h]j)}(hj1Ch]h#struct ttm_kmap_iter_iomap *iter_io}(hj3ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/Cubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj+Cubj )}(hhh]h)}(h-The struct ttm_kmap_iter_iomap to initialize.h]h-The struct ttm_kmap_iter_iomap to initialize.}(hjJChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFChMhjGCubah}(h]h ]h"]h$]h&]uh1j hj+Cubeh}(h]h ]h"]h$]h&]uh1jhjFChMhj(Cubj)}(ha``struct io_mapping *iomap`` The struct io_mapping representing the underlying linear io_memory. h](j)}(h``struct io_mapping *iomap``h]j)}(hjjCh]hstruct io_mapping *iomap}(hjlChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhCubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhjdCubj )}(hhh]h)}(hCThe struct io_mapping representing the underlying linear io_memory.h]hCThe struct io_mapping representing the underlying linear io_memory.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMhjCubah}(h]h ]h"]h$]h&]uh1j hjdCubeh}(h]h ]h"]h$]h&]uh1jhjChMhj(Cubj)}(he``struct sg_table *st`` sg_table into **iomap**, representing the memory of the struct ttm_resource. h](j)}(h``struct sg_table *st``h]j)}(hjCh]hstruct sg_table *st}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhjCubj )}(hhh]h)}(hLsg_table into **iomap**, representing the memory of the struct ttm_resource.h](hsg_table into }(hjChhhNhNubj)}(h **iomap**h]hiomap}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubh5, representing the memory of the struct ttm_resource.}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhjCubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhjChMhj(Cubj)}(h``resource_size_t start`` Offset that needs to be subtracted from **st** to make sg_dma_address(st->sgl) - **start** == 0 for **iomap** start. h](j)}(h``resource_size_t start``h]j)}(hjCh]hresource_size_t start}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhjCubj )}(hhh]h)}(htOffset that needs to be subtracted from **st** to make sg_dma_address(st->sgl) - **start** == 0 for **iomap** start.h](h(Offset that needs to be subtracted from }(hjDhhhNhNubj)}(h**st**h]hst}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubh# to make sg_dma_address(st->sgl) - }(hjDhhhNhNubj)}(h **start**h]hstart}(hj"DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubh == 0 for }(hjDhhhNhNubj)}(h **iomap**h]hiomap}(hj4DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubh start.}(hjDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhjDubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhjDhMhj(Cubeh}(h]h ]h"]h$]h&]uh1jhj Cubh)}(h **Return**h]j)}(hjaDh]hReturn}(hjcDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_Dubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj Cubh)}(h-Pointer to the embedded struct ttm_kmap_iter.h]h-Pointer to the embedded struct ttm_kmap_iter.}(hjwDhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMhj Cubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjAhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.0ttm_resource_manager_create_debugfs (C function)%c.ttm_resource_manager_create_debugfshNtauh1j!hjAhhhNhNubj3)}(hhh](j8)}(huvoid ttm_resource_manager_create_debugfs (struct ttm_resource_manager *man, struct dentry * parent, const char *name)h]j>)}(hsvoid ttm_resource_manager_create_debugfs(struct ttm_resource_manager *man, struct dentry *parent, const char *name)h](j)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjDhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:58: ./drivers/gpu/drm/ttm/ttm_resource.chMubjV)}(h h]h }(hjDhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDhhhjDhMubjg)}(h#ttm_resource_manager_create_debugfsh]jm)}(h#ttm_resource_manager_create_debugfsh]h#ttm_resource_manager_create_debugfs}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjDubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjDhhhjDhMubj)}(hK(struct ttm_resource_manager *man, struct dentry *parent, const char *name)h](j)}(h struct ttm_resource_manager *manh](jD)}(hjh]hstruct}(hjDhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjDubjV)}(h h]h }(hjDhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubh)}(hhh]jm)}(httm_resource_managerh]httm_resource_manager}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjDubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEmodnameN classnameNjj)}j]j )}jjDsb%c.ttm_resource_manager_create_debugfsasbuh1hhjDubjV)}(h h]h }(hj!EhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubj4)}(hj7h]h*}(hj/EhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjDubjm)}(hmanh]hman}(hjubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt (C struct)c.ttm_tthNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(httm_tth]j>)}(h struct ttm_tth](jD)}(hjh]hstruct}(hjGhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{GhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{GhhhjGhKubjg)}(httm_tth]jm)}(hjyGh]httm_tt}(hjGhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjGubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj{GhhhjGhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjwGhhhjGhKubah}(h]jrGah ](jjeh"]h$]h&]jj)jhuh1j7hjGhKhjtGhhubj)}(hhh]h)}(hThis is a structure holding the pages, caching- and aperture binding status for a buffer object that isn't backed by fixed (VRAM / AGP) memory.h]hThis is a structure holding the pages, caching- and aperture binding status for a buffer object that isn’t backed by fixed (VRAM / AGP) memory.}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK,hjGhhubah}(h]h ]h"]h$]h&]uh1jhjtGhhhjGhKubeh}(h]h ](jstructeh"]h$]h&]jjjjGjjGjjjuh1j2hhhjUGhNhNubj)}(hX **Definition**:: struct ttm_tt { struct page **pages; #define TTM_TT_FLAG_SWAPPED BIT(0); #define TTM_TT_FLAG_ZERO_ALLOC BIT(1); #define TTM_TT_FLAG_EXTERNAL BIT(2); #define TTM_TT_FLAG_EXTERNAL_MAPPABLE BIT(3); #define TTM_TT_FLAG_DECRYPTED BIT(4); #define TTM_TT_FLAG_BACKED_UP BIT(5); #define TTM_TT_FLAG_PRIV_POPULATED BIT(6); uint32_t page_flags; uint32_t num_pages; struct sg_table *sg; dma_addr_t *dma_address; struct file *swap_storage; struct file *backup; enum ttm_caching caching; struct ttm_pool_tt_restore *restore; }; **Members** ``pages`` Array of pages backing the data. ``page_flags`` The page flags. Supported values: TTM_TT_FLAG_SWAPPED: Set by TTM when the pages have been unpopulated and swapped out by TTM. Calling ttm_tt_populate() will then swap the pages back in, and unset the flag. Drivers should in general never need to touch this. TTM_TT_FLAG_ZERO_ALLOC: Set if the pages will be zeroed on allocation. TTM_TT_FLAG_EXTERNAL: Set if the underlying pages were allocated externally, like with dma-buf or userptr. This effectively disables TTM swapping out such pages. Also important is to prevent TTM from ever directly mapping these pages. Note that enum ttm_bo_type.ttm_bo_type_sg objects will always enable this flag. TTM_TT_FLAG_EXTERNAL_MAPPABLE: Same behaviour as TTM_TT_FLAG_EXTERNAL, but with the reduced restriction that it is still valid to use TTM to map the pages directly. This is useful when implementing a ttm_tt backend which still allocates driver owned pages underneath(say with shmem). Note that since this also implies TTM_TT_FLAG_EXTERNAL, the usage here should always be: page_flags = TTM_TT_FLAG_EXTERNAL | TTM_TT_FLAG_EXTERNAL_MAPPABLE; TTM_TT_FLAG_DECRYPTED: The mapped ttm pages should be marked as not encrypted. The framework will try to match what the dma layer is doing, but note that it is a little fragile because ttm page fault handling abuses the DMA api a bit and dma_map_attrs can't be used to assure pgprot always matches. TTM_TT_FLAG_BACKED_UP: TTM internal only. This is set if the struct ttm_tt has been (possibly partially) backed up. TTM_TT_FLAG_PRIV_POPULATED: TTM internal only. DO NOT USE. This is set by TTM after ttm_tt_populate() has successfully returned, and is then unset when TTM calls ttm_tt_unpopulate(). ``num_pages`` Number of pages in the page array. ``sg`` for SG objects via dma-buf. ``dma_address`` The DMA (bus) addresses of the pages. ``swap_storage`` Pointer to shmem struct file for swap storage. ``backup`` Pointer to backup struct for backed up tts. Could be unified with **swap_storage**. Meanwhile, the driver's ttm_tt_create() callback is responsible for assigning this field. ``caching`` The current caching state of the pages, see enum ttm_caching. ``restore`` Partial restoration from backup state. TTM privateh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubh:}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK0hjGubjT)}(hXastruct ttm_tt { struct page **pages; #define TTM_TT_FLAG_SWAPPED BIT(0); #define TTM_TT_FLAG_ZERO_ALLOC BIT(1); #define TTM_TT_FLAG_EXTERNAL BIT(2); #define TTM_TT_FLAG_EXTERNAL_MAPPABLE BIT(3); #define TTM_TT_FLAG_DECRYPTED BIT(4); #define TTM_TT_FLAG_BACKED_UP BIT(5); #define TTM_TT_FLAG_PRIV_POPULATED BIT(6); uint32_t page_flags; uint32_t num_pages; struct sg_table *sg; dma_addr_t *dma_address; struct file *swap_storage; struct file *backup; enum ttm_caching caching; struct ttm_pool_tt_restore *restore; };h]hXastruct ttm_tt { struct page **pages; #define TTM_TT_FLAG_SWAPPED BIT(0); #define TTM_TT_FLAG_ZERO_ALLOC BIT(1); #define TTM_TT_FLAG_EXTERNAL BIT(2); #define TTM_TT_FLAG_EXTERNAL_MAPPABLE BIT(3); #define TTM_TT_FLAG_DECRYPTED BIT(4); #define TTM_TT_FLAG_BACKED_UP BIT(5); #define TTM_TT_FLAG_PRIV_POPULATED BIT(6); uint32_t page_flags; uint32_t num_pages; struct sg_table *sg; dma_addr_t *dma_address; struct file *swap_storage; struct file *backup; enum ttm_caching caching; struct ttm_pool_tt_restore *restore; };}hjGsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK2hjGubh)}(h **Members**h]j)}(hjHh]hMembers}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Hubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKEhjGubj)}(hhh](j)}(h+``pages`` Array of pages backing the data. h](j)}(h ``pages``h]j)}(hj.Hh]hpages}(hj0HhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,Hubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK2hj(Hubj )}(hhh]h)}(h Array of pages backing the data.h]h Array of pages backing the data.}(hjGHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjCHhK2hjDHubah}(h]h ]h"]h$]h&]uh1j hj(Hubeh}(h]h ]h"]h$]h&]uh1jhjCHhK2hj%Hubj)}(hX``page_flags`` The page flags. Supported values: TTM_TT_FLAG_SWAPPED: Set by TTM when the pages have been unpopulated and swapped out by TTM. Calling ttm_tt_populate() will then swap the pages back in, and unset the flag. Drivers should in general never need to touch this. TTM_TT_FLAG_ZERO_ALLOC: Set if the pages will be zeroed on allocation. TTM_TT_FLAG_EXTERNAL: Set if the underlying pages were allocated externally, like with dma-buf or userptr. This effectively disables TTM swapping out such pages. Also important is to prevent TTM from ever directly mapping these pages. Note that enum ttm_bo_type.ttm_bo_type_sg objects will always enable this flag. TTM_TT_FLAG_EXTERNAL_MAPPABLE: Same behaviour as TTM_TT_FLAG_EXTERNAL, but with the reduced restriction that it is still valid to use TTM to map the pages directly. This is useful when implementing a ttm_tt backend which still allocates driver owned pages underneath(say with shmem). Note that since this also implies TTM_TT_FLAG_EXTERNAL, the usage here should always be: page_flags = TTM_TT_FLAG_EXTERNAL | TTM_TT_FLAG_EXTERNAL_MAPPABLE; TTM_TT_FLAG_DECRYPTED: The mapped ttm pages should be marked as not encrypted. The framework will try to match what the dma layer is doing, but note that it is a little fragile because ttm page fault handling abuses the DMA api a bit and dma_map_attrs can't be used to assure pgprot always matches. TTM_TT_FLAG_BACKED_UP: TTM internal only. This is set if the struct ttm_tt has been (possibly partially) backed up. TTM_TT_FLAG_PRIV_POPULATED: TTM internal only. DO NOT USE. This is set by TTM after ttm_tt_populate() has successfully returned, and is then unset when TTM calls ttm_tt_unpopulate(). h](j)}(h``page_flags``h]j)}(hjgHh]h page_flags}(hjiHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeHubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK`hjaHubj )}(hhh](h)}(hThe page flags.h]hThe page flags.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK5hj}Hubh)}(hSupported values:h]hSupported values:}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK7hj}Hubh)}(hTTM_TT_FLAG_SWAPPED: Set by TTM when the pages have been unpopulated and swapped out by TTM. Calling ttm_tt_populate() will then swap the pages back in, and unset the flag. Drivers should in general never need to touch this.h]hTTM_TT_FLAG_SWAPPED: Set by TTM when the pages have been unpopulated and swapped out by TTM. Calling ttm_tt_populate() will then swap the pages back in, and unset the flag. Drivers should in general never need to touch this.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK9hj}Hubh)}(hFTTM_TT_FLAG_ZERO_ALLOC: Set if the pages will be zeroed on allocation.h]hFTTM_TT_FLAG_ZERO_ALLOC: Set if the pages will be zeroed on allocation.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhK>hj}Hubh)}(hTTM_TT_FLAG_EXTERNAL: Set if the underlying pages were allocated externally, like with dma-buf or userptr. This effectively disables TTM swapping out such pages. Also important is to prevent TTM from ever directly mapping these pages.h]hTTM_TT_FLAG_EXTERNAL: Set if the underlying pages were allocated externally, like with dma-buf or userptr. This effectively disables TTM swapping out such pages. Also important is to prevent TTM from ever directly mapping these pages.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKAhj}Hubh)}(hONote that enum ttm_bo_type.ttm_bo_type_sg objects will always enable this flag.h]hONote that enum ttm_bo_type.ttm_bo_type_sg objects will always enable this flag.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKFhj}Hubh)}(hXTTM_TT_FLAG_EXTERNAL_MAPPABLE: Same behaviour as TTM_TT_FLAG_EXTERNAL, but with the reduced restriction that it is still valid to use TTM to map the pages directly. This is useful when implementing a ttm_tt backend which still allocates driver owned pages underneath(say with shmem).h]hXTTM_TT_FLAG_EXTERNAL_MAPPABLE: Same behaviour as TTM_TT_FLAG_EXTERNAL, but with the reduced restriction that it is still valid to use TTM to map the pages directly. This is useful when implementing a ttm_tt backend which still allocates driver owned pages underneath(say with shmem).}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKIhj}Hubh)}(hXNote that since this also implies TTM_TT_FLAG_EXTERNAL, the usage here should always be:h]hXNote that since this also implies TTM_TT_FLAG_EXTERNAL, the usage here should always be:}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKOhj}Hubj)}(hPpage_flags = TTM_TT_FLAG_EXTERNAL | TTM_TT_FLAG_EXTERNAL_MAPPABLE; h]j)}(hhh]j)}(hCpage_flags = TTM_TT_FLAG_EXTERNAL | TTM_TT_FLAG_EXTERNAL_MAPPABLE; h](j)}(h#page_flags = TTM_TT_FLAG_EXTERNAL |h]h#page_flags = TTM_TT_FLAG_EXTERNAL |}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKShjHubj )}(hhh]h)}(hTTM_TT_FLAG_EXTERNAL_MAPPABLE;h]hTTM_TT_FLAG_EXTERNAL_MAPPABLE;}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhKShjIubah}(h]h ]h"]h$]h&]uh1j hjHubeh}(h]h ]h"]h$]h&]uh1jhjIhKShjHubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKRhj}Hubh)}(hX*TTM_TT_FLAG_DECRYPTED: The mapped ttm pages should be marked as not encrypted. The framework will try to match what the dma layer is doing, but note that it is a little fragile because ttm page fault handling abuses the DMA api a bit and dma_map_attrs can't be used to assure pgprot always matches.h]hX,TTM_TT_FLAG_DECRYPTED: The mapped ttm pages should be marked as not encrypted. The framework will try to match what the dma layer is doing, but note that it is a little fragile because ttm page fault handling abuses the DMA api a bit and dma_map_attrs can’t be used to assure pgprot always matches.}(hj``restore`` Partial restoration from backup state. TTM privateh](j)}(h ``restore``h]j)}(hjJh]hrestore}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjJubj )}(hhh]h)}(h2Partial restoration from backup state. TTM privateh]h2Partial restoration from backup state. TTM private}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjJubah}(h]h ]h"]h$]h&]uh1j hjJubeh}(h]h ]h"]h$]h&]uh1jhjJhKhj%Hubeh}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_kmap_iter_tt (C struct)c.ttm_kmap_iter_tthNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(httm_kmap_iter_tth]j>)}(hstruct ttm_kmap_iter_tth](jD)}(hjh]hstruct}(hj?KhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj;KhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjMKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;KhhhjLKhKubjg)}(httm_kmap_iter_tth]jm)}(hj9Kh]httm_kmap_iter_tt}(hj_KhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[Kubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj;KhhhjLKhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj7KhhhjLKhKubah}(h]j2Kah ](jjeh"]h$]h&]jj)jhuh1j7hjLKhKhj4Khhubj)}(hhh]h)}(h-Specialization of a mappig iterator for a tt.h]h-Specialization of a mappig iterator for a tt.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj~Khhubah}(h]h ]h"]h$]h&]uh1jhj4KhhhjLKhKubeh}(h]h ](jstructeh"]h$]h&]jjjjKjjKjjjuh1j2hhhjUGhNhNubj)}(hX&**Definition**:: struct ttm_kmap_iter_tt { struct ttm_kmap_iter base; struct ttm_tt *tt; pgprot_t prot; }; **Members** ``base`` Embedded struct ttm_kmap_iter providing the usage interface ``tt`` Cached struct ttm_tt. ``prot`` Cached page protection for mapping.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubh:}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKubjT)}(hestruct ttm_kmap_iter_tt { struct ttm_kmap_iter base; struct ttm_tt *tt; pgprot_t prot; };h]hestruct ttm_kmap_iter_tt { struct ttm_kmap_iter base; struct ttm_tt *tt; pgprot_t prot; };}hjKsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKubh)}(h **Members**h]j)}(hjKh]hMembers}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKubj)}(hhh](j)}(hE``base`` Embedded struct ttm_kmap_iter providing the usage interface h](j)}(h``base``h]j)}(hjKh]hbase}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKubj )}(hhh]h)}(h;Embedded struct ttm_kmap_iter providing the usage interfaceh]h;Embedded struct ttm_kmap_iter providing the usage interface}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhKhjLubah}(h]h ]h"]h$]h&]uh1j hjKubeh}(h]h ]h"]h$]h&]uh1jhjLhKhjKubj)}(h``tt`` Cached struct ttm_tt. h](j)}(h``tt``h]j)}(hj'Lh]htt}(hj)LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%Lubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj!Lubj )}(hhh]h)}(hCached struct ttm_tt.h]hCached struct ttm_tt.}(hj@LhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)}(h/bool ttm_tt_is_swapped(const struct ttm_tt *tt)h](j)}(hj*h]hbool}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLhhhjLhKubjg)}(httm_tt_is_swappedh]jm)}(httm_tt_is_swappedh]httm_tt_is_swapped}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjLhhhjLhKubj)}(h(const struct ttm_tt *tt)h]j)}(hconst struct ttm_tt *tth](jD)}(hj h]hconst}(hjLhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjLubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubjD)}(hjh]hstruct}(hjMhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjLubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubh)}(hhh]jm)}(httm_tth]httm_tt}(hj/MhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,Mubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1MmodnameN classnameNjj)}j]j )}jjLsbc.ttm_tt_is_swappedasbuh1hhjLubjV)}(h h]h }(hjOMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubj4)}(hj7h]h*}(hj]MhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjLubjm)}(htth]htt}(hjjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjLubah}(h]h ]h"]h$]h&]jjuh1jhjLhhhjLhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjLhhhjLhKubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1j7hjLhKhjLhhubj)}(hhh]h)}(h.Whether the ttm_tt is swapped out or backed uph]h.Whether the ttm_tt is swapped out or backed up}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjMhhubah}(h]h ]h"]h$]h&]uh1jhjLhhhjLhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjMjjMjjjuh1j2hhhjUGhNhNubj)}(h|**Parameters** ``const struct ttm_tt *tt`` The struct ttm_tt. **Return** true if swapped or backed up, false otherwise.h](h)}(h**Parameters**h]j)}(hjMh]h Parameters}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjMubj)}(hhh]j)}(h/``const struct ttm_tt *tt`` The struct ttm_tt. h](j)}(h``const struct ttm_tt *tt``h]j)}(hjMh]hconst struct ttm_tt *tt}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjMubj )}(hhh]h)}(hThe struct ttm_tt.h]hThe struct ttm_tt.}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhKhjMubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjMhKhjMubah}(h]h ]h"]h$]h&]uh1jhjMubh)}(h **Return**h]j)}(hjNh]hReturn}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjMubh)}(h.true if swapped or backed up, false otherwise.h]h.true if swapped or backed up, false otherwise.}(hj&NhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjMubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. ttm_tt_is_backed_up (C function)c.ttm_tt_is_backed_uphNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h2bool ttm_tt_is_backed_up (const struct ttm_tt *tt)h]j>)}(h1bool ttm_tt_is_backed_up(const struct ttm_tt *tt)h](j)}(hj*h]hbool}(hjUNhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQNhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjcNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQNhhhjbNhKubjg)}(httm_tt_is_backed_uph]jm)}(httm_tt_is_backed_uph]httm_tt_is_backed_up}(hjuNhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqNubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjQNhhhjbNhKubj)}(h(const struct ttm_tt *tt)h]j)}(hconst struct ttm_tt *tth](jD)}(hj h]hconst}(hjNhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjNubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNubjD)}(hjh]hstruct}(hjNhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjNubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNubh)}(hhh]jm)}(httm_tth]httm_tt}(hjNhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjNmodnameN classnameNjj)}j]j )}jjwNsbc.ttm_tt_is_backed_upasbuh1hhjNubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNubj4)}(hj7h]h*}(hjNhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjNubjm)}(htth]htt}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjNubah}(h]h ]h"]h$]h&]jjuh1jhjQNhhhjbNhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjMNhhhjbNhKubah}(h]jHNah ](jjeh"]h$]h&]jj)jhuh1j7hjbNhKhjJNhhubj)}(hhh]h)}(hWhether the ttm_tt backed uph]hWhether the ttm_tt backed up}(hj/OhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj,Ohhubah}(h]h ]h"]h$]h&]uh1jhjJNhhhjbNhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjGOjjGOjjjuh1j2hhhjUGhNhNubj)}(h|**Parameters** ``const struct ttm_tt *tt`` The struct ttm_tt. **Return** true if swapped or backed up, false otherwise.h](h)}(h**Parameters**h]j)}(hjQOh]h Parameters}(hjSOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOOubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKOubj)}(hhh]j)}(h/``const struct ttm_tt *tt`` The struct ttm_tt. h](j)}(h``const struct ttm_tt *tt``h]j)}(hjpOh]hconst struct ttm_tt *tt}(hjrOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnOubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjjOubj )}(hhh]h)}(hThe struct ttm_tt.h]hThe struct ttm_tt.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhKhjOubah}(h]h ]h"]h$]h&]uh1j hjjOubeh}(h]h ]h"]h$]h&]uh1jhjOhKhjgOubah}(h]h ]h"]h$]h&]uh1jhjKOubh)}(h **Return**h]j)}(hjOh]hReturn}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKOubh)}(h.true if swapped or backed up, false otherwise.h]h.true if swapped or backed up, false otherwise.}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjKOubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#ttm_tt_clear_backed_up (C function)c.ttm_tt_clear_backed_uphNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h/void ttm_tt_clear_backed_up (struct ttm_tt *tt)h]j>)}(h.void ttm_tt_clear_backed_up(struct ttm_tt *tt)h](j)}(hvoidh]hvoid}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjOhhhjOhKubjg)}(httm_tt_clear_backed_uph]jm)}(httm_tt_clear_backed_uph]httm_tt_clear_backed_up}(hjPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj Pubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjOhhhjOhKubj)}(h(struct ttm_tt *tt)h]j)}(hstruct ttm_tt *tth](jD)}(hjh]hstruct}(hj-PhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj)PubjV)}(h h]h }(hj:PhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)Pubh)}(hhh]jm)}(httm_tth]httm_tt}(hjKPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHPubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjMPmodnameN classnameNjj)}j]j )}jjPsbc.ttm_tt_clear_backed_upasbuh1hhj)PubjV)}(h h]h }(hjkPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)Pubj4)}(hj7h]h*}(hjyPhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj)Pubjm)}(htth]htt}(hjPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)Pubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%Pubah}(h]h ]h"]h$]h&]jjuh1jhjOhhhjOhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjOhhhjOhKubah}(h]jOah ](jjeh"]h$]h&]jj)jhuh1j7hjOhKhjOhhubj)}(hhh]h)}(h!Clear the ttm_tt backed-up statush]h!Clear the ttm_tt backed-up status}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjPhhubah}(h]h ]h"]h$]h&]uh1jhjOhhhjOhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjPjjPjjjuh1j2hhhjUGhNhNubj)}(h**Parameters** ``struct ttm_tt *tt`` The struct ttm_tt. **Description** Drivers can use this functionto clear the backed-up status, for example before destroying or re-validating a purged tt.h](h)}(h**Parameters**h]j)}(hjPh]h Parameters}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjPubj)}(hhh]j)}(h)``struct ttm_tt *tt`` The struct ttm_tt. h](j)}(h``struct ttm_tt *tt``h]j)}(hjPh]hstruct ttm_tt *tt}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjPubj )}(hhh]h)}(hThe struct ttm_tt.h]hThe struct ttm_tt.}(hj QhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhKhjQubah}(h]h ]h"]h$]h&]uh1j hjPubeh}(h]h ]h"]h$]h&]uh1jhjQhKhjPubah}(h]h ]h"]h$]h&]uh1jhjPubh)}(h**Description**h]j)}(hj,Qh]h Description}(hj.QhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*Qubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjPubh)}(hwDrivers can use this functionto clear the backed-up status, for example before destroying or re-validating a purged tt.h]hwDrivers can use this functionto clear the backed-up status, for example before destroying or re-validating a purged tt.}(hjBQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_create (C function)c.ttm_tt_createhNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(hAint ttm_tt_create (struct ttm_buffer_object *bo, bool zero_alloc)h]j>)}(h@int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)h](j)}(hinth]hint}(hjqQhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmQhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmQhhhjQhKubjg)}(h ttm_tt_createh]jm)}(h ttm_tt_createh]h ttm_tt_create}(hjQhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjmQhhhjQhKubj)}(h/(struct ttm_buffer_object *bo, bool zero_alloc)h](j)}(hstruct ttm_buffer_object *boh](jD)}(hjh]hstruct}(hjQhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjQubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQubh)}(hhh]jm)}(httm_buffer_objecth]httm_buffer_object}(hjQhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjQmodnameN classnameNjj)}j]j )}jjQsbc.ttm_tt_createasbuh1hhjQubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQubj4)}(hj7h]h*}(hjQhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjQubjm)}(hboh]hbo}(hjRhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjQubj)}(hbool zero_alloch](j)}(hj*h]hbool}(hj RhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubjV)}(h h]h }(hj-RhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubjm)}(h zero_alloch]h zero_alloc}(hj;RhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjQubeh}(h]h ]h"]h$]h&]jjuh1jhjmQhhhjQhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjiQhhhjQhKubah}(h]jdQah ](jjeh"]h$]h&]jj)jhuh1j7hjQhKhjfQhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjfQhhhjQhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjnRjjnRjjjuh1j2hhhjUGhNhNubj)}(hX **Parameters** ``struct ttm_buffer_object *bo`` pointer to a struct ttm_buffer_object ``bool zero_alloc`` true if allocated pages needs to be zeroed **Description** Make sure we have a TTM structure allocated for the given BO. No pages are actually allocated.h](h)}(h**Parameters**h]j)}(hjxRh]h Parameters}(hjzRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvRubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjrRubj)}(hhh](j)}(hG``struct ttm_buffer_object *bo`` pointer to a struct ttm_buffer_object h](j)}(h ``struct ttm_buffer_object *bo``h]j)}(hjRh]hstruct ttm_buffer_object *bo}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjRubj )}(hhh]h)}(h%pointer to a struct ttm_buffer_objecth]h%pointer to a struct ttm_buffer_object}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhKhjRubah}(h]h ]h"]h$]h&]uh1j hjRubeh}(h]h ]h"]h$]h&]uh1jhjRhKhjRubj)}(h?``bool zero_alloc`` true if allocated pages needs to be zeroed h](j)}(h``bool zero_alloc``h]j)}(hjRh]hbool zero_alloc}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjRubj )}(hhh]h)}(h*true if allocated pages needs to be zeroedh]h*true if allocated pages needs to be zeroed}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhKhjRubah}(h]h ]h"]h$]h&]uh1j hjRubeh}(h]h ]h"]h$]h&]uh1jhjRhKhjRubeh}(h]h ]h"]h$]h&]uh1jhjrRubh)}(h**Description**h]j)}(hj Sh]h Description}(hj ShhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Subah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjrRubh)}(h^Make sure we have a TTM structure allocated for the given BO. No pages are actually allocated.h]h^Make sure we have a TTM structure allocated for the given BO. No pages are actually allocated.}(hj!ShhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjrRubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_init (C function) c.ttm_tt_inithNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(hint ttm_tt_init (struct ttm_tt *ttm, struct ttm_buffer_object *bo, uint32_t page_flags, enum ttm_caching caching, unsigned long extra_pages)h]j>)}(hint ttm_tt_init(struct ttm_tt *ttm, struct ttm_buffer_object *bo, uint32_t page_flags, enum ttm_caching caching, unsigned long extra_pages)h](j)}(hinth]hint}(hjPShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLShhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hj_ShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLShhhj^ShKubjg)}(h ttm_tt_inith]jm)}(h ttm_tt_inith]h ttm_tt_init}(hjqShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmSubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjLShhhj^ShKubj)}(h|(struct ttm_tt *ttm, struct ttm_buffer_object *bo, uint32_t page_flags, enum ttm_caching caching, unsigned long extra_pages)h](j)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hjShhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjSubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjSubh)}(hhh]jm)}(httm_tth]httm_tt}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjSmodnameN classnameNjj)}j]j )}jjsSsb c.ttm_tt_initasbuh1hhjSubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjSubj4)}(hj7h]h*}(hjShhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjSubjm)}(httmh]httm}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(hstruct ttm_buffer_object *boh](jD)}(hjh]hstruct}(hjShhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjSubjV)}(h h]h }(hj ThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjSubh)}(hhh]jm)}(httm_buffer_objecth]httm_buffer_object}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjTmodnameN classnameNjj)}j]jS c.ttm_tt_initasbuh1hhjSubjV)}(h h]h }(hj;ThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjSubj4)}(hj7h]h*}(hjIThhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjSubjm)}(hboh]hbo}(hjVThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(huint32_t page_flagsh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjrThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtTmodnameN classnameNjj)}j]jS c.ttm_tt_initasbuh1hhjkTubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkTubjm)}(h page_flagsh]h page_flags}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(henum ttm_caching cachingh](jD)}(hjGh]henum}(hjThhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjTubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubh)}(hhh]jm)}(h ttm_cachingh]h ttm_caching}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjTmodnameN classnameNjj)}j]jS c.ttm_tt_initasbuh1hhjTubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubjm)}(hcachingh]hcaching}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubj)}(hunsigned long extra_pagesh](j)}(hunsignedh]hunsigned}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubjV)}(h h]h }(hj(UhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUubj)}(hlongh]hlong}(hj6UhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubjV)}(h h]h }(hjDUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUubjm)}(h extra_pagesh]h extra_pages}(hjRUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjSubeh}(h]h ]h"]h$]h&]jjuh1jhjLShhhj^ShKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjHShhhj^ShKubah}(h]jCSah ](jjeh"]h$]h&]jj)jhuh1j7hj^ShKhjEShhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjEShhhj^ShKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjUjjUjjjuh1j2hhhjUGhNhNubj)}(hX**Parameters** ``struct ttm_tt *ttm`` The struct ttm_tt. ``struct ttm_buffer_object *bo`` The buffer object we create the ttm for. ``uint32_t page_flags`` Page flags as identified by TTM_TT_FLAG_XX flags. ``enum ttm_caching caching`` the desired caching state of the pages ``unsigned long extra_pages`` Extra pages needed for the driver. **Description** Create a struct ttm_tt to back data with system memory pages. No pages are actually allocated. **Return** NULL: Out of memory.h](h)}(h**Parameters**h]j)}(hjUh]h Parameters}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubj)}(hhh](j)}(h*``struct ttm_tt *ttm`` The struct ttm_tt. h](j)}(h``struct ttm_tt *ttm``h]j)}(hjUh]hstruct ttm_tt *ttm}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubj )}(hhh]h)}(hThe struct ttm_tt.h]hThe struct ttm_tt.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhKhjUubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhKhjUubj)}(hJ``struct ttm_buffer_object *bo`` The buffer object we create the ttm for. h](j)}(h ``struct ttm_buffer_object *bo``h]j)}(hjUh]hstruct ttm_buffer_object *bo}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubj )}(hhh]h)}(h(The buffer object we create the ttm for.h]h(The buffer object we create the ttm for.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhKhjUubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhKhjUubj)}(hJ``uint32_t page_flags`` Page flags as identified by TTM_TT_FLAG_XX flags. h](j)}(h``uint32_t page_flags``h]j)}(hj Vh]huint32_t page_flags}(hj"VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjVubj )}(hhh]h)}(h1Page flags as identified by TTM_TT_FLAG_XX flags.h]h1Page flags as identified by TTM_TT_FLAG_XX flags.}(hj9VhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5VhKhj6Vubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhj5VhKhjUubj)}(hD``enum ttm_caching caching`` the desired caching state of the pages h](j)}(h``enum ttm_caching caching``h]j)}(hjYVh]henum ttm_caching caching}(hj[VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWVubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjSVubj )}(hhh]h)}(h&the desired caching state of the pagesh]h&the desired caching state of the pages}(hjrVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnVhKhjoVubah}(h]h ]h"]h$]h&]uh1j hjSVubeh}(h]h ]h"]h$]h&]uh1jhjnVhKhjUubj)}(hA``unsigned long extra_pages`` Extra pages needed for the driver. h](j)}(h``unsigned long extra_pages``h]j)}(hjVh]hunsigned long extra_pages}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjVubj )}(hhh]h)}(h"Extra pages needed for the driver.h]h"Extra pages needed for the driver.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhKhjVubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhKhjUubeh}(h]h ]h"]h$]h&]uh1jhjUubh)}(h**Description**h]j)}(hjVh]h Description}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubh)}(h^Create a struct ttm_tt to back data with system memory pages. No pages are actually allocated.h]h^Create a struct ttm_tt to back data with system memory pages. No pages are actually allocated.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubh)}(h **Return**h]j)}(hjVh]hReturn}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubh)}(hNULL: Out of memory.h]hNULL: Out of memory.}(hj WhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjUubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_fini (C function) c.ttm_tt_finihNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h%void ttm_tt_fini (struct ttm_tt *ttm)h]j>)}(h$void ttm_tt_fini(struct ttm_tt *ttm)h](j)}(hvoidh]hvoid}(hj9WhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj5WhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjHWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5WhhhjGWhKubjg)}(h ttm_tt_finih]jm)}(h ttm_tt_finih]h ttm_tt_fini}(hjZWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVWubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj5WhhhjGWhKubj)}(h(struct ttm_tt *ttm)h]j)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hjvWhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjrWubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjrWubh)}(hhh]jm)}(httm_tth]httm_tt}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]j )}jj\Wsb c.ttm_tt_finiasbuh1hhjrWubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjrWubj4)}(hj7h]h*}(hjWhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjrWubjm)}(httmh]httm}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjrWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjnWubah}(h]h ]h"]h$]h&]jjuh1jhj5WhhhjGWhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj1WhhhjGWhKubah}(h]j,Wah ](jjeh"]h$]h&]jj)jhuh1j7hjGWhKhj.Whhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj.WhhhjGWhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjXjjXjjjuh1j2hhhjUGhNhNubj)}(hp**Parameters** ``struct ttm_tt *ttm`` the ttm_tt structure. **Description** Free memory of ttm_tt structureh](h)}(h**Parameters**h]j)}(hj Xh]h Parameters}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Xubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjXubj)}(hhh]j)}(h-``struct ttm_tt *ttm`` the ttm_tt structure. h](j)}(h``struct ttm_tt *ttm``h]j)}(hj+Xh]hstruct ttm_tt *ttm}(hj-XhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)Xubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj%Xubj )}(hhh]h)}(hthe ttm_tt structure.h]hthe ttm_tt structure.}(hjDXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@XhKhjAXubah}(h]h ]h"]h$]h&]uh1j hj%Xubeh}(h]h ]h"]h$]h&]uh1jhj@XhKhj"Xubah}(h]h ]h"]h$]h&]uh1jhjXubh)}(h**Description**h]j)}(hjfXh]h Description}(hjhXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdXubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjXubh)}(hFree memory of ttm_tt structureh]hFree memory of ttm_tt structure}(hj|XhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjXubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_destroy (C function)c.ttm_tt_destroyhNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(hAvoid ttm_tt_destroy (struct ttm_device *bdev, struct ttm_tt *ttm)h]j>)}(h@void ttm_tt_destroy(struct ttm_device *bdev, struct ttm_tt *ttm)h](j)}(hvoidh]hvoid}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXhhhjXhKubjg)}(httm_tt_destroyh]jm)}(httm_tt_destroyh]httm_tt_destroy}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjXhhhjXhKubj)}(h-(struct ttm_device *bdev, struct ttm_tt *ttm)h](j)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hjXhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjXubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjYmodnameN classnameNjj)}j]j )}jjXsbc.ttm_tt_destroyasbuh1hhjXubjV)}(h h]h }(hj&YhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubj4)}(hj7h]h*}(hj4YhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjXubjm)}(hbdevh]hbdev}(hjAYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hjZYhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjVYubjV)}(h h]h }(hjgYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVYubh)}(hhh]jm)}(httm_tth]httm_tt}(hjxYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjzYmodnameN classnameNjj)}j]j"Yc.ttm_tt_destroyasbuh1hhjVYubjV)}(h h]h }(hjYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVYubj4)}(hj7h]h*}(hjYhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjVYubjm)}(httmh]httm}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubeh}(h]h ]h"]h$]h&]jjuh1jhjXhhhjXhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjXhhhjXhKubah}(h]jXah ](jjeh"]h$]h&]jj)jhuh1j7hjXhKhjXhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjXhhhjXhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjYjjYjjjuh1j2hhhjUGhNhNubj)}(h**Parameters** ``struct ttm_device *bdev`` the ttm_device this object belongs to ``struct ttm_tt *ttm`` The struct ttm_tt. **Description** Unbind, unpopulate and destroy common struct ttm_tt.h](h)}(h**Parameters**h]j)}(hjYh]h Parameters}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjYubj)}(hhh](j)}(hB``struct ttm_device *bdev`` the ttm_device this object belongs to h](j)}(h``struct ttm_device *bdev``h]j)}(hj Zh]hstruct ttm_device *bdev}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Zubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjZubj )}(hhh]h)}(h%the ttm_device this object belongs toh]h%the ttm_device this object belongs to}(hj&ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"ZhKhj#Zubah}(h]h ]h"]h$]h&]uh1j hjZubeh}(h]h ]h"]h$]h&]uh1jhj"ZhKhjZubj)}(h*``struct ttm_tt *ttm`` The struct ttm_tt. h](j)}(h``struct ttm_tt *ttm``h]j)}(hjFZh]hstruct ttm_tt *ttm}(hjHZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDZubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj@Zubj )}(hhh]h)}(hThe struct ttm_tt.h]hThe struct ttm_tt.}(hj_ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[ZhKhj\Zubah}(h]h ]h"]h$]h&]uh1j hj@Zubeh}(h]h ]h"]h$]h&]uh1jhj[ZhKhjZubeh}(h]h ]h"]h$]h&]uh1jhjYubh)}(h**Description**h]j)}(hjZh]h Description}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjYubh)}(h4Unbind, unpopulate and destroy common struct ttm_tt.h]h4Unbind, unpopulate and destroy common struct ttm_tt.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_swapin (C function)c.ttm_tt_swapinhNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h&int ttm_tt_swapin (struct ttm_tt *ttm)h]j>)}(h%int ttm_tt_swapin(struct ttm_tt *ttm)h](j)}(hinth]hint}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZhhhjZhKubjg)}(h ttm_tt_swapinh]jm)}(h ttm_tt_swapinh]h ttm_tt_swapin}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjZhhhjZhKubj)}(h(struct ttm_tt *ttm)h]j)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hj[hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjZubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubh)}(hhh]jm)}(httm_tth]httm_tt}(hj![hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#[modnameN classnameNjj)}j]j )}jjZsbc.ttm_tt_swapinasbuh1hhjZubjV)}(h h]h }(hjA[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubj4)}(hj7h]h*}(hjO[hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjZubjm)}(httmh]httm}(hj\[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubah}(h]h ]h"]h$]h&]jjuh1jhjZhhhjZhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjZhhhjZhKubah}(h]jZah ](jjeh"]h$]h&]jj)jhuh1j7hjZhKhjZhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjZhhhjZhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj[jj[jjjuh1j2hhhjUGhNhNubj)}(hs**Parameters** ``struct ttm_tt *ttm`` The struct ttm_tt. **Description** Swap in a previously swap out ttm_tt.h](h)}(h**Parameters**h]j)}(hj[h]h Parameters}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj[ubj)}(hhh]j)}(h*``struct ttm_tt *ttm`` The struct ttm_tt. h](j)}(h``struct ttm_tt *ttm``h]j)}(hj[h]hstruct ttm_tt *ttm}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj[ubj )}(hhh]h)}(hThe struct ttm_tt.h]hThe struct ttm_tt.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hKhj[ubah}(h]h ]h"]h$]h&]uh1j hj[ubeh}(h]h ]h"]h$]h&]uh1jhj[hKhj[ubah}(h]h ]h"]h$]h&]uh1jhj[ubh)}(h**Description**h]j)}(hj[h]h Description}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj[ubh)}(h%Swap in a previously swap out ttm_tt.h]h%Swap in a previously swap out ttm_tt.}(hj \hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj[ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_populate (C function)c.ttm_tt_populatehNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h`int ttm_tt_populate (struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)h]j>)}(h_int ttm_tt_populate(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)h](j)}(hinth]hint}(hj8\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4\hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKubjV)}(h h]h }(hjG\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4\hhhjF\hKubjg)}(httm_tt_populateh]jm)}(httm_tt_populateh]httm_tt_populate}(hjY\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjU\ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj4\hhhjF\hKubj)}(hL(struct ttm_device *bdev, struct ttm_tt *ttm, struct ttm_operation_ctx *ctx)h](j)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hju\hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjq\ubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjq\ubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj\modnameN classnameNjj)}j]j )}jj[\sbc.ttm_tt_populateasbuh1hhjq\ubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjq\ubj4)}(hj7h]h*}(hj\hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjq\ubjm)}(hbdevh]hbdev}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjq\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjm\ubj)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hj\hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj\ubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubh)}(hhh]jm)}(httm_tth]httm_tt}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]modnameN classnameNjj)}j]j\c.ttm_tt_populateasbuh1hhj\ubjV)}(h h]h }(hj#]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubj4)}(hj7h]h*}(hj1]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj\ubjm)}(httmh]httm}(hj>]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjm\ubj)}(hstruct ttm_operation_ctx *ctxh](jD)}(hjh]hstruct}(hjW]hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjS]ubjV)}(h h]h }(hjd]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjS]ubh)}(hhh]jm)}(httm_operation_ctxh]httm_operation_ctx}(hju]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjr]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjw]modnameN classnameNjj)}j]j\c.ttm_tt_populateasbuh1hhjS]ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjS]ubj4)}(hj7h]h*}(hj]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjS]ubjm)}(hctxh]hctx}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjS]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjm\ubeh}(h]h ]h"]h$]h&]jjuh1jhj4\hhhjF\hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj0\hhhjF\hKubah}(h]j+\ah ](jjeh"]h$]h&]jj)jhuh1j7hjF\hKhj-\hhubj)}(hhh]h)}(hallocate pages for a ttmh]hallocate pages for a ttm}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj]hhubah}(h]h ]h"]h$]h&]uh1jhj-\hhhjF\hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj]jj]jjjuh1j2hhhjUGhNhNubj)}(hX(**Parameters** ``struct ttm_device *bdev`` the ttm_device this object belongs to ``struct ttm_tt *ttm`` Pointer to the ttm_tt structure ``struct ttm_operation_ctx *ctx`` operation context for populating the tt object. **Description** Calls the driver method to allocate pages for a ttmh](h)}(h**Parameters**h]j)}(hj]h]h Parameters}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj]ubj)}(hhh](j)}(hB``struct ttm_device *bdev`` the ttm_device this object belongs to h](j)}(h``struct ttm_device *bdev``h]j)}(hj^h]hstruct ttm_device *bdev}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj^ubj )}(hhh]h)}(h%the ttm_device this object belongs toh]h%the ttm_device this object belongs to}(hj2^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj.^hKhj/^ubah}(h]h ]h"]h$]h&]uh1j hj^ubeh}(h]h ]h"]h$]h&]uh1jhj.^hKhj^ubj)}(h7``struct ttm_tt *ttm`` Pointer to the ttm_tt structure h](j)}(h``struct ttm_tt *ttm``h]j)}(hjR^h]hstruct ttm_tt *ttm}(hjT^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjP^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhjL^ubj )}(hhh]h)}(hPointer to the ttm_tt structureh]hPointer to the ttm_tt structure}(hjk^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjg^hKhjh^ubah}(h]h ]h"]h$]h&]uh1j hjL^ubeh}(h]h ]h"]h$]h&]uh1jhjg^hKhj^ubj)}(hR``struct ttm_operation_ctx *ctx`` operation context for populating the tt object. h](j)}(h!``struct ttm_operation_ctx *ctx``h]j)}(hj^h]hstruct ttm_operation_ctx *ctx}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj^ubj )}(hhh]h)}(h/operation context for populating the tt object.h]h/operation context for populating the tt object.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hKhj^ubah}(h]h ]h"]h$]h&]uh1j hj^ubeh}(h]h ]h"]h$]h&]uh1jhj^hKhj^ubeh}(h]h ]h"]h$]h&]uh1jhj]ubh)}(h**Description**h]j)}(hj^h]h Description}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj]ubh)}(h3Calls the driver method to allocate pages for a ttmh]h3Calls the driver method to allocate pages for a ttm}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhKhj]ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_tt_unpopulate (C function)c.ttm_tt_unpopulatehNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(hDvoid ttm_tt_unpopulate (struct ttm_device *bdev, struct ttm_tt *ttm)h]j>)}(hCvoid ttm_tt_unpopulate(struct ttm_device *bdev, struct ttm_tt *ttm)h](j)}(hvoidh]hvoid}(hj _hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj_hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_hhhj_hMubjg)}(httm_tt_unpopulateh]jm)}(httm_tt_unpopulateh]httm_tt_unpopulate}(hj,_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(_ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj_hhhj_hMubj)}(h-(struct ttm_device *bdev, struct ttm_tt *ttm)h](j)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hjH_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjD_ubjV)}(h h]h }(hjU_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjD_ubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hjf_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjc_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjh_modnameN classnameNjj)}j]j )}jj._sbc.ttm_tt_unpopulateasbuh1hhjD_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjD_ubj4)}(hj7h]h*}(hj_hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjD_ubjm)}(hbdevh]hbdev}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjD_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj@_ubj)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubh)}(hhh]jm)}(httm_tth]httm_tt}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_modnameN classnameNjj)}j]j_c.ttm_tt_unpopulateasbuh1hhj_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubj4)}(hj7h]h*}(hj`hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj_ubjm)}(httmh]httm}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj@_ubeh}(h]h ]h"]h$]h&]jjuh1jhj_hhhj_hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj_hhhj_hMubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hj_hMhj_hhubj)}(hhh]h)}(hfree pages from a ttmh]hfree pages from a ttm}(hj;`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhj8`hhubah}(h]h ]h"]h$]h&]uh1jhj_hhhj_hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjS`jjS`jjjuh1j2hhhjUGhNhNubj)}(h**Parameters** ``struct ttm_device *bdev`` the ttm_device this object belongs to ``struct ttm_tt *ttm`` Pointer to the ttm_tt structure **Description** Calls the driver method to free all pages from a ttmh](h)}(h**Parameters**h]j)}(hj]`h]h Parameters}(hj_`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[`ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjW`ubj)}(hhh](j)}(hB``struct ttm_device *bdev`` the ttm_device this object belongs to h](j)}(h``struct ttm_device *bdev``h]j)}(hj|`h]hstruct ttm_device *bdev}(hj~`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjz`ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjv`ubj )}(hhh]h)}(h%the ttm_device this object belongs toh]h%the ttm_device this object belongs to}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hMhj`ubah}(h]h ]h"]h$]h&]uh1j hjv`ubeh}(h]h ]h"]h$]h&]uh1jhj`hMhjs`ubj)}(h7``struct ttm_tt *ttm`` Pointer to the ttm_tt structure h](j)}(h``struct ttm_tt *ttm``h]j)}(hj`h]hstruct ttm_tt *ttm}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhj`ubj )}(hhh]h)}(hPointer to the ttm_tt structureh]hPointer to the ttm_tt structure}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hMhj`ubah}(h]h ]h"]h$]h&]uh1j hj`ubeh}(h]h ]h"]h$]h&]uh1jhj`hMhjs`ubeh}(h]h ]h"]h$]h&]uh1jhjW`ubh)}(h**Description**h]j)}(hj`h]h Description}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjW`ubh)}(h4Calls the driver method to free all pages from a ttmh]h4Calls the driver method to free all pages from a ttm}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjW`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."ttm_tt_mark_for_clear (C function)c.ttm_tt_mark_for_clearhNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h/void ttm_tt_mark_for_clear (struct ttm_tt *ttm)h]j>)}(h.void ttm_tt_mark_for_clear(struct ttm_tt *ttm)h](j)}(hvoidh]hvoid}(hj5ahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ahhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM ubjV)}(h h]h }(hjDahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ahhhjCahM ubjg)}(httm_tt_mark_for_clearh]jm)}(httm_tt_mark_for_clearh]httm_tt_mark_for_clear}(hjVahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRaubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj1ahhhjCahM ubj)}(h(struct ttm_tt *ttm)h]j)}(hstruct ttm_tt *ttmh](jD)}(hjh]hstruct}(hjrahhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjnaubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnaubh)}(hhh]jm)}(httm_tth]httm_tt}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjamodnameN classnameNjj)}j]j )}jjXasbc.ttm_tt_mark_for_clearasbuh1hhjnaubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnaubj4)}(hj7h]h*}(hjahhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjnaubjm)}(httmh]httm}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjjaubah}(h]h ]h"]h$]h&]jjuh1jhj1ahhhjCahM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj-ahhhjCahM ubah}(h]j(aah ](jjeh"]h$]h&]jj)jhuh1j7hjCahM hj*ahhubj)}(hhh]h)}(h$Mark pages for clearing on populate.h]h$Mark pages for clearing on populate.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM hjahhubah}(h]h ]h"]h$]h&]uh1jhj*ahhhjCahM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj bjj bjjjuh1j2hhhjUGhNhNubj)}(h**Parameters** ``struct ttm_tt *ttm`` Pointer to the ttm_tt structure **Description** Marks pages for clearing so that the next time the page vector is populated, the pages will be cleared.h](h)}(h**Parameters**h]j)}(hjbh]h Parameters}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjbubj)}(hhh]j)}(h7``struct ttm_tt *ttm`` Pointer to the ttm_tt structure h](j)}(h``struct ttm_tt *ttm``h]j)}(hj6bh]hstruct ttm_tt *ttm}(hj8bhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4bubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM hj0bubj )}(hhh]h)}(hPointer to the ttm_tt structureh]hPointer to the ttm_tt structure}(hjObhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKbhM hjLbubah}(h]h ]h"]h$]h&]uh1j hj0bubeh}(h]h ]h"]h$]h&]uh1jhjKbhM hj-bubah}(h]h ]h"]h$]h&]uh1jhjbubh)}(h**Description**h]j)}(hjqbh]h Description}(hjsbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjobubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjbubh)}(hgMarks pages for clearing so that the next time the page vector is populated, the pages will be cleared.h]hgMarks pages for clearing so that the next time the page vector is populated, the pages will be cleared.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM hjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_backup_flags (C struct)c.ttm_backup_flagshNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(httm_backup_flagsh]j>)}(hstruct ttm_backup_flagsh](jD)}(hjh]hstruct}(hjbhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjbhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMubjV)}(h h]h }(hjbhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbhhhjbhMubjg)}(httm_backup_flagsh]jm)}(hjbh]httm_backup_flags}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjbhhhjbhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjbhhhjbhMubah}(h]jbah ](jjeh"]h$]h&]jj)jhuh1j7hjbhMhjbhhubj)}(hhh]h)}(h!Flags to govern backup behaviour.h]h!Flags to govern backup behaviour.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhjbhhubah}(h]h ]h"]h$]h&]uh1jhjbhhhjbhMubeh}(h]h ](jstructeh"]h$]h&]jjjjcjjcjjjuh1j2hhhjUGhNhNubj)}(hX%**Definition**:: struct ttm_backup_flags { u32 purge : 1; u32 writeback : 1; }; **Members** ``purge`` Free pages without backing up. Bypass pools. ``writeback`` Attempt to copy contents directly to swap space, even if that means blocking on writes to external memory.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubh:}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM!hjcubjT)}(hFstruct ttm_backup_flags { u32 purge : 1; u32 writeback : 1; };h]hFstruct ttm_backup_flags { u32 purge : 1; u32 writeback : 1; };}hj5csbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM#hjcubh)}(h **Members**h]j)}(hjFch]hMembers}(hjHchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDcubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM(hjcubj)}(hhh](j)}(h7``purge`` Free pages without backing up. Bypass pools. h](j)}(h ``purge``h]j)}(hjech]hpurge}(hjgchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjccubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhMhj_cubj )}(hhh]h)}(h,Free pages without backing up. Bypass pools.h]h,Free pages without backing up. Bypass pools.}(hj~chhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzchMhj{cubah}(h]h ]h"]h$]h&]uh1j hj_cubeh}(h]h ]h"]h$]h&]uh1jhjzchMhj\cubj)}(hx``writeback`` Attempt to copy contents directly to swap space, even if that means blocking on writes to external memory.h](j)}(h ``writeback``h]j)}(hjch]h writeback}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM hjcubj )}(hhh]h)}(hjAttempt to copy contents directly to swap space, even if that means blocking on writes to external memory.h]hjAttempt to copy contents directly to swap space, even if that means blocking on writes to external memory.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchM hjcubah}(h]h ]h"]h$]h&]uh1j hjcubeh}(h]h ]h"]h$]h&]uh1jhjchM hj\cubeh}(h]h ]h"]h$]h&]uh1jhjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_agp_tt_create (C function)c.ttm_agp_tt_createhNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(hustruct ttm_tt * ttm_agp_tt_create (struct ttm_buffer_object *bo, struct agp_bridge_data *bridge, uint32_t page_flags)h]j>)}(hsstruct ttm_tt *ttm_agp_tt_create(struct ttm_buffer_object *bo, struct agp_bridge_data *bridge, uint32_t page_flags)h](jD)}(hjh]hstruct}(hjchhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjchhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM3ubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjchhhjdhM3ubh)}(hhh]jm)}(httm_tth]httm_tt}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdmodnameN classnameNjj)}j]j )}jttm_agp_tt_createsbc.ttm_agp_tt_createasbuh1hhjchhhjdhM3ubjV)}(h h]h }(hj7dhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjchhhjdhM3ubj4)}(hj7h]h*}(hjEdhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjchhhjdhM3ubjg)}(httm_agp_tt_createh]jm)}(hj4dh]httm_agp_tt_create}(hjVdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjchhhjdhM3ubj)}(hS(struct ttm_buffer_object *bo, struct agp_bridge_data *bridge, uint32_t page_flags)h](j)}(hstruct ttm_buffer_object *boh](jD)}(hjh]hstruct}(hjqdhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjmdubjV)}(h h]h }(hj~dhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmdubh)}(hhh]jm)}(httm_buffer_objecth]httm_buffer_object}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdmodnameN classnameNjj)}j]j2dc.ttm_agp_tt_createasbuh1hhjmdubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmdubj4)}(hj7h]h*}(hjdhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjmdubjm)}(hboh]hbo}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjidubj)}(hstruct agp_bridge_data *bridgeh](jD)}(hjh]hstruct}(hjdhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjdubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubh)}(hhh]jm)}(hagp_bridge_datah]hagp_bridge_data}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjemodnameN classnameNjj)}j]j2dc.ttm_agp_tt_createasbuh1hhjdubjV)}(h h]h }(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubj4)}(hj7h]h*}(hj+ehhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjdubjm)}(hbridgeh]hbridge}(hj8ehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjidubj)}(huint32_t page_flagsh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjTehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjVemodnameN classnameNjj)}j]j2dc.ttm_agp_tt_createasbuh1hhjMeubjV)}(h h]h }(hjrehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMeubjm)}(h page_flagsh]h page_flags}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjidubeh}(h]h ]h"]h$]h&]jjuh1jhjchhhjdhM3ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjdhM3ubah}(h]jcah ](jjeh"]h$]h&]jj)jhuh1j7hjdhM3hjchhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjchhhjdhM3ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjejjejjjuh1j2hhhjUGhNhNubj)}(hX**Parameters** ``struct ttm_buffer_object *bo`` Buffer object we allocate the ttm for. ``struct agp_bridge_data *bridge`` The agp bridge this device is sitting on. ``uint32_t page_flags`` Page flags as identified by TTM_TT_FLAG_XX flags. **Description** Create a TTM backend that uses the indicated AGP bridge as an aperture for TT memory. This function uses the linux agpgart interface to bind and unbind memory backing a ttm_tt.h](h)}(h**Parameters**h]j)}(hjeh]h Parameters}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM7hjeubj)}(hhh](j)}(hH``struct ttm_buffer_object *bo`` Buffer object we allocate the ttm for. h](j)}(h ``struct ttm_buffer_object *bo``h]j)}(hjeh]hstruct ttm_buffer_object *bo}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM5hjeubj )}(hhh]h)}(h&Buffer object we allocate the ttm for.h]h&Buffer object we allocate the ttm for.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjehM5hjeubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjehM5hjeubj)}(hM``struct agp_bridge_data *bridge`` The agp bridge this device is sitting on. h](j%)}(h"``struct agp_bridge_data *bridge``h]j)}(hjfh]hstruct agp_bridge_data *bridge}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM6hjfubj )}(hhh]h)}(h)The agp bridge this device is sitting on.h]h)The agp bridge this device is sitting on.}(hj.fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*fhM6hj+fubah}(h]h ]h"]h$]h&]uh1j hjfubeh}(h]h ]h"]h$]h&]uh1jhj*fhM6hjeubj)}(hJ``uint32_t page_flags`` Page flags as identified by TTM_TT_FLAG_XX flags. h](j)}(h``uint32_t page_flags``h]j)}(hjNfh]huint32_t page_flags}(hjPfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLfubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM7hjHfubj )}(hhh]h)}(h1Page flags as identified by TTM_TT_FLAG_XX flags.h]h1Page flags as identified by TTM_TT_FLAG_XX flags.}(hjgfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjcfhM7hjdfubah}(h]h ]h"]h$]h&]uh1j hjHfubeh}(h]h ]h"]h$]h&]uh1jhjcfhM7hjeubeh}(h]h ]h"]h$]h&]uh1jhjeubh)}(h**Description**h]j)}(hjfh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM9hjeubh)}(hCreate a TTM backend that uses the indicated AGP bridge as an aperture for TT memory. This function uses the linux agpgart interface to bind and unbind memory backing a ttm_tt.h]hCreate a TTM backend that uses the indicated AGP bridge as an aperture for TT memory. This function uses the linux agpgart interface to bind and unbind memory backing a ttm_tt.}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:64: ./include/drm/ttm/ttm_tt.hhM4hjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."ttm_kmap_iter_tt_init (C function)c.ttm_kmap_iter_tt_inithNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(hbstruct ttm_kmap_iter * ttm_kmap_iter_tt_init (struct ttm_kmap_iter_tt *iter_tt, struct ttm_tt *tt)h]j>)}(h`struct ttm_kmap_iter *ttm_kmap_iter_tt_init(struct ttm_kmap_iter_tt *iter_tt, struct ttm_tt *tt)h](jD)}(hjh]hstruct}(hjfhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjfhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMubjV)}(h h]h }(hjfhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjfhhhjfhMubh)}(hhh]jm)}(h ttm_kmap_iterh]h ttm_kmap_iter}(hjfhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjfubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfmodnameN classnameNjj)}j]j )}jttm_kmap_iter_tt_initsbc.ttm_kmap_iter_tt_initasbuh1hhjfhhhjfhMubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjfhhhjfhMubj4)}(hj7h]h*}(hjghhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjfhhhjfhMubjg)}(httm_kmap_iter_tt_inith]jm)}(hj gh]httm_kmap_iter_tt_init}(hj-ghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)gubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjfhhhjfhMubj)}(h5(struct ttm_kmap_iter_tt *iter_tt, struct ttm_tt *tt)h](j)}(h struct ttm_kmap_iter_tt *iter_tth](jD)}(hjh]hstruct}(hjHghhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjDgubjV)}(h h]h }(hjUghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDgubh)}(hhh]jm)}(httm_kmap_iter_tth]httm_kmap_iter_tt}(hjfghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjcgubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjhgmodnameN classnameNjj)}j]j gc.ttm_kmap_iter_tt_initasbuh1hhjDgubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDgubj4)}(hj7h]h*}(hjghhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjDgubjm)}(hiter_tth]hiter_tt}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjDgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj@gubj)}(hstruct ttm_tt *tth](jD)}(hjh]hstruct}(hjghhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjgubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgubh)}(hhh]jm)}(httm_tth]httm_tt}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjgubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]j gc.ttm_kmap_iter_tt_initasbuh1hhjgubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgubj4)}(hj7h]h*}(hjhhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjgubjm)}(htth]htt}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj@gubeh}(h]h ]h"]h$]h&]jjuh1jhjfhhhjfhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjfhhhjfhMubah}(h]jfah ](jjeh"]h$]h&]jj)jhuh1j7hjfhMhjfhhubj)}(hhh]h)}(h$Initialize a struct ttm_kmap_iter_tth]h$Initialize a struct ttm_kmap_iter_tt}(hj9hhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhj6hhhubah}(h]h ]h"]h$]h&]uh1jhjfhhhjfhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjQhjjQhjjjuh1j2hhhjUGhNhNubj)}(h**Parameters** ``struct ttm_kmap_iter_tt *iter_tt`` The struct ttm_kmap_iter_tt to initialize. ``struct ttm_tt *tt`` Struct ttm_tt holding page pointers of the struct ttm_resource. **Return** Pointer to the embedded struct ttm_kmap_iter.h](h)}(h**Parameters**h]j)}(hj[hh]h Parameters}(hj]hhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYhubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjUhubj)}(hhh](j)}(hP``struct ttm_kmap_iter_tt *iter_tt`` The struct ttm_kmap_iter_tt to initialize. h](j)}(h$``struct ttm_kmap_iter_tt *iter_tt``h]j)}(hjzhh]h struct ttm_kmap_iter_tt *iter_tt}(hj|hhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxhubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjthubj )}(hhh]h)}(h*The struct ttm_kmap_iter_tt to initialize.h]h*The struct ttm_kmap_iter_tt to initialize.}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j hjthubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjqhubj)}(hV``struct ttm_tt *tt`` Struct ttm_tt holding page pointers of the struct ttm_resource. h](j)}(h``struct ttm_tt *tt``h]j)}(hjhh]hstruct ttm_tt *tt}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjhubj )}(hhh]h)}(h?Struct ttm_tt holding page pointers of the struct ttm_resource.h]h?Struct ttm_tt holding page pointers of the struct ttm_resource.}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjhubah}(h]h ]h"]h$]h&]uh1j hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjqhubeh}(h]h ]h"]h$]h&]uh1jhjUhubh)}(h **Return**h]j)}(hjhh]hReturn}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjUhubh)}(h-Pointer to the embedded struct ttm_kmap_iter.h]h-Pointer to the embedded struct ttm_kmap_iter.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjUhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. ttm_tt_setup_backup (C function)c.ttm_tt_setup_backuphNtauh1j!hjUGhhhNhNubj3)}(hhh](j8)}(h+int ttm_tt_setup_backup (struct ttm_tt *tt)h]j>)}(h*int ttm_tt_setup_backup(struct ttm_tt *tt)h](j)}(hinth]hint}(hj3ihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ihhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMubjV)}(h h]h }(hjBihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ihhhjAihMubjg)}(httm_tt_setup_backuph]jm)}(httm_tt_setup_backuph]httm_tt_setup_backup}(hjTihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPiubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj/ihhhjAihMubj)}(h(struct ttm_tt *tt)h]j)}(hstruct ttm_tt *tth](jD)}(hjh]hstruct}(hjpihhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjliubjV)}(h h]h }(hj}ihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjliubh)}(hhh]jm)}(httm_tth]httm_tt}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjiubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjimodnameN classnameNjj)}j]j )}jjVisbc.ttm_tt_setup_backupasbuh1hhjliubjV)}(h h]h }(hjihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjliubj4)}(hj7h]h*}(hjihhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjliubjm)}(htth]htt}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjliubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhiubah}(h]h ]h"]h$]h&]jjuh1jhj/ihhhjAihMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj+ihhhjAihMubah}(h]j&iah ](jjeh"]h$]h&]jj)jhuh1j7hjAihMhj(ihhubj)}(hhh]h)}(h3Allocate and assign a backup structure for a ttm_tth]h3Allocate and assign a backup structure for a ttm_tt}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjihhubah}(h]h ]h"]h$]h&]uh1jhj(ihhhjAihMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jjj jjjjuh1j2hhhjUGhNhNubj)}(hX=**Parameters** ``struct ttm_tt *tt`` The ttm_tt for wich to allocate and assign a backup structure. **Description** Assign a backup structure to be used for tt backup. This should typically be done at bo creation, to avoid allocations at shrinking time. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjjh]h Parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjjubj)}(hhh]j)}(hU``struct ttm_tt *tt`` The ttm_tt for wich to allocate and assign a backup structure. h](j)}(h``struct ttm_tt *tt``h]j)}(hj4jh]hstruct ttm_tt *tt}(hj6jhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2jubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhj.jubj )}(hhh]h)}(h>The ttm_tt for wich to allocate and assign a backup structure.h]h>The ttm_tt for wich to allocate and assign a backup structure.}(hjMjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIjhMhjJjubah}(h]h ]h"]h$]h&]uh1j hj.jubeh}(h]h ]h"]h$]h&]uh1jhjIjhMhj+jubah}(h]h ]h"]h$]h&]uh1jhjjubh)}(h**Description**h]j)}(hjojh]h Description}(hjqjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjjubh)}(hAssign a backup structure to be used for tt backup. This should typically be done at bo creation, to avoid allocations at shrinking time.h]hAssign a backup structure to be used for tt backup. This should typically be done at bo creation, to avoid allocations at shrinking time.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chMhjjubh)}(h **Return**h]j)}(hjjh]hReturn}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chM!hjjubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:67: ./drivers/gpu/drm/ttm/ttm_tt.chM"hjjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjUGhhhNhNubeh}(h]ttm-tt-object-referenceah ]h"]ttm tt object referenceah$]h&]uh1hhhhhhhhK>ubh)}(hhh](h)}(hTTM page pool referenceh]hTTM page pool reference}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjhhhhhKGubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_pool_type (C struct)c.ttm_pool_typehNtauh1j!hjjhhhNhNubj3)}(hhh](j8)}(h ttm_pool_typeh]j>)}(hstruct ttm_pool_typeh](jD)}(hjh]hstruct}(hjjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKubjV)}(h h]h }(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjhhhjkhKubjg)}(h ttm_pool_typeh]jm)}(hjjh]h ttm_pool_type}(hjkhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjjhhhjkhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjjhhhjkhKubah}(h]jjah ](jjeh"]h$]h&]jj)jhuh1j7hjkhKhjjhhubj)}(hhh]h)}(hPool for a certain memory typeh]hPool for a certain memory type}(hj6khhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK*hj3khhubah}(h]h ]h"]h$]h&]uh1jhjjhhhjkhKubeh}(h]h ](jstructeh"]h$]h&]jjjjNkjjNkjjjuh1j2hhhjjhNhNubj)}(hX!**Definition**:: struct ttm_pool_type { struct ttm_pool *pool; unsigned int order; enum ttm_caching caching; struct list_head shrinker_list; spinlock_t lock; struct list_head pages; }; **Members** ``pool`` the pool we belong to, might be NULL for the global ones ``order`` the allocation order our pages have ``caching`` the caching type our pages have ``shrinker_list`` our place on the global shrinker list ``lock`` protection of the page list ``pages`` the list of pages in the poolh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjZkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVkubh:}(hjVkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK.hjRkubjT)}(hstruct ttm_pool_type { struct ttm_pool *pool; unsigned int order; enum ttm_caching caching; struct list_head shrinker_list; spinlock_t lock; struct list_head pages; };h]hstruct ttm_pool_type { struct ttm_pool *pool; unsigned int order; enum ttm_caching caching; struct list_head shrinker_list; spinlock_t lock; struct list_head pages; };}hjsksbah}(h]h ]h"]h$]h&]jjuh1jShU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK0hjRkubh)}(h **Members**h]j)}(hjkh]hMembers}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK9hjRkubj)}(hhh](j)}(hB``pool`` the pool we belong to, might be NULL for the global ones h](j)}(h``pool``h]j)}(hjkh]hpool}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK-hjkubj )}(hhh]h)}(h8the pool we belong to, might be NULL for the global onesh]h8the pool we belong to, might be NULL for the global ones}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhK-hjkubah}(h]h ]h"]h$]h&]uh1j hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhK-hjkubj)}(h.``order`` the allocation order our pages have h](j)}(h ``order``h]j)}(hjkh]horder}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK.hjkubj )}(hhh]h)}(h#the allocation order our pages haveh]h#the allocation order our pages have}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhK.hjkubah}(h]h ]h"]h$]h&]uh1j hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhK.hjkubj)}(h,``caching`` the caching type our pages have h](j)}(h ``caching``h]j)}(hjlh]hcaching}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK/hjlubj )}(hhh]h)}(hthe caching type our pages haveh]hthe caching type our pages have}(hj.lhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*lhK/hj+lubah}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhj*lhK/hjkubj)}(h8``shrinker_list`` our place on the global shrinker list h](j)}(h``shrinker_list``h]j)}(hjNlh]h shrinker_list}(hjPlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLlubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK0hjHlubj )}(hhh]h)}(h%our place on the global shrinker listh]h%our place on the global shrinker list}(hjglhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjclhK0hjdlubah}(h]h ]h"]h$]h&]uh1j hjHlubeh}(h]h ]h"]h$]h&]uh1jhjclhK0hjkubj)}(h%``lock`` protection of the page list h](j)}(h``lock``h]j)}(hjlh]hlock}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK1hjlubj )}(hhh]h)}(hprotection of the page listh]hprotection of the page list}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhK1hjlubah}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhK1hjkubj)}(h'``pages`` the list of pages in the poolh](j)}(h ``pages``h]j)}(hjlh]hpages}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK1hjlubj )}(hhh]h)}(hthe list of pages in the poolh]hthe list of pages in the pool}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK2hjlubah}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhK1hjkubeh}(h]h ]h"]h$]h&]uh1jhjRkubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_pool (C struct) c.ttm_poolhNtauh1j!hjjhhhNhNubj3)}(hhh](j8)}(httm_poolh]j>)}(hstruct ttm_poolh](jD)}(hjh]hstruct}(hjmhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjmhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK8ubjV)}(h h]h }(hj(mhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmhhhj'mhK8ubjg)}(httm_poolh]jm)}(hjmh]httm_pool}(hj:mhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6mubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjmhhhj'mhK8ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjmhhhj'mhK8ubah}(h]j mah ](jjeh"]h$]h&]jj)jhuh1j7hj'mhK8hjmhhubj)}(hhh]h)}(hPool for all caching and ordersh]hPool for all caching and orders}(hj\mhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhK?hjYmhhubah}(h]h ]h"]h$]h&]uh1jhjmhhhj'mhK8ubeh}(h]h ](jstructeh"]h$]h&]jjjjtmjjtmjjjuh1j2hhhjjhNhNubj)}(hX**Definition**:: struct ttm_pool { struct device *dev; int nid; unsigned int alloc_flags; struct { struct ttm_pool_type orders[NR_PAGE_ORDERS]; } caching[TTM_NUM_CACHING_TYPES]; }; **Members** ``dev`` the device we allocate pages for ``nid`` which numa node to use ``alloc_flags`` TTM_ALLOCATION_POOL_* flags ``caching`` pools for each caching/orderh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|mubh:}(hj|mhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKChjxmubjT)}(hstruct ttm_pool { struct device *dev; int nid; unsigned int alloc_flags; struct { struct ttm_pool_type orders[NR_PAGE_ORDERS]; } caching[TTM_NUM_CACHING_TYPES]; };h]hstruct ttm_pool { struct device *dev; int nid; unsigned int alloc_flags; struct { struct ttm_pool_type orders[NR_PAGE_ORDERS]; } caching[TTM_NUM_CACHING_TYPES]; };}hjmsbah}(h]h ]h"]h$]h&]jjuh1jShU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKEhjxmubh)}(h **Members**h]j)}(hjmh]hMembers}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKNhjxmubj)}(hhh](j)}(h)``dev`` the device we allocate pages for h](j)}(h``dev``h]j)}(hjmh]hdev}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKBhjmubj )}(hhh]h)}(h the device we allocate pages forh]h the device we allocate pages for}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjmhKBhjmubah}(h]h ]h"]h$]h&]uh1j hjmubeh}(h]h ]h"]h$]h&]uh1jhjmhKBhjmubj)}(h``nid`` which numa node to use h](j)}(h``nid``h]j)}(hjnh]hnid}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKChjmubj )}(hhh]h)}(hwhich numa node to useh]hwhich numa node to use}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhKChjnubah}(h]h ]h"]h$]h&]uh1j hjmubeh}(h]h ]h"]h$]h&]uh1jhjnhKChjmubj)}(h,``alloc_flags`` TTM_ALLOCATION_POOL_* flags h](j)}(h``alloc_flags``h]j)}(hj;nh]h alloc_flags}(hj=nhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9nubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKDhj5nubj )}(hhh]h)}(hTTM_ALLOCATION_POOL_* flagsh]hTTM_ALLOCATION_POOL_* flags}(hjTnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPnhKDhjQnubah}(h]h ]h"]h$]h&]uh1j hj5nubeh}(h]h ]h"]h$]h&]uh1jhjPnhKDhjmubj)}(h(``caching`` pools for each caching/orderh](j)}(h ``caching``h]j)}(hjtnh]hcaching}(hjvnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrnubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKDhjnnubj )}(hhh]h)}(hpools for each caching/orderh]hpools for each caching/order}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:73: ./include/drm/ttm/ttm_pool.hhKEhjnubah}(h]h ]h"]h$]h&]uh1j hjnnubeh}(h]h ]h"]h$]h&]uh1jhjnhKDhjmubeh}(h]h ]h"]h$]h&]uh1jhjxmubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_pool_alloc (C function)c.ttm_pool_allochNtauh1j!hjjhhhNhNubj3)}(hhh](j8)}(h\int ttm_pool_alloc (struct ttm_pool *pool, struct ttm_tt *tt, struct ttm_operation_ctx *ctx)h]j>)}(h[int ttm_pool_alloc(struct ttm_pool *pool, struct ttm_tt *tt, struct ttm_operation_ctx *ctx)h](j)}(hinth]hint}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM'ubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnhhhjnhM'ubjg)}(httm_pool_alloch]jm)}(httm_pool_alloch]httm_pool_alloc}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjnhhhjnhM'ubj)}(hI(struct ttm_pool *pool, struct ttm_tt *tt, struct ttm_operation_ctx *ctx)h](j)}(hstruct ttm_pool *poolh](jD)}(hjh]hstruct}(hj ohhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjoubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubh)}(hhh]jm)}(httm_poolh]httm_pool}(hj)ohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&oubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+omodnameN classnameNjj)}j]j )}jjnsbc.ttm_pool_allocasbuh1hhjoubjV)}(h h]h }(hjIohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubj4)}(hj7h]h*}(hjWohhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjoubjm)}(hpoolh]hpool}(hjdohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubj)}(hstruct ttm_tt *tth](jD)}(hjh]hstruct}(hj}ohhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjyoubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyoubh)}(hhh]jm)}(httm_tth]httm_tt}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjomodnameN classnameNjj)}j]jEoc.ttm_pool_allocasbuh1hhjyoubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyoubj4)}(hj7h]h*}(hjohhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjyoubjm)}(htth]htt}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubj)}(hstruct ttm_operation_ctx *ctxh](jD)}(hjh]hstruct}(hjohhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjoubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubh)}(hhh]jm)}(httm_operation_ctxh]httm_operation_ctx}(hj phhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj pmodnameN classnameNjj)}j]jEoc.ttm_pool_allocasbuh1hhjoubjV)}(h h]h }(hj)phhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubj4)}(hj7h]h*}(hj7phhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjoubjm)}(hctxh]hctx}(hjDphhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubeh}(h]h ]h"]h$]h&]jjuh1jhjnhhhjnhM'ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjnhhhjnhM'ubah}(h]jnah ](jjeh"]h$]h&]jj)jhuh1j7hjnhM'hjnhhubj)}(hhh]h)}(hFill a ttm_tt objecth]hFill a ttm_tt object}(hjnphhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM'hjkphhubah}(h]h ]h"]h$]h&]uh1jhjnhhhjnhM'ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjpjjpjjjuh1j2hhhjjhNhNubj)}(hXC**Parameters** ``struct ttm_pool *pool`` ttm_pool to use ``struct ttm_tt *tt`` ttm_tt object to fill ``struct ttm_operation_ctx *ctx`` operation context **Description** Fill the ttm_tt object with pages and also make sure to DMA map them when necessary. **Return** 0 on successe, negative error code otherwise.h](h)}(h**Parameters**h]j)}(hjph]h Parameters}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM+hjpubj)}(hhh](j)}(h*``struct ttm_pool *pool`` ttm_pool to use h](j)}(h``struct ttm_pool *pool``h]j)}(hjph]hstruct ttm_pool *pool}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM)hjpubj )}(hhh]h)}(httm_pool to useh]httm_pool to use}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphM)hjpubah}(h]h ]h"]h$]h&]uh1j hjpubeh}(h]h ]h"]h$]h&]uh1jhjphM)hjpubj)}(h,``struct ttm_tt *tt`` ttm_tt object to fill h](j)}(h``struct ttm_tt *tt``h]j)}(hjph]hstruct ttm_tt *tt}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM*hjpubj )}(hhh]h)}(httm_tt object to fillh]httm_tt object to fill}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphM*hjpubah}(h]h ]h"]h$]h&]uh1j hjpubeh}(h]h ]h"]h$]h&]uh1jhjphM*hjpubj)}(h4``struct ttm_operation_ctx *ctx`` operation context h](j)}(h!``struct ttm_operation_ctx *ctx``h]j)}(hj!qh]hstruct ttm_operation_ctx *ctx}(hj#qhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM+hjqubj )}(hhh]h)}(hoperation contexth]hoperation context}(hj:qhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6qhM+hj7qubah}(h]h ]h"]h$]h&]uh1j hjqubeh}(h]h ]h"]h$]h&]uh1jhj6qhM+hjpubeh}(h]h ]h"]h$]h&]uh1jhjpubh)}(h**Description**h]j)}(hj\qh]h Description}(hj^qhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZqubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM-hjpubh)}(hTFill the ttm_tt object with pages and also make sure to DMA map them when necessary.h]hTFill the ttm_tt object with pages and also make sure to DMA map them when necessary.}(hjrqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM,hjpubh)}(h **Return**h]j)}(hjqh]hReturn}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM/hjpubh)}(h-0 on successe, negative error code otherwise.h]h-0 on successe, negative error code otherwise.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM0hjpubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_pool_free (C function)c.ttm_pool_freehNtauh1j!hjjhhhNhNubj3)}(hhh](j8)}(h=void ttm_pool_free (struct ttm_pool *pool, struct ttm_tt *tt)h]j>)}(h)}(h`void ttm_pool_init(struct ttm_pool *pool, struct device *dev, int nid, unsigned int alloc_flags)h](j)}(hvoidh]hvoid}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjshhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM+ubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjshhhjthM+ubjg)}(h ttm_pool_inith]jm)}(h ttm_pool_inith]h ttm_pool_init}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjshhhjthM+ubj)}(hN(struct ttm_pool *pool, struct device *dev, int nid, unsigned int alloc_flags)h](j)}(hstruct ttm_pool *poolh](jD)}(hjh]hstruct}(hj/thhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj+tubjV)}(h h]h }(hj)}(h)void ttm_pool_fini(struct ttm_pool *pool)h](j)}(hvoidh]hvoid}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM[ubjV)}(h h]h }(hj#whhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwhhhj"whM[ubjg)}(h ttm_pool_finih]jm)}(h ttm_pool_finih]h ttm_pool_fini}(hj5whhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1wubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjwhhhj"whM[ubj)}(h(struct ttm_pool *pool)h]j)}(hstruct ttm_pool *poolh](jD)}(hjh]hstruct}(hjQwhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjMwubjV)}(h h]h }(hj^whhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMwubh)}(hhh]jm)}(httm_poolh]httm_pool}(hjowhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjlwubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqwmodnameN classnameNjj)}j]j )}jj7wsbc.ttm_pool_finiasbuh1hhjMwubjV)}(h h]h }(hjwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMwubj4)}(hj7h]h*}(hjwhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjMwubjm)}(hpoolh]hpool}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMwubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIwubah}(h]h ]h"]h$]h&]jjuh1jhjwhhhj"whM[ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj whhhj"whM[ubah}(h]jwah ](jjeh"]h$]h&]jj)jhuh1j7hj"whM[hj whhubj)}(hhh]h)}(hCleanup a poolh]hCleanup a pool}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM[hjwhhubah}(h]h ]h"]h$]h&]uh1jhj whhhj"whM[ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjwjjwjjjuh1j2hhhjjhNhNubj)}(h**Parameters** ``struct ttm_pool *pool`` the pool to clean up **Description** Free all pages in the pool and unregister the types from the global shrinker.h](h)}(h**Parameters**h]j)}(hjwh]h Parameters}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM_hjwubj)}(hhh]j)}(h/``struct ttm_pool *pool`` the pool to clean up h](j)}(h``struct ttm_pool *pool``h]j)}(hjxh]hstruct ttm_pool *pool}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM]hjxubj )}(hhh]h)}(hthe pool to clean uph]hthe pool to clean up}(hj.xhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*xhM]hj+xubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhj*xhM]hj xubah}(h]h ]h"]h$]h&]uh1jhjwubh)}(h**Description**h]j)}(hjPxh]h Description}(hjRxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNxubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM_hjwubh)}(hMFree all pages in the pool and unregister the types from the global shrinker.h]hMFree all pages in the pool and unregister the types from the global shrinker.}(hjfxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chM^hjwubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.ttm_pool_debugfs (C function)c.ttm_pool_debugfshNtauh1j!hjjhhhNhNubj3)}(hhh](j8)}(h@int ttm_pool_debugfs (struct ttm_pool *pool, struct seq_file *m)h]j>)}(h?int ttm_pool_debugfs(struct ttm_pool *pool, struct seq_file *m)h](j)}(hinth]hint}(hjxhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjxhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMubjV)}(h h]h }(hjxhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxhhhjxhMubjg)}(httm_pool_debugfsh]jm)}(httm_pool_debugfsh]httm_pool_debugfs}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjxhhhjxhMubj)}(h+(struct ttm_pool *pool, struct seq_file *m)h](j)}(hstruct ttm_pool *poolh](jD)}(hjh]hstruct}(hjxhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjxubjV)}(h h]h }(hjxhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubh)}(hhh]jm)}(httm_poolh]httm_pool}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjxmodnameN classnameNjj)}j]j )}jjxsbc.ttm_pool_debugfsasbuh1hhjxubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubj4)}(hj7h]h*}(hjyhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjxubjm)}(hpoolh]hpool}(hj+yhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjxubj)}(hstruct seq_file *mh](jD)}(hjh]hstruct}(hjDyhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj@yubjV)}(h h]h }(hjQyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@yubh)}(hhh]jm)}(hseq_fileh]hseq_file}(hjbyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_yubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdymodnameN classnameNjj)}j]j yc.ttm_pool_debugfsasbuh1hhj@yubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@yubj4)}(hj7h]h*}(hjyhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj@yubjm)}(hmh]hm}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@yubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjxubeh}(h]h ]h"]h$]h&]jjuh1jhjxhhhjxhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjxhhhjxhMubah}(h]jxah ](jjeh"]h$]h&]jj)jhuh1j7hjxhMhjxhhubj)}(hhh]h)}(h Debugfs dump function for a poolh]h Debugfs dump function for a pool}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMhjyhhubah}(h]h ]h"]h$]h&]uh1jhjxhhhjxhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjyjjyjjjuh1j2hhhjjhNhNubj)}(h**Parameters** ``struct ttm_pool *pool`` the pool to dump the information for ``struct seq_file *m`` seq_file to dump to **Description** Make a debugfs dump with the per pool and global information.h](h)}(h**Parameters**h]j)}(hjyh]h Parameters}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMhjyubj)}(hhh](j)}(h?``struct ttm_pool *pool`` the pool to dump the information for h](j)}(h``struct ttm_pool *pool``h]j)}(hjzh]hstruct ttm_pool *pool}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMhjzubj )}(hhh]h)}(h$the pool to dump the information forh]h$the pool to dump the information for}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjyubj)}(h+``struct seq_file *m`` seq_file to dump to h](j)}(h``struct seq_file *m``h]j)}(hj?zh]hstruct seq_file *m}(hjAzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=zubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMhj9zubj )}(hhh]h)}(hseq_file to dump toh]hseq_file to dump to}(hjXzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjTzhMhjUzubah}(h]h ]h"]h$]h&]uh1j hj9zubeh}(h]h ]h"]h$]h&]uh1jhjTzhMhjyubeh}(h]h ]h"]h$]h&]uh1jhjyubh)}(h**Description**h]j)}(hjzzh]h Description}(hj|zhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxzubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMhjyubh)}(h=Make a debugfs dump with the per pool and global information.h]h=Make a debugfs dump with the per pool and global information.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:76: ./drivers/gpu/drm/ttm/ttm_pool.chMhjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjjhhhNhNubeh}(h]ttm-page-pool-referenceah ]h"]ttm page pool referenceah$]h&]uh1hhhhhhhhKGubeh}(h]!the-translation-table-manager-ttmah ]h"]#the translation table manager (ttm)ah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h$The Graphics Execution Manager (GEM)h]h$The Graphics Execution Manager (GEM)}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhhhhhKPubh)}(hXcThe GEM design approach has resulted in a memory manager that doesn't provide full coverage of all (or even all common) use cases in its userspace or kernel API. GEM exposes a set of standard memory-related operations to userspace and a set of helper functions to drivers, and let drivers implement hardware-specific operations with their own private API.h]hXeThe GEM design approach has resulted in a memory manager that doesn’t provide full coverage of all (or even all common) use cases in its userspace or kernel API. GEM exposes a set of standard memory-related operations to userspace and a set of helper functions to drivers, and let drivers implement hardware-specific operations with their own private API.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKRhjzhhubh)}(hXpThe GEM userspace API is described in the `GEM - the Graphics Execution Manager `__ article on LWN. While slightly outdated, the document provides a good overview of the GEM API principles. Buffer allocation and read and write operations, described as part of the common GEM API, are currently implemented using driver-specific ioctls.h](h*The GEM userspace API is described in the }(hjzhhhNhNubh reference)}(hJ`GEM - the Graphics Execution Manager `__h]h$GEM - the Graphics Execution Manager}(hjzhhhNhNubah}(h]h ]h"]h$]h&]name$GEM - the Graphics Execution Managerrefurihttp://lwn.net/Articles/283798/uh1jzhjzubh article on LWN. While slightly outdated, the document provides a good overview of the GEM API principles. Buffer allocation and read and write operations, described as part of the common GEM API, are currently implemented using driver-specific ioctls.}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKYhjzhhubh)}(hX8GEM is data-agnostic. It manages abstract buffer objects without knowing what individual buffers contain. APIs that require knowledge of buffer contents or purpose, such as buffer allocation or synchronization primitives, are thus outside of the scope of GEM and must be implemented using driver-specific ioctls.h]hX8GEM is data-agnostic. It manages abstract buffer objects without knowing what individual buffers contain. APIs that require knowledge of buffer contents or purpose, such as buffer allocation or synchronization primitives, are thus outside of the scope of GEM and must be implemented using driver-specific ioctls.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK`hjzhhubh)}(h8On a fundamental level, GEM involves several operations:h]h8On a fundamental level, GEM involves several operations:}(hj {hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKfhjzhhubh bullet_list)}(hhh](h list_item)}(hMemory allocation and freeingh]h)}(hj {h]hMemory allocation and freeing}(hj"{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhj{ubah}(h]h ]h"]h$]h&]uh1j{hj{hhhhhNubj{)}(hCommand executionh]h)}(hj7{h]hCommand execution}(hj9{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKihj5{ubah}(h]h ]h"]h$]h&]uh1j{hj{hhhhhNubj{)}(h.Aperture management at command execution time h]h)}(h-Aperture management at command execution timeh]h-Aperture management at command execution time}(hjP{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKjhjL{ubah}(h]h ]h"]h$]h&]uh1j{hj{hhhhhNubeh}(h]h ]h"]h$]h&]bullet-uh1j{hhhKhhjzhhubh)}(hBuffer object allocation is relatively straightforward and largely provided by Linux's shmem layer, which provides memory to back each object.h]hBuffer object allocation is relatively straightforward and largely provided by Linux’s shmem layer, which provides memory to back each object.}(hjl{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKlhjzhhubh)}(hDevice-specific operations, such as command execution, pinning, buffer read & write, mapping, and domain ownership transfers are left to driver-specific ioctls.h]hDevice-specific operations, such as command execution, pinning, buffer read & write, mapping, and domain ownership transfers are left to driver-specific ioctls.?}(hjz{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKphjzhhubh)}(hhh](h)}(hGEM Initializationh]hGEM Initialization}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hhhhhKuubh)}(hXYDrivers that use GEM must set the DRIVER_GEM bit in the struct :c:type:`struct drm_driver ` driver_features field. The DRM core will then automatically initialize the GEM core before calling the load operation. Behind the scene, this will create a DRM Memory Manager object which provides an address space pool for object allocation.h](h?Drivers that use GEM must set the DRIVER_GEM bit in the struct }(hj{hhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hj{h]hstruct drm_driver}(hj{hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhhhKwhj{ubh driver_features field. The DRM core will then automatically initialize the GEM core before calling the load operation. Behind the scene, this will create a DRM Memory Manager object which provides an address space pool for object allocation.}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKwhj{hhubh)}(hXIn a KMS configuration, drivers need to allocate and initialize a command ring buffer following core GEM initialization if required by the hardware. UMA devices usually have what is called a "stolen" memory region, which provides space for the initial framebuffer and large, contiguous memory regions required by the device. This space is typically not managed by GEM, and must be initialized separately into its own DRM MM object.h]hXIn a KMS configuration, drivers need to allocate and initialize a command ring buffer following core GEM initialization if required by the hardware. UMA devices usually have what is called a “stolen” memory region, which provides space for the initial framebuffer and large, contiguous memory regions required by the device. This space is typically not managed by GEM, and must be initialized separately into its own DRM MM object.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK~hj{hhubeh}(h]gem-initializationah ]h"]gem initializationah$]h&]uh1hhjzhhhhhKuubh)}(hhh](h)}(hGEM Objects Creationh]hGEM Objects Creation}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hhhhhKubh)}(hkGEM splits creation of GEM objects and allocation of the memory that backs them in two distinct operations.h]hkGEM splits creation of GEM objects and allocation of the memory that backs them in two distinct operations.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj{hhubh)}(hX:GEM objects are represented by an instance of struct :c:type:`struct drm_gem_object `. Drivers usually need to extend GEM objects with private information and thus create a driver-specific GEM object structure type that embeds an instance of struct :c:type:`struct drm_gem_object `.h](h5GEM objects are represented by an instance of struct }(hj{hhhNhNubh)}(h0:c:type:`struct drm_gem_object `h]j)}(hj |h]hstruct drm_gem_object}(hj |hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhhhKhj{ubh. Drivers usually need to extend GEM objects with private information and thus create a driver-specific GEM object structure type that embeds an instance of struct }(hj{hhhNhNubh)}(h0:c:type:`struct drm_gem_object `h]j)}(hj,|h]hstruct drm_gem_object}(hj.|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj*|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhhhKhj{ubh.}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj{hhubh)}(hXMTo create a GEM object, a driver allocates memory for an instance of its specific GEM object type and initializes the embedded struct :c:type:`struct drm_gem_object ` with a call to drm_gem_object_init(). The function takes a pointer to the DRM device, a pointer to the GEM object and the buffer object size in bytes.h](hTo create a GEM object, a driver allocates memory for an instance of its specific GEM object type and initializes the embedded struct }(hjS|hhhNhNubh)}(h0:c:type:`struct drm_gem_object `h]j)}(hj]|h]hstruct drm_gem_object}(hj_|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj[|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhhhKhjS|ubh with a call to drm_gem_object_init(). The function takes a pointer to the DRM device, a pointer to the GEM object and the buffer object size in bytes.}(hjS|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj{hhubh)}(hXxGEM uses shmem to allocate anonymous pageable memory. drm_gem_object_init() will create an shmfs file of the requested size and store it into the struct :c:type:`struct drm_gem_object ` filp field. The memory is used as either main storage for the object when the graphics hardware uses system memory directly or as a backing store otherwise. Drivers can call drm_gem_huge_mnt_create() to create, mount and use a huge shmem mountpoint instead of the default one ('shm_mnt'). For builds with CONFIG_TRANSPARENT_HUGEPAGE enabled, further calls to drm_gem_object_init() will let shmem allocate huge pages when possible.h](hGEM uses shmem to allocate anonymous pageable memory. drm_gem_object_init() will create an shmfs file of the requested size and store it into the struct }(hj|hhhNhNubh)}(h0:c:type:`struct drm_gem_object `h]j)}(hj|h]hstruct drm_gem_object}(hj|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhhhKhj|ubhX filp field. The memory is used as either main storage for the object when the graphics hardware uses system memory directly or as a backing store otherwise. Drivers can call drm_gem_huge_mnt_create() to create, mount and use a huge shmem mountpoint instead of the default one (‘shm_mnt’). For builds with CONFIG_TRANSPARENT_HUGEPAGE enabled, further calls to drm_gem_object_init() will let shmem allocate huge pages when possible.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj{hhubh)}(hXDrivers are responsible for the actual physical pages allocation by calling shmem_read_mapping_page_gfp() for each page. Note that they can decide to allocate pages when initializing the GEM object, or to delay allocation until the memory is needed (for instance when a page fault occurs as a result of a userspace memory access or when the driver needs to start a DMA transfer involving the memory).h]hXDrivers are responsible for the actual physical pages allocation by calling shmem_read_mapping_page_gfp() for each page. Note that they can decide to allocate pages when initializing the GEM object, or to delay allocation until the memory is needed (for instance when a page fault occurs as a result of a userspace memory access or when the driver needs to start a DMA transfer involving the memory).}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj{hhubh)}(hXAnonymous pageable memory allocation is not always desired, for instance when the hardware requires physically contiguous system memory as is often the case in embedded devices. Drivers can create GEM objects with no shmfs backing (called private GEM objects) by initializing them with a call to drm_gem_private_object_init() instead of drm_gem_object_init(). Storage for private GEM objects must be managed by drivers.h]hXAnonymous pageable memory allocation is not always desired, for instance when the hardware requires physically contiguous system memory as is often the case in embedded devices. Drivers can create GEM objects with no shmfs backing (called private GEM objects) by initializing them with a call to drm_gem_private_object_init() instead of drm_gem_object_init(). Storage for private GEM objects must be managed by drivers.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj{hhubeh}(h]gem-objects-creationah ]h"]gem objects creationah$]h&]uh1hhjzhhhhhKubh)}(hhh](h)}(hGEM Objects Lifetimeh]hGEM Objects Lifetime}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hhhhhKubh)}(hAll GEM objects are reference-counted by the GEM core. References can be acquired and release by calling drm_gem_object_get() and drm_gem_object_put() respectively.h]hAll GEM objects are reference-counted by the GEM core. References can be acquired and release by calling drm_gem_object_get() and drm_gem_object_put() respectively.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj|hhubh)}(hXWhen the last reference to a GEM object is released the GEM core calls the :c:type:`struct drm_gem_object_funcs ` free operation. That operation is mandatory for GEM-enabled drivers and must free the GEM object and all associated resources.h](hKWhen the last reference to a GEM object is released the GEM core calls the }(hj|hhhNhNubh)}(h8:c:type:`struct drm_gem_object_funcs `h]j)}(hj}h]hstruct drm_gem_object_funcs}(hj}hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMgem_object_funcsuh1hhhhKhj|ubh free operation. That operation is mandatory for GEM-enabled drivers and must free the GEM object and all associated resources.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhKhj|hhubh)}(hvoid (\*free) (struct drm_gem_object \*obj); Drivers are responsible for freeing all GEM object resources. This includes the resources created by the GEM core, which need to be released with drm_gem_object_release().h]hvoid (*free) (struct drm_gem_object *obj); Drivers are responsible for freeing all GEM object resources. This includes the resources created by the GEM core, which need to be released with drm_gem_object_release().}(hj)}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj|hhubeh}(h]gem-objects-lifetimeah ]h"]gem objects lifetimeah$]h&]uh1hhjzhhhhhKubh)}(hhh](h)}(hGEM Objects Namingh]hGEM Objects Naming}(hjB}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?}hhhhhKubh)}(hCommunication between userspace and the kernel refers to GEM objects using local handles, global names or, more recently, file descriptors. All of those are 32-bit integer values; the usual Linux kernel limits apply to the file descriptors.h]hCommunication between userspace and the kernel refers to GEM objects using local handles, global names or, more recently, file descriptors. All of those are 32-bit integer values; the usual Linux kernel limits apply to the file descriptors.}(hjP}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj?}hhubh)}(hX0GEM handles are local to a DRM file. Applications get a handle to a GEM object through a driver-specific ioctl, and can use that handle to refer to the GEM object in other standard or driver-specific ioctls. Closing a DRM file handle frees all its GEM handles and dereferences the associated GEM objects.h]hX0GEM handles are local to a DRM file. Applications get a handle to a GEM object through a driver-specific ioctl, and can use that handle to refer to the GEM object in other standard or driver-specific ioctls. Closing a DRM file handle frees all its GEM handles and dereferences the associated GEM objects.}(hj^}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj?}hhubh)}(hXtTo create a handle for a GEM object drivers call drm_gem_handle_create(). The function takes a pointer to the DRM file and the GEM object and returns a locally unique handle. When the handle is no longer needed drivers delete it with a call to drm_gem_handle_delete(). Finally the GEM object associated with a handle can be retrieved by a call to drm_gem_object_lookup().h]hXtTo create a handle for a GEM object drivers call drm_gem_handle_create(). The function takes a pointer to the DRM file and the GEM object and returns a locally unique handle. When the handle is no longer needed drivers delete it with a call to drm_gem_handle_delete(). Finally the GEM object associated with a handle can be retrieved by a call to drm_gem_object_lookup().}(hjl}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj?}hhubh)}(hX;Handles don't take ownership of GEM objects, they only take a reference to the object that will be dropped when the handle is destroyed. To avoid leaking GEM objects, drivers must make sure they drop the reference(s) they own (such as the initial reference taken at object creation time) as appropriate, without any special consideration for the handle. For example, in the particular case of combined GEM object and handle creation in the implementation of the dumb_create operation, drivers must drop the initial reference to the GEM object before returning the handle.h]hX=Handles don’t take ownership of GEM objects, they only take a reference to the object that will be dropped when the handle is destroyed. To avoid leaking GEM objects, drivers must make sure they drop the reference(s) they own (such as the initial reference taken at object creation time) as appropriate, without any special consideration for the handle. For example, in the particular case of combined GEM object and handle creation in the implementation of the dumb_create operation, drivers must drop the initial reference to the GEM object before returning the handle.}(hjz}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj?}hhubh)}(hXGEM names are similar in purpose to handles but are not local to DRM files. They can be passed between processes to reference a GEM object globally. Names can't be used directly to refer to objects in the DRM API, applications must convert handles to names and names to handles using the DRM_IOCTL_GEM_FLINK and DRM_IOCTL_GEM_OPEN ioctls respectively. The conversion is handled by the DRM core without any driver-specific support.h]hXGEM names are similar in purpose to handles but are not local to DRM files. They can be passed between processes to reference a GEM object globally. Names can’t be used directly to refer to objects in the DRM API, applications must convert handles to names and names to handles using the DRM_IOCTL_GEM_FLINK and DRM_IOCTL_GEM_OPEN ioctls respectively. The conversion is handled by the DRM core without any driver-specific support.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj?}hhubh)}(hXGEM also supports buffer sharing with dma-buf file descriptors through PRIME. GEM-based drivers must use the provided helpers functions to implement the exporting and importing correctly. See ?. Since sharing file descriptors is inherently more secure than the easily guessable and global GEM names it is the preferred buffer sharing mechanism. Sharing buffers through GEM names is only supported for legacy userspace. Furthermore PRIME also allows cross-device buffer sharing since it is based on dma-bufs.h]hXGEM also supports buffer sharing with dma-buf file descriptors through PRIME. GEM-based drivers must use the provided helpers functions to implement the exporting and importing correctly. See ?. Since sharing file descriptors is inherently more secure than the easily guessable and global GEM names it is the preferred buffer sharing mechanism. Sharing buffers through GEM names is only supported for legacy userspace. Furthermore PRIME also allows cross-device buffer sharing since it is based on dma-bufs.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj?}hhubeh}(h]gem-objects-namingah ]h"]gem objects namingah$]h&]uh1hhjzhhhhhKubh)}(hhh](h)}(hGEM Objects Mappingh]hGEM Objects Mapping}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}hhhhhKubh)}(hXDBecause mapping operations are fairly heavyweight GEM favours read/write-like access to buffers, implemented through driver-specific ioctls, over mapping buffers to userspace. However, when random access to the buffer is needed (to perform software rendering for instance), direct access to the object can be more efficient.h]hXDBecause mapping operations are fairly heavyweight GEM favours read/write-like access to buffers, implemented through driver-specific ioctls, over mapping buffers to userspace. However, when random access to the buffer is needed (to perform software rendering for instance), direct access to the object can be more efficient.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj}hhubh)}(hXThe mmap system call can't be used directly to map GEM objects, as they don't have their own file handle. Two alternative methods currently co-exist to map GEM objects to userspace. The first method uses a driver-specific ioctl to perform the mapping operation, calling do_mmap() under the hood. This is often considered dubious, seems to be discouraged for new GEM-enabled drivers, and will thus not be described here.h]hXThe mmap system call can’t be used directly to map GEM objects, as they don’t have their own file handle. Two alternative methods currently co-exist to map GEM objects to userspace. The first method uses a driver-specific ioctl to perform the mapping operation, calling do_mmap() under the hood. This is often considered dubious, seems to be discouraged for new GEM-enabled drivers, and will thus not be described here.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj}hhubh)}(hXThe second method uses the mmap system call on the DRM file handle. void \*mmap(void \*addr, size_t length, int prot, int flags, int fd, off_t offset); DRM identifies the GEM object to be mapped by a fake offset passed through the mmap offset argument. Prior to being mapped, a GEM object must thus be associated with a fake offset. To do so, drivers must call drm_gem_create_mmap_offset() on the object.h]hXThe second method uses the mmap system call on the DRM file handle. void *mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offset); DRM identifies the GEM object to be mapped by a fake offset passed through the mmap offset argument. Prior to being mapped, a GEM object must thus be associated with a fake offset. To do so, drivers must call drm_gem_create_mmap_offset() on the object.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj}hhubh)}(hOnce allocated, the fake offset value must be passed to the application in a driver-specific way and can then be used as the mmap offset argument.h]hOnce allocated, the fake offset value must be passed to the application in a driver-specific way and can then be used as the mmap offset argument.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM hj}hhubh)}(hXThe GEM core provides a helper method drm_gem_mmap() to handle object mapping. The method can be set directly as the mmap file operation handler. It will look up the GEM object based on the offset value and set the VMA operations to the :c:type:`struct drm_driver ` gem_vm_ops field. Note that drm_gem_mmap() doesn't map memory to userspace, but relies on the driver-provided fault handler to map pages individually.h](hThe GEM core provides a helper method drm_gem_mmap() to handle object mapping. The method can be set directly as the mmap file operation handler. It will look up the GEM object based on the offset value and set the VMA operations to the }(hj}hhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hj}h]hstruct drm_driver}(hj~hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhhhMhj}ubh gem_vm_ops field. Note that drm_gem_mmap() doesn’t map memory to userspace, but relies on the driver-provided fault handler to map pages individually.}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhj}hhubh)}(hTo use drm_gem_mmap(), drivers must fill the struct :c:type:`struct drm_driver ` gem_vm_ops field with a pointer to VM operations.h](h4To use drm_gem_mmap(), drivers must fill the struct }(hj&~hhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hj0~h]hstruct drm_driver}(hj2~hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj.~ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhhhMhj&~ubh2 gem_vm_ops field with a pointer to VM operations.}(hj&~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhj}hhubh)}(hThe VM operations is a :c:type:`struct vm_operations_struct ` made up of several fields, the more interesting ones being:h](hThe VM operations is a }(hjW~hhhNhNubh)}(h<:c:type:`struct vm_operations_struct `h]j)}(hja~h]hstruct vm_operations_struct}(hjc~hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj_~ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMvm_operations_structuh1hhhhMhjW~ubh< made up of several fields, the more interesting ones being:}(hjW~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMhj}hhubjT)}(hstruct vm_operations_struct { void (*open)(struct vm_area_struct * area); void (*close)(struct vm_area_struct * area); vm_fault_t (*fault)(struct vm_fault *vmf); };h]hstruct vm_operations_struct { void (*open)(struct vm_area_struct * area); void (*close)(struct vm_area_struct * area); vm_fault_t (*fault)(struct vm_fault *vmf); };}hj~sbah}(h]h ]h"]h$]h&]jjforcelanguagejhighlight_args}uh1jShhhMhj}hhubh)}(hThe open and close operations must update the GEM object reference count. Drivers can use the drm_gem_vm_open() and drm_gem_vm_close() helper functions directly as open and close handlers.h]hThe open and close operations must update the GEM object reference count. Drivers can use the drm_gem_vm_open() and drm_gem_vm_close() helper functions directly as open and close handlers.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM&hj}hhubh)}(hXThe fault operation handler is responsible for mapping pages to userspace when a page fault occurs. Depending on the memory allocation scheme, drivers can allocate pages at fault time, or can decide to allocate memory for the GEM object at the time the object is created.h]hXThe fault operation handler is responsible for mapping pages to userspace when a page fault occurs. Depending on the memory allocation scheme, drivers can allocate pages at fault time, or can decide to allocate memory for the GEM object at the time the object is created.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM*hj}hhubh)}(hDrivers that want to map the GEM object upfront instead of handling page faults can implement their own mmap file operation handler.h]hDrivers that want to map the GEM object upfront instead of handling page faults can implement their own mmap file operation handler.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM/hj}hhubh)}(hX3In order to reduce page table overhead, if the internal shmem mountpoint "shm_mnt" is configured to use transparent huge pages (for builds with CONFIG_TRANSPARENT_HUGEPAGE enabled) and if the shmem backing store managed to allocate a huge page for a faulty address, the fault handler will first attempt to insert that huge page into the VMA before falling back to individual page insertion. mmap() user address alignment for GEM objects is handled by providing a custom get_unmapped_area file operation which forwards to the shmem backing store. For most drivers, which don't create a huge mountpoint by default or through a module parameter, transparent huge pages can be enabled by either setting the "transparent_hugepage_shmem" kernel parameter or the "/sys/kernel/mm/transparent_hugepage/shmem_enabled" sysfs knob.h]hXAIn order to reduce page table overhead, if the internal shmem mountpoint “shm_mnt” is configured to use transparent huge pages (for builds with CONFIG_TRANSPARENT_HUGEPAGE enabled) and if the shmem backing store managed to allocate a huge page for a faulty address, the fault handler will first attempt to insert that huge page into the VMA before falling back to individual page insertion. mmap() user address alignment for GEM objects is handled by providing a custom get_unmapped_area file operation which forwards to the shmem backing store. For most drivers, which don’t create a huge mountpoint by default or through a module parameter, transparent huge pages can be enabled by either setting the “transparent_hugepage_shmem” kernel parameter or the “/sys/kernel/mm/transparent_hugepage/shmem_enabled” sysfs knob.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM2hj}hhubh)}(hFor platforms without MMU the GEM core provides a helper method drm_gem_dma_get_unmapped_area(). The mmap() routines will call this to get a proposed address for the mapping.h]hFor platforms without MMU the GEM core provides a helper method drm_gem_dma_get_unmapped_area(). The mmap() routines will call this to get a proposed address for the mapping.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM?hj}hhubh)}(hTo use drm_gem_dma_get_unmapped_area(), drivers must fill the struct :c:type:`struct file_operations ` get_unmapped_area field with a pointer on drm_gem_dma_get_unmapped_area().h](hETo use drm_gem_dma_get_unmapped_area(), drivers must fill the struct }(hj~hhhNhNubh)}(h2:c:type:`struct file_operations `h]j)}(hj~h]hstruct file_operations}(hj~hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfile_operationsuh1hhhhMChj~ubhK get_unmapped_area field with a pointer on drm_gem_dma_get_unmapped_area().}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhMChj}hhubh)}(hmMore detailed information about get_unmapped_area can be found in Documentation/admin-guide/mm/nommu-mmap.rsth]hmMore detailed information about get_unmapped_area can be found in Documentation/admin-guide/mm/nommu-mmap.rst}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMGhj}hhubeh}(h]gem-objects-mappingah ]h"]gem objects mappingah$]h&]uh1hhjzhhhhhKubh)}(hhh](h)}(hMemory Coherencyh]hMemory Coherency}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hhhhhMKubh)}(hX2When mapped to the device or used in a command buffer, backing pages for an object are flushed to memory and marked write combined so as to be coherent with the GPU. Likewise, if the CPU accesses an object after the GPU has finished rendering to the object, then the object must be made coherent with the CPU's view of memory, usually involving GPU cache flushing of various kinds. This core CPU<->GPU coherency management is provided by a device-specific ioctl, which evaluates an object's current domain and performs any necessary flushing or synchronization to put the object into the desired coherency domain (note that the object may be busy, i.e. an active render target; in that case, setting the domain blocks the client and waits for rendering to complete before performing any necessary flushing operations).h]hX6When mapped to the device or used in a command buffer, backing pages for an object are flushed to memory and marked write combined so as to be coherent with the GPU. Likewise, if the CPU accesses an object after the GPU has finished rendering to the object, then the object must be made coherent with the CPU’s view of memory, usually involving GPU cache flushing of various kinds. This core CPU<->GPU coherency management is provided by a device-specific ioctl, which evaluates an object’s current domain and performs any necessary flushing or synchronization to put the object into the desired coherency domain (note that the object may be busy, i.e. an active render target; in that case, setting the domain blocks the client and waits for rendering to complete before performing any necessary flushing operations).}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMMhj'hhubeh}(h]memory-coherencyah ]h"]memory coherencyah$]h&]uh1hhjzhhhhhMKubh)}(hhh](h)}(hCommand Executionh]hCommand Execution}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhhhhhM[ubh)}(hX,Perhaps the most important GEM function for GPU devices is providing a command execution interface to clients. Client programs construct command buffers containing references to previously allocated memory objects, and then submit them to GEM. At that point, GEM takes care to bind all the objects into the GTT, execute the buffer, and provide necessary synchronization between clients accessing the same buffers. This often involves evicting some objects from the GTT and re-binding others (a fairly expensive operation), and providing relocation support which hides fixed GTT offsets from clients. Clients must take care not to submit command buffers that reference more objects than can fit in the GTT; otherwise, GEM will reject them and no rendering will occur. Similarly, if several objects in the buffer require fence registers to be allocated for correct rendering (e.g. 2D blits on pre-965 chips), care must be taken not to require more fence registers than are available to the client. Such resource management should be abstracted from the client in libdrm.h]hX,Perhaps the most important GEM function for GPU devices is providing a command execution interface to clients. Client programs construct command buffers containing references to previously allocated memory objects, and then submit them to GEM. At that point, GEM takes care to bind all the objects into the GTT, execute the buffer, and provide necessary synchronization between clients accessing the same buffers. This often involves evicting some objects from the GTT and re-binding others (a fairly expensive operation), and providing relocation support which hides fixed GTT offsets from clients. Clients must take care not to submit command buffers that reference more objects than can fit in the GTT; otherwise, GEM will reject them and no rendering will occur. Similarly, if several objects in the buffer require fence registers to be allocated for correct rendering (e.g. 2D blits on pre-965 chips), care must be taken not to require more fence registers than are available to the client. Such resource management should be abstracted from the client in libdrm.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM]hjNhhubeh}(h]command-executionah ]h"]command executionah$]h&]uh1hhjzhhhhhM[ubh)}(hhh](h)}(hGEM Function Referenceh]hGEM Function Reference}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhhhhhMoubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_object_status (C enum)c.drm_gem_object_statushNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hdrm_gem_object_statush]j>)}(henum drm_gem_object_statush](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_gem_object_statush]jm)}(hjh]hdrm_gem_object_status}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h,bitmask of object state for fdinfo reportingh]h,bitmask of object state for fdinfo reporting}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK4hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jenumeh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Constants** ``DRM_GEM_OBJECT_RESIDENT`` object is resident in memory (ie. not unpinned) ``DRM_GEM_OBJECT_PURGEABLE`` object marked as purgeable by userspace ``DRM_GEM_OBJECT_ACTIVE`` object is currently used by an active submissionh](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK8hjubj)}(hhh](j)}(hL``DRM_GEM_OBJECT_RESIDENT`` object is resident in memory (ie. not unpinned) h](j)}(h``DRM_GEM_OBJECT_RESIDENT``h]j)}(hj"h]hDRM_GEM_OBJECT_RESIDENT}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK;hjubj )}(hhh]h)}(h/object is resident in memory (ie. not unpinned)h]h/object is resident in memory (ie. not unpinned)}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hK;hj8ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj7hK;hjubj)}(hE``DRM_GEM_OBJECT_PURGEABLE`` object marked as purgeable by userspace h](j)}(h``DRM_GEM_OBJECT_PURGEABLE``h]j)}(hj[h]hDRM_GEM_OBJECT_PURGEABLE}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK>hjUubj )}(hhh]h)}(h'object marked as purgeable by userspaceh]h'object marked as purgeable by userspace}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphK>hjqubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjphK>hjubj)}(hJ``DRM_GEM_OBJECT_ACTIVE`` object is currently used by an active submissionh](j)}(h``DRM_GEM_OBJECT_ACTIVE``h]j)}(hjh]hDRM_GEM_OBJECT_ACTIVE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK@hjubj )}(hhh]h)}(h0object is currently used by an active submissionh]h0object is currently used by an active submission}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKAhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK@hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubh)}(h**Description**h]j)}(hj׀h]h Description}(hjـhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjՀubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKChjuhhubh)}(hXWBitmask of status used for fdinfo memory stats, see :c:type:`drm_gem_object_funcs.status ` and drm_show_fdinfo(). Note that an object can report DRM_GEM_OBJECT_PURGEABLE and be active or not resident, in which case drm_show_fdinfo() will not account for it as purgeable. So drivers do not need to check if the buffer is idle and resident to return this bit, i.e. userspace can mark a buffer as purgeable even while it is still busy on the GPU. It will not get reported in the puregeable stats until it becomes idle. The status gem object func does not need to consider this.h](h4Bitmask of status used for fdinfo memory stats, see }(hjhhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.status `h]j)}(hjh]hdrm_gem_object_funcs.status}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK8hjubhX and drm_show_fdinfo(). Note that an object can report DRM_GEM_OBJECT_PURGEABLE and be active or not resident, in which case drm_show_fdinfo() will not account for it as purgeable. So drivers do not need to check if the buffer is idle and resident to return this bit, i.e. userspace can mark a buffer as purgeable even while it is still busy on the GPU. It will not get reported in the puregeable stats until it becomes idle. The status gem object func does not need to consider this.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhK8hjuhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_object_funcs (C struct)c.drm_gem_object_funcshNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hdrm_gem_object_funcsh]j>)}(hstruct drm_gem_object_funcsh](jD)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4hhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKDubjV)}(h h]h }(hjFhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4hhhjEhKDubjg)}(hdrm_gem_object_funcsh]jm)}(hj2h]hdrm_gem_object_funcs}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj4hhhjEhKDubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj0hhhjEhKDubah}(h]j+ah ](jjeh"]h$]h&]jj)jhuh1j7hjEhKDhj-hhubj)}(hhh]h)}(hGEM object functionsh]hGEM object functions}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKIhjwhhubah}(h]h ]h"]h$]h&]uh1jhj-hhhjEhKDubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hX**Definition**:: struct drm_gem_object_funcs { void (*free)(struct drm_gem_object *obj); int (*open)(struct drm_gem_object *obj, struct drm_file *file); void (*close)(struct drm_gem_object *obj, struct drm_file *file); void (*print_info)(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj); struct dma_buf *(*export)(struct drm_gem_object *obj, int flags); int (*pin)(struct drm_gem_object *obj); void (*unpin)(struct drm_gem_object *obj); struct sg_table *(*get_sg_table)(struct drm_gem_object *obj); int (*vmap)(struct drm_gem_object *obj, struct iosys_map *map); void (*vunmap)(struct drm_gem_object *obj, struct iosys_map *map); int (*mmap)(struct drm_gem_object *obj, struct vm_area_struct *vma); int (*evict)(struct drm_gem_object *obj); enum drm_gem_object_status (*status)(struct drm_gem_object *obj); size_t (*rss)(struct drm_gem_object *obj); const struct vm_operations_struct *vm_ops; }; **Members** ``free`` Deconstructor for drm_gem_objects. This callback is mandatory. ``open`` Called upon GEM handle creation. This callback is optional. ``close`` Called upon GEM handle release. This callback is optional. ``print_info`` If driver subclasses struct :c:type:`drm_gem_object`, it can implement this optional hook for printing additional driver specific info. drm_printf_indent() should be used in the callback passing it the indent argument. This callback is called from drm_gem_print_info(). This callback is optional. ``export`` Export backing buffer as a :c:type:`dma_buf`. If this is not set drm_gem_prime_export() is used. This callback is optional. ``pin`` Pin backing buffer in memory, such that dma-buf importers can access it. Used by the drm_gem_map_attach() helper. This callback is optional. ``unpin`` Unpin backing buffer. Used by the drm_gem_map_detach() helper. This callback is optional. ``get_sg_table`` Returns a Scatter-Gather table representation of the buffer. Used when exporting a buffer by the drm_gem_map_dma_buf() helper. Releasing is done by calling dma_unmap_sg_attrs() and sg_free_table() in drm_gem_unmap_buf(), therefore these helpers and this callback here cannot be used for sg tables pointing at driver private memory ranges. See also drm_prime_pages_to_sg(). ``vmap`` Returns a virtual address for the buffer. Used by the drm_gem_dmabuf_vmap() helper. Called with a held GEM reservation lock. This callback is optional. ``vunmap`` Releases the address previously returned by **vmap**. Used by the drm_gem_dmabuf_vunmap() helper. Called with a held GEM reservation lock. This callback is optional. ``mmap`` Handle mmap() of the gem object, setup vma accordingly. This callback is optional. The callback is used by both drm_gem_mmap_obj() and drm_gem_prime_mmap(). When **mmap** is present **vm_ops** is not used, the **mmap** callback must set vma->vm_ops instead. ``evict`` Evicts gem object out from memory. Used by the drm_gem_object_evict() helper. Returns 0 on success, -errno otherwise. Called with a held GEM reservation lock. This callback is optional. ``status`` The optional status callback can return additional object state which determines which stats the object is counted against. The callback is called under table_lock. Racing against object status change is "harmless", and the callback can expect to not race against object destruction. Called by drm_show_memory_stats(). ``rss`` Return resident size of the object in physical memory. Called by drm_show_memory_stats(). ``vm_ops`` Virtual memory operations used with mmap. This is optional but necessary for mmap support.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKMhjubjT)}(hXstruct drm_gem_object_funcs { void (*free)(struct drm_gem_object *obj); int (*open)(struct drm_gem_object *obj, struct drm_file *file); void (*close)(struct drm_gem_object *obj, struct drm_file *file); void (*print_info)(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj); struct dma_buf *(*export)(struct drm_gem_object *obj, int flags); int (*pin)(struct drm_gem_object *obj); void (*unpin)(struct drm_gem_object *obj); struct sg_table *(*get_sg_table)(struct drm_gem_object *obj); int (*vmap)(struct drm_gem_object *obj, struct iosys_map *map); void (*vunmap)(struct drm_gem_object *obj, struct iosys_map *map); int (*mmap)(struct drm_gem_object *obj, struct vm_area_struct *vma); int (*evict)(struct drm_gem_object *obj); enum drm_gem_object_status (*status)(struct drm_gem_object *obj); size_t (*rss)(struct drm_gem_object *obj); const struct vm_operations_struct *vm_ops; };h]hXstruct drm_gem_object_funcs { void (*free)(struct drm_gem_object *obj); int (*open)(struct drm_gem_object *obj, struct drm_file *file); void (*close)(struct drm_gem_object *obj, struct drm_file *file); void (*print_info)(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj); struct dma_buf *(*export)(struct drm_gem_object *obj, int flags); int (*pin)(struct drm_gem_object *obj); void (*unpin)(struct drm_gem_object *obj); struct sg_table *(*get_sg_table)(struct drm_gem_object *obj); int (*vmap)(struct drm_gem_object *obj, struct iosys_map *map); void (*vunmap)(struct drm_gem_object *obj, struct iosys_map *map); int (*mmap)(struct drm_gem_object *obj, struct vm_area_struct *vma); int (*evict)(struct drm_gem_object *obj); enum drm_gem_object_status (*status)(struct drm_gem_object *obj); size_t (*rss)(struct drm_gem_object *obj); const struct vm_operations_struct *vm_ops; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKOhjubh)}(h **Members**h]j)}(hjȁh]hMembers}(hjʁhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjƁubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKahjubj)}(hhh](j)}(hI``free`` Deconstructor for drm_gem_objects. This callback is mandatory. h](j)}(h``free``h]j)}(hjh]hfree}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKPhjubj )}(hhh](h)}(h"Deconstructor for drm_gem_objects.h]h"Deconstructor for drm_gem_objects.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKNhjubh)}(hThis callback is mandatory.h]hThis callback is mandatory.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKPhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKPhjށubj)}(hF``open`` Called upon GEM handle creation. This callback is optional. h](j)}(h``open``h]j)}(hj/h]hopen}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKYhj)ubj )}(hhh](h)}(h Called upon GEM handle creation.h]h Called upon GEM handle creation.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKWhjEubh)}(hThis callback is optional.h]hThis callback is optional.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhKYhjEubeh}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhKYhjށubj)}(hF``close`` Called upon GEM handle release. This callback is optional. h](j)}(h ``close``h]j)}(hjwh]hclose}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKbhjqubj )}(hhh](h)}(hCalled upon GEM handle release.h]hCalled upon GEM handle release.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK`hjubh)}(hThis callback is optional.h]hThis callback is optional.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKbhjubeh}(h]h ]h"]h$]h&]uh1j hjqubeh}(h]h ]h"]h$]h&]uh1jhjhKbhjށubj)}(hX;``print_info`` If driver subclasses struct :c:type:`drm_gem_object`, it can implement this optional hook for printing additional driver specific info. drm_printf_indent() should be used in the callback passing it the indent argument. This callback is called from drm_gem_print_info(). This callback is optional. h](j)}(h``print_info``h]j)}(hjh]h print_info}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKqhjubj )}(hhh](h)}(hIf driver subclasses struct :c:type:`drm_gem_object`, it can implement this optional hook for printing additional driver specific info.h](hIf driver subclasses struct }(hj؂hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKihj؂ubhS, it can implement this optional hook for printing additional driver specific info.}(hj؂hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKihjՂubh)}(hRdrm_printf_indent() should be used in the callback passing it the indent argument.h]hRdrm_printf_indent() should be used in the callback passing it the indent argument.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKlhjՂubh)}(h2This callback is called from drm_gem_print_info().h]h2This callback is called from drm_gem_print_info().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKohjՂubh)}(hThis callback is optional.h]hThis callback is optional.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԂhKqhjՂubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjԂhKqhjށubj)}(h``export`` Export backing buffer as a :c:type:`dma_buf`. If this is not set drm_gem_prime_export() is used. This callback is optional. h](j)}(h ``export``h]j)}(hjHh]hexport}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhK|hjBubj )}(hhh](h)}(h`Export backing buffer as a :c:type:`dma_buf`. If this is not set drm_gem_prime_export() is used.h](hExport backing buffer as a }(hjahhhNhNubh)}(h:c:type:`dma_buf`h]j)}(hjkh]hdma_buf}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_bufuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKyhjaubh4. If this is not set drm_gem_prime_export() is used.}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKyhj^ubh)}(hThis callback is optional.h]hThis callback is optional.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hK|hj^ubeh}(h]h ]h"]h$]h&]uh1j hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hK|hjށubj)}(h``pin`` Pin backing buffer in memory, such that dma-buf importers can access it. Used by the drm_gem_map_attach() helper. This callback is optional. h](j)}(h``pin``h]j)}(hjh]hpin}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh](h)}(hqPin backing buffer in memory, such that dma-buf importers can access it. Used by the drm_gem_map_attach() helper.h]hqPin backing buffer in memory, such that dma-buf importers can access it. Used by the drm_gem_map_attach() helper.}(hj̃hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjɃubh)}(hThis callback is optional.h]hThis callback is optional.}(hjۃhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjȃhKhjɃubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjȃhKhjށubj)}(he``unpin`` Unpin backing buffer. Used by the drm_gem_map_detach() helper. This callback is optional. h](j)}(h ``unpin``h]j)}(hjh]hunpin}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh](h)}(h>Unpin backing buffer. Used by the drm_gem_map_detach() helper.h]h>Unpin backing buffer. Used by the drm_gem_map_detach() helper.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubh)}(hThis callback is optional.h]hThis callback is optional.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjށubj)}(hX``get_sg_table`` Returns a Scatter-Gather table representation of the buffer. Used when exporting a buffer by the drm_gem_map_dma_buf() helper. Releasing is done by calling dma_unmap_sg_attrs() and sg_free_table() in drm_gem_unmap_buf(), therefore these helpers and this callback here cannot be used for sg tables pointing at driver private memory ranges. See also drm_prime_pages_to_sg(). h](j)}(h``get_sg_table``h]j)}(hjCh]h get_sg_table}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhj=ubj )}(hhh](h)}(hXRReturns a Scatter-Gather table representation of the buffer. Used when exporting a buffer by the drm_gem_map_dma_buf() helper. Releasing is done by calling dma_unmap_sg_attrs() and sg_free_table() in drm_gem_unmap_buf(), therefore these helpers and this callback here cannot be used for sg tables pointing at driver private memory ranges.h]hXRReturns a Scatter-Gather table representation of the buffer. Used when exporting a buffer by the drm_gem_map_dma_buf() helper. Releasing is done by calling dma_unmap_sg_attrs() and sg_free_table() in drm_gem_unmap_buf(), therefore these helpers and this callback here cannot be used for sg tables pointing at driver private memory ranges.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjYubh)}(h!See also drm_prime_pages_to_sg().h]h!See also drm_prime_pages_to_sg().}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXhKhjYubeh}(h]h ]h"]h$]h&]uh1j hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhKhjށubj)}(h``vmap`` Returns a virtual address for the buffer. Used by the drm_gem_dmabuf_vmap() helper. Called with a held GEM reservation lock. This callback is optional. h](j)}(h``vmap``h]j)}(hjh]hvmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh](h)}(h|Returns a virtual address for the buffer. Used by the drm_gem_dmabuf_vmap() helper. Called with a held GEM reservation lock.h]h|Returns a virtual address for the buffer. Used by the drm_gem_dmabuf_vmap() helper. Called with a held GEM reservation lock.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubh)}(hThis callback is optional.h]hThis callback is optional.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjށubj)}(h``vunmap`` Releases the address previously returned by **vmap**. Used by the drm_gem_dmabuf_vunmap() helper. Called with a held GEM reservation lock. This callback is optional. h](j)}(h ``vunmap``h]j)}(hjӄh]hvunmap}(hjՄhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjфubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhj̈́ubj )}(hhh](h)}(hReleases the address previously returned by **vmap**. Used by the drm_gem_dmabuf_vunmap() helper. Called with a held GEM reservation lock.h](h,Releases the address previously returned by }(hjhhhNhNubj)}(h**vmap**h]hvmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhV. Used by the drm_gem_dmabuf_vunmap() helper. Called with a held GEM reservation lock.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubh)}(hThis callback is optional.h]hThis callback is optional.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubeh}(h]h ]h"]h$]h&]uh1j hj̈́ubeh}(h]h ]h"]h$]h&]uh1jhjhKhjށubj)}(hX``mmap`` Handle mmap() of the gem object, setup vma accordingly. This callback is optional. The callback is used by both drm_gem_mmap_obj() and drm_gem_prime_mmap(). When **mmap** is present **vm_ops** is not used, the **mmap** callback must set vma->vm_ops instead. h](j)}(h``mmap``h]j)}(hj-h]hmmap}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhj'ubj )}(hhh](h)}(h7Handle mmap() of the gem object, setup vma accordingly.h]h7Handle mmap() of the gem object, setup vma accordingly.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjCubh)}(hThis callback is optional.h]hThis callback is optional.}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjCubh)}(hThe callback is used by both drm_gem_mmap_obj() and drm_gem_prime_mmap(). When **mmap** is present **vm_ops** is not used, the **mmap** callback must set vma->vm_ops instead.h](hPThe callback is used by both drm_gem_mmap_obj() and drm_gem_prime_mmap(). When }(hjdhhhNhNubj)}(h**mmap**h]hmmap}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubh is present }(hjdhhhNhNubj)}(h **vm_ops**h]hvm_ops}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubh is not used, the }(hjdhhhNhNubj)}(h**mmap**h]hmmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubh' callback must set vma->vm_ops instead.}(hjdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjCubeh}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhKhjށubj)}(h``evict`` Evicts gem object out from memory. Used by the drm_gem_object_evict() helper. Returns 0 on success, -errno otherwise. Called with a held GEM reservation lock. This callback is optional. h](j)}(h ``evict``h]j)}(hjh]hevict}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh](h)}(hEvicts gem object out from memory. Used by the drm_gem_object_evict() helper. Returns 0 on success, -errno otherwise. Called with a held GEM reservation lock.h]hEvicts gem object out from memory. Used by the drm_gem_object_evict() helper. Returns 0 on success, -errno otherwise. Called with a held GEM reservation lock.}(hjԅhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjхubh)}(hThis callback is optional.h]hThis callback is optional.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjЅhKhjхubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjЅhKhjށubj)}(hXM``status`` The optional status callback can return additional object state which determines which stats the object is counted against. The callback is called under table_lock. Racing against object status change is "harmless", and the callback can expect to not race against object destruction. Called by drm_show_memory_stats(). h](j)}(h ``status``h]j)}(hjh]hstatus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh](h)}(hXThe optional status callback can return additional object state which determines which stats the object is counted against. The callback is called under table_lock. Racing against object status change is "harmless", and the callback can expect to not race against object destruction.h]hX!The optional status callback can return additional object state which determines which stats the object is counted against. The callback is called under table_lock. Racing against object status change is “harmless”, and the callback can expect to not race against object destruction.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubh)}(h"Called by drm_show_memory_stats().h]h"Called by drm_show_memory_stats().}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjށubj)}(hc``rss`` Return resident size of the object in physical memory. Called by drm_show_memory_stats(). h](j)}(h``rss``h]j)}(hjKh]hrss}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjEubj )}(hhh](h)}(h6Return resident size of the object in physical memory.h]h6Return resident size of the object in physical memory.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjaubh)}(h"Called by drm_show_memory_stats().h]h"Called by drm_show_memory_stats().}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hKhjaubeh}(h]h ]h"]h$]h&]uh1j hjEubeh}(h]h ]h"]h$]h&]uh1jhj`hKhjށubj)}(hf``vm_ops`` Virtual memory operations used with mmap. This is optional but necessary for mmap support.h](j)}(h ``vm_ops``h]j)}(hjh]hvm_ops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh](h)}(h)Virtual memory operations used with mmap.h]h)Virtual memory operations used with mmap.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubh)}(h0This is optional but necessary for mmap support.h]h0This is optional but necessary for mmap support.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjށubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_lru (C struct) c.drm_gem_lruhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h drm_gem_lruh]j>)}(hstruct drm_gem_lruh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj hKubjg)}(h drm_gem_lruh]jm)}(hjh]h drm_gem_lru}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj hKhjhhubj)}(hhh]h)}(hA simple LRU helperh]hA simple LRU helper}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhj;hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hKubeh}(h]h ](jstructeh"]h$]h&]jjjjVjjVjjjuh1j2hhhjuhNhNubj)}(hX**Definition**:: struct drm_gem_lru { struct mutex *lock; long count; struct list_head list; }; **Members** ``lock`` Lock protecting movement of GEM objects between LRUs. All LRUs that the object can move between should be protected by the same lock. ``count`` The total number of backing pages of the GEM objects in this LRU. ``list`` The LRU list.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubh:}(hj^hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjZubjT)}(hZstruct drm_gem_lru { struct mutex *lock; long count; struct list_head list; };h]hZstruct drm_gem_lru { struct mutex *lock; long count; struct list_head list; };}hj{sbah}(h]h ]h"]h$]h&]jjuh1jShQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjZubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjZubj)}(hhh](j)}(h``lock`` Lock protecting movement of GEM objects between LRUs. All LRUs that the object can move between should be protected by the same lock. h](j)}(h``lock``h]j)}(hjh]hlock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubj )}(hhh]h)}(hLock protecting movement of GEM objects between LRUs. All LRUs that the object can move between should be protected by the same lock.h]hLock protecting movement of GEM objects between LRUs. All LRUs that the object can move between should be protected by the same lock.}(hjćhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hL``count`` The total number of backing pages of the GEM objects in this LRU. h](j)}(h ``count``h]j)}(hjh]hcount}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj߇ubj )}(hhh]h)}(hAThe total number of backing pages of the GEM objects in this LRU.h]hAThe total number of backing pages of the GEM objects in this LRU.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubah}(h]h ]h"]h$]h&]uh1j hj߇ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h``list`` The LRU list.h](j)}(h``list``h]j)}(hjh]hlist}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM hjubj )}(hhh]h)}(h The LRU list.h]h The LRU list.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM hj5ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj4hM hjubeh}(h]h ]h"]h$]h&]uh1jhjZubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubh)}(h**Description**h]j)}(hjbh]h Description}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubh)}(hX$A helper for tracking GEM objects in a given state, to aid in driver's shrinker implementation. Tracks the count of pages for lockless :c:type:`shrinker.count_objects `, and provides :c:type:`drm_gem_lru_scan` for driver's :c:type:`shrinker.scan_objects ` implementation.h](hA helper for tracking GEM objects in a given state, to aid in driver’s shrinker implementation. Tracks the count of pages for lockless }(hjxhhhNhNubh)}(h+:c:type:`shrinker.count_objects `h]j)}(hjh]hshrinker.count_objects}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMshrinkeruh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKhjxubh, and provides }(hjxhhhNhNubh)}(h:c:type:`drm_gem_lru_scan`h]j)}(hjh]hdrm_gem_lru_scan}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_lru_scanuh1hhjhKhjxubh for driver’s }(hjxhhhNhNubh)}(h*:c:type:`shrinker.scan_objects `h]j)}(hjɈh]hshrinker.scan_objects}(hjˈhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjLjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMshrinkeruh1hhjhKhjxubh implementation.}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjuhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_object (C struct)c.drm_gem_objecthNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hdrm_gem_objecth]j>)}(hstruct drm_gem_objecth](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_gem_objecth]jm)}(hjh]hdrm_gem_object}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(hGEM buffer objecth]hGEM buffer object}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjHhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjcjjcjjjuh1j2hhhjuhNhNubj)}(hXn**Definition**:: struct drm_gem_object { struct kref refcount; unsigned handle_count; struct drm_device *dev; struct file *filp; struct drm_vma_offset_node vma_node; size_t size; int name; struct dma_buf *dma_buf; struct dma_buf_attachment *import_attach; struct dma_resv *resv; struct dma_resv _resv; struct { struct list_head list; struct mutex lock; } gpuva; const struct drm_gem_object_funcs *funcs; struct list_head lru_node; struct drm_gem_lru *lru; }; **Members** ``refcount`` Reference count of this object Please use drm_gem_object_get() to acquire and drm_gem_object_put_locked() or drm_gem_object_put() to release a reference to a GEM buffer object. ``handle_count`` This is the GEM file_priv handle count of this object. Each handle also holds a reference. Note that when the handle_count drops to 0 any global names (e.g. the id in the flink namespace) will be cleared. Protected by :c:type:`drm_device.object_name_lock `. ``dev`` DRM dev this object belongs to. ``filp`` SHMEM file node used as backing storage for swappable buffer objects. GEM also supports driver private objects with driver-specific backing storage (contiguous DMA memory, special reserved blocks). In this case **filp** is NULL. ``vma_node`` Mapping info for this object to support mmap. Drivers are supposed to allocate the mmap offset using drm_gem_create_mmap_offset(). The offset itself can be retrieved using drm_vma_node_offset_addr(). Memory mapping itself is handled by drm_gem_mmap(), which also checks that userspace is allowed to access the object. ``size`` Size of the object, in bytes. Immutable over the object's lifetime. ``name`` Global name for this object, starts at 1. 0 means unnamed. Access is covered by :c:type:`drm_device.object_name_lock `. This is used by the GEM_FLINK and GEM_OPEN ioctls. ``dma_buf`` dma-buf associated with this GEM object. Pointer to the dma-buf associated with this gem object (either through importing or exporting). We break the resulting reference loop when the last gem handle for this object is released. Protected by :c:type:`drm_device.object_name_lock `. ``import_attach`` dma-buf attachment backing this object. Any foreign dma_buf imported as a gem object has this set to the attachment point for the device. This is invariant over the lifetime of a gem object. The :c:type:`drm_gem_object_funcs.free ` callback is responsible for cleaning up the dma_buf attachment and references acquired at import time. Note that the drm gem/prime core does not depend upon drivers setting this field any more. So for drivers where this doesn't make sense (e.g. virtual devices or a displaylink behind an usb bus) they can simply leave it as NULL. ``resv`` Pointer to reservation object associated with the this GEM object. Normally (**resv** == &**_resv**) except for imported GEM objects. ``_resv`` A reservation object for this GEM object. This is unused for imported GEM objects. ``gpuva`` Fields used by GPUVM to manage mappings pointing to this GEM object. When DRM_GPUVM_IMMEDIATE_MODE is set, this list is protected by the mutex. Otherwise, the list is protected by the GEMs :c:type:`dma_resv` lock. Note that all entries in this list must agree on whether DRM_GPUVM_IMMEDIATE_MODE is set. ``gpuva.list`` list of GPUVM mappings attached to this GEM object. Drivers should lock list accesses with either the GEMs :c:type:`dma_resv` lock (:c:type:`drm_gem_object.resv `) or the :c:type:`drm_gem_object.gpuva `.lock mutex. ``gpuva.lock`` lock protecting access to :c:type:`drm_gem_object.gpuva `.list when DRM_GPUVM_IMMEDIATE_MODE is used. Only used when DRM_GPUVM_IMMEDIATE_MODE is set. It should be safe to take this mutex during the fence signalling path, so do not allocate memory while holding this lock. Otherwise, the :c:type:`dma_resv` lock should be used. ``funcs`` Optional GEM object functions. If this is set, it will be used instead of the corresponding :c:type:`drm_driver` GEM callbacks. New drivers should use this. ``lru_node`` List node in a :c:type:`drm_gem_lru`. ``lru`` The current LRU list that the GEM object is on.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubh:}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjgubjT)}(hX struct drm_gem_object { struct kref refcount; unsigned handle_count; struct drm_device *dev; struct file *filp; struct drm_vma_offset_node vma_node; size_t size; int name; struct dma_buf *dma_buf; struct dma_buf_attachment *import_attach; struct dma_resv *resv; struct dma_resv _resv; struct { struct list_head list; struct mutex lock; } gpuva; const struct drm_gem_object_funcs *funcs; struct list_head lru_node; struct drm_gem_lru *lru; };h]hX struct drm_gem_object { struct kref refcount; unsigned handle_count; struct drm_device *dev; struct file *filp; struct drm_vma_offset_node vma_node; size_t size; int name; struct dma_buf *dma_buf; struct dma_buf_attachment *import_attach; struct dma_resv *resv; struct dma_resv _resv; struct { struct list_head list; struct mutex lock; } gpuva; const struct drm_gem_object_funcs *funcs; struct list_head lru_node; struct drm_gem_lru *lru; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjgubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM/hjgubj)}(hhh](j)}(h``refcount`` Reference count of this object Please use drm_gem_object_get() to acquire and drm_gem_object_put_locked() or drm_gem_object_put() to release a reference to a GEM buffer object. h](j)}(h ``refcount``h]j)}(hjh]hrefcount}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM"hjubj )}(hhh](h)}(hReference count of this objecth]hReference count of this object}(hjщhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjΉubh)}(hPlease use drm_gem_object_get() to acquire and drm_gem_object_put_locked() or drm_gem_object_put() to release a reference to a GEM buffer object.h]hPlease use drm_gem_object_get() to acquire and drm_gem_object_put_locked() or drm_gem_object_put() to release a reference to a GEM buffer object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM hjΉubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj͉hM"hjubj)}(hX!``handle_count`` This is the GEM file_priv handle count of this object. Each handle also holds a reference. Note that when the handle_count drops to 0 any global names (e.g. the id in the flink namespace) will be cleared. Protected by :c:type:`drm_device.object_name_lock `. h](j)}(h``handle_count``h]j)}(hjh]h handle_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM/hjubj )}(hhh](h)}(h6This is the GEM file_priv handle count of this object.h]h6This is the GEM file_priv handle count of this object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM)hjubh)}(hEach handle also holds a reference. Note that when the handle_count drops to 0 any global names (e.g. the id in the flink namespace) will be cleared.h]hEach handle also holds a reference. Note that when the handle_count drops to 0 any global names (e.g. the id in the flink namespace) will be cleared.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM+hjubh)}(h@Protected by :c:type:`drm_device.object_name_lock `.h](h Protected by }(hj8hhhNhNubh)}(h2:c:type:`drm_device.object_name_lock `h]j)}(hjBh]hdrm_device.object_name_lock}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhjhM/hj8ubh.}(hj8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM/hjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(h(``dev`` DRM dev this object belongs to. h](j)}(h``dev``h]j)}(hj{h]hdev}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM6hjuubj )}(hhh]h)}(hDRM dev this object belongs to.h]hDRM dev this object belongs to.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM6hjubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjhM6hjubj)}(h``filp`` SHMEM file node used as backing storage for swappable buffer objects. GEM also supports driver private objects with driver-specific backing storage (contiguous DMA memory, special reserved blocks). In this case **filp** is NULL. h](j)}(h``filp``h]j)}(hjh]hfilp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM>hjubj )}(hhh]h)}(hSHMEM file node used as backing storage for swappable buffer objects. GEM also supports driver private objects with driver-specific backing storage (contiguous DMA memory, special reserved blocks). In this case **filp** is NULL.h](hSHMEM file node used as backing storage for swappable buffer objects. GEM also supports driver private objects with driver-specific backing storage (contiguous DMA memory, special reserved blocks). In this case }(hj͊hhhNhNubj)}(h**filp**h]hfilp}(hjՊhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj͊ubh is NULL.}(hj͊hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM;hjʊubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjɊhM>hjubj)}(hXL``vma_node`` Mapping info for this object to support mmap. Drivers are supposed to allocate the mmap offset using drm_gem_create_mmap_offset(). The offset itself can be retrieved using drm_vma_node_offset_addr(). Memory mapping itself is handled by drm_gem_mmap(), which also checks that userspace is allowed to access the object. h](j)}(h ``vma_node``h]j)}(hjh]hvma_node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMJhjubj )}(hhh](h)}(hMapping info for this object to support mmap. Drivers are supposed to allocate the mmap offset using drm_gem_create_mmap_offset(). The offset itself can be retrieved using drm_vma_node_offset_addr().h]hMapping info for this object to support mmap. Drivers are supposed to allocate the mmap offset using drm_gem_create_mmap_offset(). The offset itself can be retrieved using drm_vma_node_offset_addr().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMEhjubh)}(huMemory mapping itself is handled by drm_gem_mmap(), which also checks that userspace is allowed to access the object.h]huMemory mapping itself is handled by drm_gem_mmap(), which also checks that userspace is allowed to access the object.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMIhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMJhjubj)}(hN``size`` Size of the object, in bytes. Immutable over the object's lifetime. h](j)}(h``size``h]j)}(hjIh]hsize}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMRhjCubj )}(hhh]h)}(hDSize of the object, in bytes. Immutable over the object's lifetime.h]hFSize of the object, in bytes. Immutable over the object’s lifetime.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMQhj_ubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMRhjubj)}(h``name`` Global name for this object, starts at 1. 0 means unnamed. Access is covered by :c:type:`drm_device.object_name_lock `. This is used by the GEM_FLINK and GEM_OPEN ioctls. h](j)}(h``name``h]j)}(hjh]hname}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM[hj}ubj )}(hhh]h)}(hGlobal name for this object, starts at 1. 0 means unnamed. Access is covered by :c:type:`drm_device.object_name_lock `. This is used by the GEM_FLINK and GEM_OPEN ioctls.h](hPGlobal name for this object, starts at 1. 0 means unnamed. Access is covered by }(hjhhhNhNubh)}(h2:c:type:`drm_device.object_name_lock `h]j)}(hjh]hdrm_device.object_name_lock}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMYhjubh4. This is used by the GEM_FLINK and GEM_OPEN ioctls.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjËhMYhjubah}(h]h ]h"]h$]h&]uh1j hj}ubeh}(h]h ]h"]h$]h&]uh1jhjhM[hjubj)}(hX4``dma_buf`` dma-buf associated with this GEM object. Pointer to the dma-buf associated with this gem object (either through importing or exporting). We break the resulting reference loop when the last gem handle for this object is released. Protected by :c:type:`drm_device.object_name_lock `. h](j)}(h ``dma_buf``h]j)}(hjh]hdma_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjދubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhhjڋubj )}(hhh](h)}(h(dma-buf associated with this GEM object.h]h(dma-buf associated with this GEM object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMbhjubh)}(hPointer to the dma-buf associated with this gem object (either through importing or exporting). We break the resulting reference loop when the last gem handle for this object is released.h]hPointer to the dma-buf associated with this gem object (either through importing or exporting). We break the resulting reference loop when the last gem handle for this object is released.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMdhjubh)}(h@Protected by :c:type:`drm_device.object_name_lock `.h](h Protected by }(hjhhhNhNubh)}(h2:c:type:`drm_device.object_name_lock `h]j)}(hj!h]hdrm_device.object_name_lock}(hj#hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhjhMhhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhhjubeh}(h]h ]h"]h$]h&]uh1j hjڋubeh}(h]h ]h"]h$]h&]uh1jhjhMhhjubj)}(hX^``import_attach`` dma-buf attachment backing this object. Any foreign dma_buf imported as a gem object has this set to the attachment point for the device. This is invariant over the lifetime of a gem object. The :c:type:`drm_gem_object_funcs.free ` callback is responsible for cleaning up the dma_buf attachment and references acquired at import time. Note that the drm gem/prime core does not depend upon drivers setting this field any more. So for drivers where this doesn't make sense (e.g. virtual devices or a displaylink behind an usb bus) they can simply leave it as NULL. h](j)}(h``import_attach``h]j)}(hjZh]h import_attach}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM|hjTubj )}(hhh](h)}(h'dma-buf attachment backing this object.h]h'dma-buf attachment backing this object.}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMohjpubh)}(hAny foreign dma_buf imported as a gem object has this set to the attachment point for the device. This is invariant over the lifetime of a gem object.h]hAny foreign dma_buf imported as a gem object has this set to the attachment point for the device. This is invariant over the lifetime of a gem object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMqhjpubh)}(hThe :c:type:`drm_gem_object_funcs.free ` callback is responsible for cleaning up the dma_buf attachment and references acquired at import time.h](hThe }(hjhhhNhNubh)}(h::c:type:`drm_gem_object_funcs.free `h]j)}(hjh]hdrm_gem_object_funcs.free}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMuhjubhg callback is responsible for cleaning up the dma_buf attachment and references acquired at import time.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMuhjpubh)}(hNote that the drm gem/prime core does not depend upon drivers setting this field any more. So for drivers where this doesn't make sense (e.g. virtual devices or a displaylink behind an usb bus) they can simply leave it as NULL.h]hNote that the drm gem/prime core does not depend upon drivers setting this field any more. So for drivers where this doesn’t make sense (e.g. virtual devices or a displaylink behind an usb bus) they can simply leave it as NULL.}(hjÌhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMyhjpubeh}(h]h ]h"]h$]h&]uh1j hjTubeh}(h]h ]h"]h$]h&]uh1jhjohM|hjubj)}(h``resv`` Pointer to reservation object associated with the this GEM object. Normally (**resv** == &**_resv**) except for imported GEM objects. h](j)}(h``resv``h]j)}(hjh]hresv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjތubj )}(hhh](h)}(hBPointer to reservation object associated with the this GEM object.h]hBPointer to reservation object associated with the this GEM object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hBNormally (**resv** == &**_resv**) except for imported GEM objects.h](h Normally (}(hj hhhNhNubj)}(h**resv**h]hresv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh0 == &**_resv**) except for imported GEM objects.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1j hjތubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h^``_resv`` A reservation object for this GEM object. This is unused for imported GEM objects. h](j)}(h ``_resv``h]j)}(hj>h]h_resv}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj8ubj )}(hhh](h)}(h)A reservation object for this GEM object.h]h)A reservation object for this GEM object.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjTubh)}(h(This is unused for imported GEM objects.h]h(This is unused for imported GEM objects.}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhjTubeh}(h]h ]h"]h$]h&]uh1j hj8ubeh}(h]h ]h"]h$]h&]uh1jhjShMhjubj)}(hX<``gpuva`` Fields used by GPUVM to manage mappings pointing to this GEM object. When DRM_GPUVM_IMMEDIATE_MODE is set, this list is protected by the mutex. Otherwise, the list is protected by the GEMs :c:type:`dma_resv` lock. Note that all entries in this list must agree on whether DRM_GPUVM_IMMEDIATE_MODE is set. h](j)}(h ``gpuva``h]j)}(hjh]hgpuva}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh](h)}(hDFields used by GPUVM to manage mappings pointing to this GEM object.h]hDFields used by GPUVM to manage mappings pointing to this GEM object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hWhen DRM_GPUVM_IMMEDIATE_MODE is set, this list is protected by the mutex. Otherwise, the list is protected by the GEMs :c:type:`dma_resv` lock.h](hxWhen DRM_GPUVM_IMMEDIATE_MODE is set, this list is protected by the mutex. Otherwise, the list is protected by the GEMs }(hjhhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjh]hdma_resv}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh lock.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjՍhMhjubh)}(hYNote that all entries in this list must agree on whether DRM_GPUVM_IMMEDIATE_MODE is set.h]hYNote that all entries in this list must agree on whether DRM_GPUVM_IMMEDIATE_MODE is set.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``gpuva.list`` list of GPUVM mappings attached to this GEM object. Drivers should lock list accesses with either the GEMs :c:type:`dma_resv` lock (:c:type:`drm_gem_object.resv `) or the :c:type:`drm_gem_object.gpuva `.lock mutex. h](j)}(h``gpuva.list``h]j)}(hjh]h gpuva.list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh](h)}(h3list of GPUVM mappings attached to this GEM object.h]h3list of GPUVM mappings attached to this GEM object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hDrivers should lock list accesses with either the GEMs :c:type:`dma_resv` lock (:c:type:`drm_gem_object.resv `) or the :c:type:`drm_gem_object.gpuva `.lock mutex.h](h7Drivers should lock list accesses with either the GEMs }(hj)hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj3h]hdma_resv}(hj5hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj)ubh lock (}(hj)hhhNhNubh)}(h.:c:type:`drm_gem_object.resv `h]j)}(hjWh]hdrm_gem_object.resv}(hjYhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjPhMhj)ubh ) or the }(hj)hhhNhNubh)}(h/:c:type:`drm_gem_object.gpuva `h]j)}(hjzh]hdrm_gem_object.gpuva}(hj|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjPhMhj)ubh .lock mutex.}(hj)hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjPhMhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hXg``gpuva.lock`` lock protecting access to :c:type:`drm_gem_object.gpuva `.list when DRM_GPUVM_IMMEDIATE_MODE is used. Only used when DRM_GPUVM_IMMEDIATE_MODE is set. It should be safe to take this mutex during the fence signalling path, so do not allocate memory while holding this lock. Otherwise, the :c:type:`dma_resv` lock should be used. h](j)}(h``gpuva.lock``h]j)}(hjh]h gpuva.lock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh](h)}(hulock protecting access to :c:type:`drm_gem_object.gpuva `.list when DRM_GPUVM_IMMEDIATE_MODE is used.h](hlock protecting access to }(hj̎hhhNhNubh)}(h/:c:type:`drm_gem_object.gpuva `h]j)}(hj֎h]hdrm_gem_object.gpuva}(hj؎hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjԎubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj̎ubh,.list when DRM_GPUVM_IMMEDIATE_MODE is used.}(hj̎hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjɎubh)}(hOnly used when DRM_GPUVM_IMMEDIATE_MODE is set. It should be safe to take this mutex during the fence signalling path, so do not allocate memory while holding this lock. Otherwise, the :c:type:`dma_resv` lock should be used.h](hOnly used when DRM_GPUVM_IMMEDIATE_MODE is set. It should be safe to take this mutex during the fence signalling path, so do not allocate memory while holding this lock. Otherwise, the }(hjhhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjh]hdma_resv}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh lock should be used.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj%hMhjɎubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjȎhMhjubj)}(h``funcs`` Optional GEM object functions. If this is set, it will be used instead of the corresponding :c:type:`drm_driver` GEM callbacks. New drivers should use this. h](j)}(h ``funcs``h]j)}(hjBh]hfuncs}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj<ubj )}(hhh](h)}(hOptional GEM object functions. If this is set, it will be used instead of the corresponding :c:type:`drm_driver` GEM callbacks.h](h\Optional GEM object functions. If this is set, it will be used instead of the corresponding }(hj[hhhNhNubh)}(h:c:type:`drm_driver`h]j)}(hjeh]h drm_driver}(hjghhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj[ubh GEM callbacks.}(hj[hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjXubh)}(hNew drivers should use this.h]hNew drivers should use this.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhMhjXubeh}(h]h ]h"]h$]h&]uh1j hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhMhjubj)}(h3``lru_node`` List node in a :c:type:`drm_gem_lru`. h](j)}(h ``lru_node``h]j)}(hjh]hlru_node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(h%List node in a :c:type:`drm_gem_lru`.h](hList node in a }(hjƏhhhNhNubh)}(h:c:type:`drm_gem_lru`h]j)}(hjЏh]h drm_gem_lru}(hjҏhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjΏubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gem_lruuh1hhjhMhjƏubh.}(hjƏhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjÏubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h7``lru`` The current LRU list that the GEM object is on.h](j)}(h``lru``h]j)}(hj h]hlru}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(h/The current LRU list that the GEM object is on.h]h/The current LRU list that the GEM object is on.}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubh)}(h**Description**h]j)}(hjLh]h Description}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubh)}(h}This structure defines the generic parts for GEM buffer objects, which are mostly around handling mmap and userspace handles.h]h}This structure defines the generic parts for GEM buffer objects, which are mostly around handling mmap and userspace handles.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubh)}(h+Buffer objects are often abbreviated to BO.h]h+Buffer objects are often abbreviated to BO.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.DRM_GEM_FOPS (C macro)c.DRM_GEM_FOPShNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h DRM_GEM_FOPSh]j>)}(h DRM_GEM_FOPSh]jg)}(h DRM_GEM_FOPSh]jm)}(hjh]h DRM_GEM_FOPS}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjɐjjɐjjjuh1j2hhhjuhNhNubh)}(h``DRM_GEM_FOPS``h]j)}(hjϐh]h DRM_GEM_FOPS}(hjѐhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj͐ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubj)}(h Default drm GEM file operations **Description** This macro provides a shorthand for setting the GEM file ops in the :c:type:`file_operations` structure. If all you need are the default ops, use DEFINE_DRM_GEM_FOPS instead. h](j)}(h Default drm GEM file operations h]h)}(hDefault drm GEM file operationsh]hDefault drm GEM file operations}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubah}(h]h ]h"]h$]h&]uh1jhjhMhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hThis macro provides a shorthand for setting the GEM file ops in the :c:type:`file_operations` structure. If all you need are the default ops, use DEFINE_DRM_GEM_FOPS instead.h](hDThis macro provides a shorthand for setting the GEM file ops in the }(hjhhhNhNubh)}(h:c:type:`file_operations`h]j)}(hj$h]hfile_operations}(hj&hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfile_operationsuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubhR structure. If all you need are the default ops, use DEFINE_DRM_GEM_FOPS instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjAhMhjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjuhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.DEFINE_DRM_GEM_FOPS (C macro)c.DEFINE_DRM_GEM_FOPShNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hDEFINE_DRM_GEM_FOPSh]j>)}(hDEFINE_DRM_GEM_FOPSh]jg)}(hDEFINE_DRM_GEM_FOPSh]jm)}(hjeh]hDEFINE_DRM_GEM_FOPS}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjghhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjhMubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhj`hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj`hhhjhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubh)}(h``DEFINE_DRM_GEM_FOPS (name)``h]j)}(hjh]hDEFINE_DRM_GEM_FOPS (name)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubj)}(h2macro to generate file operations for GEM drivers h]h)}(h1macro to generate file operations for GEM driversh]h1macro to generate file operations for GEM drivers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubah}(h]h ]h"]h$]h&]uh1jhjɑhMhjuhhubj)}(hX7**Parameters** ``name`` name for the generated structure **Description** This macro autogenerates a suitable :c:type:`struct file_operations ` for GEM based drivers, which can be assigned to :c:type:`drm_driver.fops `. Note that this structure cannot be shared between drivers, because it contains a reference to the current module using THIS_MODULE. Note that the declaration is already marked as static - if you need a non-static version of this you're probably doing it wrong and will break the THIS_MODULE reference by accident.h](h)}(h**Parameters**h]j)}(hj֑h]h Parameters}(hjؑhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjԑubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjБubj)}(hhh]j)}(h*``name`` name for the generated structure h](j)}(h``name``h]j)}(hjh]hname}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(h name for the generated structureh]h name for the generated structure}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubah}(h]h ]h"]h$]h&]uh1jhjБubh)}(h**Description**h]j)}(hj0h]h Description}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjБubh)}(hX2This macro autogenerates a suitable :c:type:`struct file_operations ` for GEM based drivers, which can be assigned to :c:type:`drm_driver.fops `. Note that this structure cannot be shared between drivers, because it contains a reference to the current module using THIS_MODULE.h](h$This macro autogenerates a suitable }(hjFhhhNhNubh)}(h2:c:type:`struct file_operations `h]j)}(hjPh]hstruct file_operations}(hjRhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfile_operationsuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjFubh1 for GEM based drivers, which can be assigned to }(hjFhhhNhNubh)}(h&:c:type:`drm_driver.fops `h]j)}(hjth]hdrm_driver.fops}(hjvhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhjmhMhjFubh. Note that this structure cannot be shared between drivers, because it contains a reference to the current module using THIS_MODULE.}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjmhMhjБubh)}(hNote that the declaration is already marked as static - if you need a non-static version of this you're probably doing it wrong and will break the THIS_MODULE reference by accident.h]hNote that the declaration is already marked as static - if you need a non-static version of this you’re probably doing it wrong and will break the THIS_MODULE reference by accident.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjБubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gem_get_huge_mnt (C function)c.drm_gem_get_huge_mnthNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h?struct vfsmount * drm_gem_get_huge_mnt (struct drm_device *dev)h]j>)}(h=struct vfsmount *drm_gem_get_huge_mnt(struct drm_device *dev)h](jD)}(hjh]hstruct}(hjʒhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjƒhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubjV)}(h h]h }(hjؒhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjƒhhhjגhMubh)}(hhh]jm)}(hvfsmounth]hvfsmount}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gem_get_huge_mntsbc.drm_gem_get_huge_mntasbuh1hhjƒhhhjגhMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjƒhhhjגhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjƒhhhjגhMubjg)}(hdrm_gem_get_huge_mnth]jm)}(hjh]hdrm_gem_get_huge_mnt}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjƒhhhjגhMubj)}(h(struct drm_device *dev)h]j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjDhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj@ubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdmodnameN classnameNjj)}j]jc.drm_gem_get_huge_mntasbuh1hhj@ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj@ubjm)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubah}(h]h ]h"]h$]h&]jjuh1jhjƒhhhjגhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj’hhhjגhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjגhMhjhhubj)}(hhh]h)}(h2Get the huge tmpfs mountpoint used by a DRM deviceh]h2Get the huge tmpfs mountpoint used by a DRM device}(hjœhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj“hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjגhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjݓjjݓjjjuh1j2hhhjuhNhNubj)}(hXh**Parameters** ``struct drm_device *dev`` DRM device **Description** This function gets the huge tmpfs mountpoint used by DRM device **dev**. A huge tmpfs mountpoint is used instead of `shm_mnt` after a successful call to drm_gem_huge_mnt_create() when CONFIG_TRANSPARENT_HUGEPAGE is enabled. **Return** The huge tmpfs mountpoint in use, NULL otherwise.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj)}(hhh]j)}(h&``struct drm_device *dev`` DRM device h](j)}(h``struct drm_device *dev``h]j)}(hjh]hstruct drm_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjAh]h Description}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hThis function gets the huge tmpfs mountpoint used by DRM device **dev**. A huge tmpfs mountpoint is used instead of `shm_mnt` after a successful call to drm_gem_huge_mnt_create() when CONFIG_TRANSPARENT_HUGEPAGE is enabled.h](h@This function gets the huge tmpfs mountpoint used by DRM device }(hjWhhhNhNubj)}(h**dev**h]hdev}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubh-. A huge tmpfs mountpoint is used instead of }(hjWhhhNhNubhtitle_reference)}(h `shm_mnt`h]hshm_mnt}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjWubhb after a successful call to drm_gem_huge_mnt_create() when CONFIG_TRANSPARENT_HUGEPAGE is enabled.}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(h1The huge tmpfs mountpoint in use, NULL otherwise.h]h1The huge tmpfs mountpoint in use, NULL otherwise.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_object_get (C function)c.drm_gem_object_gethNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h4void drm_gem_object_get (struct drm_gem_object *obj)h]j>)}(h3void drm_gem_object_get(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjӔhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjϔhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM&ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjϔhhhjhM&ubjg)}(hdrm_gem_object_geth]jm)}(hdrm_gem_object_geth]hdrm_gem_object_get}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjϔhhhjhM&ubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j )}jjsbc.drm_gem_object_getasbuh1hhj ubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj\hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hobjh]hobj}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjϔhhhjhM&ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj˔hhhjhM&ubah}(h]jƔah ](jjeh"]h$]h&]jj)jhuh1j7hjhM&hjȔhhubj)}(hhh]h)}(h%acquire a GEM buffer object referenceh]h%acquire a GEM buffer object reference}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM&hjhhubah}(h]h ]h"]h$]h&]uh1jhjȔhhhjhM&ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` GEM buffer object **Description** This function acquires an additional reference to **obj**. It is illegal to call this without already holding a reference. No locks required.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM*hjubj)}(hhh]j)}(h1``struct drm_gem_object *obj`` GEM buffer object h](j)}(h``struct drm_gem_object *obj``h]j)}(hjԕh]hstruct drm_gem_object *obj}(hj֕hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҕubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM'hjΕubj )}(hhh]h)}(hGEM buffer objecth]hGEM buffer object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM'hjubah}(h]h ]h"]h$]h&]uh1j hjΕubeh}(h]h ]h"]h$]h&]uh1jhjhM'hj˕ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM)hjubh)}(hThis function acquires an additional reference to **obj**. It is illegal to call this without already holding a reference. No locks required.h](h2This function acquires an additional reference to }(hj%hhhNhNubj)}(h**obj**h]hobj}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubhT. It is illegal to call this without already holding a reference. No locks required.}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM(hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_object_put (C function)c.drm_gem_object_puthNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h4void drm_gem_object_put (struct drm_gem_object *obj)h]j>)}(h3void drm_gem_object_put(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM9ubjV)}(h h]h }(hjuhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbhhhjthM9ubjg)}(hdrm_gem_object_puth]jm)}(hdrm_gem_object_puth]hdrm_gem_object_put}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjbhhhjthM9ubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjÖmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_object_putasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjbhhhjthM9ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj^hhhjthM9ubah}(h]jYah ](jjeh"]h$]h&]jj)jhuh1j7hjthM9hj[hhubj)}(hhh]h)}(h"drop a GEM buffer object referenceh]h"drop a GEM buffer object reference}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM9hj#hhubah}(h]h ]h"]h$]h&]uh1jhj[hhhjthM9ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj>jj>jjjuh1j2hhhjuhNhNubj)}(hz**Parameters** ``struct drm_gem_object *obj`` GEM buffer object **Description** This releases a reference to **obj**.h](h)}(h**Parameters**h]j)}(hjHh]h Parameters}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM=hjBubj)}(hhh]j)}(h1``struct drm_gem_object *obj`` GEM buffer object h](j)}(h``struct drm_gem_object *obj``h]j)}(hjgh]hstruct drm_gem_object *obj}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM:hjaubj )}(hhh]h)}(hGEM buffer objecth]hGEM buffer object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hM:hj}ubah}(h]h ]h"]h$]h&]uh1j hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hM:hj^ubah}(h]h ]h"]h$]h&]uh1jhjBubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM<hjBubh)}(h%This releases a reference to **obj**.h](hThis releases a reference to }(hjhhhNhNubj)}(h**obj**h]hobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhM;hjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.6drm_gem_object_is_shared_for_memory_stats (C function)+c.drm_gem_object_is_shared_for_memory_statshNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hKbool drm_gem_object_is_shared_for_memory_stats (struct drm_gem_object *obj)h]j>)}(hJbool drm_gem_object_is_shared_for_memory_stats(struct drm_gem_object *obj)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMsubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMsubjg)}(h)drm_gem_object_is_shared_for_memory_statsh]jm)}(h)drm_gem_object_is_shared_for_memory_statsh]h)drm_gem_object_is_shared_for_memory_stats}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMsubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj5hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj1ubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjUmodnameN classnameNjj)}j]j )}jjsb+c.drm_gem_object_is_shared_for_memory_statsasbuh1hhj1ubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj1ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj-ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMsubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMsubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMshjhhubj)}(hhh]h)}(hhelper for shared memory statsh]hhelper for shared memory stats}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMshjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMsubeh}(h]h ](jfunctioneh"]h$]h&]jjjjИjjИjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` obj in question **Description** This helper should only be used for fdinfo shared memory stats to determine if a GEM object is shared.h](h)}(h**Parameters**h]j)}(hjژh]h Parameters}(hjܘhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjؘubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMwhjԘubj)}(hhh]j)}(h/``struct drm_gem_object *obj`` obj in question h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMxhjubj )}(hhh]h)}(hobj in questionh]hobj in question}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMxhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMxhjubah}(h]h ]h"]h$]h&]uh1jhjԘubh)}(h**Description**h]j)}(hj4h]h Description}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMzhjԘubh)}(hfThis helper should only be used for fdinfo shared memory stats to determine if a GEM object is shared.h]hfThis helper should only be used for fdinfo shared memory stats to determine if a GEM object is shared.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMthjԘubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_is_imported (C function)c.drm_gem_is_importedhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h;bool drm_gem_is_imported (const struct drm_gem_object *obj)h]j>)}(h:bool drm_gem_is_imported(const struct drm_gem_object *obj)h](j)}(hj*h]hbool}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjuhhhjhMubjg)}(hdrm_gem_is_importedh]jm)}(hdrm_gem_is_importedh]hdrm_gem_is_imported}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjuhhhjhMubj)}(h"(const struct drm_gem_object *obj)h]j)}(h const struct drm_gem_object *objh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj™hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjЙhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjݙhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_is_importedasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjuhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjqhhhjhMubah}(h]jlah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjnhhubj)}(hhh]h)}(h.Tests if GEM object's buffer has been importedh]h0Tests if GEM object’s buffer has been imported}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjPhhubah}(h]h ]h"]h$]h&]uh1jhjnhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjkjjkjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``const struct drm_gem_object *obj`` the GEM object **Return** True if the GEM object's buffer has been imported, false otherwiseh](h)}(h**Parameters**h]j)}(hjuh]h Parameters}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjoubj)}(hhh]j)}(h4``const struct drm_gem_object *obj`` the GEM object h](j)}(h$``const struct drm_gem_object *obj``h]j)}(hjh]h const struct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(hthe GEM objecth]hthe GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjoubh)}(h **Return**h]j)}(hjϚh]hReturn}(hjњhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj͚ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjoubh)}(hBTrue if the GEM object's buffer has been imported, false otherwiseh]hDTrue if the GEM object’s buffer has been imported, false otherwise}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjoubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_gpuva_init (C function)c.drm_gem_gpuva_inithNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h4void drm_gem_gpuva_init (struct drm_gem_object *obj)h]j>)}(h3void drm_gem_gpuva_init(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj"hMubjg)}(hdrm_gem_gpuva_inith]jm)}(hdrm_gem_gpuva_inith]hdrm_gem_gpuva_init}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj"hMubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjQhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjMubjV)}(h h]h }(hj^hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjlubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]j )}jj7sbc.drm_gem_gpuva_initasbuh1hhjMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjMubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubah}(h]h ]h"]h$]h&]jjuh1jhjhhhj"hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj"hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj"hMhj hhubj)}(hhh]h)}(h)initialize the gpuva list of a GEM objecth]h)initialize the gpuva list of a GEM object}(hjԛhhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjћhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj"hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hXM**Parameters** ``struct drm_gem_object *obj`` the :c:type:`drm_gem_object` **Description** This initializes the :c:type:`drm_gem_object`'s :c:type:`drm_gpuvm_bo` list. Calling this function is only necessary for drivers intending to support the :c:type:`drm_driver_feature` DRIVER_GEM_GPUVA. See also drm_gem_gpuva_set_lock().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj)}(hhh]j)}(h<``struct drm_gem_object *obj`` the :c:type:`drm_gem_object` h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(hthe :c:type:`drm_gem_object`h](hthe }(hj.hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj8h]hdrm_gem_object}(hj:hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhj*hMhj.ubeh}(h]h ]h"]h$]h&]uh1hhj*hMhj+ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj*hMhj ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjoh]h Description}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hLThis initializes the :c:type:`drm_gem_object`'s :c:type:`drm_gpuvm_bo` list.h](hThis initializes the }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh’s }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMhjubh list.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h{Calling this function is only necessary for drivers intending to support the :c:type:`drm_driver_feature` DRIVER_GEM_GPUVA.h](hMCalling this function is only necessary for drivers intending to support the }(hjڜhhhNhNubh)}(h:c:type:`drm_driver_feature`h]j)}(hjh]hdrm_driver_feature}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_driver_featureuh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjڜubh DRIVER_GEM_GPUVA.}(hjڜhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h"See also drm_gem_gpuva_set_lock().h]h"See also drm_gem_gpuva_set_lock().}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gem_for_each_gpuvm_bo (C macro)c.drm_gem_for_each_gpuvm_bohNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hdrm_gem_for_each_gpuvm_boh]j>)}(hdrm_gem_for_each_gpuvm_boh]jg)}(hdrm_gem_for_each_gpuvm_boh]jm)}(hj5h]hdrm_gem_for_each_gpuvm_bo}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj7hhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj3hhhjRhMubah}(h]j.ah ](jjeh"]h$]h&]jj)jhuh1j7hjRhMhj0hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj0hhhjRhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjkjjkjjjuh1j2hhhjuhNhNubh)}(h.``drm_gem_for_each_gpuvm_bo (entry__, obj__)``h]j)}(hjqh]h*drm_gem_for_each_gpuvm_bo (entry__, obj__)}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubj)}(h7iterator to walk over a list of :c:type:`drm_gpuvm_bo` h]h)}(h6iterator to walk over a list of :c:type:`drm_gpuvm_bo`h](h iterator to walk over a list of }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjhMhjuhhubj)}(hXB**Parameters** ``entry__`` :c:type:`drm_gpuvm_bo` structure to assign to in each iteration step ``obj__`` the :c:type:`drm_gem_object` the :c:type:`drm_gpuvm_bo` to walk are associated with **Description** This iterator walks over all :c:type:`drm_gpuvm_bo` structures associated with the :c:type:`drm_gem_object`.h](h)}(h**Parameters**h]j)}(hjŝh]h Parameters}(hjǝhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjÝubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj)}(hhh](j)}(hQ``entry__`` :c:type:`drm_gpuvm_bo` structure to assign to in each iteration step h](j)}(h ``entry__``h]j)}(hjh]hentry__}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjޝubj )}(hhh]h)}(hD:c:type:`drm_gpuvm_bo` structure to assign to in each iteration steph](h)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMhjubh. structure to assign to in each iteration step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjޝubeh}(h]h ]h"]h$]h&]uh1jhjhMhj۝ubj)}(h^``obj__`` the :c:type:`drm_gem_object` the :c:type:`drm_gpuvm_bo` to walk are associated with h](j)}(h ``obj__``h]j)}(hj<h]hobj__}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj6ubj )}(hhh]h)}(hSthe :c:type:`drm_gem_object` the :c:type:`drm_gpuvm_bo` to walk are associated withh](hthe }(hjUhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj_h]hdrm_gem_object}(hjahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjQhMhjUubh the }(hjUhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjQhMhjUubh to walk are associated with}(hjUhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjQhMhjRubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhMhj۝ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubh)}(hlThis iterator walks over all :c:type:`drm_gpuvm_bo` structures associated with the :c:type:`drm_gem_object`.h](hThis iterator walks over all }(hjӞhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjݞh]h drm_gpuvm_bo}(hjߞhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj۞ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjӞubh structures associated with the }(hjӞhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMhjӞubh.}(hjӞhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gem_for_each_gpuvm_bo_safe (C macro) c.drm_gem_for_each_gpuvm_bo_safehNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hdrm_gem_for_each_gpuvm_bo_safeh]j>)}(hdrm_gem_for_each_gpuvm_bo_safeh]jg)}(hdrm_gem_for_each_gpuvm_bo_safeh]jm)}(hjBh]hdrm_gem_for_each_gpuvm_bo_safe}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjDhhhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj@hhhj_hMubah}(h]j;ah ](jjeh"]h$]h&]jj)jhuh1j7hj_hMhj=hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj=hhhj_hMubeh}(h]h ](jmacroeh"]h$]h&]jjjjxjjxjjjuh1j2hhhjuhNhNubh)}(h;``drm_gem_for_each_gpuvm_bo_safe (entry__, next__, obj__)``h]j)}(hj~h]h7drm_gem_for_each_gpuvm_bo_safe (entry__, next__, obj__)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjuhhubj)}(h>iterator to safely walk over a list of :c:type:`drm_gpuvm_bo` h]h)}(h=iterator to safely walk over a list of :c:type:`drm_gpuvm_bo`h](h'iterator to safely walk over a list of }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjhMhjuhhubj)}(hX**Parameters** ``entry__`` :c:type:`drm_gpuvm_bostructure` to assign to in each iteration step ``next__`` :c:type:`next` :c:type:`drm_gpuvm_bo` to store the next step ``obj__`` the :c:type:`drm_gem_object` the :c:type:`drm_gpuvm_bo` to walk are associated with **Description** This iterator walks over all :c:type:`drm_gpuvm_bo` structures associated with the :c:type:`drm_gem_object`. It is implemented with list_for_each_entry_safe(), hence it is save against removal of elements.h](h)}(h**Parameters**h]j)}(hjҟh]h Parameters}(hjԟhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjПubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj̟ubj)}(hhh](j)}(hP``entry__`` :c:type:`drm_gpuvm_bostructure` to assign to in each iteration step h](j)}(h ``entry__``h]j)}(hjh]hentry__}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(hC:c:type:`drm_gpuvm_bostructure` to assign to in each iteration steph](h)}(h:c:type:`drm_gpuvm_bostructure`h]j)}(hjh]hdrm_gpuvm_bostructure}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_bostructureuh1hhjhMhj ubh$ to assign to in each iteration step}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hH``next__`` :c:type:`next` :c:type:`drm_gpuvm_bo` to store the next step h](j)}(h ``next__``h]j)}(hjIh]hnext__}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjCubj )}(hhh]h)}(h<:c:type:`next` :c:type:`drm_gpuvm_bo` to store the next steph](h)}(h:c:type:`next`h]j)}(hjhh]hnext}(hjjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMnextuh1hhj^hMhjbubh }(hjbhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj^hMhjbubh to store the next step}(hjbhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj^hMhj_ubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMhjubj)}(h^``obj__`` the :c:type:`drm_gem_object` the :c:type:`drm_gpuvm_bo` to walk are associated with h](j)}(h ``obj__``h]j)}(hjĠh]hobj__}(hjƠhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhjubj )}(hhh]h)}(hSthe :c:type:`drm_gem_object` the :c:type:`drm_gpuvm_bo` to walk are associated withh](hthe }(hjݠhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhj٠hMhjݠubh the }(hjݠhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj h]h drm_gpuvm_bo}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj٠hMhjݠubh to walk are associated with}(hjݠhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj٠hMhjڠubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj٠hMhjubeh}(h]h ]h"]h$]h&]uh1jhj̟ubh)}(h**Description**h]j)}(hjEh]h Description}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj̟ubh)}(hThis iterator walks over all :c:type:`drm_gpuvm_bo` structures associated with the :c:type:`drm_gem_object`. It is implemented with list_for_each_entry_safe(), hence it is save against removal of elements.h](hThis iterator walks over all }(hj[hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjeh]h drm_gpuvm_bo}(hjghhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhQ/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:369: ./include/drm/drm_gem.hhMhj[ubh structures associated with the }(hj[hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMhj[ubhb. It is implemented with list_for_each_entry_safe(), hence it is save against removal of elements.}(hj[hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj̟ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gem_huge_mnt_create (C function)c.drm_gem_huge_mnt_createhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hGint drm_gem_huge_mnt_create (struct drm_device *dev, const char *value)h]j>)}(hFint drm_gem_huge_mnt_create(struct drm_device *dev, const char *value)h](j)}(hinth]hint}(hjСhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj̡hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chK_ubjV)}(h h]h }(hjߡhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj̡hhhjޡhK_ubjg)}(hdrm_gem_huge_mnt_createh]jm)}(hdrm_gem_huge_mnt_createh]hdrm_gem_huge_mnt_create}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj̡hhhjޡhK_ubj)}(h+(struct drm_device *dev, const char *value)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]j )}jjsbc.drm_gem_huge_mnt_createasbuh1hhj ubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjYhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hdevh]hdev}(hjfhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hconst char *valueh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(hvalueh]hvalue}(hjâhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj̡hhhjޡhK_ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjȡhhhjޡhK_ubah}(h]jáah ](jjeh"]h$]h&]jj)jhuh1j7hjޡhK_hjšhhubj)}(hhh]h)}(h-Create, mount and use a huge tmpfs mountpointh]h-Create, mount and use a huge tmpfs mountpoint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chK_hjhhubah}(h]h ]h"]h$]h&]uh1jhjšhhhjޡhK_ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_device *dev`` DRM device that will use the huge tmpfs mountpoint ``const char *value`` huge tmpfs mount option value **Description** This function creates and mounts a dedicated huge tmpfs mountpoint for the lifetime of the DRM device **dev** which is used at GEM object initialization with drm_gem_object_init(). The most common option for **value** is "within_size" which only allocates huge pages if the page will be fully within the GEM object size. "always", "advise" and "never" are supported too but the latter would just create a mountpoint similar to the default one (`shm_mnt`). See shmemfs and Transparent Hugepage for more information. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKchj ubj)}(hhh](j)}(hN``struct drm_device *dev`` DRM device that will use the huge tmpfs mountpoint h](j)}(h``struct drm_device *dev``h]j)}(hj.h]hstruct drm_device *dev}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chK`hj(ubj )}(hhh]h)}(h2DRM device that will use the huge tmpfs mountpointh]h2DRM device that will use the huge tmpfs mountpoint}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChK`hjDubah}(h]h ]h"]h$]h&]uh1j hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChK`hj%ubj)}(h4``const char *value`` huge tmpfs mount option value h](j)}(h``const char *value``h]j)}(hjgh]hconst char *value}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKahjaubj )}(hhh]h)}(hhuge tmpfs mount option valueh]hhuge tmpfs mount option value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hKahj}ubah}(h]h ]h"]h$]h&]uh1j hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hKahj%ubeh}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKchj ubh)}(hThis function creates and mounts a dedicated huge tmpfs mountpoint for the lifetime of the DRM device **dev** which is used at GEM object initialization with drm_gem_object_init().h](hfThis function creates and mounts a dedicated huge tmpfs mountpoint for the lifetime of the DRM device }(hjhhhNhNubj)}(h**dev**h]hdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhG which is used at GEM object initialization with drm_gem_object_init().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKbhj ubh)}(hXMThe most common option for **value** is "within_size" which only allocates huge pages if the page will be fully within the GEM object size. "always", "advise" and "never" are supported too but the latter would just create a mountpoint similar to the default one (`shm_mnt`). See shmemfs and Transparent Hugepage for more information.h](hThe most common option for }(hj٣hhhNhNubj)}(h **value**h]hvalue}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj٣ubh is “within_size” which only allocates huge pages if the page will be fully within the GEM object size. “always”, “advise” and “never” are supported too but the latter would just create a mountpoint similar to the default one (}(hj٣hhhNhNubjr)}(h `shm_mnt`h]hshm_mnt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj٣ubh=). See shmemfs and Transparent Hugepage for more information.}(hj٣hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKfhj ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKlhj ubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKmhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_object_init (C function)c.drm_gem_object_inithNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hYint drm_gem_object_init (struct drm_device *dev, struct drm_gem_object *obj, size_t size)h]j>)}(hXint drm_gem_object_init(struct drm_device *dev, struct drm_gem_object *obj, size_t size)h](j)}(hinth]hint}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjOhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKubjV)}(h h]h }(hjbhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjOhhhjahKubjg)}(hdrm_gem_object_inith]jm)}(hdrm_gem_object_inith]hdrm_gem_object_init}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjOhhhjahKubj)}(hA(struct drm_device *dev, struct drm_gem_object *obj, size_t size)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjvsbc.drm_gem_object_initasbuh1hhjubjV)}(h h]h }(hjΤhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjܤhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]jʤc.drm_gem_object_initasbuh1hhjubjV)}(h h]h }(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjLhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hjuhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjrubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjwmodnameN classnameNjj)}j]jʤc.drm_gem_object_initasbuh1hhjnubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnubjm)}(hsizeh]hsize}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjOhhhjahKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjKhhhjahKubah}(h]jFah ](jjeh"]h$]h&]jj)jhuh1j7hjahKhjHhhubj)}(hhh]h)}(h/initialize an allocated shmem-backed GEM objecth]h/initialize an allocated shmem-backed GEM object}(hj˥hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjȥhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhjahKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hXv**Parameters** ``struct drm_device *dev`` drm_device the object should be initialized for ``struct drm_gem_object *obj`` drm_gem_object to initialize ``size_t size`` object size **Description** Initialize an already allocated GEM object of the specified size with shmfs backing store. A huge mountpoint can be used by calling drm_gem_huge_mnt_create() beforehand.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubj)}(hhh](j)}(hK``struct drm_device *dev`` drm_device the object should be initialized for h](j)}(h``struct drm_device *dev``h]j)}(hj h]hstruct drm_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubj )}(hhh]h)}(h/drm_device the object should be initialized forh]h/drm_device the object should be initialized for}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hKhj"ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj!hKhjubj)}(h<``struct drm_gem_object *obj`` drm_gem_object to initialize h](j)}(h``struct drm_gem_object *obj``h]j)}(hjEh]hstruct drm_gem_object *obj}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhj?ubj )}(hhh]h)}(hdrm_gem_object to initializeh]hdrm_gem_object to initialize}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhKhj[ubah}(h]h ]h"]h$]h&]uh1j hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhKhjubj)}(h``size_t size`` object size h](j)}(h``size_t size``h]j)}(hj~h]h size_t size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjxubj )}(hhh]h)}(h object sizeh]h object size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubh)}(hInitialize an already allocated GEM object of the specified size with shmfs backing store. A huge mountpoint can be used by calling drm_gem_huge_mnt_create() beforehand.h]hInitialize an already allocated GEM object of the specified size with shmfs backing store. A huge mountpoint can be used by calling drm_gem_huge_mnt_create() beforehand.}(hjϦhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gem_private_object_init (C function)c.drm_gem_private_object_inithNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hbvoid drm_gem_private_object_init (struct drm_device *dev, struct drm_gem_object *obj, size_t size)h]j>)}(havoid drm_gem_private_object_init(struct drm_device *dev, struct drm_gem_object *obj, size_t size)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj hKubjg)}(hdrm_gem_private_object_inith]jm)}(hdrm_gem_private_object_inith]hdrm_gem_private_object_init}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj hKubj)}(hA(struct drm_device *dev, struct drm_gem_object *obj, size_t size)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj;hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj7ubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj[modnameN classnameNjj)}j]j )}jj!sbc.drm_gem_private_object_initasbuh1hhj7ubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj7ubjm)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj˧hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjȧubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjͧmodnameN classnameNjj)}j]juc.drm_gem_private_object_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]juc.drm_gem_private_object_initasbuh1hhjubjV)}(h h]h }(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hsizeh]hsize}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj hKhjhhubj)}(hhh]h)}(h*initialize an allocated private GEM objecth]h*initialize an allocated private GEM object}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjshhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hX{**Parameters** ``struct drm_device *dev`` drm_device the object should be initialized for ``struct drm_gem_object *obj`` drm_gem_object to initialize ``size_t size`` object size **Description** Initialize an already allocated GEM object of the specified size with no GEM provided backing store. Instead the caller is responsible for backing the object and handling it.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubj)}(hhh](j)}(hK``struct drm_device *dev`` drm_device the object should be initialized for h](j)}(h``struct drm_device *dev``h]j)}(hjh]hstruct drm_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubj )}(hhh]h)}(h/drm_device the object should be initialized forh]h/drm_device the object should be initialized for}(hjШhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj̨hKhjͨubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj̨hKhjubj)}(h<``struct drm_gem_object *obj`` drm_gem_object to initialize h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubj )}(hhh]h)}(hdrm_gem_object to initializeh]hdrm_gem_object to initialize}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``size_t size`` object size h](j)}(h``size_t size``h]j)}(hj)h]h size_t size}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhj#ubj )}(hhh]h)}(h object sizeh]h object size}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hKhj?ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hKhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjdh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubh)}(hInitialize an already allocated GEM object of the specified size with no GEM provided backing store. Instead the caller is responsible for backing the object and handling it.h]hInitialize an already allocated GEM object of the specified size with no GEM provided backing store. Instead the caller is responsible for backing the object and handling it.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gem_private_object_fini (C function)c.drm_gem_private_object_finihNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h=void drm_gem_private_object_fini (struct drm_gem_object *obj)h]j>)}(h)}(h)}(hcint drm_gem_dumb_map_offset(struct drm_file *file, struct drm_device *dev, u32 handle, u64 *offset)h](j)}(hinth]hint}(hj>hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:hhhjLhMubjg)}(hdrm_gem_dumb_map_offseth]jm)}(hdrm_gem_dumb_map_offseth]hdrm_gem_dumb_map_offset}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj:hhhjLhMubj)}(hH(struct drm_file *file, struct drm_device *dev, u32 handle, u64 *offset)h](j)}(hstruct drm_file *fileh](jD)}(hjh]hstruct}(hj{hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjwubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjasbc.drm_gem_dumb_map_offsetasbuh1hhjwubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwubj4)}(hj7h]h*}(hjǭhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjwubjm)}(hfileh]hfile}(hjԭhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjwubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]jc.drm_gem_dumb_map_offsetasbuh1hhjubjV)}(h h]h }(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj7hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(h u32 handleh](h)}(hhh]jm)}(hu32h]hu32}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]jc.drm_gem_dumb_map_offsetasbuh1hhjYubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjYubjm)}(hhandleh]hhandle}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(h u64 *offseth](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_dumb_map_offsetasbuh1hhjubjV)}(h h]h }(hjƮhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjԮhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hoffseth]hoffset}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubeh}(h]h ]h"]h$]h&]jjuh1jhj:hhhjLhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj6hhhjLhMubah}(h]j1ah ](jjeh"]h$]h&]jj)jhuh1j7hjLhMhj3hhubj)}(hhh]h)}(h,return the fake mmap offset for a gem objecth]h,return the fake mmap offset for a gem object}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj3hhhjLhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj#jj#jjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_file *file`` drm file-private structure containing the gem object ``struct drm_device *dev`` corresponding drm_device ``u32 handle`` gem object handle ``u64 *offset`` return location for the fake mmap offset **Description** This implements the :c:type:`drm_driver.dumb_map_offset ` kms driver callback for drivers which use gem to manage their backing storage. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hj-h]h Parameters}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj'ubj)}(hhh](j)}(hO``struct drm_file *file`` drm file-private structure containing the gem object h](j)}(h``struct drm_file *file``h]j)}(hjLh]hstruct drm_file *file}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjFubj )}(hhh]h)}(h4drm file-private structure containing the gem objecth]h4drm file-private structure containing the gem object}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahMhjbubah}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhjahMhjCubj)}(h4``struct drm_device *dev`` corresponding drm_device h](j)}(h``struct drm_device *dev``h]j)}(hjh]hstruct drm_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hcorresponding drm_deviceh]hcorresponding drm_device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjCubj)}(h!``u32 handle`` gem object handle h](j)}(h``u32 handle``h]j)}(hjh]h u32 handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hgem object handleh]hgem object handle}(hjׯhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjӯhMhjԯubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjӯhMhjCubj)}(h9``u64 *offset`` return location for the fake mmap offset h](j)}(h``u64 *offset``h]j)}(hjh]h u64 *offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(h(return location for the fake mmap offseth]h(return location for the fake mmap offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjCubeh}(h]h ]h"]h$]h&]uh1jhj'ubh)}(h**Description**h]j)}(hj2h]h Description}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj'ubh)}(hThis implements the :c:type:`drm_driver.dumb_map_offset ` kms driver callback for drivers which use gem to manage their backing storage.h](hThis implements the }(hjHhhhNhNubh)}(h1:c:type:`drm_driver.dumb_map_offset `h]j)}(hjRh]hdrm_driver.dumb_map_offset}(hjThhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjHubhO kms driver callback for drivers which use gem to manage their backing storage.}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjohMhj'ubh)}(h **Return**h]j)}(hj|h]hReturn}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj'ubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_handle_create (C function)c.drm_gem_handle_createhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h`int drm_gem_handle_create (struct drm_file *file_priv, struct drm_gem_object *obj, u32 *handlep)h]j>)}(h_int drm_gem_handle_create(struct drm_file *file_priv, struct drm_gem_object *obj, u32 *handlep)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjаhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjϰhMubjg)}(hdrm_gem_handle_createh]jm)}(hdrm_gem_handle_createh]hdrm_gem_handle_create}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjްubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjϰhMubj)}(hF(struct drm_file *file_priv, struct drm_gem_object *obj, u32 *handlep)h](j)}(hstruct drm_file *file_privh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_handle_createasbuh1hhjubjV)}(h h]h }(hj<hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjJhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h file_privh]h file_priv}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjphhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjlubjV)}(h h]h }(hj}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjlubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j8c.drm_gem_handle_createasbuh1hhjlubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjlubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjlubjm)}(hobjh]hobj}(hjDZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjlubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u32 *handleph](h)}(hhh]jm)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j8c.drm_gem_handle_createasbuh1hhjܱubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjܱubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjܱubjm)}(hhandleph]hhandlep}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjܱubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjϰhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjϰhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjϰhMhjhhubj)}(hhh]h)}(h!create a gem handle for an objecth]h!create a gem handle for an object}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjChhubah}(h]h ]h"]h$]h&]uh1jhjhhhjϰhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1j2hhhjuhNhNubj)}(hXC**Parameters** ``struct drm_file *file_priv`` drm file-private structure to register the handle for ``struct drm_gem_object *obj`` object to register ``u32 *handlep`` pointer to return the created handle to the caller **Description** Create a handle for this object. This adds a handle reference to the object, which includes a regular reference count. Callers will likely want to dereference the object afterwards. Since this publishes **obj** to userspace it must be fully set up by this point, drivers must call this last in their buffer object creation callbacks.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjbubj)}(hhh](j)}(hU``struct drm_file *file_priv`` drm file-private structure to register the handle for h](j)}(h``struct drm_file *file_priv``h]j)}(hjh]hstruct drm_file *file_priv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(h5drm file-private structure to register the handle forh]h5drm file-private structure to register the handle for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubj)}(h2``struct drm_gem_object *obj`` object to register h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hj²hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hobject to registerh]hobject to register}(hjٲhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjղhMhjֲubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjղhMhj~ubj)}(hD``u32 *handlep`` pointer to return the created handle to the caller h](j)}(h``u32 *handlep``h]j)}(hjh]h u32 *handlep}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(h2pointer to return the created handle to the callerh]h2pointer to return the created handle to the caller}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubeh}(h]h ]h"]h$]h&]uh1jhjbubh)}(h**Description**h]j)}(hj4h]h Description}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM!hjbubh)}(hCreate a handle for this object. This adds a handle reference to the object, which includes a regular reference count. Callers will likely want to dereference the object afterwards.h]hCreate a handle for this object. This adds a handle reference to the object, which includes a regular reference count. Callers will likely want to dereference the object afterwards.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjbubh)}(hSince this publishes **obj** to userspace it must be fully set up by this point, drivers must call this last in their buffer object creation callbacks.h](hSince this publishes }(hjYhhhNhNubj)}(h**obj**h]hobj}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubh{ to userspace it must be fully set up by this point, drivers must call this last in their buffer object creation callbacks.}(hjYhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM$hjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gem_free_mmap_offset (C function)c.drm_gem_free_mmap_offsethNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h:void drm_gem_free_mmap_offset (struct drm_gem_object *obj)h]j>)}(h9void drm_gem_free_mmap_offset(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM4ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM4ubjg)}(hdrm_gem_free_mmap_offseth]jm)}(hdrm_gem_free_mmap_offseth]hdrm_gem_free_mmap_offset}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM4ubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj׳hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjӳubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjӳubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_free_mmap_offsetasbuh1hhjӳubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjӳubj4)}(hj7h]h*}(hj#hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjӳubjm)}(hobjh]hobj}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjӳubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjϳubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM4ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM4ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM4hjhhubj)}(hhh]h)}(h(release a fake mmap offset for an objecth]h(release a fake mmap offset for an object}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM4hjWhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM4ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjrjjrjjjuh1j2hhhjuhNhNubj)}(hXF**Parameters** ``struct drm_gem_object *obj`` obj in question **Description** This routine frees fake offsets allocated by drm_gem_create_mmap_offset(). Note that drm_gem_object_release() already calls this function, so drivers don't have to take care of releasing the mmap offset themselves when freeing the GEM object.h](h)}(h**Parameters**h]j)}(hj|h]h Parameters}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM8hjvubj)}(hhh]j)}(h/``struct drm_gem_object *obj`` obj in question h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM5hjubj )}(hhh]h)}(hobj in questionh]hobj in question}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM5hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM5hjubah}(h]h ]h"]h$]h&]uh1jhjvubh)}(h**Description**h]j)}(hjִh]h Description}(hjشhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjԴubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM7hjvubh)}(hJThis routine frees fake offsets allocated by drm_gem_create_mmap_offset().h]hJThis routine frees fake offsets allocated by drm_gem_create_mmap_offset().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM6hjvubh)}(hNote that drm_gem_object_release() already calls this function, so drivers don't have to take care of releasing the mmap offset themselves when freeing the GEM object.h]hNote that drm_gem_object_release() already calls this function, so drivers don’t have to take care of releasing the mmap offset themselves when freeing the GEM object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM8hjvubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.,drm_gem_create_mmap_offset_size (C function)!c.drm_gem_create_mmap_offset_sizehNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hMint drm_gem_create_mmap_offset_size (struct drm_gem_object *obj, size_t size)h]j>)}(hLint drm_gem_create_mmap_offset_size(struct drm_gem_object *obj, size_t size)h](j)}(hinth]hint}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMGubjV)}(h h]h }(hj9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&hhhj8hMGubjg)}(hdrm_gem_create_mmap_offset_sizeh]jm)}(hdrm_gem_create_mmap_offset_sizeh]hdrm_gem_create_mmap_offset_size}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjGubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj&hhhj8hMGubj)}(h)(struct drm_gem_object *obj, size_t size)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjghhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjcubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjcubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjMsb!c.drm_gem_create_mmap_offset_sizeasbuh1hhjcubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjcubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjcubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjcubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj_ubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hjܵhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjٵubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj޵modnameN classnameNjj)}j]j!c.drm_gem_create_mmap_offset_sizeasbuh1hhjյubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjյubjm)}(hsizeh]hsize}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjյubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj_ubeh}(h]h ]h"]h$]h&]jjuh1jhj&hhhj8hMGubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj"hhhj8hMGubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj8hMGhjhhubj)}(hhh]h)}(h'create a fake mmap offset for an objecth]h'create a fake mmap offset for an object}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMGhj/hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj8hMGubeh}(h]h ](jfunctioneh"]h$]h&]jjjjJjjJjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_gem_object *obj`` obj in question ``size_t size`` the virtual size **Description** GEM memory mapping works by handing back to userspace a fake mmap offset it can use in a subsequent mmap(2) call. The DRM core code then looks up the object based on the offset and sets up the various memory mapping structures. This routine allocates and attaches a fake offset for **obj**, in cases where the virtual size differs from the physical size (ie. :c:type:`drm_gem_object.size `). Otherwise just use drm_gem_create_mmap_offset(). This function is idempotent and handles an already allocated mmap offset transparently. Drivers do not need to check for this case.h](h)}(h**Parameters**h]j)}(hjTh]h Parameters}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMKhjNubj)}(hhh](j)}(h/``struct drm_gem_object *obj`` obj in question h](j)}(h``struct drm_gem_object *obj``h]j)}(hjsh]hstruct drm_gem_object *obj}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMHhjmubj )}(hhh]h)}(hobj in questionh]hobj in question}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMHhjubah}(h]h ]h"]h$]h&]uh1j hjmubeh}(h]h ]h"]h$]h&]uh1jhjhMHhjjubj)}(h!``size_t size`` the virtual size h](j)}(h``size_t size``h]j)}(hjh]h size_t size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMIhjubj )}(hhh]h)}(hthe virtual sizeh]hthe virtual size}(hjŶhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMIhj¶ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMIhjjubeh}(h]h ]h"]h$]h&]uh1jhjNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMKhjNubh)}(hGEM memory mapping works by handing back to userspace a fake mmap offset it can use in a subsequent mmap(2) call. The DRM core code then looks up the object based on the offset and sets up the various memory mapping structures.h]hGEM memory mapping works by handing back to userspace a fake mmap offset it can use in a subsequent mmap(2) call. The DRM core code then looks up the object based on the offset and sets up the various memory mapping structures.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMJhjNubh)}(hThis routine allocates and attaches a fake offset for **obj**, in cases where the virtual size differs from the physical size (ie. :c:type:`drm_gem_object.size `). Otherwise just use drm_gem_create_mmap_offset().h](h6This routine allocates and attaches a fake offset for }(hj hhhNhNubj)}(h**obj**h]hobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhF, in cases where the virtual size differs from the physical size (ie. }(hj hhhNhNubh)}(h.:c:type:`drm_gem_object.size `h]j)}(hj(h]hdrm_gem_object.size}(hj*hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMOhj ubh3). Otherwise just use drm_gem_create_mmap_offset().}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjEhMOhjNubh)}(hThis function is idempotent and handles an already allocated mmap offset transparently. Drivers do not need to check for this case.h]hThis function is idempotent and handles an already allocated mmap offset transparently. Drivers do not need to check for this case.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMShjNubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gem_create_mmap_offset (C function)c.drm_gem_create_mmap_offsethNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h;int drm_gem_create_mmap_offset (struct drm_gem_object *obj)h]j>)}(h:int drm_gem_create_mmap_offset(struct drm_gem_object *obj)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMbubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{hhhjhMbubjg)}(hdrm_gem_create_mmap_offseth]jm)}(hdrm_gem_create_mmap_offseth]hdrm_gem_create_mmap_offset}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj{hhhjhMbubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjɷhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjڷhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj׷ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjܷmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_create_mmap_offsetasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj{hhhjhMbubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjwhhhjhMbubah}(h]jrah ](jjeh"]h$]h&]jj)jhuh1j7hjhMbhjthhubj)}(hhh]h)}(h'create a fake mmap offset for an objecth]h'create a fake mmap offset for an object}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMbhj<hhubah}(h]h ]h"]h$]h&]uh1jhjthhhjhMbubeh}(h]h ](jfunctioneh"]h$]h&]jjjjWjjWjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_gem_object *obj`` obj in question **Description** GEM memory mapping works by handing back to userspace a fake mmap offset it can use in a subsequent mmap(2) call. The DRM core code then looks up the object based on the offset and sets up the various memory mapping structures. This routine allocates and attaches a fake offset for **obj**. Drivers can call drm_gem_free_mmap_offset() before freeing **obj** to release the fake offset again.h](h)}(h**Parameters**h]j)}(hjah]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMfhj[ubj)}(hhh]j)}(h/``struct drm_gem_object *obj`` obj in question h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMchjzubj )}(hhh]h)}(hobj in questionh]hobj in question}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMchjubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjhMchjwubah}(h]h ]h"]h$]h&]uh1jhj[ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMehj[ubh)}(hGEM memory mapping works by handing back to userspace a fake mmap offset it can use in a subsequent mmap(2) call. The DRM core code then looks up the object based on the offset and sets up the various memory mapping structures.h]hGEM memory mapping works by handing back to userspace a fake mmap offset it can use in a subsequent mmap(2) call. The DRM core code then looks up the object based on the offset and sets up the various memory mapping structures.}(hjѸhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMdhj[ubh)}(h>This routine allocates and attaches a fake offset for **obj**.h](h6This routine allocates and attaches a fake offset for }(hjhhhNhNubj)}(h**obj**h]hobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMihj[ubh)}(hdDrivers can call drm_gem_free_mmap_offset() before freeing **obj** to release the fake offset again.h](h;Drivers can call drm_gem_free_mmap_offset() before freeing }(hjhhhNhNubj)}(h**obj**h]hobj}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh" to release the fake offset again.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMkhj[ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_get_pages (C function)c.drm_gem_get_pageshNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h=struct page ** drm_gem_get_pages (struct drm_gem_object *obj)h]j>)}(h;struct page **drm_gem_get_pages(struct drm_gem_object *obj)h](jD)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj>hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhjOhMubh)}(hhh]jm)}(hpageh]hpage}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjcmodnameN classnameNjj)}j]j )}jdrm_gem_get_pagessbc.drm_gem_get_pagesasbuh1hhj>hhhjOhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhjOhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>hhhjOhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>hhhjOhMubjg)}(hdrm_gem_get_pagesh]jm)}(hjh]hdrm_gem_get_pages}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj>hhhjOhMubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjɹhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjŹubjV)}(h h]h }(hjֹhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjŹubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j}c.drm_gem_get_pagesasbuh1hhjŹubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjŹubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjŹubjm)}(hobjh]hobj}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjŹubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj>hhhjOhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj:hhhjOhMubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1j7hjOhMhj7hhubj)}(hhh]h)}(h)}(hbvoid drm_gem_put_pages(struct drm_gem_object *obj, struct page **pages, bool dirty, bool accessed)h](j)}(hvoidh]hvoid}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjChhhjUhMubjg)}(hdrm_gem_put_pagesh]jm)}(hdrm_gem_put_pagesh]hdrm_gem_put_pages}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjChhhjUhMubj)}(hL(struct drm_gem_object *obj, struct page **pages, bool dirty, bool accessed)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjjsbc.drm_gem_put_pagesasbuh1hhjubjV)}(h h]h }(hj»hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjлhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjݻhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubj)}(hstruct page **pagesh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hpageh]hpage}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_put_pagesasbuh1hhjubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj@hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubj4)}(hj7h]h*}(hjMhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hpagesh]hpages}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubj)}(h bool dirtyh](j)}(hj*h]hbool}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubjm)}(hdirtyh]hdirty}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubj)}(h bool accessedh](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(haccessedh]haccessed}(hj¼hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubeh}(h]h ]h"]h$]h&]jjuh1jhjChhhjUhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj?hhhjUhMubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1j7hjUhMhj<hhubj)}(hhh]h)}(h-helper to free backing pages for a GEM objecth]h-helper to free backing pages for a GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj<hhhjUhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` obj in question ``struct page **pages`` pages to free ``bool dirty`` if true, pages will be marked as dirty ``bool accessed`` if true, the pages will be marked as accessedh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj)}(hhh](j)}(h/``struct drm_gem_object *obj`` obj in question h](j)}(h``struct drm_gem_object *obj``h]j)}(hj-h]hstruct drm_gem_object *obj}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj'ubj )}(hhh]h)}(hobj in questionh]hobj in question}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhMhjCubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhjBhMhj$ubj)}(h&``struct page **pages`` pages to free h](j)}(h``struct page **pages``h]j)}(hjfh]hstruct page **pages}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj`ubj )}(hhh]h)}(h pages to freeh]h pages to free}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{hMhj|ubah}(h]h ]h"]h$]h&]uh1j hj`ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhj$ubj)}(h6``bool dirty`` if true, pages will be marked as dirty h](j)}(h``bool dirty``h]j)}(hjh]h bool dirty}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(h&if true, pages will be marked as dirtyh]h&if true, pages will be marked as dirty}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj$ubj)}(h?``bool accessed`` if true, the pages will be marked as accessedh](j)}(h``bool accessed``h]j)}(hjؽh]h bool accessed}(hjڽhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjֽubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjҽubj )}(hhh]h)}(h-if true, the pages will be marked as accessedh]h-if true, the pages will be marked as accessed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubah}(h]h ]h"]h$]h&]uh1j hjҽubeh}(h]h ]h"]h$]h&]uh1jhjhMhj$ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gem_objects_lookup (C function)c.drm_gem_objects_lookuphNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hyint drm_gem_objects_lookup (struct drm_file *filp, void __user *bo_handles, int count, struct drm_gem_object ***objs_out)h]j>)}(hxint drm_gem_objects_lookup(struct drm_file *filp, void __user *bo_handles, int count, struct drm_gem_object ***objs_out)h](j)}(hinth]hint}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM(ubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.hhhj@hM(ubjg)}(hdrm_gem_objects_lookuph]jm)}(hdrm_gem_objects_lookuph]hdrm_gem_objects_lookup}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjOubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj.hhhj@hM(ubj)}(h^(struct drm_file *filp, void __user *bo_handles, int count, struct drm_gem_object ***objs_out)h](j)}(hstruct drm_file *filph](jD)}(hjh]hstruct}(hjohhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjkubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjUsbc.drm_gem_objects_lookupasbuh1hhjkubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjkubjm)}(hfilph]hfilp}(hjȾhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubj)}(hvoid __user *bo_handlesh](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjݾubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjݾubh__user}(hjݾhhhNhNubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjݾubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjݾubjm)}(h bo_handlesh]h bo_handles}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjݾubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubj)}(h int counth](j)}(hinth]hint}(hj5hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1ubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubjm)}(hcounth]hcount}(hjQhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubj)}(h!struct drm_gem_object ***objs_outh](jD)}(hjh]hstruct}(hjjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjfubjV)}(h h]h }(hjwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjfubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_objects_lookupasbuh1hhjfubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjfubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjfubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjfubj4)}(hj7h]h*}(hjοhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjfubjm)}(hobjs_outh]hobjs_out}(hjۿhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjfubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjgubeh}(h]h ]h"]h$]h&]jjuh1jhj.hhhj@hM(ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj*hhhj@hM(ubah}(h]j%ah ](jjeh"]h$]h&]jj)jhuh1j7hj@hM(hj'hhubj)}(hhh]h)}(h,look up GEM objects from an array of handlesh]h,look up GEM objects from an array of handles}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM(hjhhubah}(h]h ]h"]h$]h&]uh1jhj'hhhj@hM(ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hXs**Parameters** ``struct drm_file *filp`` DRM file private date ``void __user *bo_handles`` user pointer to array of userspace handle ``int count`` size of handle array ``struct drm_gem_object ***objs_out`` returned pointer to array of drm_gem_object pointers **Description** Takes an array of userspace handles and returns a newly allocated array of GEM objects. For a single handle lookup, use drm_gem_object_lookup(). **Return** **objs** filled in with GEM object pointers. Returned GEM objects need to be released with drm_gem_object_put(). -ENOENT is returned on a lookup failure. 0 is returned on success.h](h)}(h**Parameters**h]j)}(hj'h]h Parameters}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM,hj!ubj)}(hhh](j)}(h0``struct drm_file *filp`` DRM file private date h](j)}(h``struct drm_file *filp``h]j)}(hjFh]hstruct drm_file *filp}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM)hj@ubj )}(hhh]h)}(hDRM file private dateh]hDRM file private date}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hM)hj\ubah}(h]h ]h"]h$]h&]uh1j hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hM)hj=ubj)}(hF``void __user *bo_handles`` user pointer to array of userspace handle h](j)}(h``void __user *bo_handles``h]j)}(hjh]hvoid __user *bo_handles}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM*hjyubj )}(hhh]h)}(h)user pointer to array of userspace handleh]h)user pointer to array of userspace handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM*hjubah}(h]h ]h"]h$]h&]uh1j hjyubeh}(h]h ]h"]h$]h&]uh1jhjhM*hj=ubj)}(h#``int count`` size of handle array h](j)}(h ``int count``h]j)}(hjh]h int count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM+hjubj )}(hhh]h)}(hsize of handle arrayh]hsize of handle array}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM+hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM+hj=ubj)}(h[``struct drm_gem_object ***objs_out`` returned pointer to array of drm_gem_object pointers h](j)}(h%``struct drm_gem_object ***objs_out``h]j)}(hjh]h!struct drm_gem_object ***objs_out}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM,hjubj )}(hhh]h)}(h4returned pointer to array of drm_gem_object pointersh]h4returned pointer to array of drm_gem_object pointers}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM,hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM,hj=ubeh}(h]h ]h"]h$]h&]uh1jhj!ubh)}(h**Description**h]j)}(hj,h]h Description}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM.hj!ubh)}(hWTakes an array of userspace handles and returns a newly allocated array of GEM objects.h]hWTakes an array of userspace handles and returns a newly allocated array of GEM objects.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM-hj!ubh)}(h8For a single handle lookup, use drm_gem_object_lookup().h]h8For a single handle lookup, use drm_gem_object_lookup().}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM0hj!ubh)}(h **Return**h]j)}(hjbh]hReturn}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM2hj!ubh)}(h**objs** filled in with GEM object pointers. Returned GEM objects need to be released with drm_gem_object_put(). -ENOENT is returned on a lookup failure. 0 is returned on success.h](j)}(h**objs**h]hobjs}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubh filled in with GEM object pointers. Returned GEM objects need to be released with drm_gem_object_put(). -ENOENT is returned on a lookup failure. 0 is returned on success.}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM3hj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_object_lookup (C function)c.drm_gem_object_lookuphNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hQstruct drm_gem_object * drm_gem_object_lookup (struct drm_file *filp, u32 handle)h]j>)}(hOstruct drm_gem_object *drm_gem_object_lookup(struct drm_file *filp, u32 handle)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMVubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gem_object_lookupsbc.drm_gem_object_lookupasbuh1hhjhhhjhMVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMVubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhMVubjg)}(hdrm_gem_object_lookuph]jm)}(hjh]hdrm_gem_object_lookup}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMVubj)}(h#(struct drm_file *filp, u32 handle)h](j)}(hstruct drm_file *filph](jD)}(hjh]hstruct}(hj/hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj+ubjV)}(h h]h }(hj<hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjJubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjOmodnameN classnameNjj)}j]jc.drm_gem_object_lookupasbuh1hhj+ubjV)}(h h]h }(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+ubj4)}(hj7h]h*}(hjyhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj+ubjm)}(hfilph]hfilp}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj'ubj)}(h u32 handleh](h)}(hhh]jm)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_object_lookupasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hhandleh]hhandle}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj'ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMVubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMVubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMVhjhhubj)}(hhh]h)}(h$look up a GEM object from its handleh]h$look up a GEM object from its handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMVhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMVubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_file *filp`` DRM file private date ``u32 handle`` userspace handle **Description** If looking up an array of handles, use drm_gem_objects_lookup(). **Return** A reference to the object named by the handle if such exists on **filp**, NULL otherwise.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMZhjubj)}(hhh](j)}(h0``struct drm_file *filp`` DRM file private date h](j)}(h``struct drm_file *filp``h]j)}(hj9h]hstruct drm_file *filp}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMWhj3ubj )}(hhh]h)}(hDRM file private dateh]hDRM file private date}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjNhMWhjOubah}(h]h ]h"]h$]h&]uh1j hj3ubeh}(h]h ]h"]h$]h&]uh1jhjNhMWhj0ubj)}(h ``u32 handle`` userspace handle h](j)}(h``u32 handle``h]j)}(hjrh]h u32 handle}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMXhjlubj )}(hhh]h)}(huserspace handleh]huserspace handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMXhjubah}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhjhMXhj0ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMZhjubh)}(h@If looking up an array of handles, use drm_gem_objects_lookup().h]h@If looking up an array of handles, use drm_gem_objects_lookup().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMYhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM[hjubh)}(hYA reference to the object named by the handle if such exists on **filp**, NULL otherwise.h](h@A reference to the object named by the handle if such exists on }(hjhhhNhNubj)}(h**filp**h]hfilp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, NULL otherwise.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM\hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_dma_resv_wait (C function)c.drm_gem_dma_resv_waithNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(helong drm_gem_dma_resv_wait (struct drm_file *filep, u32 handle, bool wait_all, unsigned long timeout)h]j>)}(hdlong drm_gem_dma_resv_wait(struct drm_file *filep, u32 handle, bool wait_all, unsigned long timeout)h](j)}(hlongh]hlong}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMkubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj'hhhj9hMkubjg)}(hdrm_gem_dma_resv_waith]jm)}(hdrm_gem_dma_resv_waith]hdrm_gem_dma_resv_wait}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj'hhhj9hMkubj)}(hJ(struct drm_file *filep, u32 handle, bool wait_all, unsigned long timeout)h](j)}(hstruct drm_file *fileph](jD)}(hjh]hstruct}(hjhhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjdubjV)}(h h]h }(hjuhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjNsbc.drm_gem_dma_resv_waitasbuh1hhjdubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjdubjm)}(hfileph]hfilep}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(h u32 handleh](h)}(hhh]jm)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_dma_resv_waitasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hhandleh]hhandle}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(h bool wait_allh](j)}(hj*h]hbool}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hwait_allh]hwait_all}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(hunsigned long timeouth](j)}(hunsignedh]hunsigned}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubj)}(hlongh]hlong}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubjm)}(htimeouth]htimeout}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubeh}(h]h ]h"]h$]h&]jjuh1jhj'hhhj9hMkubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj#hhhj9hMkubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj9hMkhj hhubj)}(hhh]h)}(hJWait on GEM object's reservation's objects shared and/or exclusive fences.h]hNWait on GEM object’s reservation’s objects shared and/or exclusive fences.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMkhjhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj9hMkubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hXv**Parameters** ``struct drm_file *filep`` DRM file private date ``u32 handle`` userspace handle ``bool wait_all`` if true, wait on all fences, else wait on just exclusive fence ``unsigned long timeout`` timeout value in jiffies or zero to return immediately **Return** Returns -ERESTARTSYS if interrupted, 0 if the wait timed out, or greater than 0 on success.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMohjubj)}(hhh](j)}(h1``struct drm_file *filep`` DRM file private date h](j)}(h``struct drm_file *filep``h]j)}(hjh]hstruct drm_file *filep}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMmhjubj )}(hhh]h)}(hDRM file private dateh]hDRM file private date}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMmhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMmhjubj)}(h ``u32 handle`` userspace handle h](j)}(h``u32 handle``h]j)}(hj2h]h u32 handle}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMnhj,ubj )}(hhh]h)}(huserspace handleh]huserspace handle}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhMnhjHubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhMnhjubj)}(hQ``bool wait_all`` if true, wait on all fences, else wait on just exclusive fence h](j)}(h``bool wait_all``h]j)}(hjkh]h bool wait_all}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMohjeubj )}(hhh]h)}(h>if true, wait on all fences, else wait on just exclusive fenceh]h>if true, wait on all fences, else wait on just exclusive fence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMohjubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMohjubj)}(hQ``unsigned long timeout`` timeout value in jiffies or zero to return immediately h](j)}(h``unsigned long timeout``h]j)}(hjh]hunsigned long timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMphjubj )}(hhh]h)}(h6timeout value in jiffies or zero to return immediatelyh]h6timeout value in jiffies or zero to return immediately}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMphjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMphjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMrhjubh)}(h[Returns -ERESTARTSYS if interrupted, 0 if the wait timed out, or greater than 0 on success.h]h[Returns -ERESTARTSYS if interrupted, 0 if the wait timed out, or greater than 0 on success.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMrhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gem_object_release (C function)c.drm_gem_object_releasehNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h8void drm_gem_object_release (struct drm_gem_object *obj)h]j>)}(h7void drm_gem_object_release(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMFubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj2hMFubjg)}(hdrm_gem_object_releaseh]jm)}(hdrm_gem_object_releaseh]hdrm_gem_object_release}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj2hMFubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjahhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj]ubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjGsbc.drm_gem_object_releaseasbuh1hhj]ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj]ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjYubah}(h]h ]h"]h$]h&]jjuh1jhj hhhj2hMFubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj2hMFubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj2hMFhjhhubj)}(hhh]h)}(h#release GEM buffer object resourcesh]h#release GEM buffer object resources}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMFhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj2hMFubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` GEM buffer object **Description** This releases any structures and resources used by **obj** and is the inverse of drm_gem_object_init().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMJhjubj)}(hhh]j)}(h1``struct drm_gem_object *obj`` GEM buffer object h](j)}(h``struct drm_gem_object *obj``h]j)}(hj%h]hstruct drm_gem_object *obj}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMGhjubj )}(hhh]h)}(hGEM buffer objecth]hGEM buffer object}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMGhj;ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj:hMGhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj`h]h Description}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMIhjubh)}(hgThis releases any structures and resources used by **obj** and is the inverse of drm_gem_object_init().h](h3This releases any structures and resources used by }(hjvhhhNhNubj)}(h**obj**h]hobj}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubh- and is the inverse of drm_gem_object_init().}(hjvhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMHhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_object_free (C function)c.drm_gem_object_freehNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h,void drm_gem_object_free (struct kref *kref)h]j>)}(h+void drm_gem_object_free(struct kref *kref)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMZubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMZubjg)}(hdrm_gem_object_freeh]jm)}(hdrm_gem_object_freeh]hdrm_gem_object_free}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMZubj)}(h(struct kref *kref)h]j)}(hstruct kref *krefh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hkrefh]hkref}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_object_freeasbuh1hhjubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj@hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hkrefh]hkref}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMZubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMZubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMZhjhhubj)}(hhh]h)}(hfree a GEM objecth]hfree a GEM object}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMZhjthhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMZubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct kref *kref`` kref of the object to free **Description** Called after the last reference to the object has been lost. Frees the objecth](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM^hjubj)}(hhh]j)}(h1``struct kref *kref`` kref of the object to free h](j)}(h``struct kref *kref``h]j)}(hjh]hstruct kref *kref}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM[hjubj )}(hhh]h)}(hkref of the object to freeh]hkref of the object to free}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM[hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM[hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM]hjubh)}(h)}(h0void drm_gem_vm_open(struct vm_area_struct *vma)h](j)}(hvoidh]hvoid}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMoubjV)}(h h]h }(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjChhhjUhMoubjg)}(hdrm_gem_vm_openh]jm)}(hdrm_gem_vm_openh]hdrm_gem_vm_open}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjChhhjUhMoubj)}(h(struct vm_area_struct *vma)h]j)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjjsbc.drm_gem_vm_openasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubah}(h]h ]h"]h$]h&]jjuh1jhjChhhjUhMoubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj?hhhjUhMoubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1j7hjUhMohj<hhubj)}(hhh]h)}(h%vma->ops->open implementation for GEMh]h%vma->ops->open implementation for GEM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMohjhhubah}(h]h ]h"]h$]h&]uh1jhj<hhhjUhMoubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct vm_area_struct *vma`` VM area structure **Description** This function implements the #vm_operations_struct open() callback for GEM drivers. This must be used together with drm_gem_vm_close().h](h)}(h**Parameters**h]j)}(hj)h]h Parameters}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMshj#ubj)}(hhh]j)}(h1``struct vm_area_struct *vma`` VM area structure h](j)}(h``struct vm_area_struct *vma``h]j)}(hjHh]hstruct vm_area_struct *vma}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMphjBubj )}(hhh]h)}(hVM area structureh]hVM area structure}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMphj^ubah}(h]h ]h"]h$]h&]uh1j hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hMphj?ubah}(h]h ]h"]h$]h&]uh1jhj#ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMrhj#ubh)}(hThis function implements the #vm_operations_struct open() callback for GEM drivers. This must be used together with drm_gem_vm_close().h]hThis function implements the #vm_operations_struct open() callback for GEM drivers. This must be used together with drm_gem_vm_close().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMqhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_vm_close (C function)c.drm_gem_vm_closehNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h2void drm_gem_vm_close (struct vm_area_struct *vma)h]j>)}(h1void drm_gem_vm_close(struct vm_area_struct *vma)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM~ubjg)}(hdrm_gem_vm_closeh]jm)}(hdrm_gem_vm_closeh]hdrm_gem_vm_close}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM~ubj)}(h(struct vm_area_struct *vma)h]j)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hj#hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]j )}jjsbc.drm_gem_vm_closeasbuh1hhjubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjQhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvmah]hvma}(hj^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM~ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM~ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM~hjhhubj)}(hhh]h)}(h&vma->ops->close implementation for GEMh]h&vma->ops->close implementation for GEM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM~hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM~ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct vm_area_struct *vma`` VM area structure **Description** This function implements the #vm_operations_struct close() callback for GEM drivers. This must be used together with drm_gem_vm_open().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj)}(hhh]j)}(h1``struct vm_area_struct *vma`` VM area structure h](j)}(h``struct vm_area_struct *vma``h]j)}(hjh]hstruct vm_area_struct *vma}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hVM area structureh]hVM area structure}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(hThis function implements the #vm_operations_struct close() callback for GEM drivers. This must be used together with drm_gem_vm_open().h]hThis function implements the #vm_operations_struct close() callback for GEM drivers. This must be used together with drm_gem_vm_open().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_mmap_obj (C function)c.drm_gem_mmap_objhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(heint drm_gem_mmap_obj (struct drm_gem_object *obj, unsigned long obj_size, struct vm_area_struct *vma)h]j>)}(hdint drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size, struct vm_area_struct *vma)h](j)}(hinth]hint}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEhhhjWhMubjg)}(hdrm_gem_mmap_objh]jm)}(hdrm_gem_mmap_objh]hdrm_gem_mmap_obj}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjfubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjEhhhjWhMubj)}(hP(struct drm_gem_object *obj, unsigned long obj_size, struct vm_area_struct *vma)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjlsbc.drm_gem_mmap_objasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hunsigned long obj_sizeh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hobj_sizeh]hobj_size}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjIhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjEubjV)}(h h]h }(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjimodnameN classnameNjj)}j]jc.drm_gem_mmap_objasbuh1hhjEubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjEubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubeh}(h]h ]h"]h$]h&]jjuh1jhjEhhhjWhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjAhhhjWhMubah}(h]j<ah ](jjeh"]h$]h&]jj)jhuh1j7hjWhMhj>hhubj)}(hhh]h)}(hmemory map a GEM objecth]hmemory map a GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj>hhhjWhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_gem_object *obj`` the GEM object to map ``unsigned long obj_size`` the object size to be mapped, in bytes ``struct vm_area_struct *vma`` VMA for the area to be mapped **Description** Set up the VMA to prepare mapping of the GEM object using the GEM object's vm_ops. Depending on their requirements, GEM objects can either provide a fault handler in their vm_ops (in which case any accesses to the object will be trapped, to perform migration, GTT binding, surface register allocation, or performance monitoring), or mmap the buffer memory synchronously after calling drm_gem_mmap_obj. This function is mainly intended to implement the DMABUF mmap operation, when the GEM object is not looked up based on its fake offset. To implement the DRM mmap operation, drivers should use the drm_gem_mmap() function. drm_gem_mmap_obj() assumes the user is granted access to the buffer while drm_gem_mmap() prevents unprivileged users from mapping random objects. So callers must verify access restrictions before calling this helper. Return 0 or success or -EINVAL if the object size is smaller than the VMA size, or if no vm_ops are provided.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj)}(hhh](j)}(h5``struct drm_gem_object *obj`` the GEM object to map h](j)}(h``struct drm_gem_object *obj``h]j)}(hj h]hstruct drm_gem_object *obj}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hthe GEM object to maph]hthe GEM object to map}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj!ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hB``unsigned long obj_size`` the object size to be mapped, in bytes h](j)}(h``unsigned long obj_size``h]j)}(hjDh]hunsigned long obj_size}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj>ubj )}(hhh]h)}(h&the object size to be mapped, in bytesh]h&the object size to be mapped, in bytes}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjZubah}(h]h ]h"]h$]h&]uh1j hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhMhjubj)}(h=``struct vm_area_struct *vma`` VMA for the area to be mapped h](j)}(h``struct vm_area_struct *vma``h]j)}(hj}h]hstruct vm_area_struct *vma}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjwubj )}(hhh]h)}(hVMA for the area to be mappedh]hVMA for the area to be mapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjwubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(hXSet up the VMA to prepare mapping of the GEM object using the GEM object's vm_ops. Depending on their requirements, GEM objects can either provide a fault handler in their vm_ops (in which case any accesses to the object will be trapped, to perform migration, GTT binding, surface register allocation, or performance monitoring), or mmap the buffer memory synchronously after calling drm_gem_mmap_obj.h]hXSet up the VMA to prepare mapping of the GEM object using the GEM object’s vm_ops. Depending on their requirements, GEM objects can either provide a fault handler in their vm_ops (in which case any accesses to the object will be trapped, to perform migration, GTT binding, surface register allocation, or performance monitoring), or mmap the buffer memory synchronously after calling drm_gem_mmap_obj.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(hThis function is mainly intended to implement the DMABUF mmap operation, when the GEM object is not looked up based on its fake offset. To implement the DRM mmap operation, drivers should use the drm_gem_mmap() function.h]hThis function is mainly intended to implement the DMABUF mmap operation, when the GEM object is not looked up based on its fake offset. To implement the DRM mmap operation, drivers should use the drm_gem_mmap() function.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(hdrm_gem_mmap_obj() assumes the user is granted access to the buffer while drm_gem_mmap() prevents unprivileged users from mapping random objects. So callers must verify access restrictions before calling this helper.h]hdrm_gem_mmap_obj() assumes the user is granted access to the buffer while drm_gem_mmap() prevents unprivileged users from mapping random objects. So callers must verify access restrictions before calling this helper.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(hmReturn 0 or success or -EINVAL if the object size is smaller than the VMA size, or if no vm_ops are provided.h]hmReturn 0 or success or -EINVAL if the object size is smaller than the VMA size, or if no vm_ops are provided.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gem_get_unmapped_area (C function)c.drm_gem_get_unmapped_areahNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hunsigned long drm_gem_get_unmapped_area (struct file *filp, unsigned long uaddr, unsigned long len, unsigned long pgoff, unsigned long flags)h]j>)}(hunsigned long drm_gem_get_unmapped_area(struct file *filp, unsigned long uaddr, unsigned long len, unsigned long pgoff, unsigned long flags)h](j)}(hunsignedh]hunsigned}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hj9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&hhhj8hMubj)}(hlongh]hlong}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&hhhj8hMubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&hhhj8hMubjg)}(hdrm_gem_get_unmapped_areah]jm)}(hdrm_gem_get_unmapped_areah]hdrm_gem_get_unmapped_area}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjcubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj&hhhj8hMubj)}(he(struct file *filp, unsigned long uaddr, unsigned long len, unsigned long pgoff, unsigned long flags)h](j)}(hstruct file *filph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hfileh]hfile}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjisbc.drm_gem_get_unmapped_areaasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hfilph]hfilp}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hunsigned long uaddrh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(huaddrh]huaddr}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hunsigned long lenh](j)}(hunsignedh]hunsigned}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubj)}(hlongh]hlong}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubjm)}(hlenh]hlen}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hunsigned long pgoffh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hpgoffh]hpgoff}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hunsigned long flagsh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hflagsh]hflags}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubeh}(h]h ]h"]h$]h&]jjuh1jhj&hhhj8hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj"hhhj8hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj8hMhjhhubj)}(hhh]h)}(h1get memory mapping region routine for GEM objectsh]h1get memory mapping region routine for GEM objects}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjGhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj8hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjbjjbjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct file *filp`` DRM file pointer ``unsigned long uaddr`` User address hint ``unsigned long len`` Mapping length ``unsigned long pgoff`` Offset (in pages) ``unsigned long flags`` Mapping flags **Description** If a driver supports GEM object mapping, before ending up in drm_gem_mmap(), mmap calls on the DRM file descriptor will first try to find a free linear address space large enough for a mapping. Since GEM objects are backed by shmem buffers, this should preferably be handled by the shmem virtual memory filesystem which can appropriately align addresses to huge page sizes when needed. Look up the GEM object based on the offset passed in (vma->vm_pgoff will contain the fake offset we created) and call shmem_get_unmapped_area() with the right file pointer. If a GEM object is not available at the given offset or if the caller is not granted access to it, fall back to mm_get_unmapped_area().h](h)}(h**Parameters**h]j)}(hjlh]h Parameters}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjfubj)}(hhh](j)}(h'``struct file *filp`` DRM file pointer h](j)}(h``struct file *filp``h]j)}(hjh]hstruct file *filp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hDRM file pointerh]hDRM file pointer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h*``unsigned long uaddr`` User address hint h](j)}(h``unsigned long uaddr``h]j)}(hjh]hunsigned long uaddr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hUser address hinth]hUser address hint}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h%``unsigned long len`` Mapping length h](j)}(h``unsigned long len``h]j)}(hjh]hunsigned long len}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hMapping lengthh]hMapping length}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h*``unsigned long pgoff`` Offset (in pages) h](j)}(h``unsigned long pgoff``h]j)}(hj6h]hunsigned long pgoff}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj0ubj )}(hhh]h)}(hOffset (in pages)h]hOffset (in pages)}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhMhjLubah}(h]h ]h"]h$]h&]uh1j hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhMhjubj)}(h&``unsigned long flags`` Mapping flags h](j)}(h``unsigned long flags``h]j)}(hjoh]hunsigned long flags}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjiubj )}(hhh]h)}(h Mapping flagsh]h Mapping flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjiubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjfubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjfubh)}(hXIf a driver supports GEM object mapping, before ending up in drm_gem_mmap(), mmap calls on the DRM file descriptor will first try to find a free linear address space large enough for a mapping. Since GEM objects are backed by shmem buffers, this should preferably be handled by the shmem virtual memory filesystem which can appropriately align addresses to huge page sizes when needed.h]hXIf a driver supports GEM object mapping, before ending up in drm_gem_mmap(), mmap calls on the DRM file descriptor will first try to find a free linear address space large enough for a mapping. Since GEM objects are backed by shmem buffers, this should preferably be handled by the shmem virtual memory filesystem which can appropriately align addresses to huge page sizes when needed.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjfubh)}(hLook up the GEM object based on the offset passed in (vma->vm_pgoff will contain the fake offset we created) and call shmem_get_unmapped_area() with the right file pointer.h]hLook up the GEM object based on the offset passed in (vma->vm_pgoff will contain the fake offset we created) and call shmem_get_unmapped_area() with the right file pointer.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjfubh)}(hIf a GEM object is not available at the given offset or if the caller is not granted access to it, fall back to mm_get_unmapped_area().h]hIf a GEM object is not available at the given offset or if the caller is not granted access to it, fall back to mm_get_unmapped_area().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjfubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_mmap (C function)c.drm_gem_mmaphNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h@int drm_gem_mmap (struct file *filp, struct vm_area_struct *vma)h]j>)}(h?int drm_gem_mmap(struct file *filp, struct vm_area_struct *vma)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM0ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhM0ubjg)}(h drm_gem_mmaph]jm)}(h drm_gem_mmaph]h drm_gem_mmap}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhM0ubj)}(h/(struct file *filp, struct vm_area_struct *vma)h](j)}(hstruct file *filph](jD)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjFubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubh)}(hhh]jm)}(hfileh]hfile}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j )}jj0sbc.drm_gem_mmapasbuh1hhjFubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjFubjm)}(hfilph]hfilp}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_mmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhM0ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM0ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM0hjhhubj)}(hhh]h)}(h"memory map routine for GEM objectsh]h"memory map routine for GEM objects}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM0hj:hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM0ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjUjjUjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct file *filp`` DRM file pointer ``struct vm_area_struct *vma`` VMA for the area to be mapped **Description** If a driver supports GEM object mapping, mmap calls on the DRM file descriptor will end up here. Look up the GEM object based on the offset passed in (vma->vm_pgoff will contain the fake offset we created) and map it with a call to drm_gem_mmap_obj(). If the caller is not granted access to the buffer object, the mmap will fail with EACCES. Please see the vma manager for more information.h](h)}(h**Parameters**h]j)}(hj_h]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM4hjYubj)}(hhh](j)}(h'``struct file *filp`` DRM file pointer h](j)}(h``struct file *filp``h]j)}(hj~h]hstruct file *filp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM1hjxubj )}(hhh]h)}(hDRM file pointerh]hDRM file pointer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1hjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjuubj)}(h=``struct vm_area_struct *vma`` VMA for the area to be mapped h](j)}(h``struct vm_area_struct *vma``h]j)}(hjh]hstruct vm_area_struct *vma}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM2hjubj )}(hhh]h)}(hVMA for the area to be mappedh]hVMA for the area to be mapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjuubeh}(h]h ]h"]h$]h&]uh1jhjYubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM4hjYubh)}(h`If a driver supports GEM object mapping, mmap calls on the DRM file descriptor will end up here.h]h`If a driver supports GEM object mapping, mmap calls on the DRM file descriptor will end up here.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM3hjYubh)}(hLook up the GEM object based on the offset passed in (vma->vm_pgoff will contain the fake offset we created) and map it with a call to drm_gem_mmap_obj().h]hLook up the GEM object based on the offset passed in (vma->vm_pgoff will contain the fake offset we created) and map it with a call to drm_gem_mmap_obj().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM6hjYubh)}(hIf the caller is not granted access to the buffer object, the mmap will fail with EACCES. Please see the vma manager for more information.h]hIf the caller is not granted access to the buffer object, the mmap will fail with EACCES. Please see the vma manager for more information.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM:hjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gem_lock_reservations (C function)c.drm_gem_lock_reservationshNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hkint drm_gem_lock_reservations (struct drm_gem_object **objs, int count, struct ww_acquire_ctx *acquire_ctx)h]j>)}(hjint drm_gem_lock_reservations(struct drm_gem_object **objs, int count, struct ww_acquire_ctx *acquire_ctx)h](j)}(hinth]hint}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQhhhjchMubjg)}(hdrm_gem_lock_reservationsh]jm)}(hdrm_gem_lock_reservationsh]hdrm_gem_lock_reservations}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjrubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjQhhhjchMubj)}(hM(struct drm_gem_object **objs, int count, struct ww_acquire_ctx *acquire_ctx)h](j)}(hstruct drm_gem_object **objsh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjxsbc.drm_gem_lock_reservationsasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjsh]hobjs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int counth](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(hcounth]hcount}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h"struct ww_acquire_ctx *acquire_ctxh](jD)}(hjh]hstruct}(hjFhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjBubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubh)}(hhh]jm)}(hww_acquire_ctxh]hww_acquire_ctx}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfmodnameN classnameNjj)}j]jc.drm_gem_lock_reservationsasbuh1hhjBubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjBubjm)}(h acquire_ctxh]h acquire_ctx}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjQhhhjchMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjMhhhjchMubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1j7hjchMhjJhhubj)}(hhh]h)}(hHSets up the ww context and acquires the lock on an array of GEM objects.h]hHSets up the ww context and acquires the lock on an array of GEM objects.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjchMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_gem_object **objs`` drm_gem_objects to lock ``int count`` Number of objects in **objs** ``struct ww_acquire_ctx *acquire_ctx`` struct ww_acquire_ctx that will be initialized as part of tracking this set of locked reservations. **Description** Once you've locked your reservations, you'll want to set up space for your shared fences (if applicable), submit your job, then drm_gem_unlock_reservations().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj)}(hhh](j)}(h9``struct drm_gem_object **objs`` drm_gem_objects to lock h](j)}(h ``struct drm_gem_object **objs``h]j)}(hjh]hstruct drm_gem_object **objs}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hdrm_gem_objects to lockh]hdrm_gem_objects to lock}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h,``int count`` Number of objects in **objs** h](j)}(h ``int count``h]j)}(hjAh]h int count}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj;ubj )}(hhh]h)}(hNumber of objects in **objs**h](hNumber of objects in }(hjZhhhNhNubj)}(h**objs**h]hobjs}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubeh}(h]h ]h"]h$]h&]uh1hhjVhMhjWubah}(h]h ]h"]h$]h&]uh1j hj;ubeh}(h]h ]h"]h$]h&]uh1jhjVhMhjubj)}(h``struct ww_acquire_ctx *acquire_ctx`` struct ww_acquire_ctx that will be initialized as part of tracking this set of locked reservations. h](j)}(h&``struct ww_acquire_ctx *acquire_ctx``h]j)}(hjh]h"struct ww_acquire_ctx *acquire_ctx}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hcstruct ww_acquire_ctx that will be initialized as part of tracking this set of locked reservations.h]hcstruct ww_acquire_ctx that will be initialized as part of tracking this set of locked reservations.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(hOnce you've locked your reservations, you'll want to set up space for your shared fences (if applicable), submit your job, then drm_gem_unlock_reservations().h]hOnce you’ve locked your reservations, you’ll want to set up space for your shared fences (if applicable), submit your job, then drm_gem_unlock_reservations().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_lru_init (C function)c.drm_gem_lru_inithNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hCvoid drm_gem_lru_init (struct drm_gem_lru *lru, struct mutex *lock)h]j>)}(hBvoid drm_gem_lru_init(struct drm_gem_lru *lru, struct mutex *lock)h](j)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gem_lru_inith]jm)}(hdrm_gem_lru_inith]hdrm_gem_lru_init}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h-(struct drm_gem_lru *lru, struct mutex *lock)h](j)}(hstruct drm_gem_lru *lruh](jD)}(hjh]hstruct}(hjFhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjBubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubh)}(hhh]jm)}(h drm_gem_lruh]h drm_gem_lru}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfmodnameN classnameNjj)}j]j )}jj,sbc.drm_gem_lru_initasbuh1hhjBubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjBubjm)}(hlruh]hlru}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>ubj)}(hstruct mutex *lockh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hmutexh]hmutex}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_lru_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hlockh]hlock}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hinitialize a LRUh]hinitialize a LRU}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj6hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjQjjQjjjuh1j2hhhjuhNhNubj)}(hy**Parameters** ``struct drm_gem_lru *lru`` The LRU to initialize ``struct mutex *lock`` The lock protecting the LRUh](h)}(h**Parameters**h]j)}(hj[h]h Parameters}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjUubj)}(hhh](j)}(h2``struct drm_gem_lru *lru`` The LRU to initialize h](j)}(h``struct drm_gem_lru *lru``h]j)}(hjzh]hstruct drm_gem_lru *lru}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjtubj )}(hhh]h)}(hThe LRU to initializeh]hThe LRU to initialize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjtubeh}(h]h ]h"]h$]h&]uh1jhjhMhjqubj)}(h2``struct mutex *lock`` The lock protecting the LRUh](j)}(h``struct mutex *lock``h]j)}(hjh]hstruct mutex *lock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(hThe lock protecting the LRUh]hThe lock protecting the LRU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjqubeh}(h]h ]h"]h$]h&]uh1jhjUubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_lru_remove (C function)c.drm_gem_lru_removehNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h4void drm_gem_lru_remove (struct drm_gem_object *obj)h]j>)}(h3void drm_gem_lru_remove(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhM ubjg)}(hdrm_gem_lru_removeh]jm)}(hdrm_gem_lru_removeh]hdrm_gem_lru_remove}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhM ubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjFubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j )}jj0sbc.drm_gem_lru_removeasbuh1hhjFubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjFubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM hjhhubj)}(hhh]h)}(h(remove object from whatever LRU it is inh]h(remove object from whatever LRU it is in}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` The GEM object to remove from current LRU **Description** If the object is currently in any LRU, remove it.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj)}(hhh]j)}(hI``struct drm_gem_object *obj`` The GEM object to remove from current LRU h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj )}(hhh]h)}(h)The GEM object to remove from current LRUh]h)The GEM object to remove from current LRU}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hMhj$ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj#hMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjIh]h Description}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubh)}(h1If the object is currently in any LRU, remove it.h]h1If the object is currently in any LRU, remove it.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_gem_lru_move_tail_locked (C function)c.drm_gem_lru_move_tail_lockedhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hWvoid drm_gem_lru_move_tail_locked (struct drm_gem_lru *lru, struct drm_gem_object *obj)h]j>)}(hVvoid drm_gem_lru_move_tail_locked(struct drm_gem_lru *lru, struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM ubjg)}(hdrm_gem_lru_move_tail_lockedh]jm)}(hdrm_gem_lru_move_tail_lockedh]hdrm_gem_lru_move_tail_locked}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM ubj)}(h5(struct drm_gem_lru *lru, struct drm_gem_object *obj)h](j)}(hstruct drm_gem_lru *lruh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gem_lruh]h drm_gem_lru}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_lru_move_tail_lockedasbuh1hhjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hlruh]hlru}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj=hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj9ubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj9ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]modnameN classnameNjj)}j]jc.drm_gem_lru_move_tail_lockedasbuh1hhj9ubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj9ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj9ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM hjhhubj)}(hhh]h)}(h&move the object to the tail of the LRUh]h&move the object to the tail of the LRU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h**Parameters** ``struct drm_gem_lru *lru`` The LRU to move the object into. ``struct drm_gem_object *obj`` The GEM object to move into this LRU **Description** Like :c:type:`drm_gem_lru_move_tail` but lru lock must be heldh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM$hjubj)}(hhh](j)}(h=``struct drm_gem_lru *lru`` The LRU to move the object into. h](j)}(h``struct drm_gem_lru *lru``h]j)}(hjh]hstruct drm_gem_lru *lru}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM$hjubj )}(hhh]h)}(h The LRU to move the object into.h]h The LRU to move the object into.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM$hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM$hjubj)}(hD``struct drm_gem_object *obj`` The GEM object to move into this LRU h](j)}(h``struct drm_gem_object *obj``h]j)}(hj8h]hstruct drm_gem_object *obj}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM%hj2ubj )}(hhh]h)}(h$The GEM object to move into this LRUh]h$The GEM object to move into this LRU}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhM%hjNubah}(h]h ]h"]h$]h&]uh1j hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhM%hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjsh]h Description}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM'hjubh)}(h>Like :c:type:`drm_gem_lru_move_tail` but lru lock must be heldh](hLike }(hjhhhNhNubh)}(h:c:type:`drm_gem_lru_move_tail`h]j)}(hjh]hdrm_gem_lru_move_tail}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_lru_move_tailuh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM!hjubh but lru lock must be held}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM!hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_lru_move_tail (C function)c.drm_gem_lru_move_tailhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hPvoid drm_gem_lru_move_tail (struct drm_gem_lru *lru, struct drm_gem_object *obj)h]j>)}(hOvoid drm_gem_lru_move_tail(struct drm_gem_lru *lru, struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM6ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM6ubjg)}(hdrm_gem_lru_move_tailh]jm)}(hdrm_gem_lru_move_tailh]hdrm_gem_lru_move_tail}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM6ubj)}(h5(struct drm_gem_lru *lru, struct drm_gem_object *obj)h](j)}(hstruct drm_gem_lru *lruh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gem_lruh]h drm_gem_lru}(hj6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj3ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj8modnameN classnameNjj)}j]j )}jjsbc.drm_gem_lru_move_tailasbuh1hhjubjV)}(h h]h }(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjdhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hlruh]hlru}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jRc.drm_gem_lru_move_tailasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM6ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM6ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM6hjhhubj)}(hhh]h)}(h&move the object to the tail of the LRUh]h&move the object to the tail of the LRU}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM6hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM6ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj#jj#jjjuh1j2hhhjuhNhNubj)}(hXL**Parameters** ``struct drm_gem_lru *lru`` The LRU to move the object into. ``struct drm_gem_object *obj`` The GEM object to move into this LRU **Description** If the object is already in this LRU it will be moved to the tail. Otherwise it will be removed from whichever other LRU it is in (if any) and moved into this LRU.h](h)}(h**Parameters**h]j)}(hj-h]h Parameters}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM:hj'ubj)}(hhh](j)}(h=``struct drm_gem_lru *lru`` The LRU to move the object into. h](j)}(h``struct drm_gem_lru *lru``h]j)}(hjLh]hstruct drm_gem_lru *lru}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM<hjFubj )}(hhh]h)}(h The LRU to move the object into.h]h The LRU to move the object into.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahM<hjbubah}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhjahM<hjCubj)}(hD``struct drm_gem_object *obj`` The GEM object to move into this LRU h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM=hjubj )}(hhh]h)}(h$The GEM object to move into this LRUh]h$The GEM object to move into this LRU}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM=hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM=hjCubeh}(h]h ]h"]h$]h&]uh1jhj'ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM?hj'ubh)}(hIf the object is already in this LRU it will be moved to the tail. Otherwise it will be removed from whichever other LRU it is in (if any) and moved into this LRU.h]hIf the object is already in this LRU it will be moved to the tail. Otherwise it will be removed from whichever other LRU it is in (if any) and moved into this LRU.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chM7hj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_lru_scan (C function)c.drm_gem_lru_scanhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(hunsigned long drm_gem_lru_scan (struct drm_gem_lru *lru, unsigned int nr_to_scan, unsigned long *remaining, bool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket), struct ww_acquire_ctx *ticket)h]j>)}(hunsigned long drm_gem_lru_scan(struct drm_gem_lru *lru, unsigned int nr_to_scan, unsigned long *remaining, bool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket), struct ww_acquire_ctx *ticket)h](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMIubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMIubj)}(hlongh]hlong}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMIubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMIubjg)}(hdrm_gem_lru_scanh]jm)}(hdrm_gem_lru_scanh]hdrm_gem_lru_scan}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMIubj)}(h(struct drm_gem_lru *lru, unsigned int nr_to_scan, unsigned long *remaining, bool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket), struct ww_acquire_ctx *ticket)h](j)}(hstruct drm_gem_lru *lruh](jD)}(hjh]hstruct}(hj^hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjZubjV)}(h h]h }(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubh)}(hhh]jm)}(h drm_gem_lruh]h drm_gem_lru}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~modnameN classnameNjj)}j]j )}jjDsbc.drm_gem_lru_scanasbuh1hhjZubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjZubjm)}(hlruh]hlru}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjVubj)}(hunsigned int nr_to_scanh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h nr_to_scanh]h nr_to_scan}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjVubj)}(hunsigned long *remainingh](j)}(hunsignedh]hunsigned}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjYhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h remainingh]h remaining}(hjfhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjVubj)}(hIbool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(h(h]h(}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(hshrinkh]hshrink}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubj4)}(h)h]h)}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubj4)}(hjh]h(}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_lru_scanasbuh1hhj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(hj7h]h*}(hj(hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(hobjh]hobj}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubj4)}(h,h]h,}(hjChhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubjD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{ubjV)}(h h]h }(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubh)}(hhh]jm)}(hww_acquire_ctxh]hww_acquire_ctx}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_lru_scanasbuh1hhj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(hticketh]hticket}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubj4)}(hjh]h)}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjVubj)}(hstruct ww_acquire_ctx *ticketh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hww_acquire_ctxh]hww_acquire_ctx}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_lru_scanasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj&hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hticketh]hticket}(hj3hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjVubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMIubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMIubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMIhjhhubj)}(hhh]h)}(h)helper to implement shrinker.scan_objectsh]h)helper to implement shrinker.scan_objects}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMIhjZhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMIubeh}(h]h ](jfunctioneh"]h$]h&]jjjjujjujjjuh1j2hhhjuhNhNubj)}(hX**Parameters** ``struct drm_gem_lru *lru`` The LRU to scan ``unsigned int nr_to_scan`` The number of pages to try to reclaim ``unsigned long *remaining`` The number of pages left to reclaim, should be initialized by caller ``bool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket)`` Callback to try to shrink/reclaim the object. ``struct ww_acquire_ctx *ticket`` Optional ww_acquire_ctx context to use for locking **Description** If the shrink callback succeeds, it is expected that the driver move the object out of this LRU. If the LRU possibly contain active buffers, it is the responsibility of the shrink callback to check for this (ie. dma_resv_test_signaled()) or if necessary block until the buffer becomes idle.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMMhjyubj)}(hhh](j)}(h,``struct drm_gem_lru *lru`` The LRU to scan h](j)}(h``struct drm_gem_lru *lru``h]j)}(hjh]hstruct drm_gem_lru *lru}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMRhjubj )}(hhh]h)}(hThe LRU to scanh]hThe LRU to scan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMRhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMRhjubj)}(hB``unsigned int nr_to_scan`` The number of pages to try to reclaim h](j)}(h``unsigned int nr_to_scan``h]j)}(hjh]hunsigned int nr_to_scan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMShjubj )}(hhh]h)}(h%The number of pages to try to reclaimh]h%The number of pages to try to reclaim}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMShjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMShjubj)}(hb``unsigned long *remaining`` The number of pages left to reclaim, should be initialized by caller h](j)}(h``unsigned long *remaining``h]j)}(hjh]hunsigned long *remaining}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMThj ubj )}(hhh]h)}(hDThe number of pages left to reclaim, should be initialized by callerh]hDThe number of pages left to reclaim, should be initialized by caller}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMThj&ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj%hMThjubj)}(h|``bool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket)`` Callback to try to shrink/reclaim the object. h](j)}(hM``bool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket)``h]j)}(hjIh]hIbool (*shrink)(struct drm_gem_object *obj, struct ww_acquire_ctx *ticket)}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMUhjCubj )}(hhh]h)}(h-Callback to try to shrink/reclaim the object.h]h-Callback to try to shrink/reclaim the object.}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hMUhj_ubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hMUhjubj)}(hU``struct ww_acquire_ctx *ticket`` Optional ww_acquire_ctx context to use for locking h](j)}(h!``struct ww_acquire_ctx *ticket``h]j)}(hjh]hstruct ww_acquire_ctx *ticket}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMVhj|ubj )}(hhh]h)}(h2Optional ww_acquire_ctx context to use for lockingh]h2Optional ww_acquire_ctx context to use for locking}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMVhjubah}(h]h ]h"]h$]h&]uh1j hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhMVhjubeh}(h]h ]h"]h$]h&]uh1jhjyubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMXhjyubh)}(h`If the shrink callback succeeds, it is expected that the driver move the object out of this LRU.h]h`If the shrink callback succeeds, it is expected that the driver move the object out of this LRU.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMJhjyubh)}(hIf the LRU possibly contain active buffers, it is the responsibility of the shrink callback to check for this (ie. dma_resv_test_signaled()) or if necessary block until the buffer becomes idle.h]hIf the LRU possibly contain active buffers, it is the responsibility of the shrink callback to check for this (ie. dma_resv_test_signaled()) or if necessary block until the buffer becomes idle.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMMhjyubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gem_evict_locked (C function)c.drm_gem_evict_lockedhNtauh1j!hjuhhhNhNubj3)}(hhh](j8)}(h5int drm_gem_evict_locked (struct drm_gem_object *obj)h]j>)}(h4int drm_gem_evict_locked(struct drm_gem_object *obj)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhMubjg)}(hdrm_gem_evict_lockedh]jm)}(hdrm_gem_evict_lockedh]hdrm_gem_evict_locked}(hj2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhMubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjNhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjJubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjlhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjiubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjnmodnameN classnameNjj)}j]j )}jj4sbc.drm_gem_evict_lockedasbuh1hhjJubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjJubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjJubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjFubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h.helper to evict backing pages for a GEM objecth]h.helper to evict backing pages for a GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjuhNhNubj)}(h@**Parameters** ``struct drm_gem_object *obj`` obj in questionh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhjubj)}(hhh]j)}(h.``struct drm_gem_object *obj`` obj in questionh](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj ubj )}(hhh]h)}(hobj in questionh]hobj in question}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:372: ./drivers/gpu/drm/drm_gem.chMhj(ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhj ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjuhhhNhNubeh}(h]gem-function-referenceah ]h"]gem function referenceah$]h&]uh1hhjzhhhhhMoubh)}(hhh](h)}(h"GEM DMA Helper Functions Referenceh]h"GEM DMA Helper Functions Reference}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hhhhhMxubh)}(hThe DRM GEM/DMA helpers are a means to provide buffer objects that are presented to the device as a contiguous chunk of memory. This is useful for devices that do not support scatter-gather DMA (either directly or by using an intimately attached IOMMU).h]hThe DRM GEM/DMA helpers are a means to provide buffer objects that are presented to the device as a contiguous chunk of memory. This is useful for devices that do not support scatter-gather DMA (either directly or by using an intimately attached IOMMU).}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:378: ./drivers/gpu/drm/drm_gem_dma_helper.chKhj[hhubh)}(hXFor devices that access the memory bus through an (external) IOMMU then the buffer objects are allocated using a traditional page-based allocator and may be scattered through physical memory. However they are contiguous in the IOVA space so appear contiguous to devices using them.h]hXFor devices that access the memory bus through an (external) IOMMU then the buffer objects are allocated using a traditional page-based allocator and may be scattered through physical memory. However they are contiguous in the IOVA space so appear contiguous to devices using them.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:378: ./drivers/gpu/drm/drm_gem_dma_helper.chK"hj[hhubh)}(hrFor other devices then the helpers rely on CMA to provide buffer objects that are physically contiguous in memory.h]hrFor other devices then the helpers rely on CMA to provide buffer objects that are physically contiguous in memory.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:378: ./drivers/gpu/drm/drm_gem_dma_helper.chK(hj[hhubh)}(hFor GEM callback helpers in struct :c:type:`drm_gem_object` functions, see likewise named functions with an _object_ infix (e.g., drm_gem_dma_object_vmap() wraps drm_gem_dma_vmap()). These helpers perform the necessary type conversion.h](h#For GEM callback helpers in struct }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:378: ./drivers/gpu/drm/drm_gem_dma_helper.chK+hjubh functions, see likewise named functions with an _object_ infix (e.g., drm_gem_dma_object_vmap() wraps drm_gem_dma_vmap()). These helpers perform the necessary type conversion.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhK+hj[hhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_dma_object (C struct)c.drm_gem_dma_objecthNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hdrm_gem_dma_objecth]j>)}(hstruct drm_gem_dma_objecth](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_gem_dma_objecth]jm)}(hjh]hdrm_gem_dma_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h+GEM object backed by DMA memory allocationsh]h+GEM object backed by DMA memory allocations}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK hj#hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjj>jj>jjjuh1j2hhhj[hNhNubj)}(hXB**Definition**:: struct drm_gem_dma_object { struct drm_gem_object base; dma_addr_t dma_addr; struct sg_table *sgt; void *vaddr; bool map_noncoherent; }; **Members** ``base`` base GEM object ``dma_addr`` DMA address of the backing memory ``sgt`` scatter/gather table for imported PRIME buffers. The table can have more than one entry but they are guaranteed to have contiguous DMA addresses. ``vaddr`` kernel virtual address of the backing memory ``map_noncoherent`` if true, the GEM object is backed by non-coherent memoryh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubh:}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjBubjT)}(hstruct drm_gem_dma_object { struct drm_gem_object base; dma_addr_t dma_addr; struct sg_table *sgt; void *vaddr; bool map_noncoherent; };h]hstruct drm_gem_dma_object { struct drm_gem_object base; dma_addr_t dma_addr; struct sg_table *sgt; void *vaddr; bool map_noncoherent; };}hjcsbah}(h]h ]h"]h$]h&]jjuh1jSh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjBubh)}(h **Members**h]j)}(hjth]hMembers}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjBubj)}(hhh](j)}(h``base`` base GEM object h](j)}(h``base``h]j)}(hjh]hbase}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubj )}(hhh]h)}(hbase GEM objecth]hbase GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h/``dma_addr`` DMA address of the backing memory h](j)}(h ``dma_addr``h]j)}(hjh]hdma_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubj )}(hhh]h)}(h!DMA address of the backing memoryh]h!DMA address of the backing memory}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``sgt`` scatter/gather table for imported PRIME buffers. The table can have more than one entry but they are guaranteed to have contiguous DMA addresses. h](j)}(h``sgt``h]j)}(hjh]hsgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubj )}(hhh]h)}(hscatter/gather table for imported PRIME buffers. The table can have more than one entry but they are guaranteed to have contiguous DMA addresses.h]hscatter/gather table for imported PRIME buffers. The table can have more than one entry but they are guaranteed to have contiguous DMA addresses.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h7``vaddr`` kernel virtual address of the backing memory h](j)}(h ``vaddr``h]j)}(hj?h]hvaddr}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj9ubj )}(hhh]h)}(h,kernel virtual address of the backing memoryh]h,kernel virtual address of the backing memory}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThKhjUubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThKhjubj)}(hL``map_noncoherent`` if true, the GEM object is backed by non-coherent memoryh](j)}(h``map_noncoherent``h]j)}(hjxh]hmap_noncoherent}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjrubj )}(hhh]h)}(h8if true, the GEM object is backed by non-coherent memoryh]h8if true, the GEM object is backed by non-coherent memory}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gem_dma_object_free (C function)c.drm_gem_dma_object_freehNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(h9void drm_gem_dma_object_free (struct drm_gem_object *obj)h]j>)}(h8void drm_gem_dma_object_free(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK4ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhK4ubjg)}(hdrm_gem_dma_object_freeh]jm)}(hdrm_gem_dma_object_freeh]hdrm_gem_dma_object_free}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhK4ubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj/modnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_object_freeasbuh1hhj ubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj[hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hobjh]hobj}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhK4ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhK4ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhK4hjhhubj)}(hhh]h)}(h*GEM object function for drm_gem_dma_free()h]h*GEM object function for drm_gem_dma_free()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK4hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhK4ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_gem_object *obj`` GEM object to free **Description** This function wraps drm_gem_dma_free_object(). Drivers that employ the DMA helpers should use it as their :c:type:`drm_gem_object_funcs.free ` handler.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK8hjubj)}(hhh]j)}(h2``struct drm_gem_object *obj`` GEM object to free h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK5hjubj )}(hhh]h)}(hGEM object to freeh]hGEM object to free}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK5hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK5hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK7hjubh)}(hThis function wraps drm_gem_dma_free_object(). Drivers that employ the DMA helpers should use it as their :c:type:`drm_gem_object_funcs.free ` handler.h](hjThis function wraps drm_gem_dma_free_object(). Drivers that employ the DMA helpers should use it as their }(hj$hhhNhNubh)}(h::c:type:`drm_gem_object_funcs.free `h]j)}(hj.h]hdrm_gem_object_funcs.free}(hj0hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK6hj$ubh handler.}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjKhK6hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gem_dma_object_print_info (C function)c.drm_gem_dma_object_print_infohNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hqvoid drm_gem_dma_object_print_info (struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj)h]j>)}(hpvoid drm_gem_dma_object_print_info(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKBubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjrhhhjhKBubjg)}(hdrm_gem_dma_object_print_infoh]jm)}(hdrm_gem_dma_object_print_infoh]hdrm_gem_dma_object_print_info}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjrhhhjhKBubj)}(hN(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj)h](j)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_object_print_infoasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hj@h]hp}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int indenth](j)}(hunsignedh]hunsigned}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj)}(hinth]hint}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(hindenth]hindent}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const struct drm_gem_object *objh](jD)}(hj h]hconst}(hjuhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_dma_object_print_infoasbuh1hhjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjqubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjrhhhjhKBubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjnhhhjhKBubah}(h]jiah ](jjeh"]h$]h&]jj)jhuh1j7hjhKBhjkhhubj)}(hhh]h)}(h3Print :c:type:`drm_gem_dma_object` info for debugfsh](hPrint }(hjhhhNhNubh)}(h:c:type:`drm_gem_dma_object`h]j)}(hjh]hdrm_gem_dma_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gem_dma_object_print_infoasbjMdrm_gem_dma_objectuh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh info for debugfs}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKBhjhhubah}(h]h ]h"]h$]h&]uh1jhjkhhhjhKBubeh}(h]h ](jfunctioneh"]h$]h&]jjjjRjjRjjjuh1j2hhhj[hNhNubj)}(hXk**Parameters** ``struct drm_printer *p`` DRM printer ``unsigned int indent`` Tab indentation level ``const struct drm_gem_object *obj`` GEM object **Description** This function wraps drm_gem_dma_print_info(). Drivers that employ the DMA helpers should use this function as their :c:type:`drm_gem_object_funcs.print_info ` handler.h](h)}(h**Parameters**h]j)}(hj\h]h Parameters}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKFhjVubj)}(hhh](j)}(h&``struct drm_printer *p`` DRM printer h](j)}(h``struct drm_printer *p``h]j)}(hj{h]hstruct drm_printer *p}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKChjuubj )}(hhh]h)}(h DRM printerh]h DRM printer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKChjubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjhKChjrubj)}(h.``unsigned int indent`` Tab indentation level h](j)}(h``unsigned int indent``h]j)}(hjh]hunsigned int indent}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKDhjubj )}(hhh]h)}(hTab indentation levelh]hTab indentation level}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKDhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKDhjrubj)}(h0``const struct drm_gem_object *obj`` GEM object h](j)}(h$``const struct drm_gem_object *obj``h]j)}(hjh]h const struct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKEhjubj )}(hhh]h)}(h GEM objecth]h GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKEhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKEhjrubeh}(h]h ]h"]h$]h&]uh1jhjVubh)}(h**Description**h]j)}(hj(h]h Description}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKGhjVubh)}(hThis function wraps drm_gem_dma_print_info(). Drivers that employ the DMA helpers should use this function as their :c:type:`drm_gem_object_funcs.print_info ` handler.h](htThis function wraps drm_gem_dma_print_info(). Drivers that employ the DMA helpers should use this function as their }(hj>hhhNhNubh)}(h@:c:type:`drm_gem_object_funcs.print_info `h]j)}(hjHh]hdrm_gem_object_funcs.print_info}(hjJhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKFhj>ubh handler.}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjehKFhjVubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.,drm_gem_dma_object_get_sg_table (C function)!c.drm_gem_dma_object_get_sg_tablehNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hNstruct sg_table * drm_gem_dma_object_get_sg_table (struct drm_gem_object *obj)h]j>)}(hLstruct sg_table *drm_gem_dma_object_get_sg_table(struct drm_gem_object *obj)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKSubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKSubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gem_dma_object_get_sg_tablesb!c.drm_gem_dma_object_get_sg_tableasbuh1hhjhhhjhKSubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKSubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhKSubjg)}(hdrm_gem_dma_object_get_sg_tableh]jm)}(hjh]hdrm_gem_dma_object_get_sg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKSubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j!c.drm_gem_dma_object_get_sg_tableasbuh1hhjubjV)}(h h]h }(hjFhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjThhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKSubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKSubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKShjhhubj)}(hhh]h)}(h2GEM object function for drm_gem_dma_get_sg_table()h]h2GEM object function for drm_gem_dma_get_sg_table()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKShjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKSubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX[**Parameters** ``struct drm_gem_object *obj`` GEM object **Description** This function wraps drm_gem_dma_get_sg_table(). Drivers that employ the DMA helpers should use it as their :c:type:`drm_gem_object_funcs.get_sg_table ` handler. **Return** A pointer to the scatter/gather table of pinned pages or NULL on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKWhjubj)}(hhh]j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKThjubj )}(hhh]h)}(h GEM objecth]h GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKThjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKThjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKVhjubh)}(hThis function wraps drm_gem_dma_get_sg_table(). Drivers that employ the DMA helpers should use it as their :c:type:`drm_gem_object_funcs.get_sg_table ` handler.h](hkThis function wraps drm_gem_dma_get_sg_table(). Drivers that employ the DMA helpers should use it as their }(hjhhhNhNubh)}(hB:c:type:`drm_gem_object_funcs.get_sg_table `h]j)}(hj'h]h!drm_gem_object_funcs.get_sg_table}(hj)hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKUhjubh handler.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjDhKUhjubh)}(h **Return**h]j)}(hjQh]hReturn}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKXhjubh)}(hIA pointer to the scatter/gather table of pinned pages or NULL on failure.h]hIA pointer to the scatter/gather table of pinned pages or NULL on failure.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKYhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gem_dma_object_mmap (C function)c.drm_gem_dma_object_mmaphNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hTint drm_gem_dma_object_mmap (struct drm_gem_object *obj, struct vm_area_struct *vma)h]j>)}(hSint drm_gem_dma_object_mmap(struct drm_gem_object *obj, struct vm_area_struct *vma)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKwubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKwubjg)}(hdrm_gem_dma_object_mmaph]jm)}(hdrm_gem_dma_object_mmaph]hdrm_gem_dma_object_mmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKwubj)}(h8(struct drm_gem_object *obj, struct vm_area_struct *vma)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_object_mmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjEhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjAubjV)}(h h]h }(hjRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjchhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjemodnameN classnameNjj)}j]j c.drm_gem_dma_object_mmapasbuh1hhjAubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjAubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKwubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKwubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKwhjhhubj)}(hhh]h)}(h*GEM object function for drm_gem_dma_mmap()h]h*GEM object function for drm_gem_dma_mmap()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKwhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKwubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hXs**Parameters** ``struct drm_gem_object *obj`` GEM object ``struct vm_area_struct *vma`` VMA for the area to be mapped **Description** This function wraps drm_gem_dma_mmap(). Drivers that employ the dma helpers should use it as their :c:type:`drm_gem_object_funcs.mmap ` handler. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK{hjubj)}(hhh](j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKxhjubj )}(hhh]h)}(h GEM objecth]h GEM object}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKxhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKxhjubj)}(h=``struct vm_area_struct *vma`` VMA for the area to be mapped h](j)}(h``struct vm_area_struct *vma``h]j)}(hj@h]hstruct vm_area_struct *vma}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKyhj:ubj )}(hhh]h)}(hVMA for the area to be mappedh]hVMA for the area to be mapped}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhKyhjVubah}(h]h ]h"]h$]h&]uh1j hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhKyhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj{h]h Description}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK{hjubh)}(hThis function wraps drm_gem_dma_mmap(). Drivers that employ the dma helpers should use it as their :c:type:`drm_gem_object_funcs.mmap ` handler.h](hcThis function wraps drm_gem_dma_mmap(). Drivers that employ the dma helpers should use it as their }(hjhhhNhNubh)}(h::c:type:`drm_gem_object_funcs.mmap `h]j)}(hjh]hdrm_gem_object_funcs.mmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKzhjubh handler.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKzhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK}hjubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhK~hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.1DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE (C macro))c.DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATEhNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(h'DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATEh]j>)}(h'DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATEh]jg)}(h'DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATEh]jm)}(hjh]h'DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj!hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj!hKhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhj!hKubeh}(h]h ](jmacroeh"]h$]h&]jjjj:jj:jjjuh1j2hhhj[hNhNubh)}(h>``DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE (dumb_create_func)``h]j)}(hj@h]h:DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE (dumb_create_func)}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj[hhubj)}(hDMA GEM driver operations h]h)}(hDMA GEM driver operationsh]hDMA GEM driver operations}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjVubah}(h]h ]h"]h$]h&]uh1jhjhhKhj[hhubj)}(hX **Parameters** ``dumb_create_func`` callback function for .dumb_create **Description** This macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure. This macro is a variant of DRM_GEM_DMA_DRIVER_OPS for drivers that override the default implementation of :c:type:`struct rm_driver `.dumb_create. Use DRM_GEM_DMA_DRIVER_OPS if possible. Drivers that require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE() instead.h](h)}(h**Parameters**h]j)}(hjuh]h Parameters}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjoubj)}(hhh]j)}(h8``dumb_create_func`` callback function for .dumb_create h](j)}(h``dumb_create_func``h]j)}(hjh]hdumb_create_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubj )}(hhh]h)}(h"callback function for .dumb_createh]h"callback function for .dumb_create}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjoubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjoubh)}(hlThis macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure.h](hMThis macro provides a shortcut for setting the default GEM operations in the }(hjhhhNhNubh)}(h:c:type:`drm_driver`h]j)}(hjh]h drm_driver}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh structure.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hKhjoubh)}(hXCThis macro is a variant of DRM_GEM_DMA_DRIVER_OPS for drivers that override the default implementation of :c:type:`struct rm_driver `.dumb_create. Use DRM_GEM_DMA_DRIVER_OPS if possible. Drivers that require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE() instead.h](hjThis macro is a variant of DRM_GEM_DMA_DRIVER_OPS for drivers that override the default implementation of }(hjhhhNhNubh)}(h&:c:type:`struct rm_driver `h]j)}(hj!h]hstruct rm_driver}(hj#hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM rm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh.dumb_create. Use DRM_GEM_DMA_DRIVER_OPS if possible. Drivers that require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE() instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj>hKhjoubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. DRM_GEM_DMA_DRIVER_OPS (C macro)c.DRM_GEM_DMA_DRIVER_OPShNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hDRM_GEM_DMA_DRIVER_OPSh]j>)}(hDRM_GEM_DMA_DRIVER_OPSh]jg)}(hDRM_GEM_DMA_DRIVER_OPSh]jm)}(hjch]hDRM_GEM_DMA_DRIVER_OPS}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjiubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjehhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjahhhjhKubah}(h]j\ah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhj^hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj^hhhjhKubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubh)}(h``DRM_GEM_DMA_DRIVER_OPS``h]j)}(hjh]hDRM_GEM_DMA_DRIVER_OPS}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj[hhubj)}(hX DMA GEM driver operations **Description** This macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure. Drivers that come with their own implementation of :c:type:`struct drm_driver `.dumb_create should use DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE() instead. Use DRM_GEM_DMA_DRIVER_OPS if possible. Drivers that require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_VMAP instead. h](j)}(hDMA GEM driver operations h]h)}(hDMA GEM driver operationsh]hDMA GEM driver operations}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjhKhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh)}(hlThis macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure.h](hMThis macro provides a shortcut for setting the default GEM operations in the }(hjhhhNhNubh)}(h:c:type:`drm_driver`h]j)}(hjh]h drm_driver}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh structure.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjubh)}(hX8Drivers that come with their own implementation of :c:type:`struct drm_driver `.dumb_create should use DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE() instead. Use DRM_GEM_DMA_DRIVER_OPS if possible. Drivers that require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_VMAP instead.h](h3Drivers that come with their own implementation of }(hjhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hj&h]hstruct drm_driver}(hj(hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh.dumb_create should use DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE() instead. Use DRM_GEM_DMA_DRIVER_OPS if possible. Drivers that require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_VMAP instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChKhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj[hhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.6DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE (C macro).c.DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATEhNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(h,DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATEh]j>)}(h,DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATEh]jg)}(h,DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATEh]jm)}(hjgh]h,DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjihhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjehhhjhKubah}(h]j`ah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjbhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjbhhhjhKubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubh)}(hC``DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE (dumb_create_func)``h]j)}(hjh]h?DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE (dumb_create_func)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj[hhubj)}(hCDMA GEM driver operations ensuring a virtual address on the buffer h]h)}(hBDMA GEM driver operations ensuring a virtual address on the bufferh]hBDMA GEM driver operations ensuring a virtual address on the buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjhKhj[hhubj)}(hX^**Parameters** ``dumb_create_func`` callback function for .dumb_create **Description** This macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure for drivers that need the virtual address also on imported buffers. This macro is a variant of DRM_GEM_DMA_DRIVER_OPS_VMAP for drivers that override the default implementation of :c:type:`struct drm_driver `.dumb_create. Use DRM_GEM_DMA_DRIVER_OPS_VMAP if possible. Drivers that do not require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE() instead.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubj)}(hhh]j)}(h8``dumb_create_func`` callback function for .dumb_create h](j)}(h``dumb_create_func``h]j)}(hjh]hdumb_create_func}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubj )}(hhh]h)}(h"callback function for .dumb_createh]h"callback function for .dumb_create}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hKhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj2h]h Description}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh)}(hThis macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure for drivers that need the virtual address also on imported buffers.h](hMThis macro provides a shortcut for setting the default GEM operations in the }(hjHhhhNhNubh)}(h:c:type:`drm_driver`h]j)}(hjRh]h drm_driver}(hjThhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjHubhN structure for drivers that need the virtual address also on imported buffers.}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjohKhjubh)}(hXQThis macro is a variant of DRM_GEM_DMA_DRIVER_OPS_VMAP for drivers that override the default implementation of :c:type:`struct drm_driver `.dumb_create. Use DRM_GEM_DMA_DRIVER_OPS_VMAP if possible. Drivers that do not require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE() instead.h](hoThis macro is a variant of DRM_GEM_DMA_DRIVER_OPS_VMAP for drivers that override the default implementation of }(hjzhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjh]hstruct drm_driver}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjzubh.dumb_create. Use DRM_GEM_DMA_DRIVER_OPS_VMAP if possible. Drivers that do not require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS_WITH_DUMB_CREATE() instead.}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%DRM_GEM_DMA_DRIVER_OPS_VMAP (C macro)c.DRM_GEM_DMA_DRIVER_OPS_VMAPhNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hDRM_GEM_DMA_DRIVER_OPS_VMAPh]j>)}(hDRM_GEM_DMA_DRIVER_OPS_VMAPh]jg)}(hDRM_GEM_DMA_DRIVER_OPS_VMAPh]jm)}(hjh]hDRM_GEM_DMA_DRIVER_OPS_VMAP}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubh)}(h``DRM_GEM_DMA_DRIVER_OPS_VMAP``h]j)}(hjh]hDRM_GEM_DMA_DRIVER_OPS_VMAP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj[hhubj)}(hXM DMA GEM driver operations ensuring a virtual address on the buffer **Description** This macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure for drivers that need the virtual address also on imported buffers. Drivers that come with their own implementation of :c:type:`struct drm_driver `.dumb_create should use DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE() instead. Use DRM_GEM_DMA_DRIVER_OPS_VMAP if possible. Drivers that do not require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS instead. h](j)}(hCDMA GEM driver operations ensuring a virtual address on the buffer h]h)}(hBDMA GEM driver operations ensuring a virtual address on the bufferh]hBDMA GEM driver operations ensuring a virtual address on the buffer}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubah}(h]h ]h"]h$]h&]uh1jhj.hKhjubh)}(h**Description**h]j)}(hj7h]h Description}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh)}(hThis macro provides a shortcut for setting the default GEM operations in the :c:type:`drm_driver` structure for drivers that need the virtual address also on imported buffers.h](hMThis macro provides a shortcut for setting the default GEM operations in the }(hjMhhhNhNubh)}(h:c:type:`drm_driver`h]j)}(hjWh]h drm_driver}(hjYhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjMubhN structure for drivers that need the virtual address also on imported buffers.}(hjMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjthKhjubh)}(hXDDrivers that come with their own implementation of :c:type:`struct drm_driver `.dumb_create should use DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE() instead. Use DRM_GEM_DMA_DRIVER_OPS_VMAP if possible. Drivers that do not require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS instead.h](h3Drivers that come with their own implementation of }(hjhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjh]hstruct drm_driver}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh.dumb_create should use DRM_GEM_DMA_DRIVER_OPS_VMAP_WITH_DUMB_CREATE() instead. Use DRM_GEM_DMA_DRIVER_OPS_VMAP if possible. Drivers that do not require a virtual address on imported buffers should use DRM_GEM_DMA_DRIVER_OPS instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhj.hKhj[hhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!DEFINE_DRM_GEM_DMA_FOPS (C macro)c.DEFINE_DRM_GEM_DMA_FOPShNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hDEFINE_DRM_GEM_DMA_FOPSh]j>)}(hDEFINE_DRM_GEM_DMA_FOPSh]jg)}(hDEFINE_DRM_GEM_DMA_FOPSh]jm)}(hjh]hDEFINE_DRM_GEM_DMA_FOPS}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubh)}(h"``DEFINE_DRM_GEM_DMA_FOPS (name)``h]j)}(hjh]hDEFINE_DRM_GEM_DMA_FOPS (name)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj[hhubj)}(h2macro to generate file operations for DMA drivers h]h)}(h1macro to generate file operations for DMA driversh]h1macro to generate file operations for DMA drivers}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubah}(h]h ]h"]h$]h&]uh1jhj.hKhj[hhubj)}(hX7**Parameters** ``name`` name for the generated structure **Description** This macro autogenerates a suitable :c:type:`struct file_operations ` for DMA based drivers, which can be assigned to :c:type:`drm_driver.fops `. Note that this structure cannot be shared between drivers, because it contains a reference to the current module using THIS_MODULE. Note that the declaration is already marked as static - if you need a non-static version of this you're probably doing it wrong and will break the THIS_MODULE reference by accident.h](h)}(h**Parameters**h]j)}(hj;h]h Parameters}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj5ubj)}(hhh]j)}(h*``name`` name for the generated structure h](j)}(h``name``h]j)}(hjZh]hname}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjTubj )}(hhh]h)}(h name for the generated structureh]h name for the generated structure}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohKhjpubah}(h]h ]h"]h$]h&]uh1j hjTubeh}(h]h ]h"]h$]h&]uh1jhjohKhjQubah}(h]h ]h"]h$]h&]uh1jhj5ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj5ubh)}(hX2This macro autogenerates a suitable :c:type:`struct file_operations ` for DMA based drivers, which can be assigned to :c:type:`drm_driver.fops `. Note that this structure cannot be shared between drivers, because it contains a reference to the current module using THIS_MODULE.h](h$This macro autogenerates a suitable }(hjhhhNhNubh)}(h2:c:type:`struct file_operations `h]j)}(hjh]hstruct file_operations}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfile_operationsuh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhjubh1 for DMA based drivers, which can be assigned to }(hjhhhNhNubh)}(h&:c:type:`drm_driver.fops `h]j)}(hjh]hdrm_driver.fops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhjhKhjubh. Note that this structure cannot be shared between drivers, because it contains a reference to the current module using THIS_MODULE.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhj5ubh)}(hNote that the declaration is already marked as static - if you need a non-static version of this you're probably doing it wrong and will break the THIS_MODULE reference by accident.h]hNote that the declaration is already marked as static - if you need a non-static version of this you’re probably doing it wrong and will break the THIS_MODULE reference by accident.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh\/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:381: ./include/drm/drm_gem_dma_helper.hhKhj5ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_dma_create (C function)c.drm_gem_dma_createhNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hTstruct drm_gem_dma_object * drm_gem_dma_create (struct drm_device *drm, size_t size)h]j>)}(hRstruct drm_gem_dma_object *drm_gem_dma_create(struct drm_device *drm, size_t size)h](jD)}(hjh]hstruct}(hj/hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj+hhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKwubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+hhhj<hKwubh)}(hhh]jm)}(hdrm_gem_dma_objecth]hdrm_gem_dma_object}(hjNhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjKubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjPmodnameN classnameNjj)}j]j )}jdrm_gem_dma_createsbc.drm_gem_dma_createasbuh1hhj+hhhj<hKwubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+hhhj<hKwubj4)}(hj7h]h*}(hj}hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj+hhhj<hKwubjg)}(hdrm_gem_dma_createh]jm)}(hjlh]hdrm_gem_dma_create}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj+hhhj<hKwubj)}(h%(struct drm_device *drm, size_t size)h](j)}(hstruct drm_device *drmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jjc.drm_gem_dma_createasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdrmh]hdrm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jjc.drm_gem_dma_createasbuh1hhjubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hsizeh]hsize}(hjHhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj+hhhj<hKwubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj'hhhj<hKwubah}(h]j"ah ](jjeh"]h$]h&]jj)jhuh1j7hj<hKwhj$hhubj)}(hhh]h)}(h&allocate an object with the given sizeh]h&allocate an object with the given size}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKwhjohhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj<hKwubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_device *drm`` DRM device ``size_t size`` size of the object to allocate **Description** This function creates a DMA GEM object and allocates memory as backing store. The allocated memory will occupy a contiguous chunk of bus address space. For devices that are directly connected to the memory bus then the allocated memory will be physically contiguous. For devices that access through an IOMMU, then the allocated memory is not expected to be physically contiguous because having contiguous IOVAs is sufficient to meet a devices DMA requirements. **Return** A struct drm_gem_dma_object * on success or an ERR_PTR()-encoded negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chK{hjubj)}(hhh](j)}(h&``struct drm_device *drm`` DRM device h](j)}(h``struct drm_device *drm``h]j)}(hjh]hstruct drm_device *drm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKxhjubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKxhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKxhjubj)}(h/``size_t size`` size of the object to allocate h](j)}(h``size_t size``h]j)}(hjh]h size_t size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKyhjubj )}(hhh]h)}(hsize of the object to allocateh]hsize of the object to allocate}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKyhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKyhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj'h]h Description}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chK{hjubh)}(hThis function creates a DMA GEM object and allocates memory as backing store. The allocated memory will occupy a contiguous chunk of bus address space.h]hThis function creates a DMA GEM object and allocates memory as backing store. The allocated memory will occupy a contiguous chunk of bus address space.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKzhjubh)}(hX4For devices that are directly connected to the memory bus then the allocated memory will be physically contiguous. For devices that access through an IOMMU, then the allocated memory is not expected to be physically contiguous because having contiguous IOVAs is sufficient to meet a devices DMA requirements.h]hX4For devices that are directly connected to the memory bus then the allocated memory will be physically contiguous. For devices that access through an IOMMU, then the allocated memory is not expected to be physically contiguous because having contiguous IOVAs is sufficient to meet a devices DMA requirements.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chK}hjubh)}(h **Return**h]j)}(hj]h]hReturn}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhjubh)}(h`A struct drm_gem_dma_object * on success or an ERR_PTR()-encoded negative error code on failure.h]h`A struct drm_gem_dma_object * on success or an ERR_PTR()-encoded negative error code on failure.}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_dma_free (C function)c.drm_gem_dma_freehNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(h:void drm_gem_dma_free (struct drm_gem_dma_object *dma_obj)h]j>)}(h9void drm_gem_dma_free(struct drm_gem_dma_object *dma_obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_gem_dma_freeh]jm)}(hdrm_gem_dma_freeh]hdrm_gem_dma_free}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h$(struct drm_gem_dma_object *dma_obj)h]j)}(h"struct drm_gem_dma_object *dma_objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_dma_objecth]hdrm_gem_dma_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_freeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj+hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdma_objh]hdma_obj}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h/free resources associated with a DMA GEM objecth]h/free resources associated with a DMA GEM object}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhj_hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjzjjzjjjuh1j2hhhj[hNhNubj)}(hX>**Parameters** ``struct drm_gem_dma_object *dma_obj`` DMA GEM object to free **Description** This function frees the backing memory of the DMA GEM object, cleans up the GEM object state and frees the memory used to store the object itself. If the buffer is imported and the virtual address is set, it is released.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhj~ubj)}(hhh]j)}(h>``struct drm_gem_dma_object *dma_obj`` DMA GEM object to free h](j)}(h&``struct drm_gem_dma_object *dma_obj``h]j)}(hjh]h"struct drm_gem_dma_object *dma_obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhjubj )}(hhh]h)}(hDMA GEM object to freeh]hDMA GEM object to free}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhj~ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhj~ubh)}(hThis function frees the backing memory of the DMA GEM object, cleans up the GEM object state and frees the memory used to store the object itself. If the buffer is imported and the virtual address is set, it is released.h]hThis function frees the backing memory of the DMA GEM object, cleans up the GEM object state and frees the memory used to store the object itself. If the buffer is imported and the virtual address is set, it is released.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhj~ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.-drm_gem_dma_dumb_create_internal (C function)"c.drm_gem_dma_dumb_create_internalhNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(h|int drm_gem_dma_dumb_create_internal (struct drm_file *file_priv, struct drm_device *drm, struct drm_mode_create_dumb *args)h]j>)}(h{int drm_gem_dma_dumb_create_internal(struct drm_file *file_priv, struct drm_device *drm, struct drm_mode_create_dumb *args)h](j)}(hinth]hint}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj1hKubjg)}(h drm_gem_dma_dumb_create_internalh]jm)}(h drm_gem_dma_dumb_create_internalh]h drm_gem_dma_dumb_create_internal}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj1hKubj)}(hW(struct drm_file *file_priv, struct drm_device *drm, struct drm_mode_create_dumb *args)h](j)}(hstruct drm_file *file_privh](jD)}(hjh]hstruct}(hj`hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj\ubjV)}(h h]h }(hjmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjFsb"c.drm_gem_dma_dumb_create_internalasbuh1hhj\ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj\ubjm)}(h file_privh]h file_priv}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hstruct drm_device *drmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j"c.drm_gem_dma_dumb_create_internalasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdrmh]hdrm}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h!struct drm_mode_create_dumb *argsh](jD)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj>ubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubh)}(hhh]jm)}(hdrm_mode_create_dumbh]hdrm_mode_create_dumb}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]j"c.drm_gem_dma_dumb_create_internalasbuh1hhj>ubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>ubjm)}(hargsh]hargs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj1hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj1hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj1hKhjhhubj)}(hhh]h)}(hcreate a dumb buffer objecth]hcreate a dumb buffer object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj1hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX7**Parameters** ``struct drm_file *file_priv`` DRM file-private structure to create the dumb buffer for ``struct drm_device *drm`` DRM device ``struct drm_mode_create_dumb *args`` IOCTL data **Description** This aligns the pitch and size arguments to the minimum required. This is an internal helper that can be wrapped by a driver to account for hardware with more specific alignment requirements. It should not be used directly as their :c:type:`drm_driver.dumb_create ` callback. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubj)}(hhh](j)}(hX``struct drm_file *file_priv`` DRM file-private structure to create the dumb buffer for h](j)}(h``struct drm_file *file_priv``h]j)}(hjh]hstruct drm_file *file_priv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chKhjubj )}(hhh]h)}(h8DRM file-private structure to create the dumb buffer forh]h8DRM file-private structure to create the dumb buffer for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h&``struct drm_device *drm`` DRM device h](j)}(h``struct drm_device *drm``h]j)}(hj=h]hstruct drm_device *drm}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj7ubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhMhjSubah}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjubj)}(h1``struct drm_mode_create_dumb *args`` IOCTL data h](j)}(h%``struct drm_mode_create_dumb *args``h]j)}(hjvh]h!struct drm_mode_create_dumb *args}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjpubj )}(hhh]h)}(h IOCTL datah]h IOCTL data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubh)}(hXThis aligns the pitch and size arguments to the minimum required. This is an internal helper that can be wrapped by a driver to account for hardware with more specific alignment requirements. It should not be used directly as their :c:type:`drm_driver.dumb_create ` callback.h](hThis aligns the pitch and size arguments to the minimum required. This is an internal helper that can be wrapped by a driver to account for hardware with more specific alignment requirements. It should not be used directly as their }(hjhhhNhNubh)}(h-:c:type:`drm_driver.dumb_create `h]j)}(hjh]hdrm_driver.dumb_create}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gem_dma_dumb_create (C function)c.drm_gem_dma_dumb_createhNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hsint drm_gem_dma_dumb_create (struct drm_file *file_priv, struct drm_device *drm, struct drm_mode_create_dumb *args)h]j>)}(hrint drm_gem_dma_dumb_create(struct drm_file *file_priv, struct drm_device *drm, struct drm_mode_create_dumb *args)h](j)}(hinth]hint}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<hhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<hhhjNhMubjg)}(hdrm_gem_dma_dumb_createh]jm)}(hdrm_gem_dma_dumb_createh]hdrm_gem_dma_dumb_create}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj<hhhjNhMubj)}(hW(struct drm_file *file_priv, struct drm_device *drm, struct drm_mode_create_dumb *args)h](j)}(hstruct drm_file *file_privh](jD)}(hjh]hstruct}(hj}hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjyubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjcsbc.drm_gem_dma_dumb_createasbuh1hhjyubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjyubjm)}(h file_privh]h file_priv}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjuubj)}(hstruct drm_device *drmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_dma_dumb_createasbuh1hhjubjV)}(h h]h }(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj9hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdrmh]hdrm}(hjFhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjuubj)}(h!struct drm_mode_create_dumb *argsh](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj[ubjV)}(h h]h }(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubh)}(hhh]jm)}(hdrm_mode_create_dumbh]hdrm_mode_create_dumb}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_dma_dumb_createasbuh1hhj[ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj[ubjm)}(hargsh]hargs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjuubeh}(h]h ]h"]h$]h&]jjuh1jhj<hhhjNhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj8hhhjNhMubah}(h]j3ah ](jjeh"]h$]h&]jj)jhuh1j7hjNhMhj5hhubj)}(hhh]h)}(hcreate a dumb buffer objecth]hcreate a dumb buffer object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj5hhhjNhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_file *file_priv`` DRM file-private structure to create the dumb buffer for ``struct drm_device *drm`` DRM device ``struct drm_mode_create_dumb *args`` IOCTL data **Description** This function computes the pitch of the dumb buffer and rounds it up to an integer number of bytes per pixel. Drivers for hardware that doesn't have any additional restrictions on the pitch can directly use this function as their :c:type:`drm_driver.dumb_create ` callback. For hardware with additional restrictions, drivers can adjust the fields set up by userspace and pass the IOCTL data along to the drm_gem_dma_dumb_create_internal() function. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM#hjubj)}(hhh](j)}(hX``struct drm_file *file_priv`` DRM file-private structure to create the dumb buffer for h](j)}(h``struct drm_file *file_priv``h]j)}(hj!h]hstruct drm_file *file_priv}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM hjubj )}(hhh]h)}(h8DRM file-private structure to create the dumb buffer forh]h8DRM file-private structure to create the dumb buffer for}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM hj7ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj6hM hjubj)}(h&``struct drm_device *drm`` DRM device h](j)}(h``struct drm_device *drm``h]j)}(hjZh]hstruct drm_device *drm}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM!hjTubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohM!hjpubah}(h]h ]h"]h$]h&]uh1j hjTubeh}(h]h ]h"]h$]h&]uh1jhjohM!hjubj)}(h1``struct drm_mode_create_dumb *args`` IOCTL data h](j)}(h%``struct drm_mode_create_dumb *args``h]j)}(hjh]h!struct drm_mode_create_dumb *args}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM"hjubj )}(hhh]h)}(h IOCTL datah]h IOCTL data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM"hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM$hjubh)}(hXThis function computes the pitch of the dumb buffer and rounds it up to an integer number of bytes per pixel. Drivers for hardware that doesn't have any additional restrictions on the pitch can directly use this function as their :c:type:`drm_driver.dumb_create ` callback.h](hThis function computes the pitch of the dumb buffer and rounds it up to an integer number of bytes per pixel. Drivers for hardware that doesn’t have any additional restrictions on the pitch can directly use this function as their }(hjhhhNhNubh)}(h-:c:type:`drm_driver.dumb_create `h]j)}(hjh]hdrm_driver.dumb_create}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM#hjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hM#hjubh)}(hFor hardware with additional restrictions, drivers can adjust the fields set up by userspace and pass the IOCTL data along to the drm_gem_dma_dumb_create_internal() function.h]hFor hardware with additional restrictions, drivers can adjust the fields set up by userspace and pass the IOCTL data along to the drm_gem_dma_dumb_create_internal() function.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM(hjubh)}(h **Return**h]j)}(hj'h]hReturn}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM,hjubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM-hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gem_dma_get_unmapped_area (C function)c.drm_gem_dma_get_unmapped_areahNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hunsigned long drm_gem_dma_get_unmapped_area (struct file *filp, unsigned long addr, unsigned long len, unsigned long pgoff, unsigned long flags)h]j>)}(hunsigned long drm_gem_dma_get_unmapped_area(struct file *filp, unsigned long addr, unsigned long len, unsigned long pgoff, unsigned long flags)h](j)}(hunsignedh]hunsigned}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMIubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhhjzhMIubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhjzhMIubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhhjzhMIubjg)}(hdrm_gem_dma_get_unmapped_areah]jm)}(hdrm_gem_dma_get_unmapped_areah]hdrm_gem_dma_get_unmapped_area}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhhjzhMIubj)}(hd(struct file *filp, unsigned long addr, unsigned long len, unsigned long pgoff, unsigned long flags)h](j)}(hstruct file *filph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hfileh]hfile}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_get_unmapped_areaasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hfilph]hfilp}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long addrh](j)}(hunsignedh]hunsigned}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj3ubj)}(hlongh]hlong}(hjShhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj3ubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj3ubjm)}(haddrh]haddr}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj3ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long lenh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hlenh]hlen}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long pgoffh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hpgoffh]hpgoff}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long flagsh](j)}(hunsignedh]hunsigned}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubj)}(hlongh]hlong}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj&ubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubjm)}(hflagsh]hflags}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhhjzhMIubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjdhhhjzhMIubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1j7hjzhMIhjahhubj)}(hhh]h)}(h*propose address for mapping in noMMU casesh]h*propose address for mapping in noMMU cases}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMIhjhhubah}(h]h ]h"]h$]h&]uh1jhjahhhjzhMIubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX **Parameters** ``struct file *filp`` file object ``unsigned long addr`` memory address ``unsigned long len`` buffer size ``unsigned long pgoff`` page offset ``unsigned long flags`` memory flags **Description** This function is used in noMMU platforms to propose address mapping for a given buffer. It's intended to be used as a direct handler for the struct :c:type:`file_operations.get_unmapped_area ` operation. **Return** mapping address on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMMhjubj)}(hhh](j)}(h"``struct file *filp`` file object h](j)}(h``struct file *filp``h]j)}(hjh]hstruct file *filp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMJhjubj )}(hhh]h)}(h file objecth]h file object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMJhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMJhjubj)}(h&``unsigned long addr`` memory address h](j)}(h``unsigned long addr``h]j)}(hjh]hunsigned long addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMKhjubj )}(hhh]h)}(hmemory addressh]hmemory address}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMKhjubj)}(h"``unsigned long len`` buffer size h](j)}(h``unsigned long len``h]j)}(hj?h]hunsigned long len}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMLhj9ubj )}(hhh]h)}(h buffer sizeh]h buffer size}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMLhjUubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThMLhjubj)}(h$``unsigned long pgoff`` page offset h](j)}(h``unsigned long pgoff``h]j)}(hjxh]hunsigned long pgoff}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMMhjrubj )}(hhh]h)}(h page offseth]h page offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMMhjubah}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhMMhjubj)}(h%``unsigned long flags`` memory flags h](j)}(h``unsigned long flags``h]j)}(hjh]hunsigned long flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMNhjubj )}(hhh]h)}(h memory flagsh]h memory flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMNhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMNhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMPhjubh)}(hThis function is used in noMMU platforms to propose address mapping for a given buffer. It's intended to be used as a direct handler for the struct :c:type:`file_operations.get_unmapped_area ` operation.h](hThis function is used in noMMU platforms to propose address mapping for a given buffer. It’s intended to be used as a direct handler for the struct }(hjhhhNhNubh)}(h=:c:type:`file_operations.get_unmapped_area `h]j)}(hj h]h!file_operations.get_unmapped_area}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfile_operationsuh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMOhjubh operation.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj)hMOhjubh)}(h **Return**h]j)}(hj6h]hReturn}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMThjubh)}(h?mapping address on success or a negative error code on failure.h]h?mapping address on success or a negative error code on failure.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMUhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gem_dma_print_info (C function)c.drm_gem_dma_print_infohNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hrvoid drm_gem_dma_print_info (const struct drm_gem_dma_object *dma_obj, struct drm_printer *p, unsigned int indent)h]j>)}(hqvoid drm_gem_dma_print_info(const struct drm_gem_dma_object *dma_obj, struct drm_printer *p, unsigned int indent)h](j)}(hvoidh]hvoid}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwhhhjhMubjg)}(hdrm_gem_dma_print_infoh]jm)}(hdrm_gem_dma_print_infoh]hdrm_gem_dma_print_info}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjwhhhjhMubj)}(hV(const struct drm_gem_dma_object *dma_obj, struct drm_printer *p, unsigned int indent)h](j)}(h(const struct drm_gem_dma_object *dma_objh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_dma_objecth]hdrm_gem_dma_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_print_infoasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdma_objh]hdma_obj}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hjEhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjAubjV)}(h h]h }(hjRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hjchhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjemodnameN classnameNjj)}j]j c.drm_gem_dma_print_infoasbuh1hhjAubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjAubjm)}(hj@h]hp}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int indenth](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hindenth]hindent}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjwhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjshhhjhMubah}(h]jnah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjphhubj)}(hhh]h)}(h3Print :c:type:`drm_gem_dma_object` info for debugfsh](hPrint }(hj hhhNhNubh)}(h:c:type:`drm_gem_dma_object`h]j)}(hj h]hdrm_gem_dma_object}(hj" hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j c.drm_gem_dma_print_infoasbjMdrm_gem_dma_objectuh1hhj<hKwhj ubh info for debugfs}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjphhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjV jjV jjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``const struct drm_gem_dma_object *dma_obj`` DMA GEM object ``struct drm_printer *p`` DRM printer ``unsigned int indent`` Tab indentation level **Description** This function prints dma_addr and vaddr for use in e.g. debugfs output.h](h)}(h**Parameters**h]j)}(hj` h]h Parameters}(hjb hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjZ ubj)}(hhh](j)}(h<``const struct drm_gem_dma_object *dma_obj`` DMA GEM object h](j)}(h,``const struct drm_gem_dma_object *dma_obj``h]j)}(hj h]h(const struct drm_gem_dma_object *dma_obj}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj} ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjy ubj )}(hhh]h)}(hDMA GEM objecth]hDMA GEM object}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjy ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjv ubj)}(h&``struct drm_printer *p`` DRM printer h](j)}(h``struct drm_printer *p``h]j)}(hj h]hstruct drm_printer *p}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubj )}(hhh]h)}(h DRM printerh]h DRM printer}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjv ubj)}(h.``unsigned int indent`` Tab indentation level h](j)}(h``unsigned int indent``h]j)}(hj h]hunsigned int indent}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubj )}(hhh]h)}(hTab indentation levelh]hTab indentation level}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjv ubeh}(h]h ]h"]h$]h&]uh1jhjZ ubh)}(h**Description**h]j)}(hj, h]h Description}(hj. hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj* ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjZ ubh)}(hGThis function prints dma_addr and vaddr for use in e.g. debugfs output.h]hGThis function prints dma_addr and vaddr for use in e.g. debugfs output.}(hjB hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjZ ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gem_dma_get_sg_table (C function)c.drm_gem_dma_get_sg_tablehNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hOstruct sg_table * drm_gem_dma_get_sg_table (struct drm_gem_dma_object *dma_obj)h]j>)}(hMstruct sg_table *drm_gem_dma_get_sg_table(struct drm_gem_dma_object *dma_obj)h](jD)}(hjh]hstruct}(hjq hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjm hhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm hhhj~ hMubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jdrm_gem_dma_get_sg_tablesbc.drm_gem_dma_get_sg_tableasbuh1hhjm hhhj~ hMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm hhhj~ hMubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjm hhhj~ hMubjg)}(hdrm_gem_dma_get_sg_tableh]jm)}(hj h]hdrm_gem_dma_get_sg_table}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjm hhhj~ hMubj)}(h$(struct drm_gem_dma_object *dma_obj)h]j)}(h"struct drm_gem_dma_object *dma_objh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_gem_dma_objecth]hdrm_gem_dma_object}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j c.drm_gem_dma_get_sg_tableasbuh1hhj ubjV)}(h h]h }(hj' hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj5 hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hdma_objh]hdma_obj}(hjB hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhjm hhhj~ hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhji hhhj~ hMubah}(h]jd ah ](jjeh"]h$]h&]jj)jhuh1j7hj~ hMhjf hhubj)}(hhh]h)}(hCprovide a scatter/gather table of pinned pages for a DMA GEM objecth]hCprovide a scatter/gather table of pinned pages for a DMA GEM object}(hjl hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhji hhubah}(h]h ]h"]h$]h&]uh1jhjf hhhj~ hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_gem_dma_object *dma_obj`` DMA GEM object **Description** This function exports a scatter/gather table by calling the standard DMA mapping API. **Return** A pointer to the scatter/gather table of pinned pages or NULL on failure.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubj)}(hhh]j)}(h6``struct drm_gem_dma_object *dma_obj`` DMA GEM object h](j)}(h&``struct drm_gem_dma_object *dma_obj``h]j)}(hj h]h"struct drm_gem_dma_object *dma_obj}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubj )}(hhh]h)}(hDMA GEM objecth]hDMA GEM object}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhj ubah}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubh)}(hUThis function exports a scatter/gather table by calling the standard DMA mapping API.h]hUThis function exports a scatter/gather table by calling the standard DMA mapping API.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubh)}(h **Return**h]j)}(hj h]hReturn}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubh)}(hIA pointer to the scatter/gather table of pinned pages or NULL on failure.h]hIA pointer to the scatter/gather table of pinned pages or NULL on failure.}(hj% hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j..drm_gem_dma_prime_import_sg_table (C function)#c.drm_gem_dma_prime_import_sg_tablehNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hstruct drm_gem_object * drm_gem_dma_prime_import_sg_table (struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h]j>)}(hstruct drm_gem_object *drm_gem_dma_prime_import_sg_table(struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h](jD)}(hjh]hstruct}(hjT hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjP hhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMubjV)}(h h]h }(hjb hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjP hhhja hMubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjs hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjp ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetju modnameN classnameNjj)}j]j )}j!drm_gem_dma_prime_import_sg_tablesb#c.drm_gem_dma_prime_import_sg_tableasbuh1hhjP hhhja hMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjP hhhja hMubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjP hhhja hMubjg)}(h!drm_gem_dma_prime_import_sg_tableh]jm)}(hj h]h!drm_gem_dma_prime_import_sg_table}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjP hhhja hMubj)}(hQ(struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j #c.drm_gem_dma_prime_import_sg_tableasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hdevh]hdev}(hj% hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hj> hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj: ubjV)}(h h]h }(hjK hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj: ubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hj\ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjY ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj^ modnameN classnameNjj)}j]j #c.drm_gem_dma_prime_import_sg_tableasbuh1hhj: ubjV)}(h h]h }(hjz hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj: ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj: ubjm)}(hattachh]hattach}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj: ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j #c.drm_gem_dma_prime_import_sg_tableasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hsgth]hsgt}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjP hhhja hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjL hhhja hMubah}(h]jG ah ](jjeh"]h$]h&]jj)jhuh1j7hja hMhjI hhubj)}(hhh]h)}(hSproduce a DMA GEM object from another driver's scatter/gather table of pinned pagesh]hUproduce a DMA GEM object from another driver’s scatter/gather table of pinned pages}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj,hhubah}(h]h ]h"]h$]h&]uh1jhjI hhhja hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjGjjGjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_device *dev`` device to import into ``struct dma_buf_attachment *attach`` DMA-BUF attachment ``struct sg_table *sgt`` scatter/gather table of pinned pages **Description** This function imports a scatter/gather table exported via DMA-BUF by another driver. Imported buffers must be physically contiguous in memory (i.e. the scatter/gather table must contain a single entry). Drivers that use the DMA helpers should set this as their :c:type:`drm_driver.gem_prime_import_sg_table ` callback. **Return** A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.h](h)}(h**Parameters**h]j)}(hjQh]h Parameters}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjKubj)}(hhh](j)}(h1``struct drm_device *dev`` device to import into h](j)}(h``struct drm_device *dev``h]j)}(hjph]hstruct drm_device *dev}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjjubj )}(hhh]h)}(hdevice to import intoh]hdevice to import into}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjgubj)}(h9``struct dma_buf_attachment *attach`` DMA-BUF attachment h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hjh]h!struct dma_buf_attachment *attach}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubj )}(hhh]h)}(hDMA-BUF attachmenth]hDMA-BUF attachment}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjgubj)}(h>``struct sg_table *sgt`` scatter/gather table of pinned pages h](j)}(h``struct sg_table *sgt``h]j)}(hjh]hstruct sg_table *sgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubj )}(hhh]h)}(h$scatter/gather table of pinned pagesh]h$scatter/gather table of pinned pages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjgubeh}(h]h ]h"]h$]h&]uh1jhjKubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjKubh)}(hXJThis function imports a scatter/gather table exported via DMA-BUF by another driver. Imported buffers must be physically contiguous in memory (i.e. the scatter/gather table must contain a single entry). Drivers that use the DMA helpers should set this as their :c:type:`drm_driver.gem_prime_import_sg_table ` callback.h](hXThis function imports a scatter/gather table exported via DMA-BUF by another driver. Imported buffers must be physically contiguous in memory (i.e. the scatter/gather table must contain a single entry). Drivers that use the DMA helpers should set this as their }(hj3hhhNhNubh)}(h;:c:type:`drm_driver.gem_prime_import_sg_table `h]j)}(hj=h]h$drm_driver.gem_prime_import_sg_table}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj3ubh callback.}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjZhMhjKubh)}(h **Return**h]j)}(hjgh]hReturn}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjKubh)}(h]A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.h]h]A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_dma_vmap (C function)c.drm_gem_dma_vmaphNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hPint drm_gem_dma_vmap (struct drm_gem_dma_object *dma_obj, struct iosys_map *map)h]j>)}(hOint drm_gem_dma_vmap(struct drm_gem_dma_object *dma_obj, struct iosys_map *map)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gem_dma_vmaph]jm)}(hdrm_gem_dma_vmaph]hdrm_gem_dma_vmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h;(struct drm_gem_dma_object *dma_obj, struct iosys_map *map)h](j)}(h"struct drm_gem_dma_object *dma_objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_dma_objecth]hdrm_gem_dma_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jjsbc.drm_gem_dma_vmapasbuh1hhjubjV)}(h h]h }(hj'hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj5hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdma_objh]hdma_obj}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hj[hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjWubjV)}(h h]h }(hjhhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj{modnameN classnameNjj)}j]j#c.drm_gem_dma_vmapasbuh1hhjWubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjWubjm)}(hmaph]hmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hmap a DMA GEM object into the kernel’s virtual address space}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_gem_dma_object *dma_obj`` DMA GEM object ``struct iosys_map *map`` Returns the kernel virtual address of the DMA GEM object's backing store. **Description** This function maps a buffer into the kernel's virtual address space. Since the DMA buffers are already mapped into the kernel virtual address space this simply returns the cached virtual address. **Return** 0 on success, or a negative error code otherwise.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubj)}(hhh](j)}(h6``struct drm_gem_dma_object *dma_obj`` DMA GEM object h](j)}(h&``struct drm_gem_dma_object *dma_obj``h]j)}(hjh]h"struct drm_gem_dma_object *dma_obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubj )}(hhh]h)}(hDMA GEM objecth]hDMA GEM object}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMhj3ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMhjubj)}(hd``struct iosys_map *map`` Returns the kernel virtual address of the DMA GEM object's backing store. h](j)}(h``struct iosys_map *map``h]j)}(hjVh]hstruct iosys_map *map}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjPubj )}(hhh]h)}(hIReturns the kernel virtual address of the DMA GEM object's backing store.h]hKReturns the kernel virtual address of the DMA GEM object’s backing store.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjlubah}(h]h ]h"]h$]h&]uh1j hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubh)}(hThis function maps a buffer into the kernel's virtual address space. Since the DMA buffers are already mapped into the kernel virtual address space this simply returns the cached virtual address.h]hThis function maps a buffer into the kernel’s virtual address space. Since the DMA buffers are already mapped into the kernel virtual address space this simply returns the cached virtual address.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubh)}(h10 on success, or a negative error code otherwise.h]h10 on success, or a negative error code otherwise.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_dma_mmap (C function)c.drm_gem_dma_mmaphNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hUint drm_gem_dma_mmap (struct drm_gem_dma_object *dma_obj, struct vm_area_struct *vma)h]j>)}(hTint drm_gem_dma_mmap(struct drm_gem_dma_object *dma_obj, struct vm_area_struct *vma)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj hMubjg)}(hdrm_gem_dma_mmaph]jm)}(hdrm_gem_dma_mmaph]hdrm_gem_dma_mmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj hMubj)}(h@(struct drm_gem_dma_object *dma_obj, struct vm_area_struct *vma)h](j)}(h"struct drm_gem_dma_object *dma_objh](jD)}(hjh]hstruct}(hj;hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj7ubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubh)}(hhh]jm)}(hdrm_gem_dma_objecth]hdrm_gem_dma_object}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj[modnameN classnameNjj)}j]j )}jj!sbc.drm_gem_dma_mmapasbuh1hhj7ubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj7ubjm)}(hdma_objh]hdma_obj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj7ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]juc.drm_gem_dma_mmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj3ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj hMhjhhubj)}(hhh]h)}(h%memory-map an exported DMA GEM objecth]h%memory-map an exported DMA GEM object}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhj+hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjFjjFjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_gem_dma_object *dma_obj`` DMA GEM object ``struct vm_area_struct *vma`` VMA for the area to be mapped **Description** This function maps a buffer into a userspace process's address space. In addition to the usual GEM VMA setup it immediately faults in the entire object instead of using on-demand faulting. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjPh]h Parameters}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjJubj)}(hhh](j)}(h6``struct drm_gem_dma_object *dma_obj`` DMA GEM object h](j)}(h&``struct drm_gem_dma_object *dma_obj``h]j)}(hjoh]h"struct drm_gem_dma_object *dma_obj}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjiubj )}(hhh]h)}(hDMA GEM objecth]hDMA GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjiubeh}(h]h ]h"]h$]h&]uh1jhjhMhjfubj)}(h=``struct vm_area_struct *vma`` VMA for the area to be mapped h](j)}(h``struct vm_area_struct *vma``h]j)}(hjh]hstruct vm_area_struct *vma}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjubj )}(hhh]h)}(hVMA for the area to be mappedh]hVMA for the area to be mapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjfubeh}(h]h ]h"]h$]h&]uh1jhjJubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjJubh)}(hThis function maps a buffer into a userspace process's address space. In addition to the usual GEM VMA setup it immediately faults in the entire object instead of using on-demand faulting.h]hThis function maps a buffer into a userspace process’s address space. In addition to the usual GEM VMA setup it immediately faults in the entire object instead of using on-demand faulting.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chMhjJubh)}(h **Return**h]j)}(hj h]hReturn}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM hjJubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM hjJubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.3drm_gem_dma_prime_import_sg_table_vmap (C function)(c.drm_gem_dma_prime_import_sg_table_vmaphNtauh1j!hj[hhhNhNubj3)}(hhh](j8)}(hstruct drm_gem_object * drm_gem_dma_prime_import_sg_table_vmap (struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h]j>)}(hstruct drm_gem_object *drm_gem_dma_prime_import_sg_table_vmap(struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h](jD)}(hjh]hstruct}(hjOhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjKhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM.ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKhhhj\hM.ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjpmodnameN classnameNjj)}j]j )}j&drm_gem_dma_prime_import_sg_table_vmapsb(c.drm_gem_dma_prime_import_sg_table_vmapasbuh1hhjKhhhj\hM.ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKhhhj\hM.ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjKhhhj\hM.ubjg)}(h&drm_gem_dma_prime_import_sg_table_vmaph]jm)}(hjh]h&drm_gem_dma_prime_import_sg_table_vmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjKhhhj\hM.ubj)}(hQ(struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j(c.drm_gem_dma_prime_import_sg_table_vmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hj9hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj5ubjV)}(h h]h }(hjFhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjYmodnameN classnameNjj)}j]j(c.drm_gem_dma_prime_import_sg_table_vmapasbuh1hhj5ubjV)}(h h]h }(hjuhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj5ubjm)}(hattachh]hattach}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j(c.drm_gem_dma_prime_import_sg_table_vmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hsgth]hsgt}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjKhhhj\hM.ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjGhhhj\hM.ubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1j7hj\hM.hjDhhubj)}(hhh]h)}(h\PRIME import another driver's scatter/gather table and get the virtual address of the bufferh]h^PRIME import another driver’s scatter/gather table and get the virtual address of the buffer}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM.hj'hhubah}(h]h ]h"]h$]h&]uh1jhjDhhhj\hM.ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjBjjBjjjuh1j2hhhj[hNhNubj)}(hX**Parameters** ``struct drm_device *dev`` DRM device ``struct dma_buf_attachment *attach`` DMA-BUF attachment ``struct sg_table *sgt`` Scatter/gather table of pinned pages **Description** This function imports a scatter/gather table using drm_gem_dma_prime_import_sg_table() and uses dma_buf_vmap() to get the kernel virtual address. This ensures that a DMA GEM object always has its virtual address set. This address is released when the object is freed. This function can be used as the :c:type:`drm_driver.gem_prime_import_sg_table ` callback. The :c:type:`DRM_GEM_DMA_DRIVER_OPS_VMAP` macro provides a shortcut to set the necessary DRM driver operations. **Return** A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.h](h)}(h**Parameters**h]j)}(hjLh]h Parameters}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM2hjFubj)}(hhh](j)}(h&``struct drm_device *dev`` DRM device h](j)}(h``struct drm_device *dev``h]j)}(hjkh]hstruct drm_device *dev}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM0hjeubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM0hjubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjhM0hjbubj)}(h9``struct dma_buf_attachment *attach`` DMA-BUF attachment h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hjh]h!struct dma_buf_attachment *attach}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM1hjubj )}(hhh]h)}(hDMA-BUF attachmenth]hDMA-BUF attachment}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjbubj)}(h>``struct sg_table *sgt`` Scatter/gather table of pinned pages h](j)}(h``struct sg_table *sgt``h]j)}(hjh]hstruct sg_table *sgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM2hjubj )}(hhh]h)}(h$Scatter/gather table of pinned pagesh]h$Scatter/gather table of pinned pages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjbubeh}(h]h ]h"]h$]h&]uh1jhjFubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM4hjFubh)}(hX This function imports a scatter/gather table using drm_gem_dma_prime_import_sg_table() and uses dma_buf_vmap() to get the kernel virtual address. This ensures that a DMA GEM object always has its virtual address set. This address is released when the object is freed.h]hX This function imports a scatter/gather table using drm_gem_dma_prime_import_sg_table() and uses dma_buf_vmap() to get the kernel virtual address. This ensures that a DMA GEM object always has its virtual address set. This address is released when the object is freed.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM3hjFubh)}(hThis function can be used as the :c:type:`drm_driver.gem_prime_import_sg_table ` callback. The :c:type:`DRM_GEM_DMA_DRIVER_OPS_VMAP` macro provides a shortcut to set the necessary DRM driver operations.h](h!This function can be used as the }(hj=hhhNhNubh)}(h;:c:type:`drm_driver.gem_prime_import_sg_table `h]j)}(hjGh]h$drm_driver.gem_prime_import_sg_table}(hjIhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM8hj=ubh callback. The }(hj=hhhNhNubh)}(h%:c:type:`DRM_GEM_DMA_DRIVER_OPS_VMAP`h]j)}(hjkh]hDRM_GEM_DMA_DRIVER_OPS_VMAP}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_GEM_DMA_DRIVER_OPS_VMAPuh1hhjdhM8hj=ubhF macro provides a shortcut to set the necessary DRM driver operations.}(hj=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjdhM8hjFubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM<hjFubh)}(h]A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.h]h]A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:384: ./drivers/gpu/drm/drm_gem_dma_helper.chM=hjFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj[hhhNhNubeh}(h]"gem-dma-helper-functions-referenceah ]h"]"gem dma helper functions referenceah$]h&]uh1hhjzhhhhhMxubh)}(hhh](h)}(h#GEM SHMEM Helper Function Referenceh]h#GEM SHMEM Helper Function Reference}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMubh)}(hpThis library provides helpers for GEM objects backed by shmem buffers allocated using anonymous pageable memory.h]hpThis library provides helpers for GEM objects backed by shmem buffers allocated using anonymous pageable memory.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:390: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhjhhubh)}(hXGFunctions that operate on the GEM object receive struct :c:type:`drm_gem_shmem_object`. For GEM callback helpers in struct :c:type:`drm_gem_object` functions, see likewise named functions with an _object_ infix (e.g., drm_gem_shmem_object_vmap() wraps drm_gem_shmem_vmap()). These helpers perform the necessary type conversion.h](h8Functions that operate on the GEM object receive struct }(hjhhhNhNubh)}(h:c:type:`drm_gem_shmem_object`h]j)}(hjh]hdrm_gem_shmem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_shmem_objectuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:390: ./drivers/gpu/drm/drm_gem_shmem_helper.chK"hjubh%. For GEM callback helpers in struct }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhK"hjubh functions, see likewise named functions with an _object_ infix (e.g., drm_gem_shmem_object_vmap() wraps drm_gem_shmem_vmap()). These helpers perform the necessary type conversion.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhK"hjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_shmem_object (C struct)c.drm_gem_shmem_objecthNtauh1j!hjhhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhNubj3)}(hhh](j8)}(hdrm_gem_shmem_objecth]j>)}(hstruct drm_gem_shmem_objecth](jD)}(hjh]hstruct}(hjWhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjShhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKubjV)}(h h]h }(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjShhhjdhKubjg)}(hdrm_gem_shmem_objecth]jm)}(hjQh]hdrm_gem_shmem_object}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjShhhjdhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjOhhhjdhKubah}(h]jIah ](jjeh"]h$]h&]jj)jhuh1j7hjdhKhjLhhubj)}(hhh]h)}(hGEM object backed by shmemh]hGEM object backed by shmem}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjLhhhjdhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjhjKhNubj)}(hX**Definition**:: struct drm_gem_shmem_object { struct drm_gem_object base; struct page **pages; refcount_t pages_use_count; refcount_t pages_pin_count; int madv; struct list_head madv_list; struct sg_table *sgt; void *vaddr; refcount_t vmap_use_count; bool pages_mark_dirty_on_put : 1; bool pages_mark_accessed_on_put : 1; bool map_wc : 1; }; **Members** ``base`` Base GEM object ``pages`` Page table ``pages_use_count`` Reference count on the pages table. The pages are put when the count reaches zero. ``pages_pin_count`` Reference count on the pinned pages table. Pages are hard-pinned and reside in memory if count greater than zero. Otherwise, when count is zero, the pages are allowed to be evicted and purged by memory shrinker. ``madv`` State for madvise 0 is active/inuse. A negative value is the object is purged. Positive values are driver specific and not used by the helpers. ``madv_list`` List entry for madvise tracking Typically used by drivers to track purgeable objects ``sgt`` Scatter/gather table for imported PRIME buffers ``vaddr`` Kernel virtual address of the backing memory ``vmap_use_count`` Reference count on the virtual address. The address are un-mapped when the count reaches zero. ``pages_mark_dirty_on_put`` Mark pages as dirty when they are put. ``pages_mark_accessed_on_put`` Mark pages as accessed when they are put. ``map_wc`` map object write-combined (instead of using shmem defaults).h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubjT)}(hXustruct drm_gem_shmem_object { struct drm_gem_object base; struct page **pages; refcount_t pages_use_count; refcount_t pages_pin_count; int madv; struct list_head madv_list; struct sg_table *sgt; void *vaddr; refcount_t vmap_use_count; bool pages_mark_dirty_on_put : 1; bool pages_mark_accessed_on_put : 1; bool map_wc : 1; };h]hXustruct drm_gem_shmem_object { struct drm_gem_object base; struct page **pages; refcount_t pages_use_count; refcount_t pages_pin_count; int madv; struct list_head madv_list; struct sg_table *sgt; void *vaddr; refcount_t vmap_use_count; bool pages_mark_dirty_on_put : 1; bool pages_mark_accessed_on_put : 1; bool map_wc : 1; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jSh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK*hjubj)}(hhh](j)}(h``base`` Base GEM object h](j)}(h``base``h]j)}(hjh]hbase}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubj )}(hhh]h)}(hBase GEM objecth]hBase GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h``pages`` Page table h](j)}(h ``pages``h]j)}(hj?h]hpages}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj9ubj )}(hhh]h)}(h Page tableh]h Page table}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThKhjUubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThKhjubj)}(hg``pages_use_count`` Reference count on the pages table. The pages are put when the count reaches zero. h](j)}(h``pages_use_count``h]j)}(hjxh]hpages_use_count}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK%hjrubj )}(hhh]h)}(hRReference count on the pages table. The pages are put when the count reaches zero.h]hRReference count on the pages table. The pages are put when the count reaches zero.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK$hjubah}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhK%hjubj)}(h``pages_pin_count`` Reference count on the pinned pages table. Pages are hard-pinned and reside in memory if count greater than zero. Otherwise, when count is zero, the pages are allowed to be evicted and purged by memory shrinker. h](j)}(h``pages_pin_count``h]j)}(hjh]hpages_pin_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK0hjubj )}(hhh](h)}(h*Reference count on the pinned pages table.h]h*Reference count on the pinned pages table.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK,hjubh)}(hPages are hard-pinned and reside in memory if count greater than zero. Otherwise, when count is zero, the pages are allowed to be evicted and purged by memory shrinker.h]hPages are hard-pinned and reside in memory if count greater than zero. Otherwise, when count is zero, the pages are allowed to be evicted and purged by memory shrinker.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK.hjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK0hjubj)}(h``madv`` State for madvise 0 is active/inuse. A negative value is the object is purged. Positive values are driver specific and not used by the helpers. h](j)}(h``madv``h]j)}(hjh]hmadv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK;hjubj )}(hhh](h)}(hState for madviseh]hState for madvise}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK7hjubh)}(h}0 is active/inuse. A negative value is the object is purged. Positive values are driver specific and not used by the helpers.h]h}0 is active/inuse. A negative value is the object is purged. Positive values are driver specific and not used by the helpers.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK9hjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK;hjubj)}(hd``madv_list`` List entry for madvise tracking Typically used by drivers to track purgeable objects h](j)}(h ``madv_list``h]j)}(hjDh]h madv_list}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKBhj>ubj )}(hhh](h)}(hList entry for madvise trackingh]hList entry for madvise tracking}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK@hjZubh)}(h4Typically used by drivers to track purgeable objectsh]h4Typically used by drivers to track purgeable objects}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhKBhjZubeh}(h]h ]h"]h$]h&]uh1j hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhKBhjubj)}(h8``sgt`` Scatter/gather table for imported PRIME buffers h](j)}(h``sgt``h]j)}(hjh]hsgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKGhjubj )}(hhh]h)}(h/Scatter/gather table for imported PRIME buffersh]h/Scatter/gather table for imported PRIME buffers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKGhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKGhjubj)}(h7``vaddr`` Kernel virtual address of the backing memory h](j)}(h ``vaddr``h]j)}(hjh]hvaddr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKLhjubj )}(hhh]h)}(h,Kernel virtual address of the backing memoryh]h,Kernel virtual address of the backing memory}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKLhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKLhjubj)}(hr``vmap_use_count`` Reference count on the virtual address. The address are un-mapped when the count reaches zero. h](j)}(h``vmap_use_count``h]j)}(hjh]hvmap_use_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKRhjubj )}(hhh]h)}(h^Reference count on the virtual address. The address are un-mapped when the count reaches zero.h]h^Reference count on the virtual address. The address are un-mapped when the count reaches zero.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKQhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKRhjubj)}(hC``pages_mark_dirty_on_put`` Mark pages as dirty when they are put. h](j)}(h``pages_mark_dirty_on_put``h]j)}(hj8h]hpages_mark_dirty_on_put}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKYhj2ubj )}(hhh]h)}(h&Mark pages as dirty when they are put.h]h&Mark pages as dirty when they are put.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjMhKYhjNubah}(h]h ]h"]h$]h&]uh1j hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhKYhjubj)}(hI``pages_mark_accessed_on_put`` Mark pages as accessed when they are put. h](j)}(h``pages_mark_accessed_on_put``h]j)}(hjqh]hpages_mark_accessed_on_put}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhK`hjkubj )}(hhh]h)}(h)Mark pages as accessed when they are put.h]h)Mark pages as accessed when they are put.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK`hjubah}(h]h ]h"]h$]h&]uh1j hjkubeh}(h]h ]h"]h$]h&]uh1jhjhK`hjubj)}(hG``map_wc`` map object write-combined (instead of using shmem defaults).h](j)}(h ``map_wc``h]j)}(hjh]hmap_wc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKfhjubj )}(hhh]h)}(h)}(h:void drm_gem_shmem_object_free(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_gem_shmem_object_freeh]jm)}(hdrm_gem_shmem_object_freeh]hdrm_gem_shmem_object_free}(hj%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjAhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj=ubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjamodnameN classnameNjj)}j]j )}jj'sbc.drm_gem_shmem_object_freeasbuh1hhj=ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj=ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj9ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h,GEM object function for drm_gem_shmem_free()h]h,GEM object function for drm_gem_shmem_free()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhjKhNubj)}(hX**Parameters** ``struct drm_gem_object *obj`` GEM object to free **Description** This function wraps drm_gem_shmem_free(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.free ` handler.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubj)}(hhh]j)}(h2``struct drm_gem_object *obj`` GEM object to free h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubj )}(hhh]h)}(hGEM object to freeh]hGEM object to free}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj@h]h Description}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubh)}(hThis function wraps drm_gem_shmem_free(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.free ` handler.h](hgThis function wraps drm_gem_shmem_free(). Drivers that employ the shmem helpers should use it as their }(hjVhhhNhNubh)}(h::c:type:`drm_gem_object_funcs.free `h]j)}(hj`h]hdrm_gem_object_funcs.free}(hjbhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjVubh handler.}(hjVhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj}hKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhjKhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.,drm_gem_shmem_object_print_info (C function)!c.drm_gem_shmem_object_print_infohNtauh1j!hjhhhjKhNubj3)}(hhh](j8)}(hsvoid drm_gem_shmem_object_print_info (struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj)h]j>)}(hrvoid drm_gem_shmem_object_print_info(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_gem_shmem_object_print_infoh]jm)}(hdrm_gem_shmem_object_print_infoh]hdrm_gem_shmem_object_print_info}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(hN(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *obj)h](j)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsb!c.drm_gem_shmem_object_print_infoasbuh1hhjubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj1hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hj@h]hp}(hj>hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int indenth](j)}(hunsignedh]hunsigned}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubj)}(hinth]hint}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubjm)}(hindenth]hindent}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h const struct drm_gem_object *objh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j!c.drm_gem_shmem_object_print_infoasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h5Print :c:type:`drm_gem_shmem_object` info for debugfsh](hPrint }(hjChhhNhNubh)}(h:c:type:`drm_gem_shmem_object`h]j)}(hjMh]hdrm_gem_shmem_object}(hjOhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j!c.drm_gem_shmem_object_print_infoasbjMdrm_gem_shmem_objectuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjCubh info for debugfs}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj@hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhjKhNubj)}(hXo**Parameters** ``struct drm_printer *p`` DRM printer ``unsigned int indent`` Tab indentation level ``const struct drm_gem_object *obj`` GEM object **Description** This function wraps drm_gem_shmem_print_info(). Drivers that employ the shmem helpers should use this function as their :c:type:`drm_gem_object_funcs.print_info ` handler.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubj)}(hhh](j)}(h&``struct drm_printer *p`` DRM printer h](j)}(h``struct drm_printer *p``h]j)}(hjh]hstruct drm_printer *p}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubj )}(hhh]h)}(h DRM printerh]h DRM printer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h.``unsigned int indent`` Tab indentation level h](j)}(h``unsigned int indent``h]j)}(hjh]hunsigned int indent}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubj )}(hhh]h)}(hTab indentation levelh]hTab indentation level}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h0``const struct drm_gem_object *obj`` GEM object h](j)}(h$``const struct drm_gem_object *obj``h]j)}(hj h]h const struct drm_gem_object *obj}(hj! hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj ubj )}(hhh]h)}(h GEM objecth]h GEM object}(hj8 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4 hKhj5 ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj4 hKhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjZ h]h Description}(hj\ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjubh)}(hThis function wraps drm_gem_shmem_print_info(). Drivers that employ the shmem helpers should use this function as their :c:type:`drm_gem_object_funcs.print_info ` handler.h](hxThis function wraps drm_gem_shmem_print_info(). Drivers that employ the shmem helpers should use this function as their }(hjp hhhNhNubh)}(h@:c:type:`drm_gem_object_funcs.print_info `h]j)}(hjz h]hdrm_gem_object_funcs.print_info}(hj| hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjx ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjp ubh handler.}(hjp hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhjKhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gem_shmem_object_pin (C function)c.drm_gem_shmem_object_pinhNtauh1j!hjhhhjKhNubj3)}(hhh](j8)}(h9int drm_gem_shmem_object_pin (struct drm_gem_object *obj)h]j>)}(h8int drm_gem_shmem_object_pin(struct drm_gem_object *obj)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hKubjg)}(hdrm_gem_shmem_object_pinh]jm)}(hdrm_gem_shmem_object_pinh]hdrm_gem_shmem_object_pin}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj hKubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj !hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]j )}jj sbc.drm_gem_shmem_object_pinasbuh1hhj ubjV)}(h h]h }(hj=!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjK!hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hobjh]hobj}(hjX!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhj hhhj hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hKubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj hKhj hhubj)}(hhh]h)}(h+GEM object function for drm_gem_shmem_pin()h]h+GEM object function for drm_gem_shmem_pin()}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj!jj!jjjuh1j2hhhjhjKhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` GEM object **Description** This function wraps drm_gem_shmem_pin(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.pin ` handler.h](h)}(h**Parameters**h]j)}(hj!h]h Parameters}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!ubj)}(hhh]j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hj!h]hstruct drm_gem_object *obj}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!ubj )}(hhh]h)}(h GEM objecth]h GEM object}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hKhj!ubah}(h]h ]h"]h$]h&]uh1j hj!ubeh}(h]h ]h"]h$]h&]uh1jhj!hKhj!ubah}(h]h ]h"]h$]h&]uh1jhj!ubh)}(h**Description**h]j)}(hj!h]h Description}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!ubh)}(hThis function wraps drm_gem_shmem_pin(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.pin ` handler.h](hfThis function wraps drm_gem_shmem_pin(). Drivers that employ the shmem helpers should use it as their }(hj"hhhNhNubh)}(h9:c:type:`drm_gem_object_funcs.pin `h]j)}(hj"h]hdrm_gem_object_funcs.pin}(hj "hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj"ubh handler.}(hj"hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;"hKhj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhjKhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gem_shmem_object_unpin (C function)c.drm_gem_shmem_object_unpinhNtauh1j!hjhhhjKhNubj3)}(hhh](j8)}(h)}(h;void drm_gem_shmem_object_unpin(struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hjf"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjb"hhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKubjV)}(h h]h }(hju"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjb"hhhjt"hKubjg)}(hdrm_gem_shmem_object_unpinh]jm)}(hdrm_gem_shmem_object_unpinh]hdrm_gem_shmem_object_unpin}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjb"hhhjt"hKubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj"hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj"ubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]j )}jj"sbc.drm_gem_shmem_object_unpinasbuh1hhj"ubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubj4)}(hj7h]h*}(hj"hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj"ubjm)}(hobjh]hobj}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubah}(h]h ]h"]h$]h&]jjuh1jhjb"hhhjt"hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj^"hhhjt"hKubah}(h]jY"ah ](jjeh"]h$]h&]jj)jhuh1j7hjt"hKhj["hhubj)}(hhh]h)}(h-GEM object function for drm_gem_shmem_unpin()h]h-GEM object function for drm_gem_shmem_unpin()}(hj&#hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj##hhubah}(h]h ]h"]h$]h&]uh1jhj["hhhjt"hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj>#jj>#jjjuh1j2hhhjhjKhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` GEM object **Description** This function wraps drm_gem_shmem_unpin(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.unpin ` handler.h](h)}(h**Parameters**h]j)}(hjH#h]h Parameters}(hjJ#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF#ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjB#ubj)}(hhh]j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hjg#h]hstruct drm_gem_object *obj}(hji#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhje#ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhja#ubj )}(hhh]h)}(h GEM objecth]h GEM object}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|#hKhj}#ubah}(h]h ]h"]h$]h&]uh1j hja#ubeh}(h]h ]h"]h$]h&]uh1jhj|#hKhj^#ubah}(h]h ]h"]h$]h&]uh1jhjB#ubh)}(h**Description**h]j)}(hj#h]h Description}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhjB#ubh)}(hThis function wraps drm_gem_shmem_unpin(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.unpin ` handler.h](hhThis function wraps drm_gem_shmem_unpin(). Drivers that employ the shmem helpers should use it as their }(hj#hhhNhNubh)}(h;:c:type:`drm_gem_object_funcs.unpin `h]j)}(hj#h]hdrm_gem_object_funcs.unpin}(hj#hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj#ubh handler.}(hj#hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj#hKhjB#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhjKhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j..drm_gem_shmem_object_get_sg_table (C function)#c.drm_gem_shmem_object_get_sg_tablehNtauh1j!hjhhhjKhNubj3)}(hhh](j8)}(hPstruct sg_table * drm_gem_shmem_object_get_sg_table (struct drm_gem_object *obj)h]j>)}(hNstruct sg_table *drm_gem_shmem_object_get_sg_table(struct drm_gem_object *obj)h](jD)}(hjh]hstruct}(hj $hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$hhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$hhhj$hKubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj)$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&$ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+$modnameN classnameNjj)}j]j )}j!drm_gem_shmem_object_get_sg_tablesb#c.drm_gem_shmem_object_get_sg_tableasbuh1hhj$hhhj$hKubjV)}(h h]h }(hjJ$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$hhhj$hKubj4)}(hj7h]h*}(hjX$hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$hhhj$hKubjg)}(h!drm_gem_shmem_object_get_sg_tableh]jm)}(hjG$h]h!drm_gem_shmem_object_get_sg_table}(hji$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhje$ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj$hhhj$hKubj)}(h(struct drm_gem_object *obj)h]j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$ubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj$modnameN classnameNjj)}j]jE$#c.drm_gem_shmem_object_get_sg_tableasbuh1hhj$ubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubj4)}(hj7h]h*}(hj$hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$ubjm)}(hobjh]hobj}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|$ubah}(h]h ]h"]h$]h&]jjuh1jhj$hhhj$hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj$hhhj$hKubah}(h]j#ah ](jjeh"]h$]h&]jj)jhuh1j7hj$hKhj#hhubj)}(hhh]h)}(h4GEM object function for drm_gem_shmem_get_sg_table()h]h4GEM object function for drm_gem_shmem_get_sg_table()}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj%hhubah}(h]h ]h"]h$]h&]uh1jhj#hhhj$hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj%jj%jjjuh1j2hhhjhjKhNubj)}(hXh**Parameters** ``struct drm_gem_object *obj`` GEM object **Description** This function wraps drm_gem_shmem_get_sg_table(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.get_sg_table ` handler. **Return** A pointer to the scatter/gather table of pinned pages or error pointer on failure.h](h)}(h**Parameters**h]j)}(hj'%h]h Parameters}(hj)%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%%ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!%ubj)}(hhh]j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hjF%h]hstruct drm_gem_object *obj}(hjH%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjD%ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj@%ubj )}(hhh]h)}(h GEM objecth]h GEM object}(hj_%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[%hKhj\%ubah}(h]h ]h"]h$]h&]uh1j hj@%ubeh}(h]h ]h"]h$]h&]uh1jhj[%hKhj=%ubah}(h]h ]h"]h$]h&]uh1jhj!%ubh)}(h**Description**h]j)}(hj%h]h Description}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!%ubh)}(hThis function wraps drm_gem_shmem_get_sg_table(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.get_sg_table ` handler.h](hoThis function wraps drm_gem_shmem_get_sg_table(). Drivers that employ the shmem helpers should use it as their }(hj%hhhNhNubh)}(hB:c:type:`drm_gem_object_funcs.get_sg_table `h]j)}(hj%h]h!drm_gem_object_funcs.get_sg_table}(hj%hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj%ubh handler.}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj%hKhj!%ubh)}(h **Return**h]j)}(hj%h]hReturn}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!%ubh)}(hRA pointer to the scatter/gather table of pinned pages or error pointer on failure.h]hRA pointer to the scatter/gather table of pinned pages or error pointer on failure.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhKhj!%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhjKhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gem_shmem_object_mmap (C function)c.drm_gem_shmem_object_mmaphNtauh1j!hjhhhjKhNubj3)}(hhh](j8)}(hVint drm_gem_shmem_object_mmap (struct drm_gem_object *obj, struct vm_area_struct *vma)h]j>)}(hUint drm_gem_shmem_object_mmap(struct drm_gem_object *obj, struct vm_area_struct *vma)h](j)}(hinth]hint}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj &hhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhMubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj &hhhj&hMubjg)}(hdrm_gem_shmem_object_mmaph]jm)}(hdrm_gem_shmem_object_mmaph]hdrm_gem_shmem_object_mmap}(hj1&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-&ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj &hhhj&hMubj)}(h8(struct drm_gem_object *obj, struct vm_area_struct *vma)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjM&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjI&ubjV)}(h h]h }(hjZ&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjI&ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjk&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjh&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjm&modnameN classnameNjj)}j]j )}jj3&sbc.drm_gem_shmem_object_mmapasbuh1hhjI&ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjI&ubj4)}(hj7h]h*}(hj&hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjI&ubjm)}(hobjh]hobj}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjI&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjE&ubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hj&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj&ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj&modnameN classnameNjj)}j]j&c.drm_gem_shmem_object_mmapasbuh1hhj&ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubj4)}(hj7h]h*}(hj 'hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj&ubjm)}(hvmah]hvma}(hj'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjE&ubeh}(h]h ]h"]h$]h&]jjuh1jhj &hhhj&hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj&hhhj&hMubah}(h]j&ah ](jjeh"]h$]h&]jj)jhuh1j7hj&hMhj&hhubj)}(hhh]h)}(h,GEM object function for drm_gem_shmem_mmap()h]h,GEM object function for drm_gem_shmem_mmap()}(hj@'hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhMhj='hhubah}(h]h ]h"]h$]h&]uh1jhj&hhhj&hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjX'jjX'jjjuh1j2hhhjhjKhNubj)}(hXw**Parameters** ``struct drm_gem_object *obj`` GEM object ``struct vm_area_struct *vma`` VMA for the area to be mapped **Description** This function wraps drm_gem_shmem_mmap(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.mmap ` handler. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjb'h]h Parameters}(hjd'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`'ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM hj\'ubj)}(hhh](j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hj'h]hstruct drm_gem_object *obj}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhMhj{'ubj )}(hhh]h)}(h GEM objecth]h GEM object}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1j hj{'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhjx'ubj)}(h=``struct vm_area_struct *vma`` VMA for the area to be mapped h](j)}(h``struct vm_area_struct *vma``h]j)}(hj'h]hstruct vm_area_struct *vma}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhMhj'ubj )}(hhh]h)}(hVMA for the area to be mappedh]hVMA for the area to be mapped}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhjx'ubeh}(h]h ]h"]h$]h&]uh1jhj\'ubh)}(h**Description**h]j)}(hj'h]h Description}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM hj\'ubh)}(hThis function wraps drm_gem_shmem_mmap(). Drivers that employ the shmem helpers should use it as their :c:type:`drm_gem_object_funcs.mmap ` handler.h](hgThis function wraps drm_gem_shmem_mmap(). Drivers that employ the shmem helpers should use it as their }(hj (hhhNhNubh)}(h::c:type:`drm_gem_object_funcs.mmap `h]j)}(hj(h]hdrm_gem_object_funcs.mmap}(hj(hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM hj (ubh handler.}(hj (hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj2(hM hj\'ubh)}(h **Return**h]j)}(hj?(h]hReturn}(hjA(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=(ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM hj\'ubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hjU(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM hj\'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhjKhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."DRM_GEM_SHMEM_DRIVER_OPS (C macro)c.DRM_GEM_SHMEM_DRIVER_OPShNtauh1j!hjhhhjKhNubj3)}(hhh](j8)}(hDRM_GEM_SHMEM_DRIVER_OPSh]j>)}(hDRM_GEM_SHMEM_DRIVER_OPSh]jg)}(hDRM_GEM_SHMEM_DRIVER_OPSh]jm)}(hj~(h]hDRM_GEM_SHMEM_DRIVER_OPS}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj(hhh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM%ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj|(hhhj(hM%ubah}(h]jw(ah ](jjeh"]h$]h&]jj)jhuh1j7hj(hM%hjy(hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjy(hhhj(hM%ubeh}(h]h ](jmacroeh"]h$]h&]jjjj(jj(jjjuh1j2hhhjhjKhNubh)}(h``DRM_GEM_SHMEM_DRIVER_OPS``h]j)}(hj(h]hDRM_GEM_SHMEM_DRIVER_OPS}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM'hjhhubj)}(h Default shmem GEM operations **Description** This macro provides a shortcut for setting the shmem GEM operations in the :c:type:`drm_driver` structure. Drivers that do not require an s/g table for imported buffers should use this. h](j)}(hDefault shmem GEM operations h]h)}(hDefault shmem GEM operationsh]hDefault shmem GEM operations}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM%hj(ubah}(h]h ]h"]h$]h&]uh1jhj(hM%hj(ubh)}(h**Description**h]j)}(hj(h]h Description}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM'hj(ubh)}(hThis macro provides a shortcut for setting the shmem GEM operations in the :c:type:`drm_driver` structure. Drivers that do not require an s/g table for imported buffers should use this.h](hKThis macro provides a shortcut for setting the shmem GEM operations in the }(hj)hhhNhNubh)}(h:c:type:`drm_driver`h]j)}(hj)h]h drm_driver}(hj)hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj )ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh^/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:393: ./include/drm/drm_gem_shmem_helper.hhM&hj)ubhZ structure. Drivers that do not require an s/g table for imported buffers should use this.}(hj)hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj,)hM&hj(ubeh}(h]h ]h"]h$]h&]uh1jhj(hM%hjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_shmem_init (C function)c.drm_gem_shmem_inithNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h`int drm_gem_shmem_init (struct drm_device *dev, struct drm_gem_shmem_object *shmem, size_t size)h]j>)}(h_int drm_gem_shmem_init(struct drm_device *dev, struct drm_gem_shmem_object *shmem, size_t size)h](j)}(hinth]hint}(hjV)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjR)hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKcubjV)}(h h]h }(hje)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjR)hhhjd)hKcubjg)}(hdrm_gem_shmem_inith]jm)}(hdrm_gem_shmem_inith]hdrm_gem_shmem_init}(hjw)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjs)ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjR)hhhjd)hKcubj)}(hI(struct drm_device *dev, struct drm_gem_shmem_object *shmem, size_t size)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj)hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj)ubjV)}(h h]h }(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj)modnameN classnameNjj)}j]j )}jjy)sbc.drm_gem_shmem_initasbuh1hhj)ubjV)}(h h]h }(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubj4)}(hj7h]h*}(hj)hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj)ubjm)}(hdevh]hdev}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj)ubj)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hj*hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj*ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj#*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj *ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%*modnameN classnameNjj)}j]j)c.drm_gem_shmem_initasbuh1hhj*ubjV)}(h h]h }(hjA*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*ubj4)}(hj7h]h*}(hjO*hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj*ubjm)}(hshmemh]hshmem}(hj\*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj)ubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hjx*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhju*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjz*modnameN classnameNjj)}j]j)c.drm_gem_shmem_initasbuh1hhjq*ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjq*ubjm)}(hsizeh]hsize}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjq*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj)ubeh}(h]h ]h"]h$]h&]jjuh1jhjR)hhhjd)hKcubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjN)hhhjd)hKcubah}(h]jI)ah ](jjeh"]h$]h&]jj)jhuh1j7hjd)hKchjK)hhubj)}(hhh]h)}(hInitialize an allocated object.h]hInitialize an allocated object.}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKchj*hhubah}(h]h ]h"]h$]h&]uh1jhjK)hhhjd)hKcubeh}(h]h ](jfunctioneh"]h$]h&]jjjj*jj*jjjuh1j2hhhjhNhNubj)}(hX3**Parameters** ``struct drm_device *dev`` DRM device ``struct drm_gem_shmem_object *shmem`` shmem GEM object to initialize ``size_t size`` Buffer size in bytes **Description** This function initializes an allocated shmem GEM object. **Return** 0 on success, or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hj*h]h Parameters}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKghj*ubj)}(hhh](j)}(h&``struct drm_device *dev`` DRM device h](j)}(h``struct drm_device *dev``h]j)}(hj+h]hstruct drm_device *dev}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj +ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKdhj +ubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hj(+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$+hKdhj%+ubah}(h]h ]h"]h$]h&]uh1j hj +ubeh}(h]h ]h"]h$]h&]uh1jhj$+hKdhj+ubj)}(hF``struct drm_gem_shmem_object *shmem`` shmem GEM object to initialize h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hjH+h]h"struct drm_gem_shmem_object *shmem}(hjJ+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjF+ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKehjB+ubj )}(hhh]h)}(hshmem GEM object to initializeh]hshmem GEM object to initialize}(hja+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]+hKehj^+ubah}(h]h ]h"]h$]h&]uh1j hjB+ubeh}(h]h ]h"]h$]h&]uh1jhj]+hKehj+ubj)}(h%``size_t size`` Buffer size in bytes h](j)}(h``size_t size``h]j)}(hj+h]h size_t size}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKfhj{+ubj )}(hhh]h)}(hBuffer size in bytesh]hBuffer size in bytes}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hKfhj+ubah}(h]h ]h"]h$]h&]uh1j hj{+ubeh}(h]h ]h"]h$]h&]uh1jhj+hKfhj+ubeh}(h]h ]h"]h$]h&]uh1jhj*ubh)}(h**Description**h]j)}(hj+h]h Description}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhhj*ubh)}(h8This function initializes an allocated shmem GEM object.h]h8This function initializes an allocated shmem GEM object.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKghj*ubh)}(h **Return**h]j)}(hj+h]hReturn}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKihj*ubh)}(h20 on success, or a negative error code on failure.h]h20 on success, or a negative error code on failure.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKjhj*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gem_shmem_create (C function)c.drm_gem_shmem_createhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hXstruct drm_gem_shmem_object * drm_gem_shmem_create (struct drm_device *dev, size_t size)h]j>)}(hVstruct drm_gem_shmem_object *drm_gem_shmem_create(struct drm_device *dev, size_t size)h](jD)}(hjh]hstruct}(hj(,hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$,hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKubjV)}(h h]h }(hj6,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$,hhhj5,hKubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hjG,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjD,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjI,modnameN classnameNjj)}j]j )}jdrm_gem_shmem_createsbc.drm_gem_shmem_createasbuh1hhj$,hhhj5,hKubjV)}(h h]h }(hjh,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$,hhhj5,hKubj4)}(hj7h]h*}(hjv,hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$,hhhj5,hKubjg)}(hdrm_gem_shmem_createh]jm)}(hje,h]hdrm_gem_shmem_create}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj$,hhhj5,hKubj)}(h%(struct drm_device *dev, size_t size)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj,hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj,ubjV)}(h h]h }(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,modnameN classnameNjj)}j]jc,c.drm_gem_shmem_createasbuh1hhj,ubjV)}(h h]h }(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,ubj4)}(hj7h]h*}(hj,hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj,ubjm)}(hdevh]hdev}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]jc,c.drm_gem_shmem_createasbuh1hhj-ubjV)}(h h]h }(hj3-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubjm)}(hsizeh]hsize}(hjA-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,ubeh}(h]h ]h"]h$]h&]jjuh1jhj$,hhhj5,hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj ,hhhj5,hKubah}(h]j,ah ](jjeh"]h$]h&]jj)jhuh1j7hj5,hKhj,hhubj)}(hhh]h)}(h&Allocate an object with the given sizeh]h&Allocate an object with the given size}(hjk-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhjh-hhubah}(h]h ]h"]h$]h&]uh1jhj,hhhj5,hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj-jj-jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_device *dev`` DRM device ``size_t size`` Size of the object to allocate **Description** This function creates a shmem GEM object. **Return** A struct drm_gem_shmem_object * on success or an ERR_PTR()-encoded negative error code on failure.h](h)}(h**Parameters**h]j)}(hj-h]h Parameters}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubj)}(hhh](j)}(h&``struct drm_device *dev`` DRM device h](j)}(h``struct drm_device *dev``h]j)}(hj-h]hstruct drm_device *dev}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hKhj-ubah}(h]h ]h"]h$]h&]uh1j hj-ubeh}(h]h ]h"]h$]h&]uh1jhj-hKhj-ubj)}(h/``size_t size`` Size of the object to allocate h](j)}(h``size_t size``h]j)}(hj-h]h size_t size}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubj )}(hhh]h)}(hSize of the object to allocateh]hSize of the object to allocate}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hKhj-ubah}(h]h ]h"]h$]h&]uh1j hj-ubeh}(h]h ]h"]h$]h&]uh1jhj-hKhj-ubeh}(h]h ]h"]h$]h&]uh1jhj-ubh)}(h**Description**h]j)}(hj .h]h Description}(hj".hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubh)}(h)This function creates a shmem GEM object.h]h)This function creates a shmem GEM object.}(hj6.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubh)}(h **Return**h]j)}(hjG.h]hReturn}(hjI.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjE.ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubh)}(hbA struct drm_gem_shmem_object * on success or an ERR_PTR()-encoded negative error code on failure.h]hbA struct drm_gem_shmem_object * on success or an ERR_PTR()-encoded negative error code on failure.}(hj].hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_shmem_release (C function)c.drm_gem_shmem_releasehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h?void drm_gem_shmem_release (struct drm_gem_shmem_object *shmem)h]j>)}(h>void drm_gem_shmem_release(struct drm_gem_shmem_object *shmem)h](j)}(hvoidh]hvoid}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKubjV)}(h h]h }(hj.hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.hhhj.hKubjg)}(hdrm_gem_shmem_releaseh]jm)}(hdrm_gem_shmem_releaseh]hdrm_gem_shmem_release}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj.hhhj.hKubj)}(h$(struct drm_gem_shmem_object *shmem)h]j)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hj.hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj.ubjV)}(h h]h }(hj.hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj.modnameN classnameNjj)}j]j )}jj.sbc.drm_gem_shmem_releaseasbuh1hhj.ubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubj4)}(hj7h]h*}(hj/hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj.ubjm)}(hshmemh]hshmem}(hj"/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubah}(h]h ]h"]h$]h&]jjuh1jhj.hhhj.hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj.hhhj.hKubah}(h]j.ah ](jjeh"]h$]h&]jj)jhuh1j7hj.hKhj.hhubj)}(hhh]h)}(h5Release resources associated with a shmem GEM object.h]h5Release resources associated with a shmem GEM object.}(hjL/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhjI/hhubah}(h]h ]h"]h$]h&]uh1jhj.hhhj.hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjd/jjd/jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_gem_shmem_object *shmem`` shmem GEM object **Description** This function cleans up the GEM object state, but does not free the memory used to store the object itself. This function is meant to be a dedicated helper for the Rust GEM bindings.h](h)}(h**Parameters**h]j)}(hjn/h]h Parameters}(hjp/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjl/ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhjh/ubj)}(hhh]j)}(h8``struct drm_gem_shmem_object *shmem`` shmem GEM object h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hj/h]h"struct drm_gem_shmem_object *shmem}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj/ubj )}(hhh]h)}(hshmem GEM objecth]hshmem GEM object}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hKhj/ubah}(h]h ]h"]h$]h&]uh1j hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hKhj/ubah}(h]h ]h"]h$]h&]uh1jhjh/ubh)}(h**Description**h]j)}(hj/h]h Description}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhjh/ubh)}(hThis function cleans up the GEM object state, but does not free the memory used to store the object itself. This function is meant to be a dedicated helper for the Rust GEM bindings.h]hThis function cleans up the GEM object state, but does not free the memory used to store the object itself. This function is meant to be a dedicated helper for the Rust GEM bindings.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhjh/ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_shmem_free (C function)c.drm_gem_shmem_freehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h)}(h;void drm_gem_shmem_free(struct drm_gem_shmem_object *shmem)h](j)}(hvoidh]hvoid}(hj 0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj 0hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj 0hhhj0hKubjg)}(hdrm_gem_shmem_freeh]jm)}(hdrm_gem_shmem_freeh]hdrm_gem_shmem_free}(hj.0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*0ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj 0hhhj0hKubj)}(h$(struct drm_gem_shmem_object *shmem)h]j)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hjJ0hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjF0ubjV)}(h h]h }(hjW0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjF0ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hjh0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhje0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjj0modnameN classnameNjj)}j]j )}jj00sbc.drm_gem_shmem_freeasbuh1hhjF0ubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjF0ubj4)}(hj7h]h*}(hj0hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjF0ubjm)}(hshmemh]hshmem}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjF0ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjB0ubah}(h]h ]h"]h$]h&]jjuh1jhj 0hhhj0hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj0hhhj0hKubah}(h]j0ah ](jjeh"]h$]h&]jj)jhuh1j7hj0hKhj0hhubj)}(hhh]h)}(h1Free resources associated with a shmem GEM objecth]h1Free resources associated with a shmem GEM object}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj0hhubah}(h]h ]h"]h$]h&]uh1jhj0hhhj0hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj0jj0jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gem_shmem_object *shmem`` shmem GEM object to free **Description** This function cleans up the GEM object state and frees the memory used to store the object itself.h](h)}(h**Parameters**h]j)}(hj0h]h Parameters}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj0ubj)}(hhh]j)}(h@``struct drm_gem_shmem_object *shmem`` shmem GEM object to free h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hj1h]h"struct drm_gem_shmem_object *shmem}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 1ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj1ubj )}(hhh]h)}(hshmem GEM object to freeh]hshmem GEM object to free}(hj'1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#1hKhj$1ubah}(h]h ]h"]h$]h&]uh1j hj1ubeh}(h]h ]h"]h$]h&]uh1jhj#1hKhj1ubah}(h]h ]h"]h$]h&]uh1jhj0ubh)}(h**Description**h]j)}(hjI1h]h Description}(hjK1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjG1ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj0ubh)}(hbThis function cleans up the GEM object state and frees the memory used to store the object itself.h]hbThis function cleans up the GEM object state and frees the memory used to store the object itself.}(hj_1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chKhj0ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_shmem_pin (C function)c.drm_gem_shmem_pinhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h:int drm_gem_shmem_pin (struct drm_gem_shmem_object *shmem)h]j>)}(h9int drm_gem_shmem_pin(struct drm_gem_shmem_object *shmem)h](j)}(hinth]hint}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM-ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1hhhj1hM-ubjg)}(hdrm_gem_shmem_pinh]jm)}(hdrm_gem_shmem_pinh]hdrm_gem_shmem_pin}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj1hhhj1hM-ubj)}(h$(struct drm_gem_shmem_object *shmem)h]j)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hj1hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj1ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]j )}jj1sbc.drm_gem_shmem_pinasbuh1hhj1ubjV)}(h h]h }(hj 2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubj4)}(hj7h]h*}(hj2hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj1ubjm)}(hshmemh]hshmem}(hj$2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj1ubah}(h]h ]h"]h$]h&]jjuh1jhj1hhhj1hM-ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj1hhhj1hM-ubah}(h]j1ah ](jjeh"]h$]h&]jj)jhuh1j7hj1hM-hj1hhubj)}(hhh]h)}(h(Pin backing pages for a shmem GEM objecth]h(Pin backing pages for a shmem GEM object}(hjN2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM-hjK2hhubah}(h]h ]h"]h$]h&]uh1jhj1hhhj1hM-ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjf2jjf2jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gem_shmem_object *shmem`` shmem GEM object **Description** This function makes sure the backing pages are pinned in memory while the buffer is exported. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjp2h]h Parameters}(hjr2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjn2ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM1hjj2ubj)}(hhh]j)}(h8``struct drm_gem_shmem_object *shmem`` shmem GEM object h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hj2h]h"struct drm_gem_shmem_object *shmem}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM.hj2ubj )}(hhh]h)}(hshmem GEM objecth]hshmem GEM object}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hM.hj2ubah}(h]h ]h"]h$]h&]uh1j hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hM.hj2ubah}(h]h ]h"]h$]h&]uh1jhjj2ubh)}(h**Description**h]j)}(hj2h]h Description}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM0hjj2ubh)}(h]This function makes sure the backing pages are pinned in memory while the buffer is exported.h]h]This function makes sure the backing pages are pinned in memory while the buffer is exported.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM/hjj2ubh)}(h **Return**h]j)}(hj2h]hReturn}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM2hjj2ubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM3hjj2ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_shmem_unpin (C function)c.drm_gem_shmem_unpinhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h=void drm_gem_shmem_unpin (struct drm_gem_shmem_object *shmem)h]j>)}(h)}(hoint drm_gem_shmem_dumb_create(struct drm_file *file, struct drm_device *dev, struct drm_mode_create_dumb *args)h](j)}(hinth]hint}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM ubjV)}(h h]h }(hj4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4hhhj4hM ubjg)}(hdrm_gem_shmem_dumb_createh]jm)}(hdrm_gem_shmem_dumb_createh]hdrm_gem_shmem_dumb_create}(hj4hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj4hhhj4hM ubj)}(hR(struct drm_file *file, struct drm_device *dev, struct drm_mode_create_dumb *args)h](j)}(hstruct drm_file *fileh](jD)}(hjh]hstruct}(hj4hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j )}jj4sbc.drm_gem_shmem_dumb_createasbuh1hhj4ubjV)}(h h]h }(hj25hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubj4)}(hj7h]h*}(hj@5hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj4ubjm)}(hfileh]hfile}(hjM5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubj)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjf5hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjb5ubjV)}(h h]h }(hjs5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjb5ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j.5c.drm_gem_shmem_dumb_createasbuh1hhjb5ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjb5ubj4)}(hj7h]h*}(hj5hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjb5ubjm)}(hdevh]hdev}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjb5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubj)}(h!struct drm_mode_create_dumb *argsh](jD)}(hjh]hstruct}(hj5hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj5ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubh)}(hhh]jm)}(hdrm_mode_create_dumbh]hdrm_mode_create_dumb}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j.5c.drm_gem_shmem_dumb_createasbuh1hhj5ubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubj4)}(hj7h]h*}(hj 6hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj5ubjm)}(hargsh]hargs}(hj-6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj4ubeh}(h]h ]h"]h$]h&]jjuh1jhj4hhhj4hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj4hhhj4hM ubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1j7hj4hM hj4hhubj)}(hhh]h)}(h!Create a dumb shmem buffer objecth]h!Create a dumb shmem buffer object}(hjW6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM hjT6hhubah}(h]h ]h"]h$]h&]uh1jhj4hhhj4hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjo6jjo6jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_file *file`` DRM file structure to create the dumb buffer for ``struct drm_device *dev`` DRM device ``struct drm_mode_create_dumb *args`` IOCTL data **Description** This function computes the pitch of the dumb buffer and rounds it up to an integer number of bytes per pixel. Drivers for hardware that doesn't have any additional restrictions on the pitch can directly use this function as their :c:type:`drm_driver.dumb_create ` callback. For hardware with additional restrictions, drivers can adjust the fields set up by userspace before calling into this function. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjy6h]h Parameters}(hj{6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjw6ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjs6ubj)}(hhh](j)}(hK``struct drm_file *file`` DRM file structure to create the dumb buffer for h](j)}(h``struct drm_file *file``h]j)}(hj6h]hstruct drm_file *file}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM hj6ubj )}(hhh]h)}(h0DRM file structure to create the dumb buffer forh]h0DRM file structure to create the dumb buffer for}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hM hj6ubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hM hj6ubj)}(h&``struct drm_device *dev`` DRM device h](j)}(h``struct drm_device *dev``h]j)}(hj6h]hstruct drm_device *dev}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj6ubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hMhj6ubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hMhj6ubj)}(h1``struct drm_mode_create_dumb *args`` IOCTL data h](j)}(h%``struct drm_mode_create_dumb *args``h]j)}(hj 7h]h!struct drm_mode_create_dumb *args}(hj 7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj7ubj )}(hhh]h)}(h IOCTL datah]h IOCTL data}(hj#7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMhj 7ubah}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhj7hMhj6ubeh}(h]h ]h"]h$]h&]uh1jhjs6ubh)}(h**Description**h]j)}(hjE7h]h Description}(hjG7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjC7ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjs6ubh)}(hXThis function computes the pitch of the dumb buffer and rounds it up to an integer number of bytes per pixel. Drivers for hardware that doesn't have any additional restrictions on the pitch can directly use this function as their :c:type:`drm_driver.dumb_create ` callback.h](hThis function computes the pitch of the dumb buffer and rounds it up to an integer number of bytes per pixel. Drivers for hardware that doesn’t have any additional restrictions on the pitch can directly use this function as their }(hj[7hhhNhNubh)}(h-:c:type:`drm_driver.dumb_create `h]j)}(hje7h]hdrm_driver.dumb_create}(hjg7hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjc7ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj[7ubh callback.}(hj[7hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj7hMhjs6ubh)}(hFor hardware with additional restrictions, drivers can adjust the fields set up by userspace before calling into this function.h]hFor hardware with additional restrictions, drivers can adjust the fields set up by userspace before calling into this function.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjs6ubh)}(h **Return**h]j)}(hj7h]hReturn}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjs6ubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjs6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_shmem_mmap (C function)c.drm_gem_shmem_mmaphNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hWint drm_gem_shmem_mmap (struct drm_gem_shmem_object *shmem, struct vm_area_struct *vma)h]j>)}(hVint drm_gem_shmem_mmap(struct drm_gem_shmem_object *shmem, struct vm_area_struct *vma)h](j)}(hinth]hint}(hj7hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj7hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMubjV)}(h h]h }(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj7hhhj7hMubjg)}(hdrm_gem_shmem_mmaph]jm)}(hdrm_gem_shmem_mmaph]hdrm_gem_shmem_mmap}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj7hhhj7hMubj)}(h@(struct drm_gem_shmem_object *shmem, struct vm_area_struct *vma)h](j)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hj 8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj8ubjV)}(h h]h }(hj-8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj>8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@8modnameN classnameNjj)}j]j )}jj8sbc.drm_gem_shmem_mmapasbuh1hhj8ubjV)}(h h]h }(hj^8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8ubj4)}(hj7h]h*}(hjl8hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj8ubjm)}(hshmemh]hshmem}(hjy8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj8ubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8ubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj8modnameN classnameNjj)}j]jZ8c.drm_gem_shmem_mmapasbuh1hhj8ubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8ubj4)}(hj7h]h*}(hj8hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj8ubjm)}(hvmah]hvma}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj8ubeh}(h]h ]h"]h$]h&]jjuh1jhj7hhhj7hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj7hhhj7hMubah}(h]j7ah ](jjeh"]h$]h&]jj)jhuh1j7hj7hMhj7hhubj)}(hhh]h)}(hMemory-map a shmem GEM objecth]hMemory-map a shmem GEM object}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj9hhubah}(h]h ]h"]h$]h&]uh1jhj7hhhj7hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj+9jj+9jjjuh1j2hhhjhNhNubj)}(hX>**Parameters** ``struct drm_gem_shmem_object *shmem`` shmem GEM object ``struct vm_area_struct *vma`` VMA for the area to be mapped **Description** This function implements an augmented version of the GEM DRM file mmap operation for shmem objects. **Return** 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hj59h]h Parameters}(hj79hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj39ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj/9ubj)}(hhh](j)}(h8``struct drm_gem_shmem_object *shmem`` shmem GEM object h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hjT9h]h"struct drm_gem_shmem_object *shmem}(hjV9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR9ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjN9ubj )}(hhh]h)}(hshmem GEM objecth]hshmem GEM object}(hjm9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhji9hMhjj9ubah}(h]h ]h"]h$]h&]uh1j hjN9ubeh}(h]h ]h"]h$]h&]uh1jhji9hMhjK9ubj)}(h=``struct vm_area_struct *vma`` VMA for the area to be mapped h](j)}(h``struct vm_area_struct *vma``h]j)}(hj9h]hstruct vm_area_struct *vma}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj9ubj )}(hhh]h)}(hVMA for the area to be mappedh]hVMA for the area to be mapped}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj9hMhj9ubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhj9hMhjK9ubeh}(h]h ]h"]h$]h&]uh1jhj/9ubh)}(h**Description**h]j)}(hj9h]h Description}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj/9ubh)}(hcThis function implements an augmented version of the GEM DRM file mmap operation for shmem objects.h]hcThis function implements an augmented version of the GEM DRM file mmap operation for shmem objects.}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj/9ubh)}(h **Return**h]j)}(hj9h]hReturn}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj/9ubh)}(h10 on success or a negative error code on failure.h]h10 on success or a negative error code on failure.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj/9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gem_shmem_print_info (C function)c.drm_gem_shmem_print_infohNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(htvoid drm_gem_shmem_print_info (const struct drm_gem_shmem_object *shmem, struct drm_printer *p, unsigned int indent)h]j>)}(hsvoid drm_gem_shmem_print_info(const struct drm_gem_shmem_object *shmem, struct drm_printer *p, unsigned int indent)h](j)}(hvoidh]hvoid}(hj4:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj0:hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMubjV)}(h h]h }(hjC:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0:hhhjB:hMubjg)}(hdrm_gem_shmem_print_infoh]jm)}(hdrm_gem_shmem_print_infoh]hdrm_gem_shmem_print_info}(hjU:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQ:ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj0:hhhjB:hMubj)}(hV(const struct drm_gem_shmem_object *shmem, struct drm_printer *p, unsigned int indent)h](j)}(h(const struct drm_gem_shmem_object *shmemh](jD)}(hj h]hconst}(hjq:hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjm:ubjV)}(h h]h }(hj~:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm:ubjD)}(hjh]hstruct}(hj:hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjm:ubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm:ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj:modnameN classnameNjj)}j]j )}jjW:sbc.drm_gem_shmem_print_infoasbuh1hhjm:ubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm:ubj4)}(hj7h]h*}(hj:hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjm:ubjm)}(hshmemh]hshmem}(hj:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjm:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhji:ubj)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hj:hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj:ubjV)}(h h]h }(hj ;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj;modnameN classnameNjj)}j]j:c.drm_gem_shmem_print_infoasbuh1hhj:ubjV)}(h h]h }(hj:;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubj4)}(hj7h]h*}(hjH;hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj:ubjm)}(hj@h]hp}(hjU;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhji:ubj)}(hunsigned int indenth](j)}(hunsignedh]hunsigned}(hjm;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji;ubjV)}(h h]h }(hj{;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhji;ubj)}(hinth]hint}(hj;hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhji;ubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhji;ubjm)}(hindenth]hindent}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhji;ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhji:ubeh}(h]h ]h"]h$]h&]jjuh1jhj0:hhhjB:hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj,:hhhjB:hMubah}(h]j':ah ](jjeh"]h$]h&]jj)jhuh1j7hjB:hMhj):hhubj)}(hhh]h)}(h5Print :c:type:`drm_gem_shmem_object` info for debugfsh](hPrint }(hj;hhhNhNubh)}(h:c:type:`drm_gem_shmem_object`h]j)}(hj;h]hdrm_gem_shmem_object}(hj;hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j:c.drm_gem_shmem_print_infoasbjMdrm_gem_shmem_objectuh1hhjd)hKchj;ubh info for debugfs}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj;hhubah}(h]h ]h"]h$]h&]uh1jhj):hhhjB:hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj<jj<jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``const struct drm_gem_shmem_object *shmem`` shmem GEM object ``struct drm_printer *p`` DRM printer ``unsigned int indent`` Tab indentation levelh](h)}(h**Parameters**h]j)}(hj<h]h Parameters}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj<ubj)}(hhh](j)}(h>``const struct drm_gem_shmem_object *shmem`` shmem GEM object h](j)}(h,``const struct drm_gem_shmem_object *shmem``h]j)}(hj8<h]h(const struct drm_gem_shmem_object *shmem}(hj:<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6<ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj2<ubj )}(hhh]h)}(hshmem GEM objecth]hshmem GEM object}(hjQ<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjM<hMhjN<ubah}(h]h ]h"]h$]h&]uh1j hj2<ubeh}(h]h ]h"]h$]h&]uh1jhjM<hMhj/<ubj)}(h&``struct drm_printer *p`` DRM printer h](j)}(h``struct drm_printer *p``h]j)}(hjq<h]hstruct drm_printer *p}(hjs<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjo<ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhjk<ubj )}(hhh]h)}(h DRM printerh]h DRM printer}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj<ubah}(h]h ]h"]h$]h&]uh1j hjk<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhj/<ubj)}(h-``unsigned int indent`` Tab indentation levelh](j)}(h``unsigned int indent``h]j)}(hj<h]hunsigned int indent}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj<ubj )}(hhh]h)}(hTab indentation levelh]hTab indentation level}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj<ubah}(h]h ]h"]h$]h&]uh1j hj<ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhj/<ubeh}(h]h ]h"]h$]h&]uh1jhj<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gem_shmem_get_sg_table (C function)c.drm_gem_shmem_get_sg_tablehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hQstruct sg_table * drm_gem_shmem_get_sg_table (struct drm_gem_shmem_object *shmem)h]j>)}(hOstruct sg_table *drm_gem_shmem_get_sg_table(struct drm_gem_shmem_object *shmem)h](jD)}(hjh]hstruct}(hj=hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj=hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=hhhj=hMubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj#=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj =ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%=modnameN classnameNjj)}j]j )}jdrm_gem_shmem_get_sg_tablesbc.drm_gem_shmem_get_sg_tableasbuh1hhj=hhhj=hMubjV)}(h h]h }(hjD=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=hhhj=hMubj4)}(hj7h]h*}(hjR=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj=hhhj=hMubjg)}(hdrm_gem_shmem_get_sg_tableh]jm)}(hjA=h]hdrm_gem_shmem_get_sg_table}(hjc=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_=ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj=hhhj=hMubj)}(h$(struct drm_gem_shmem_object *shmem)h]j)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hj~=hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjz=ubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjz=ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=modnameN classnameNjj)}j]j?=c.drm_gem_shmem_get_sg_tableasbuh1hhjz=ubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjz=ubj4)}(hj7h]h*}(hj=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjz=ubjm)}(hshmemh]hshmem}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjz=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjv=ubah}(h]h ]h"]h$]h&]jjuh1jhj=hhhj=hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj<hhhj=hMubah}(h]j<ah ](jjeh"]h$]h&]jj)jhuh1j7hj=hMhj<hhubj)}(hhh]h)}(hEProvide a scatter/gather table of pinned pages for a shmem GEM objecth]hEProvide a scatter/gather table of pinned pages for a shmem GEM object}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj=hhubah}(h]h ]h"]h$]h&]uh1jhj<hhhj=hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj>jj>jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_gem_shmem_object *shmem`` shmem GEM object **Description** This function exports a scatter/gather table suitable for PRIME usage by calling the standard DMA mapping API. Drivers who need to acquire an scatter/gather table for objects need to call drm_gem_shmem_get_pages_sgt() instead. **Return** A pointer to the scatter/gather table of pinned pages or error pointer on failure.h](h)}(h**Parameters**h]j)}(hj!>h]h Parameters}(hj#>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj>ubj)}(hhh]j)}(h8``struct drm_gem_shmem_object *shmem`` shmem GEM object h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hj@>h]h"struct drm_gem_shmem_object *shmem}(hjB>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>>ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj:>ubj )}(hhh]h)}(hshmem GEM objecth]hshmem GEM object}(hjY>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjU>hMhjV>ubah}(h]h ]h"]h$]h&]uh1j hj:>ubeh}(h]h ]h"]h$]h&]uh1jhjU>hMhj7>ubah}(h]h ]h"]h$]h&]uh1jhj>ubh)}(h**Description**h]j)}(hj{>h]h Description}(hj}>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjy>ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj>ubh)}(hnThis function exports a scatter/gather table suitable for PRIME usage by calling the standard DMA mapping API.h]hnThis function exports a scatter/gather table suitable for PRIME usage by calling the standard DMA mapping API.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj>ubh)}(hsDrivers who need to acquire an scatter/gather table for objects need to call drm_gem_shmem_get_pages_sgt() instead.h]hsDrivers who need to acquire an scatter/gather table for objects need to call drm_gem_shmem_get_pages_sgt() instead.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj>ubh)}(h **Return**h]j)}(hj>h]hReturn}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj>ubh)}(hRA pointer to the scatter/gather table of pinned pages or error pointer on failure.h]hRA pointer to the scatter/gather table of pinned pages or error pointer on failure.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj>ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gem_shmem_get_pages_sgt (C function)c.drm_gem_shmem_get_pages_sgthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hRstruct sg_table * drm_gem_shmem_get_pages_sgt (struct drm_gem_shmem_object *shmem)h]j>)}(hPstruct sg_table *drm_gem_shmem_get_pages_sgt(struct drm_gem_shmem_object *shmem)h](jD)}(hjh]hstruct}(hj>hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj>hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhj?hMubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj?modnameN classnameNjj)}j]j )}jdrm_gem_shmem_get_pages_sgtsbc.drm_gem_shmem_get_pages_sgtasbuh1hhj>hhhj?hMubjV)}(h h]h }(hj6?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhj?hMubj4)}(hj7h]h*}(hjD?hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>hhhj?hMubjg)}(hdrm_gem_shmem_get_pages_sgth]jm)}(hj3?h]hdrm_gem_shmem_get_pages_sgt}(hjU?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQ?ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj>hhhj?hMubj)}(h$(struct drm_gem_shmem_object *shmem)h]j)}(h"struct drm_gem_shmem_object *shmemh](jD)}(hjh]hstruct}(hjp?hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjl?ubjV)}(h h]h }(hj}?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjl?ubh)}(hhh]jm)}(hdrm_gem_shmem_objecth]hdrm_gem_shmem_object}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj?modnameN classnameNjj)}j]j1?c.drm_gem_shmem_get_pages_sgtasbuh1hhjl?ubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjl?ubj4)}(hj7h]h*}(hj?hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjl?ubjm)}(hshmemh]hshmem}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjl?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjh?ubah}(h]h ]h"]h$]h&]jjuh1jhj>hhhj?hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj>hhhj?hMubah}(h]j>ah ](jjeh"]h$]h&]jj)jhuh1j7hj?hMhj>hhubj)}(hhh]h)}(hRPin pages, dma map them, and return a scatter/gather table for a shmem GEM object.h]hRPin pages, dma map them, and return a scatter/gather table for a shmem GEM object.}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj?hhubah}(h]h ]h"]h$]h&]uh1jhj>hhhj?hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj @jj @jjjuh1j2hhhjhNhNubj)}(hX2**Parameters** ``struct drm_gem_shmem_object *shmem`` shmem GEM object **Description** This function returns a scatter/gather table suitable for driver usage. If the sg table doesn't exist, the pages are pinned, dma-mapped, and a sg table created. This is the main function for drivers to get at backing storage, and it hides and difference between dma-buf imported and natively allocated objects. drm_gem_shmem_get_sg_table() should not be directly called by drivers. **Return** A pointer to the scatter/gather table of pinned pages or errno on failure.h](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj @ubj)}(hhh]j)}(h8``struct drm_gem_shmem_object *shmem`` shmem GEM object h](j)}(h&``struct drm_gem_shmem_object *shmem``h]j)}(hj2@h]h"struct drm_gem_shmem_object *shmem}(hj4@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0@ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj,@ubj )}(hhh]h)}(hshmem GEM objecth]hshmem GEM object}(hjK@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjG@hMhjH@ubah}(h]h ]h"]h$]h&]uh1j hj,@ubeh}(h]h ]h"]h$]h&]uh1jhjG@hMhj)@ubah}(h]h ]h"]h$]h&]uh1jhj @ubh)}(h**Description**h]j)}(hjm@h]h Description}(hjo@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjk@ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj @ubh)}(hThis function returns a scatter/gather table suitable for driver usage. If the sg table doesn't exist, the pages are pinned, dma-mapped, and a sg table created.h]hThis function returns a scatter/gather table suitable for driver usage. If the sg table doesn’t exist, the pages are pinned, dma-mapped, and a sg table created.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj @ubh)}(hThis is the main function for drivers to get at backing storage, and it hides and difference between dma-buf imported and natively allocated objects. drm_gem_shmem_get_sg_table() should not be directly called by drivers.h]hThis is the main function for drivers to get at backing storage, and it hides and difference between dma-buf imported and natively allocated objects. drm_gem_shmem_get_sg_table() should not be directly called by drivers.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMhj @ubh)}(h **Return**h]j)}(hj@h]hReturn}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM!hj @ubh)}(hJA pointer to the scatter/gather table of pinned pages or errno on failure.h]hJA pointer to the scatter/gather table of pinned pages or errno on failure.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM"hj @ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.0drm_gem_shmem_prime_import_sg_table (C function)%c.drm_gem_shmem_prime_import_sg_tablehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hstruct drm_gem_object * drm_gem_shmem_prime_import_sg_table (struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h]j>)}(hstruct drm_gem_object *drm_gem_shmem_prime_import_sg_table(struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h](jD)}(hjh]hstruct}(hj@hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj@hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM5ubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@hhhj@hM5ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj AmodnameN classnameNjj)}j]j )}j#drm_gem_shmem_prime_import_sg_tablesb%c.drm_gem_shmem_prime_import_sg_tableasbuh1hhj@hhhj@hM5ubjV)}(h h]h }(hj(AhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@hhhj@hM5ubj4)}(hj7h]h*}(hj6AhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj@hhhj@hM5ubjg)}(h#drm_gem_shmem_prime_import_sg_tableh]jm)}(hj%Ah]h#drm_gem_shmem_prime_import_sg_table}(hjGAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCAubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj@hhhj@hM5ubj)}(hQ(struct drm_device *dev, struct dma_buf_attachment *attach, struct sg_table *sgt)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjbAhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj^AubjV)}(h h]h }(hjoAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj^Aubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}Aubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]j#A%c.drm_gem_shmem_prime_import_sg_tableasbuh1hhj^AubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj^Aubj4)}(hj7h]h*}(hjAhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj^Aubjm)}(hdevh]hdev}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^Aubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZAubj)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hjAhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjAubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]j#A%c.drm_gem_shmem_prime_import_sg_tableasbuh1hhjAubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAubj4)}(hj7h]h*}(hjBhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjAubjm)}(hattachh]hattach}(hj)BhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZAubj)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hjBBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj>BubjV)}(h h]h }(hjOBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>Bubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj`BhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]Bubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbBmodnameN classnameNjj)}j]j#A%c.drm_gem_shmem_prime_import_sg_tableasbuh1hhj>BubjV)}(h h]h }(hj~BhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>Bubj4)}(hj7h]h*}(hjBhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>Bubjm)}(hsgth]hsgt}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>Bubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZAubeh}(h]h ]h"]h$]h&]jjuh1jhj@hhhj@hM5ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj@hhhj@hM5ubah}(h]j@ah ](jjeh"]h$]h&]jj)jhuh1j7hj@hM5hj@hhubj)}(hhh]h)}(hUProduce a shmem GEM object from another driver's scatter/gather table of pinned pagesh]hWProduce a shmem GEM object from another driver’s scatter/gather table of pinned pages}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM5hjBhhubah}(h]h ]h"]h$]h&]uh1jhj@hhhj@hM5ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjBjjBjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_device *dev`` Device to import into ``struct dma_buf_attachment *attach`` DMA-BUF attachment ``struct sg_table *sgt`` Scatter/gather table of pinned pages **Description** This function imports a scatter/gather table exported via DMA-BUF by another driver. Drivers that use the shmem helpers should set this as their :c:type:`drm_driver.gem_prime_import_sg_table ` callback. **Return** A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.h](h)}(h**Parameters**h]j)}(hjBh]h Parameters}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM9hjBubj)}(hhh](j)}(h1``struct drm_device *dev`` Device to import into h](j)}(h``struct drm_device *dev``h]j)}(hjCh]hstruct drm_device *dev}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM7hjBubj )}(hhh]h)}(hDevice to import intoh]hDevice to import into}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM7hjCubah}(h]h ]h"]h$]h&]uh1j hjBubeh}(h]h ]h"]h$]h&]uh1jhjChM7hjBubj)}(h9``struct dma_buf_attachment *attach`` DMA-BUF attachment h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hj=Ch]h!struct dma_buf_attachment *attach}(hj?ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;Cubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM8hj7Cubj )}(hhh]h)}(hDMA-BUF attachmenth]hDMA-BUF attachment}(hjVChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRChM8hjSCubah}(h]h ]h"]h$]h&]uh1j hj7Cubeh}(h]h ]h"]h$]h&]uh1jhjRChM8hjBubj)}(h>``struct sg_table *sgt`` Scatter/gather table of pinned pages h](j)}(h``struct sg_table *sgt``h]j)}(hjvCh]hstruct sg_table *sgt}(hjxChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtCubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM9hjpCubj )}(hhh]h)}(h$Scatter/gather table of pinned pagesh]h$Scatter/gather table of pinned pages}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChM9hjCubah}(h]h ]h"]h$]h&]uh1j hjpCubeh}(h]h ]h"]h$]h&]uh1jhjChM9hjBubeh}(h]h ]h"]h$]h&]uh1jhjBubh)}(h**Description**h]j)}(hjCh]h Description}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM;hjBubh)}(hThis function imports a scatter/gather table exported via DMA-BUF by another driver. Drivers that use the shmem helpers should set this as their :c:type:`drm_driver.gem_prime_import_sg_table ` callback.h](hThis function imports a scatter/gather table exported via DMA-BUF by another driver. Drivers that use the shmem helpers should set this as their }(hjChhhNhNubh)}(h;:c:type:`drm_driver.gem_prime_import_sg_table `h]j)}(hjCh]h$drm_driver.gem_prime_import_sg_table}(hjChhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM:hjCubh callback.}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChM:hjBubh)}(h **Return**h]j)}(hjCh]hReturn}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM>hjBubh)}(h]A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.h]h]A pointer to a newly created GEM object or an ERR_PTR-encoded negative error code on failure.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM?hjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j..drm_gem_shmem_prime_import_no_map (C function)#c.drm_gem_shmem_prime_import_no_maphNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hkstruct drm_gem_object * drm_gem_shmem_prime_import_no_map (struct drm_device *dev, struct dma_buf *dma_buf)h]j>)}(histruct drm_gem_object *drm_gem_shmem_prime_import_no_map(struct drm_device *dev, struct dma_buf *dma_buf)h](jD)}(hjh]hstruct}(hj@DhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj` implementation.h](h)}(h**Parameters**h]j)}(hjEh]h Parameters}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM\hjEubj)}(hhh](j)}(h1``struct drm_device *dev`` Device to import into h](j)}(h``struct drm_device *dev``h]j)}(hjEh]hstruct drm_device *dev}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMYhjEubj )}(hhh]h)}(hDevice to import intoh]hDevice to import into}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMYhjFubah}(h]h ]h"]h$]h&]uh1j hjEubeh}(h]h ]h"]h$]h&]uh1jhjFhMYhjEubj)}(h5``struct dma_buf *dma_buf`` dma-buf object to import h](j)}(h``struct dma_buf *dma_buf``h]j)}(hj%Fh]hstruct dma_buf *dma_buf}(hj'FhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#Fubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chMZhjFubj )}(hhh]h)}(hdma-buf object to importh]hdma-buf object to import}(hj>FhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:FhMZhj;Fubah}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhj:FhMZhjEubeh}(h]h ]h"]h$]h&]uh1jhjEubh)}(h**Description**h]j)}(hj`Fh]h Description}(hjbFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^Fubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM\hjEubh)}(hDrivers that use the shmem helpers but also wants to import dmabuf without mapping its sg_table can use this as their :c:type:`drm_driver.gem_prime_import ` implementation.h](hvDrivers that use the shmem helpers but also wants to import dmabuf without mapping its sg_table can use this as their }(hjvFhhhNhNubh)}(h2:c:type:`drm_driver.gem_prime_import `h]j)}(hjFh]hdrm_driver.gem_prime_import}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj~Fubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:396: ./drivers/gpu/drm/drm_gem_shmem_helper.chM[hjvFubh implementation.}(hjvFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjFhM[hjEubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]#gem-shmem-helper-function-referenceah ]h"]#gem shmem helper function referenceah$]h&]uh1hhjzhhhhhMubh)}(hhh](h)}(h#GEM VRAM Helper Functions Referenceh]h#GEM VRAM Helper Functions Reference}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhhhhhMubh)}(hThis library provides :c:type:`struct drm_gem_vram_object ` (GEM VRAM), a GEM buffer object that is backed by video RAM (VRAM). It can be used for framebuffer devices with dedicated memory.h](hThis library provides }(hjFhhhNhNubh)}(h::c:type:`struct drm_gem_vram_object `h]j)}(hjFh]hstruct drm_gem_vram_object}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_vram_objectuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjFubh (GEM VRAM), a GEM buffer object that is backed by video RAM (VRAM). It can be used for framebuffer devices with dedicated memory.}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjFhKhjFhhubh)}(hXThe data structure :c:type:`struct drm_vram_mm ` and its helpers implement a memory manager for simple framebuffer devices with dedicated video memory. GEM VRAM buffer objects are either placed in the video memory or remain evicted to system memory.h](hThe data structure }(hjFhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hjGh]hstruct drm_vram_mm}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chK hjFubh and its helpers implement a memory manager for simple framebuffer devices with dedicated video memory. GEM VRAM buffer objects are either placed in the video memory or remain evicted to system memory.}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj!GhK hjFhhubh)}(hX|With the GEM interface userspace applications create, manage and destroy graphics buffers, such as an on-screen framebuffer. GEM does not provide an implementation of these interfaces. It's up to the DRM driver to provide an implementation that suits the hardware. If the hardware device contains dedicated video memory, the DRM driver can use the VRAM helper library. Each active buffer object is stored in video RAM. Active buffer are used for drawing the current frame, typically something like the frame's scanout buffer or the cursor image. If there's no more space left in VRAM, inactive GEM objects can be moved to system memory.h]hXWith the GEM interface userspace applications create, manage and destroy graphics buffers, such as an on-screen framebuffer. GEM does not provide an implementation of these interfaces. It’s up to the DRM driver to provide an implementation that suits the hardware. If the hardware device contains dedicated video memory, the DRM driver can use the VRAM helper library. Each active buffer object is stored in video RAM. Active buffer are used for drawing the current frame, typically something like the frame’s scanout buffer or the cursor image. If there’s no more space left in VRAM, inactive GEM objects can be moved to system memory.}(hj,GhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chK%hjFhhubh)}(hXTo initialize the VRAM helper library call drmm_vram_helper_init(). The function allocates and initializes an instance of :c:type:`struct drm_vram_mm ` in :c:type:`struct drm_device `.vram_mm . Use :c:type:`DRM_GEM_VRAM_DRIVER` to initialize :c:type:`struct drm_driver ` and :c:type:`DRM_VRAM_MM_FILE_OPERATIONS` to initialize :c:type:`struct file_operations `; as illustrated below.h](hzTo initialize the VRAM helper library call drmm_vram_helper_init(). The function allocates and initializes an instance of }(hj;GhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hjEGh]hstruct drm_vram_mm}(hjGGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjCGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chK/hj;Gubh in }(hj;GhhhNhNubh)}(h(:c:type:`struct drm_device `h]j)}(hjiGh]hstruct drm_device}(hjkGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjgGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhjbGhK/hj;Gubh.vram_mm . Use }(hj;GhhhNhNubh)}(h:c:type:`DRM_GEM_VRAM_DRIVER`h]j)}(hjGh]hDRM_GEM_VRAM_DRIVER}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_GEM_VRAM_DRIVERuh1hhjbGhK/hj;Gubh to initialize }(hj;GhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjGh]hstruct drm_driver}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhjbGhK/hj;Gubh and }(hj;GhhhNhNubh)}(h%:c:type:`DRM_VRAM_MM_FILE_OPERATIONS`h]j)}(hjGh]hDRM_VRAM_MM_FILE_OPERATIONS}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_VRAM_MM_FILE_OPERATIONSuh1hhjbGhK/hj;Gubh to initialize }hj;Gsbh)}(h2:c:type:`struct file_operations `h]j)}(hjGh]hstruct file_operations}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfile_operationsuh1hhjbGhK/hj;Gubh; as illustrated below.}(hj;GhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjbGhK/hjFhhubjT)}(hXstruct file_operations fops ={ .owner = THIS_MODULE, DRM_VRAM_MM_FILE_OPERATION }; struct drm_driver drv = { .driver_feature = DRM_ ... , .fops = &fops, DRM_GEM_VRAM_DRIVER }; int init_drm_driver() { struct drm_device *dev; uint64_t vram_base; unsigned long vram_size; int ret; // setup device, vram base and size // ... ret = drmm_vram_helper_init(dev, vram_base, vram_size); if (ret) return ret; return 0; }h]hXstruct file_operations fops ={ .owner = THIS_MODULE, DRM_VRAM_MM_FILE_OPERATION }; struct drm_driver drv = { .driver_feature = DRM_ ... , .fops = &fops, DRM_GEM_VRAM_DRIVER }; int init_drm_driver() { struct drm_device *dev; uint64_t vram_base; unsigned long vram_size; int ret; // setup device, vram base and size // ... ret = drmm_vram_helper_init(dev, vram_base, vram_size); if (ret) return ret; return 0; }}hjHsbah}(h]h ]h"]h$]h&]jjj~j~jj~}uh1jSha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chK5hjFhhubh)}(hXDThis creates an instance of :c:type:`struct drm_vram_mm `, exports DRM userspace interfaces for GEM buffer management and initializes file operations to allow for accessing created GEM buffers. With this setup, the DRM driver manages an area of video RAM with VRAM MM and provides GEM VRAM objects to userspace.h](hThis creates an instance of }(hj,HhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hj6Hh]hstruct drm_vram_mm}(hj8HhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj4Hubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chKQhj,Hubh, exports DRM userspace interfaces for GEM buffer management and initializes file operations to allow for accessing created GEM buffers. With this setup, the DRM driver manages an area of video RAM with VRAM MM and provides GEM VRAM objects to userspace.}(hj,HhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjSHhKQhjFhhubh)}(hYou don't have to clean up the instance of VRAM MM. drmm_vram_helper_init() is a managed interface that installs a clean-up handler to run during the DRM device's release.h]hYou don’t have to clean up the instance of VRAM MM. drmm_vram_helper_init() is a managed interface that installs a clean-up handler to run during the DRM device’s release.}(hj^HhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chKWhjFhhubh)}(hXDA buffer object that is pinned in video RAM has a fixed address within that memory region. Call drm_gem_vram_offset() to retrieve this value. Typically it's used to program the hardware's scanout engine for framebuffers, set the cursor overlay's image for a mouse cursor, or use it as input to the hardware's drawing engine.h]hXLA buffer object that is pinned in video RAM has a fixed address within that memory region. Call drm_gem_vram_offset() to retrieve this value. Typically it’s used to program the hardware’s scanout engine for framebuffers, set the cursor overlay’s image for a mouse cursor, or use it as input to the hardware’s drawing engine.}(hjmHhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chK[hjFhhubh)}(hTo access a buffer object's memory from the DRM driver, call drm_gem_vram_vmap(). It maps the buffer into kernel address space and returns the memory address. Use drm_gem_vram_vunmap() to release the mapping.h]hTo access a buffer object’s memory from the DRM driver, call drm_gem_vram_vmap(). It maps the buffer into kernel address space and returns the memory address. Use drm_gem_vram_vunmap() to release the mapping.}(hj|HhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:402: ./drivers/gpu/drm/drm_gem_vram_helper.chKahjFhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_vram_object (C struct)c.drm_gem_vram_objecthNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hdrm_gem_vram_objecth]j>)}(hstruct drm_gem_vram_objecth](jD)}(hjh]hstruct}(hjHhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjHhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHhhhjHhKubjg)}(hdrm_gem_vram_objecth]jm)}(hjHh]hdrm_gem_vram_object}(hjHhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjHhhhjHhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjHhhhjHhKubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1j7hjHhKhjHhhubj)}(hhh]h)}(hGEM object backed by VRAMh]hGEM object backed by VRAM}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK hjHhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhjHhKubeh}(h]h ](jstructeh"]h$]h&]jjjjHjjHjjjuh1j2hhhjFhNhNubj)}(hXG**Definition**:: struct drm_gem_vram_object { struct ttm_buffer_object bo; struct iosys_map map; unsigned int vmap_use_count; struct ttm_placement placement; struct ttm_place placements[2]; }; **Members** ``bo`` TTM buffer object ``map`` Mapping information for **bo** ``vmap_use_count`` Reference count on the virtual address. The address are un-mapped when the count reaches zero. ``placement`` TTM placement information. Supported placements are ``TTM_PL_VRAM`` and ``TTM_PL_SYSTEM`` ``placements`` TTM placement information.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj IhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubh:}(hjIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK$hjIubjT)}(hstruct drm_gem_vram_object { struct ttm_buffer_object bo; struct iosys_map map; unsigned int vmap_use_count; struct ttm_placement placement; struct ttm_place placements[2]; };h]hstruct drm_gem_vram_object { struct ttm_buffer_object bo; struct iosys_map map; unsigned int vmap_use_count; struct ttm_placement placement; struct ttm_place placements[2]; };}hj#Isbah}(h]h ]h"]h$]h&]jjuh1jSh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK&hjIubh)}(h **Members**h]j)}(hj4Ih]hMembers}(hj6IhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2Iubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK.hjIubj)}(hhh](j)}(h``bo`` TTM buffer object h](j)}(h``bo``h]j)}(hjSIh]hbo}(hjUIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQIubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK"hjMIubj )}(hhh]h)}(hTTM buffer objecth]hTTM buffer object}(hjlIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhIhK"hjiIubah}(h]h ]h"]h$]h&]uh1j hjMIubeh}(h]h ]h"]h$]h&]uh1jhjhIhK"hjJIubj)}(h'``map`` Mapping information for **bo** h](j)}(h``map``h]j)}(hjIh]hmap}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK#hjIubj )}(hhh]h)}(hMapping information for **bo**h](hMapping information for }(hjIhhhNhNubj)}(h**bo**h]hbo}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubeh}(h]h ]h"]h$]h&]uh1hhjIhK#hjIubah}(h]h ]h"]h$]h&]uh1j hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhK#hjJIubj)}(hr``vmap_use_count`` Reference count on the virtual address. The address are un-mapped when the count reaches zero. h](j)}(h``vmap_use_count``h]j)}(hjIh]hvmap_use_count}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK:hjIubj )}(hhh]h)}(h^Reference count on the virtual address. The address are un-mapped when the count reaches zero.h]h^Reference count on the virtual address. The address are un-mapped when the count reaches zero.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK9hjIubah}(h]h ]h"]h$]h&]uh1j hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhK:hjJIubj)}(hh``placement`` TTM placement information. Supported placements are ``TTM_PL_VRAM`` and ``TTM_PL_SYSTEM`` h](j)}(h ``placement``h]j)}(hj Jh]h placement}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Jubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK%hjJubj )}(hhh]h)}(hYTTM placement information. Supported placements are ``TTM_PL_VRAM`` and ``TTM_PL_SYSTEM``h](h4TTM placement information. Supported placements are }(hj&JhhhNhNubj)}(h``TTM_PL_VRAM``h]h TTM_PL_VRAM}(hj.JhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&Jubh and }(hj&JhhhNhNubj)}(h``TTM_PL_SYSTEM``h]h TTM_PL_SYSTEM}(hj@JhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&Jubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK$hj#Jubah}(h]h ]h"]h$]h&]uh1j hjJubeh}(h]h ]h"]h$]h&]uh1jhj"JhK%hjJIubj)}(h)``placements`` TTM placement information.h](j)}(h``placements``h]j)}(hjgJh]h placements}(hjiJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeJubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK%hjaJubj )}(hhh]h)}(hTTM placement information.h]hTTM placement information.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK&hj}Jubah}(h]h ]h"]h$]h&]uh1j hjaJubeh}(h]h ]h"]h$]h&]uh1jhj|JhK%hjJIubeh}(h]h ]h"]h$]h&]uh1jhjIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubh)}(h**Description**h]j)}(hjJh]h Description}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK)hjFhhubh)}(hThe type struct drm_gem_vram_object represents a GEM object that is backed by VRAM. It can be used for simple framebuffer devices with dedicated memory. The buffer object can be evicted to system memory if video memory becomes scarce.h]hThe type struct drm_gem_vram_object represents a GEM object that is backed by VRAM. It can be used for simple framebuffer devices with dedicated memory. The buffer object can be evicted to system memory if video memory becomes scarce.}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK&hjFhhubh)}(hXVGEM VRAM objects perform reference counting for pin and mapping operations. So a buffer object that has been pinned N times with drm_gem_vram_pin() must be unpinned N times with drm_gem_vram_unpin(). The same applies to pairs of drm_gem_vram_kmap() and drm_gem_vram_kunmap(), as well as pairs of drm_gem_vram_vmap() and drm_gem_vram_vunmap().h]hXVGEM VRAM objects perform reference counting for pin and mapping operations. So a buffer object that has been pinned N times with drm_gem_vram_pin() must be unpinned N times with drm_gem_vram_unpin(). The same applies to pairs of drm_gem_vram_kmap() and drm_gem_vram_kunmap(), as well as pairs of drm_gem_vram_vmap() and drm_gem_vram_vunmap().}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK+hjFhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_vram_of_bo (C function)c.drm_gem_vram_of_bohNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hNstruct drm_gem_vram_object * drm_gem_vram_of_bo (struct ttm_buffer_object *bo)h]j>)}(hLstruct drm_gem_vram_object *drm_gem_vram_of_bo(struct ttm_buffer_object *bo)h](jD)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjJhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKEubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhjKhKEubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjKubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjKmodnameN classnameNjj)}j]j )}jdrm_gem_vram_of_bosbc.drm_gem_vram_of_boasbuh1hhjJhhhjKhKEubjV)}(h h]h }(hj7KhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhjKhKEubj4)}(hj7h]h*}(hjEKhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjJhhhjKhKEubjg)}(hdrm_gem_vram_of_boh]jm)}(hj4Kh]hdrm_gem_vram_of_bo}(hjVKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRKubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjJhhhjKhKEubj)}(h(struct ttm_buffer_object *bo)h]j)}(hstruct ttm_buffer_object *boh](jD)}(hjh]hstruct}(hjqKhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjmKubjV)}(h h]h }(hj~KhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmKubh)}(hhh]jm)}(httm_buffer_objecth]httm_buffer_object}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjKubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjKmodnameN classnameNjj)}j]j2Kc.drm_gem_vram_of_boasbuh1hhjmKubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmKubj4)}(hj7h]h*}(hjKhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjmKubjm)}(hboh]hbo}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiKubah}(h]h ]h"]h$]h&]jjuh1jhjJhhhjKhKEubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjJhhhjKhKEubah}(h]jJah ](jjeh"]h$]h&]jj)jhuh1j7hjKhKEhjJhhubj)}(hhh]h)}(hfReturns the container of type :c:type:`struct drm_gem_vram_object ` for field bo.h](hReturns the container of type }(hjKhhhNhNubh)}(h::c:type:`struct drm_gem_vram_object `h]j)}(hjKh]hstruct drm_gem_vram_object}(hjKhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j2Kc.drm_gem_vram_of_boasbjMdrm_gem_vram_objectuh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjKubh for field bo.}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKEhjKhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjKhKEubeh}(h]h ](jfunctioneh"]h$]h&]jjjj3Ljj3Ljjjuh1j2hhhjFhNhNubj)}(hu**Parameters** ``struct ttm_buffer_object *bo`` the VRAM buffer object **Return** The containing GEM VRAM objecth](h)}(h**Parameters**h]j)}(hj=Lh]h Parameters}(hj?LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;Lubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKIhj7Lubj)}(hhh]j)}(h8``struct ttm_buffer_object *bo`` the VRAM buffer object h](j)}(h ``struct ttm_buffer_object *bo``h]j)}(hj\Lh]hstruct ttm_buffer_object *bo}(hj^LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZLubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKGhjVLubj )}(hhh]h)}(hthe VRAM buffer objecth]hthe VRAM buffer object}(hjuLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqLhKGhjrLubah}(h]h ]h"]h$]h&]uh1j hjVLubeh}(h]h ]h"]h$]h&]uh1jhjqLhKGhjSLubah}(h]h ]h"]h$]h&]uh1jhj7Lubh)}(h **Return**h]j)}(hjLh]hReturn}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKIhj7Lubh)}(hThe containing GEM VRAM objecth]hThe containing GEM VRAM object}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKHhj7Lubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_vram_of_gem (C function)c.drm_gem_vram_of_gemhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hMstruct drm_gem_vram_object * drm_gem_vram_of_gem (struct drm_gem_object *gem)h]j>)}(hKstruct drm_gem_vram_object *drm_gem_vram_of_gem(struct drm_gem_object *gem)h](jD)}(hjh]hstruct}(hjLhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjLhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKQubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLhhhjLhKQubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjLmodnameN classnameNjj)}j]j )}jdrm_gem_vram_of_gemsbc.drm_gem_vram_of_gemasbuh1hhjLhhhjLhKQubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLhhhjLhKQubj4)}(hj7h]h*}(hj*MhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjLhhhjLhKQubjg)}(hdrm_gem_vram_of_gemh]jm)}(hjMh]hdrm_gem_vram_of_gem}(hj;MhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj7Mubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjLhhhjLhKQubj)}(h(struct drm_gem_object *gem)h]j)}(hstruct drm_gem_object *gemh](jD)}(hjh]hstruct}(hjVMhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjRMubjV)}(h h]h }(hjcMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRMubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjtMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqMubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjvMmodnameN classnameNjj)}j]jMc.drm_gem_vram_of_gemasbuh1hhjRMubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRMubj4)}(hj7h]h*}(hjMhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjRMubjm)}(hgemh]hgem}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjNMubah}(h]h ]h"]h$]h&]jjuh1jhjLhhhjLhKQubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjLhhhjLhKQubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1j7hjLhKQhjLhhubj)}(hhh]h)}(hgReturns the container of type :c:type:`struct drm_gem_vram_object ` for field gem.h](hReturns the container of type }(hjMhhhNhNubh)}(h::c:type:`struct drm_gem_vram_object `h]j)}(hjMh]hstruct drm_gem_vram_object}(hjMhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jMc.drm_gem_vram_of_gemasbjMdrm_gem_vram_objectuh1hhjLhKhjMubh for field gem.}(hjMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKQhjMhhubah}(h]h ]h"]h$]h&]uh1jhjLhhhjLhKQubeh}(h]h ](jfunctioneh"]h$]h&]jjjjNjjNjjjuh1j2hhhjFhNhNubj)}(hk**Parameters** ``struct drm_gem_object *gem`` the GEM object **Return** The containing GEM VRAM objecth](h)}(h**Parameters**h]j)}(hj!Nh]h Parameters}(hj#NhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKUhjNubj)}(hhh]j)}(h.``struct drm_gem_object *gem`` the GEM object h](j)}(h``struct drm_gem_object *gem``h]j)}(hj@Nh]hstruct drm_gem_object *gem}(hjBNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>Nubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKShj:Nubj )}(hhh]h)}(hthe GEM objecth]hthe GEM object}(hjYNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUNhKShjVNubah}(h]h ]h"]h$]h&]uh1j hj:Nubeh}(h]h ]h"]h$]h&]uh1jhjUNhKShj7Nubah}(h]h ]h"]h$]h&]uh1jhjNubh)}(h **Return**h]j)}(hj{Nh]hReturn}(hj}NhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKUhjNubh)}(hThe containing GEM VRAM objecth]hThe containing GEM VRAM object}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKThjNubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)DRM_GEM_VRAM_PLANE_HELPER_FUNCS (C macro)!c.DRM_GEM_VRAM_PLANE_HELPER_FUNCShNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hDRM_GEM_VRAM_PLANE_HELPER_FUNCSh]j>)}(hDRM_GEM_VRAM_PLANE_HELPER_FUNCSh]jg)}(hDRM_GEM_VRAM_PLANE_HELPER_FUNCSh]jm)}(hjNh]hDRM_GEM_VRAM_PLANE_HELPER_FUNCS}(hjNhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjNhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhK~ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjNhhhjNhK~ubah}(h]jNah ](jjeh"]h$]h&]jj)jhuh1j7hjNhK~hjNhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjNhhhjNhK~ubeh}(h]h ](jmacroeh"]h$]h&]jjjjNjjNjjjuh1j2hhhjFhNhNubh)}(h#``DRM_GEM_VRAM_PLANE_HELPER_FUNCS``h]j)}(hjNh]hDRM_GEM_VRAM_PLANE_HELPER_FUNCS}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjFhhubj)}(h Initializes struct drm_plane_helper_funcs for VRAM handling **Description** Drivers may use GEM BOs as VRAM helpers for the framebuffer memory. This macro initializes struct drm_plane_helper_funcs to use the respective helper functions. h](j)}(h)}(hDRM_GEM_VRAM_DRIVERh]jg)}(hDRM_GEM_VRAM_DRIVERh]jm)}(hjiOh]hDRM_GEM_VRAM_DRIVER}(hjsOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoOubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjkOhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjgOhhhjOhKubah}(h]jbOah ](jjeh"]h$]h&]jj)jhuh1j7hjOhKhjdOhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjdOhhhjOhKubeh}(h]h ](jmacroeh"]h$]h&]jjjjOjjOjjjuh1j2hhhjFhNhNubh)}(h``DRM_GEM_VRAM_DRIVER``h]j)}(hjOh]hDRM_GEM_VRAM_DRIVER}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjFhhubj)}(h default callback functions for :c:type:`struct drm_driver ` **Description** Drivers that use VRAM MM and GEM VRAM can use this macro to initialize :c:type:`struct drm_driver ` with default functions. h](j)}(hHdefault callback functions for :c:type:`struct drm_driver ` h]h)}(hGdefault callback functions for :c:type:`struct drm_driver `h](hdefault callback functions for }(hjOhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjOh]hstruct drm_driver}(hjOhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjOubeh}(h]h ]h"]h$]h&]uh1hhjOhKhjOubah}(h]h ]h"]h$]h&]uh1jhjOhKhjOubh)}(h**Description**h]j)}(hjOh]h Description}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjOubh)}(hDrivers that use VRAM MM and GEM VRAM can use this macro to initialize :c:type:`struct drm_driver ` with default functions.h](hGDrivers that use VRAM MM and GEM VRAM can use this macro to initialize }(hjPhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjPh]hstruct drm_driver}(hjPhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjPubh with default functions.}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj6PhKhjOubeh}(h]h ]h"]h$]h&]uh1jhjOhKhjFhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vram_mm (C struct) c.drm_vram_mmhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(h drm_vram_mmh]j>)}(hstruct drm_vram_mmh](jD)}(hjh]hstruct}(hj`PhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj\Phhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKubjV)}(h h]h }(hjnPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\PhhhjmPhKubjg)}(h drm_vram_mmh]jm)}(hjZPh]h drm_vram_mm}(hjPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|Pubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj\PhhhjmPhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjXPhhhjmPhKubah}(h]jSPah ](jjeh"]h$]h&]jj)jhuh1j7hjmPhKhjUPhhubj)}(hhh]h)}(hAn instance of VRAM MMh]hAn instance of VRAM MM}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjPhhubah}(h]h ]h"]h$]h&]uh1jhjUPhhhjmPhKubeh}(h]h ](jstructeh"]h$]h&]jjjjPjjPjjjuh1j2hhhjFhNhNubj)}(hX**Definition**:: struct drm_vram_mm { uint64_t vram_base; size_t vram_size; struct ttm_device bdev; }; **Members** ``vram_base`` Base address of the managed video memory ``vram_size`` Size of the managed video memory in bytes ``bdev`` The TTM BO device.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubh:}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjPubjT)}(hastruct drm_vram_mm { uint64_t vram_base; size_t vram_size; struct ttm_device bdev; };h]hastruct drm_vram_mm { uint64_t vram_base; size_t vram_size; struct ttm_device bdev; };}hjPsbah}(h]h ]h"]h$]h&]jjuh1jSh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjPubh)}(h **Members**h]j)}(hjPh]hMembers}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjPubj)}(hhh](j)}(h7``vram_base`` Base address of the managed video memory h](j)}(h ``vram_base``h]j)}(hjQh]h vram_base}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Qubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhj Qubj )}(hhh]h)}(h(Base address of the managed video memoryh]h(Base address of the managed video memory}(hj(QhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$QhKhj%Qubah}(h]h ]h"]h$]h&]uh1j hj Qubeh}(h]h ]h"]h$]h&]uh1jhj$QhKhjQubj)}(h8``vram_size`` Size of the managed video memory in bytes h](j)}(h ``vram_size``h]j)}(hjHQh]h vram_size}(hjJQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFQubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjBQubj )}(hhh]h)}(h)Size of the managed video memory in bytesh]h)Size of the managed video memory in bytes}(hjaQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]QhKhj^Qubah}(h]h ]h"]h$]h&]uh1j hjBQubeh}(h]h ]h"]h$]h&]uh1jhj]QhKhjQubj)}(h``bdev`` The TTM BO device.h](j)}(h``bdev``h]j)}(hjQh]hbdev}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhj{Qubj )}(hhh]h)}(hThe TTM BO device.h]hThe TTM BO device.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjQubah}(h]h ]h"]h$]h&]uh1j hj{Qubeh}(h]h ]h"]h$]h&]uh1jhjQhKhjQubeh}(h]h ]h"]h$]h&]uh1jhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubh)}(h**Description**h]j)}(hjQh]h Description}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjFhhubh)}(hXThe fields :c:type:`struct drm_vram_mm `.vram_base and :c:type:`struct drm_vram_mm `.vrm_size are managed by VRAM MM, but are available for public read access. Use the field :c:type:`struct drm_vram_mm `.bdev to access the TTM BO device.h](h The fields }(hjQhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hjQh]hstruct drm_vram_mm}(hjQhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjQubh.vram_base and }(hjQhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hjRh]hstruct drm_vram_mm}(hj RhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hhjRhKhjQubhZ.vrm_size are managed by VRAM MM, but are available for public read access. Use the field }(hjQhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hj+Rh]hstruct drm_vram_mm}(hj-RhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj)Rubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hhjRhKhjQubh".bdev to access the TTM BO device.}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjRhKhjFhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_vram_mm_of_bdev (C function)c.drm_vram_mm_of_bdevhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hBstruct drm_vram_mm * drm_vram_mm_of_bdev (struct ttm_device *bdev)h]j>)}(h@struct drm_vram_mm *drm_vram_mm_of_bdev(struct ttm_device *bdev)h](jD)}(hjh]hstruct}(hjkRhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjgRhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKubjV)}(h h]h }(hjyRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgRhhhjxRhKubh)}(hhh]jm)}(h drm_vram_mmh]h drm_vram_mm}(hjRhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjRmodnameN classnameNjj)}j]j )}jdrm_vram_mm_of_bdevsbc.drm_vram_mm_of_bdevasbuh1hhjgRhhhjxRhKubjV)}(h h]h }(hjRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgRhhhjxRhKubj4)}(hj7h]h*}(hjRhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjgRhhhjxRhKubjg)}(hdrm_vram_mm_of_bdevh]jm)}(hjRh]hdrm_vram_mm_of_bdev}(hjRhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjgRhhhjxRhKubj)}(h(struct ttm_device *bdev)h]j)}(hstruct ttm_device *bdevh](jD)}(hjh]hstruct}(hjRhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjRubjV)}(h h]h }(hjRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubh)}(hhh]jm)}(h ttm_deviceh]h ttm_device}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjSmodnameN classnameNjj)}j]jRc.drm_vram_mm_of_bdevasbuh1hhjRubjV)}(h h]h }(hj!ShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubj4)}(hj7h]h*}(hj/ShhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjRubjm)}(hbdevh]hbdev}(hj` for field bdev.h](hReturns the container of type }(hjfShhhNhNubh)}(h(:c:type:`struct ttm_device `h]j)}(hjpSh]hstruct ttm_device}(hjrShhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjnSubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jRc.drm_vram_mm_of_bdevasbjM ttm_deviceuh1hhjLhKhjfSubh for field bdev.}(hjfShhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjcShhubah}(h]h ]h"]h$]h&]uh1jhj`RhhhjxRhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjSjjSjjjuh1j2hhhjFhNhNubj)}(h**Parameters** ``struct ttm_device *bdev`` the TTM BO device **Return** The containing instance of :c:type:`struct drm_vram_mm `h](h)}(h**Parameters**h]j)}(hjSh]h Parameters}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjSubj)}(hhh]j)}(h.``struct ttm_device *bdev`` the TTM BO device h](j)}(h``struct ttm_device *bdev``h]j)}(hjSh]hstruct ttm_device *bdev}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjSubj )}(hhh]h)}(hthe TTM BO deviceh]hthe TTM BO device}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShKhjSubah}(h]h ]h"]h$]h&]uh1j hjSubeh}(h]h ]h"]h$]h&]uh1jhjShKhjSubah}(h]h ]h"]h$]h&]uh1jhjSubh)}(h **Return**h]j)}(hj Th]hReturn}(hj ThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhjSubh)}(hEThe containing instance of :c:type:`struct drm_vram_mm `h](hThe containing instance of }(hj ThhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hj*Th]hstruct drm_vram_mm}(hj,ThhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj(Tubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:405: ./include/drm/drm_gem_vram_helper.hhKhj Tubeh}(h]h ]h"]h$]h&]uh1hhjGThKhjSubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_vram_create (C function)c.drm_gem_vram_createhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hnstruct drm_gem_vram_object * drm_gem_vram_create (struct drm_device *dev, size_t size, unsigned long pg_align)h]j>)}(hlstruct drm_gem_vram_object *drm_gem_vram_create(struct drm_device *dev, size_t size, unsigned long pg_align)h](jD)}(hjh]hstruct}(hjnThhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjjThhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKubjV)}(h h]h }(hj|ThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjThhhj{ThKubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjTmodnameN classnameNjj)}j]j )}jdrm_gem_vram_createsbc.drm_gem_vram_createasbuh1hhjjThhhj{ThKubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjThhhj{ThKubj4)}(hj7h]h*}(hjThhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjjThhhj{ThKubjg)}(hdrm_gem_vram_createh]jm)}(hjTh]hdrm_gem_vram_create}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjjThhhj{ThKubj)}(h=(struct drm_device *dev, size_t size, unsigned long pg_align)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjThhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjTubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjUmodnameN classnameNjj)}j]jTc.drm_gem_vram_createasbuh1hhjTubjV)}(h h]h }(hj$UhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubj4)}(hj7h]h*}(hj2UhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjTubjm)}(hdevh]hdev}(hj?UhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjTubj)}(h size_t sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hj[UhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXUubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]UmodnameN classnameNjj)}j]jTc.drm_gem_vram_createasbuh1hhjTUubjV)}(h h]h }(hjyUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTUubjm)}(hsizeh]hsize}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjTubj)}(hunsigned long pg_alignh](j)}(hunsignedh]hunsigned}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUubj)}(hlongh]hlong}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUubjm)}(hpg_alignh]hpg_align}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjTubeh}(h]h ]h"]h$]h&]jjuh1jhjjThhhj{ThKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjfThhhj{ThKubah}(h]jaTah ](jjeh"]h$]h&]jj)jhuh1j7hj{ThKhjcThhubj)}(hhh]h)}(h Creates a VRAM-backed GEM objecth]h Creates a VRAM-backed GEM object}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjUhhubah}(h]h ]h"]h$]h&]uh1jhjcThhhj{ThKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjVjjVjjjuh1j2hhhjFhNhNubj)}(hX**Parameters** ``struct drm_device *dev`` the DRM device ``size_t size`` the buffer size in bytes ``unsigned long pg_align`` the buffer's alignment in multiples of the page size **Description** GEM objects are allocated by calling struct drm_driver.gem_create_object, if set. Otherwise kzalloc() will be used. Drivers can set their own GEM object functions in struct drm_driver.gem_create_object. If no functions are set, the new GEM object will use the default functions from GEM VRAM helpers. **Return** A new instance of :c:type:`struct drm_gem_vram_object ` on success, or an ERR_PTR()-encoded error code otherwise.h](h)}(h**Parameters**h]j)}(hj$Vh]h Parameters}(hj&VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"Vubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjVubj)}(hhh](j)}(h*``struct drm_device *dev`` the DRM device h](j)}(h``struct drm_device *dev``h]j)}(hjCVh]hstruct drm_device *dev}(hjEVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAVubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhj=Vubj )}(hhh]h)}(hthe DRM deviceh]hthe DRM device}(hj\VhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjXVhKhjYVubah}(h]h ]h"]h$]h&]uh1j hj=Vubeh}(h]h ]h"]h$]h&]uh1jhjXVhKhj:Vubj)}(h)``size_t size`` the buffer size in bytes h](j)}(h``size_t size``h]j)}(hj|Vh]h size_t size}(hj~VhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzVubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjvVubj )}(hhh]h)}(hthe buffer size in bytesh]hthe buffer size in bytes}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhKhjVubah}(h]h ]h"]h$]h&]uh1j hjvVubeh}(h]h ]h"]h$]h&]uh1jhjVhKhj:Vubj)}(hP``unsigned long pg_align`` the buffer's alignment in multiples of the page size h](j)}(h``unsigned long pg_align``h]j)}(hjVh]hunsigned long pg_align}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjVubj )}(hhh]h)}(h4the buffer's alignment in multiples of the page sizeh]h6the buffer’s alignment in multiples of the page size}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhKhjVubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhKhj:Vubeh}(h]h ]h"]h$]h&]uh1jhjVubh)}(h**Description**h]j)}(hjVh]h Description}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjVubh)}(hX,GEM objects are allocated by calling struct drm_driver.gem_create_object, if set. Otherwise kzalloc() will be used. Drivers can set their own GEM object functions in struct drm_driver.gem_create_object. If no functions are set, the new GEM object will use the default functions from GEM VRAM helpers.h]hX,GEM objects are allocated by calling struct drm_driver.gem_create_object, if set. Otherwise kzalloc() will be used. Drivers can set their own GEM object functions in struct drm_driver.gem_create_object. If no functions are set, the new GEM object will use the default functions from GEM VRAM helpers.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjVubh)}(h **Return**h]j)}(hjWh]hReturn}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhjVubh)}(hA new instance of :c:type:`struct drm_gem_vram_object ` on success, or an ERR_PTR()-encoded error code otherwise.h](hA new instance of }(hj-WhhhNhNubh)}(h::c:type:`struct drm_gem_vram_object `h]j)}(hj7Wh]hstruct drm_gem_vram_object}(hj9WhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj5Wubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_vram_objectuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhj-Wubh: on success, or an ERR_PTR()-encoded error code otherwise.}(hj-WhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjTWhKhjVubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_vram_put (C function)c.drm_gem_vram_puthNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(h7void drm_gem_vram_put (struct drm_gem_vram_object *gbo)h]j>)}(h6void drm_gem_vram_put(struct drm_gem_vram_object *gbo)h](j)}(hvoidh]hvoid}(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{Whhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{WhhhjWhKubjg)}(hdrm_gem_vram_puth]jm)}(hdrm_gem_vram_puth]hdrm_gem_vram_put}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj{WhhhjWhKubj)}(h!(struct drm_gem_vram_object *gbo)h]j)}(hstruct drm_gem_vram_object *gboh](jD)}(hjh]hstruct}(hjWhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjWubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]j )}jjWsbc.drm_gem_vram_putasbuh1hhjWubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubj4)}(hj7h]h*}(hjXhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjWubjm)}(hgboh]hgbo}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjWubah}(h]h ]h"]h$]h&]jjuh1jhj{WhhhjWhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjwWhhhjWhKubah}(h]jrWah ](jjeh"]h$]h&]jj)jhuh1j7hjWhKhjtWhhubj)}(hhh]h)}(h0Releases a reference to a VRAM-backed GEM objecth]h0Releases a reference to a VRAM-backed GEM object}(hj?XhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chKhj)}(h8s64 drm_gem_vram_offset(struct drm_gem_vram_object *gbo)h](h)}(hhh]jm)}(hs64h]hs64}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjYmodnameN classnameNjj)}j]j )}jdrm_gem_vram_offsetsbc.drm_gem_vram_offsetasbuh1hhjXhhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMubjV)}(h h]h }(hj%YhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXhhhj$YhMubjg)}(hdrm_gem_vram_offseth]jm)}(hj!Yh]hdrm_gem_vram_offset}(hj7YhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj3Yubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjXhhhj$YhMubj)}(h!(struct drm_gem_vram_object *gbo)h]j)}(hstruct drm_gem_vram_object *gboh](jD)}(hjh]hstruct}(hjRYhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjNYubjV)}(h h]h }(hj_YhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNYubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hjpYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjrYmodnameN classnameNjj)}j]jYc.drm_gem_vram_offsetasbuh1hhjNYubjV)}(h h]h }(hjYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNYubj4)}(hj7h]h*}(hjYhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjNYubjm)}(hgboh]hgbo}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJYubah}(h]h ]h"]h$]h&]jjuh1jhjXhhhj$YhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjXhhhj$YhMubah}(h]jXah ](jjeh"]h$]h&]jj)jhuh1j7hj$YhMhjXhhubj)}(hhh]h)}(h2Returns a GEM VRAM object's offset in video memoryh]h4Returns a GEM VRAM object’s offset in video memory}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjYhhubah}(h]h ]h"]h$]h&]uh1jhjXhhhj$YhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjYjjYjjjuh1j2hhhjFhNhNubj)}(hXI**Parameters** ``struct drm_gem_vram_object *gbo`` the GEM VRAM object **Description** This function returns the buffer object's offset in the device's video memory. The buffer object has to be pinned to ``TTM_PL_VRAM``. **Return** The buffer object's offset in video memory on success, or a negative errno code otherwise.h](h)}(h**Parameters**h]j)}(hjYh]h Parameters}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjYubj)}(hhh]j)}(h8``struct drm_gem_vram_object *gbo`` the GEM VRAM object h](j)}(h#``struct drm_gem_vram_object *gbo``h]j)}(hjZh]hstruct drm_gem_vram_object *gbo}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjZubj )}(hhh]h)}(hthe GEM VRAM objecth]hthe GEM VRAM object}(hj-ZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)ZhMhj*Zubah}(h]h ]h"]h$]h&]uh1j hjZubeh}(h]h ]h"]h$]h&]uh1jhj)ZhMhj Zubah}(h]h ]h"]h$]h&]uh1jhjYubh)}(h**Description**h]j)}(hjOZh]h Description}(hjQZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMZubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjYubh)}(hThis function returns the buffer object's offset in the device's video memory. The buffer object has to be pinned to ``TTM_PL_VRAM``.h](hyThis function returns the buffer object’s offset in the device’s video memory. The buffer object has to be pinned to }(hjeZhhhNhNubj)}(h``TTM_PL_VRAM``h]h TTM_PL_VRAM}(hjmZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeZubh.}(hjeZhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjYubh)}(h **Return**h]j)}(hjZh]hReturn}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjYubh)}(hZThe buffer object's offset in video memory on success, or a negative errno code otherwise.h]h\The buffer object’s offset in video memory on success, or a negative errno code otherwise.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_vram_vmap (C function)c.drm_gem_vram_vmaphNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hNint drm_gem_vram_vmap (struct drm_gem_vram_object *gbo, struct iosys_map *map)h]j>)}(hMint drm_gem_vram_vmap(struct drm_gem_vram_object *gbo, struct iosys_map *map)h](j)}(hinth]hint}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZhhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMNubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZhhhjZhMNubjg)}(hdrm_gem_vram_vmaph]jm)}(hdrm_gem_vram_vmaph]hdrm_gem_vram_vmap}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjZhhhjZhMNubj)}(h8(struct drm_gem_vram_object *gbo, struct iosys_map *map)h](j)}(hstruct drm_gem_vram_object *gboh](jD)}(hjh]hstruct}(hj [hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj[ubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hj([hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%[ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*[modnameN classnameNjj)}j]j )}jjZsbc.drm_gem_vram_vmapasbuh1hhj[ubjV)}(h h]h }(hjH[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubj4)}(hj7h]h*}(hjV[hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj[ubjm)}(hgboh]hgbo}(hjc[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj[ubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hj|[hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjx[ubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjx[ubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj[modnameN classnameNjj)}j]jD[c.drm_gem_vram_vmapasbuh1hhjx[ubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjx[ubj4)}(hj7h]h*}(hj[hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjx[ubjm)}(hmaph]hmap}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjx[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj[ubeh}(h]h ]h"]h$]h&]jjuh1jhjZhhhjZhMNubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjZhhhjZhMNubah}(h]jZah ](jjeh"]h$]h&]jj)jhuh1j7hjZhMNhjZhhubj)}(hhh]h)}(h9Pins and maps a GEM VRAM object into kernel address spaceh]h9Pins and maps a GEM VRAM object into kernel address space}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMNhj[hhubah}(h]h ]h"]h$]h&]uh1jhjZhhhjZhMNubeh}(h]h ](jfunctioneh"]h$]h&]jjjj\jj\jjjuh1j2hhhjFhNhNubj)}(hXL**Parameters** ``struct drm_gem_vram_object *gbo`` The GEM VRAM object to map ``struct iosys_map *map`` Returns the kernel virtual address of the VRAM GEM object's backing store. **Description** The vmap function pins a GEM VRAM object to its current location, either system or video memory, and maps its buffer into kernel address space. As pinned object cannot be relocated, you should avoid pinning objects permanently. Call drm_gem_vram_vunmap() with the returned address to unmap and unpin the GEM VRAM object. **Return** 0 on success, or a negative error code otherwise.h](h)}(h**Parameters**h]j)}(hj\h]h Parameters}(hj!\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMRhj\ubj)}(hhh](j)}(h?``struct drm_gem_vram_object *gbo`` The GEM VRAM object to map h](j)}(h#``struct drm_gem_vram_object *gbo``h]j)}(hj>\h]hstruct drm_gem_vram_object *gbo}(hj@\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<\ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMPhj8\ubj )}(hhh]h)}(hThe GEM VRAM object to maph]hThe GEM VRAM object to map}(hjW\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjS\hMPhjT\ubah}(h]h ]h"]h$]h&]uh1j hj8\ubeh}(h]h ]h"]h$]h&]uh1jhjS\hMPhj5\ubj)}(he``struct iosys_map *map`` Returns the kernel virtual address of the VRAM GEM object's backing store. h](j)}(h``struct iosys_map *map``h]j)}(hjw\h]hstruct iosys_map *map}(hjy\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhju\ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMRhjq\ubj )}(hhh]h)}(hJReturns the kernel virtual address of the VRAM GEM object's backing store.h]hLReturns the kernel virtual address of the VRAM GEM object’s backing store.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMQhj\ubah}(h]h ]h"]h$]h&]uh1j hjq\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMRhj5\ubeh}(h]h ]h"]h$]h&]uh1jhj\ubh)}(h**Description**h]j)}(hj\h]h Description}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMThj\ubh)}(hX@The vmap function pins a GEM VRAM object to its current location, either system or video memory, and maps its buffer into kernel address space. As pinned object cannot be relocated, you should avoid pinning objects permanently. Call drm_gem_vram_vunmap() with the returned address to unmap and unpin the GEM VRAM object.h]hX@The vmap function pins a GEM VRAM object to its current location, either system or video memory, and maps its buffer into kernel address space. As pinned object cannot be relocated, you should avoid pinning objects permanently. Call drm_gem_vram_vunmap() with the returned address to unmap and unpin the GEM VRAM object.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMShj\ubh)}(h **Return**h]j)}(hj\h]hReturn}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMYhj\ubh)}(h10 on success, or a negative error code otherwise.h]h10 on success, or a negative error code otherwise.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMZhj\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_vram_vunmap (C function)c.drm_gem_vram_vunmaphNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hQvoid drm_gem_vram_vunmap (struct drm_gem_vram_object *gbo, struct iosys_map *map)h]j>)}(hPvoid drm_gem_vram_vunmap(struct drm_gem_vram_object *gbo, struct iosys_map *map)h](j)}(hvoidh]hvoid}(hj]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]hhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMzubjV)}(h h]h }(hj.]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]hhhj-]hMzubjg)}(hdrm_gem_vram_vunmaph]jm)}(hdrm_gem_vram_vunmaph]hdrm_gem_vram_vunmap}(hj@]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj<]ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj]hhhj-]hMzubj)}(h8(struct drm_gem_vram_object *gbo, struct iosys_map *map)h](j)}(hstruct drm_gem_vram_object *gboh](jD)}(hjh]hstruct}(hj\]hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjX]ubjV)}(h h]h }(hji]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjX]ubh)}(hhh]jm)}(hdrm_gem_vram_objecth]hdrm_gem_vram_object}(hjz]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjw]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj|]modnameN classnameNjj)}j]j )}jjB]sbc.drm_gem_vram_vunmapasbuh1hhjX]ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjX]ubj4)}(hj7h]h*}(hj]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjX]ubjm)}(hgboh]hgbo}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjX]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjT]ubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hj]hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj]ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]modnameN classnameNjj)}j]j]c.drm_gem_vram_vunmapasbuh1hhj]ubjV)}(h h]h }(hj ^hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubj4)}(hj7h]h*}(hj^hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj]ubjm)}(hmaph]hmap}(hj%^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjT]ubeh}(h]h ]h"]h$]h&]jjuh1jhj]hhhj-]hMzubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj]hhhj-]hMzubah}(h]j]ah ](jjeh"]h$]h&]jj)jhuh1j7hj-]hMzhj]hhubj)}(hhh]h)}(h#Unmaps and unpins a GEM VRAM objecth]h#Unmaps and unpins a GEM VRAM object}(hjO^hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMzhjL^hhubah}(h]h ]h"]h$]h&]uh1jhj]hhhj-]hMzubeh}(h]h ](jfunctioneh"]h$]h&]jjjjg^jjg^jjjuh1j2hhhjFhNhNubj)}(hXF**Parameters** ``struct drm_gem_vram_object *gbo`` The GEM VRAM object to unmap ``struct iosys_map *map`` Kernel virtual address where the VRAM GEM object was mapped **Description** A call to drm_gem_vram_vunmap() unmaps and unpins a GEM VRAM buffer. See the documentation for drm_gem_vram_vmap() for more information.h](h)}(h**Parameters**h]j)}(hjq^h]h Parameters}(hjs^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjo^ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chM~hjk^ubj)}(hhh](j)}(hA``struct drm_gem_vram_object *gbo`` The GEM VRAM object to unmap h](j)}(h#``struct drm_gem_vram_object *gbo``h]j)}(hj^h]hstruct drm_gem_vram_object *gbo}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chM{hj^ubj )}(hhh]h)}(hThe GEM VRAM object to unmaph]hThe GEM VRAM object to unmap}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hM{hj^ubah}(h]h ]h"]h$]h&]uh1j hj^ubeh}(h]h ]h"]h$]h&]uh1jhj^hM{hj^ubj)}(hV``struct iosys_map *map`` Kernel virtual address where the VRAM GEM object was mapped h](j)}(h``struct iosys_map *map``h]j)}(hj^h]hstruct iosys_map *map}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chM|hj^ubj )}(hhh]h)}(h;Kernel virtual address where the VRAM GEM object was mappedh]h;Kernel virtual address where the VRAM GEM object was mapped}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hM|hj^ubah}(h]h ]h"]h$]h&]uh1j hj^ubeh}(h]h ]h"]h$]h&]uh1jhj^hM|hj^ubeh}(h]h ]h"]h$]h&]uh1jhjk^ubh)}(h**Description**h]j)}(hj_h]h Description}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chM~hjk^ubh)}(hA call to drm_gem_vram_vunmap() unmaps and unpins a GEM VRAM buffer. See the documentation for drm_gem_vram_vmap() for more information.h]hA call to drm_gem_vram_vunmap() unmaps and unpins a GEM VRAM buffer. See the documentation for drm_gem_vram_vmap() for more information.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chM}hjk^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gem_vram_fill_create_dumb (C function)c.drm_gem_vram_fill_create_dumbhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hint drm_gem_vram_fill_create_dumb (struct drm_file *file, struct drm_device *dev, unsigned long pg_align, unsigned long pitch_align, struct drm_mode_create_dumb *args)h]j>)}(hint drm_gem_vram_fill_create_dumb(struct drm_file *file, struct drm_device *dev, unsigned long pg_align, unsigned long pitch_align, struct drm_mode_create_dumb *args)h](j)}(hinth]hint}(hjI_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjE_hhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMubjV)}(h h]h }(hjX_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjE_hhhjW_hMubjg)}(hdrm_gem_vram_fill_create_dumbh]jm)}(hdrm_gem_vram_fill_create_dumbh]hdrm_gem_vram_fill_create_dumb}(hjj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjf_ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjE_hhhjW_hMubj)}(h(struct drm_file *file, struct drm_device *dev, unsigned long pg_align, unsigned long pitch_align, struct drm_mode_create_dumb *args)h](j)}(hstruct drm_file *fileh](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_modnameN classnameNjj)}j]j )}jjl_sbc.drm_gem_vram_fill_create_dumbasbuh1hhj_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubj4)}(hj7h]h*}(hj_hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj_ubjm)}(hfileh]hfile}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~_ubj)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj_ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj`modnameN classnameNjj)}j]j_c.drm_gem_vram_fill_create_dumbasbuh1hhj_ubjV)}(h h]h }(hj4`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubj4)}(hj7h]h*}(hjB`hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj_ubjm)}(hdevh]hdev}(hjO`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~_ubj)}(hunsigned long pg_alignh](j)}(hunsignedh]hunsigned}(hjh`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjd`ubjV)}(h h]h }(hjv`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjd`ubj)}(hlongh]hlong}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjd`ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjd`ubjm)}(hpg_alignh]hpg_align}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjd`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~_ubj)}(hunsigned long pitch_alignh](j)}(hunsignedh]hunsigned}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`ubj)}(hlongh]hlong}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`ubjm)}(h pitch_alignh]h pitch_align}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~_ubj)}(h!struct drm_mode_create_dumb *argsh](jD)}(hjh]hstruct}(hj ahhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjaubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubh)}(hhh]jm)}(hdrm_mode_create_dumbh]hdrm_mode_create_dumb}(hj(ahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%aubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*amodnameN classnameNjj)}j]j_c.drm_gem_vram_fill_create_dumbasbuh1hhjaubjV)}(h h]h }(hjFahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubj4)}(hj7h]h*}(hjTahhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjaubjm)}(hargsh]hargs}(hjaahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~_ubeh}(h]h ]h"]h$]h&]jjuh1jhjE_hhhjW_hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjA_hhhjW_hMubah}(h]j<_ah ](jjeh"]h$]h&]jj)jhuh1j7hjW_hMhj>_hhubj)}(hhh]h)}(hLHelper for implementing :c:type:`struct drm_driver `.dumb_createh](hHelper for implementing }(hjahhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjah]hstruct drm_driver}(hjahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j_c.drm_gem_vram_fill_create_dumbasbjM drm_driveruh1hhj{ThKhjaubh .dumb_create}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjahhubah}(h]h ]h"]h$]h&]uh1jhj>_hhhjW_hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjajjajjjuh1j2hhhjFhNhNubj)}(hX**Parameters** ``struct drm_file *file`` the DRM file ``struct drm_device *dev`` the DRM device ``unsigned long pg_align`` the buffer's alignment in multiples of the page size ``unsigned long pitch_align`` the scanline's alignment in powers of 2 ``struct drm_mode_create_dumb *args`` the arguments as provided to :c:type:`struct drm_driver `.dumb_create **Description** This helper function fills :c:type:`struct drm_mode_create_dumb `, which is used by :c:type:`struct drm_driver `.dumb_create. Implementations of this interface should forwards their arguments to this helper, plus the driver-specific parameters. **Return** 0 on success, or a negative error code otherwise.h](h)}(h**Parameters**h]j)}(hjah]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjaubj)}(hhh](j)}(h'``struct drm_file *file`` the DRM file +h](j)}(h``struct drm_file *file``h]j)}(hjah]hstruct drm_file *file}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjaubj )}(hhh]h)}(h the DRM fileh]h the DRM file}(hj bhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj bhMhj bubah}(h]h ]h"]h$]h&]uh1j hjaubeh}(h]h ]h"]h$]h&]uh1jhj bhMhjaubj)}(h*``struct drm_device *dev`` the DRM device h](j)}(h``struct drm_device *dev``h]j)}(hj-bh]hstruct drm_device *dev}(hj/bhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+bubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhj'bubj )}(hhh]h)}(hthe DRM deviceh]hthe DRM device}(hjFbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBbhMhjCbubah}(h]h ]h"]h$]h&]uh1j hj'bubeh}(h]h ]h"]h$]h&]uh1jhjBbhMhjaubj)}(hP``unsigned long pg_align`` the buffer's alignment in multiples of the page size h](j)}(h``unsigned long pg_align``h]j)}(hjfbh]hunsigned long pg_align}(hjhbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdbubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhj`bubj )}(hhh]h)}(h4the buffer's alignment in multiples of the page sizeh]h6the buffer’s alignment in multiples of the page size}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{bhMhj|bubah}(h]h ]h"]h$]h&]uh1j hj`bubeh}(h]h ]h"]h$]h&]uh1jhj{bhMhjaubj)}(hF``unsigned long pitch_align`` the scanline's alignment in powers of 2 h](j)}(h``unsigned long pitch_align``h]j)}(hjbh]hunsigned long pitch_align}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjbubj )}(hhh]h)}(h'the scanline's alignment in powers of 2h]h)the scanline’s alignment in powers of 2}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMhjbubah}(h]h ]h"]h$]h&]uh1j hjbubeh}(h]h ]h"]h$]h&]uh1jhjbhMhjaubj)}(hx``struct drm_mode_create_dumb *args`` the arguments as provided to :c:type:`struct drm_driver `.dumb_create h](j)}(h%``struct drm_mode_create_dumb *args``h]j)}(hjbh]h!struct drm_mode_create_dumb *args}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjbubj )}(hhh]h)}(hQthe arguments as provided to :c:type:`struct drm_driver `.dumb_createh](hthe arguments as provided to }(hjbhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjbh]hstruct drm_driver}(hjbhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjbubh .dumb_create}(hjbhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjchMhjbubah}(h]h ]h"]h$]h&]uh1j hjbubeh}(h]h ]h"]h$]h&]uh1jhjbhMhjaubeh}(h]h ]h"]h$]h&]uh1jhjaubh)}(h**Description**h]j)}(hj7ch]h Description}(hj9chhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5cubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjaubh)}(hXThis helper function fills :c:type:`struct drm_mode_create_dumb `, which is used by :c:type:`struct drm_driver `.dumb_create. Implementations of this interface should forwards their arguments to this helper, plus the driver-specific parameters.h](hThis helper function fills }(hjMchhhNhNubh)}(h<:c:type:`struct drm_mode_create_dumb `h]j)}(hjWch]hstruct drm_mode_create_dumb}(hjYchhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjUcubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mode_create_dumbuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjMcubh, which is used by }(hjMchhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hj{ch]hstruct drm_driver}(hj}chhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjycubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhjtchMhjMcubh.dumb_create. Implementations of this interface should forwards their arguments to this helper, plus the driver-specific parameters.}(hjMchhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjtchMhjaubh)}(h **Return**h]j)}(hjch]hReturn}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjaubh)}(h10 on success, or a negative error code otherwise.h]h10 on success, or a negative error code otherwise.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjaubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.,drm_gem_vram_driver_dumb_create (C function)!c.drm_gem_vram_driver_dumb_createhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hvint drm_gem_vram_driver_dumb_create (struct drm_file *file, struct drm_device *dev, struct drm_mode_create_dumb *args)h]j>)}(huint drm_gem_vram_driver_dumb_create(struct drm_file *file, struct drm_device *dev, struct drm_mode_create_dumb *args)h](j)}(hinth]hint}(hjchhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjchhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMubjV)}(h h]h }(hjchhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjchhhjchMubjg)}(hdrm_gem_vram_driver_dumb_createh]jm)}(hdrm_gem_vram_driver_dumb_createh]hdrm_gem_vram_driver_dumb_create}(hj dhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjchhhjchMubj)}(hR(struct drm_file *file, struct drm_device *dev, struct drm_mode_create_dumb *args)h](j)}(hstruct drm_file *fileh](jD)}(hjh]hstruct}(hj&dhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj"dubjV)}(h h]h }(hj3dhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"dubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjDdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFdmodnameN classnameNjj)}j]j )}jj dsb!c.drm_gem_vram_driver_dumb_createasbuh1hhj"dubjV)}(h h]h }(hjddhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"dubj4)}(hj7h]h*}(hjrdhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj"dubjm)}(hfileh]hfile}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"dubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubj)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjdhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjdubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdmodnameN classnameNjj)}j]j`d!c.drm_gem_vram_driver_dumb_createasbuh1hhjdubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubj4)}(hj7h]h*}(hjdhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjdubjm)}(hdevh]hdev}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubj)}(h!struct drm_mode_create_dumb *argsh](jD)}(hjh]hstruct}(hjehhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjeubjV)}(h h]h }(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjeubh)}(hhh]jm)}(hdrm_mode_create_dumbh]hdrm_mode_create_dumb}(hj&ehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj#eubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj(emodnameN classnameNjj)}j]j`d!c.drm_gem_vram_driver_dumb_createasbuh1hhjeubjV)}(h h]h }(hjDehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjeubj4)}(hj7h]h*}(hjRehhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjeubjm)}(hargsh]hargs}(hj_ehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjdubeh}(h]h ]h"]h$]h&]jjuh1jhjchhhjchMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjchMubah}(h]jcah ](jjeh"]h$]h&]jj)jhuh1j7hjchMhjchhubj)}(hhh]h)}(h?Implements :c:type:`struct drm_driver `.dumb_createh](h Implements }(hjehhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjeh]hstruct drm_driver}(hjehhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j`d!c.drm_gem_vram_driver_dumb_createasbjM drm_driveruh1hhj{ThKhjeubh .dumb_create}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjehhubah}(h]h ]h"]h$]h&]uh1jhjchhhjchMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjejjejjjuh1j2hhhjFhNhNubj)}(hX**Parameters** ``struct drm_file *file`` the DRM file ``struct drm_device *dev`` the DRM device ``struct drm_mode_create_dumb *args`` the arguments as provided to :c:type:`struct drm_driver `.dumb_create **Description** This function requires the driver to use **drm_device.vram_mm** for its instance of VRAM MM. **Return** 0 on success, or a negative error code otherwise.h](h)}(h**Parameters**h]j)}(hjeh]h Parameters}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjeubj)}(hhh](j)}(h'``struct drm_file *file`` the DRM file h](j)}(h``struct drm_file *file``h]j)}(hjeh]hstruct drm_file *file}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjeubj )}(hhh]h)}(h the DRM fileh]h the DRM file}(hj fhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjfhMhjfubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjfhMhjeubj)}(h*``struct drm_device *dev`` the DRM device h](j)}(h``struct drm_device *dev``h]j)}(hj+fh]hstruct drm_device *dev}(hj-fhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)fubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhj%fubj )}(hhh]h)}(hthe DRM deviceh]hthe DRM device}(hjDfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@fhMhjAfubah}(h]h ]h"]h$]h&]uh1j hj%fubeh}(h]h ]h"]h$]h&]uh1jhj@fhMhjeubj)}(hx``struct drm_mode_create_dumb *args`` the arguments as provided to :c:type:`struct drm_driver `.dumb_create h](j)}(h%``struct drm_mode_create_dumb *args``h]j)}(hjdfh]h!struct drm_mode_create_dumb *args}(hjffhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbfubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhj^fubj )}(hhh]h)}(hQthe arguments as provided to :c:type:`struct drm_driver `.dumb_createh](hthe arguments as provided to }(hj}fhhhNhNubh)}(h(:c:type:`struct drm_driver `h]j)}(hjfh]hstruct drm_driver}(hjfhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhj}fubh .dumb_create}(hj}fhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjfhMhjzfubah}(h]h ]h"]h$]h&]uh1j hj^fubeh}(h]h ]h"]h$]h&]uh1jhjyfhMhjeubeh}(h]h ]h"]h$]h&]uh1jhjeubh)}(h**Description**h]j)}(hjfh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjeubh)}(h\This function requires the driver to use **drm_device.vram_mm** for its instance of VRAM MM.h](h)This function requires the driver to use }(hjfhhhNhNubj)}(h**drm_device.vram_mm**h]hdrm_device.vram_mm}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubh for its instance of VRAM MM.}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjeubh)}(h **Return**h]j)}(hjfh]hReturn}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjeubh)}(h10 on success, or a negative error code otherwise.h]h10 on success, or a negative error code otherwise.}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.1drm_gem_vram_plane_helper_prepare_fb (C function)&c.drm_gem_vram_plane_helper_prepare_fbhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(heint drm_gem_vram_plane_helper_prepare_fb (struct drm_plane *plane, struct drm_plane_state *new_state)h]j>)}(hdint drm_gem_vram_plane_helper_prepare_fb(struct drm_plane *plane, struct drm_plane_state *new_state)h](j)}(hinth]hint}(hjAghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=ghhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMCubjV)}(h h]h }(hjPghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ghhhjOghMCubjg)}(h$drm_gem_vram_plane_helper_prepare_fbh]jm)}(h$drm_gem_vram_plane_helper_prepare_fbh]h$drm_gem_vram_plane_helper_prepare_fb}(hjbghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^gubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj=ghhhjOghMCubj)}(h<(struct drm_plane *plane, struct drm_plane_state *new_state)h](j)}(hstruct drm_plane *planeh](jD)}(hjh]hstruct}(hj~ghhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjzgubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzgubh)}(hhh]jm)}(h drm_planeh]h drm_plane}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjgubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]j )}jjdgsb&c.drm_gem_vram_plane_helper_prepare_fbasbuh1hhjzgubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzgubj4)}(hj7h]h*}(hjghhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjzgubjm)}(hplaneh]hplane}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvgubj)}(h!struct drm_plane_state *new_stateh](jD)}(hjh]hstruct}(hjghhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjgubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgubh)}(hhh]jm)}(hdrm_plane_stateh]hdrm_plane_state}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj hubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjhmodnameN classnameNjj)}j]jg&c.drm_gem_vram_plane_helper_prepare_fbasbuh1hhjgubjV)}(h h]h }(hj,hhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjgubj4)}(hj7h]h*}(hj:hhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjgubjm)}(h new_stateh]h new_state}(hjGhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjgubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvgubeh}(h]h ]h"]h$]h&]jjuh1jhj=ghhhjOghMCubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj9ghhhjOghMCubah}(h]j4gah ](jjeh"]h$]h&]jj)jhuh1j7hjOghMChj6ghhubj)}(hhh]h)}(hVImplements :c:type:`struct drm_plane_helper_funcs `.prepare_fbh](h Implements }(hjqhhhhNhNubh)}(h@:c:type:`struct drm_plane_helper_funcs `h]j)}(hj{hh]hstruct drm_plane_helper_funcs}(hj}hhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjyhubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jg&c.drm_gem_vram_plane_helper_prepare_fbasbjMdrm_plane_helper_funcsuh1hhj{ThKhjqhubh .prepare_fb}(hjqhhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMChjnhhhubah}(h]h ]h"]h$]h&]uh1jhj6ghhhjOghMCubeh}(h]h ](jfunctioneh"]h$]h&]jjjjhjjhjjjuh1j2hhhjFhNhNubj)}(hX**Parameters** ``struct drm_plane *plane`` a DRM plane ``struct drm_plane_state *new_state`` the plane's new state **Description** During plane updates, this function sets the plane's fence and pins the GEM VRAM objects of the plane's new framebuffer to VRAM. Call drm_gem_vram_plane_helper_cleanup_fb() to unpin them. **Return** 0 on success, or a negative errno code otherwise.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMGhjhubj)}(hhh](j)}(h(``struct drm_plane *plane`` a DRM plane h](j)}(h``struct drm_plane *plane``h]j)}(hjhh]hstruct drm_plane *plane}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMEhjhubj )}(hhh]h)}(h a DRM planeh]h a DRM plane}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMEhjhubah}(h]h ]h"]h$]h&]uh1j hjhubeh}(h]h ]h"]h$]h&]uh1jhjhhMEhjhubj)}(h<``struct drm_plane_state *new_state`` the plane's new state h](j)}(h%``struct drm_plane_state *new_state``h]j)}(hjih]h!struct drm_plane_state *new_state}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMFhj iubj )}(hhh]h)}(hthe plane's new stateh]hthe plane’s new state}(hj,ihhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(ihMFhj)iubah}(h]h ]h"]h$]h&]uh1j hj iubeh}(h]h ]h"]h$]h&]uh1jhj(ihMFhjhubeh}(h]h ]h"]h$]h&]uh1jhjhubh)}(h**Description**h]j)}(hjNih]h Description}(hjPihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLiubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMHhjhubh)}(hDuring plane updates, this function sets the plane's fence and pins the GEM VRAM objects of the plane's new framebuffer to VRAM. Call drm_gem_vram_plane_helper_cleanup_fb() to unpin them.h]hDuring plane updates, this function sets the plane’s fence and pins the GEM VRAM objects of the plane’s new framebuffer to VRAM. Call drm_gem_vram_plane_helper_cleanup_fb() to unpin them.}(hjdihhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMGhjhubh)}(h **Return**h]j)}(hjuih]hReturn}(hjwihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsiubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMKhjhubh)}(h10 on success, or a negative errno code otherwise.h]h10 on success, or a negative errno code otherwise.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMLhjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.1drm_gem_vram_plane_helper_cleanup_fb (C function)&c.drm_gem_vram_plane_helper_cleanup_fbhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hfvoid drm_gem_vram_plane_helper_cleanup_fb (struct drm_plane *plane, struct drm_plane_state *old_state)h]j>)}(hevoid drm_gem_vram_plane_helper_cleanup_fb(struct drm_plane *plane, struct drm_plane_state *old_state)h](j)}(hvoidh]hvoid}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjihhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMvubjV)}(h h]h }(hjihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjihhhjihMvubjg)}(h$drm_gem_vram_plane_helper_cleanup_fbh]jm)}(h$drm_gem_vram_plane_helper_cleanup_fbh]h$drm_gem_vram_plane_helper_cleanup_fb}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjiubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjihhhjihMvubj)}(h<(struct drm_plane *plane, struct drm_plane_state *old_state)h](j)}(hstruct drm_plane *planeh](jD)}(hjh]hstruct}(hjihhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjiubjV)}(h h]h }(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubh)}(hhh]jm)}(h drm_planeh]h drm_plane}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j )}jjisb&c.drm_gem_vram_plane_helper_cleanup_fbasbuh1hhjiubjV)}(h h]h }(hj5jhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubj4)}(hj7h]h*}(hjCjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjiubjm)}(hplaneh]hplane}(hjPjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjiubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubj)}(h!struct drm_plane_state *old_stateh](jD)}(hjh]hstruct}(hjijhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjejubjV)}(h h]h }(hjvjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjejubh)}(hhh]jm)}(hdrm_plane_stateh]hdrm_plane_state}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j1j&c.drm_gem_vram_plane_helper_cleanup_fbasbuh1hhjejubjV)}(h h]h }(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjejubj4)}(hj7h]h*}(hjjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjejubjm)}(h old_stateh]h old_state}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjejubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjiubeh}(h]h ]h"]h$]h&]jjuh1jhjihhhjihMvubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjihhhjihMvubah}(h]jiah ](jjeh"]h$]h&]jj)jhuh1j7hjihMvhjihhubj)}(hhh]h)}(hVImplements :c:type:`struct drm_plane_helper_funcs `.cleanup_fbh](h Implements }(hjjhhhNhNubh)}(h@:c:type:`struct drm_plane_helper_funcs `h]j)}(hjjh]hstruct drm_plane_helper_funcs}(hjjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j1j&c.drm_gem_vram_plane_helper_cleanup_fbasbjMdrm_plane_helper_funcsuh1hhj{ThKhjjubh .cleanup_fb}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMvhjjhhubah}(h]h ]h"]h$]h&]uh1jhjihhhjihMvubeh}(h]h ](jfunctioneh"]h$]h&]jjjj*kjj*kjjjuh1j2hhhjFhNhNubj)}(hX(**Parameters** ``struct drm_plane *plane`` a DRM plane ``struct drm_plane_state *old_state`` the plane's old state **Description** During plane updates, this function unpins the GEM VRAM objects of the plane's old framebuffer from VRAM. Complements drm_gem_vram_plane_helper_prepare_fb().h](h)}(h**Parameters**h]j)}(hj4kh]h Parameters}(hj6khhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2kubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMzhj.kubj)}(hhh](j)}(h(``struct drm_plane *plane`` a DRM plane h](j)}(h``struct drm_plane *plane``h]j)}(hjSkh]hstruct drm_plane *plane}(hjUkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQkubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMxhjMkubj )}(hhh]h)}(h a DRM planeh]h a DRM plane}(hjlkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhkhMxhjikubah}(h]h ]h"]h$]h&]uh1j hjMkubeh}(h]h ]h"]h$]h&]uh1jhjhkhMxhjJkubj)}(h<``struct drm_plane_state *old_state`` the plane's old state h](j)}(h%``struct drm_plane_state *old_state``h]j)}(hjkh]h!struct drm_plane_state *old_state}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMyhjkubj )}(hhh]h)}(hthe plane's old stateh]hthe plane’s old state}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMyhjkubah}(h]h ]h"]h$]h&]uh1j hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhMyhjJkubeh}(h]h ]h"]h$]h&]uh1jhj.kubh)}(h**Description**h]j)}(hjkh]h Description}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chM{hj.kubh)}(hDuring plane updates, this function unpins the GEM VRAM objects of the plane's old framebuffer from VRAM. Complements drm_gem_vram_plane_helper_prepare_fb().h]hDuring plane updates, this function unpins the GEM VRAM objects of the plane’s old framebuffer from VRAM. Complements drm_gem_vram_plane_helper_prepare_fb().}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMzhj.kubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_vram_mm_debugfs_init (C function)c.drm_vram_mm_debugfs_inithNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(h7void drm_vram_mm_debugfs_init (struct drm_minor *minor)h]j>)}(h6void drm_vram_mm_debugfs_init(struct drm_minor *minor)h](j)}(hvoidh]hvoid}(hj lhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjlhhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMHubjV)}(h h]h }(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjlhhhjlhMHubjg)}(hdrm_vram_mm_debugfs_inith]jm)}(hdrm_vram_mm_debugfs_inith]hdrm_vram_mm_debugfs_init}(hj-lhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)lubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjlhhhjlhMHubj)}(h(struct drm_minor *minor)h]j)}(hstruct drm_minor *minorh](jD)}(hjh]hstruct}(hjIlhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjElubjV)}(h h]h }(hjVlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjElubh)}(hhh]jm)}(h drm_minorh]h drm_minor}(hjglhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdlubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjilmodnameN classnameNjj)}j]j )}jj/lsbc.drm_vram_mm_debugfs_initasbuh1hhjElubjV)}(h h]h }(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjElubj4)}(hj7h]h*}(hjlhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjElubjm)}(hminorh]hminor}(hjlhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjElubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjAlubah}(h]h ]h"]h$]h&]jjuh1jhjlhhhjlhMHubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjlhhhjlhMHubah}(h]jkah ](jjeh"]h$]h&]jj)jhuh1j7hjlhMHhjlhhubj)}(hhh]h)}(hRegister VRAM MM debugfs file.h]hRegister VRAM MM debugfs file.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMHhjlhhubah}(h]h ]h"]h$]h&]uh1jhjlhhhjlhMHubeh}(h]h ](jfunctioneh"]h$]h&]jjjjljjljjjuh1j2hhhjFhNhNubj)}(h?**Parameters** ``struct drm_minor *minor`` drm minor device.h](h)}(h**Parameters**h]j)}(hjlh]h Parameters}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMLhjlubj)}(hhh]j)}(h-``struct drm_minor *minor`` drm minor device.h](j)}(h``struct drm_minor *minor``h]j)}(hj mh]hstruct drm_minor *minor}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj mubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMNhjmubj )}(hhh]h)}(hdrm minor device.h]hdrm minor device.}(hj&mhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMJhj#mubah}(h]h ]h"]h$]h&]uh1j hjmubeh}(h]h ]h"]h$]h&]uh1jhj"mhMNhjmubah}(h]h ]h"]h$]h&]uh1jhjlubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drmm_vram_helper_init (C function)c.drmm_vram_helper_inithNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hXint drmm_vram_helper_init (struct drm_device *dev, uint64_t vram_base, size_t vram_size)h]j>)}(hWint drmm_vram_helper_init(struct drm_device *dev, uint64_t vram_base, size_t vram_size)h](j)}(hinth]hint}(hjgmhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjcmhhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMubjV)}(h h]h }(hjvmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjcmhhhjumhMubjg)}(hdrmm_vram_helper_inith]jm)}(hdrmm_vram_helper_inith]hdrmm_vram_helper_init}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjcmhhhjumhMubj)}(h>(struct drm_device *dev, uint64_t vram_base, size_t vram_size)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjmhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjmubjV)}(h h]h }(hjmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmmodnameN classnameNjj)}j]j )}jjmsbc.drmm_vram_helper_initasbuh1hhjmubjV)}(h h]h }(hjmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmubj4)}(hj7h]h*}(hjmhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjmubjm)}(hdevh]hdev}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjmubj)}(huint64_t vram_baseh](h)}(hhh]jm)}(huint64_th]huint64_t}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjnmodnameN classnameNjj)}j]jmc.drmm_vram_helper_initasbuh1hhjnubjV)}(h h]h }(hj7nhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnubjm)}(h vram_baseh]h vram_base}(hjEnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjmubj)}(hsize_t vram_sizeh](h)}(hhh]jm)}(hsize_th]hsize_t}(hjanhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^nubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjcnmodnameN classnameNjj)}j]jmc.drmm_vram_helper_initasbuh1hhjZnubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZnubjm)}(h vram_sizeh]h vram_size}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZnubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjmubeh}(h]h ]h"]h$]h&]jjuh1jhjcmhhhjumhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj_mhhhjumhMubah}(h]jZmah ](jjeh"]h$]h&]jj)jhuh1j7hjumhMhj\mhhubj)}(hhh]h)}(hMInitializes a device's instance of :c:type:`struct drm_vram_mm `h](h%Initializes a device’s instance of }(hjnhhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hjnh]hstruct drm_vram_mm}(hjnhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jmc.drmm_vram_helper_initasbjM drm_vram_mmuh1hhj{ThKhjnubeh}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjnhhubah}(h]h ]h"]h$]h&]uh1jhj\mhhhjumhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjnjjnjjjuh1j2hhhjFhNhNubj)}(hX**Parameters** ``struct drm_device *dev`` the DRM device ``uint64_t vram_base`` the base address of the video memory ``size_t vram_size`` the size of the video memory in bytes **Description** Creates a new instance of :c:type:`struct drm_vram_mm ` and stores it in struct :c:type:`drm_device.vram_mm `. The instance is auto-managed and cleaned up as part of device cleanup. Calling this function multiple times will generate an error message. **Return** 0 on success, or a negative errno code otherwise.h](h)}(h**Parameters**h]j)}(hjnh]h Parameters}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjnubj)}(hhh](j)}(h*``struct drm_device *dev`` the DRM device h](j)}(h``struct drm_device *dev``h]j)}(hjoh]hstruct drm_device *dev}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjoubj )}(hhh]h)}(hthe DRM deviceh]hthe DRM device}(hj5ohhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1ohMhj2oubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhj1ohMhjoubj)}(h<``uint64_t vram_base`` the base address of the video memory h](j)}(h``uint64_t vram_base``h]j)}(hjUoh]huint64_t vram_base}(hjWohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSoubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjOoubj )}(hhh]h)}(h$the base address of the video memoryh]h$the base address of the video memory}(hjnohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjjohMhjkoubah}(h]h ]h"]h$]h&]uh1j hjOoubeh}(h]h ]h"]h$]h&]uh1jhjjohMhjoubj)}(h;``size_t vram_size`` the size of the video memory in bytes h](j)}(h``size_t vram_size``h]j)}(hjoh]hsize_t vram_size}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjoubj )}(hhh]h)}(h%the size of the video memory in bytesh]h%the size of the video memory in bytes}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohMhjoubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjohMhjoubeh}(h]h ]h"]h$]h&]uh1jhjnubh)}(h**Description**h]j)}(hjoh]h Description}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjnubh)}(hXCreates a new instance of :c:type:`struct drm_vram_mm ` and stores it in struct :c:type:`drm_device.vram_mm `. The instance is auto-managed and cleaned up as part of device cleanup. Calling this function multiple times will generate an error message.h](hCreates a new instance of }(hjohhhNhNubh)}(h*:c:type:`struct drm_vram_mm `h]j)}(hjoh]hstruct drm_vram_mm}(hjohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_vram_mmuh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjoubh and stores it in struct }(hjohhhNhNubh)}(h):c:type:`drm_device.vram_mm `h]j)}(hj ph]hdrm_device.vram_mm}(hjphhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj pubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhjphMhjoubh. The instance is auto-managed and cleaned up as part of device cleanup. Calling this function multiple times will generate an error message.}(hjohhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjphMhjnubh)}(h **Return**h]j)}(hj6ph]hReturn}(hj8phhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4pubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjnubh)}(h10 on success, or a negative errno code otherwise.h]h10 on success, or a negative errno code otherwise.}(hjLphhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_vram_helper_mode_valid (C function)c.drm_vram_helper_mode_validhNtauh1j!hjFhhhNhNubj3)}(hhh](j8)}(hmenum drm_mode_status drm_vram_helper_mode_valid (struct drm_device *dev, const struct drm_display_mode *mode)h]j>)}(hlenum drm_mode_status drm_vram_helper_mode_valid(struct drm_device *dev, const struct drm_display_mode *mode)h](jD)}(hjGh]henum}(hj{phhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjwphhha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwphhhjphMubh)}(hhh]jm)}(hdrm_mode_statush]hdrm_mode_status}(hjphhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjpmodnameN classnameNjj)}j]j )}jdrm_vram_helper_mode_validsbc.drm_vram_helper_mode_validasbuh1hhjwphhhjphMubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwphhhjphMubjg)}(hdrm_vram_helper_mode_validh]jm)}(hjph]hdrm_vram_helper_mode_valid}(hjphhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjwphhhjphMubj)}(h=(struct drm_device *dev, const struct drm_display_mode *mode)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjphhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjpubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjpubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]jpc.drm_vram_helper_mode_validasbuh1hhjpubjV)}(h h]h }(hj$qhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjpubj4)}(hj7h]h*}(hj2qhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjpubjm)}(hdevh]hdev}(hj?qhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjpubj)}(h#const struct drm_display_mode *modeh](jD)}(hj h]hconst}(hjXqhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjTqubjV)}(h h]h }(hjeqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTqubjD)}(hjh]hstruct}(hjsqhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjTqubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTqubh)}(hhh]jm)}(hdrm_display_modeh]hdrm_display_mode}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]jpc.drm_vram_helper_mode_validasbuh1hhjTqubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTqubj4)}(hj7h]h*}(hjqhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjTqubjm)}(hmodeh]hmode}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjpubeh}(h]h ]h"]h$]h&]jjuh1jhjwphhhjphMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjsphhhjphMubah}(h]jnpah ](jjeh"]h$]h&]jj)jhuh1j7hjphMhjpphhubj)}(hhh]h)}(hKTests if a display mode's framebuffer fits into the available video memory.h]hMTests if a display mode’s framebuffer fits into the available video memory.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjqhhubah}(h]h ]h"]h$]h&]uh1jhjpphhhjphMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj rjj rjjjuh1j2hhhjFhNhNubj)}(hX**Parameters** ``struct drm_device *dev`` the DRM device ``const struct drm_display_mode *mode`` the mode to test **Description** This function tests if enough video memory is available for using the specified display mode. Atomic modesetting requires importing the designated framebuffer into video memory before evicting the active one. Hence, any framebuffer may consume at most half of the available VRAM. Display modes that require a larger framebuffer can not be used, even if the CRTC does support them. Each framebuffer is assumed to have 32-bit color depth. **Note** The function can only test if the display mode is supported in general. If there are too many framebuffers pinned to video memory, a display mode may still not be usable in practice. The color depth of 32-bit fits all current use case. A more flexible test can be added when necessary. **Return** MODE_OK if the display mode is supported, or an error code of type enum drm_mode_status otherwise.h](h)}(h**Parameters**h]j)}(hjrh]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubj)}(hhh](j)}(h*``struct drm_device *dev`` the DRM device h](j)}(h``struct drm_device *dev``h]j)}(hj5rh]hstruct drm_device *dev}(hj7rhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3rubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhj/rubj )}(hhh]h)}(hthe DRM deviceh]hthe DRM device}(hjNrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjJrhMhjKrubah}(h]h ]h"]h$]h&]uh1j hj/rubeh}(h]h ]h"]h$]h&]uh1jhjJrhMhj,rubj)}(h9``const struct drm_display_mode *mode`` the mode to test h](j)}(h'``const struct drm_display_mode *mode``h]j)}(hjnrh]h#const struct drm_display_mode *mode}(hjprhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlrubah}(h]h ]h"]h$]h&]uh1jha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjhrubj )}(hhh]h)}(hthe mode to testh]hthe mode to test}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhMhjrubah}(h]h ]h"]h$]h&]uh1j hjhrubeh}(h]h ]h"]h$]h&]uh1jhjrhMhj,rubeh}(h]h ]h"]h$]h&]uh1jhjrubh)}(h**Description**h]j)}(hjrh]h Description}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubh)}(hXThis function tests if enough video memory is available for using the specified display mode. Atomic modesetting requires importing the designated framebuffer into video memory before evicting the active one. Hence, any framebuffer may consume at most half of the available VRAM. Display modes that require a larger framebuffer can not be used, even if the CRTC does support them. Each framebuffer is assumed to have 32-bit color depth.h]hXThis function tests if enough video memory is available for using the specified display mode. Atomic modesetting requires importing the designated framebuffer into video memory before evicting the active one. Hence, any framebuffer may consume at most half of the available VRAM. Display modes that require a larger framebuffer can not be used, even if the CRTC does support them. Each framebuffer is assumed to have 32-bit color depth.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubh)}(h**Note**h]j)}(hjrh]hNote}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubh)}(hXThe function can only test if the display mode is supported in general. If there are too many framebuffers pinned to video memory, a display mode may still not be usable in practice. The color depth of 32-bit fits all current use case. A more flexible test can be added when necessary.h]hXThe function can only test if the display mode is supported in general. If there are too many framebuffers pinned to video memory, a display mode may still not be usable in practice. The color depth of 32-bit fits all current use case. A more flexible test can be added when necessary.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubh)}(h **Return**h]j)}(hjrh]hReturn}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubh)}(hbMODE_OK if the display mode is supported, or an error code of type enum drm_mode_status otherwise.h]hbMODE_OK if the display mode is supported, or an error code of type enum drm_mode_status otherwise.}(hj shhhNhNubah}(h]h ]h"]h$]h&]uh1hha/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:408: ./drivers/gpu/drm/drm_gem_vram_helper.chMhjrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjFhhhNhNubeh}(h]#gem-vram-helper-functions-referenceah ]h"]#gem vram helper functions referenceah$]h&]uh1hhjzhhhhhMubh)}(hhh](h)}(h"GEM TTM Helper Functions Referenceh]h"GEM TTM Helper Functions Reference}(hj.shhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+shhhhhMubh)}(hEThis library provides helper functions for gem objects backed by ttm.h]hEThis library provides helper functions for gem objects backed by ttm.}(hj)}(hivoid drm_gem_ttm_print_info(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *gem)h](j)}(hvoidh]hvoid}(hjdshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`shhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKubjV)}(h h]h }(hjsshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`shhhjrshKubjg)}(hdrm_gem_ttm_print_infoh]jm)}(hdrm_gem_ttm_print_infoh]hdrm_gem_ttm_print_info}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj`shhhjrshKubj)}(hN(struct drm_printer *p, unsigned int indent, const struct drm_gem_object *gem)h](j)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hjshhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjsubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjsmodnameN classnameNjj)}j]j )}jjssbc.drm_gem_ttm_print_infoasbuh1hhjsubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubj4)}(hj7h]h*}(hjshhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjsubjm)}(hj@h]hp}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(hunsigned int indenth](j)}(hunsignedh]hunsigned}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubjV)}(h h]h }(hj thhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubj)}(hinth]hint}(hj.thhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjtubjV)}(h h]h }(hj` callback.h](h)}(h**Parameters**h]j)}(hjIuh]h Parameters}(hjKuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGuubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjCuubj)}(hhh](j)}(h&``struct drm_printer *p`` DRM printer h](j)}(h``struct drm_printer *p``h]j)}(hjhuh]hstruct drm_printer *p}(hjjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjbuubj )}(hhh]h)}(h DRM printerh]h DRM printer}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj}uhKhj~uubah}(h]h ]h"]h$]h&]uh1j hjbuubeh}(h]h ]h"]h$]h&]uh1jhj}uhKhj_uubj)}(h.``unsigned int indent`` Tab indentation level h](j)}(h``unsigned int indent``h]j)}(hjuh]hunsigned int indent}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjuubj )}(hhh]h)}(hTab indentation levelh]hTab indentation level}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhKhjuubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjuhKhj_uubj)}(h0``const struct drm_gem_object *gem`` GEM object h](j)}(h$``const struct drm_gem_object *gem``h]j)}(hjuh]h const struct drm_gem_object *gem}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjuubj )}(hhh]h)}(h GEM objecth]h GEM object}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhKhjuubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjuhKhj_uubeh}(h]h ]h"]h$]h&]uh1jhjCuubh)}(h**Description**h]j)}(hjvh]h Description}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjCuubh)}(hgThis function can be used as :c:type:`drm_gem_object_funcs.print_info ` callback.h](hThis function can be used as }(hj+vhhhNhNubh)}(h@:c:type:`drm_gem_object_funcs.print_info `h]j)}(hj5vh]hdrm_gem_object_funcs.print_info}(hj7vhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj3vubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhj+vubh callback.}(hj+vhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjRvhKhjCuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+shhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_ttm_vmap (C function)c.drm_gem_ttm_vmaphNtauh1j!hj+shhhNhNubj3)}(hhh](j8)}(hHint drm_gem_ttm_vmap (struct drm_gem_object *gem, struct iosys_map *map)h]j>)}(hGint drm_gem_ttm_vmap(struct drm_gem_object *gem, struct iosys_map *map)h](j)}(hinth]hint}(hj}vhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyvhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK9ubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyvhhhjvhK9ubjg)}(hdrm_gem_ttm_vmaph]jm)}(hdrm_gem_ttm_vmaph]hdrm_gem_ttm_vmap}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjyvhhhjvhK9ubj)}(h3(struct drm_gem_object *gem, struct iosys_map *map)h](j)}(hstruct drm_gem_object *gemh](jD)}(hjh]hstruct}(hjvhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjvubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjvubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjvmodnameN classnameNjj)}j]j )}jjvsbc.drm_gem_ttm_vmapasbuh1hhjvubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjvubj4)}(hj7h]h*}(hjwhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjvubjm)}(hgemh]hgem}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hj,whhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj(wubjV)}(h h]h }(hj9whhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(wubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hjJwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjGwubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjLwmodnameN classnameNjj)}j]jvc.drm_gem_ttm_vmapasbuh1hhj(wubjV)}(h h]h }(hjhwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(wubj4)}(hj7h]h*}(hjvwhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj(wubjm)}(hmaph]hmap}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(wubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubeh}(h]h ]h"]h$]h&]jjuh1jhjyvhhhjvhK9ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjuvhhhjvhK9ubah}(h]jpvah ](jjeh"]h$]h&]jj)jhuh1j7hjvhK9hjrvhhubj)}(hhh]h)}(h vmap :c:type:`ttm_buffer_object`h](hvmap }(hjwhhhNhNubh)}(h:c:type:`ttm_buffer_object`h]j)}(hjwh]httm_buffer_object}(hjwhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jvc.drm_gem_ttm_vmapasbjMttm_buffer_objectuh1hhjrshKhjwubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK9hjwhhubah}(h]h ]h"]h$]h&]uh1jhjrvhhhjvhK9ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjwjjwjjjuh1j2hhhj+shNhNubj)}(hXU**Parameters** ``struct drm_gem_object *gem`` GEM object. ``struct iosys_map *map`` [out] returns the dma-buf mapping. **Description** Maps a GEM object with ttm_bo_vmap(). This function can be used as :c:type:`drm_gem_object_funcs.vmap ` callback. **Return** 0 on success, or a negative errno code otherwise.h](h)}(h**Parameters**h]j)}(hjwh]h Parameters}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK=hjwubj)}(hhh](j)}(h+``struct drm_gem_object *gem`` GEM object. h](j)}(h``struct drm_gem_object *gem``h]j)}(hjxh]hstruct drm_gem_object *gem}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK:hj xubj )}(hhh]h)}(h GEM object.h]h GEM object.}(hj+xhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'xhK:hj(xubah}(h]h ]h"]h$]h&]uh1j hj xubeh}(h]h ]h"]h$]h&]uh1jhj'xhK:hj xubj)}(h=``struct iosys_map *map`` [out] returns the dma-buf mapping. h](j)}(h``struct iosys_map *map``h]j)}(hjKxh]hstruct iosys_map *map}(hjMxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIxubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK;hjExubj )}(hhh]h)}(h"[out] returns the dma-buf mapping.h]h"[out] returns the dma-buf mapping.}(hjdxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`xhK;hjaxubah}(h]h ]h"]h$]h&]uh1j hjExubeh}(h]h ]h"]h$]h&]uh1jhj`xhK;hj xubeh}(h]h ]h"]h$]h&]uh1jhjwubh)}(h**Description**h]j)}(hjxh]h Description}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK=hjwubh)}(hMaps a GEM object with ttm_bo_vmap(). This function can be used as :c:type:`drm_gem_object_funcs.vmap ` callback.h](hCMaps a GEM object with ttm_bo_vmap(). This function can be used as }(hjxhhhNhNubh)}(h::c:type:`drm_gem_object_funcs.vmap `h]j)}(hjxh]hdrm_gem_object_funcs.vmap}(hjxhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK)}(hJvoid drm_gem_ttm_vunmap(struct drm_gem_object *gem, struct iosys_map *map)h](j)}(hvoidh]hvoid}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyhhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKMubjV)}(h h]h }(hj$yhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyhhhj#yhKMubjg)}(hdrm_gem_ttm_vunmaph]jm)}(hdrm_gem_ttm_vunmaph]hdrm_gem_ttm_vunmap}(hj6yhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj2yubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjyhhhj#yhKMubj)}(h3(struct drm_gem_object *gem, struct iosys_map *map)h](j)}(hstruct drm_gem_object *gemh](jD)}(hjh]hstruct}(hjRyhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjNyubjV)}(h h]h }(hj_yhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNyubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjpyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmyubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjrymodnameN classnameNjj)}j]j )}jj8ysbc.drm_gem_ttm_vunmapasbuh1hhjNyubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNyubj4)}(hj7h]h*}(hjyhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjNyubjm)}(hgemh]hgem}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJyubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hjyhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjyubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjymodnameN classnameNjj)}j]jyc.drm_gem_ttm_vunmapasbuh1hhjyubjV)}(h h]h }(hjzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubj4)}(hj7h]h*}(hjzhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjyubjm)}(hmaph]hmap}(hjzhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJyubeh}(h]h ]h"]h$]h&]jjuh1jhjyhhhj#yhKMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj yhhhj#yhKMubah}(h]jyah ](jjeh"]h$]h&]jj)jhuh1j7hj#yhKMhj yhhubj)}(hhh]h)}(h"vunmap :c:type:`ttm_buffer_object`h](hvunmap }(hjEzhhhNhNubh)}(h:c:type:`ttm_buffer_object`h]j)}(hjOzh]httm_buffer_object}(hjQzhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjMzubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jyc.drm_gem_ttm_vunmapasbjMttm_buffer_objectuh1hhjrshKhjEzubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKMhjBzhhubah}(h]h ]h"]h$]h&]uh1jhj yhhhj#yhKMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjzjjzjjjuh1j2hhhj+shNhNubj)}(hX**Parameters** ``struct drm_gem_object *gem`` GEM object. ``struct iosys_map *map`` dma-buf mapping. **Description** Unmaps a GEM object with ttm_bo_vunmap(). This function can be used as :c:type:`drm_gem_object_funcs.vmap ` callback.h](h)}(h**Parameters**h]j)}(hjzh]h Parameters}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKQhjzubj)}(hhh](j)}(h+``struct drm_gem_object *gem`` GEM object. h](j)}(h``struct drm_gem_object *gem``h]j)}(hjzh]hstruct drm_gem_object *gem}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKNhjzubj )}(hhh]h)}(h GEM object.h]h GEM object.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhKNhjzubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhKNhjzubj)}(h+``struct iosys_map *map`` dma-buf mapping. h](j)}(h``struct iosys_map *map``h]j)}(hjzh]hstruct iosys_map *map}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKOhjzubj )}(hhh]h)}(hdma-buf mapping.h]hdma-buf mapping.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjzhKOhjzubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhKOhjzubeh}(h]h ]h"]h$]h&]uh1jhjzubh)}(h**Description**h]j)}(hj{h]h Description}(hj {hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKQhjzubh)}(hUnmaps a GEM object with ttm_bo_vunmap(). This function can be used as :c:type:`drm_gem_object_funcs.vmap ` callback.h](hGUnmaps a GEM object with ttm_bo_vunmap(). This function can be used as }(hj4{hhhNhNubh)}(h::c:type:`drm_gem_object_funcs.vmap `h]j)}(hj>{h]hdrm_gem_object_funcs.vmap}(hj@{hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKPhj4{ubh callback.}(hj4{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj[{hKPhjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+shhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_ttm_mmap (C function)c.drm_gem_ttm_mmaphNtauh1j!hj+shhhNhNubj3)}(hhh](j8)}(hMint drm_gem_ttm_mmap (struct drm_gem_object *gem, struct vm_area_struct *vma)h]j>)}(hLint drm_gem_ttm_mmap(struct drm_gem_object *gem, struct vm_area_struct *vma)h](j)}(hinth]hint}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{hhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK^ubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{hhhj{hK^ubjg)}(hdrm_gem_ttm_mmaph]jm)}(hdrm_gem_ttm_mmaph]hdrm_gem_ttm_mmap}(hj{hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj{hhhj{hK^ubj)}(h8(struct drm_gem_object *gem, struct vm_area_struct *vma)h](j)}(hstruct drm_gem_object *gemh](jD)}(hjh]hstruct}(hj{hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{ubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj{hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj{modnameN classnameNjj)}j]j )}jj{sbc.drm_gem_ttm_mmapasbuh1hhj{ubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(hj7h]h*}(hj|hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(hgemh]hgem}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hj5|hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj1|ubjV)}(h h]h }(hjB|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1|ubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjS|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjP|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjU|modnameN classnameNjj)}j]j{c.drm_gem_ttm_mmapasbuh1hhj1|ubjV)}(h h]h }(hjq|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1|ubj4)}(hj7h]h*}(hj|hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj1|ubjm)}(hvmah]hvma}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1|ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubeh}(h]h ]h"]h$]h&]jjuh1jhj{hhhj{hK^ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj~{hhhj{hK^ubah}(h]jy{ah ](jjeh"]h$]h&]jj)jhuh1j7hj{hK^hj{{hhubj)}(hhh]h)}(h mmap :c:type:`ttm_buffer_object`h](hmmap }(hj|hhhNhNubh)}(h:c:type:`ttm_buffer_object`h]j)}(hj|h]httm_buffer_object}(hj|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j{c.drm_gem_ttm_mmapasbjMttm_buffer_objectuh1hhjrshKhj|ubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK^hj|hhubah}(h]h ]h"]h$]h&]uh1jhj{{hhhj{hK^ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj|jj|jjjuh1j2hhhj+shNhNubj)}(h**Parameters** ``struct drm_gem_object *gem`` GEM object. ``struct vm_area_struct *vma`` vm area. **Description** This function can be used as :c:type:`drm_gem_object_funcs.mmap ` callback.h](h)}(h**Parameters**h]j)}(hj|h]h Parameters}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKbhj|ubj)}(hhh](j)}(h+``struct drm_gem_object *gem`` GEM object. h](j)}(h``struct drm_gem_object *gem``h]j)}(hj}h]hstruct drm_gem_object *gem}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK_hj}ubj )}(hhh]h)}(h GEM object.h]h GEM object.}(hj4}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0}hK_hj1}ubah}(h]h ]h"]h$]h&]uh1j hj}ubeh}(h]h ]h"]h$]h&]uh1jhj0}hK_hj}ubj)}(h(``struct vm_area_struct *vma`` vm area. h](j)}(h``struct vm_area_struct *vma``h]j)}(hjT}h]hstruct vm_area_struct *vma}(hjV}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR}ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK`hjN}ubj )}(hhh]h)}(hvm area.h]hvm area.}(hjm}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhji}hK`hjj}ubah}(h]h ]h"]h$]h&]uh1j hjN}ubeh}(h]h ]h"]h$]h&]uh1jhji}hK`hj}ubeh}(h]h ]h"]h$]h&]uh1jhj|ubh)}(h**Description**h]j)}(hj}h]h Description}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKbhj|ubh)}(haThis function can be used as :c:type:`drm_gem_object_funcs.mmap ` callback.h](hThis function can be used as }(hj}hhhNhNubh)}(h::c:type:`drm_gem_object_funcs.mmap `h]j)}(hj}h]hdrm_gem_object_funcs.mmap}(hj}hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKahj}ubh callback.}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj}hKahj|ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+shhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gem_ttm_dumb_map_offset (C function)c.drm_gem_ttm_dumb_map_offsethNtauh1j!hj+shhhNhNubj3)}(hhh](j8)}(hrint drm_gem_ttm_dumb_map_offset (struct drm_file *file, struct drm_device *dev, uint32_t handle, uint64_t *offset)h]j>)}(hqint drm_gem_ttm_dumb_map_offset(struct drm_file *file, struct drm_device *dev, uint32_t handle, uint64_t *offset)h](j)}(hinth]hint}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj}hhh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKzubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj}hhhj~hKzubjg)}(hdrm_gem_ttm_dumb_map_offseth]jm)}(hdrm_gem_ttm_dumb_map_offseth]hdrm_gem_ttm_dumb_map_offset}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj}hhhj~hKzubj)}(hR(struct drm_file *file, struct drm_device *dev, uint32_t handle, uint64_t *offset)h](j)}(hstruct drm_file *fileh](jD)}(hjh]hstruct}(hj4~hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj0~ubjV)}(h h]h }(hjA~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0~ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjR~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjO~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjT~modnameN classnameNjj)}j]j )}jj~sbc.drm_gem_ttm_dumb_map_offsetasbuh1hhj0~ubjV)}(h h]h }(hjr~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0~ubj4)}(hj7h]h*}(hj~hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj0~ubjm)}(hfileh]hfile}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,~ubj)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj~hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj~ubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~modnameN classnameNjj)}j]jn~c.drm_gem_ttm_dumb_map_offsetasbuh1hhj~ubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubj4)}(hj7h]h*}(hj~hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj~ubjm)}(hdevh]hdev}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,~ubj)}(huint32_t handleh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jn~c.drm_gem_ttm_dumb_map_offsetasbuh1hhjubjV)}(h h]h }(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hhandleh]hhandle}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,~ubj)}(huint64_t *offseth](h)}(hhh]jm)}(huint64_th]huint64_t}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjcmodnameN classnameNjj)}j]jn~c.drm_gem_ttm_dumb_map_offsetasbuh1hhjZubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjZubjm)}(hoffseth]hoffset}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj,~ubeh}(h]h ]h"]h$]h&]jjuh1jhj}hhhj~hKzubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj}hhhj~hKzubah}(h]j}ah ](jjeh"]h$]h&]jj)jhuh1j7hj~hKzhj}hhubj)}(hhh]h)}(hCImplements struct :c:type:`drm_driver.dumb_map_offset `h](hImplements struct }(hjhhhNhNubh)}(h1:c:type:`drm_driver.dumb_map_offset `h]j)}(hjh]hdrm_driver.dumb_map_offset}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jn~c.drm_gem_ttm_dumb_map_offsetasbjM drm_driveruh1hhjrshKhjubeh}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKzhjhhubah}(h]h ]h"]h$]h&]uh1jhj}hhhj~hKzubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj+shNhNubj)}(hXD**Parameters** ``struct drm_file *file`` DRM file pointer. ``struct drm_device *dev`` DRM device. ``uint32_t handle`` GEM handle ``uint64_t *offset`` Returns the mapping's memory offset on success **Description** Provides an implementation of struct :c:type:`drm_driver.dumb_map_offset ` for TTM-based GEM drivers. TTM allocates the offset internally and drm_gem_ttm_dumb_map_offset() returns it for dumb-buffer implementations. See struct :c:type:`drm_driver.dumb_map_offset `. **Return** 0 on success, or a negative errno code otherwise.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK~hjubj)}(hhh](j)}(h,``struct drm_file *file`` DRM file pointer. h](j)}(h``struct drm_file *file``h]j)}(hj)h]hstruct drm_file *file}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK{hj#ubj )}(hhh]h)}(hDRM file pointer.h]hDRM file pointer.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hK{hj?ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hK{hj ubj)}(h'``struct drm_device *dev`` DRM device. h](j)}(h``struct drm_device *dev``h]j)}(hjbh]hstruct drm_device *dev}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK|hj\ubj )}(hhh]h)}(h DRM device.h]h DRM device.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjwhK|hjxubah}(h]h ]h"]h$]h&]uh1j hj\ubeh}(h]h ]h"]h$]h&]uh1jhjwhK|hj ubj)}(h``uint32_t handle`` GEM handle h](j)}(h``uint32_t handle``h]j)}(hjh]huint32_t handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK}hjubj )}(hhh]h)}(h GEM handleh]h GEM handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK}hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK}hj ubj)}(hD``uint64_t *offset`` Returns the mapping's memory offset on success h](j)}(h``uint64_t *offset``h]j)}(hjԀh]huint64_t *offset}(hjրhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjҀubah}(h]h ]h"]h$]h&]uh1jh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chK~hj΀ubj )}(hhh]h)}(h.Returns the mapping's memory offset on successh]h0Returns the mapping’s memory offset on success}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK~hjubah}(h]h ]h"]h$]h&]uh1j hj΀ubeh}(h]h ]h"]h$]h&]uh1jhjhK~hj ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjubh)}(hProvides an implementation of struct :c:type:`drm_driver.dumb_map_offset ` for TTM-based GEM drivers. TTM allocates the offset internally and drm_gem_ttm_dumb_map_offset() returns it for dumb-buffer implementations.h](h%Provides an implementation of struct }(hj%hhhNhNubh)}(h1:c:type:`drm_driver.dumb_map_offset `h]j)}(hj/h]hdrm_driver.dumb_map_offset}(hj1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhj%ubh for TTM-based GEM drivers. TTM allocates the offset internally and drm_gem_ttm_dumb_map_offset() returns it for dumb-buffer implementations.}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjLhKhjubh)}(h=See struct :c:type:`drm_driver.dumb_map_offset `.h](h See struct }(hjWhhhNhNubh)}(h1:c:type:`drm_driver.dumb_map_offset `h]j)}(hjah]hdrm_driver.dumb_map_offset}(hjchhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjWubh.}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~hKhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjubh)}(h10 on success, or a negative errno code otherwise.h]h10 on success, or a negative errno code otherwise.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh`/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:417: ./drivers/gpu/drm/drm_gem_ttm_helper.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj+shhhNhNubeh}(h]"gem-ttm-helper-functions-referenceah ]h"]"gem ttm helper functions referenceah$]h&]uh1hhjzhhhhhMubeh}(h]"the-graphics-execution-manager-gemah ]h"]$the graphics execution manager (gem)ah$]h&]uh1hhhhhhhhKPubh)}(hhh](h)}(hVMA Offset Managerh]hVMA Offset Manager}(hjʁhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjǁhhhhhMubh)}(hXThe vma-manager is responsible to map arbitrary driver-dependent memory regions into the linear user address-space. It provides offsets to the caller which can then be used on the address_space of the drm-device. It takes care to not overlap regions, size them appropriately and to not confuse mm-core by inconsistent fake vm_pgoff fields. Drivers shouldn't use this for object placement in VMEM. This manager should only be used to manage mappings into linear user-space VMs.h]hXThe vma-manager is responsible to map arbitrary driver-dependent memory regions into the linear user address-space. It provides offsets to the caller which can then be used on the address_space of the drm-device. It takes care to not overlap regions, size them appropriately and to not confuse mm-core by inconsistent fake vm_pgoff fields. Drivers shouldn’t use this for object placement in VMEM. This manager should only be used to manage mappings into linear user-space VMs.}(hj؁hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:423: ./drivers/gpu/drm/drm_vma_manager.chK&hjǁhhubh)}(hWe use drm_mm as backend to manage object allocations. But it is highly optimized for alloc/free calls, not lookups. Hence, we use an rb-tree to speed up offset lookups.h]hWe use drm_mm as backend to manage object allocations. But it is highly optimized for alloc/free calls, not lookups. Hence, we use an rb-tree to speed up offset lookups.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:423: ./drivers/gpu/drm/drm_vma_manager.chK.hjǁhhubh)}(hYou must not use multiple offset managers on a single address_space. Otherwise, mm-core will be unable to tear down memory mappings as the VM will no longer be linear.h]hYou must not use multiple offset managers on a single address_space. Otherwise, mm-core will be unable to tear down memory mappings as the VM will no longer be linear.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:423: ./drivers/gpu/drm/drm_vma_manager.chK2hjǁhhubh)}(hXThis offset manager works on page-based addresses. That is, every argument and return code (with the exception of drm_vma_node_offset_addr()) is given in number of pages, not number of bytes. That means, object sizes and offsets must always be page-aligned (as usual). If you want to get a valid byte-based user-space address for a given offset, please see drm_vma_node_offset_addr().h]hXThis offset manager works on page-based addresses. That is, every argument and return code (with the exception of drm_vma_node_offset_addr()) is given in number of pages, not number of bytes. That means, object sizes and offsets must always be page-aligned (as usual). If you want to get a valid byte-based user-space address for a given offset, please see drm_vma_node_offset_addr().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:423: ./drivers/gpu/drm/drm_vma_manager.chK6hjǁhhubh)}(hXAdditionally to offset management, the vma offset manager also handles access management. For every open-file context that is allowed to access a given node, you must call drm_vma_node_allow(). Otherwise, an mmap() call on this open-file with the offset of the node will fail with -EACCES. To revoke access again, use drm_vma_node_revoke(). However, the caller is responsible for destroying already existing mappings, if required.h]hXAdditionally to offset management, the vma offset manager also handles access management. For every open-file context that is allowed to access a given node, you must call drm_vma_node_allow(). Otherwise, an mmap() call on this open-file with the offset of the node will fail with -EACCES. To revoke access again, use drm_vma_node_revoke(). However, the caller is responsible for destroying already existing mappings, if required.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:423: ./drivers/gpu/drm/drm_vma_manager.chK=hjǁhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j./drm_vma_offset_exact_lookup_locked (C function)$c.drm_vma_offset_exact_lookup_lockedhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hstruct drm_vma_offset_node * drm_vma_offset_exact_lookup_locked (struct drm_vma_offset_manager *mgr, unsigned long start, unsigned long pages)h]j>)}(hstruct drm_vma_offset_node *drm_vma_offset_exact_lookup_locked(struct drm_vma_offset_manager *mgr, unsigned long start, unsigned long pages)h](jD)}(hjh]hstruct}(hj<hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj8hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKTubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8hhhjIhKTubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]modnameN classnameNjj)}j]j )}j"drm_vma_offset_exact_lookup_lockedsb$c.drm_vma_offset_exact_lookup_lockedasbuh1hhj8hhhjIhKTubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8hhhjIhKTubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj8hhhjIhKTubjg)}(h"drm_vma_offset_exact_lookup_lockedh]jm)}(hjyh]h"drm_vma_offset_exact_lookup_locked}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj8hhhjIhKTubj)}(hN(struct drm_vma_offset_manager *mgr, unsigned long start, unsigned long pages)h](j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjÂhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjԂhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjтubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjւmodnameN classnameNjj)}j]jw$c.drm_vma_offset_exact_lookup_lockedasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmgrh]hmgr}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long starth](j)}(hunsignedh]hunsigned}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubjV)}(h h]h }(hj4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubj)}(hlongh]hlong}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj"ubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubjm)}(hstarth]hstart}(hj^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long pagesh](j)}(hunsignedh]hunsigned}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubjm)}(hpagesh]hpages}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj8hhhjIhKTubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj4hhhjIhKTubah}(h]j/ah ](jjeh"]h$]h&]jj)jhuh1j7hjIhKThj1hhubj)}(hhh]h)}(hLook up node by exact addressh]hLook up node by exact address}(hjكhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKThjփhhubah}(h]h ]h"]h$]h&]uh1jhj1hhhjIhKTubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object ``unsigned long start`` Start address (page-based, not byte-based) ``unsigned long pages`` Size of object (page-based) **Description** Same as drm_vma_offset_lookup_locked() but does not allow any offset into the node. It only returns the exact object with the given start address. **Return** Node at exact start address **start**.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKXhjubj)}(hhh](j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hjh]h"struct drm_vma_offset_manager *mgr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKUhjubj )}(hhh]h)}(hManager objecth]hManager object}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hKUhj0ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj/hKUhjubj)}(hC``unsigned long start`` Start address (page-based, not byte-based) h](j)}(h``unsigned long start``h]j)}(hjSh]hunsigned long start}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKVhjMubj )}(hhh]h)}(h*Start address (page-based, not byte-based)h]h*Start address (page-based, not byte-based)}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhKVhjiubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhKVhjubj)}(h4``unsigned long pages`` Size of object (page-based) h](j)}(h``unsigned long pages``h]j)}(hjh]hunsigned long pages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKWhjubj )}(hhh]h)}(hSize of object (page-based)h]hSize of object (page-based)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKWhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKWhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjDŽh]h Description}(hjɄhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjńubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKYhjubh)}(hSame as drm_vma_offset_lookup_locked() but does not allow any offset into the node. It only returns the exact object with the given start address.h]hSame as drm_vma_offset_lookup_locked() but does not allow any offset into the node. It only returns the exact object with the given start address.}(hj݄hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKXhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhK[hjubh)}(h&Node at exact start address **start**.h](hNode at exact start address }(hjhhhNhNubj)}(h **start**h]hstart}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhK\hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_vma_offset_lock_lookup (C function)c.drm_vma_offset_lock_lookuphNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hDvoid drm_vma_offset_lock_lookup (struct drm_vma_offset_manager *mgr)h]j>)}(hCvoid drm_vma_offset_lock_lookup(struct drm_vma_offset_manager *mgr)h](j)}(hvoidh]hvoid}(hjEhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjAhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKkubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAhhhjShKkubjg)}(hdrm_vma_offset_lock_lookuph]jm)}(hdrm_vma_offset_lock_lookuph]hdrm_vma_offset_lock_lookup}(hjfhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjAhhhjShKkubj)}(h$(struct drm_vma_offset_manager *mgr)h]j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjhsbc.drm_vma_offset_lock_lookupasbuh1hhj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubj4)}(hj7h]h*}(hj΅hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj~ubjm)}(hmgrh]hmgr}(hjۅhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjzubah}(h]h ]h"]h$]h&]jjuh1jhjAhhhjShKkubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj=hhhjShKkubah}(h]j8ah ](jjeh"]h$]h&]jj)jhuh1j7hjShKkhj:hhubj)}(hhh]h)}(h$Lock lookup for extended private useh]h$Lock lookup for extended private use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKkhjhhubah}(h]h ]h"]h$]h&]uh1jhj:hhhjShKkubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hXt**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object **Description** Lock VMA manager for extended lookups. Only locked VMA function calls are allowed while holding this lock. All other contexts are blocked from VMA until the lock is released via drm_vma_offset_unlock_lookup(). Use this if you need to take a reference to the objects returned by drm_vma_offset_lookup_locked() before releasing this lock again. This lock must not be used for anything else than extended lookups. You must not call any other VMA helpers while holding this lock. **Note** You're in atomic-context while holding this lock!h](h)}(h**Parameters**h]j)}(hj'h]h Parameters}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKohj!ubj)}(hhh]j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hjFh]h"struct drm_vma_offset_manager *mgr}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKlhj@ubj )}(hhh]h)}(hManager objecth]hManager object}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hKlhj\ubah}(h]h ]h"]h$]h&]uh1j hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hKlhj=ubah}(h]h ]h"]h$]h&]uh1jhj!ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKnhj!ubh)}(hLock VMA manager for extended lookups. Only locked VMA function calls are allowed while holding this lock. All other contexts are blocked from VMA until the lock is released via drm_vma_offset_unlock_lookup().h]hLock VMA manager for extended lookups. Only locked VMA function calls are allowed while holding this lock. All other contexts are blocked from VMA until the lock is released via drm_vma_offset_unlock_lookup().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKmhj!ubh)}(hUse this if you need to take a reference to the objects returned by drm_vma_offset_lookup_locked() before releasing this lock again.h]hUse this if you need to take a reference to the objects returned by drm_vma_offset_lookup_locked() before releasing this lock again.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKqhj!ubh)}(hThis lock must not be used for anything else than extended lookups. You must not call any other VMA helpers while holding this lock.h]hThis lock must not be used for anything else than extended lookups. You must not call any other VMA helpers while holding this lock.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKthj!ubh)}(h**Note**h]j)}(hjƆh]hNote}(hjȆhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjĆubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKwhj!ubh)}(h1You're in atomic-context while holding this lock!h]h3You’re in atomic-context while holding this lock!}(hj܆hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKxhj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_vma_offset_unlock_lookup (C function)c.drm_vma_offset_unlock_lookuphNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hFvoid drm_vma_offset_unlock_lookup (struct drm_vma_offset_manager *mgr)h]j>)}(hEvoid drm_vma_offset_unlock_lookup(struct drm_vma_offset_manager *mgr)h](j)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_vma_offset_unlock_lookuph]jm)}(hdrm_vma_offset_unlock_lookuph]hdrm_vma_offset_unlock_lookup}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h$(struct drm_vma_offset_manager *mgr)h]j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjHhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjDubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjfhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjcubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjhmodnameN classnameNjj)}j]j )}jj.sbc.drm_vma_offset_unlock_lookupasbuh1hhjDubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjDubjm)}(hmgrh]hmgr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjDubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj@ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h&Unlock lookup for extended private useh]h&Unlock lookup for extended private use}(hjˇhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjȇhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(h**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object **Description** Release lookup-lock. See drm_vma_offset_lock_lookup() for more information.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj)}(hhh]j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hj h]h"struct drm_vma_offset_manager *mgr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj )}(hhh]h)}(hManager objecth]hManager object}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hKhj"ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj!hKhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjGh]h Description}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubh)}(hKRelease lookup-lock. See drm_vma_offset_lock_lookup() for more information.h]hKRelease lookup-lock. See drm_vma_offset_lock_lookup() for more information.}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vma_node_reset (C function)c.drm_vma_node_resethNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(h:void drm_vma_node_reset (struct drm_vma_offset_node *node)h]j>)}(h9void drm_vma_node_reset(struct drm_vma_offset_node *node)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_vma_node_reseth]jm)}(hdrm_vma_node_reseth]hdrm_vma_node_reset}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h"(struct drm_vma_offset_node *node)h]j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjɈhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjňubjV)}(h h]h }(hjֈhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjňubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_vma_node_resetasbuh1hhjňubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjňubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjňubjm)}(hnodeh]hnode}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjňubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(hInitialize or reset node objecth]hInitialize or reset node object}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjIhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjdjjdjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_node *node`` Node to initialize or reset **Description** Reset a node to its initial state. This must be called before using it with any VMA offset manager. This must not be called on an already allocated node, or you will leak memory.h](h)}(h**Parameters**h]j)}(hjnh]h Parameters}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhubj)}(hhh]j)}(hA``struct drm_vma_offset_node *node`` Node to initialize or reset h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj )}(hhh]h)}(hNode to initialize or reseth]hNode to initialize or reset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjhubh)}(h**Description**h]j)}(hjȉh]h Description}(hjʉhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjƉubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhubh)}(hcReset a node to its initial state. This must be called before using it with any VMA offset manager.h]hcReset a node to its initial state. This must be called before using it with any VMA offset manager.}(hjމhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhubh)}(hNThis must not be called on an already allocated node, or you will leak memory.h]hNThis must not be called on an already allocated node, or you will leak memory.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vma_node_start (C function)c.drm_vma_node_starthNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hIunsigned long drm_vma_node_start (const struct drm_vma_offset_node *node)h]j>)}(hHunsigned long drm_vma_node_start(const struct drm_vma_offset_node *node)h](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj*hKubj)}(hlongh]hlong}(hj9hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhj*hKubjV)}(h h]h }(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj*hKubjg)}(hdrm_vma_node_starth]jm)}(hdrm_vma_node_starth]hdrm_vma_node_start}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj*hKubj)}(h((const struct drm_vma_offset_node *node)h]j)}(h&const struct drm_vma_offset_node *nodeh](jD)}(hj h]hconst}(hjuhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jj[sbc.drm_vma_node_startasbuh1hhjqubjV)}(h h]h }(hjΊhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubj4)}(hj7h]h*}(hj܊hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjqubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjmubah}(h]h ]h"]h$]h&]jjuh1jhjhhhj*hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj*hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj*hKhjhhubj)}(hhh]h)}(h.Return start address for page-based addressingh]h.Return start address for page-based addressing}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj*hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj+jj+jjjuh1j2hhhjǁhNhNubj)}(hX"**Parameters** ``const struct drm_vma_offset_node *node`` Node to inspect **Description** Return the start address of the given node. This can be used as offset into the linear VM space that is provided by the VMA offset manager. Note that this can only be used for page-based addressing. If you need a proper offset for user-space mappings, you must apply "<< PAGE_SHIFT" or use the drm_vma_node_offset_addr() helper instead. **Return** Start address of **node** for page-based addressing. 0 if the node does not have an offset allocated.h](h)}(h**Parameters**h]j)}(hj5h]h Parameters}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj/ubj)}(hhh]j)}(h;``const struct drm_vma_offset_node *node`` Node to inspect h](j)}(h*``const struct drm_vma_offset_node *node``h]j)}(hjTh]h&const struct drm_vma_offset_node *node}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjNubj )}(hhh]h)}(hNode to inspecth]hNode to inspect}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihKhjjubah}(h]h ]h"]h$]h&]uh1j hjNubeh}(h]h ]h"]h$]h&]uh1jhjihKhjKubah}(h]h ]h"]h$]h&]uh1jhj/ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj/ubh)}(hXPReturn the start address of the given node. This can be used as offset into the linear VM space that is provided by the VMA offset manager. Note that this can only be used for page-based addressing. If you need a proper offset for user-space mappings, you must apply "<< PAGE_SHIFT" or use the drm_vma_node_offset_addr() helper instead.h]hXTReturn the start address of the given node. This can be used as offset into the linear VM space that is provided by the VMA offset manager. Note that this can only be used for page-based addressing. If you need a proper offset for user-space mappings, you must apply “<< PAGE_SHIFT” or use the drm_vma_node_offset_addr() helper instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj/ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj/ubh)}(heStart address of **node** for page-based addressing. 0 if the node does not have an offset allocated.h](hStart address of }(hj̋hhhNhNubj)}(h**node**h]hnode}(hjԋhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj̋ubhL for page-based addressing. 0 if the node does not have an offset allocated.}(hj̋hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj/ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vma_node_size (C function)c.drm_vma_node_sizehNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hBunsigned long drm_vma_node_size (struct drm_vma_offset_node *node)h]j>)}(hAunsigned long drm_vma_node_size(struct drm_vma_offset_node *node)h](j)}(hunsignedh]hunsigned}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhKubj)}(hlongh]hlong}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhjhKubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhKubjg)}(hdrm_vma_node_sizeh]jm)}(hdrm_vma_node_sizeh]hdrm_vma_node_size}(hjJhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhKubj)}(h"(struct drm_vma_offset_node *node)h]j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjfhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjbubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjLsbc.drm_vma_node_sizeasbuh1hhjbubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjbubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj^ubah}(h]h ]h"]h$]h&]jjuh1jhj hhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(hReturn size (page-based)h]hReturn size (page-based)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hXd**Parameters** ``struct drm_vma_offset_node *node`` Node to inspect **Description** Return the size as number of pages for the given node. This is the same size that was passed to drm_vma_offset_add(). If no offset is allocated for the node, this is 0. **Return** Size of **node** as number of pages. 0 if the node does not have an offset allocated.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj)}(hhh]j)}(h5``struct drm_vma_offset_node *node`` Node to inspect h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hj*h]h struct drm_vma_offset_node *node}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj$ubj )}(hhh]h)}(hNode to inspecth]hNode to inspect}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hKhj@ubah}(h]h ]h"]h$]h&]uh1j hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hKhj!ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjeh]h Description}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubh)}(hReturn the size as number of pages for the given node. This is the same size that was passed to drm_vma_offset_add(). If no offset is allocated for the node, this is 0.h]hReturn the size as number of pages for the given node. This is the same size that was passed to drm_vma_offset_add(). If no offset is allocated for the node, this is 0.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubh)}(hUSize of **node** as number of pages. 0 if the node does not have an offset allocated.h](hSize of }(hjhhhNhNubj)}(h**node**h]hnode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhE as number of pages. 0 if the node does not have an offset allocated.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_vma_node_offset_addr (C function)c.drm_vma_node_offset_addrhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hA__u64 drm_vma_node_offset_addr (struct drm_vma_offset_node *node)h]j>)}(h@__u64 drm_vma_node_offset_addr(struct drm_vma_offset_node *node)h](h)}(hhh]jm)}(h__u64h]h__u64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_vma_node_offset_addrsbc.drm_vma_node_offset_addrasbuh1hhjߍhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjߍhhhjhKubjg)}(hdrm_vma_node_offset_addrh]jm)}(hjh]hdrm_vma_node_offset_addr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjߍhhhjhKubj)}(h"(struct drm_vma_offset_node *node)h]j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hj5hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj1ubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjUmodnameN classnameNjj)}j]jc.drm_vma_node_offset_addrasbuh1hhj1ubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj1ubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj-ubah}(h]h ]h"]h$]h&]jjuh1jhjߍhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjۍhhhjhKubah}(h]j֍ah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhj؍hhubj)}(hhh]h)}(h,Return sanitized offset for user-space mmapsh]h,Return sanitized offset for user-space mmaps}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhj؍hhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjΎjjΎjjjuh1j2hhhjǁhNhNubj)}(hXq**Parameters** ``struct drm_vma_offset_node *node`` Linked offset node **Description** Same as drm_vma_node_start() but returns the address as a valid offset that can be used for user-space mappings during mmap(). This must not be called on unlinked nodes. **Return** Offset of **node** for byte-based addressing. 0 if the node does not have an object allocated.h](h)}(h**Parameters**h]j)}(hj؎h]h Parameters}(hjڎhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj֎ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjҎubj)}(hhh]j)}(h8``struct drm_vma_offset_node *node`` Linked offset node h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj )}(hhh]h)}(hLinked offset nodeh]hLinked offset node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hKhjubah}(h]h ]h"]h$]h&]uh1jhjҎubh)}(h**Description**h]j)}(hj2h]h Description}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjҎubh)}(hSame as drm_vma_node_start() but returns the address as a valid offset that can be used for user-space mappings during mmap(). This must not be called on unlinked nodes.h]hSame as drm_vma_node_start() but returns the address as a valid offset that can be used for user-space mappings during mmap(). This must not be called on unlinked nodes.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjҎubh)}(h **Return**h]j)}(hjYh]hReturn}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjҎubh)}(h^Offset of **node** for byte-based addressing. 0 if the node does not have an object allocated.h](h Offset of }(hjohhhNhNubj)}(h**node**h]hnode}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubhL for byte-based addressing. 0 if the node does not have an object allocated.}(hjohhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjҎubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vma_node_unmap (C function)c.drm_vma_node_unmaphNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(h^void drm_vma_node_unmap (struct drm_vma_offset_node *node, struct address_space *file_mapping)h]j>)}(h]void drm_vma_node_unmap(struct drm_vma_offset_node *node, struct address_space *file_mapping)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_vma_node_unmaph]jm)}(hdrm_vma_node_unmaph]hdrm_vma_node_unmap}(hjяhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj͏ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(hF(struct drm_vma_offset_node *node, struct address_space *file_mapping)h](j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jjӏsbc.drm_vma_node_unmapasbuh1hhjubjV)}(h h]h }(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj9hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnodeh]hnode}(hjFhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h"struct address_space *file_mappingh](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj[ubjV)}(h h]h }(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubh)}(hhh]jm)}(h address_spaceh]h address_space}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j'c.drm_vma_node_unmapasbuh1hhj[ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj[ubjm)}(h file_mappingh]h file_mapping}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(hUnmap offset nodeh]hUnmap offset node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjݐhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_node *node`` Offset node ``struct address_space *file_mapping`` Address space to unmap **node** from **Description** Unmap all userspace mappings for a given offset node. The mappings must be associated with the **file_mapping** address-space. If no offset exists nothing is done. This call is unlocked. The caller must guarantee that drm_vma_offset_remove() is not called on this node concurrently.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj)}(hhh](j)}(h1``struct drm_vma_offset_node *node`` Offset node h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hj!h]h struct drm_vma_offset_node *node}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj )}(hhh]h)}(h Offset nodeh]h Offset node}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6hKhj7ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj6hKhjubj)}(hL``struct address_space *file_mapping`` Address space to unmap **node** from h](j)}(h&``struct address_space *file_mapping``h]j)}(hjZh]h"struct address_space *file_mapping}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjTubj )}(hhh]h)}(h$Address space to unmap **node** fromh](hAddress space to unmap }(hjshhhNhNubj)}(h**node**h]hnode}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubh from}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjohKhjpubah}(h]h ]h"]h$]h&]uh1j hjTubeh}(h]h ]h"]h$]h&]uh1jhjohKhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubh)}(hUnmap all userspace mappings for a given offset node. The mappings must be associated with the **file_mapping** address-space. If no offset exists nothing is done.h](h_Unmap all userspace mappings for a given offset node. The mappings must be associated with the }(hjhhhNhNubj)}(h**file_mapping**h]h file_mapping}(hjőhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh4 address-space. If no offset exists nothing is done.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubh)}(hvThis call is unlocked. The caller must guarantee that drm_vma_offset_remove() is not called on this node concurrently.h]hvThis call is unlocked. The caller must guarantee that drm_vma_offset_remove() is not called on this node concurrently.}(hjޑhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_vma_node_verify_access (C function)c.drm_vma_node_verify_accesshNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hWint drm_vma_node_verify_access (struct drm_vma_offset_node *node, struct drm_file *tag)h]j>)}(hVint drm_vma_node_verify_access(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhKubjg)}(hdrm_vma_node_verify_accessh]jm)}(hdrm_vma_node_verify_accessh]hdrm_vma_node_verify_access}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhKubj)}(h8(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjFubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j )}jj0sbc.drm_vma_node_verify_accessasbuh1hhjFubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjFubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubj)}(hstruct drm_file *tagh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjɒhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjڒhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjגubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjܒmodnameN classnameNjj)}j]jc.drm_vma_node_verify_accessasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(htagh]htag}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h"Access verification helper for TTMh]h"Access verification helper for TTM}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhj:hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjUjjUjjjuh1j2hhhjǁhNhNubj)}(hXf**Parameters** ``struct drm_vma_offset_node *node`` Offset node ``struct drm_file *tag`` Tag of file to check **Description** This checks whether **tag** is granted access to **node**. It is the same as drm_vma_node_is_allowed() but suitable as drop-in helper for TTM verify_access() callbacks. **Return** 0 if access is granted, -EACCES otherwise.h](h)}(h**Parameters**h]j)}(hj_h]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjYubj)}(hhh](j)}(h1``struct drm_vma_offset_node *node`` Offset node h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hj~h]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjxubj )}(hhh]h)}(h Offset nodeh]h Offset node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhKhjuubj)}(h.``struct drm_file *tag`` Tag of file to check h](j)}(h``struct drm_file *tag``h]j)}(hjh]hstruct drm_file *tag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjubj )}(hhh]h)}(hTag of file to checkh]hTag of file to check}(hjГhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj̓hKhj͓ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj̓hKhjuubeh}(h]h ]h"]h$]h&]uh1jhjYubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjYubh)}(hThis checks whether **tag** is granted access to **node**. It is the same as drm_vma_node_is_allowed() but suitable as drop-in helper for TTM verify_access() callbacks.h](hThis checks whether }(hjhhhNhNubj)}(h**tag**h]htag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is granted access to }(hjhhhNhNubj)}(h**node**h]hnode}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubho. It is the same as drm_vma_node_is_allowed() but suitable as drop-in helper for TTM verify_access() callbacks.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjYubh)}(h **Return**h]j)}(hj=h]hReturn}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjYubh)}(h*0 if access is granted, -EACCES otherwise.h]h*0 if access is granted, -EACCES otherwise.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:426: ./include/drm/drm_vma_manager.hhKhjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_vma_offset_manager_init (C function)c.drm_vma_offset_manager_inithNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(htvoid drm_vma_offset_manager_init (struct drm_vma_offset_manager *mgr, unsigned long page_offset, unsigned long size)h]j>)}(hsvoid drm_vma_offset_manager_init(struct drm_vma_offset_manager *mgr, unsigned long page_offset, unsigned long size)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKHubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~hhhjhKHubjg)}(hdrm_vma_offset_manager_inith]jm)}(hdrm_vma_offset_manager_inith]hdrm_vma_offset_manager_init}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj~hhhjhKHubj)}(hS(struct drm_vma_offset_manager *mgr, unsigned long page_offset, unsigned long size)h](j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj̔hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjݔhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjڔubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjߔmodnameN classnameNjj)}j]j )}jjsbc.drm_vma_offset_manager_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmgrh]hmgr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long page_offseth](j)}(hunsignedh]hunsigned}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubj)}(hlongh]hlong}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj-ubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubjm)}(h page_offseth]h page_offset}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long sizeh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubjm)}(hsizeh]hsize}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj~hhhjhKHubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjzhhhjhKHubah}(h]juah ](jjeh"]h$]h&]jj)jhuh1j7hjhKHhjwhhubj)}(hhh]h)}(hInitialize new offset-managerh]hInitialize new offset-manager}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKHhjhhubah}(h]h ]h"]h$]h&]uh1jhjwhhhjhKHubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object ``unsigned long page_offset`` Offset of available memory area (page-based) ``unsigned long size`` Size of available address space range (page-based) **Description** Initialize a new offset-manager. The offset and area size available for the manager are given as **page_offset** and **size**. Both are interpreted as page-numbers, not bytes. Adding/removing nodes from the manager is locked internally and protected against concurrent access. However, node allocation and destruction is left for the caller. While calling into the vma-manager, a given node must always be guaranteed to be referenced.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKLhjubj)}(hhh](j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hj%h]h"struct drm_vma_offset_manager *mgr}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKIhjubj )}(hhh]h)}(hManager objecth]hManager object}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hKIhj;ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj:hKIhjubj)}(hK``unsigned long page_offset`` Offset of available memory area (page-based) h](j)}(h``unsigned long page_offset``h]j)}(hj^h]hunsigned long page_offset}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKJhjXubj )}(hhh]h)}(h,Offset of available memory area (page-based)h]h,Offset of available memory area (page-based)}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshKJhjtubah}(h]h ]h"]h$]h&]uh1j hjXubeh}(h]h ]h"]h$]h&]uh1jhjshKJhjubj)}(hJ``unsigned long size`` Size of available address space range (page-based) h](j)}(h``unsigned long size``h]j)}(hjh]hunsigned long size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKKhjubj )}(hhh]h)}(h2Size of available address space range (page-based)h]h2Size of available address space range (page-based)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKKhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjҖh]h Description}(hjԖhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjЖubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKMhjubh)}(hInitialize a new offset-manager. The offset and area size available for the manager are given as **page_offset** and **size**. Both are interpreted as page-numbers, not bytes.h](haInitialize a new offset-manager. The offset and area size available for the manager are given as }(hjhhhNhNubj)}(h**page_offset**h]h page_offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h**size**h]hsize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh2. Both are interpreted as page-numbers, not bytes.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKLhjubh)}(hXAdding/removing nodes from the manager is locked internally and protected against concurrent access. However, node allocation and destruction is left for the caller. While calling into the vma-manager, a given node must always be guaranteed to be referenced.h]hXAdding/removing nodes from the manager is locked internally and protected against concurrent access. However, node allocation and destruction is left for the caller. While calling into the vma-manager, a given node must always be guaranteed to be referenced.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKPhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.+drm_vma_offset_manager_destroy (C function) c.drm_vma_offset_manager_destroyhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hHvoid drm_vma_offset_manager_destroy (struct drm_vma_offset_manager *mgr)h]j>)}(hGvoid drm_vma_offset_manager_destroy(struct drm_vma_offset_manager *mgr)h](j)}(hvoidh]hvoid}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chK_ubjV)}(h h]h }(hjYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFhhhjXhK_ubjg)}(hdrm_vma_offset_manager_destroyh]jm)}(hdrm_vma_offset_manager_destroyh]hdrm_vma_offset_manager_destroy}(hjkhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjgubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjFhhhjXhK_ubj)}(h$(struct drm_vma_offset_manager *mgr)h]j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjmsb c.drm_vma_offset_manager_destroyasbuh1hhjubjV)}(h h]h }(hjŗhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjӗhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmgrh]hmgr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjFhhhjXhK_ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjBhhhjXhK_ubah}(h]j=ah ](jjeh"]h$]h&]jj)jhuh1j7hjXhK_hj?hhubj)}(hhh]h)}(hDestroy offset managerh]hDestroy offset manager}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chK_hjhhubah}(h]h ]h"]h$]h&]uh1jhj?hhhjXhK_ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj"jj"jjjuh1j2hhhjǁhNhNubj)}(hX}**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object **Description** Destroy an object manager which was previously created via drm_vma_offset_manager_init(). The caller must remove all allocated nodes before destroying the manager. Otherwise, drm_mm will refuse to free the requested resources. The manager must not be accessed after this function is called.h](h)}(h**Parameters**h]j)}(hj,h]h Parameters}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKchj&ubj)}(hhh]j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hjKh]h"struct drm_vma_offset_manager *mgr}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chK`hjEubj )}(hhh]h)}(hManager objecth]hManager object}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj`hK`hjaubah}(h]h ]h"]h$]h&]uh1j hjEubeh}(h]h ]h"]h$]h&]uh1jhj`hK`hjBubah}(h]h ]h"]h$]h&]uh1jhj&ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKbhj&ubh)}(hDestroy an object manager which was previously created via drm_vma_offset_manager_init(). The caller must remove all allocated nodes before destroying the manager. Otherwise, drm_mm will refuse to free the requested resources.h]hDestroy an object manager which was previously created via drm_vma_offset_manager_init(). The caller must remove all allocated nodes before destroying the manager. Otherwise, drm_mm will refuse to free the requested resources.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKahj&ubh)}(h?The manager must not be accessed after this function is called.h]h?The manager must not be accessed after this function is called.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKfhj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_vma_offset_lookup_locked (C function)c.drm_vma_offset_lookup_lockedhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hstruct drm_vma_offset_node * drm_vma_offset_lookup_locked (struct drm_vma_offset_manager *mgr, unsigned long start, unsigned long pages)h]j>)}(hstruct drm_vma_offset_node *drm_vma_offset_lookup_locked(struct drm_vma_offset_manager *mgr, unsigned long start, unsigned long pages)h](jD)}(hjh]hstruct}(hjژhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj֘hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKpubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj֘hhhjhKpubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_vma_offset_lookup_lockedsbc.drm_vma_offset_lookup_lockedasbuh1hhj֘hhhjhKpubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj֘hhhjhKpubj4)}(hj7h]h*}(hj(hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj֘hhhjhKpubjg)}(hdrm_vma_offset_lookup_lockedh]jm)}(hjh]hdrm_vma_offset_lookup_locked}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj֘hhhjhKpubj)}(hN(struct drm_vma_offset_manager *mgr, unsigned long start, unsigned long pages)h](j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjThhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjPubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjPubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjrhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]jc.drm_vma_offset_lookup_lockedasbuh1hhjPubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjPubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjPubjm)}(hmgrh]hmgr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjLubj)}(hunsigned long starth](j)}(hunsignedh]hunsigned}(hjęhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjҙhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hstarth]hstart}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjLubj)}(hunsigned long pagesh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hpagesh]hpages}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjLubeh}(h]h ]h"]h$]h&]jjuh1jhj֘hhhjhKpubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjҘhhhjhKpubah}(h]j͘ah ](jjeh"]h$]h&]jj)jhuh1j7hjhKphjϘhhubj)}(hhh]h)}(hFind node in offset spaceh]hFind node in offset space}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKphjthhubah}(h]h ]h"]h$]h&]uh1jhjϘhhhjhKpubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object ``unsigned long start`` Start address for object (page-based) ``unsigned long pages`` Size of object (page-based) **Description** Find a node given a start address and object size. This returns the _best_ match for the given node. That is, **start** may point somewhere into a valid region and the given node will be returned, as long as the node spans the whole requested area (given the size in number of pages as **pages**). Note that before lookup the vma offset manager lookup lock must be acquired with drm_vma_offset_lock_lookup(). See there for an example. This can then be used to implement weakly referenced lookups using kref_get_unless_zero(). **Example** :: drm_vma_offset_lock_lookup(mgr); node = drm_vma_offset_lookup_locked(mgr); if (node) kref_get_unless_zero(container_of(node, sth, entr)); drm_vma_offset_unlock_lookup(mgr); **Return** Returns NULL if no suitable node can be found. Otherwise, the best match is returned. It's the caller's responsibility to make sure the node doesn't get destroyed before the caller can access it.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKthjubj)}(hhh](j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hjh]h"struct drm_vma_offset_manager *mgr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKqhjubj )}(hhh]h)}(hManager objecth]hManager object}(hjњhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj͚hKqhjΚubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj͚hKqhjubj)}(h>``unsigned long start`` Start address for object (page-based) h](j)}(h``unsigned long start``h]j)}(hjh]hunsigned long start}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKrhjubj )}(hhh]h)}(h%Start address for object (page-based)h]h%Start address for object (page-based)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKrhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKrhjubj)}(h4``unsigned long pages`` Size of object (page-based) h](j)}(h``unsigned long pages``h]j)}(hj*h]hunsigned long pages}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKshj$ubj )}(hhh]h)}(hSize of object (page-based)h]hSize of object (page-based)}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hKshj@ubah}(h]h ]h"]h$]h&]uh1j hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hKshjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjeh]h Description}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKuhjubh)}(hX)Find a node given a start address and object size. This returns the _best_ match for the given node. That is, **start** may point somewhere into a valid region and the given node will be returned, as long as the node spans the whole requested area (given the size in number of pages as **pages**).h](hnFind a node given a start address and object size. This returns the _best_ match for the given node. That is, }(hj{hhhNhNubj)}(h **start**h]hstart}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubh may point somewhere into a valid region and the given node will be returned, as long as the node spans the whole requested area (given the size in number of pages as }(hj{hhhNhNubj)}(h **pages**h]hpages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubh).}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKthjubh)}(hNote that before lookup the vma offset manager lookup lock must be acquired with drm_vma_offset_lock_lookup(). See there for an example. This can then be used to implement weakly referenced lookups using kref_get_unless_zero().h]hNote that before lookup the vma offset manager lookup lock must be acquired with drm_vma_offset_lock_lookup(). See there for an example. This can then be used to implement weakly referenced lookups using kref_get_unless_zero().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKyhjubh)}(h **Example**h]j)}(hjh]hExample}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chK}hjubjT)}(hdrm_vma_offset_lock_lookup(mgr); node = drm_vma_offset_lookup_locked(mgr); if (node) kref_get_unless_zero(container_of(node, sth, entr)); drm_vma_offset_unlock_lookup(mgr);h]hdrm_vma_offset_lock_lookup(mgr); node = drm_vma_offset_lookup_locked(mgr); if (node) kref_get_unless_zero(container_of(node, sth, entr)); drm_vma_offset_unlock_lookup(mgr);}hj՛sbah}(h]h ]h"]h$]h&]jjuh1jSh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubh)}(hReturns NULL if no suitable node can be found. Otherwise, the best match is returned. It's the caller's responsibility to make sure the node doesn't get destroyed before the caller can access it.h]hReturns NULL if no suitable node can be found. Otherwise, the best match is returned. It’s the caller’s responsibility to make sure the node doesn’t get destroyed before the caller can access it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vma_offset_add (C function)c.drm_vma_offset_addhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hrint drm_vma_offset_add (struct drm_vma_offset_manager *mgr, struct drm_vma_offset_node *node, unsigned long pages)h]j>)}(hqint drm_vma_offset_add(struct drm_vma_offset_manager *mgr, struct drm_vma_offset_node *node, unsigned long pages)h](j)}(hinth]hint}(hj+hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj'hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj'hhhj9hKubjg)}(hdrm_vma_offset_addh]jm)}(hdrm_vma_offset_addh]hdrm_vma_offset_add}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj'hhhj9hKubj)}(h[(struct drm_vma_offset_manager *mgr, struct drm_vma_offset_node *node, unsigned long pages)h](j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjhhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjdubjV)}(h h]h }(hjuhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjNsbc.drm_vma_offset_addasbuh1hhjdubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjdubjm)}(hmgrh]hmgr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjڜhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj֜ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj֜ubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_vma_offset_addasbuh1hhj֜ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj֜ubj4)}(hj7h]h*}(hj$hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj֜ubjm)}(hnodeh]hnode}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj֜ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubj)}(hunsigned long pagesh](j)}(hunsignedh]hunsigned}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubj)}(hlongh]hlong}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjFubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubjm)}(hpagesh]hpages}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj`ubeh}(h]h ]h"]h$]h&]jjuh1jhj'hhhj9hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj#hhhj9hKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj9hKhj hhubj)}(hhh]h)}(hAdd offset node to managerh]hAdd offset node to manager}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj9hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjĝjjĝjjjuh1j2hhhjǁhNhNubj)}(hXZ**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object ``struct drm_vma_offset_node *node`` Node to be added ``unsigned long pages`` Allocation size visible to user-space (in number of pages) **Description** Add a node to the offset-manager. If the node was already added, this does nothing and return 0. **pages** is the size of the object given in number of pages. After this call succeeds, you can access the offset of the node until it is removed again. If this call fails, it is safe to retry the operation or call drm_vma_offset_remove(), anyway. However, no cleanup is required in that case. **pages** is not required to be the same size as the underlying memory object that you want to map. It only limits the size that user-space can map into their address space. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjΝh]h Parameters}(hjНhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj̝ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubj)}(hhh](j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hjh]h"struct drm_vma_offset_manager *mgr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubj )}(hhh]h)}(hManager objecth]hManager object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h6``struct drm_vma_offset_node *node`` Node to be added h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hj&h]h struct drm_vma_offset_node *node}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhj ubj )}(hhh]h)}(hNode to be addedh]hNode to be added}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hKhj<ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj;hKhjubj)}(hS``unsigned long pages`` Allocation size visible to user-space (in number of pages) h](j)}(h``unsigned long pages``h]j)}(hj_h]hunsigned long pages}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjYubj )}(hhh]h)}(h:Allocation size visible to user-space (in number of pages)h]h:Allocation size visible to user-space (in number of pages)}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthKhjuubah}(h]h ]h"]h$]h&]uh1j hjYubeh}(h]h ]h"]h$]h&]uh1jhjthKhjubeh}(h]h ]h"]h$]h&]uh1jhjȝubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubh)}(hAdd a node to the offset-manager. If the node was already added, this does nothing and return 0. **pages** is the size of the object given in number of pages. After this call succeeds, you can access the offset of the node until it is removed again.h](haAdd a node to the offset-manager. If the node was already added, this does nothing and return 0. }(hjhhhNhNubj)}(h **pages**h]hpages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is the size of the object given in number of pages. After this call succeeds, you can access the offset of the node until it is removed again.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubh)}(hIf this call fails, it is safe to retry the operation or call drm_vma_offset_remove(), anyway. However, no cleanup is required in that case.h]hIf this call fails, it is safe to retry the operation or call drm_vma_offset_remove(), anyway. However, no cleanup is required in that case.}(hjўhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubh)}(h**pages** is not required to be the same size as the underlying memory object that you want to map. It only limits the size that user-space can map into their address space.h](j)}(h **pages**h]hpages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is not required to be the same size as the underlying memory object that you want to map. It only limits the size that user-space can map into their address space.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjȝubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_vma_offset_remove (C function)c.drm_vma_offset_removehNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(havoid drm_vma_offset_remove (struct drm_vma_offset_manager *mgr, struct drm_vma_offset_node *node)h]j>)}(h`void drm_vma_offset_remove(struct drm_vma_offset_manager *mgr, struct drm_vma_offset_node *node)h](j)}(hvoidh]hvoid}(hjDhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj@hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@hhhjRhKubjg)}(hdrm_vma_offset_removeh]jm)}(hdrm_vma_offset_removeh]hdrm_vma_offset_remove}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj@hhhjRhKubj)}(hF(struct drm_vma_offset_manager *mgr, struct drm_vma_offset_node *node)h](j)}(h"struct drm_vma_offset_manager *mgrh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj}ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj}ubh)}(hhh]jm)}(hdrm_vma_offset_managerh]hdrm_vma_offset_manager}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjgsbc.drm_vma_offset_removeasbuh1hhj}ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj}ubj4)}(hj7h]h*}(hj͟hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj}ubjm)}(hmgrh]hmgr}(hjڟhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_vma_offset_removeasbuh1hhjubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnodeh]hnode}(hjJhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubeh}(h]h ]h"]h$]h&]jjuh1jhj@hhhjRhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj<hhhjRhKubah}(h]j7ah ](jjeh"]h$]h&]jj)jhuh1j7hjRhKhj9hhubj)}(hhh]h)}(hRemove offset node from managerh]hRemove offset node from manager}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjqhhubah}(h]h ]h"]h$]h&]uh1jhj9hhhjRhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_manager *mgr`` Manager object ``struct drm_vma_offset_node *node`` Node to be removed **Description** Remove a node from the offset manager. If the node wasn't added before, this does nothing. After this call returns, the offset and size will be 0 until a new offset is allocated via drm_vma_offset_add() again. Helper functions like drm_vma_node_start() and drm_vma_node_offset_addr() will return 0 if no offset is allocated.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubj)}(hhh](j)}(h6``struct drm_vma_offset_manager *mgr`` Manager object h](j)}(h&``struct drm_vma_offset_manager *mgr``h]j)}(hjh]h"struct drm_vma_offset_manager *mgr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubj )}(hhh]h)}(hManager objecth]hManager object}(hjΠhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjʠhKhjˠubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjʠhKhjubj)}(h8``struct drm_vma_offset_node *node`` Node to be removed h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubj )}(hhh]h)}(hNode to be removedh]hNode to be removed}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj)h]h Description}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubh)}(hXDRemove a node from the offset manager. If the node wasn't added before, this does nothing. After this call returns, the offset and size will be 0 until a new offset is allocated via drm_vma_offset_add() again. Helper functions like drm_vma_node_start() and drm_vma_node_offset_addr() will return 0 if no offset is allocated.h]hXFRemove a node from the offset manager. If the node wasn’t added before, this does nothing. After this call returns, the offset and size will be 0 until a new offset is allocated via drm_vma_offset_add() again. Helper functions like drm_vma_node_start() and drm_vma_node_offset_addr() will return 0 if no offset is allocated.}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_vma_node_allow (C function)c.drm_vma_node_allowhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hOint drm_vma_node_allow (struct drm_vma_offset_node *node, struct drm_file *tag)h]j>)}(hNint drm_vma_node_allow(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(hinth]hint}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM'ubjV)}(h h]h }(hj}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjhhhj|hM'ubjg)}(hdrm_vma_node_allowh]jm)}(hdrm_vma_node_allowh]hdrm_vma_node_allow}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjjhhhj|hM'ubj)}(h8(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjɡhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjơubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjˡmodnameN classnameNjj)}j]j )}jjsbc.drm_vma_node_allowasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_file *tagh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=modnameN classnameNjj)}j]jc.drm_vma_node_allowasbuh1hhjubjV)}(h h]h }(hjYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjghhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(htagh]htag}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjjhhhj|hM'ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjfhhhj|hM'ubah}(h]jaah ](jjeh"]h$]h&]jj)jhuh1j7hj|hM'hjchhubj)}(hhh]h)}(h&Add open-file to list of allowed usersh]h&Add open-file to list of allowed users}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM'hjhhubah}(h]h ]h"]h$]h&]uh1jhjchhhj|hM'ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_node *node`` Node to modify ``struct drm_file *tag`` Tag of file to remove **Description** Add **tag** to the list of allowed open-files for this node. If **tag** is already on this list, the ref-count is incremented. The list of allowed-users is preserved across drm_vma_offset_add() and drm_vma_offset_remove() calls. You may even call it if the node is currently not added to any offset-manager. You must remove all open-files the same number of times as you added them before destroying the node. Otherwise, you will leak memory. This is locked against concurrent access internally. **Return** 0 on success, negative error code on internal failure (out-of-mem)h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hj¢hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM+hjubj)}(hhh](j)}(h4``struct drm_vma_offset_node *node`` Node to modify h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjߢh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjݢubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM(hj٢ubj )}(hhh]h)}(hNode to modifyh]hNode to modify}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM(hjubah}(h]h ]h"]h$]h&]uh1j hj٢ubeh}(h]h ]h"]h$]h&]uh1jhjhM(hj֢ubj)}(h/``struct drm_file *tag`` Tag of file to remove h](j)}(h``struct drm_file *tag``h]j)}(hjh]hstruct drm_file *tag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM)hjubj )}(hhh]h)}(hTag of file to removeh]hTag of file to remove}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj-hM)hj.ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj-hM)hj֢ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjSh]h Description}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM+hjubh)}(h~Add **tag** to the list of allowed open-files for this node. If **tag** is already on this list, the ref-count is incremented.h](hAdd }(hjihhhNhNubj)}(h**tag**h]htag}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubh5 to the list of allowed open-files for this node. If }(hjihhhNhNubj)}(h**tag**h]htag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubh7 is already on this list, the ref-count is incremented.}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM*hjubh)}(hThe list of allowed-users is preserved across drm_vma_offset_add() and drm_vma_offset_remove() calls. You may even call it if the node is currently not added to any offset-manager.h]hThe list of allowed-users is preserved across drm_vma_offset_add() and drm_vma_offset_remove() calls. You may even call it if the node is currently not added to any offset-manager.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM-hjubh)}(hYou must remove all open-files the same number of times as you added them before destroying the node. Otherwise, you will leak memory.h]hYou must remove all open-files the same number of times as you added them before destroying the node. Otherwise, you will leak memory.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM1hjubh)}(h4This is locked against concurrent access internally.h]h4This is locked against concurrent access internally.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM4hjubh)}(h **Return**h]j)}(hjˣh]hReturn}(hjͣhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjɣubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM6hjubh)}(hB0 on success, negative error code on internal failure (out-of-mem)h]hB0 on success, negative error code on internal failure (out-of-mem)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM7hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_vma_node_allow_once (C function)c.drm_vma_node_allow_oncehNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hTint drm_vma_node_allow_once (struct drm_vma_offset_node *node, struct drm_file *tag)h]j>)}(hSint drm_vma_node_allow_once(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMAubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhMAubjg)}(hdrm_vma_node_allow_onceh]jm)}(hdrm_vma_node_allow_onceh]hdrm_vma_node_allow_once}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhMAubj)}(h8(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjMhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjIubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjIubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjkhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjhubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmmodnameN classnameNjj)}j]j )}jj3sbc.drm_vma_node_allow_onceasbuh1hhjIubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjIubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjIubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubj)}(hstruct drm_file *tagh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj̤hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjݤhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjڤubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjߤmodnameN classnameNjj)}j]jc.drm_vma_node_allow_onceasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(htagh]htag}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMAubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMAubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMAhjhhubj)}(hhh]h)}(h&Add open-file to list of allowed usersh]h&Add open-file to list of allowed users}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMAhj=hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMAubeh}(h]h ](jfunctioneh"]h$]h&]jjjjXjjXjjjuh1j2hhhjǁhNhNubj)}(hXz**Parameters** ``struct drm_vma_offset_node *node`` Node to modify ``struct drm_file *tag`` Tag of file to remove **Description** Add **tag** to the list of allowed open-files for this node. The list of allowed-users is preserved across drm_vma_offset_add() and drm_vma_offset_remove() calls. You may even call it if the node is currently not added to any offset-manager. This is not ref-counted unlike drm_vma_node_allow() hence drm_vma_node_revoke() should only be called once after this. This is locked against concurrent access internally. **Return** 0 on success, negative error code on internal failure (out-of-mem)h](h)}(h**Parameters**h]j)}(hjbh]h Parameters}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMEhj\ubj)}(hhh](j)}(h4``struct drm_vma_offset_node *node`` Node to modify h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMBhj{ubj )}(hhh]h)}(hNode to modifyh]hNode to modify}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMBhjubah}(h]h ]h"]h$]h&]uh1j hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhMBhjxubj)}(h/``struct drm_file *tag`` Tag of file to remove h](j)}(h``struct drm_file *tag``h]j)}(hjh]hstruct drm_file *tag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMChjubj )}(hhh]h)}(hTag of file to removeh]hTag of file to remove}(hjӥhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjϥhMChjХubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjϥhMChjxubeh}(h]h ]h"]h$]h&]uh1jhj\ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMEhj\ubh)}(h)}(hPvoid drm_vma_node_revoke(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMZubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMZubjg)}(hdrm_vma_node_revokeh]jm)}(hdrm_vma_node_revokeh]hdrm_vma_node_revoke}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMZubj)}(h8(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hjݦhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj٦ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj٦ubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjæsbc.drm_vma_node_revokeasbuh1hhj٦ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj٦ubj4)}(hj7h]h*}(hj)hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj٦ubjm)}(hnodeh]hnode}(hj6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj٦ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjզubj)}(hstruct drm_file *tagh](jD)}(hjh]hstruct}(hjOhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjKubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjomodnameN classnameNjj)}j]jc.drm_vma_node_revokeasbuh1hhjKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjKubjm)}(htagh]htag}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjզubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMZubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMZubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMZhjhhubj)}(hhh]h)}(h+Remove open-file from list of allowed usersh]h+Remove open-file from list of allowed users}(hjЧhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMZhjͧhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMZubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hX**Parameters** ``struct drm_vma_offset_node *node`` Node to modify ``struct drm_file *tag`` Tag of file to remove **Description** Decrement the ref-count of **tag** in the list of allowed open-files on **node**. If the ref-count drops to zero, remove **tag** from the list. You must call this once for every drm_vma_node_allow() on **tag**. This is locked against concurrent access internally. If **tag** is not on the list, nothing is done.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM^hjubj)}(hhh](j)}(h4``struct drm_vma_offset_node *node`` Node to modify h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM[hj ubj )}(hhh]h)}(hNode to modifyh]hNode to modify}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj&hM[hj'ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hM[hjubj)}(h/``struct drm_file *tag`` Tag of file to remove h](j)}(h``struct drm_file *tag``h]j)}(hjJh]hstruct drm_file *tag}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM\hjDubj )}(hhh]h)}(hTag of file to removeh]hTag of file to remove}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hM\hj`ubah}(h]h ]h"]h$]h&]uh1j hjDubeh}(h]h ]h"]h$]h&]uh1jhj_hM\hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM^hjubh)}(hDecrement the ref-count of **tag** in the list of allowed open-files on **node**. If the ref-count drops to zero, remove **tag** from the list. You must call this once for every drm_vma_node_allow() on **tag**.h](hDecrement the ref-count of }(hjhhhNhNubj)}(h**tag**h]htag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh& in the list of allowed open-files on }(hjhhhNhNubj)}(h**node**h]hnode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh). If the ref-count drops to zero, remove }(hjhhhNhNubj)}(h**tag**h]htag}(hjǨhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhJ from the list. You must call this once for every drm_vma_node_allow() on }(hjhhhNhNubj)}(h**tag**h]htag}(hj٨hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chM]hjubh)}(h4This is locked against concurrent access internally.h]h4This is locked against concurrent access internally.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMahjubh)}(h/If **tag** is not on the list, nothing is done.h](hIf }(hjhhhNhNubj)}(h**tag**h]htag}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh% is not on the list, nothing is done.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMchjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_vma_node_is_allowed (C function)c.drm_vma_node_is_allowedhNtauh1j!hjǁhhhNhNubj3)}(hhh](j8)}(hUbool drm_vma_node_is_allowed (struct drm_vma_offset_node *node, struct drm_file *tag)h]j>)}(hTbool drm_vma_node_is_allowed(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(hj*h]hbool}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhjOhMubjg)}(hdrm_vma_node_is_allowedh]jm)}(hdrm_vma_node_is_allowedh]hdrm_vma_node_is_allowed}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj>hhhjOhMubj)}(h8(struct drm_vma_offset_node *node, struct drm_file *tag)h](j)}(h struct drm_vma_offset_node *nodeh](jD)}(hjh]hstruct}(hj~hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjzubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubh)}(hhh]jm)}(hdrm_vma_offset_nodeh]hdrm_vma_offset_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjdsbc.drm_vma_node_is_allowedasbuh1hhjzubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubj4)}(hj7h]h*}(hjʩhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjzubjm)}(hnodeh]hnode}(hjשhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubj)}(hstruct drm_file *tagh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_vma_node_is_allowedasbuh1hhjubjV)}(h h]h }(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj:hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(htagh]htag}(hjGhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubeh}(h]h ]h"]h$]h&]jjuh1jhj>hhhjOhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj:hhhjOhMubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1j7hjOhMhj7hhubj)}(hhh]h)}(h,Check whether an open-file is granted accessh]h,Check whether an open-file is granted access}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjnhhubah}(h]h ]h"]h$]h&]uh1jhj7hhhjOhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjǁhNhNubj)}(hXb**Parameters** ``struct drm_vma_offset_node *node`` Node to check ``struct drm_file *tag`` Tag of file to remove **Description** Search the list in **node** whether **tag** is currently on the list of allowed open-files (see drm_vma_node_allow()). This is locked against concurrent access internally. **Return** true if **filp** is on the listh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubj)}(hhh](j)}(h3``struct drm_vma_offset_node *node`` Node to check h](j)}(h$``struct drm_vma_offset_node *node``h]j)}(hjh]h struct drm_vma_offset_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubj )}(hhh]h)}(h Node to checkh]h Node to check}(hj˪hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjǪhMhjȪubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjǪhMhjubj)}(h/``struct drm_file *tag`` Tag of file to remove h](j)}(h``struct drm_file *tag``h]j)}(hjh]hstruct drm_file *tag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubj )}(hhh]h)}(hTag of file to removeh]hTag of file to remove}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj&h]h Description}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubh)}(hvSearch the list in **node** whether **tag** is currently on the list of allowed open-files (see drm_vma_node_allow()).h](hSearch the list in }(hj<hhhNhNubj)}(h**node**h]hnode}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubh whether }(hj<hhhNhNubj)}(h**tag**h]htag}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubhK is currently on the list of allowed open-files (see drm_vma_node_allow()).}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubh)}(h4This is locked against concurrent access internally.h]h4This is locked against concurrent access internally.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubh)}(htrue if **filp** is on the listh](htrue if }(hjhhhNhNubj)}(h**filp**h]hfilp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is on the list}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hh]/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:429: ./drivers/gpu/drm/drm_vma_manager.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjǁhhhNhNubhtarget)}(h.. _prime_buffer_sharing:h]h}(h]h ]h"]h$]h&]refidprime-buffer-sharinguh1jhMhjǁhhhhubeh}(h]vma-offset-managerah ]h"]vma offset managerah$]h&]uh1hhhhhhhhMubh)}(hhh](h)}(hPRIME Buffer Sharingh]hPRIME Buffer Sharing}(hj׫hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjԫhhhhhMubh)}(hPRIME is the cross device buffer sharing framework in drm, originally created for the OPTIMUS range of multi-gpu platforms. To userspace PRIME buffers are dma-buf based file descriptors.h]hPRIME is the cross device buffer sharing framework in drm, originally created for the OPTIMUS range of multi-gpu platforms. To userspace PRIME buffers are dma-buf based file descriptors.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjԫhhubh)}(hhh](h)}(hOverview and Lifetime Rulesh]hOverview and Lifetime Rules}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMubh)}(hX-Similar to GEM global names, PRIME file descriptors are also used to share buffer objects across processes. They offer additional security: as file descriptors must be explicitly sent over UNIX domain sockets to be shared between applications, they can't be guessed like the globally unique GEM names.h]hX/Similar to GEM global names, PRIME file descriptors are also used to share buffer objects across processes. They offer additional security: as file descriptors must be explicitly sent over UNIX domain sockets to be shared between applications, they can’t be guessed like the globally unique GEM names.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:444: ./drivers/gpu/drm/drm_prime.chK/hjhhubh)}(hXDrivers that support the PRIME API implement the drm_gem_object_funcs.export and :c:type:`drm_driver.gem_prime_import ` hooks. :c:type:`dma_buf_ops` implementations for drivers are all individually exported for drivers which need to overwrite or reimplement some of them.h](hQDrivers that support the PRIME API implement the drm_gem_object_funcs.export and }(hjhhhNhNubh)}(h2:c:type:`drm_driver.gem_prime_import `h]j)}(hjh]hdrm_driver.gem_prime_import}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:444: ./drivers/gpu/drm/drm_prime.chK5hjubh hooks. }(hjhhhNhNubh)}(h:c:type:`dma_buf_ops`h]j)}(hjAh]h dma_buf_ops}(hjChhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhj:hK5hjubh{ implementations for drivers are all individually exported for drivers which need to overwrite or reimplement some of them.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj:hK5hjhhubh)}(hhh](h)}(h"Reference Counting for GEM Driversh]h"Reference Counting for GEM Drivers}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhNhNubh)}(hXOn the export the :c:type:`dma_buf` holds a reference to the exported buffer object, usually a :c:type:`drm_gem_object`. It takes this reference in the PRIME_HANDLE_TO_FD IOCTL, when it first calls :c:type:`drm_gem_object_funcs.export ` and stores the exporting GEM object in the :c:type:`dma_buf.priv ` field. This reference needs to be released when the final reference to the :c:type:`dma_buf` itself is dropped and its :c:type:`dma_buf_ops.release ` function is called. For GEM-based drivers, the :c:type:`dma_buf` should be exported using drm_gem_dmabuf_export() and then released by drm_gem_dmabuf_release().h](hOn the export the }(hjyhhhNhNubh)}(h:c:type:`dma_buf`h]j)}(hjh]hdma_buf}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_bufuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:444: ./drivers/gpu/drm/drm_prime.chK=hjyubh< holds a reference to the exported buffer object, usually a }(hjyhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhK=hjyubhO. It takes this reference in the PRIME_HANDLE_TO_FD IOCTL, when it first calls }(hjyhhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.export `h]j)}(hjʬh]hdrm_gem_object_funcs.export}(hj̬hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjȬubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhjhK=hjyubh, and stores the exporting GEM object in the }(hjyhhhNhNubh)}(h :c:type:`dma_buf.priv `h]j)}(hjh]h dma_buf.priv}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_bufuh1hhjhK=hjyubhL field. This reference needs to be released when the final reference to the }(hjyhhhNhNubh)}(h:c:type:`dma_buf`h]j)}(hjh]hdma_buf}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_bufuh1hhjhK=hjyubh itself is dropped and its }(hjyhhhNhNubh)}(h+:c:type:`dma_buf_ops.release `h]j)}(hj3h]hdma_buf_ops.release}(hj5hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhjhK=hjyubh1 function is called. For GEM-based drivers, the }(hjyhhhNhNubh)}(h:c:type:`dma_buf`h]j)}(hjVh]hdma_buf}(hjXhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_bufuh1hhjhK=hjyubh` should be exported using drm_gem_dmabuf_export() and then released by drm_gem_dmabuf_release().}(hjyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhK=hjhubh)}(hXtThus the chain of references always flows in one direction, avoiding loops: importing GEM object -> dma-buf -> exported GEM bo. A further complication are the lookup caches for import and export. These are required to guarantee that any given object will always have only one unique userspace handle. This is required to allow userspace to detect duplicated imports, since some GEM drivers do fail command submissions if a given buffer object is listed more than once. These import and export caches in :c:type:`drm_prime_file_private` only retain a weak reference, which is cleaned up when the corresponding object is released.h](hXThus the chain of references always flows in one direction, avoiding loops: importing GEM object -> dma-buf -> exported GEM bo. A further complication are the lookup caches for import and export. These are required to guarantee that any given object will always have only one unique userspace handle. This is required to allow userspace to detect duplicated imports, since some GEM drivers do fail command submissions if a given buffer object is listed more than once. These import and export caches in }(hj}hhhNhNubh)}(h :c:type:`drm_prime_file_private`h]j)}(hjh]hdrm_prime_file_private}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_prime_file_privateuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:444: ./drivers/gpu/drm/drm_prime.chKFhj}ubh] only retain a weak reference, which is cleaned up when the corresponding object is released.}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKFhjhubh)}(hX=Self-importing: If userspace is using PRIME as a replacement for flink then it will get a fd->handle request for a GEM object that it created. Drivers should detect this situation and return back the underlying object from the dma-buf private. For GEM based drivers this is handled in drm_gem_prime_import() already.h]hX=Self-importing: If userspace is using PRIME as a replacement for flink then it will get a fd->handle request for a GEM object that it created. Drivers should detect this situation and return back the underlying object from the dma-buf private. For GEM based drivers this is handled in drm_gem_prime_import() already.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:444: ./drivers/gpu/drm/drm_prime.chKPhjhubeh}(h]"reference-counting-for-gem-driversah ]h"]"reference counting for gem driversah$]h&]uh1hhjhhhNhNubeh}(h]overview-and-lifetime-rulesah ]h"]overview and lifetime rulesah$]h&]uh1hhjԫhhhhhMubh)}(hhh](h)}(hPRIME Helper Functionsh]hPRIME Helper Functions}(hjѭhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjέhhhhhMubh)}(hX}Drivers can implement :c:type:`drm_gem_object_funcs.export ` and :c:type:`drm_driver.gem_prime_import ` in terms of simpler APIs by using the helper functions drm_gem_prime_export() and drm_gem_prime_import(). These functions implement dma-buf support in terms of some lower-level helpers, which are again exported for drivers to use individually:h](hDrivers can implement }(hj߭hhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.export `h]j)}(hjh]hdrm_gem_object_funcs.export}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chM(hj߭ubh and }(hj߭hhhNhNubh)}(h2:c:type:`drm_driver.gem_prime_import `h]j)}(hj h]hdrm_driver.gem_prime_import}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhjhM(hj߭ubh in terms of simpler APIs by using the helper functions drm_gem_prime_export() and drm_gem_prime_import(). These functions implement dma-buf support in terms of some lower-level helpers, which are again exported for drivers to use individually:}(hj߭hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM(hjέhhubh)}(hhh](h)}(hExporting buffersh]hExporting buffers}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj4hNhNubh)}(hXOptional pinning of buffers is handled at dma-buf attach and detach time in drm_gem_map_attach() and drm_gem_map_detach(). Backing storage itself is handled by drm_gem_map_dma_buf() and drm_gem_unmap_dma_buf(), which relies on :c:type:`drm_gem_object_funcs.get_sg_table `. If :c:type:`drm_gem_object_funcs.get_sg_table ` is unimplemented, exports into another device are rejected.h](hOptional pinning of buffers is handled at dma-buf attach and detach time in drm_gem_map_attach() and drm_gem_map_detach(). Backing storage itself is handled by drm_gem_map_dma_buf() and drm_gem_unmap_dma_buf(), which relies on }(hjEhhhNhNubh)}(hB:c:type:`drm_gem_object_funcs.get_sg_table `h]j)}(hjOh]h!drm_gem_object_funcs.get_sg_table}(hjQhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chM1hjEubh. If }(hjEhhhNhNubh)}(hB:c:type:`drm_gem_object_funcs.get_sg_table `h]j)}(hjsh]h!drm_gem_object_funcs.get_sg_table}(hjuhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhjlhM1hjEubh< is unimplemented, exports into another device are rejected.}(hjEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjlhM1hj4ubh)}(hFor kernel-internal access there's drm_gem_dmabuf_vmap() and drm_gem_dmabuf_vunmap(). Userspace mmap support is provided by drm_gem_dmabuf_mmap().h]hFor kernel-internal access there’s drm_gem_dmabuf_vmap() and drm_gem_dmabuf_vunmap(). Userspace mmap support is provided by drm_gem_dmabuf_mmap().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chM7hj4ubh)}(hNote that these export helpers can only be used if the underlying backing storage is fully coherent and either permanently pinned, or it is safe to pin it indefinitely.h]hNote that these export helpers can only be used if the underlying backing storage is fully coherent and either permanently pinned, or it is safe to pin it indefinitely.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chM;hj4ubh)}(hGFIXME: The underlying helper functions are named rather inconsistently.h]hGFIXME: The underlying helper functions are named rather inconsistently.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chM?hj4ubeh}(h]exporting-buffersah ]h"]exporting buffersah$]h&]uh1hhjέhhhNhNubh)}(hhh](h)}(hImporting buffersh]hImporting buffers}(hjҮhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjϮhNhNubh)}(hvImporting dma-bufs using drm_gem_prime_import() relies on :c:type:`drm_driver.gem_prime_import_sg_table `.h](h:Importing dma-bufs using drm_gem_prime_import() relies on }(hjhhhNhNubh)}(h;:c:type:`drm_driver.gem_prime_import_sg_table `h]j)}(hjh]h$drm_driver.gem_prime_import_sg_table}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chMDhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMDhjϮubh)}(hNote that similarly to the export helpers this permanently pins the underlying backing storage. Which is ok for scanout, but is not the best option for sharing lots of buffers for rendering.h]hNote that similarly to the export helpers this permanently pins the underlying backing storage. Which is ok for scanout, but is not the best option for sharing lots of buffers for rendering.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:450: ./drivers/gpu/drm/drm_prime.chMGhjϮubeh}(h]importing-buffersah ]h"]importing buffersah$]h&]uh1hhjέhhhNhNubeh}(h]prime-helper-functionsah ]h"]prime helper functionsah$]h&]uh1hhjԫhhhhhMubh)}(hhh](h)}(hPRIME Function Referencesh]hPRIME Function References}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hhhhhMubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_prime_file_private (C struct)c.drm_prime_file_privatehNtauh1j!hj1hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhNubj3)}(hhh](j8)}(hdrm_prime_file_privateh]j>)}(hstruct drm_prime_file_privateh](jD)}(hjh]hstruct}(hj\hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjXhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhKubjV)}(h h]h }(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXhhhjihKubjg)}(hdrm_prime_file_privateh]jm)}(hjVh]hdrm_prime_file_private}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjXhhhjihKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjThhhjihKubah}(h]jNah ](jjeh"]h$]h&]jj)jhuh1j7hjihKhjQhhubj)}(hhh]h)}(hper-file tracking for PRIMEh]hper-file tracking for PRIME}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhK(hjhhubah}(h]h ]h"]h$]h&]uh1jhjQhhhjihKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhj1hjPhNubj)}(hE**Definition**:: struct drm_prime_file_private { }; **Members**h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj¯hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhK,hjubjT)}(h"struct drm_prime_file_private { };h]h"struct drm_prime_file_private { };}hjۯsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhK.hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhK1hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhjPhNubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhK4hj1hhubh)}(hThis just contains the internal :c:type:`struct dma_buf ` and handle caches for each :c:type:`struct drm_file ` used by the PRIME core code.h](h This just contains the internal }(hj!hhhNhNubh)}(h":c:type:`struct dma_buf `h]j)}(hj+h]hstruct dma_buf}(hj-hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_bufuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:456: ./include/drm/drm_prime.hhK)hj!ubh and handle caches for each }(hj!hhhNhNubh)}(h$:c:type:`struct drm_file `h]j)}(hjOh]hstruct drm_file}(hjQhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_fileuh1hhjHhK)hj!ubh used by the PRIME core code.}(hj!hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjHhK)hj1hhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_dmabuf_export (C function)c.drm_gem_dmabuf_exporthNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hestruct dma_buf * drm_gem_dmabuf_export (struct drm_device *dev, struct dma_buf_export_info *exp_info)h]j>)}(hcstruct dma_buf *drm_gem_dmabuf_export(struct drm_device *dev, struct dma_buf_export_info *exp_info)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gem_dmabuf_exportsbc.drm_gem_dmabuf_exportasbuh1hhjhhhjhKubjV)}(h h]h }(hjϰhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubj4)}(hj7h]h*}(hjݰhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhKubjg)}(hdrm_gem_dmabuf_exporth]jm)}(hj̰h]hdrm_gem_dmabuf_export}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h>(struct drm_device *dev, struct dma_buf_export_info *exp_info)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj)modnameN classnameNjj)}j]jʰc.drm_gem_dmabuf_exportasbuh1hhjubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjShhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h$struct dma_buf_export_info *exp_infoh](jD)}(hjh]hstruct}(hjyhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjuubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjuubh)}(hhh]jm)}(hdma_buf_export_infoh]hdma_buf_export_info}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jʰc.drm_gem_dmabuf_exportasbuh1hhjuubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjuubj4)}(hj7h]h*}(hjñhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjuubjm)}(hexp_infoh]hexp_info}(hjбhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h/:c:type:`dma_buf` export implementation for GEMh](h)}(h:c:type:`dma_buf`h]j)}(hjh]hdma_buf}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jʰc.drm_gem_dmabuf_exportasbjMdma_bufuh1hhjhKhjubh export implementation for GEM}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj6jj6jjjuh1j2hhhj1hNhNubj)}(hX4**Parameters** ``struct drm_device *dev`` parent device for the exported dmabuf ``struct dma_buf_export_info *exp_info`` the export information used by dma_buf_export() **Description** This wraps dma_buf_export() for use by generic GEM drivers that are using drm_gem_dmabuf_release(). In addition to calling dma_buf_export(), we take a reference to the :c:type:`drm_device` and the exported :c:type:`drm_gem_object` (stored in :c:type:`dma_buf_export_info.priv `) which is released by drm_gem_dmabuf_release(). Returns the new dmabuf.h](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhj:ubj)}(hhh](j)}(hA``struct drm_device *dev`` parent device for the exported dmabuf h](j)}(h``struct drm_device *dev``h]j)}(hj_h]hstruct drm_device *dev}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhjYubj )}(hhh]h)}(h%parent device for the exported dmabufh]h%parent device for the exported dmabuf}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthKhjuubah}(h]h ]h"]h$]h&]uh1j hjYubeh}(h]h ]h"]h$]h&]uh1jhjthKhjVubj)}(hY``struct dma_buf_export_info *exp_info`` the export information used by dma_buf_export() h](j)}(h(``struct dma_buf_export_info *exp_info``h]j)}(hjh]h$struct dma_buf_export_info *exp_info}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhjubj )}(hhh]h)}(h/the export information used by dma_buf_export()h]h/the export information used by dma_buf_export()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjVubeh}(h]h ]h"]h$]h&]uh1jhj:ubh)}(h**Description**h]j)}(hjӲh]h Description}(hjղhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjѲubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhj:ubh)}(hXZThis wraps dma_buf_export() for use by generic GEM drivers that are using drm_gem_dmabuf_release(). In addition to calling dma_buf_export(), we take a reference to the :c:type:`drm_device` and the exported :c:type:`drm_gem_object` (stored in :c:type:`dma_buf_export_info.priv `) which is released by drm_gem_dmabuf_release().h](hThis wraps dma_buf_export() for use by generic GEM drivers that are using drm_gem_dmabuf_release(). In addition to calling dma_buf_export(), we take a reference to the }(hjhhhNhNubh)}(h:c:type:`drm_device`h]j)}(hjh]h drm_device}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhjubh and the exported }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhKhjubh (stored in }(hjhhhNhNubh)}(h8:c:type:`dma_buf_export_info.priv `h]j)}(hj:h]hdma_buf_export_info.priv}(hj<hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_buf_export_infouh1hhjhKhjubh0) which is released by drm_gem_dmabuf_release().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhj:ubh)}(hReturns the new dmabuf.h]hReturns the new dmabuf.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chKhj:ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gem_dmabuf_release (C function)c.drm_gem_dmabuf_releasehNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(h5void drm_gem_dmabuf_release (struct dma_buf *dma_buf)h]j>)}(h4void drm_gem_dmabuf_release(struct dma_buf *dma_buf)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gem_dmabuf_releaseh]jm)}(hdrm_gem_dmabuf_releaseh]hdrm_gem_dmabuf_release}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h(struct dma_buf *dma_buf)h]j)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjͳhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjɳubjV)}(h h]h }(hjڳhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjɳubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_dmabuf_releaseasbuh1hhjɳubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjɳubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjɳubjm)}(hdma_bufh]hdma_buf}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjɳubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjųubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h0:c:type:`dma_buf` release implementation for GEMh](h)}(h:c:type:`dma_buf`h]j)}(hjVh]hdma_buf}(hjXhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gem_dmabuf_releaseasbjMdma_bufuh1hhjhKhjPubh release implementation for GEM}(hjPhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjMhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hXG**Parameters** ``struct dma_buf *dma_buf`` buffer to be released **Description** Generic release function for dma_bufs exported as PRIME buffers. GEM drivers must use this in their :c:type:`dma_buf_ops` structure as the release callback. drm_gem_dmabuf_release() should be used in conjunction with drm_gem_dmabuf_export().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh]j)}(h2``struct dma_buf *dma_buf`` buffer to be released h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjh]hstruct dma_buf *dma_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hbuffer to be releasedh]hbuffer to be released}(hjδhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjʴhMhj˴ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjʴhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hGeneric release function for dma_bufs exported as PRIME buffers. GEM drivers must use this in their :c:type:`dma_buf_ops` structure as the release callback. drm_gem_dmabuf_release() should be used in conjunction with drm_gem_dmabuf_export().h](hdGeneric release function for dma_bufs exported as PRIME buffers. GEM drivers must use this in their }(hjhhhNhNubh)}(h:c:type:`dma_buf_ops`h]j)}(hjh]h dma_buf_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubhx structure as the release callback. drm_gem_dmabuf_release() should be used in conjunction with drm_gem_dmabuf_export().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj-hMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gem_prime_fd_to_handle (C function)c.drm_gem_prime_fd_to_handlehNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hsint drm_gem_prime_fd_to_handle (struct drm_device *dev, struct drm_file *file_priv, int prime_fd, uint32_t *handle)h]j>)}(hrint drm_gem_prime_fd_to_handle(struct drm_device *dev, struct drm_file *file_priv, int prime_fd, uint32_t *handle)h](j)}(hinth]hint}(hjXhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjThhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjThhhjfhMubjg)}(hdrm_gem_prime_fd_to_handleh]jm)}(hdrm_gem_prime_fd_to_handleh]hdrm_gem_prime_fd_to_handle}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjThhhjfhMubj)}(hT(struct drm_device *dev, struct drm_file *file_priv, int prime_fd, uint32_t *handle)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jj{sbc.drm_gem_prime_fd_to_handleasbuh1hhjubjV)}(h h]h }(hjӵhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_file *file_privh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj'modnameN classnameNjj)}j]jϵc.drm_gem_prime_fd_to_handleasbuh1hhjubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjQhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h file_privh]h file_priv}(hj^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int prime_fdh](j)}(hinth]hint}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjsubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubjm)}(hprime_fdh]hprime_fd}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(huint32_t *handleh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jϵc.drm_gem_prime_fd_to_handleasbuh1hhjubjV)}(h h]h }(hjͶhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj۶hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hhandleh]hhandle}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjThhhjfhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjPhhhjfhMubah}(h]jKah ](jjeh"]h$]h&]jj)jhuh1j7hjfhMhjMhhubj)}(hhh]h)}(h%PRIME import function for GEM driversh]h%PRIME import function for GEM drivers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjMhhhjfhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj*jj*jjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct drm_device *dev`` drm_device to import into ``struct drm_file *file_priv`` drm file-private structure ``int prime_fd`` fd id of the dma-buf which should be imported ``uint32_t *handle`` pointer to storage for the handle of the imported buffer object **Description** This is the PRIME import function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual importing of GEM object from the dma-buf is done through the :c:type:`drm_driver.gem_prime_import ` driver callback. Returns 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hj4h]h Parameters}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj.ubj)}(hhh](j)}(h5``struct drm_device *dev`` drm_device to import into h](j)}(h``struct drm_device *dev``h]j)}(hjSh]hstruct drm_device *dev}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjMubj )}(hhh]h)}(hdrm_device to import intoh]hdrm_device to import into}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhMhjiubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjJubj)}(h:``struct drm_file *file_priv`` drm file-private structure h](j)}(h``struct drm_file *file_priv``h]j)}(hjh]hstruct drm_file *file_priv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdrm file-private structureh]hdrm file-private structure}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjJubj)}(h?``int prime_fd`` fd id of the dma-buf which should be imported h](j)}(h``int prime_fd``h]j)}(hjŷh]h int prime_fd}(hjǷhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj÷ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(h-fd id of the dma-buf which should be importedh]h-fd id of the dma-buf which should be imported}(hj޷hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjڷhMhj۷ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjڷhMhjJubj)}(hU``uint32_t *handle`` pointer to storage for the handle of the imported buffer object h](j)}(h``uint32_t *handle``h]j)}(hjh]huint32_t *handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(h?pointer to storage for the handle of the imported buffer objecth]h?pointer to storage for the handle of the imported buffer object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjJubeh}(h]h ]h"]h$]h&]uh1jhj.ubh)}(h**Description**h]j)}(hj9h]h Description}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj.ubh)}(hXThis is the PRIME import function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual importing of GEM object from the dma-buf is done through the :c:type:`drm_driver.gem_prime_import ` driver callback.h](hThis is the PRIME import function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual importing of GEM object from the dma-buf is done through the }(hjOhhhNhNubh)}(h2:c:type:`drm_driver.gem_prime_import `h]j)}(hjYh]hdrm_driver.gem_prime_import}(hj[hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjOubh driver callback.}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjvhMhj.ubh)}(h9Returns 0 on success or a negative error code on failure.h]h9Returns 0 on success or a negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM!hj.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.+drm_gem_prime_handle_to_dmabuf (C function) c.drm_gem_prime_handle_to_dmabufhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hstruct dma_buf * drm_gem_prime_handle_to_dmabuf (struct drm_device *dev, struct drm_file *file_priv, uint32_t handle, uint32_t flags)h]j>)}(hstruct dma_buf *drm_gem_prime_handle_to_dmabuf(struct drm_device *dev, struct drm_file *file_priv, uint32_t handle, uint32_t flags)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjϸhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj̸ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjѸmodnameN classnameNjj)}j]j )}jdrm_gem_prime_handle_to_dmabufsb c.drm_gem_prime_handle_to_dmabufasbuh1hhjhhhjhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhMubjg)}(hdrm_gem_prime_handle_to_dmabufh]jm)}(hjh]hdrm_gem_prime_handle_to_dmabuf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hU(struct drm_device *dev, struct drm_file *file_priv, uint32_t handle, uint32_t flags)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj*hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj&ubjV)}(h h]h }(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjHhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjJmodnameN classnameNjj)}j]j c.drm_gem_prime_handle_to_dmabufasbuh1hhj&ubjV)}(h h]h }(hjfhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubj4)}(hj7h]h*}(hjthhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj&ubjm)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubj)}(hstruct drm_file *file_privh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j c.drm_gem_prime_handle_to_dmabufasbuh1hhjubjV)}(h h]h }(hjֹhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h file_privh]h file_priv}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubj)}(huint32_t handleh](h)}(hhh]jm)}(huint32_th]huint32_t}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j c.drm_gem_prime_handle_to_dmabufasbuh1hhjubjV)}(h h]h }(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hhandleh]hhandle}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubj)}(huint32_t flagsh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]j c.drm_gem_prime_handle_to_dmabufasbuh1hhjNubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNubjm)}(hflagsh]hflags}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj"ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h%PRIME export function for GEM driversh]h%PRIME export function for GEM drivers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjújjújjjuh1j2hhhj1hNhNubj)}(hXy**Parameters** ``struct drm_device *dev`` dev to export the buffer from ``struct drm_file *file_priv`` drm file-private structure ``uint32_t handle`` buffer handle to export ``uint32_t flags`` flags like DRM_CLOEXEC **Description** This is the PRIME export function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual exporting from GEM object to a dma-buf is done through the :c:type:`drm_gem_object_funcs.export ` callback. Unlike drm_gem_prime_handle_to_fd(), it returns the struct dma_buf it has created, without attaching it to any file descriptors. The difference between those two is similar to that between anon_inode_getfile() and anon_inode_getfd(); insertion into descriptor table is something you can not revert if any cleanup is needed, so the descriptor-returning variants should only be used when you are past the last failure exit and the only thing left is passing the new file descriptor to userland. When all you need is the object itself or when you need to do something else that might fail, use that one instead.h](h)}(h**Parameters**h]j)}(hjͺh]h Parameters}(hjϺhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj˺ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjǺubj)}(hhh](j)}(h9``struct drm_device *dev`` dev to export the buffer from h](j)}(h``struct drm_device *dev``h]j)}(hjh]hstruct drm_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdev to export the buffer fromh]hdev to export the buffer from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h:``struct drm_file *file_priv`` drm file-private structure h](j)}(h``struct drm_file *file_priv``h]j)}(hj%h]hstruct drm_file *file_priv}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdrm file-private structureh]hdrm file-private structure}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj;ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj:hMhjubj)}(h,``uint32_t handle`` buffer handle to export h](j)}(h``uint32_t handle``h]j)}(hj^h]huint32_t handle}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjXubj )}(hhh]h)}(hbuffer handle to exporth]hbuffer handle to export}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjtubah}(h]h ]h"]h$]h&]uh1j hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMhjubj)}(h*``uint32_t flags`` flags like DRM_CLOEXEC h](j)}(h``uint32_t flags``h]j)}(hjh]huint32_t flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hflags like DRM_CLOEXECh]hflags like DRM_CLOEXEC}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjǺubh)}(h**Description**h]j)}(hjһh]h Description}(hjԻhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjлubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjǺubh)}(hX This is the PRIME export function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual exporting from GEM object to a dma-buf is done through the :c:type:`drm_gem_object_funcs.export ` callback.h](hThis is the PRIME export function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual exporting from GEM object to a dma-buf is done through the }(hjhhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.export `h]j)}(hjh]hdrm_gem_object_funcs.export}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjǺubh)}(hXaUnlike drm_gem_prime_handle_to_fd(), it returns the struct dma_buf it has created, without attaching it to any file descriptors. The difference between those two is similar to that between anon_inode_getfile() and anon_inode_getfd(); insertion into descriptor table is something you can not revert if any cleanup is needed, so the descriptor-returning variants should only be used when you are past the last failure exit and the only thing left is passing the new file descriptor to userland. When all you need is the object itself or when you need to do something else that might fail, use that one instead.h]hXaUnlike drm_gem_prime_handle_to_fd(), it returns the struct dma_buf it has created, without attaching it to any file descriptors. The difference between those two is similar to that between anon_inode_getfile() and anon_inode_getfd(); insertion into descriptor table is something you can not revert if any cleanup is needed, so the descriptor-returning variants should only be used when you are past the last failure exit and the only thing left is passing the new file descriptor to userland. When all you need is the object itself or when you need to do something else that might fail, use that one instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjǺubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gem_prime_handle_to_fd (C function)c.drm_gem_prime_handle_to_fdhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hint drm_gem_prime_handle_to_fd (struct drm_device *dev, struct drm_file *file_priv, uint32_t handle, uint32_t flags, int *prime_fd)h]j>)}(hint drm_gem_prime_handle_to_fd(struct drm_device *dev, struct drm_file *file_priv, uint32_t handle, uint32_t flags, int *prime_fd)h](j)}(hinth]hint}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjEhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEhhhjWhMubjg)}(hdrm_gem_prime_handle_to_fdh]jm)}(hdrm_gem_prime_handle_to_fdh]hdrm_gem_prime_handle_to_fd}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjfubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjEhhhjWhMubj)}(hd(struct drm_device *dev, struct drm_file *file_priv, uint32_t handle, uint32_t flags, int *prime_fd)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjlsbc.drm_gem_prime_handle_to_fdasbuh1hhjubjV)}(h h]h }(hjļhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjҼhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hj߼hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(hstruct drm_file *file_privh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_prime_handle_to_fdasbuh1hhjubjV)}(h h]h }(hj4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjBhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h file_privh]h file_priv}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(huint32_t handleh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjkhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjhubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmmodnameN classnameNjj)}j]jc.drm_gem_prime_handle_to_fdasbuh1hhjdubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdubjm)}(hhandleh]hhandle}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(huint32_t flagsh](h)}(hhh]jm)}(huint32_th]huint32_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_prime_handle_to_fdasbuh1hhjubjV)}(h h]h }(hjѽhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hflagsh]hflags}(hj߽hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubj)}(h int *prime_fdh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hprime_fdh]hprime_fd}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj~ubeh}(h]h ]h"]h$]h&]jjuh1jhjEhhhjWhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjAhhhjWhMubah}(h]j<ah ](jjeh"]h$]h&]jj)jhuh1j7hjWhMhj>hhubj)}(hhh]h)}(h%PRIME export function for GEM driversh]h%PRIME export function for GEM drivers}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjHhhubah}(h]h ]h"]h$]h&]uh1jhj>hhhjWhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjcjjcjjjuh1j2hhhj1hNhNubj)}(hXb**Parameters** ``struct drm_device *dev`` dev to export the buffer from ``struct drm_file *file_priv`` drm file-private structure ``uint32_t handle`` buffer handle to export ``uint32_t flags`` flags like DRM_CLOEXEC ``int *prime_fd`` pointer to storage for the fd id of the create dma-buf **Description** This is the PRIME export function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual exporting from GEM object to a dma-buf is done through the :c:type:`drm_gem_object_funcs.export ` callback.h](h)}(h**Parameters**h]j)}(hjmh]h Parameters}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjgubj)}(hhh](j)}(h9``struct drm_device *dev`` dev to export the buffer from h](j)}(h``struct drm_device *dev``h]j)}(hjh]hstruct drm_device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdev to export the buffer fromh]hdev to export the buffer from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h:``struct drm_file *file_priv`` drm file-private structure h](j)}(h``struct drm_file *file_priv``h]j)}(hjžh]hstruct drm_file *file_priv}(hjǾhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjþubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdrm file-private structureh]hdrm file-private structure}(hj޾hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjھhMhj۾ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjھhMhjubj)}(h,``uint32_t handle`` buffer handle to export h](j)}(h``uint32_t handle``h]j)}(hjh]huint32_t handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hbuffer handle to exporth]hbuffer handle to export}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h*``uint32_t flags`` flags like DRM_CLOEXEC h](j)}(h``uint32_t flags``h]j)}(hj7h]huint32_t flags}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj1ubj )}(hhh]h)}(hflags like DRM_CLOEXECh]hflags like DRM_CLOEXEC}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjMubah}(h]h ]h"]h$]h&]uh1j hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMhjubj)}(hI``int *prime_fd`` pointer to storage for the fd id of the create dma-buf h](j)}(h``int *prime_fd``h]j)}(hjph]h int *prime_fd}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjjubj )}(hhh]h)}(h6pointer to storage for the fd id of the create dma-bufh]h6pointer to storage for the fd id of the create dma-buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjgubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjgubh)}(hX This is the PRIME export function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual exporting from GEM object to a dma-buf is done through the :c:type:`drm_gem_object_funcs.export ` callback.h](hThis is the PRIME export function which must be used mandatorily by GEM drivers to ensure correct lifetime management of the underlying GEM object. The actual exporting from GEM object to a dma-buf is done through the }(hjhhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.export `h]j)}(hj˿h]hdrm_gem_object_funcs.export}(hjͿhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjɿubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_map_attach (C function)c.drm_gem_map_attachhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hSint drm_gem_map_attach (struct dma_buf *dma_buf, struct dma_buf_attachment *attach)h]j>)}(hRint drm_gem_map_attach(struct dma_buf *dma_buf, struct dma_buf_attachment *attach)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMOubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj!hMOubjg)}(hdrm_gem_map_attachh]jm)}(hdrm_gem_map_attachh]hdrm_gem_map_attach}(hj4hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj!hMOubj)}(h<(struct dma_buf *dma_buf, struct dma_buf_attachment *attach)h](j)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjPhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjLubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjpmodnameN classnameNjj)}j]j )}jj6sbc.drm_gem_map_attachasbuh1hhjLubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjLubjm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubj)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_map_attachasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hattachh]hattach}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj!hMOubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj!hMOubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj!hMOhjhhubj)}(hhh]h)}(h%dma_buf attach implementation for GEMh]h%dma_buf attach implementation for GEM}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMOhj@hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj!hMOubeh}(h]h ](jfunctioneh"]h$]h&]jjjj[jj[jjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct dma_buf *dma_buf`` buffer to attach device to ``struct dma_buf_attachment *attach`` buffer attachment data **Description** Calls :c:type:`drm_gem_object_funcs.pin ` for device specific handling. This can be used as the :c:type:`dma_buf_ops.attach ` callback. Must be used together with drm_gem_map_detach(). Returns 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjeh]h Parameters}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMShj_ubj)}(hhh](j)}(h7``struct dma_buf *dma_buf`` buffer to attach device to h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjh]hstruct dma_buf *dma_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMPhj~ubj )}(hhh]h)}(hbuffer to attach device toh]hbuffer to attach device to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMPhjubah}(h]h ]h"]h$]h&]uh1j hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhMPhj{ubj)}(h=``struct dma_buf_attachment *attach`` buffer attachment data h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hjh]h!struct dma_buf_attachment *attach}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMQhjubj )}(hhh]h)}(hbuffer attachment datah]hbuffer attachment data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMQhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMQhj{ubeh}(h]h ]h"]h$]h&]uh1jhj_ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMShj_ubh)}(hCalls :c:type:`drm_gem_object_funcs.pin ` for device specific handling. This can be used as the :c:type:`dma_buf_ops.attach ` callback. Must be used together with drm_gem_map_detach().h](hCalls }(hjhhhNhNubh)}(h9:c:type:`drm_gem_object_funcs.pin `h]j)}(hjh]hdrm_gem_object_funcs.pin}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMRhjubh7 for device specific handling. This can be used as the }(hjhhhNhNubh)}(h*:c:type:`dma_buf_ops.attach `h]j)}(hj<h]hdma_buf_ops.attach}(hj>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhj5hMRhjubh; callback. Must be used together with drm_gem_map_detach().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5hMRhj_ubh)}(h5Returns 0 on success, negative error code on failure.h]h5Returns 0 on success, negative error code on failure.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMVhj_ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_map_detach (C function)c.drm_gem_map_detachhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hTvoid drm_gem_map_detach (struct dma_buf *dma_buf, struct dma_buf_attachment *attach)h]j>)}(hSvoid drm_gem_map_detach(struct dma_buf *dma_buf, struct dma_buf_attachment *attach)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMuubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMuubjg)}(hdrm_gem_map_detachh]jm)}(hdrm_gem_map_detachh]hdrm_gem_map_detach}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMuubj)}(h<(struct dma_buf *dma_buf, struct dma_buf_attachment *attach)h](j)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_map_detachasbuh1hhjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdma_bufh]hdma_buf}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hjAhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj=ubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjamodnameN classnameNjj)}j]j c.drm_gem_map_detachasbuh1hhj=ubjV)}(h h]h }(hj}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj=ubjm)}(hattachh]hattach}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMuubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMuubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMuhjhhubj)}(hhh]h)}(h%dma_buf detach implementation for GEMh]h%dma_buf detach implementation for GEM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMuhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMuubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct dma_buf *dma_buf`` buffer to detach from ``struct dma_buf_attachment *attach`` attachment to be detached **Description** Calls :c:type:`drm_gem_object_funcs.pin ` for device specific handling. Cleans up :c:type:`dma_buf_attachment` from drm_gem_map_attach(). This can be used as the :c:type:`dma_buf_ops.detach ` callback.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMyhjubj)}(hhh](j)}(h2``struct dma_buf *dma_buf`` buffer to detach from h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjh]hstruct dma_buf *dma_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMvhjubj )}(hhh]h)}(hbuffer to detach fromh]hbuffer to detach from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMvhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMvhjubj)}(h@``struct dma_buf_attachment *attach`` attachment to be detached h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hj<h]h!struct dma_buf_attachment *attach}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMwhj6ubj )}(hhh]h)}(hattachment to be detachedh]hattachment to be detached}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhMwhjRubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhjQhMwhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjwh]h Description}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMyhjubh)}(hCalls :c:type:`drm_gem_object_funcs.pin ` for device specific handling. Cleans up :c:type:`dma_buf_attachment` from drm_gem_map_attach(). This can be used as the :c:type:`dma_buf_ops.detach ` callback.h](hCalls }(hjhhhNhNubh)}(h9:c:type:`drm_gem_object_funcs.pin `h]j)}(hjh]hdrm_gem_object_funcs.pin}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMxhjubh* for device specific handling. Cleans up }(hjhhhNhNubh)}(h:c:type:`dma_buf_attachment`h]j)}(hjh]hdma_buf_attachment}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_buf_attachmentuh1hhjhMxhjubh4 from drm_gem_map_attach(). This can be used as the }(hjhhhNhNubh)}(h*:c:type:`dma_buf_ops.detach `h]j)}(hjh]hdma_buf_ops.detach}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhjhMxhjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMxhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_map_dma_buf (C function)c.drm_gem_map_dma_bufhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hfstruct sg_table * drm_gem_map_dma_buf (struct dma_buf_attachment *attach, enum dma_data_direction dir)h]j>)}(hdstruct sg_table *drm_gem_map_dma_buf(struct dma_buf_attachment *attach, enum dma_data_direction dir)h](jD)}(hjh]hstruct}(hj%hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj!hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!hhhj2hMubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFmodnameN classnameNjj)}j]j )}jdrm_gem_map_dma_bufsbc.drm_gem_map_dma_bufasbuh1hhj!hhhj2hMubjV)}(h h]h }(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!hhhj2hMubj4)}(hj7h]h*}(hjshhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj!hhhj2hMubjg)}(hdrm_gem_map_dma_bufh]jm)}(hjbh]hdrm_gem_map_dma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj!hhhj2hMubj)}(h@(struct dma_buf_attachment *attach, enum dma_data_direction dir)h](j)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j`c.drm_gem_map_dma_bufasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hattachh]hattach}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum dma_data_direction dirh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdma_data_directionh]hdma_data_direction}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj/modnameN classnameNjj)}j]j`c.drm_gem_map_dma_bufasbuh1hhj ubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(hdirh]hdir}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj!hhhj2hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj2hMubah}(h]jah ](jjeh"] h$]h&]jj)jhuh1j7hj2hMhjhhubj)}(hhh]h)}(h"map_dma_buf implementation for GEMh]h"map_dma_buf implementation for GEM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj2hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hX4**Parameters** ``struct dma_buf_attachment *attach`` attachment whose scatterlist is to be returned ``enum dma_data_direction dir`` direction of DMA transfer **Description** Calls :c:type:`drm_gem_object_funcs.get_sg_table ` and then maps the scatterlist. This can be used as the :c:type:`dma_buf_ops.map_dma_buf ` callback. Should be used together with drm_gem_unmap_dma_buf(). **Return** sg_table containing the scatterlist to be returned; returns ERR_PTR on error. May return -EINTR if it is interrupted by a signal.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(hU``struct dma_buf_attachment *attach`` attachment whose scatterlist is to be returned h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hjh]h!struct dma_buf_attachment *attach}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(h.attachment whose scatterlist is to be returnedh]h.attachment whose scatterlist is to be returned}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h:``enum dma_data_direction dir`` direction of DMA transfer h](j)}(h``enum dma_data_direction dir``h]j)}(hjh]henum dma_data_direction dir}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdirection of DMA transferh]hdirection of DMA transfer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj8h]h Description}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hCalls :c:type:`drm_gem_object_funcs.get_sg_table ` and then maps the scatterlist. This can be used as the :c:type:`dma_buf_ops.map_dma_buf ` callback. Should be used together with drm_gem_unmap_dma_buf().h](hCalls }(hjNhhhNhNubh)}(hB:c:type:`drm_gem_object_funcs.get_sg_table `h]j)}(hjXh]h!drm_gem_object_funcs.get_sg_table}(hjZhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjNubh8 and then maps the scatterlist. This can be used as the }(hjNhhhNhNubh)}(h/:c:type:`dma_buf_ops.map_dma_buf `h]j)}(hj|h]hdma_buf_ops.map_dma_buf}(hj~hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhjuhMhjNubh@ callback. Should be used together with drm_gem_unmap_dma_buf().}(hjNhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjuhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hsg_table containing the scatterlist to be returned; returns ERR_PTR on error. May return -EINTR if it is interrupted by a signal.h]hsg_table containing the scatterlist to be returned; returns ERR_PTR on error. May return -EINTR if it is interrupted by a signal.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_unmap_dma_buf (C function)c.drm_gem_unmap_dma_bufhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hqvoid drm_gem_unmap_dma_buf (struct dma_buf_attachment *attach, struct sg_table *sgt, enum dma_data_direction dir)h]j>)}(hpvoid drm_gem_unmap_dma_buf(struct dma_buf_attachment *attach, struct sg_table *sgt, enum dma_data_direction dir)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gem_unmap_dma_bufh]jm)}(hdrm_gem_unmap_dma_bufh]hdrm_gem_unmap_dma_buf}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hV(struct dma_buf_attachment *attach, struct sg_table *sgt, enum dma_data_direction dir)h](j)}(h!struct dma_buf_attachment *attachh](jD)}(hjh]hstruct}(hj'hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj#ubjV)}(h h]h }(hj4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#ubh)}(hhh]jm)}(hdma_buf_attachmenth]hdma_buf_attachment}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjGmodnameN classnameNjj)}j]j )}jj sbc.drm_gem_unmap_dma_bufasbuh1hhj#ubjV)}(h h]h }(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#ubj4)}(hj7h]h*}(hjshhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj#ubjm)}(hattachh]hattach}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj#ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jac.drm_gem_unmap_dma_bufasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hsgth]hsgt}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum dma_data_direction dirh](jD)}(hjGh]henum}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_data_directionh]hdma_data_direction}(hj'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj)modnameN classnameNjj)}j]jac.drm_gem_unmap_dma_bufasbuh1hhjubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hdirh]hdir}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h$unmap_dma_buf implementation for GEMh]h$unmap_dma_buf implementation for GEM}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjzhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hX>**Parameters** ``struct dma_buf_attachment *attach`` attachment to unmap buffer from ``struct sg_table *sgt`` scatterlist info of the buffer to unmap ``enum dma_data_direction dir`` direction of DMA transfer **Description** This can be used as the :c:type:`dma_buf_ops.unmap_dma_buf ` callback.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(hF``struct dma_buf_attachment *attach`` attachment to unmap buffer from h](j)}(h%``struct dma_buf_attachment *attach``h]j)}(hjh]h!struct dma_buf_attachment *attach}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hattachment to unmap buffer fromh]hattachment to unmap buffer from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hA``struct sg_table *sgt`` scatterlist info of the buffer to unmap h](j)}(h``struct sg_table *sgt``h]j)}(hjh]hstruct sg_table *sgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(h'scatterlist info of the buffer to unmaph]h'scatterlist info of the buffer to unmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h:``enum dma_data_direction dir`` direction of DMA transfer h](j)}(h``enum dma_data_direction dir``h]j)}(hj0h]henum dma_data_direction dir}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj*ubj )}(hhh]h)}(hdirection of DMA transferh]hdirection of DMA transfer}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEhMhjFubah}(h]h ]h"]h$]h&]uh1j hj*ubeh}(h]h ]h"]h$]h&]uh1jhjEhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjkh]h Description}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hSThis can be used as the :c:type:`dma_buf_ops.unmap_dma_buf ` callback.h](hThis can be used as the }(hjhhhNhNubh)}(h1:c:type:`dma_buf_ops.unmap_dma_buf `h]j)}(hjh]hdma_buf_ops.unmap_dma_buf}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_dmabuf_vmap (C function)c.drm_gem_dmabuf_vmaphNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hHint drm_gem_dmabuf_vmap (struct dma_buf *dma_buf, struct iosys_map *map)h]j>)}(hGint drm_gem_dmabuf_vmap(struct dma_buf *dma_buf, struct iosys_map *map)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gem_dmabuf_vmaph]jm)}(hdrm_gem_dmabuf_vmaph]hdrm_gem_dmabuf_vmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h0(struct dma_buf *dma_buf, struct iosys_map *map)h](j)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j )}jjsbc.drm_gem_dmabuf_vmapasbuh1hhj ubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj\hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hdma_bufh]hdma_buf}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jJc.drm_gem_dmabuf_vmapasbuh1hhj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj~ubjm)}(hmaph]hmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h#dma_buf vmap implementation for GEMh]h#dma_buf vmap implementation for GEM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct dma_buf *dma_buf`` buffer to be mapped ``struct iosys_map *map`` the virtual address of the buffer **Description** Sets up a kernel virtual mapping. This can be used as the :c:type:`dma_buf_ops.vmap ` callback. Calls into :c:type:`drm_gem_object_funcs.vmap ` for device specific handling. The kernel virtual address is returned in map. Returns 0 on success or a negative errno code otherwise.h](h)}(h**Parameters**h]j)}(hj%h]h Parameters}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h0``struct dma_buf *dma_buf`` buffer to be mapped h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjDh]hstruct dma_buf *dma_buf}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj>ubj )}(hhh]h)}(hbuffer to be mappedh]hbuffer to be mapped}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhMhjZubah}(h]h ]h"]h$]h&]uh1j hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhMhj;ubj)}(h<``struct iosys_map *map`` the virtual address of the buffer h](j)}(h``struct iosys_map *map``h]j)}(hj}h]hstruct iosys_map *map}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjwubj )}(hhh]h)}(h!the virtual address of the bufferh]h!the virtual address of the buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjwubeh}(h]h ]h"]h$]h&]uh1jhjhMhj;ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hSets up a kernel virtual mapping. This can be used as the :c:type:`dma_buf_ops.vmap ` callback. Calls into :c:type:`drm_gem_object_funcs.vmap ` for device specific handling. The kernel virtual address is returned in map.h](h:Sets up a kernel virtual mapping. This can be used as the }(hjhhhNhNubh)}(h(:c:type:`dma_buf_ops.vmap `h]j)}(hjh]hdma_buf_ops.vmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh callback. Calls into }(hjhhhNhNubh)}(h::c:type:`drm_gem_object_funcs.vmap `h]j)}(hjh]hdrm_gem_object_funcs.vmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhjhMhjubhM for device specific handling. The kernel virtual address is returned in map.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h8Returns 0 on success or a negative errno code otherwise.h]h8Returns 0 on success or a negative errno code otherwise.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gem_dmabuf_vunmap (C function)c.drm_gem_dmabuf_vunmaphNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hKvoid drm_gem_dmabuf_vunmap (struct dma_buf *dma_buf, struct iosys_map *map)h]j>)}(hJvoid drm_gem_dmabuf_vunmap(struct dma_buf *dma_buf, struct iosys_map *map)h](j)}(hvoidh]hvoid}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNhhhj`hMubjg)}(hdrm_gem_dmabuf_vunmaph]jm)}(hdrm_gem_dmabuf_vunmaph]hdrm_gem_dmabuf_vunmap}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjNhhhj`hMubj)}(h0(struct dma_buf *dma_buf, struct iosys_map *map)h](j)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjusbc.drm_gem_dmabuf_vunmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct iosys_map *maph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]jc.drm_gem_dmabuf_vunmapasbuh1hhjubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjKhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmaph]hmap}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjNhhhj`hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjJhhhj`hMubah}(h]jEah ](jjeh"]h$]h&]jj)jhuh1j7hj`hMhjGhhubj)}(hhh]h)}(h%dma_buf vunmap implementation for GEMh]h%dma_buf vunmap implementation for GEM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjGhhhj`hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hXj**Parameters** ``struct dma_buf *dma_buf`` buffer to be unmapped ``struct iosys_map *map`` the virtual address of the buffer **Description** Releases a kernel virtual mapping. This can be used as the :c:type:`dma_buf_ops.vunmap ` callback. Calls into :c:type:`drm_gem_object_funcs.vunmap ` for device specific handling.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h2``struct dma_buf *dma_buf`` buffer to be unmapped h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjh]hstruct dma_buf *dma_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hbuffer to be unmappedh]hbuffer to be unmapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h<``struct iosys_map *map`` the virtual address of the buffer h](j)}(h``struct iosys_map *map``h]j)}(hjh]hstruct iosys_map *map}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(h!the virtual address of the bufferh]h!the virtual address of the buffer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj7h]h Description}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hReleases a kernel virtual mapping. This can be used as the :c:type:`dma_buf_ops.vunmap ` callback. Calls into :c:type:`drm_gem_object_funcs.vunmap ` for device specific handling.h](h;Releases a kernel virtual mapping. This can be used as the }(hjMhhhNhNubh)}(h*:c:type:`dma_buf_ops.vunmap `h]j)}(hjWh]hdma_buf_ops.vunmap}(hjYhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjMubh callback. Calls into }(hjMhhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.vunmap `h]j)}(hj{h]hdrm_gem_object_funcs.vunmap}(hj}hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhjthMhjMubh for device specific handling.}(hjMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjthMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gem_prime_mmap (C function)c.drm_gem_prime_mmaphNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hOint drm_gem_prime_mmap (struct drm_gem_object *obj, struct vm_area_struct *vma)h]j>)}(hNint drm_gem_prime_mmap(struct drm_gem_object *obj, struct vm_area_struct *vma)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gem_prime_mmaph]jm)}(hdrm_gem_prime_mmaph]hdrm_gem_prime_mmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h8(struct drm_gem_object *obj, struct vm_area_struct *vma)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gem_prime_mmapasbuh1hhjubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjKhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjqhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjmubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j9c.drm_gem_prime_mmapasbuh1hhjmubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjmubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h#PRIME mmap function for GEM driversh]h#PRIME mmap function for GEM drivers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct drm_gem_object *obj`` GEM object ``struct vm_area_struct *vma`` Virtual address range **Description** This function sets up a userspace mapping for PRIME exported buffers using the same codepath that is used for regular GEM buffer mapping on the DRM fd. The fake GEM offset is added to vma->vm_pgoff and :c:type:`drm_driver->fops `->mmap is called to set up the mapping.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h*``struct drm_gem_object *obj`` GEM object h](j)}(h``struct drm_gem_object *obj``h]j)}(hj3h]hstruct drm_gem_object *obj}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj-ubj )}(hhh]h)}(h GEM objecth]h GEM object}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhMhjIubah}(h]h ]h"]h$]h&]uh1j hj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhMhj*ubj)}(h5``struct vm_area_struct *vma`` Virtual address range h](j)}(h``struct vm_area_struct *vma``h]j)}(hjlh]hstruct vm_area_struct *vma}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjfubj )}(hhh]h)}(hVirtual address rangeh]hVirtual address range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMhj*ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hXThis function sets up a userspace mapping for PRIME exported buffers using the same codepath that is used for regular GEM buffer mapping on the DRM fd. The fake GEM offset is added to vma->vm_pgoff and :c:type:`drm_driver->fops `->mmap is called to set up the mapping.h](hThis function sets up a userspace mapping for PRIME exported buffers using the same codepath that is used for regular GEM buffer mapping on the DRM fd. The fake GEM offset is added to vma->vm_pgoff and }(hjhhhNhNubh)}(h':c:type:`drm_driver->fops `h]j)}(hjh]hdrm_driver->fops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh'->mmap is called to set up the mapping.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gem_dmabuf_mmap (C function)c.drm_gem_dmabuf_mmaphNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hMint drm_gem_dmabuf_mmap (struct dma_buf *dma_buf, struct vm_area_struct *vma)h]j>)}(hLint drm_gem_dmabuf_mmap(struct dma_buf *dma_buf, struct vm_area_struct *vma)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM*ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhM*ubjg)}(hdrm_gem_dmabuf_mmaph]jm)}(hdrm_gem_dmabuf_mmaph]hdrm_gem_dmabuf_mmap}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhM*ubj)}(h5(struct dma_buf *dma_buf, struct vm_area_struct *vma)h](j)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjLhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjHubjV)}(h h]h }(hjYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjgubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjlmodnameN classnameNjj)}j]j )}jj2sbc.drm_gem_dmabuf_mmapasbuh1hhjHubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjHubjm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubj)}(hstruct vm_area_struct *vmah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hvm_area_structh]hvm_area_struct}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_dmabuf_mmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvmah]hvma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjDubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhM*ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM*ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM*hjhhubj)}(hhh]h)}(h#dma_buf mmap implementation for GEMh]h#dma_buf mmap implementation for GEM}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM*hj<hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM*ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjWjjWjjjuh1j2hhhj1hNhNubj)}(hXc**Parameters** ``struct dma_buf *dma_buf`` buffer to be mapped ``struct vm_area_struct *vma`` virtual address range **Description** Provides memory mapping for the buffer. This can be used as the :c:type:`dma_buf_ops.mmap ` callback. It just forwards to drm_gem_prime_mmap(). Returns 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjah]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM.hj[ubj)}(hhh](j)}(h0``struct dma_buf *dma_buf`` buffer to be mapped h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjh]hstruct dma_buf *dma_buf}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM+hjzubj )}(hhh]h)}(hbuffer to be mappedh]hbuffer to be mapped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM+hjubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjhM+hjwubj)}(h5``struct vm_area_struct *vma`` virtual address range h](j)}(h``struct vm_area_struct *vma``h]j)}(hjh]hstruct vm_area_struct *vma}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM,hjubj )}(hhh]h)}(hvirtual address rangeh]hvirtual address range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM,hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM,hjwubeh}(h]h ]h"]h$]h&]uh1jhj[ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM.hj[ubh)}(hProvides memory mapping for the buffer. This can be used as the :c:type:`dma_buf_ops.mmap ` callback. It just forwards to drm_gem_prime_mmap().h](h@Provides memory mapping for the buffer. This can be used as the }(hj hhhNhNubh)}(h(:c:type:`dma_buf_ops.mmap `h]j)}(hjh]hdma_buf_ops.mmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_buf_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM-hj ubh4 callback. It just forwards to drm_gem_prime_mmap().}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj1hM-hj[ubh)}(h9Returns 0 on success or a negative error code on failure.h]h9Returns 0 on success or a negative error code on failure.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM0hj[ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_prime_pages_to_sg (C function)c.drm_prime_pages_to_sghNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hlstruct sg_table * drm_prime_pages_to_sg (struct drm_device *dev, struct page **pages, unsigned int nr_pages)h]j>)}(hjstruct sg_table *drm_prime_pages_to_sg(struct drm_device *dev, struct page **pages, unsigned int nr_pages)h](jD)}(hjh]hstruct}(hjkhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjghhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMGubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjghhhjxhMGubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_prime_pages_to_sgsbc.drm_prime_pages_to_sgasbuh1hhjghhhjxhMGubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjghhhjxhMGubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjghhhjxhMGubjg)}(hdrm_prime_pages_to_sgh]jm)}(hjh]hdrm_prime_pages_to_sg}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjghhhjxhMGubj)}(hD(struct drm_device *dev, struct page **pages, unsigned int nr_pages)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_prime_pages_to_sgasbuh1hhjubjV)}(h h]h }(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj/hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hj<hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct page **pagesh](jD)}(hjh]hstruct}(hjUhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjQubjV)}(h h]h }(hjbhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQubh)}(hhh]jm)}(hpageh]hpage}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjumodnameN classnameNjj)}j]jc.drm_prime_pages_to_sgasbuh1hhjQubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjQubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjQubjm)}(hpagesh]hpages}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int nr_pagesh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hnr_pagesh]hnr_pages}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjghhhjxhMGubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjxhMGubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hjxhMGhj`hhubj)}(hhh]h)}(h%converts a page array into an sg listh]h%converts a page array into an sg list}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMGhj1hhubah}(h]h ]h"]h$]h&]uh1jhj`hhhjxhMGubeh}(h]h ](jfunctioneh"]h$]h&]jjjjLjjLjjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct drm_device *dev`` DRM device ``struct page **pages`` pointer to the array of page pointers to convert ``unsigned int nr_pages`` length of the page vector **Description** This helper creates an sg table object from a set of pages the driver is responsible for mapping the pages into the importers address space for use with dma_buf itself. This is useful for implementing :c:type:`drm_gem_object_funcs.get_sg_table `.h](h)}(h**Parameters**h]j)}(hjVh]h Parameters}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMKhjPubj)}(hhh](j)}(h&``struct drm_device *dev`` DRM device h](j)}(h``struct drm_device *dev``h]j)}(hjuh]hstruct drm_device *dev}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMHhjoubj )}(hhh]h)}(h DRM deviceh]h DRM device}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMHhjubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjhMHhjlubj)}(hI``struct page **pages`` pointer to the array of page pointers to convert h](j)}(h``struct page **pages``h]j)}(hjh]hstruct page **pages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMIhjubj )}(hhh]h)}(h0pointer to the array of page pointers to converth]h0pointer to the array of page pointers to convert}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMIhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMIhjlubj)}(h4``unsigned int nr_pages`` length of the page vector h](j)}(h``unsigned int nr_pages``h]j)}(hjh]hunsigned int nr_pages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMJhjubj )}(hhh]h)}(hlength of the page vectorh]hlength of the page vector}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMJhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMJhjlubeh}(h]h ]h"]h$]h&]uh1jhjPubh)}(h**Description**h]j)}(hj"h]h Description}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMLhjPubh)}(hThis helper creates an sg table object from a set of pages the driver is responsible for mapping the pages into the importers address space for use with dma_buf itself.h]hThis helper creates an sg table object from a set of pages the driver is responsible for mapping the pages into the importers address space for use with dma_buf itself.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMKhjPubh)}(hcThis is useful for implementing :c:type:`drm_gem_object_funcs.get_sg_table `.h](h This is useful for implementing }(hjGhhhNhNubh)}(hB:c:type:`drm_gem_object_funcs.get_sg_table `h]j)}(hjQh]h!drm_gem_object_funcs.get_sg_table}(hjShhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMOhjGubh.}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjnhMOhjPubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_prime_get_contiguous_size (C function)c.drm_prime_get_contiguous_sizehNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hBunsigned long drm_prime_get_contiguous_size (struct sg_table *sgt)h]j>)}(hAunsigned long drm_prime_get_contiguous_size(struct sg_table *sgt)h](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMmubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMmubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMmubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMmubjg)}(hdrm_prime_get_contiguous_sizeh]jm)}(hdrm_prime_get_contiguous_sizeh]hdrm_prime_get_contiguous_size}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMmubj)}(h(struct sg_table *sgt)h]j)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_prime_get_contiguous_sizeasbuh1hhjubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj>hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hsgth]hsgt}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMmubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMmubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMmhjhhubj)}(hhh]h)}(h)returns the contiguous size of the bufferh]h)returns the contiguous size of the buffer}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMmhjrhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMmubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hXL**Parameters** ``struct sg_table *sgt`` sg_table describing the buffer to check **Description** This helper calculates the contiguous size in the DMA address space of the buffer described by the provided sg_table. This is useful for implementing :c:type:`drm_gem_object_funcs.gem_prime_import_sg_table `.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMqhjubj)}(hhh]j)}(hA``struct sg_table *sgt`` sg_table describing the buffer to check h](j)}(h``struct sg_table *sgt``h]j)}(hjh]hstruct sg_table *sgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMnhjubj )}(hhh]h)}(h'sg_table describing the buffer to checkh]h'sg_table describing the buffer to check}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMnhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMnhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMphjubh)}(huThis helper calculates the contiguous size in the DMA address space of the buffer described by the provided sg_table.h]huThis helper calculates the contiguous size in the DMA address space of the buffer described by the provided sg_table.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMohjubh)}(hpThis is useful for implementing :c:type:`drm_gem_object_funcs.gem_prime_import_sg_table `.h](h This is useful for implementing }(hjhhhNhNubh)}(hO:c:type:`drm_gem_object_funcs.gem_prime_import_sg_table `h]j)}(hj h]h.drm_gem_object_funcs.gem_prime_import_sg_table}(hj"hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMrhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj=hMrhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gem_prime_export (C function)c.drm_gem_prime_exporthNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hMstruct dma_buf * drm_gem_prime_export (struct drm_gem_object *obj, int flags)h]j>)}(hKstruct dma_buf *drm_gem_prime_export(struct drm_gem_object *obj, int flags)h](jD)}(hjh]hstruct}(hjhhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjdhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdhhhjuhMubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gem_prime_exportsbc.drm_gem_prime_exportasbuh1hhjdhhhjuhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjdhhhjuhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjdhhhjuhMubjg)}(hdrm_gem_prime_exporth]jm)}(hjh]hdrm_gem_prime_export}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjdhhhjuhMubj)}(h'(struct drm_gem_object *obj, int flags)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_prime_exportasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj,hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int flagsh](j)}(hinth]hint}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjNubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNubjm)}(hflagsh]hflags}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjdhhhjuhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj`hhhjuhMubah}(h]j[ah ](jjeh"]h$]h&]jj)jhuh1j7hjuhMhj]hhubj)}(hhh]h)}(h4helper library implementation of the export callbackh]h4helper library implementation of the export callback}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj]hhhjuhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hXY**Parameters** ``struct drm_gem_object *obj`` GEM object to export ``int flags`` flags like DRM_CLOEXEC and DRM_RDWR **Description** This is the implementation of the :c:type:`drm_gem_object_funcs.export ` functions for GEM drivers using the PRIME helpers. It is used as the default in drm_gem_prime_handle_to_fd().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h4``struct drm_gem_object *obj`` GEM object to export h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hGEM object to exporth]hGEM object to export}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h2``int flags`` flags like DRM_CLOEXEC and DRM_RDWR h](j)}(h ``int flags``h]j)}(hjh]h int flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj ubj )}(hhh]h)}(h#flags like DRM_CLOEXEC and DRM_RDWRh]h#flags like DRM_CLOEXEC and DRM_RDWR}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hMhj(ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjMh]h Description}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hThis is the implementation of the :c:type:`drm_gem_object_funcs.export ` functions for GEM drivers using the PRIME helpers. It is used as the default in drm_gem_prime_handle_to_fd().h](h"This is the implementation of the }(hjchhhNhNubh)}(h<:c:type:`drm_gem_object_funcs.export `h]j)}(hjmh]hdrm_gem_object_funcs.export}(hjohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjcubhn functions for GEM drivers using the PRIME helpers. It is used as the default in drm_gem_prime_handle_to_fd().}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j..drm_gem_is_prime_exported_dma_buf (C function)#c.drm_gem_is_prime_exported_dma_bufhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hXbool drm_gem_is_prime_exported_dma_buf (struct drm_device *dev, struct dma_buf *dma_buf)h]j>)}(hWbool drm_gem_is_prime_exported_dma_buf(struct drm_device *dev, struct dma_buf *dma_buf)h](j)}(hj*h]hbool>}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(h!drm_gem_is_prime_exported_dma_bufh]jm)}(h!drm_gem_is_prime_exported_dma_bufh]h!drm_gem_is_prime_exported_dma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h1(struct drm_device *dev, struct dma_buf *dma_buf)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsb#c.drm_gem_is_prime_exported_dma_bufasbuh1hhjubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hjJhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjchhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj_ubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j+#c.drm_gem_is_prime_exported_dma_bufasbuh1hhj_ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj_ubjm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hJchecks if the DMA-BUF was exported from a GEM object belonging to **dev**.h](hBchecks if the DMA-BUF was exported from a GEM object belonging to }(hjhhhNhNubj)}(h**dev**h]hdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(h**Parameters** ``struct drm_device *dev`` drm_device to check against ``struct dma_buf *dma_buf`` dma-buf object to import **Return** true if the DMA-BUF was exported from a GEM object belonging to **dev**, false otherwise.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h7``struct drm_device *dev`` drm_device to check against h](j)}(h``struct drm_device *dev``h]j)}(hj7h]hstruct drm_device *dev}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj1ubj )}(hhh]h)}(hdrm_device to check againsth]hdrm_device to check against}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMhjMubah}(h]h ]h"]h$]h&]uh1j hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMhj.ubj)}(h5``struct dma_buf *dma_buf`` dma-buf object to import h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjph]hstruct dma_buf *dma_buf}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjjubj )}(hhh]h)}(hdma-buf object to importh]hdma-buf object to import}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj.ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hYtrue if the DMA-BUF was exported from a GEM object belonging to **dev**, false otherwise.h](h@true if the DMA-BUF was exported from a GEM object belonging to }(hjhhhNhNubj)}(h**dev**h]hdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, false otherwise.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gem_prime_import_dev (C function)c.drm_gem_prime_import_devhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(h}struct drm_gem_object * drm_gem_prime_import_dev (struct drm_device *dev, struct dma_buf *dma_buf, struct device *attach_dev)h]j>)}(h{struct drm_gem_object *drm_gem_prime_import_dev(struct drm_device *dev, struct dma_buf *dma_buf, struct device *attach_dev)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#modnameN classnameNjj)}j]j )}jdrm_gem_prime_import_devsbc.drm_gem_prime_import_devasbuh1hhjhhhjhMubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubj4)}(hj7h]h*}(hjPhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhMubjg)}(hdrm_gem_prime_import_devh]jm)}(hj?h]hdrm_gem_prime_import_dev}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hL(struct drm_device *dev, struct dma_buf *dma_buf, struct device *attach_dev)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hj|hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjxubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j=c.drm_gem_prime_import_devasbuh1hhjxubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjxubjm)}(hdevh]hdev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubj)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j=c.drm_gem_prime_import_devasbuh1hhjubjV)}(h h]h }(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj6hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdma_bufh]hdma_buf}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubj)}(hstruct device *attach_devh](jD)}(hjh]hstruct}(hj\hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjXubjV)}(h h]h }(hjihhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubh)}(hhh]jm)}(hdeviceh]hdevice}(hjzhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjwubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj|modnameN classnameNjj)}j]j=c.drm_gem_prime_import_devasbuh1hhjXubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjXubjm)}(h attach_devh]h attach_dev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h*core implementation of the import callbackh]h*core implementation of the import callback}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct drm_device *dev`` drm_device to import into ``struct dma_buf *dma_buf`` dma-buf object to import ``struct device *attach_dev`` struct device to dma_buf attach **Description** This is the core of drm_gem_prime_import(). It's designed to be called by drivers who want to use a different device structure than :c:type:`drm_device.dev ` for attaching via dma_buf. This function calls :c:type:`drm_driver.gem_prime_import_sg_table ` internally. Drivers must arrange to call drm_prime_gem_destroy() from their :c:type:`drm_gem_object_funcs.free ` hook when using this function.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h5``struct drm_device *dev`` drm_device to import into h](j)}(h``struct drm_device *dev``h]j)}(hjh]hstruct drm_device *dev}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hdrm_device to import intoh]hdrm_device to import into}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hMhj4ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj3hMhjubj)}(h5``struct dma_buf *dma_buf`` dma-buf object to import h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjWh]hstruct dma_buf *dma_buf}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjQubj )}(hhh]h)}(hdma-buf object to importh]hdma-buf object to import}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhMhjmubah}(h]h ]h"]h$]h&]uh1j hjQubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjubj)}(h>``struct device *attach_dev`` struct device to dma_buf attach h](j)}(h``struct device *attach_dev``h]j)}(hjh]hstruct device *attach_dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hstruct device to dma_buf attachh]hstruct device to dma_buf attach}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hX This is the core of drm_gem_prime_import(). It's designed to be called by drivers who want to use a different device structure than :c:type:`drm_device.dev ` for attaching via dma_buf. This function calls :c:type:`drm_driver.gem_prime_import_sg_table ` internally.h](hThis is the core of drm_gem_prime_import(). It’s designed to be called by drivers who want to use a different device structure than }(hjhhhNhNubh)}(h%:c:type:`drm_device.dev `h]j)}(hjh]hdrm_device.dev}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh0 for attaching via dma_buf. This function calls }(hjhhhNhNubh)}(h;:c:type:`drm_driver.gem_prime_import_sg_table `h]j)}(hjh]h$drm_driver.gem_prime_import_sg_table}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhjhMhjubh internally.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hDrivers must arrange to call drm_prime_gem_destroy() from their :c:type:`drm_gem_object_funcs.free ` hook when using this function.h](h@Drivers must arrange to call drm_prime_gem_destroy() from their }(hj6hhhNhNubh)}(h::c:type:`drm_gem_object_funcs.free `h]j)}(hj@h]hdrm_gem_object_funcs.free}(hjBhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj6ubh hook when using this function.}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj]hMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gem_prime_import (C function)c.drm_gem_prime_importhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(h^struct drm_gem_object * drm_gem_prime_import (struct drm_device *dev, struct dma_buf *dma_buf)h]j>)}(h\struct drm_gem_object *drm_gem_prime_import(struct drm_device *dev, struct dma_buf *dma_buf)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gem_prime_importsbc.drm_gem_prime_importasbuh1hhjhhhjhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhMubjg)}(hdrm_gem_prime_importh]jm)}(hjh]hdrm_gem_prime_import}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h1(struct drm_device *dev, struct dma_buf *dma_buf)h](j)}(hstruct drm_device *devh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj"modnameN classnameNjj)}j]jc.drm_gem_prime_importasbuh1hhjubjV)}(h h]h }(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjLhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdevh]hdev}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct dma_buf *dma_bufh](jD)}(hjh]hstruct}(hjrhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjnubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnubh)}(hhh]jm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gem_prime_importasbuh1hhjnubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjnubjm)}(hdma_bufh]hdma_buf}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]j{ah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhj}hhubj)}(hhh]h)}(h4helper library implementation of the import callbackh]h4helper library implementation of the import callback}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj}hhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhj1hNhNubj)}(hX<**Parameters** ``struct drm_device *dev`` drm_device to import into ``struct dma_buf *dma_buf`` dma-buf object to import **Description** This is the implementation of the gem_prime_import functions for GEM drivers using the PRIME helpers. Drivers can use this as their :c:type:`drm_driver.gem_prime_import ` implementation. It is used as the default implementation in drm_gem_prime_fd_to_handle(). Drivers must arrange to call drm_prime_gem_destroy() from their :c:type:`drm_gem_object_funcs.free ` hook when using this function.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h5``struct drm_device *dev`` drm_device to import into h](j)}(h``struct drm_device *dev``h]j)}(hj4h]hstruct drm_device *dev}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj.ubj )}(hhh]h)}(hdrm_device to import intoh]hdrm_device to import into}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhMhjJubah}(h]h ]h"]h$]h&]uh1j hj.ubeh}(h]h ]h"]h$]h&]uh1jhjIhMhj+ubj)}(h5``struct dma_buf *dma_buf`` dma-buf object to import h](j)}(h``struct dma_buf *dma_buf``h]j)}(hjmh]hstruct dma_buf *dma_buf}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjgubj )}(hhh]h)}(hdma-buf object to importh]hdma-buf object to import}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjgubeh}(h]h ]h"]h$]h&]uh1jhjhMhj+ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hXThis is the implementation of the gem_prime_import functions for GEM drivers using the PRIME helpers. Drivers can use this as their :c:type:`drm_driver.gem_prime_import ` implementation. It is used as the default implementation in drm_gem_prime_fd_to_handle().h](hThis is the implementation of the gem_prime_import functions for GEM drivers using the PRIME helpers. Drivers can use this as their }(hjhhhNhNubh)}(h2:c:type:`drm_driver.gem_prime_import `h]j)}(hjh]hdrm_driver.gem_prime_import}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubhZ implementation. It is used as the default implementation in drm_gem_prime_fd_to_handle().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hDrivers must arrange to call drm_prime_gem_destroy() from their :c:type:`drm_gem_object_funcs.free ` hook when using this function.h](h@Drivers must arrange to call drm_prime_gem_destroy() from their }(hjhhhNhNubh)}(h::c:type:`drm_gem_object_funcs.free `h]j)}(hjh]hdrm_gem_object_funcs.free}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_object_funcsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh hook when using this function.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_prime_sg_to_page_array (C function)c.drm_prime_sg_to_page_arrayhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(h[int drm_prime_sg_to_page_array (struct sg_table *sgt, struct page **pages, int max_entries)h]j>)}(hZint drm_prime_sg_to_page_array(struct sg_table *sgt, struct page **pages, int max_entries)h](j)}(hinth]hint}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj>hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>hhhjPhMubjg)}(hdrm_prime_sg_to_page_arrayh]jm)}(hdrm_prime_sg_to_page_arrayh]hdrm_prime_sg_to_page_array}(hjchhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj>hhhjPhMubj)}(h<(struct sg_table *sgt, struct page **pages, int max_entries)h](j)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjesbc.drm_prime_sg_to_page_arrayasbuh1hhj{ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(hsgth]hsgt}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwubj)}(hstruct page **pagesh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hpageh]hpage}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_prime_sg_to_page_arrayasbuh1hhjubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj;hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubj4)}(hj7h]h*}(hjHhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hpagesh]hpages}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwubj)}(hint max_entriesh](j)}(hinth]hint}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjjubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjubjm)}(h max_entriesh]h max_entries}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwubeh}(h]h ]h"]h$]h&]jjuh1jhj>hhhjPhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj:hhhjPhMubah}(h]j5ah ](jjeh"]h$]h&]jj)jhuh1j7hjPhMhj7hhubj)}(hhh]h)}(h%convert an sg table into a page arrayh]h%convert an sg table into a page array}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj7hhhjPhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hX**Parameters** ``struct sg_table *sgt`` scatter-gather table to convert ``struct page **pages`` array of page pointers to store the pages in ``int max_entries`` size of the passed-in array **Description** Exports an sg table into an array of pages. This function is deprecated and strongly discouraged to be used. The page array is only useful for page faults and those can corrupt fields in the struct page if they are not handled by the exporting driver.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj)}(hhh](j)}(h9``struct sg_table *sgt`` scatter-gather table to convert h](j)}(h``struct sg_table *sgt``h]j)}(hjh]hstruct sg_table *sgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubj )}(hhh]h)}(hscatter-gather table to converth]hscatter-gather table to convert}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hE``struct page **pages`` array of page pointers to store the pages in h](j)}(h``struct page **pages``h]j)}(hj.h]hstruct page **pages}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhj(ubj )}(hhh]h)}(h,array of page pointers to store the pages inh]h,array of page pointers to store the pages in}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjChMhjDubah}(h]h ]h"]h$]h&]uh1j hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChMhjubj)}(h0``int max_entries`` size of the passed-in array h](j)}(h``int max_entries``h]j)}(hjgh]hint max_entries}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjaubj )}(hhh]h)}(hsize of the passed-in arrayh]hsize of the passed-in array}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj|hMhj}ubah}(h]h ]h"]h$]h&]uh1j hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(h+Exports an sg table into an array of pages.h]h+Exports an sg table into an array of pages.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubh)}(hThis function is deprecated and strongly discouraged to be used. The page array is only useful for page faults and those can corrupt fields in the struct page if they are not handled by the exporting driver.h]hThis function is deprecated and strongly discouraged to be used. The page array is only useful for page faults and those can corrupt fields in the struct page if they are not handled by the exporting driver.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.+drm_prime_sg_to_dma_addr_array (C function) c.drm_prime_sg_to_dma_addr_arrayhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(h]int drm_prime_sg_to_dma_addr_array (struct sg_table *sgt, dma_addr_t *addrs, int max_entries)h]j>)}(h\int drm_prime_sg_to_dma_addr_array(struct sg_table *sgt, dma_addr_t *addrs, int max_entries)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM0ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM0ubjg)}(hdrm_prime_sg_to_dma_addr_arrayh]jm)}(hdrm_prime_sg_to_dma_addr_arrayh]hdrm_prime_sg_to_dma_addr_array}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM0ubj)}(h:(struct sg_table *sgt, dma_addr_t *addrs, int max_entries)h](j)}(hstruct sg_table *sgth](jD)}(hjh]hstruct}(hj3hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj/ubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjQhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjSmodnameN classnameNjj)}j]j )}jjsb c.drm_prime_sg_to_dma_addr_arrayasbuh1hhj/ubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj/ubjm)}(hsgth]hsgt}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj+ubj)}(hdma_addr_t *addrsh](h)}(hhh]jm)}(h dma_addr_th]h dma_addr_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jm c.drm_prime_sg_to_dma_addr_arrayasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(haddrsh]haddrs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj+ubj)}(hint max_entriesh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h max_entriesh]h max_entries}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj+ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM0ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM0ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM0hjhhubj)}(hhh]h)}(h)convert an sg table into a dma addr arrayh]h)convert an sg table into a dma addr array}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM0hj=hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM0ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjXjjXjjjuh1j2hhhj1hNhNubj)}(hX|**Parameters** ``struct sg_table *sgt`` scatter-gather table to convert ``dma_addr_t *addrs`` array to store the dma bus address of each page ``int max_entries`` size of both the passed-in arrays **Description** Exports an sg table into an array of addresses. Drivers should use this in their :c:type:`drm_driver.gem_prime_import_sg_table ` implementation.h](h)}(h**Parameters**h]j)}(hjbh]h Parameters}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM4hj\ubj)}(hhh](j)}(h9``struct sg_table *sgt`` scatter-gather table to convert h](j)}(h``struct sg_table *sgt``h]j)}(hjh]hstruct sg_table *sgt}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM1hj{ubj )}(hhh]h)}(hscatter-gather table to converth]hscatter-gather table to convert}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1hjubah}(h]h ]h"]h$]h&]uh1j hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjxubj)}(hF``dma_addr_t *addrs`` array to store the dma bus address of each page h](j)}(h``dma_addr_t *addrs``h]j)}(hjh]hdma_addr_t *addrs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM2hjubj )}(hhh]h)}(h/array to store the dma bus address of each pageh]h/array to store the dma bus address of each page}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hjxubj)}(h6``int max_entries`` size of both the passed-in arrays h](j)}(h``int max_entries``h]j)}(hjh]hint max_entries}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM3hjubj )}(hhh]h)}(h!size of both the passed-in arraysh]h!size of both the passed-in arrays}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM3hj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM3hjxubeh}(h]h ]h"]h$]h&]uh1jhj\ubh)}(h**Description**h]j)}(hj.h]h Description}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM5hj\ubh)}(h/Exports an sg table into an array of addresses.h]h/Exports an sg table into an array of addresses.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM4hj\ubh)}(hlDrivers should use this in their :c:type:`drm_driver.gem_prime_import_sg_table ` implementation.h](h!Drivers should use this in their }(hjShhhNhNubh)}(h;:c:type:`drm_driver.gem_prime_import_sg_table `h]j)}(hj]h]h$drm_driver.gem_prime_import_sg_table}(hj_hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_driveruh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chM6hjSubh implementation.}(hjShhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjzhM6hj\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_prime_gem_destroy (C function)c.drm_prime_gem_destroyhNtauh1j!hj1hhhNhNubj3)}(hhh](j8)}(hLvoid drm_prime_gem_destroy (struct drm_gem_object *obj, struct sg_table *sg)h]j>)}(hKvoid drm_prime_gem_destroy(struct drm_gem_object *obj, struct sg_table *sg)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMJubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMJubjg)}(hdrm_prime_gem_destroyh]jm)}(hdrm_prime_gem_destroyh]hdrm_prime_gem_destroy}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMJubj)}(h1(struct drm_gem_object *obj, struct sg_table *sg)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_prime_gem_destroyasbuh1hhjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj.hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hj;hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct sg_table *sgh](jD)}(hjh]hstruct}(hjThhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjPubjV)}(h h]h }(hjahhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjPubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hjrhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]jc.drm_prime_gem_destroyasbuh1hhjPubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjPubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjPubjm)}(hsgh]hsg}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMJubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMJubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMJhjhhubj)}(hhh]h)}(h.helper to clean up a PRIME-imported GEM objecth]h.helper to clean up a PRIME-imported GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMJhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMJubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj1hNhNubj)}(hXJ**Parameters** ``struct drm_gem_object *obj`` GEM object which was created from a dma-buf ``struct sg_table *sg`` the sg-table which was pinned at import time **Description** This is the cleanup functions which GEM drivers need to call when they use drm_gem_prime_import() or drm_gem_prime_import_dev() to import dma-bufs.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMNhjubj)}(hhh](j)}(hK``struct drm_gem_object *obj`` GEM object which was created from a dma-buf h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMKhjubj )}(hhh]h)}(h+GEM object which was created from a dma-bufh]h+GEM object which was created from a dma-buf}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hMKhj,ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj+hMKhj ubj)}(hE``struct sg_table *sg`` the sg-table which was pinned at import time h](j)}(h``struct sg_table *sg``h]j)}(hjOh]hstruct sg_table *sg}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMLhjIubj )}(hhh]h)}(h,the sg-table which was pinned at import timeh]h,the sg-table which was pinned at import time}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMLhjeubah}(h]h ]h"]h$]h&]uh1j hjIubeh}(h]h ]h"]h$]h&]uh1jhjdhMLhj ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMNhjubh)}(hThis is the cleanup functions which GEM drivers need to call when they use drm_gem_prime_import() or drm_gem_prime_import_dev() to import dma-bufs.h]hThis is the cleanup functions which GEM drivers need to call when they use drm_gem_prime_import() or drm_gem_prime_import_dev() to import dma-bufs.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:459: ./drivers/gpu/drm/drm_prime.chMMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj1hhhNhNubeh}(h]prime-function-referencesah ]h"]prime function referencesah$]h&]uh1hhjԫhhhhhMubeh}(h](j˫id1eh ]h"](prime buffer sharingprime_buffer_sharingeh$]h&]uh1hhhhhhhhMexpect_referenced_by_name}jjsexpect_referenced_by_id}j˫jsubh)}(hhh](h)}(hDRM MM Range Allocatorh]hDRM MM Range Allocator}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(hOverviewh]hOverview}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMubh)}(hXdrm_mm provides a simple range allocator. The drivers are free to use the resource allocator from the linux core if it suits them, the upside of drm_mm is that it's in the DRM core. Which means that it's easier to extend for some of the crazier special purpose needs of gpus.h]hXdrm_mm provides a simple range allocator. The drivers are free to use the resource allocator from the linux core if it suits them, the upside of drm_mm is that it’s in the DRM core. Which means that it’s easier to extend for some of the crazier special purpose needs of gpus.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:468: ./drivers/gpu/drm/drm_mm.chK7hjhhubh)}(hX>The main data struct is :c:type:`drm_mm`, allocations are tracked in :c:type:`drm_mm_node`. Drivers are free to embed either of them into their own suitable datastructures. drm_mm itself will not do any memory allocations of its own, so if drivers choose not to embed nodes they need to still allocate them themselves.h](hThe main data struct is }(hjhhhNhNubh)}(h:c:type:`drm_mm`h]j)}(hjh]hdrm_mm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:468: ./drivers/gpu/drm/drm_mm.chK`.h](hXThe DRM range allocator supports this use-case through the scanning interfaces. First a scan operation needs to be initialized with drm_mm_scan_init() or drm_mm_scan_init_with_range(). The driver adds objects to the roster, probably by walking an LRU list, but this can be freely implemented. Eviction candidates are added using drm_mm_scan_add_block() until a suitable hole is found or there are no further evictable objects. Eviction roster metadata is tracked in }(hjhhhNhNubh)}(h*:c:type:`struct drm_mm_scan `h]j)}(hjh]hstruct drm_mm_scan}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_scanuh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:474: ./drivers/gpu/drm/drm_mm.chMhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjhhubh)}(hThe driver must walk through all objects again in exactly the reverse order to restore the allocator state. Note that while the allocator is used in the scan mode no other operation is allowed.h]hThe driver must walk through all objects again in exactly the reverse order to restore the allocator state. Note that while the allocator is used in the scan mode no other operation is allowed.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:474: ./drivers/gpu/drm/drm_mm.chMhjhhubh)}(hXFinally the driver evicts all objects selected (drm_mm_scan_remove_block() reported true) in the scan, and any overlapping nodes after color adjustment (drm_mm_scan_color_evict()). Adding and removing an object is O(1), and since freeing a node is also O(1) the overall complexity is O(scanned_objects). So like the free stack which needs to be walked before a scan operation even begins this is linear in the number of objects. It doesn't seem to hurt too badly.h]hXFinally the driver evicts all objects selected (drm_mm_scan_remove_block() reported true) in the scan, and any overlapping nodes after color adjustment (drm_mm_scan_color_evict()). Adding and removing an object is O(1), and since freeing a node is also O(1) the overall complexity is O(scanned_objects). So like the free stack which needs to be walked before a scan operation even begins this is linear in the number of objects. It doesn’t seem to hurt too badly.}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:474: ./drivers/gpu/drm/drm_mm.chMhjhhubeh}(h]lru-scan-eviction-supportah ]h"]lru scan/eviction supportah$]h&]uh1hhjhhhhhMubh)}(hhh](h)}(h*DRM MM Range Allocator Function Referencesh]h*DRM MM Range Allocator Function References}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhhhhhMubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_insert_mode (C enum)c.drm_mm_insert_modehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hdrm_mm_insert_modeh]j>)}(henum drm_mm_insert_modeh](jD)}(hjGh]henum}(hjyhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjuhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjuhhhjhKubjg)}(hdrm_mm_insert_modeh]jm)}(hjsh]hdrm_mm_insert_mode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjuhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjqhhhjhKubah}(h]jlah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjnhhubj)}(hhh]h)}(h'control search and allocation behaviourh]h'control search and allocation behaviour}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhK`). ``DRM_MM_INSERT_EVICT`` Search for the most recently evicted hole (within the search range) that fits the desired node. This is appropriate for use immediately after performing an eviction scan (see drm_mm_scan_init()) and removing the selected nodes to form a hole. Allocates the node from the bottom of the found hole. ``DRM_MM_INSERT_ONCE`` Only check the first hole for suitablity and report -ENOSPC immediately otherwise, rather than check every hole until a suitable one is found. Can only be used in conjunction with another search method such as DRM_MM_INSERT_HIGH or DRM_MM_INSERT_LOW. ``DRM_MM_INSERT_HIGHEST`` Only check the highest hole (the hole with the largest address) and insert the node at the top of the hole or report -ENOSPC if unsuitable. Does not search all holes. ``DRM_MM_INSERT_LOWEST`` Only check the lowest hole (the hole with the smallest address) and insert the node at the bottom of the hole or report -ENOSPC if unsuitable. Does not search all holes.h](h)}(h **Constants**h]j)}(hjh]h Constants}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhK@hjubj)}(hhh](j)}(h``DRM_MM_INSERT_BEST`` Search for the smallest hole (within the search range) that fits the desired node. Allocates the node from the bottom of the found hole. h](j)}(h``DRM_MM_INSERT_BEST``h]j)}(hjh]hDRM_MM_INSERT_BEST}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKFhjubj )}(hhh](h)}(hRSearch for the smallest hole (within the search range) that fits the desired node.'h]hRSearch for the smallest hole (within the search range) that fits the desired node.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKChjubh)}(h5Allocates the node from the bottom of the found hole.h]h5Allocates the node from the bottom of the found hole.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKFhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKFhjubj)}(h``DRM_MM_INSERT_LOW`` Search for the lowest hole (address closest to 0, within the search range) that fits the desired node. Allocates the node from the bottom of the found hole. h](j)}(h``DRM_MM_INSERT_LOW``h]j)}(hjDh]hDRM_MM_INSERT_LOW}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKLhj>ubj )}(hhh](h)}(hfSearch for the lowest hole (address closest to 0, within the search range) that fits the desired node.h]hfSearch for the lowest hole (address closest to 0, within the search range) that fits the desired node.}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKIhjZubh)}(h5Allocates the node from the bottom of the found hole.h]h5Allocates the node from the bottom of the found hole.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhKLhjZubeh}(h]h ]h"]h$]h&]uh1j hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhKLhjubj)}(hX0``DRM_MM_INSERT_HIGH`` Search for the highest hole (address closest to U64_MAX, within the search range) that fits the desired node. Allocates the node from the *top* of the found hole. The specified alignment for the node is applied to the base of the node (:c:type:`drm_mm_node.start `). h](j)}(h``DRM_MM_INSERT_HIGH``h]j)}(hjh]hDRM_MM_INSERT_HIGH}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKThjubj )}(hhh](h)}(hmSearch for the highest hole (address closest to U64_MAX, within the search range) that fits the desired node.h]hmSearch for the highest hole (address closest to U64_MAX, within the search range) that fits the desired node.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKOhjubh)}(hAllocates the node from the *top* of the found hole. The specified alignment for the node is applied to the base of the node (:c:type:`drm_mm_node.start `).h](hAllocates the node from the }(hjhhhNhNubhemphasis)}(h*top*h]htop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh] of the found hole. The specified alignment for the node is applied to the base of the node (}(hjhhhNhNubh)}(h):c:type:`drm_mm_node.start `h]j)}(hjh]hdrm_mm_node.start}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKRhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKRhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKThjubj)}(hXB``DRM_MM_INSERT_EVICT`` Search for the most recently evicted hole (within the search range) that fits the desired node. This is appropriate for use immediately after performing an eviction scan (see drm_mm_scan_init()) and removing the selected nodes to form a hole. Allocates the node from the bottom of the found hole. h](j)}(h``DRM_MM_INSERT_EVICT``h]j)}(hj h]hDRM_MM_INSERT_EVICT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhK\hjubj )}(hhh](h)}(hSearch for the most recently evicted hole (within the search range) that fits the desired node. This is appropriate for use immediately after performing an eviction scan (see drm_mm_scan_init()) and removing the selected nodes to form a hole.h]hSearch for the most recently evicted hole (within the search range) that fits the desired node. This is appropriate for use immediately after performing an eviction scan (see drm_mm_scan_init()) and removing the selected nodes to form a hole.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKWhj"ubh)}(h5Allocates the node from the bottom of the found hole.h]h5Allocates the node from the bottom of the found hole.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hK\hj"ubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj!hK\hjubj)}(hX``DRM_MM_INSERT_ONCE`` Only check the first hole for suitablity and report -ENOSPC immediately otherwise, rather than check every hole until a suitable one is found. Can only be used in conjunction with another search method such as DRM_MM_INSERT_HIGH or DRM_MM_INSERT_LOW. h](j)}(h``DRM_MM_INSERT_ONCE``h]j)}(hjTh]hDRM_MM_INSERT_ONCE}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKbhjNubj )}(hhh]h)}(hOnly check the first hole for suitablity and report -ENOSPC immediately otherwise, rather than check every hole until a suitable one is found. Can only be used in conjunction with another search method such as DRM_MM_INSERT_HIGH or DRM_MM_INSERT_LOW.h]hOnly check the first hole for suitablity and report -ENOSPC immediately otherwise, rather than check every hole until a suitable one is found. Can only be used in conjunction with another search method such as DRM_MM_INSERT_HIGH or DRM_MM_INSERT_LOW.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhK_hjjubah}(h]h ]h"]h$]h&]uh1j hjNubeh}(h]h ]h"]h$]h&]uh1jhjihKbhjubj)}(h``DRM_MM_INSERT_HIGHEST`` Only check the highest hole (the hole with the largest address) and insert the node at the top of the hole or report -ENOSPC if unsuitable. Does not search all holes. h](j)}(h``DRM_MM_INSERT_HIGHEST``h]j)}(hjh]hDRM_MM_INSERT_HIGHEST}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKihjubj )}(hhh](h)}(hOnly check the highest hole (the hole with the largest address) and insert the node at the top of the hole or report -ENOSPC if unsuitable.h]hOnly check the highest hole (the hole with the largest address) and insert the node at the top of the hole or report -ENOSPC if unsuitable.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKehjubh)}(hDoes not search all holes.h]hDoes not search all holes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKihjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKihjubj)}(h``DRM_MM_INSERT_LOWEST`` Only check the lowest hole (the hole with the smallest address) and insert the node at the bottom of the hole or report -ENOSPC if unsuitable. Does not search all holes.h](j)}(h``DRM_MM_INSERT_LOWEST``h]j)}(hjh]hDRM_MM_INSERT_LOWEST}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKohjubj )}(hhh](h)}(hOnly check the lowest hole (the hole with the smallest address) and insert the node at the bottom of the hole or report -ENOSPC if unsuitable.h]hOnly check the lowest hole (the hole with the smallest address) and insert the node at the bottom of the hole or report -ENOSPC if unsuitable.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKlhjubh)}(hDoes not search all holes.h]hDoes not search all holes.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKphjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKohjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubh)}(h**Description**h]j)}(hj(h]h Description}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKrhjOhhubh)}(hXThe :c:type:`struct drm_mm ` range manager supports finding a suitable modes using a number of search trees. These trees are oranised by size, by address and in most recent eviction order. This allows the user to find either the smallest hole to reuse, the lowest or highest address to reuse, or simply reuse the most recent eviction that fits. When allocating the :c:type:`drm_mm_node` from within the hole, the :c:type:`drm_mm_insert_mode` also dictate whether to allocate the lowest matching address or the highest.h](hThe }(hj>hhhNhNubh)}(h :c:type:`struct drm_mm `h]j)}(hjHh]h struct drm_mm}(hjJhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhK=hj>ubhXQ range manager supports finding a suitable modes using a number of search trees. These trees are oranised by size, by address and in most recent eviction order. This allows the user to find either the smallest hole to reuse, the lowest or highest address to reuse, or simply reuse the most recent eviction that fits. When allocating the }(hj>hhhNhNubh)}(h:c:type:`drm_mm_node`h]j)}(hjlh]h drm_mm_node}(hjnhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhjehK=hj>ubh from within the hole, the }(hj>hhhNhNubh)}(h:c:type:`drm_mm_insert_mode`h]j)}(hjh]hdrm_mm_insert_mode}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mm_insert_modeuh1hhjehK=hj>ubhM also dictate whether to allocate the lowest matching address or the highest.}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjehK=hjOhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_node (C struct) c.drm_mm_nodehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h drm_mm_nodeh]j>)}(hstruct drm_mm_nodeh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKHubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKHubjg)}(h drm_mm_nodeh]jm)}(hjh]h drm_mm_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKHubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKHubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKHhjhhubj)}(hhh]h)}(h$allocated block in the DRM allocatorh]h$allocated block in the DRM allocator}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKHubeh}(h]h ](jstructeh"]h$]h&]jjjj)jj)jjjuh1j2hhhjOhNhNubj)}(h**Definition**:: struct drm_mm_node { unsigned long color; u64 start; u64 size; }; **Members** ``color`` Opaque driver-private tag. ``start`` Start address of the allocated block. ``size`` Size of the allocated block.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubh:}(hj1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj-ubjT)}(hMstruct drm_mm_node { unsigned long color; u64 start; u64 size; };h]hMstruct drm_mm_node { unsigned long color; u64 start; u64 size; };}hjNsbah}(h]h ]h"]h$]h&]jjuh1jShP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj-ubh)}(h **Members**h]j)}(hj_h]hMembers}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj-ubj)}(hhh](j)}(h%``color`` Opaque driver-private tag. h](j)}(h ``color``h]j)}(hj~h]hcolor}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjxubj )}(hhh]h)}(hOpaque driver-private tag.h]hOpaque driver-private tag.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhKhjuubj)}(h0``start`` Start address of the allocated block. h](j)}(h ``start``h]j)}(hjh]hstart}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubj )}(hhh]h)}(h%Start address of the allocated block.h]h%Start address of the allocated block.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjuubj)}(h%``size`` Size of the allocated block.h](j)}(h``size``h]j)}(hjh]hsize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubj )}(hhh]h)}(hSize of the allocated block.h]hSize of the allocated block.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjuubeh}(h]h ]h"]h$]h&]uh1jhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubh)}(h**Description**h]j)}(hj3h]h Description}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjOhhubh)}(hX:This represents an allocated block in a :c:type:`drm_mm` allocator. Except for pre-reserved nodes inserted using drm_mm_reserve_node() the structure is entirely opaque and should only be accessed through the provided funcions. Since allocation of these nodes is entirely handled by the driver they can be embedded.h](h(This represents an allocated block in a }(hjIhhhNhNubh)}(h:c:type:`drm_mm`h]j)}(hjSh]hdrm_mm}(hjUhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjIubhX allocator. Except for pre-reserved nodes inserted using drm_mm_reserve_node() the structure is entirely opaque and should only be accessed through the provided funcions. Since allocation of these nodes is entirely handled by the driver they can be embedded.}(hjIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjphKhjOhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm (C struct)c.drm_mmhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hdrm_mmh]j>)}(h struct drm_mmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_mmh]jm)}(hjh]hdrm_mm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h DRM allocatorh]h DRM allocator}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hX**Definition**:: struct drm_mm { void (*color_adjust)(const struct drm_mm_node *node, unsigned long color, u64 *start, u64 *end); }; **Members** ``color_adjust`` Optional driver callback to further apply restrictions on a hole. The node argument points at the node containing the hole from which the block would be allocated (see drm_mm_hole_follows() and friends). The other arguments are the size of the block to be allocated. The driver can adjust the start and end as needed to e.g. insert guard pages.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubjT)}(hwstruct drm_mm { void (*color_adjust)(const struct drm_mm_node *node, unsigned long color, u64 *start, u64 *end); };h]hwstruct drm_mm { void (*color_adjust)(const struct drm_mm_node *node, unsigned long color, u64 *start, u64 *end); };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubh)}(h **Members**h]j)}(hj$h]hMembers}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubj)}(hhh]j)}(hXi``color_adjust`` Optional driver callback to further apply restrictions on a hole. The node argument points at the node containing the hole from which the block would be allocated (see drm_mm_hole_follows() and friends). The other arguments are the size of the block to be allocated. The driver can adjust the start and end as needed to e.g. insert guard pages.h](j)}(h``color_adjust``h]j)}(hjCh]h color_adjust}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj=ubj )}(hhh]h)}(hXXOptional driver callback to further apply restrictions on a hole. The node argument points at the node containing the hole from which the block would be allocated (see drm_mm_hole_follows() and friends). The other arguments are the size of the block to be allocated. The driver can adjust the start and end as needed to e.g. insert guard pages.h]hXXOptional driver callback to further apply restrictions on a hole. The node argument points at the node containing the hole from which the block would be allocated (see drm_mm_hole_follows() and friends). The other arguments are the size of the block to be allocated. The driver can adjust the start and end as needed to e.g. insert guard pages.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjYubah}(h]h ]h"]h$]h&]uh1j hj=ubeh}(h]h ]h"]h$]h&]uh1jhjXhKhj:ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjOhhubh)}(hX0DRM range allocator with a few special functions and features geared towards managing GPU memory. Except for the **color_adjust** callback the structure is entirely opaque and should only be accessed through the provided functions and macros. This structure can be embedded into larger driver structures.h](hqDRM range allocator with a few special functions and features geared towards managing GPU memory. Except for the }(hjhhhNhNubj)}(h**color_adjust**h]h color_adjust}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh callback the structure is entirely opaque and should only be accessed through the provided functions and macros. This structure can be embedded into larger driver structures.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjOhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_scan (C struct) c.drm_mm_scanhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h drm_mm_scanh]j>)}(hstruct drm_mm_scanh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(h drm_mm_scanh]jm)}(hjh]h drm_mm_scan}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h#DRM allocator eviction roaster datah]h#DRM allocator eviction roaster data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjj0jj0jjjuh1j2hhhjOhNhNubj)}(h:**Definition**:: struct drm_mm_scan { }; **Members**h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubh:}(hj8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj4ubjT)}(hstruct drm_mm_scan { };h]hstruct drm_mm_scan { };}hjUsbah}(h]h ]h"]h$]h&]jjuh1jShP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj4ubh)}(h **Members**h]j)}(hjfh]hMembers}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhj4ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjOhhubh)}(hXMThis structure tracks data needed for the eviction roaster set up using drm_mm_scan_init(), and used with drm_mm_scan_add_block() and drm_mm_scan_remove_block(). The structure is entirely opaque and should only be accessed through the provided functions and macros. It is meant to be allocated temporarily by the driver on the stack.h]hXMThis structure tracks data needed for the eviction roaster set up using drm_mm_scan_init(), and used with drm_mm_scan_add_block() and drm_mm_scan_remove_block(). The structure is entirely opaque and should only be accessed through the provided functions and macros. It is meant to be allocated temporarily by the driver on the stack.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjOhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_mm_node_allocated (C function)c.drm_mm_node_allocatedhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h;bool drm_mm_node_allocated (const struct drm_mm_node *node)h]j>)}(h:bool drm_mm_node_allocated(const struct drm_mm_node *node)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_mm_node_allocatedh]jm)}(hdrm_mm_node_allocatedh]hdrm_mm_node_allocated}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h (const struct drm_mm_node *node)h]j)}(hconst struct drm_mm_node *nodeh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj'hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj:modnameN classnameNjj)}j]j )}jjsbc.drm_mm_node_allocatedasbuh1hhjubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjfhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnodeh]hnode}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(h"checks whether a node is allocatedh]h"checks whether a node is allocated}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hX/**Parameters** ``const struct drm_mm_node *node`` drm_mm_node to check **Description** Drivers are required to clear a node prior to using it with the drm_mm range manager. Drivers should use this helper for proper encapsulation of drm_mm internals. **Return** True if the **node** is allocated.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubj)}(hhh]j)}(h8``const struct drm_mm_node *node`` drm_mm_node to check h](j)}(h"``const struct drm_mm_node *node``h]j)}(hjh]hconst struct drm_mm_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubj )}(hhh]h)}(hdrm_mm_node to checkh]hdrm_mm_node to check}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubh)}(hUDrivers are required to clear a node prior to using it with the drm_mm range manager.h]hUDrivers are required to clear a node prior to using it with the drm_mm range manager.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubh)}(hLDrivers should use this helper for proper encapsulation of drm_mm internals.h]hLDrivers should use this helper for proper encapsulation of drm_mm internals.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubh)}(h **Return**h]j)}(hjOh]hReturn}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubh)}(h"True if the **node** is allocated.h](h True if the }(hjehhhNhNubj)}(h**node**h]hnode}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubh is allocated.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhKhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_initialized (C function)c.drm_mm_initializedhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h1bool drm_mm_initialized (const struct drm_mm *mm)h]j>)}(h0bool drm_mm_initialized(const struct drm_mm *mm)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_mm_initializedh]jm)}(hdrm_mm_initializedh]hdrm_mm_initialized}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h(const struct drm_mm *mm)h]j)}(hconst struct drm_mm *mmh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_mm_initializedasbuh1hhjubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjIhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmmh]hmm}(hjVhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h*checks whether an allocator is initializedh]h*checks whether an allocator is initialized}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj}hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hX/**Parameters** ``const struct drm_mm *mm`` drm_mm to check **Description** Drivers should clear the struct drm_mm prior to initialisation if they want to use this function. Drivers should use this helper for proper encapsulation of drm_mm internals. **Return** True if the **mm** is initialized.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubj)}(hhh]j)}(h,``const struct drm_mm *mm`` drm_mm to check h](j)}(h``const struct drm_mm *mm``h]j)}(hjh]hconst struct drm_mm *mm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubj )}(hhh]h)}(hdrm_mm to checkh]hdrm_mm to check}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubh)}(haDrivers should clear the struct drm_mm prior to initialisation if they want to use this function.h]haDrivers should clear the struct drm_mm prior to initialisation if they want to use this function.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubh)}(hLDrivers should use this helper for proper encapsulation of drm_mm internals.h]hLDrivers should use this helper for proper encapsulation of drm_mm internals.}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubh)}(h **Return**h]j)}(hj2h]hReturn}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubh)}(h"True if the **mm** is initialized.h](h True if the }(hjHhhhNhNubj)}(h**mm**h]hmm}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubh is initialized.}(hjHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_mm_hole_follows (C function)c.drm_mm_hole_followshNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h9bool drm_mm_hole_follows (const struct drm_mm_node *node)h]j>)}(h8bool drm_mm_hole_follows(const struct drm_mm_node *node)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_mm_hole_followsh]jm)}(hdrm_mm_hole_followsh]hdrm_mm_hole_follows}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h (const struct drm_mm_node *node)h]j)}(hconst struct drm_mm_node *nodeh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_mm_hole_followsasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj,hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnodeh]hnode}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]j|ah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhj~hhubj)}(hhh]h)}(h'checks whether a hole follows this nodeh]h'checks whether a hole follows this node}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj`hhubah}(h]h ]h"]h$]h&]uh1jhj~hhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj{jj{jjjuh1j2hhhjOhNhNubj)}(hXe**Parameters** ``const struct drm_mm_node *node`` drm_mm_node to check **Description** Holes are embedded into the drm_mm using the tail of a drm_mm_node. If you wish to know whether a hole follows this particular node, query this function. See also drm_mm_hole_node_start() and drm_mm_hole_node_end(). **Return** True if a hole follows the **node**.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj)}(hhh]j)}(h8``const struct drm_mm_node *node`` drm_mm_node to check h](j)}(h"``const struct drm_mm_node *node``h]j)}(hjh]hconst struct drm_mm_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(hdrm_mm_node to checkh]hdrm_mm_node to check}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubh)}(hHoles are embedded into the drm_mm using the tail of a drm_mm_node. If you wish to know whether a hole follows this particular node, query this function. See also drm_mm_hole_node_start() and drm_mm_hole_node_end().h]hHoles are embedded into the drm_mm using the tail of a drm_mm_node. If you wish to know whether a hole follows this particular node, query this function. See also drm_mm_hole_node_start() and drm_mm_hole_node_end().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM!hjubh)}(h$True if a hole follows the **node**.h](hTrue if a hole follows the }(hjhhhNhNubj)}(h**node**h]hnode}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_mm_hole_node_start (C function)c.drm_mm_hole_node_starthNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h@u64 drm_mm_hole_node_start (const struct drm_mm_node *hole_node)h]j>)}(h?u64 drm_mm_hole_node_start(const struct drm_mm_node *hole_node)h](h)}(hhh]jm)}(hu64h]hu64}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]j )}jdrm_mm_hole_node_startsbc.drm_mm_hole_node_startasbuh1hhjYhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM0ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjYhhhjhM0ubjg)}(hdrm_mm_hole_node_starth]jm)}(hj~h]hdrm_mm_hole_node_start}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjYhhhjhM0ubj)}(h%(const struct drm_mm_node *hole_node)h]j)}(h#const struct drm_mm_node *hole_nodeh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j|c.drm_mm_hole_node_startasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h hole_nodeh]h hole_node}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjYhhhjhM0ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjUhhhjhM0ubah}(h]jPah ](jjeh"]h$]h&]jj)jhuh1j7hjhM0hjRhhubj)}(hhh]h)}(h1computes the start of the hole following **node**h](h)computes the start of the hole following }(hjKhhhNhNubj)}(h**node**h]hnode}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM0hjHhhubah}(h]h ]h"]h$]h&]uh1jhjRhhhjhM0ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjqjjqjjjuh1j2hhhjOhNhNubj)}(hXq**Parameters** ``const struct drm_mm_node *hole_node`` drm_mm_node which implicitly tracks the following hole **Description** This is useful for driver-specific debug dumpers. Otherwise drivers should not inspect holes themselves. Drivers must check first whether a hole indeed follows by looking at drm_mm_hole_follows() **Return** Start of the subsequent hole.h](h)}(h**Parameters**h]j)}(hj{h]h Parameters}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM4hjuubj)}(hhh]j)}(h_``const struct drm_mm_node *hole_node`` drm_mm_node which implicitly tracks the following hole h](j)}(h'``const struct drm_mm_node *hole_node``h]j)}(hjh]h#const struct drm_mm_node *hole_node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM1hjubj )}(hhh]h)}(h6drm_mm_node which implicitly tracks the following holeh]h6drm_mm_node which implicitly tracks the following hole}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjubah}(h]h ]h"]h$]h&]uh1jhjuubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM3hjuubh)}(hThis is useful for driver-specific debug dumpers. Otherwise drivers should not inspect holes themselves. Drivers must check first whether a hole indeed follows by looking at drm_mm_hole_follows()h]hThis is useful for driver-specific debug dumpers. Otherwise drivers should not inspect holes themselves. Drivers must check first whether a hole indeed follows by looking at drm_mm_hole_follows()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM2hjuubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM6hjuubh)}(hStart of the subsequent hole.h]hStart of the subsequent hole.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM7hjuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_mm_hole_node_end (C function)c.drm_mm_hole_node_endhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h>u64 drm_mm_hole_node_end (const struct drm_mm_node *hole_node)h]j>)}(h=u64 drm_mm_hole_node_end(const struct drm_mm_node *hole_node)h](h)}(hhh]jm)}(hu64h]hu64}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFmodnameN classnameNjj)}j]j )}jdrm_mm_hole_node_endsbc.drm_mm_hole_node_endasbuh1hhj=hhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMFubjV)}(h h]h }(hjfhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=hhhjehMFubjg)}(hdrm_mm_hole_node_endh]jm)}(hjbh]hdrm_mm_hole_node_end}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj=hhhjehMFubj)}(h%(const struct drm_mm_node *hole_node)h]j)}(h#const struct drm_mm_node *hole_nodeh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j`c.drm_mm_hole_node_endasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h hole_nodeh]h hole_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj=hhhjehMFubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj9hhhjehMFubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1j7hjehMFhj6hhubj)}(hhh]h)}(h/computes the end of the hole following **node**h](h'computes the end of the hole following }(hj/hhhNhNubj)}(h**node**h]hnode}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMFhj,hhubah}(h]h ]h"]h$]h&]uh1jhj6hhhjehMFubeh}(h]h ](jfunctioneh"]h$]h&]jjjjUjjUjjjuh1j2hhhjOhNhNubj)}(hXp**Parameters** ``const struct drm_mm_node *hole_node`` drm_mm_node which implicitly tracks the following hole **Description** This is useful for driver-specific debug dumpers. Otherwise drivers should not inspect holes themselves. Drivers must check first whether a hole indeed follows by looking at drm_mm_hole_follows(). **Return** End of the subsequent hole.h](h)}(h**Parameters**h]j)}(hj_h]h Parameters}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMJhjYubj)}(hhh]j)}(h_``const struct drm_mm_node *hole_node`` drm_mm_node which implicitly tracks the following hole h](j)}(h'``const struct drm_mm_node *hole_node``h]j)}(hj~h]h#const struct drm_mm_node *hole_node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMGhjxubj )}(hhh]h)}(h6drm_mm_node which implicitly tracks the following holeh]h6drm_mm_node which implicitly tracks the following hole}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMGhjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMGhjuubah}(h]h ]h"]h$]h&]uh1jhjYubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMIhjYubh)}(hThis is useful for driver-specific debug dumpers. Otherwise drivers should not inspect holes themselves. Drivers must check first whether a hole indeed follows by looking at drm_mm_hole_follows().h]hThis is useful for driver-specific debug dumpers. Otherwise drivers should not inspect holes themselves. Drivers must check first whether a hole indeed follows by looking at drm_mm_hole_follows().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMHhjYubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMLhjYubh)}(hEnd of the subsequent hole.h]hEnd of the subsequent hole.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMMhjYubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_nodes (C macro)c.drm_mm_nodeshNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h drm_mm_nodesh]j>)}(h drm_mm_nodesh]jg)}(h drm_mm_nodesh]jm)}(hjh]h drm_mm_nodes}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj!hhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMVubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj<hMVubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj<hMVhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhj<hMVubeh}(h]h ](jmacroeh"]h$]h&]jjjjUjjUjjjuh1j2hhhjOhNhNubh)}(h``drm_mm_nodes (mm)``h]j)}(hj[h]hdrm_mm_nodes (mm)}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMXhjOhhubj)}(h-list of nodes under the drm_mm range manager h]h)}(h,list of nodes under the drm_mm range managerh]h,list of nodes under the drm_mm range manager}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMVhjqubah}(h]h ]h"]h$]h&]uh1jhjhMVhjOhhubj)}(hXV**Parameters** ``mm`` the struct drm_mm range manager **Description** As the drm_mm range manager hides its node_list deep with its structure, extracting it looks painful and repetitive. This is not expected to be used outside of the drm_mm_for_each_node() macros and similar internal functions. **Return** The node list, may be empty.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMZhjubj)}(hhh]j)}(h'``mm`` the struct drm_mm range manager h](j)}(h``mm``h]j)}(hjh]hmm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMWhjubj )}(hhh]h)}(hthe struct drm_mm range managerh]hthe struct drm_mm range manager}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMWhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMWhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMYhjubh)}(hAs the drm_mm range manager hides its node_list deep with its structure, extracting it looks painful and repetitive. This is not expected to be used outside of the drm_mm_for_each_node() macros and similar internal functions.h]hAs the drm_mm range manager hides its node_list deep with its structure, extracting it looks painful and repetitive. This is not expected to be used outside of the drm_mm_for_each_node() macros and similar internal functions.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMXhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM]hjubh)}(hThe node list, may be empty.h]hThe node list, may be empty.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM^hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_for_each_node (C macro)c.drm_mm_for_each_nodehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hdrm_mm_for_each_nodeh]j>)}(hdrm_mm_for_each_nodeh]jg)}(hdrm_mm_for_each_nodeh]jm)}(hjPh]hdrm_mm_for_each_node}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjRhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMdubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjNhhhjmhMdubah}(h]jIah ](jjeh"]h$]h&]jj)jhuh1j7hjmhMdhjKhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjKhhhjmhMdubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubh)}(h$``drm_mm_for_each_node (entry, mm)``h]j)}(hjh]h drm_mm_for_each_node (entry, mm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMfhjOhhubj)}(h*iterator to walk over all allocated nodes h]h)}(h)iterator to walk over all allocated nodesh]h)iterator to walk over all allocated nodes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMdhjubah}(h]h ]h"]h$]h&]uh1jhjhMdhjOhhubj)}(hX5**Parameters** ``entry`` :c:type:`struct drm_mm_node ` to assign to in each iteration step ``mm`` :c:type:`drm_mm` allocator to walk **Description** This iterator walks over all nodes in the range allocator. It is implemented with list_for_each(), so not save against removal of elements.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhhjubj)}(hhh](j)}(hY``entry`` :c:type:`struct drm_mm_node ` to assign to in each iteration step h](j)}(h ``entry``h]j)}(hjh]hentry}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMehjubj )}(hhh]h)}(hN:c:type:`struct drm_mm_node ` to assign to in each iteration steph](h)}(h*:c:type:`struct drm_mm_node `h]j)}(hjh]hstruct drm_mm_node}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhjhMehjubh$ to assign to in each iteration step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMehjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMehjubj)}(h*``mm`` :c:type:`drm_mm` allocator to walk h](j)}(h``mm``h]j)}(hj8h]hmm}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMfhj2ubj )}(hhh]h)}(h":c:type:`drm_mm` allocator to walkh](h)}(h:c:type:`drm_mm`h]j)}(hjWh]hdrm_mm}(hjYhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhjMhMfhjQubh allocator to walk}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjMhMfhjNubah}(h]h ]h"]h$]h&]uh1j hj2ubeh}(h]h ]h"]h$]h&]uh1jhjMhMfhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.h*hMhhjubh)}(hThis iterator walks over all nodes in the range allocator. It is implemented with list_for_each(), so not save against removal of elements.h]hThis iterator walks over all nodes in the range allocator. It is implemented with list_for_each(), so not save against removal of elements.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMghjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_mm_for_each_node_safe (C macro)c.drm_mm_for_each_node_safehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hdrm_mm_for_each_node_safeh]j>)}(hdrm_mm_for_each_node_safeh]jg)}(hdrm_mm_for_each_node_safeh]jm)}(hjh]hdrm_mm_for_each_node_safe}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMoubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMoubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMohjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhMoubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubh)}(h/``drm_mm_for_each_node_safe (entry, next, mm)``h]j)}(hj h]h+drm_mm_for_each_node_safe (entry, next, mm)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMqhjOhhubj)}(h*iterator to walk over all allocated nodes h]h)}(h)iterator to walk over all allocated nodesh]h)iterator to walk over all allocated nodes}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMohj#ubah}(h]h ]h"]h$]h&]uh1jhj5hMohjOhhubj)}(hX**Parameters** ``entry`` :c:type:`struct drm_mm_node ` to assign to in each iteration step ``next`` :c:type:`struct drm_mm_node ` to store the next step ``mm`` :c:type:`drm_mm` allocator to walk **Description** This iterator walks over all nodes in the range allocator. It is implemented with list_for_each_safe(), so save against removal of elements.h](h)}(h**Parameters**h]j)}(hjBh]h Parameters}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMshj<ubj)}(hhh](j)}(hY``entry`` :c:type:`struct drm_mm_node ` to assign to in each iteration step h](j)}(h ``entry``h]j)}(hjah]hentry}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMphj[ubj )}(hhh]h)}(hN:c:type:`struct drm_mm_node ` to assign to in each iteration steph](h)}(h*:c:type:`struct drm_mm_node `h]j)}(hjh]hstruct drm_mm_node}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhjvhMphjzubh$ to assign to in each iteration step}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjvhMphjwubah}(h]h ]h"]h$]h&]uh1j hj[ubeh}(h]h ]h"]h$]h&]uh1jhjvhMphjXubj)}(hK``next`` :c:type:`struct drm_mm_node ` to store the next step h](j)}(h``next``h]j)}(hjh]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMqhjubj )}(hhh]h)}(hA:c:type:`struct drm_mm_node ` to store the next steph](h)}(h*:c:type:`struct drm_mm_node `h]j)}(hjh]hstruct drm_mm_node}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhjhMqhjubh to store the next step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMqhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMqhjXubj)}(h*``mm`` :c:type:`drm_mm` allocator to walk h](j)}(h``mm``h]j)}(hjh]hmm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMrhj ubj )}(hhh]h)}(h":c:type:`drm_mm` allocator to walkh](h)}(h:c:type:`drm_mm`h]j)}(hj0h]hdrm_mm}(hj2hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhj&hMrhj*ubh allocator to walk}(hj*hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj&hMrhj'ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hMrhjXubeh}(h]h ]h"]h$]h&]uh1jhj<ubh)}(h**Description**h]j)}(hjkh]h Description}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMthj<ubh)}(hThis iterator walks over all nodes in the range allocator. It is implemented with list_for_each_safe(), so save against removal of elements.h]hThis iterator walks over all nodes in the range allocator. It is implemented with list_for_each_safe(), so save against removal of elements.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMshj<ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_for_each_hole (C macro)c.drm_mm_for_each_holehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hdrm_mm_for_each_holeh]j>)}(hdrm_mm_for_each_holeh]jg)}(hdrm_mm_for_each_holeh]jm)}(hjh]hdrm_mm_for_each_hole}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM{ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM{ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM{hjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhM{ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubh)}(h8``drm_mm_for_each_hole (pos, mm, hole_start, hole_end)``h]j)}(hjh]h4drm_mm_for_each_hole (pos, mm, hole_start, hole_end)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM}hjOhhubj)}(h iterator to walk over all holes h]h)}(hiterator to walk over all holesh]hiterator to walk over all holes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM{hjubah}(h]h ]h"]h$]h&]uh1jhjhM{hjOhhubj)}(hX**Parameters** ``pos`` :c:type:`drm_mm_node` used internally to track progress ``mm`` :c:type:`drm_mm` allocator to walk ``hole_start`` ulong variable to assign the hole start to on each iteration ``hole_end`` ulong variable to assign the hole end to on each iteration **Description** This iterator walks over all holes in the range allocator. It is implemented with list_for_each(), so not save against removal of elements. **entry** is used internally and will not reflect a real drm_mm_node for the very first hole. Hence users of this iterator may not access it. Implementation Note: We need to inline list_for_each_entry in order to be able to set hole_start and hole_end on each iteration while keeping the macro sane.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj)}(hhh](j)}(h@``pos`` :c:type:`drm_mm_node` used internally to track progress h](j)}(h``pos``h]j)}(hj:h]hpos}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM|hj4ubj )}(hhh]h)}(h7:c:type:`drm_mm_node` used internally to track progressh](h)}(h:c:type:`drm_mm_node`h]j)}(hjYh]h drm_mm_node}(hj[hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhjOhM|hjSubh" used internally to track progress}(hjShhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjOhM|hjPubah}(h]h ]h"]h$]h&]uh1j hj4ubeh}(h]h ]h"]h$]h&]uh1jhjOhM|hj1ubj)}(h*``mm`` :c:type:`drm_mm` allocator to walk h](j)}(h``mm``h]j)}(hjh]hmm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM}hjubj )}(hhh]h)}(h":c:type:`drm_mm` allocator to walkh](h)}(h:c:type:`drm_mm`h]j)}(hjh]hdrm_mm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhjhM}hjubh allocator to walk}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM}hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM}hj1ubj)}(hL``hole_start`` ulong variable to assign the hole start to on each iteration h](j)}(h``hole_start``h]j)}(hjh]h hole_start}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM~hjubj )}(hhh]h)}(h)}(hint drm_mm_insert_node_generic(struct drm_mm *mm, struct drm_mm_node *node, u64 size, u64 alignment, unsigned long color, enum drm_mm_insert_mode mode)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_mm_insert_node_generich]jm)}(hdrm_mm_insert_node_generich]hdrm_mm_insert_node_generic}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hy(struct drm_mm *mm, struct drm_mm_node *node, u64 size, u64 alignment, unsigned long color, enum drm_mm_insert_mode mode)h](j)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]j )}jjsbc.drm_mm_insert_node_genericasbuh1hhjubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjMhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmmh]hmm}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_mm_node *nodeh](jD)}(hjh]hstruct}(hjshhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjoubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j;c.drm_mm_insert_node_genericasbuh1hhjoubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjoubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j;c.drm_mm_insert_node_genericasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hsizeh]hsize}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 alignmenth](h)}(hhh]jm)}(hu64h]hu64}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j;c.drm_mm_insert_node_genericasbuh1hhj'ubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj'ubjm)}(h alignmenth]h alignment}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj'ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long colorh](j)}(hunsignedh]hunsigned}(hjshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjoubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubjm)}(hcolorh]hcolor}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum drm_mm_insert_mode modeh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_mm_insert_modeh]hdrm_mm_insert_mode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j;c.drm_mm_insert_node_genericasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hmodeh]hmode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h$search for space and insert **node**h](hsearch for space and insert }(hj8hhhNhNubj)}(h**node**h]hnode}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj5hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1j2hhhjOhNhNubj)}(hXF**Parameters** ``struct drm_mm *mm`` drm_mm to allocate from ``struct drm_mm_node *node`` preallocate node to insert ``u64 size`` size of the allocation ``u64 alignment`` alignment of the allocation ``unsigned long color`` opaque tag value to use for this node ``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement **Description** This is a simplified version of drm_mm_insert_node_in_range() with no range restrictions applied. The preallocated node must be cleared to 0. **Return** 0 on success, -ENOSPC if there's no suitable hole.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjbubj)}(hhh](j)}(h.``struct drm_mm *mm`` drm_mm to allocate from h](j)}(h``struct drm_mm *mm``h]j)}(hjh]hstruct drm_mm *mm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(hdrm_mm to allocate fromh]hdrm_mm to allocate from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubj)}(h8``struct drm_mm_node *node`` preallocate node to insert h](j)}(h``struct drm_mm_node *node``h]j)}(hjh]hstruct drm_mm_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(hpreallocate node to inserth]hpreallocate node to insert}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubj)}(h$``u64 size`` size of the allocation h](j)}(h ``u64 size``h]j)}(hjh]hu64 size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(hsize of the allocationh]hsize of the allocation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubj)}(h.``u64 alignment`` alignment of the allocation h](j)}(h``u64 alignment``h]j)}(hj2h]h u64 alignment}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj,ubj )}(hhh]h)}(halignment of the allocationh]halignment of the allocation}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhMhjHubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhMhj~ubj)}(h>``unsigned long color`` opaque tag value to use for this node h](j)}(h``unsigned long color``h]j)}(hjkh]hunsigned long color}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjeubj )}(hhh]h)}(h%opaque tag value to use for this nodeh]h%opaque tag value to use for this node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubj)}(hO``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement h](j)}(h ``enum drm_mm_insert_mode mode``h]j)}(hjh]henum drm_mm_insert_mode mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(h-fine-tune the allocation search and placementh]h-fine-tune the allocation search and placement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj~ubeh}(h]h ]h"]h$]h&]uh1jhjbubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjbubh)}(haThis is a simplified version of drm_mm_insert_node_in_range() with no range restrictions applied.h]haThis is a simplified version of drm_mm_insert_node_in_range() with no range restrictions applied.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjbubh)}(h+The preallocated node must be cleared to 0.h]h+The preallocated node must be cleared to 0.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjbubh)}(h **Return**h]j)}(hj h]hReturn}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjbubh)}(h20 on success, -ENOSPC if there's no suitable hole.h]h40 on success, -ENOSPC if there’s no suitable hole.}(hj+ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_insert_node (C function)c.drm_mm_insert_nodehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hNint drm_mm_insert_node (struct drm_mm *mm, struct drm_mm_node *node, u64 size)h]j>)}(hMint drm_mm_insert_node(struct drm_mm *mm, struct drm_mm_node *node, u64 size)h](j)}(hinth]hint}(hjZ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjV hhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubjV)}(h h]h }(hji hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjV hhhjh hMubjg)}(hdrm_mm_insert_nodeh]jm)}(hdrm_mm_insert_nodeh]hdrm_mm_insert_node}(hj{ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjw ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjV hhhjh hMubj)}(h7(struct drm_mm *mm, struct drm_mm_node *node, u64 size)h](j)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jj} sbc.drm_mm_insert_nodeasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hmmh]hmm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct drm_mm_node *nodeh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hj' hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj) modnameN classnameNjj)}j]j c.drm_mm_insert_nodeasbuh1hhj ubjV)}(h h]h }(hjE hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjS hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hnodeh]hnode}(hj` hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hj| hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjy ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~ modnameN classnameNjj)}j]j c.drm_mm_insert_nodeasbuh1hhju ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhju ubjm)}(hsizeh]hsize}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhju ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjV hhhjh hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjR hhhjh hMubah}(h]jM ah ](jjeh"]h$]h&]jj)jhuh1j7hjh hMhjO hhubj)}(hhh]h)}(h$search for space and insert **node**h](hsearch for space and insert }(hj hhhNhNubj)}(h**node**h]hnode}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj hhubah}(h]h ]h"]h$]h&]uh1jhjO hhhjh hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhjOhNhNubj)}(hXv**Parameters** ``struct drm_mm *mm`` drm_mm to allocate from ``struct drm_mm_node *node`` preallocate node to insert ``u64 size`` size of the allocation **Description** This is a simplified version of drm_mm_insert_node_generic() with **color** set to 0. The preallocated node must be cleared to 0. **Return** 0 on success, -ENOSPC if there's no suitable hole.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubj)}(hhh](j)}(h.``struct drm_mm *mm`` drm_mm to allocate from h](j)}(h``struct drm_mm *mm``h]j)}(hj! h]hstruct drm_mm *mm}(hj# hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubj )}(hhh]h)}(hdrm_mm to allocate fromh]hdrm_mm to allocate from}(hj: hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj6 hMhj7 ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj6 hMhj ubj)}(h8``struct drm_mm_node *node`` preallocate node to insert h](j)}(h``struct drm_mm_node *node``h]j)}(hjZ h]hstruct drm_mm_node *node}(hj\ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjX ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjT ubj )}(hhh]h)}(hpreallocate node to inserth]hpreallocate node to insert}(hjs hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjo hMhjp ubah}(h]h ]h"]h$]h&]uh1j hjT ubeh}(h]h ]h"]h$]h&]uh1jhjo hMhj ubj)}(h$``u64 size`` size of the allocation h](j)}(h ``u64 size``h]j)}(hj h]hu64 size}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubj )}(hhh]h)}(hsize of the allocationh]hsize of the allocation}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhj ubeh}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubh)}(hUThis is a simplified version of drm_mm_insert_node_generic() with **color** set to 0.h](hBThis is a simplified version of drm_mm_insert_node_generic() with }(hj hhhNhNubj)}(h **color**h]hcolor}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh set to 0.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubh)}(h+The preallocated node must be cleared to 0.h]h+The preallocated node must be cleared to 0.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubh)}(h **Return**h]j)}(hj h]hReturn}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubh)}(h20 on success, -ENOSPC if there's no suitable hole.h]h40 on success, -ENOSPC if there’s no suitable hole.}(hj, hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_clean (C function)c.drm_mm_cleanhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h+bool drm_mm_clean (const struct drm_mm *mm)h]j>)}(h*bool drm_mm_clean(const struct drm_mm *mm)h](j)}(hj*h]hbool}(hj[ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjW hhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubjV)}(h h]h }(hji hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjW hhhjh hMubjg)}(h drm_mm_cleanh]jm)}(h drm_mm_cleanh]h drm_mm_clean}(hj{ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjw ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjW hhhjh hMubj)}(h(const struct drm_mm *mm)h]j)}(hconst struct drm_mm *mmh](jD)}(hj h]hconst}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jj} sbc.drm_mm_cleanasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hmmh]hmm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhjW hhhjh hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjS hhhjh hMubah}(h]jN ah ](jjeh"]h$]h&]jj)jhuh1j7hjh hMhjP hhubj)}(hhh]h)}(h$checks whether an allocator is cleanh]h$checks whether an allocator is clean}(hj5 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj2 hhubah}(h]h ]h"]h$]h&]uh1jhjP hhhjh hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjM jjM jjjuh1j2hhhjOhNhNubj)}(h**Parameters** ``const struct drm_mm *mm`` drm_mm allocator to check **Return** True if the allocator is completely free, false if there's still a node allocated in it.h](h)}(h**Parameters**h]j)}(hjW h]h Parameters}(hjY hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjU ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjQ ubj)}(hhh]j)}(h6``const struct drm_mm *mm`` drm_mm allocator to check h](j)}(h``const struct drm_mm *mm``h]j)}(hjv h]hconst struct drm_mm *mm}(hjx hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjt ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjp ubj )}(hhh]h)}(hdrm_mm allocator to checkh]hdrm_mm allocator to check}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjp ubeh}(h]h ]h"]h$]h&]uh1jhj hMhjm ubah}(h]h ]h"]h$]h&]uh1jhjQ ubh)}(h **Return**h]j)}(hj h]hReturn}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjQ ubh)}(hXTrue if the allocator is completely free, false if there's still a node allocated in it.h]hZTrue if the allocator is completely free, false if there’s still a node allocated in it.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjQ ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_mm_for_each_node_in_range (C macro)c.drm_mm_for_each_node_in_rangehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hdrm_mm_for_each_node_in_rangeh]j>)}(hdrm_mm_for_each_node_in_rangeh]jg)}(hdrm_mm_for_each_node_in_rangeh]jm)}(hj h]hdrm_mm_for_each_node_in_range}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hMubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj hMhj hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj hhhj hMubeh}(h]h ](jmacroeh"]h$]h&]jjjj&jj&jjjuh1j2hhhjOhNhNubh)}(h@``drm_mm_for_each_node_in_range (node__, mm__, start__, end__)``h]j)}(hj,h]h`, and may even continue indefinitely.h](h)}(h**Parameters**h]j)}(hjah]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj[ubj)}(hhh](j)}(hE``node__`` drm_mm_node structure to assign to in each iteration step h](j)}(h ``node__``h]j)}(hjh]hnode__}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjzubj )}(hhh]h)}(h9drm_mm_node structure to assign to in each iteration steph]h9drm_mm_node structure to assign to in each iteration step}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjhMhjwubj)}(h"``mm__`` drm_mm allocator to walk h](j)}(h``mm__``h]j)}(hjh]hmm__}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(hdrm_mm allocator to walkh]hdrm_mm allocator to walk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjwubj)}(h>``start__`` starting offset, the first node will overlap this h](j)}(h ``start__``h]j)}(hjh]hstart__}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(h1starting offset, the first node will overlap thish]h1starting offset, the first node will overlap this}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjwubj)}(hP``end__`` ending offset, the last node will start before this (but may overlap) h](j)}(h ``end__``h]j)}(hj+h]hend__}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj%ubj )}(hhh]h)}(hEending offset, the last node will start before this (but may overlap)h]hEending offset, the last node will start before this (but may overlap)}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hMhjAubah}(h]h ]h"]h$]h&]uh1j hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhjwubeh}(h]h ]h"]h$]h&]uh1jhj[ubh)}(h**Description**h]j)}(hjfh]h Description}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj[ubh)}(hX This iterator walks over all nodes in the range allocator that lie between **start** and **end**. It is implemented similarly to list_for_each(), but using the internal interval tree to accelerate the search for the starting node, and so not safe against removal of elements. It assumes that **end** is within (or is the upper limit of) the drm_mm allocator. If [**start**, **end**] are beyond the range of the drm_mm, the iterator may walk over the special _unallocated_ :c:type:`drm_mm.head_node `, and may even continue indefinitely.h](hKThis iterator walks over all nodes in the range allocator that lie between }(hj|hhhNhNubj)}(h **start**h]hstart}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh and }(hj|hhhNhNubj)}(h**end**h]hend}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh. It is implemented similarly to list_for_each(), but using the internal interval tree to accelerate the search for the starting node, and so not safe against removal of elements. It assumes that }(hj|hhhNhNubj)}(h**end**h]hend}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh@ is within (or is the upper limit of) the drm_mm allocator. If [}(hj|hhhNhNubj)}(h **start**h]hstart}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh, }(hj|hhhNhNubj)}(h**end**h]hend}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh[] are beyond the range of the drm_mm, the iterator may walk over the special _unallocated_ }(hj|hhhNhNubh)}(h#:c:type:`drm_mm.head_node `h]j)}(hjh]hdrm_mm.head_node}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_mmuh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhj|ubh%, and may even continue indefinitely.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj[ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_scan_init (C function)c.drm_mm_scan_inithNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hvoid drm_mm_scan_init (struct drm_mm_scan *scan, struct drm_mm *mm, u64 size, u64 alignment, unsigned long color, enum drm_mm_insert_mode mode)h]j>)}(hvoid drm_mm_scan_init(struct drm_mm_scan *scan, struct drm_mm *mm, u64 size, u64 alignment, unsigned long color, enum drm_mm_insert_mode mode)h](j)}(hvoidh]hvoid}(hj(hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$hhhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMubjV)}(h h]h }(hj7hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$hhhj6hMubjg)}(hdrm_mm_scan_inith]jm)}(hdrm_mm_scan_inith]hdrm_mm_scan_init}(hjIhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj$hhhj6hMubj)}(hy(struct drm_mm_scan *scan, struct drm_mm *mm, u64 size, u64 alignment, unsigned long color, enum drm_mm_insert_mode mode)h](j)}(hstruct drm_mm_scan *scanh](jD)}(hjh]hstruct}(hjehhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjaubjV)}(h h]h }(hjrhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubh)}(hhh]jm)}(h drm_mm_scanh]h drm_mm_scan}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjKsbc.drm_mm_scan_initasbuh1hhjaubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjaubjm)}(hscanh]hscan}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_scan_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj!hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmmh]hmm}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjJhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjGubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjLmodnameN classnameNjj)}j]jc.drm_mm_scan_initasbuh1hhjCubjV)}(h h]h }(hjhhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubjm)}(hsizeh]hsize}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(h u64 alignmenth](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_scan_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h alignmenth]h alignment}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(hunsigned long colorh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hcolorh]hcolor}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubj)}(henum drm_mm_insert_mode modeh](jD)}(hjGh]henum}(hj(hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubh)}(hhh]jm)}(hdrm_mm_insert_modeh]hdrm_mm_insert_mode}(hjFhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjHmodnameN classnameNjj)}j]jc.drm_mm_scan_initasbuh1hhj$ubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubjm)}(hmodeh]hmode}(hjrhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj]ubeh}(h]h ]h"]h$]h&]jjuh1jhj$hhhj6hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj6hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj6hMhjhhubj)}(hhh]h)}(hinitialize lru scanningh]hinitialize lru scanning}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj6hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hX**Parameters** ``struct drm_mm_scan *scan`` scan state ``struct drm_mm *mm`` drm_mm to scan ``u64 size`` size of the allocation ``u64 alignment`` alignment of the allocation ``unsigned long color`` opaque tag value to use for the allocation ``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement **Description** This is a simplified version of drm_mm_scan_init_with_range() with no range restrictions applied. This simply sets up the scanning routines with the parameters for the desired hole. Warning: As long as the scan list is non-empty, no other operations than adding/removing nodes to/from the scan list are allowed.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj)}(hhh](j)}(h(``struct drm_mm_scan *scan`` scan state h](j)}(h``struct drm_mm_scan *scan``h]j)}(hjh]hstruct drm_mm_scan *scan}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(h scan stateh]h scan state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h%``struct drm_mm *mm`` drm_mm to scan h](j)}(h``struct drm_mm *mm``h]j)}(hjh]hstruct drm_mm *mm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(hdrm_mm to scanh]hdrm_mm to scan}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hMhj,ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj+hMhjubj)}(h$``u64 size`` size of the allocation h](j)}(h ``u64 size``h]j)}(hjOh]hu64 size}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjIubj )}(hhh]h)}(hsize of the allocationh]hsize of the allocation}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdhMhjeubah}(h]h ]h"]h$]h&]uh1j hjIubeh}(h]h ]h"]h$]h&]uh1jhjdhMhjubj)}(h.``u64 alignment`` alignment of the allocation h](j)}(h``u64 alignment``h]j)}(hjh]h u64 alignment}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(halignment of the allocationh]halignment of the allocation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hC``unsigned long color`` opaque tag value to use for the allocation h](j)}(h``unsigned long color``h]j)}(hjh]hunsigned long color}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(h*opaque tag value to use for the allocationh]h*opaque tag value to use for the allocation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hO``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement h](j)}(h ``enum drm_mm_insert_mode mode``h]j)}(hjh]henum drm_mm_insert_mode mode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubj )}(hhh]h)}(h-fine-tune the allocation search and placementh]h-fine-tune the allocation search and placement}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj5h]h Description}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubh)}(haThis is a simplified version of drm_mm_scan_init_with_range() with no range restrictions applied.h]haThis is a simplified version of drm_mm_scan_init_with_range() with no range restrictions applied.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubh)}(hSThis simply sets up the scanning routines with the parameters for the desired hole.h]hSThis simply sets up the scanning routines with the parameters for the desired hole.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhM hjubh)}(hWarning: As long as the scan list is non-empty, no other operations than adding/removing nodes to/from the scan list are allowed.h]hWarning: As long as the scan list is non-empty, no other operations than adding/removing nodes to/from the scan list are allowed.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhP/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:480: ./include/drm/drm_mm.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_mm_reserve_node (C function)c.drm_mm_reserve_nodehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hEint drm_mm_reserve_node (struct drm_mm *mm, struct drm_mm_node *node)h]j>)}(hDint drm_mm_reserve_node(struct drm_mm *mm, struct drm_mm_node *node)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_mm_reserve_nodeh]jm)}(hdrm_mm_reserve_nodeh]hdrm_mm_reserve_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h-(struct drm_mm *mm, struct drm_mm_node *node)h](j)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_mm_reserve_nodeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj!hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hmmh]hmm}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_mm_node *nodeh](jD)}(hjh]hstruct}(hjGhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjCubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]jc.drm_mm_reserve_nodeasbuh1hhjCubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjCubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hinsert an pre-initialized nodeh]hinsert an pre-initialized node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hXK**Parameters** ``struct drm_mm *mm`` drm_mm allocator to insert **node** into ``struct drm_mm_node *node`` drm_mm_node to insert **Description** This functions inserts an already set-up :c:type:`drm_mm_node` into the allocator, meaning that start, size and color must be set by the caller. All other fields must be cleared to 0. This is useful to initialize the allocator with preallocated objects which must be set-up before the range allocator can be set-up, e.g. when taking over a firmware framebuffer. **Return** 0 on success, -ENOSPC if there's no hole where **node** is.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj)}(hhh](j)}(h?``struct drm_mm *mm`` drm_mm allocator to insert **node** into h](j)}(h``struct drm_mm *mm``h]j)}(hj h]hstruct drm_mm *mm}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj )}(hhh]h)}(h(drm_mm allocator to insert **node** intoh](hdrm_mm allocator to insert }(hj"hhhNhNubj)}(h**node**h]hnode}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubh into}(hj"hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h3``struct drm_mm_node *node`` drm_mm_node to insert h](j)}(h``struct drm_mm_node *node``h]j)}(hjTh]hstruct drm_mm_node *node}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjNubj )}(hhh]h)}(hdrm_mm_node to inserth]hdrm_mm_node to insert}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjihMhjjubah}(h]h ]h"]h$]h&]uh1j hjNubeh}(h]h ]h"]h$]h&]uh1jhjihMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubh)}(hXiThis functions inserts an already set-up :c:type:`drm_mm_node` into the allocator, meaning that start, size and color must be set by the caller. All other fields must be cleared to 0. This is useful to initialize the allocator with preallocated objects which must be set-up before the range allocator can be set-up, e.g. when taking over a firmware framebuffer.h](h)This functions inserts an already set-up }(hjhhhNhNubh)}(h:c:type:`drm_mm_node`h]j)}(hjh]h drm_mm_node}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_mm_nodeuh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubhX+ into the allocator, meaning that start, size and color must be set by the caller. All other fields must be cleared to 0. This is useful to initialize the allocator with preallocated objects which must be set-up before the range allocator can be set-up, e.g. when taking over a firmware framebuffer.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubh)}(h;0 on success, -ENOSPC if there's no hole where **node** is.h](h10 on success, -ENOSPC if there’s no hole where }(hjhhhNhNubj)}(h**node**h]hnode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_mm_insert_node_in_range (C function)c.drm_mm_insert_node_in_rangehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hint drm_mm_insert_node_in_range (struct drm_mm * const mm, struct drm_mm_node * const node, u64 size, u64 alignment, unsigned long color, u64 range_start, u64 range_end, enum drm_mm_insert_mode mode)h]j>)}(hint drm_mm_insert_node_in_range(struct drm_mm *const mm, struct drm_mm_node *const node, u64 size, u64 alignment, unsigned long color, u64 range_start, u64 range_end, enum drm_mm_insert_mode mode)h](j)}(hinth]hint}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj,hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,hhhj>hMubjg)}(hdrm_mm_insert_node_in_rangeh]jm)}(hdrm_mm_insert_node_in_rangeh]hdrm_mm_insert_node_in_range}(hjQhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj,hhhj>hMubj)}(h(struct drm_mm *const mm, struct drm_mm_node *const node, u64 size, u64 alignment, unsigned long color, u64 range_start, u64 range_end, enum drm_mm_insert_mode mode)h](j)}(hstruct drm_mm *const mmh](jD)}(hjh]hstruct}(hjmhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjiubjV)}(h h]h }(hjzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjSsbc.drm_mm_insert_node_in_rangeasbuh1hhjiubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjiubjD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjiubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjiubjm)}(hmmh]hmm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjiubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hstruct drm_mm_node *const nodeh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_insert_node_in_rangeasbuh1hhjubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjDhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjD)}(hj h]hconst}(hjQhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj^hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hnodeh]hnode}(hjlhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_insert_node_in_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hsizeh]hsize}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(h u64 alignmenth](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_insert_node_in_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h alignmenth]h alignment}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hunsigned long colorh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hj1hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hcolorh]hcolor}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(hu64 range_starth](h)}(hhh]jm)}(hu64h]hu64}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjfubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjkmodnameN classnameNjj)}j]jc.drm_mm_insert_node_in_rangeasbuh1hhjbubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbubjm)}(h range_starth]h range_start}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(h u64 range_endh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_insert_node_in_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h range_endh]h range_end}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubj)}(henum drm_mm_insert_mode modeh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_mm_insert_modeh]hdrm_mm_insert_mode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_insert_node_in_rangeasbuh1hhjubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hmodeh]hmode}(hj@hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjeubeh}(h]h ]h"]h$]h&]jjuh1jhj,hhhj>hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj(hhhj>hMubah}(h]j#ah ](jjeh"]h$]h&]jj)jhuh1j7hj>hMhj%hhubj)}(hhh]h)}(h+ranged search for space and insert **node**h](h#ranged search for space and insert }(hjjhhhNhNubj)}(h**node**h]hnode}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjghhubah}(h]h ]h"]h$]h&]uh1jhj%hhhj>hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hXq**Parameters** ``struct drm_mm * const mm`` drm_mm to allocate from ``struct drm_mm_node * const node`` preallocate node to insert ``u64 size`` size of the allocation ``u64 alignment`` alignment of the allocation ``unsigned long color`` opaque tag value to use for this node ``u64 range_start`` start of the allowed range for this node ``u64 range_end`` end of the allowed range for this node ``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement **Description** The preallocated **node** must be cleared to 0. **Return** 0 on success, -ENOSPC if there's no suitable hole.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj)}(hhh](j)}(h5``struct drm_mm * const mm`` drm_mm to allocate from h](j)}(h``struct drm_mm * const mm``h]j)}(hjh]hstruct drm_mm * const mm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj )}(hhh]h)}(hdrm_mm to allocate fromh]hdrm_mm to allocate from}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h?``struct drm_mm_node * const node`` preallocate node to insert h](j)}(h#``struct drm_mm_node * const node``h]j)}(hjh]hstruct drm_mm_node * const node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj )}(hhh]h)}(hpreallocate node to inserth]hpreallocate node to insert}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h$``u64 size`` size of the allocation h](j)}(h ``u64 size``h]j)}(hj+h]hu64 size}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj%ubj )}(hhh]h)}(hsize of the allocationh]hsize of the allocation}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hMhjAubah}(h]h ]h"]h$]h&]uh1j hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMhjubj)}(h.``u64 alignment`` alignment of the allocation h](j)}(h``u64 alignment``h]j)}(hjdh]h u64 alignment}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj^ubj )}(hhh]h)}(halignment of the allocationh]halignment of the allocation}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMhjzubah}(h]h ]h"]h$]h&]uh1j hj^ubeh}(h]h ]h"]h$]h&]uh1jhjyhMhjubj)}(h>``unsigned long color`` opaque tag value to use for this node h](j)}(h``unsigned long color``h]j)}(hjh]hunsigned long color}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj )}(hhh]h)}(h%opaque tag value to use for this nodeh]h%opaque tag value to use for this node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h=``u64 range_start`` start of the allowed range for this node h](j)}(h``u64 range_start``h]j)}(hjh]hu64 range_start}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubj )}(hhh]h)}(h(start of the allowed range for this nodeh]h(start of the allowed range for this node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h9``u64 range_end`` end of the allowed range for this node h](j)}(h``u64 range_end``h]j)}(hjh]h u64 range_end}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj ubj )}(hhh]h)}(h&end of the allowed range for this nodeh]h&end of the allowed range for this node}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$hMhj%ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hMhjubj)}(hO``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement h](j)}(h ``enum drm_mm_insert_mode mode``h]j)}(hjHh]henum drm_mm_insert_mode mode}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjBubj )}(hhh]h)}(h-fine-tune the allocation search and placementh]h-fine-tune the allocation search and placement}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hMhj^ubah}(h]h ]h"]h$]h&]uh1j hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubh)}(h/The preallocated **node** must be cleared to 0.h](hThe preallocated }(hjhhhNhNubj)}(h**node**h]hnode}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh must be cleared to 0.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubh)}(h20 on success, -ENOSPC if there's no suitable hole.h]h40 on success, -ENOSPC if there’s no suitable hole.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_remove_node (C function)c.drm_mm_remove_nodehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h2void drm_mm_remove_node (struct drm_mm_node *node)h]j>)}(h1void drm_mm_remove_node(struct drm_mm_node *node)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMmubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMmubjg)}(hdrm_mm_remove_nodeh]jm)}(hdrm_mm_remove_nodeh]hdrm_mm_remove_node}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMmubj)}(h(struct drm_mm_node *node)h]j)}(hstruct drm_mm_node *nodeh](jD)}(hjh]hstruct}(hj>hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj:ubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj^modnameN classnameNjj)}j]j )}jj$sbc.drm_mm_remove_nodeasbuh1hhj:ubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj:ubjm)}(hnodeh]hnode}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj6ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMmubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMmubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMmhjhhubj)}(hhh]h)}(h(Remove a memory node from the allocator.h]h(Remove a memory node from the allocator.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMmhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMmubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjOhNhNubj)}(hX4**Parameters** ``struct drm_mm_node *node`` drm_mm_node to remove **Description** This just removes a node from its drm_mm allocator. The node does not need to be cleared again before it can be re-inserted into this or any other drm_mm allocator. It is a bug to call this function on a unallocated node.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMqhjubj)}(hhh]j)}(h3``struct drm_mm_node *node`` drm_mm_node to remove h](j)}(h``struct drm_mm_node *node``h]j)}(hjh]hstruct drm_mm_node *node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMnhjubj )}(hhh]h)}(hdrm_mm_node to removeh]hdrm_mm_node to remove}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMnhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMnhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj=h]h Description}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMphjubh)}(hThis just removes a node from its drm_mm allocator. The node does not need to be cleared again before it can be re-inserted into this or any other drm_mm allocator. It is a bug to call this function on a unallocated node.h]hThis just removes a node from its drm_mm allocator. The node does not need to be cleared again before it can be re-inserted into this or any other drm_mm allocator. It is a bug to call this function on a unallocated node.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMohjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_mm_scan_init_with_range (C function)c.drm_mm_scan_init_with_rangehNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hvoid drm_mm_scan_init_with_range (struct drm_mm_scan *scan, struct drm_mm *mm, u64 size, u64 alignment, unsigned long color, u64 start, u64 end, enum drm_mm_insert_mode mode)h]j>)}(hvoid drm_mm_scan_init_with_range(struct drm_mm_scan *scan, struct drm_mm *mm, u64 size, u64 alignment, unsigned long color, u64 start, u64 end, enum drm_mm_insert_mode mode)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj~hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~hhhjhMubjg)}(hdrm_mm_scan_init_with_rangeh]jm)}(hdrm_mm_scan_init_with_rangeh]hdrm_mm_scan_init_with_range}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj~hhhjhMubj)}(h(struct drm_mm_scan *scan, struct drm_mm *mm, u64 size, u64 alignment, unsigned long color, u64 start, u64 end, enum drm_mm_insert_mode mode)h](j)}(hstruct drm_mm_scan *scanh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_mm_scanh]h drm_mm_scan}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_mm_scan_init_with_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hscanh]hscan}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hj1hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj-ubjV)}(h h]h }(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjQmodnameN classnameNjj)}j]jc.drm_mm_scan_init_with_rangeasbuh1hhj-ubjV)}(h h]h }(hjmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubj4)}(hj7h]h*}(hj{hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj-ubjm)}(hmmh]hmm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_scan_init_with_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hsizeh]hsize}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 alignmenth](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_mm_scan_init_with_rangeasbuh1hhjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h alignmenth]h alignment}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long colorh](j)}(hunsignedh]hunsigned}(hj1 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj- ubjV)}(h h]h }(hj? hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj- ubj)}(hlongh]hlong}(hjM hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj- ubjV)}(h h]h }(hj[ hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj- ubjm)}(hcolorh]hcolor}(hji hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj- ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 starth](h)}(hhh]jm)}(hu64h]hu64}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]jc.drm_mm_scan_init_with_rangeasbuh1hhj~ ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ ubjm)}(hstarth]hstart}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 endh](h)}(hhh]jm)}(hu64h]hu64}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]jc.drm_mm_scan_init_with_rangeasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(hendh]hend}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(henum drm_mm_insert_mode modeh](jD)}(hjGh]henum}(hj!hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj!ubjV)}(h h]h }(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!ubh)}(hhh]jm)}(hdrm_mm_insert_modeh]hdrm_mm_insert_mode}(hj0!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-!ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj2!modnameN classnameNjj)}j]jc.drm_mm_scan_init_with_rangeasbuh1hhj!ubjV)}(h h]h }(hjN!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!ubjm)}(hmodeh]hmode}(hj\!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj~hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjzhhhjhMubah}(h]juah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjwhhubj)}(hhh]h)}(h(initialize range-restricted lru scanningh]h(initialize range-restricted lru scanning}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!hhubah}(h]h ]h"]h$]h&]uh1jhjwhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj!jj!jjjuh1j2hhhjOhNhNubj)}(hX**Parameters** ``struct drm_mm_scan *scan`` scan state ``struct drm_mm *mm`` drm_mm to scan ``u64 size`` size of the allocation ``u64 alignment`` alignment of the allocation ``unsigned long color`` opaque tag value to use for the allocation ``u64 start`` start of the allowed range for the allocation ``u64 end`` end of the allowed range for the allocation ``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement **Description** This simply sets up the scanning routines with the parameters for the desired hole. Warning: As long as the scan list is non-empty, no other operations than adding/removing nodes to/from the scan list are allowed.h](h)}(h**Parameters**h]j)}(hj!h]h Parameters}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!ubj)}(hhh](j)}(h(``struct drm_mm_scan *scan`` scan state h](j)}(h``struct drm_mm_scan *scan``h]j)}(hj!h]hstruct drm_mm_scan *scan}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!ubj )}(hhh]h)}(h scan stateh]h scan state}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMhj!ubah}(h]h ]h"]h$]h&]uh1j hj!ubeh}(h]h ]h"]h$]h&]uh1jhj!hMhj!ubj)}(h%``struct drm_mm *mm`` drm_mm to scan h](j)}(h``struct drm_mm *mm``h]j)}(hj"h]hstruct drm_mm *mm}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!ubj )}(hhh]h)}(hdrm_mm to scanh]hdrm_mm to scan}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMhj"ubah}(h]h ]h"]h$]h&]uh1j hj!ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhj!ubj)}(h$``u64 size`` size of the allocation h](j)}(h ``u64 size``h]j)}(hj9"h]hu64 size}(hj;"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7"ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj3"ubj )}(hhh]h)}(hsize of the allocationh]hsize of the allocation}(hjR"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjN"hMhjO"ubah}(h]h ]h"]h$]h&]uh1j hj3"ubeh}(h]h ]h"]h$]h&]uh1jhjN"hMhj!ubj)}(h.``u64 alignment`` alignment of the allocation h](j)}(h``u64 alignment``h]j)}(hjr"h]h u64 alignment}(hjt"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjp"ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjl"ubj )}(hhh]h)}(halignment of the allocationh]halignment of the allocation}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMhj"ubah}(h]h ]h"]h$]h&]uh1j hjl"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhj!ubj)}(hC``unsigned long color`` opaque tag value to use for the allocation h](j)}(h``unsigned long color``h]j)}(hj"h]hunsigned long color}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj"ubj )}(hhh]h)}(h*opaque tag value to use for the allocationh]h*opaque tag value to use for the allocation}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMhj"ubah}(h]h ]h"]h$]h&]uh1j hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhj!ubj)}(h<``u64 start`` start of the allowed range for the allocation h](j)}(h ``u64 start``h]j)}(hj"h]h u64 start}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj"ubj )}(hhh]h)}(h-start of the allowed range for the allocationh]h-start of the allowed range for the allocation}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMhj"ubah}(h]h ]h"]h$]h&]uh1j hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hMhj!ubj)}(h8``u64 end`` end of the allowed range for the allocation h](j)}(h ``u64 end``h]j)}(hj#h]hu64 end}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj#ubj )}(hhh]h)}(h+end of the allowed range for the allocationh]h+end of the allowed range for the allocation}(hj6#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2#hMhj3#ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj2#hMhj!ubj)}(hO``enum drm_mm_insert_mode mode`` fine-tune the allocation search and placement h](j)}(h ``enum drm_mm_insert_mode mode``h]j)}(hjV#h]henum drm_mm_insert_mode mode}(hjX#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjT#ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjP#ubj )}(hhh]h)}(h-fine-tune the allocation search and placementh]h-fine-tune the allocation search and placement}(hjo#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjk#hMhjl#ubah}(h]h ]h"]h$]h&]uh1j hjP#ubeh}(h]h ]h"]h$]h&]uh1jhjk#hMhj!ubeh}(h]h ]h"]h$]h&]uh1jhj!ubh)}(h**Description**h]j)}(hj#h]h Description}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!ubh)}(hSThis simply sets up the scanning routines with the parameters for the desired hole.h]hSThis simply sets up the scanning routines with the parameters for the desired hole.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!ubh)}(hWarning: As long as the scan list is non-empty, no other operations than adding/removing nodes to/from the scan list are allowed.h]hWarning: As long as the scan list is non-empty, no other operations than adding/removing nodes to/from the scan list are allowed.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_mm_scan_add_block (C function)c.drm_mm_scan_add_blockhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hObool drm_mm_scan_add_block (struct drm_mm_scan *scan, struct drm_mm_node *node)h]j>)}(hNbool drm_mm_scan_add_block(struct drm_mm_scan *scan, struct drm_mm_node *node)h](j)}(hj*h]hbool}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#hhhj#hMubjg)}(hdrm_mm_scan_add_blockh]jm)}(hdrm_mm_scan_add_blockh]hdrm_mm_scan_add_block}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj#hhhj#hMubj)}(h4(struct drm_mm_scan *scan, struct drm_mm_node *node)h](j)}(hstruct drm_mm_scan *scanh](jD)}(hjh]hstruct}(hj!$hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$ubjV)}(h h]h }(hj.$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubh)}(hhh]jm)}(h drm_mm_scanh]h drm_mm_scan}(hj?$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj<$ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjA$modnameN classnameNjj)}j]j )}jj$sbc.drm_mm_scan_add_blockasbuh1hhj$ubjV)}(h h]h }(hj_$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubj4)}(hj7h]h*}(hjm$hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$ubjm)}(hscanh]hscan}(hjz$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$ubj)}(hstruct drm_mm_node *nodeh](jD)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$ubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj$modnameN classnameNjj)}j]j[$c.drm_mm_scan_add_blockasbuh1hhj$ubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubj4)}(hj7h]h*}(hj$hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$ubjm)}(hnodeh]hnode}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj$ubeh}(h]h ]h"]h$]h&]jjuh1jhj#hhhj#hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj#hhhj#hMubah}(h]j#ah ](jjeh"]h$]h&]jj)jhuh1j7hj#hMhj#hhubj)}(hhh]h)}(hadd a node to the scan listh]hadd a node to the scan list}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj%hhubah}(h]h ]h"]h$]h&]uh1jhj#hhhj#hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj,%jj,%jjjuh1j2hhhjOhNhNubj)}(hX**Parameters** ``struct drm_mm_scan *scan`` the active drm_mm scanner ``struct drm_mm_node *node`` drm_mm_node to add **Description** Add a node to the scan list that might be freed to make space for the desired hole. **Return** True if a hole has been found, false otherwise.h](h)}(h**Parameters**h]j)}(hj6%h]h Parameters}(hj8%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4%ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0%ubj)}(hhh](j)}(h7``struct drm_mm_scan *scan`` the active drm_mm scanner h](j)}(h``struct drm_mm_scan *scan``h]j)}(hjU%h]hstruct drm_mm_scan *scan}(hjW%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjS%ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjO%ubj )}(hhh]h)}(hthe active drm_mm scannerh]hthe active drm_mm scanner}(hjn%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjj%hMhjk%ubah}(h]h ]h"]h$]h&]uh1j hjO%ubeh}(h]h ]h"]h$]h&]uh1jhjj%hMhjL%ubj)}(h0``struct drm_mm_node *node`` drm_mm_node to add h](j)}(h``struct drm_mm_node *node``h]j)}(hj%h]hstruct drm_mm_node *node}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj%ubj )}(hhh]h)}(hdrm_mm_node to addh]hdrm_mm_node to add}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%hMhj%ubah}(h]h ]h"]h$]h&]uh1j hj%ubeh}(h]h ]h"]h$]h&]uh1jhj%hMhjL%ubeh}(h]h ]h"]h$]h&]uh1jhj0%ubh)}(h**Description**h]j)}(hj%h]h Description}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0%ubh)}(hSAdd a node to the scan list that might be freed to make space for the desired hole.h]hSAdd a node to the scan list that might be freed to make space for the desired hole.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0%ubh)}(h **Return**h]j)}(hj%h]hReturn}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0%ubh)}(h/True if a hole has been found, false otherwise.h]h/True if a hole has been found, false otherwise.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_mm_scan_remove_block (C function)c.drm_mm_scan_remove_blockhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hRbool drm_mm_scan_remove_block (struct drm_mm_scan *scan, struct drm_mm_node *node)h]j>)}(hQbool drm_mm_scan_remove_block(struct drm_mm_scan *scan, struct drm_mm_node *node)h](j)}(hj*h]hbool}(hj5&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj1&hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM3ubjV)}(h h]h }(hjC&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1&hhhjB&hM3ubjg)}(hdrm_mm_scan_remove_blockh]jm)}(hdrm_mm_scan_remove_blockh]hdrm_mm_scan_remove_block}(hjU&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQ&ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj1&hhhjB&hM3ubj)}(h4(struct drm_mm_scan *scan, struct drm_mm_node *node)h](j)}(hstruct drm_mm_scan *scanh](jD)}(hjh]hstruct}(hjq&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjm&ubjV)}(h h]h }(hj~&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm&ubh)}(hhh]jm)}(h drm_mm_scanh]h drm_mm_scan}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj&modnameN classnameNjj)}j]j )}jjW&sbc.drm_mm_scan_remove_blockasbuh1hhjm&ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjm&ubj4)}(hj7h]h*}(hj&hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjm&ubjm)}(hscanh]hscan}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjm&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhji&ubj)}(hstruct drm_mm_node *nodeh](jD)}(hjh]hstruct}(hj&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj&ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hj'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj'modnameN classnameNjj)}j]j&c.drm_mm_scan_remove_blockasbuh1hhj&ubjV)}(h h]h }(hj'hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj&ubj4)}(hj7h]h*}(hj-'hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj&ubjm)}(hnodeh]hnode}(hj:'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhji&ubeh}(h]h ]h"]h$]h&]jjuh1jhj1&hhhjB&hM3ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj-&hhhjB&hM3ubah}(h]j(&ah ](jjeh"]h$]h&]jj)jhuh1j7hjB&hM3hj*&hhubj)}(hhh]h)}(h remove a node from the scan listh]h remove a node from the scan list}(hjd'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM3hja'hhubah}(h]h ]h"]h$]h&]uh1jhj*&hhhjB&hM3ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj|'jj|'jjjuh1j2hhhjOhNhNubj)}(hX>**Parameters** ``struct drm_mm_scan *scan`` the active drm_mm scanner ``struct drm_mm_node *node`` drm_mm_node to remove **Description** Nodes **must** be removed in exactly the reverse order from the scan list as they have been added (e.g. using list_add() as they are added and then list_for_each() over that eviction list to remove), otherwise the internal state of the memory manager will be corrupted. When the scan list is empty, the selected memory nodes can be freed. An immediately following drm_mm_insert_node_in_range_generic() or one of the simpler versions of that function with !DRM_MM_SEARCH_BEST will then return the just freed block (because it's at the top of the free_stack list). **Return** True if this block should be evicted, false otherwise. Will always return false when no hole has been found.h](h)}(h**Parameters**h]j)}(hj'h]h Parameters}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM7hj'ubj)}(hhh](j)}(h7``struct drm_mm_scan *scan`` the active drm_mm scanner h](j)}(h``struct drm_mm_scan *scan``h]j)}(hj'h]hstruct drm_mm_scan *scan}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM4hj'ubj )}(hhh]h)}(hthe active drm_mm scannerh]hthe active drm_mm scanner}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM4hj'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM4hj'ubj)}(h3``struct drm_mm_node *node`` drm_mm_node to remove h](j)}(h``struct drm_mm_node *node``h]j)}(hj'h]hstruct drm_mm_node *node}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM5hj'ubj )}(hhh]h)}(hdrm_mm_node to removeh]hdrm_mm_node to remove}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM5hj'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM5hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'ubh)}(h**Description**h]j)}(hj(h]h Description}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM7hj'ubh)}(hX Nodes **must** be removed in exactly the reverse order from the scan list as they have been added (e.g. using list_add() as they are added and then list_for_each() over that eviction list to remove), otherwise the internal state of the memory manager will be corrupted.h](hNodes }(hj/(hhhNhNubj)}(h**must**h]hmust}(hj7(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/(ubh be removed in exactly the reverse order from the scan list as they have been added (e.g. using list_add() as they are added and then list_for_each() over that eviction list to remove), otherwise the internal state of the memory manager will be corrupted.}(hj/(hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM6hj'ubh)}(hX$When the scan list is empty, the selected memory nodes can be freed. An immediately following drm_mm_insert_node_in_range_generic() or one of the simpler versions of that function with !DRM_MM_SEARCH_BEST will then return the just freed block (because it's at the top of the free_stack list).h]hX&When the scan list is empty, the selected memory nodes can be freed. An immediately following drm_mm_insert_node_in_range_generic() or one of the simpler versions of that function with !DRM_MM_SEARCH_BEST will then return the just freed block (because it’s at the top of the free_stack list).}(hjP(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM;hj'ubh)}(h **Return**h]j)}(hja(h]hReturn}(hjc(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_(ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chM@hj'ubh)}(hlTrue if this block should be evicted, false otherwise. Will always return false when no hole has been found.h]hlTrue if this block should be evicted, false otherwise. Will always return false when no hole has been found.}(hjw(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMAhj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_mm_scan_color_evict (C function)c.drm_mm_scan_color_evicthNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hGstruct drm_mm_node * drm_mm_scan_color_evict (struct drm_mm_scan *scan)h]j>)}(hEstruct drm_mm_node *drm_mm_scan_color_evict(struct drm_mm_scan *scan)h](jD)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj(hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMdubjV)}(h h]h }(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(hhhj(hMdubh)}(hhh]jm)}(h drm_mm_nodeh]h drm_mm_node}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj(modnameN classnameNjj)}j]j )}jdrm_mm_scan_color_evictsbc.drm_mm_scan_color_evictasbuh1hhj(hhhj(hMdubjV)}(h h]h }(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(hhhj(hMdubj4)}(hj7h]h*}(hj(hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj(hhhj(hMdubjg)}(hdrm_mm_scan_color_evicth]jm)}(hj(h]hdrm_mm_scan_color_evict}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj(hhhj(hMdubj)}(h(struct drm_mm_scan *scan)h]j)}(hstruct drm_mm_scan *scanh](jD)}(hjh]hstruct}(hj )hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj)ubjV)}(h h]h }(hj-)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubh)}(hhh]jm)}(h drm_mm_scanh]h drm_mm_scan}(hj>)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@)modnameN classnameNjj)}j]j(c.drm_mm_scan_color_evictasbuh1hhj)ubjV)}(h h]h }(hj\)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubj4)}(hj7h]h*}(hjj)hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj)ubjm)}(hscanh]hscan}(hjw)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj)ubah}(h]h ]h"]h$]h&]jjuh1jhj(hhhj(hMdubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj(hhhj(hMdubah}(h]j(ah ](jjeh"]h$]h&]jj)jhuh1j7hj(hMdhj(hhubj)}(hhh]h)}(h.evict overlapping nodes on either side of holeh]h.evict overlapping nodes on either side of hole}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMdhj)hhubah}(h]h ]h"]h$]h&]uh1jhj(hhhj(hMdubeh}(h]h ](jfunctioneh"]h$]h&]jjjj)jj)jjjuh1j2hhhjOhNhNubj)}(hXV**Parameters** ``struct drm_mm_scan *scan`` drm_mm scan with target hole **Description** After completing an eviction scan and removing the selected nodes, we may need to remove a few more nodes from either side of the target hole if mm.color_adjust is being used. **Return** A node to evict, or NULL if there are no overlapping nodes.h](h)}(h**Parameters**h]j)}(hj)h]h Parameters}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhhj)ubj)}(hhh]j)}(h:``struct drm_mm_scan *scan`` drm_mm scan with target hole h](j)}(h``struct drm_mm_scan *scan``h]j)}(hj)h]hstruct drm_mm_scan *scan}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMehj)ubj )}(hhh]h)}(hdrm_mm scan with target holeh]hdrm_mm scan with target hole}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj)hMehj)ubah}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhj)hMehj)ubah}(h]h ]h"]h$]h&]uh1jhj)ubh)}(h**Description**h]j)}(hj*h]h Description}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMghj)ubh)}(hAfter completing an eviction scan and removing the selected nodes, we may need to remove a few more nodes from either side of the target hole if mm.color_adjust is being used.h]hAfter completing an eviction scan and removing the selected nodes, we may need to remove a few more nodes from either side of the target hole if mm.color_adjust is being used.}(hj3*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMfhj)ubh)}(h **Return**h]j)}(hjD*h]hReturn}(hjF*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjB*ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMjhj)ubh)}(h;A node to evict, or NULL if there are no overlapping nodes.h]h;A node to evict, or NULL if there are no overlapping nodes.}(hjZ*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMkhj)ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_init (C function) c.drm_mm_inithNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h9void drm_mm_init (struct drm_mm *mm, u64 start, u64 size)h]j>)}(h8void drm_mm_init(struct drm_mm *mm, u64 start, u64 size)h](j)}(hvoidh]hvoid}(hj*hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj*hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*hhhj*hMubjg)}(h drm_mm_inith]jm)}(h drm_mm_inith]h drm_mm_init}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj*hhhj*hMubj)}(h((struct drm_mm *mm, u64 start, u64 size)h](j)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hj*hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj*ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*ubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j )}jj*sb c.drm_mm_initasbuh1hhj*ubjV)}(h h]h }(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj*ubj4)}(hj7h]h*}(hj+hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj*ubjm)}(hmmh]hmm}(hj+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj*ubj)}(h u64 starth](h)}(hhh]jm)}(hu64h]hu64}(hj;+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=+modnameN classnameNjj)}j]j+ c.drm_mm_initasbuh1hhj4+ubjV)}(h h]h }(hjY+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4+ubjm)}(hstarth]hstart}(hjg+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj*ubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hj+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]j+ c.drm_mm_initasbuh1hhj|+ubjV)}(h h]h }(hj+hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj|+ubjm)}(hsizeh]hsize}(hj+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj*ubeh}(h]h ]h"]h$]h&]jjuh1jhj*hhhj*hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj*hhhj*hMubah}(h]j|*ah ](jjeh"]h$]h&]jj)jhuh1j7hj*hMhj~*hhubj)}(hhh]h)}(hinitialize a drm-mm allocatorh]hinitialize a drm-mm allocator}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj+hhubah}(h]h ]h"]h$]h&]uh1jhj~*hhhj*hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj+jj+jjjuh1j2hhhjOhNhNubj)}(hX **Parameters** ``struct drm_mm *mm`` the drm_mm structure to initialize ``u64 start`` start of the range managed by **mm** ``u64 size`` end of the range managed by **mm** **Description** Note that **mm** must be cleared to 0 before calling this function.Jh](h)}(h**Parameters**h]j)}(hj+h]h Parameters}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj+ubj)}(hhh](j)}(h9``struct drm_mm *mm`` the drm_mm structure to initialize h](j)}(h``struct drm_mm *mm``h]j)}(hj,h]hstruct drm_mm *mm}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj,ubj )}(hhh]h)}(h"the drm_mm structure to initializeh]h"the drm_mm structure to initialize}(hj3,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/,hMhj0,ubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhj/,hMhj,ubj)}(h3``u64 start`` start of the range managed by **mm** h](j)}(h ``u64 start``h]j)}(hjS,h]h u64 start}(hjU,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQ,ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjM,ubj )}(hhh]h)}(h$start of the range managed by **mm**h](hstart of the range managed by }(hjl,hhhNhNubj)}(h**mm**h]hmm}(hjt,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjl,ubeh}(h]h ]h"]h$]h&]uh1hhjh,hMhji,ubah}(h]h ]h"]h$]h&]uh1j hjM,ubeh}(h]h ]h"]h$]h&]uh1jhjh,hMhj,ubj)}(h0``u64 size`` end of the range managed by **mm** h](j)}(h ``u64 size``h]j)}(hj,h]hu64 size}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj,ubj )}(hhh]h)}(h"end of the range managed by **mm**h](hend of the range managed by }(hj,hhhNhNubj)}(h**mm**h]hmm}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubeh}(h]h ]h"]h$]h&]uh1hhj,hMhj,ubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhj,hMhj,ubeh}(h]h ]h"]h$]h&]uh1jhj+ubh)}(h**Description**h]j)}(hj,h]h Description}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj+ubh)}(hCNote that **mm** must be cleared to 0 before calling this function.h](h Note that }(hj,hhhNhNubj)}(h**mm**h]hmm}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubh3 must be cleared to 0 before calling this function.}(hj,hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj+ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_takedown (C function)c.drm_mm_takedownhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(h(void drm_mm_takedown (struct drm_mm *mm)h]j>)}(h'void drm_mm_takedown(struct drm_mm *mm)h](j)}(hvoidh]hvoid}(hj:-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6-hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hjI-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6-hhhjH-hMubjg)}(hdrm_mm_takedownh]jm)}(hdrm_mm_takedownh]hdrm_mm_takedown}(hj[-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjW-ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj6-hhhjH-hMubj)}(h(struct drm_mm *mm)h]j)}(hstruct drm_mm *mmh](jD)}(hjh]hstruct}(hjw-hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjs-ubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjs-ubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]j )}jj]-sbc.drm_mm_takedownasbuh1hhjs-ubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjs-ubj4)}(hj7h]h*}(hj-hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjs-ubjm)}(hmmh]hmm}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjs-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjo-ubah}(h]h ]h"]h$]h&]jjuh1jhj6-hhhjH-hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj2-hhhjH-hMubah}(h]j--ah ](jjeh"]h$]h&]jj)jhuh1j7hjH-hMhj/-hhubj)}(hhh]h)}(hclean up a drm_mm allocatorh]hclean up a drm_mm allocator}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj-hhubah}(h]h ]h"]h$]h&]uh1jhj/-hhhjH-hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj.jj.jjjuh1j2hhhjOhNhNubj)}(h**Parameters** ``struct drm_mm *mm`` drm_mm allocator to clean up **Description** Note that it is a bug to call this function on an allocator which is not clean.h](h)}(h**Parameters**h]j)}(hj.h]h Parameters}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj.ubj)}(hhh]j)}(h3``struct drm_mm *mm`` drm_mm allocator to clean up h](j)}(h``struct drm_mm *mm``h]j)}(hj;.h]hstruct drm_mm *mm}(hj=.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9.ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj5.ubj )}(hhh]h)}(hdrm_mm allocator to clean uph]hdrm_mm allocator to clean up}(hjT.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjP.hMhjQ.ubah}(h]h ]h"]h$]h&]uh1j hj5.ubeh}(h]h ]h"]h$]h&]uh1jhjP.hMhj2.ubah}(h]h ]h"]h$]h&]uh1jhj.ubh)}(h**Description**h]j)}(hjv.h]h Description}(hjx.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjt.ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj.ubh)}(hONote that it is a bug to call this function on an allocator which is not clean.h]hONote that it is a bug to call this function on an allocator which is not clean.}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_mm_print (C function)c.drm_mm_printhNtauh1j!hjOhhhNhNubj3)}(hhh](j8)}(hBvoid drm_mm_print (const struct drm_mm *mm, struct drm_printer *p)h]j>)}(hAvoid drm_mm_print(const struct drm_mm *mm, struct drm_printer *p)h](j)}(hvoidh]hvoid}(hj.hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj.hhhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMubjV)}(h h]h }(hj.hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.hhhj.hMubjg)}(h drm_mm_printh]jm)}(h drm_mm_printh]h drm_mm_print}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj.hhhj.hMubj)}(h0(const struct drm_mm *mm, struct drm_printer *p)h](j)}(hconst struct drm_mm *mmh](jD)}(hj h]hconst}(hj.hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj.ubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubjD)}(hjh]hstruct}(hj/hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj.ubjV)}(h h]h }(hj /hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubh)}(hhh]jm)}(hdrm_mmh]hdrm_mm}(hj1/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj./ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj3/modnameN classnameNjj)}j]j )}jj.sbc.drm_mm_printasbuh1hhj.ubjV)}(h h]h }(hjQ/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubj4)}(hj7h]h*}(hj_/hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj.ubjm)}(hmmh]hmm}(hjl/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubj)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hj/hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj/ubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj/modnameN classnameNjj)}j]jM/c.drm_mm_printasbuh1hhj/ubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubj4)}(hj7h]h*}(hj/hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj/ubjm)}(hj@h]hp}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.ubeh}(h]h ]h"]h$]h&]jjuh1jhj.hhhj.hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj.hhhj.hMubah}(h]j.ah ](jjeh"]h$]h&]jj)jhuh1j7hj.hMhj.hhubj)}(hhh]h)}(hprint allocator stateh]hprint allocator state}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0hhubah}(h]h ]h"]h$]h&]uh1jhj.hhhj.hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj0jj0jjjuh1j2hhhjOhNhNubj)}(hw**Parameters** ``const struct drm_mm *mm`` drm_mm allocator to print ``struct drm_printer *p`` DRM printer to useh](h)}(h**Parameters**h]j)}(hj'0h]h Parameters}(hj)0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%0ubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj!0ubj)}(hhh](j)}(h6``const struct drm_mm *mm`` drm_mm allocator to print h](j)}(h``const struct drm_mm *mm``h]j)}(hjF0h]hconst struct drm_mm *mm}(hjH0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjD0ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj@0ubj )}(hhh]h)}(hdrm_mm allocator to printh]hdrm_mm allocator to print}(hj_0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[0hMhj\0ubah}(h]h ]h"]h$]h&]uh1j hj@0ubeh}(h]h ]h"]h$]h&]uh1jhj[0hMhj=0ubj)}(h,``struct drm_printer *p`` DRM printer to useh](j)}(h``struct drm_printer *p``h]j)}(hj0h]hstruct drm_printer *p}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}0ubah}(h]h ]h"]h$]h&]uh1jhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhjy0ubj )}(hhh]h)}(hDRM printer to useh]hDRM printer to use}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhT/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:483: ./drivers/gpu/drm/drm_mm.chMhj0ubah}(h]h ]h"]h$]h&]uh1j hjy0ubeh}(h]h ]h"]h$]h&]uh1jhj0hMhj=0ubeh}(h]h ]h"]h$]h&]uh1jhj!0ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjOhhhNhNubj)}(h.. _drm_gpuvm:h]h}(h]h ]h"]h$]h&]jʫ drm-gpuvmuh1jhMhjOhhhhubeh}(h]*drm-mm-range-allocator-function-referencesah ]h"]*drm mm range allocator function referencesah$]h&]uh1hhjhhhhhMubeh}(h]drm-mm-range-allocatorah ]h"]drm mm range allocatorah$]h&]uh1hhhhhhhhMubh)}(hhh](h)}(h DRM GPUVMh]h DRM GPUVM}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hhhhhMubh)}(hhh](h)}(hOverviewh]hOverview}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj0hhhhhMubh)}(hXThe DRM GPU VA Manager, represented by struct drm_gpuvm keeps track of a GPU's virtual address (VA) space and manages the corresponding virtual mappings represented by :c:type:`drm_gpuva` objects. It also keeps track of the mapping's backing :c:type:`drm_gem_object` buffers.h](hThe DRM GPU VA Manager, represented by struct drm_gpuvm keeps track of a GPU’s virtual address (VA) space and manages the corresponding virtual mappings represented by }(hj0hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj1h]h drm_gpuva}(hj 1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK$hj0ubh9 objects. It also keeps track of the mapping’s backing }(hj0hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj+1h]hdrm_gem_object}(hj-1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj)1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhj$1hK$hj0ubh buffers.}(hj0hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$1hK$hj0hhubh)}(h:c:type:`drm_gem_object` buffers maintain a list of :c:type:`drm_gpuva` objects representing all existing GPU VA mappings using this :c:type:`drm_gem_object` as backing buffer.h](h)}(h:c:type:`drm_gem_object`h]j)}(hjX1h]hdrm_gem_object}(hjZ1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjV1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK)hjR1ubh buffers maintain a list of }(hjR1hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj|1h]h drm_gpuva}(hj~1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjz1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhju1hK)hjR1ubh> objects representing all existing GPU VA mappings using this }(hjR1hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj1h]hdrm_gem_object}(hj1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhju1hK)hjR1ubh as backing buffer.}(hjR1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhju1hK)hj0hhubh)}(hGPU VAs can be flagged as sparse, such that drivers may use GPU VAs to also keep track of sparse PTEs in order to support Vulkan 'Sparse Resources'.h]hGPU VAs can be flagged as sparse, such that drivers may use GPU VAs to also keep track of sparse PTEs in order to support Vulkan ‘Sparse Resources’.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK,hj0hhubh)}(h}The GPU VA manager internally uses a rb-tree to manage the :c:type:`drm_gpuva` mappings within a GPU's virtual address space.h](h;The GPU VA manager internally uses a rb-tree to manage the }(hj1hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj1h]h drm_gpuva}(hj1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK/hj1ubh1 mappings within a GPU’s virtual address space.}(hj1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj1hK/hj0hhubh)}(hThe :c:type:`drm_gpuvm` structure contains a special :c:type:`drm_gpuva` representing the portion of VA space reserved by the kernel. This node is initialized together with the GPU VA manager instance and removed when the GPU VA manager is destroyed.h](hThe }(hj2hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj2h]h drm_gpuvm}(hj2hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK2hj2ubh structure contains a special }(hj2hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj52h]h drm_gpuva}(hj72hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj32ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj.2hK2hj2ubh representing the portion of VA space reserved by the kernel. This node is initialized together with the GPU VA manager instance and removed when the GPU VA manager is destroyed.}(hj2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj.2hK2hj0hhubh)}(hIn a typical application drivers would embed struct drm_gpuvm and struct drm_gpuva within their own driver specific structures, there won't be any memory allocations of its own nor memory allocations of :c:type:`drm_gpuva` entries.h](hIn a typical application drivers would embed struct drm_gpuvm and struct drm_gpuva within their own driver specific structures, there won’t be any memory allocations of its own nor memory allocations of }(hj\2hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjf2h]h drm_gpuva}(hjh2hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjd2ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK7hj\2ubh entries.}(hj\2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj2hK7hj0hhubh)}(hX+The data structures needed to store :c:type:`drm_gpuvas` within the :c:type:`drm_gpuvm` are contained within struct drm_gpuva already. Hence, for inserting :c:type:`drm_gpuva` entries from within dma-fence signalling critical sections it is enough to pre-allocate the :c:type:`drm_gpuva` structures.h](h$The data structures needed to store }(hj2hhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hj2h]h drm_gpuvas}(hj2hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:494: ./drivers/gpu/drm/drm_gpuvm.chK8h]h drm_gpuvm_ops}(hj@8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKyhj48ubhX callbacks contain an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The caller might receive no callback at all if no operation is required, e.g. if the requested mapping already exists in the exact same way.}(hj48hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj[8hKyhj7hhubh)}(hWThe single map operation represents the original map operation requested by the caller.h]hWThe single map operation represents the original map operation requested by the caller.}(hjf8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj7hhubh)}(hX:c:type:`drm_gpuva_op_unmap` contains a 'keep' field, which indicates whether the :c:type:`drm_gpuva` to unmap is physically contiguous with the original mapping request. Optionally, if 'keep' is set, drivers may keep the actual page table entries for this :c:type:`drm_gpuva`, adding the missing page table entries only and update the :c:type:`drm_gpuvm`'s view of things accordingly.h](h)}(h:c:type:`drm_gpuva_op_unmap`h]j)}(hj{8h]hdrm_gpuva_op_unmap}(hj}8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjy8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_op_unmapuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhju8ubh: contains a ‘keep’ field, which indicates whether the }(hju8hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj8h]h drm_gpuva}(hj8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj8hKhju8ubh to unmap is physically contiguous with the original mapping request. Optionally, if ‘keep’ is set, drivers may keep the actual page table entries for this }(hju8hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj8h]h drm_gpuva}(hj8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj8hKhju8ubh<, adding the missing page table entries only and update the }(hju8hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj8h]h drm_gpuvm}(hj8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj8hKhju8ubh ’s view of things accordingly.}(hju8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hKhj7hhubh)}(hXDrivers may do the same optimization, namely delta page table updates, also for remap operations. This is possible since :c:type:`drm_gpuva_op_remap` consists of one unmap operation and one or two map operations, such that drivers can derive the page table update delta accordingly.h](hyDrivers may do the same optimization, namely delta page table updates, also for remap operations. This is possible since }(hj 9hhhNhNubh)}(h:c:type:`drm_gpuva_op_remap`h]j)}(hj9h]hdrm_gpuva_op_remap}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_op_remapuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj 9ubh consists of one unmap operation and one or two map operations, such that drivers can derive the page table update delta accordingly.}(hj 9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj39hKhj7hhubh)}(hNote that there can't be more than two existing mappings to split up, one at the beginning and one at the end of the new mapping, hence there is a maximum of two remap operations.h]hNote that there can’t be more than two existing mappings to split up, one at the beginning and one at the end of the new mapping, hence there is a maximum of two remap operations.}(hj>9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj7hhubh)}(hXAnalogous to drm_gpuvm_sm_map() drm_gpuvm_sm_unmap() uses :c:type:`drm_gpuvm_ops` to call back into the driver in order to unmap a range of GPU VA space. The logic behind this function is way simpler though: For all existing mappings enclosed by the given range unmap operations are created. For mappings which are only partially located within the given range, remap operations are created such that those mappings are split up and re-mapped partially.h](h:Analogous to drm_gpuvm_sm_map() drm_gpuvm_sm_unmap() uses }(hjM9hhhNhNubh)}(h:c:type:`drm_gpuvm_ops`h]j)}(hjW9h]h drm_gpuvm_ops}(hjY9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjU9ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhjM9ubhXt to call back into the driver in order to unmap a range of GPU VA space. The logic behind this function is way simpler though: For all existing mappings enclosed by the given range unmap operations are created. For mappings which are only partially located within the given range, remap operations are created such that those mappings are split up and re-mapped partially.}(hjM9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjt9hKhj7hhubh)}(hXAs an alternative to drm_gpuvm_sm_map() and drm_gpuvm_sm_unmap(), drm_gpuvm_sm_map_ops_create() and drm_gpuvm_sm_unmap_ops_create() can be used to directly obtain an instance of struct drm_gpuva_ops containing a list of :c:type:`drm_gpuva_op`, which can be iterated with drm_gpuva_for_each_op(). This list contains the :c:type:`drm_gpuva_ops` analogous to the callbacks one would receive when calling drm_gpuvm_sm_map() or drm_gpuvm_sm_unmap(). While this way requires more memory (to allocate the :c:type:`drm_gpuva_ops`), it provides drivers a way to iterate the :c:type:`drm_gpuva_op` multiple times, e.g. once in a context where memory allocations are possible (e.g. to allocate GPU page tables) and once in the dma-fence signalling critical path.h](hAs an alternative to drm_gpuvm_sm_map() and drm_gpuvm_sm_unmap(), drm_gpuvm_sm_map_ops_create() and drm_gpuvm_sm_unmap_ops_create() can be used to directly obtain an instance of struct drm_gpuva_ops containing a list of }(hj9hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hj9h]h drm_gpuva_op}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj9ubhM, which can be iterated with drm_gpuva_for_each_op(). This list contains the }(hj9hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj9h]h drm_gpuva_ops}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhj9hKhj9ubh analogous to the callbacks one would receive when calling drm_gpuvm_sm_map() or drm_gpuvm_sm_unmap(). While this way requires more memory (to allocate the }(hj9hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj9h]h drm_gpuva_ops}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhj9hKhj9ubh,), it provides drivers a way to iterate the }(hj9hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hj9h]h drm_gpuva_op}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhj9hKhj9ubh multiple times, e.g. once in a context where memory allocations are possible (e.g. to allocate GPU page tables) and once in the dma-fence signalling critical path.}(hj9hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj9hKhj7hhubh)}(hXTo update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert() and drm_gpuva_remove() may be used. These functions can safely be used from :c:type:`drm_gpuvm_ops` callbacks originating from drm_gpuvm_sm_map() or drm_gpuvm_sm_unmap(). However, it might be more convenient to use the provided helper functions drm_gpuva_map(), drm_gpuva_remap() and drm_gpuva_unmap() instead.h](hTo update the }(hj:hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj$:h]h drm_gpuvm}(hj&:hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj":ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubh}’s view of the GPU VA space drm_gpuva_insert() and drm_gpuva_remove() may be used. These functions can safely be used from }(hj:hhhNhNubh)}(h:c:type:`drm_gpuvm_ops`h]j)}(hjH:h]h drm_gpuvm_ops}(hjJ:hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjF:ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhjA:hKhj:ubh callbacks originating from drm_gpuvm_sm_map() or drm_gpuvm_sm_unmap(). However, it might be more convenient to use the provided helper functions drm_gpuva_map(), drm_gpuva_remap() and drm_gpuva_unmap() instead.}(hj:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjA:hKhj7hhubh)}(hThe following diagram depicts the basic relationships of existing GPU VA mappings, a newly requested mapping and the resulting mappings as implemented by drm_gpuvm_sm_map() - it doesn't cover any arbitrary combinations of these.h]hThe following diagram depicts the basic relationships of existing GPU VA mappings, a newly requested mapping and the resulting mappings as implemented by drm_gpuvm_sm_map() - it doesn’t cover any arbitrary combinations of these.}(hjo:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj7hhubhenumerated_list)}(hhh](j{)}(hX Requested mapping is identical. Replace it, but indicate the backing PTEs could be kept. :: 0 a 1 old: |-----------| (bo_offset=n) 0 a 1 req: |-----------| (bo_offset=n) 0 a 1 new: |-----------| (bo_offset=n) h](h)}(hXRequested mapping is identical. Replace it, but indicate the backing PTEs could be kept.h]hXRequested mapping is identical. Replace it, but indicate the backing PTEs could be kept.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubjT)}(h 0 a 1 old: |-----------| (bo_offset=n) 0 a 1 req: |-----------| (bo_offset=n) 0 a 1 new: |-----------| (bo_offset=n)h]h 0 a 1 old: |-----------| (bo_offset=n) 0 a 1 req: |-----------| (bo_offset=n) 0 a 1 new: |-----------| (bo_offset=n)}hj:sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXRequested mapping is identical, except for the BO offset, hence replace the mapping. :: 0 a 1 old: |-----------| (bo_offset=n) 0 a 1 req: |-----------| (bo_offset=m) 0 a 1 new: |-----------| (bo_offset=m) h](h)}(hTRequested mapping is identical, except for the BO offset, hence replace the mapping.h]hTRequested mapping is identical, except for the BO offset, hence replace the mapping.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubjT)}(h 0 a 1 old: |-----------| (bo_offset=n) 0 a 1 req: |-----------| (bo_offset=m) 0 a 1 new: |-----------| (bo_offset=m)h]h 0 a 1 old: |-----------| (bo_offset=n) 0 a 1 req: |-----------| (bo_offset=m) 0 a 1 new: |-----------| (bo_offset=m)}hj:sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXRequested mapping is identical, except for the backing BO, hence replace the mapping. :: 0 a 1 old: |-----------| (bo_offset=n) 0 b 1 req: |-----------| (bo_offset=n) 0 b 1 new: |-----------| (bo_offset=n) h](h)}(hURequested mapping is identical, except for the backing BO, hence replace the mapping.h]hURequested mapping is identical, except for the backing BO, hence replace the mapping.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubjT)}(h 0 a 1 old: |-----------| (bo_offset=n) 0 b 1 req: |-----------| (bo_offset=n) 0 b 1 new: |-----------| (bo_offset=n)h]h 0 a 1 old: |-----------| (bo_offset=n) 0 b 1 req: |-----------| (bo_offset=n) 0 b 1 new: |-----------| (bo_offset=n)}hj:sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXExistent mapping is a left aligned subset of the requested one, hence replace the existing one. :: 0 a 1 old: |-----| (bo_offset=n) 0 a 2 req: |-----------| (bo_offset=n) 0 a 2 new: |-----------| (bo_offset=n) .. note:: We expect to see the same result for a request with a different BO and/or non-contiguous BO offset. h](h)}(h_Existent mapping is a left aligned subset of the requested one, hence replace the existing one.h]h_Existent mapping is a left aligned subset of the requested one, hence replace the existing one.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubjT)}(h 0 a 1 old: |-----| (bo_offset=n) 0 a 2 req: |-----------| (bo_offset=n) 0 a 2 new: |-----------| (bo_offset=n)h]h 0 a 1 old: |-----| (bo_offset=n) 0 a 2 req: |-----------| (bo_offset=n) 0 a 2 new: |-----------| (bo_offset=n)}hj;sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj:ubhnote)}(hcWe expect to see the same result for a request with a different BO and/or non-contiguous BO offset.h]h)}(hcWe expect to see the same result for a request with a different BO and/or non-contiguous BO offset.h]hcWe expect to see the same result for a request with a different BO and/or non-contiguous BO offset.}(hj#;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj;ubah}(h]h ]h"]h$]h&]uh1j;hj:ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXRequested mapping's range is a left aligned subset of the existing one, but backed by a different BO. Hence, map the requested mapping and split the existing one adjusting its BO offset. :: 0 a 2 old: |-----------| (bo_offset=n) 0 b 1 req: |-----| (bo_offset=n) 0 b 1 a' 2 new: |-----|-----| (b.bo_offset=n, a.bo_offset=n+1) .. note:: We expect to see the same result for a request with a different BO and/or non-contiguous BO offset. h](h)}(hRequested mapping's range is a left aligned subset of the existing one, but backed by a different BO. Hence, map the requested mapping and split the existing one adjusting its BO offset.h]hRequested mapping’s range is a left aligned subset of the existing one, but backed by a different BO. Hence, map the requested mapping and split the existing one adjusting its BO offset.}(hjB;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj>;ubjT)}(h 0 a 2 old: |-----------| (bo_offset=n) 0 b 1 req: |-----| (bo_offset=n) 0 b 1 a' 2 new: |-----|-----| (b.bo_offset=n, a.bo_offset=n+1)h]h 0 a 2 old: |-----------| (bo_offset=n) 0 b 1 req: |-----| (bo_offset=n) 0 b 1 a' 2 new: |-----|-----| (b.bo_offset=n, a.bo_offset=n+1)}hjQ;sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj>;ubj;)}(hcWe expect to see the same result for a request with a different BO and/or non-contiguous BO offset.h]h)}(hcWe expect to see the same result for a request with a different BO and/or non-contiguous BO offset.h]hcWe expect to see the same result for a request with a different BO and/or non-contiguous BO offset.}(hjd;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chKhj`;ubah}(h]h ]h"]h$]h&]uh1j;hj>;ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hX6Existent mapping is a superset of the requested mapping. Split it up, but indicate that the backing PTEs could be kept. :: 0 a 2 old: |-----------| (bo_offset=n) 0 a 1 req: |-----| (bo_offset=n) 0 a 1 a' 2 new: |-----|-----| (a.bo_offset=n, a'.bo_offset=n+1) h](h)}(hwExistent mapping is a superset of the requested mapping. Split it up, but indicate that the backing PTEs could be kept.h]hwExistent mapping is a superset of the requested mapping. Split it up, but indicate that the backing PTEs could be kept.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj;ubjT)}(h 0 a 2 old: |-----------| (bo_offset=n) 0 a 1 req: |-----| (bo_offset=n) 0 a 1 a' 2 new: |-----|-----| (a.bo_offset=n, a'.bo_offset=n+1)h]h 0 a 2 old: |-----------| (bo_offset=n) 0 a 1 req: |-----| (bo_offset=n) 0 a 1 a' 2 new: |-----|-----| (a.bo_offset=n, a'.bo_offset=n+1)}hj;sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj;ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXRequested mapping's range is a right aligned subset of the existing one, but backed by a different BO. Hence, map the requested mapping and split the existing one, without adjusting the BO offset. :: 0 a 2 old: |-----------| (bo_offset=n) 1 b 2 req: |-----| (bo_offset=m) 0 a 1 b 2 new: |-----|-----| (a.bo_offset=n,b.bo_offset=m) h](h)}(hRequested mapping's range is a right aligned subset of the existing one, but backed by a different BO. Hence, map the requested mapping and split the existing one, without adjusting the BO offset.h]hRequested mapping’s range is a right aligned subset of the existing one, but backed by a different BO. Hence, map the requested mapping and split the existing one, without adjusting the BO offset.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj;ubjT)}(h 0 a 2 old: |-----------| (bo_offset=n) 1 b 2 req: |-----| (bo_offset=m) 0 a 1 b 2 new: |-----|-----| (a.bo_offset=n,b.bo_offset=m)h]h 0 a 2 old: |-----------| (bo_offset=n) 1 b 2 req: |-----| (bo_offset=m) 0 a 1 b 2 new: |-----|-----| (a.bo_offset=n,b.bo_offset=m)}hj;sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj;ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hX?Existent mapping is a superset of the requested mapping. Split it up, but indicate that the backing PTEs could be kept. :: 0 a 2 old: |-----------| (bo_offset=n) 1 a 2 req: |-----| (bo_offset=n+1) 0 a' 1 a 2 new: |-----|-----| (a'.bo_offset=n, a.bo_offset=n+1) h](h)}(hwExistent mapping is a superset of the requested mapping. Split it up, but indicate that the backing PTEs could be kept.h]hwExistent mapping is a superset of the requested mapping. Split it up, but indicate that the backing PTEs could be kept.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chM!hj;ubjT)}(h 0 a 2 old: |-----------| (bo_offset=n) 1 a 2 req: |-----| (bo_offset=n+1) 0 a' 1 a 2 new: |-----|-----| (a'.bo_offset=n, a.bo_offset=n+1)h]h 0 a 2 old: |-----------| (bo_offset=n) 1 a 2 req: |-----| (bo_offset=n+1) 0 a' 1 a 2 new: |-----|-----| (a'.bo_offset=n, a.bo_offset=n+1)}hj;sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chM&hj;ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXExistent mapping is overlapped at the end by the requested mapping backed by a different BO. Hence, map the requested mapping and split up the existing one, without adjusting the BO offset. :: 0 a 2 old: |-----------| (bo_offset=n) 1 b 3 req: |-----------| (bo_offset=m) 0 a 1 b 3 new: |-----|-----------| (a.bo_offset=n,b.bo_offset=m) h](h)}(hExistent mapping is overlapped at the end by the requested mapping backed by a different BO. Hence, map the requested mapping and split up the existing one, without adjusting the BO offset.h]hExistent mapping is overlapped at the end by the requested mapping backed by a different BO. Hence, map the requested mapping and split up the existing one, without adjusting the BO offset.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chM0hj;ubjT)}(h 0 a 2 old: |-----------| (bo_offset=n) 1 b 3 req: |-----------| (bo_offset=m) 0 a 1 b 3 new: |-----|-----------| (a.bo_offset=n,b.bo_offset=m)h]h 0 a 2 old: |-----------| (bo_offset=n) 1 b 3 req: |-----------| (bo_offset=m) 0 a 1 b 3 new: |-----|-----------| (a.bo_offset=n,b.bo_offset=m)}hj <sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chM6hj;ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXExistent mapping is overlapped by the requested mapping, both having the same backing BO with a contiguous offset. Indicate the backing PTEs of the old mapping could be kept. :: 0 a 2 old: |-----------| (bo_offset=n) 1 a 3 req: |-----------| (bo_offset=n+1) 0 a' 1 a 3 new: |-----|-----------| (a'.bo_offset=n, a.bo_offset=n+1) h](h)}(hExistent mapping is overlapped by the requested mapping, both having the same backing BO with a contiguous offset. Indicate the backing PTEs of the old mapping could be kept.h]hExistent mapping is overlapped by the requested mapping, both having the same backing BO with a contiguous offset. Indicate the backing PTEs of the old mapping could be kept.}(hj#<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chM@hj<ubjT)}(h 0 a 2 old: |-----------| (bo_offset=n) 1 a 3 req: |-----------| (bo_offset=n+1) 0 a' 1 a 3 new: |-----|-----------| (a'.bo_offset=n, a.bo_offset=n+1)h]h 0 a 2 old: |-----------| (bo_offset=n) 1 a 3 req: |-----------| (bo_offset=n+1) 0 a' 1 a 3 new: |-----|-----------| (a'.bo_offset=n, a.bo_offset=n+1)}hj2<sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMFhj<ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXRequested mapping's range is a centered subset of the existing one having a different backing BO. Hence, map the requested mapping and split up the existing one in two mappings, adjusting the BO offset of the right one accordingly. :: 0 a 3 old: |-----------------| (bo_offset=n) 1 b 2 req: |-----| (bo_offset=m) 0 a 1 b 2 a' 3 new: |-----|-----|-----| (a.bo_offset=n,b.bo_offset=m,a'.bo_offset=n+2) h](h)}(hRequested mapping's range is a centered subset of the existing one having a different backing BO. Hence, map the requested mapping and split up the existing one in two mappings, adjusting the BO offset of the right one accordingly.h]hRequested mapping’s range is a centered subset of the existing one having a different backing BO. Hence, map the requested mapping and split up the existing one in two mappings, adjusting the BO offset of the right one accordingly.}(hjK<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMPhjG<ubjT)}(h 0 a 3 old: |-----------------| (bo_offset=n) 1 b 2 req: |-----| (bo_offset=m) 0 a 1 b 2 a' 3 new: |-----|-----|-----| (a.bo_offset=n,b.bo_offset=m,a'.bo_offset=n+2)h]h 0 a 3 old: |-----------------| (bo_offset=n) 1 b 2 req: |-----| (bo_offset=m) 0 a 1 b 2 a' 3 new: |-----|-----|-----| (a.bo_offset=n,b.bo_offset=m,a'.bo_offset=n+2)}hjZ<sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMWhjG<ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXtRequested mapping is a contiguous subset of the existing one. Split it up, but indicate that the backing PTEs could be kept. :: 0 a 3 old: |-----------------| (bo_offset=n) 1 a 2 req: |-----| (bo_offset=n+1) 0 a' 1 a 2 a'' 3 old: |-----|-----|-----| (a'.bo_offset=n, a.bo_offset=n+1, a''.bo_offset=n+2) h](h)}(h|Requested mapping is a contiguous subset of the existing one. Split it up, but indicate that the backing PTEs could be kept.h]h|Requested mapping is a contiguous subset of the existing one. Split it up, but indicate that the backing PTEs could be kept.}(hjs<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMahjo<ubjT)}(h 0 a 3 old: |-----------------| (bo_offset=n) 1 a 2 req: |-----| (bo_offset=n+1) 0 a' 1 a 2 a'' 3 old: |-----|-----|-----| (a'.bo_offset=n, a.bo_offset=n+1, a''.bo_offset=n+2)h]h 0 a 3 old: |-----------------| (bo_offset=n) 1 a 2 req: |-----| (bo_offset=n+1) 0 a' 1 a 2 a'' 3 old: |-----|-----|-----| (a'.bo_offset=n, a.bo_offset=n+1, a''.bo_offset=n+2)}hj<sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMfhjo<ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXExistent mapping is a right aligned subset of the requested one, hence replace the existing one. :: 1 a 2 old: |-----| (bo_offset=n+1) 0 a 2 req: |-----------| (bo_offset=n) 0 a 2 new: |-----------| (bo_offset=n) .. note:: We expect to see the same result for a request with a different bo and/or non-contiguous bo_offset. h](h)}(h`Existent mapping is a right aligned subset of the requested one, hence replace the existing one.h]h`Existent mapping is a right aligned subset of the requested one, hence replace the existing one.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMphj<ubjT)}(h 1 a 2 old: |-----| (bo_offset=n+1) 0 a 2 req: |-----------| (bo_offset=n) 0 a 2 new: |-----------| (bo_offset=n)h]h 1 a 2 old: |-----| (bo_offset=n+1) 0 a 2 req: |-----------| (bo_offset=n) 0 a 2 new: |-----------| (bo_offset=n)}hj<sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMuhj<ubj;)}(hcWe expect to see the same result for a request with a different bo and/or non-contiguous bo_offset.h]h)}(hcWe expect to see the same result for a request with a different bo and/or non-contiguous bo_offset.h]hcWe expect to see the same result for a request with a different bo and/or non-contiguous bo_offset.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj<ubah}(h]h ]h"]h$]h&]uh1j;hj<ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXExistent mapping is a centered subset of the requested one, hence replace the existing one. :: 1 a 2 old: |-----| (bo_offset=n+1) 0 a 3 req: |----------------| (bo_offset=n) 0 a 3 new: |----------------| (bo_offset=n) .. note:: We expect to see the same result for a request with a different bo and/or non-contiguous bo_offset. h](h)}(h[Existent mapping is a centered subset of the requested one, hence replace the existing one.h]h[Existent mapping is a centered subset of the requested one, hence replace the existing one.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj<ubjT)}(h 1 a 2 old: |-----| (bo_offset=n+1) 0 a 3 req: |----------------| (bo_offset=n) 0 a 3 new: |----------------| (bo_offset=n)h]h 1 a 2 old: |-----| (bo_offset=n+1) 0 a 3 req: |----------------| (bo_offset=n) 0 a 3 new: |----------------| (bo_offset=n)}hj<sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj<ubj;)}(hcWe expect to see the same result for a request with a different bo and/or non-contiguous bo_offset.h]h)}(hcWe expect to see the same result for a request with a different bo and/or non-contiguous bo_offset.h]hcWe expect to see the same result for a request with a different bo and/or non-contiguous bo_offset.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj<ubah}(h]h ]h"]h$]h&]uh1j;hj<ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubj{)}(hXExistent mappings is overlapped at the beginning by the requested mapping backed by a different BO. Hence, map the requested mapping and split up the existing one, adjusting its BO offset accordingly. :: 1 a 3 old: |-----------| (bo_offset=n) 0 b 2 req: |-----------| (bo_offset=m) 0 b 2 a' 3 new: |-----------|-----| (b.bo_offset=m,a.bo_offset=n+2) h](h)}(hExistent mappings is overlapped at the beginning by the requested mapping backed by a different BO. Hence, map the requested mapping and split up the existing one, adjusting its BO offset accordingly.h]hExistent mappings is overlapped at the beginning by the requested mapping backed by a different BO. Hence, map the requested mapping and split up the existing one, adjusting its BO offset accordingly.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj=ubjT)}(h 1 a 3 old: |-----------| (bo_offset=n) 0 b 2 req: |-----------| (bo_offset=m) 0 b 2 a' 3 new: |-----------|-----| (b.bo_offset=m,a.bo_offset=n+2)h]h 1 a 3 old: |-----------| (bo_offset=n) 0 b 2 req: |-----------| (bo_offset=m) 0 b 2 a' 3 new: |-----------|-----| (b.bo_offset=m,a.bo_offset=n+2)}hj,=sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:500: ./drivers/gpu/drm/drm_gpuvm.chMhj=ubeh}(h]h ]h"]h$]h&]uh1j{hj:ubeh}(h]h ]h"]h$]h&]enumtypearabicprefixhsuffixjuh1j~:hj7hhhNhNubj)}(h.. _drm_gpuvm_locking:h]h}(h]h ]h"]h$]h&]jʫdrm-gpuvm-lockinguh1jhMhj7hhhhubeh}(h]split-and-mergeah ]h"]split and mergeah$]h&]uh1hhj0hhhhhMubh)}(hhh](h)}(hLockingh]hLocking}(hja=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^=hhhhhMubh)}(hXeIn terms of managing :c:type:`drm_gpuva` entries DRM GPUVM does not take care of locking itself, it is the drivers responsibility to take care about locking. Drivers might want to protect the following operations: inserting, removing and iterating :c:type:`drm_gpuva` objects as well as generating all kinds of operations, such as split / merge or prefetch.h](hIn terms of managing }(hjo=hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjy=h]h drm_gpuva}(hj{=hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjw=ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhjo=ubh entries DRM GPUVM does not take care of locking itself, it is the drivers responsibility to take care about locking. Drivers might want to protect the following operations: inserting, removing and iterating }(hjo=hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj=h]h drm_gpuva}(hj=hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj=hMhjo=ubhZ objects as well as generating all kinds of operations, such as split / merge or prefetch.}(hjo=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj=hMhj^=hhubh)}(hXDRM GPUVM also does not take care of the locking of the backing :c:type:`drm_gem_object` buffers GPU VA lists and :c:type:`drm_gpuvm_bo` abstractions by itself; drivers are responsible to enforce mutual exclusion using either the GEMs dma_resv lock or the GEMs gpuva.lock mutex.h](h@DRM GPUVM also does not take care of the locking of the backing }(hj=hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj=h]hdrm_gem_object}(hj=hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhj=ubh buffers GPU VA lists and }(hj=hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj=h]h drm_gpuvm_bo}(hj=hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj=hMhj=ubh abstractions by itself; drivers are responsible to enforce mutual exclusion using either the GEMs dma_resv lock or the GEMs gpuva.lock mutex.}(hj=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj=hMhj^=hhubh)}(hXHowever, DRM GPUVM contains lockdep checks to ensure callers of its API hold the corresponding lock whenever the :c:type:`drm_gem_objects` GPU VA list is accessed by functions such as drm_gpuva_link() or drm_gpuva_unlink(), but also drm_gpuvm_bo_obtain() and drm_gpuvm_bo_put().h](hqHowever, DRM GPUVM contains lockdep checks to ensure callers of its API hold the corresponding lock whenever the }(hj>hhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hj#>h]hdrm_gem_objects}(hj%>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj!>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhj>ubh GPU VA list is accessed by functions such as drm_gpuva_link() or drm_gpuva_unlink(), but also drm_gpuvm_bo_obtain() and drm_gpuvm_bo_put().}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj@>hMhj^=hhubh)}(hXThe latter is required since on creation and destruction of a :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuvm_bo` is attached / removed from the :c:type:`drm_gem_objects` gpuva list. Subsequent calls to drm_gpuvm_bo_obtain() for the same :c:type:`drm_gpuvm` and :c:type:`drm_gem_object` must be able to observe previous creations and destructions of :c:type:`drm_gpuvm_bos` in order to keep instances unique.h](h>The latter is required since on creation and destruction of a }(hjK>hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjU>h]h drm_gpuvm_bo}(hjW>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjS>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhjK>ubh the }(hjK>hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjy>h]h drm_gpuvm_bo}(hj{>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjw>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjr>hMhjK>ubh is attached / removed from the }(hjK>hhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hj>h]hdrm_gem_objects}(hj>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhjr>hMhjK>ubhD gpuva list. Subsequent calls to drm_gpuvm_bo_obtain() for the same }(hjK>hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj>h]h drm_gpuvm}(hj>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjr>hMhjK>ubh and }(hjK>hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj>h]hdrm_gem_object}(hj>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjr>hMhjK>ubh@ must be able to observe previous creations and destructions of }(hjK>hhhNhNubh)}(h:c:type:`drm_gpuvm_bos`h]j)}(hj?h]h drm_gpuvm_bos}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bosuh1hhjr>hMhjK>ubh# in order to keep instances unique.}(hjK>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjr>hMhj^=hhubh)}(hThe :c:type:`drm_gpuvm`'s lists for keeping track of external and evicted objects are protected against concurrent insertion / removal and iteration internally.h](hThe }(hj,?hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj6?h]h drm_gpuvm}(hj8?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj4?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhj,?ubh’s lists for keeping track of external and evicted objects are protected against concurrent insertion / removal and iteration internally.}(hj,?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjS?hMhj^=hhubh)}(hHowever, drivers still need ensure to protect concurrent calls to functions iterating those lists, namely drm_gpuvm_prepare_objects() and drm_gpuvm_validate().h]hHowever, drivers still need ensure to protect concurrent calls to functions iterating those lists, namely drm_gpuvm_prepare_objects() and drm_gpuvm_validate().}(hj^?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhj^=hhubh)}(hXAlternatively, drivers can set the :c:type:`DRM_GPUVM_RESV_PROTECTED` flag to indicate that the corresponding :c:type:`dma_resv` locks are held in order to protect the lists. If :c:type:`DRM_GPUVM_RESV_PROTECTED` is set, internal locking is disabled and the corresponding lockdep checks are enabled. This is an optimization for drivers which are capable of taking the corresponding :c:type:`dma_resv` locks and hence do not require internal locking.h](h#Alternatively, drivers can set the }(hjm?hhhNhNubh)}(h":c:type:`DRM_GPUVM_RESV_PROTECTED`h]j)}(hjw?h]hDRM_GPUVM_RESV_PROTECTED}(hjy?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhju?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_GPUVM_RESV_PROTECTEDuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:508: ./drivers/gpu/drm/drm_gpuvm.chMhjm?ubh) flag to indicate that the corresponding }(hjm?hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj?h]hdma_resv}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhj?hMhjm?ubh2 locks are held in order to protect the lists. If }(hjm?hhhNhNubh)}(h":c:type:`DRM_GPUVM_RESV_PROTECTED`h]j)}(hj?h]hDRM_GPUVM_RESV_PROTECTED}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_GPUVM_RESV_PROTECTEDuh1hhj?hMhjm?ubh is set, internal locking is disabled and the corresponding lockdep checks are enabled. This is an optimization for drivers which are capable of taking the corresponding }(hjm?hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj?h]hdma_resv}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhj?hMhjm?ubh1 locks and hence do not require internal locking.}(hjm?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj?hMhj^=hhubeh}(h](lockingjU=eh ]h"](lockingdrm_gpuvm_lockingeh$]h&]uh1hhj0hhhhhMj}j@jK=sj}jU=jK=subh)}(hhh](h)}(hExamplesh]hExamples}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hhhhhMubh)}(hThis section gives two examples on how to let the DRM GPUVA Manager generate :c:type:`drm_gpuva_op` in order to satisfy a given map or unmap request and how to make use of them.h](hMThis section gives two examples on how to let the DRM GPUVA Manager generate }(hj$@hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hj.@h]h drm_gpuva_op}(hj0@hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj,@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:514: ./drivers/gpu/drm/drm_gpuvm.chMhj$@ubhN in order to satisfy a given map or unmap request and how to make use of them.}(hj$@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjK@hMhj@hhubh)}(hXFThe below code is strictly limited to illustrate the generic usage pattern. To maintain simplicity, it doesn't make use of any abstractions for common code, different (asynchronous) stages with fence signalling critical paths, any other helpers or error handling in terms of freeing memory and dropping previously taken locks.h]hXHThe below code is strictly limited to illustrate the generic usage pattern. To maintain simplicity, it doesn’t make use of any abstractions for common code, different (asynchronous) stages with fence signalling critical paths, any other helpers or error handling in terms of freeing memory and dropping previously taken locks.}(hjV@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:514: ./drivers/gpu/drm/drm_gpuvm.chMhj@hhubj:)}(hhh](j{)}(hX Obtain a list of :c:type:`drm_gpuva_op` to create a new mapping:: // Allocates a new &drm_gpuva. struct drm_gpuva * driver_gpuva_alloc(void); // Typically drivers would embed the &drm_gpuvm and &drm_gpuva // structure in individual driver structures and lock the dma-resv with // drm_exec or similar helpers. int driver_mapping_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range, struct drm_gem_object *obj, u64 offset) { struct drm_gpuvm_map_req map_req = { .map.va.addr = addr, .map.va.range = range, .map.gem.obj = obj, .map.gem.offset = offset, }; struct drm_gpuva_ops *ops; struct drm_gpuva_op *op struct drm_gpuvm_bo *vm_bo; driver_lock_va_space(); ops = drm_gpuvm_sm_map_ops_create(gpuvm, &map_req); if (IS_ERR(ops)) return PTR_ERR(ops); vm_bo = drm_gpuvm_bo_obtain(gpuvm, obj); if (IS_ERR(vm_bo)) return PTR_ERR(vm_bo); drm_gpuva_for_each_op(op, ops) { struct drm_gpuva *va; switch (op->op) { case DRM_GPUVA_OP_MAP: va = driver_gpuva_alloc(); if (!va) ; // unwind previous VA space updates, // free memory and unlock driver_vm_map(); drm_gpuva_map(gpuvm, va, &op->map); drm_gpuva_link(va, vm_bo); break; case DRM_GPUVA_OP_REMAP: { struct drm_gpuva *prev = NULL, *next = NULL; va = op->remap.unmap->va; if (op->remap.prev) { prev = driver_gpuva_alloc(); if (!prev) ; // unwind previous VA space // updates, free memory and // unlock } if (op->remap.next) { next = driver_gpuva_alloc(); if (!next) ; // unwind previous VA space // updates, free memory and // unlock } driver_vm_remap(); drm_gpuva_remap(prev, next, &op->remap); if (prev) drm_gpuva_link(prev, va->vm_bo); if (next) drm_gpuva_link(next, va->vm_bo); drm_gpuva_unlink(va); break; } case DRM_GPUVA_OP_UNMAP: va = op->unmap->va; driver_vm_unmap(); drm_gpuva_unlink(va); drm_gpuva_unmap(&op->unmap); break; default: break; } } drm_gpuvm_bo_put(vm_bo); driver_unlock_va_space(); return 0; } h](h)}(hAObtain a list of :c:type:`drm_gpuva_op` to create a new mapping::h](hObtain a list of }(hjl@hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjv@h]h drm_gpuva_op}(hjx@hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjt@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:514: ./drivers/gpu/drm/drm_gpuvm.chMhjl@ubh to create a new mapping:}(hjl@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj@hMhjh@ubjT)}(hX // Allocates a new &drm_gpuva. struct drm_gpuva * driver_gpuva_alloc(void); // Typically drivers would embed the &drm_gpuvm and &drm_gpuva // structure in individual driver structures and lock the dma-resv with // drm_exec or similar helpers. int driver_mapping_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range, struct drm_gem_object *obj, u64 offset) { struct drm_gpuvm_map_req map_req = { .map.va.addr = addr, .map.va.range = range, .map.gem.obj = obj, .map.gem.offset = offset, }; struct drm_gpuva_ops *ops; struct drm_gpuva_op *op struct drm_gpuvm_bo *vm_bo; driver_lock_va_space(); ops = drm_gpuvm_sm_map_ops_create(gpuvm, &map_req); if (IS_ERR(ops)) return PTR_ERR(ops); vm_bo = drm_gpuvm_bo_obtain(gpuvm, obj); if (IS_ERR(vm_bo)) return PTR_ERR(vm_bo); drm_gpuva_for_each_op(op, ops) { struct drm_gpuva *va; switch (op->op) { case DRM_GPUVA_OP_MAP: va = driver_gpuva_alloc(); if (!va) ; // unwind previous VA space updates, // free memory and unlock driver_vm_map(); drm_gpuva_map(gpuvm, va, &op->map); drm_gpuva_link(va, vm_bo); break; case DRM_GPUVA_OP_REMAP: { struct drm_gpuva *prev = NULL, *next = NULL; va = op->remap.unmap->va; if (op->remap.prev) { prev = driver_gpuva_alloc(); if (!prev) ; // unwind previous VA space // updates, free memory and // unlock } if (op->remap.next) { next = driver_gpuva_alloc(); if (!next) ; // unwind previous VA space // updates, free memory and // unlock } driver_vm_remap(); drm_gpuva_remap(prev, next, &op->remap); if (prev) drm_gpuva_link(prev, va->vm_bo); if (next) drm_gpuva_link(next, va->vm_bo); drm_gpuva_unlink(va); break; } case DRM_GPUVA_OP_UNMAP: va = op->unmap->va; driver_vm_unmap(); drm_gpuva_unlink(va); drm_gpuva_unmap(&op->unmap); break; default: break; } } drm_gpuvm_bo_put(vm_bo); driver_unlock_va_space(); return 0; }h]hX // Allocates a new &drm_gpuva. struct drm_gpuva * driver_gpuva_alloc(void); // Typically drivers would embed the &drm_gpuvm and &drm_gpuva // structure in individual driver structures and lock the dma-resv with // drm_exec or similar helpers. int driver_mapping_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range, struct drm_gem_object *obj, u64 offset) { struct drm_gpuvm_map_req map_req = { .map.va.addr = addr, .map.va.range = range, .map.gem.obj = obj, .map.gem.offset = offset, }; struct drm_gpuva_ops *ops; struct drm_gpuva_op *op struct drm_gpuvm_bo *vm_bo; driver_lock_va_space(); ops = drm_gpuvm_sm_map_ops_create(gpuvm, &map_req); if (IS_ERR(ops)) return PTR_ERR(ops); vm_bo = drm_gpuvm_bo_obtain(gpuvm, obj); if (IS_ERR(vm_bo)) return PTR_ERR(vm_bo); drm_gpuva_for_each_op(op, ops) { struct drm_gpuva *va; switch (op->op) { case DRM_GPUVA_OP_MAP: va = driver_gpuva_alloc(); if (!va) ; // unwind previous VA space updates, // free memory and unlock driver_vm_map(); drm_gpuva_map(gpuvm, va, &op->map); drm_gpuva_link(va, vm_bo); break; case DRM_GPUVA_OP_REMAP: { struct drm_gpuva *prev = NULL, *next = NULL; va = op->remap.unmap->va; if (op->remap.prev) { prev = driver_gpuva_alloc(); if (!prev) ; // unwind previous VA space // updates, free memory and // unlock } if (op->remap.next) { next = driver_gpuva_alloc(); if (!next) ; // unwind previous VA space // updates, free memory and // unlock } driver_vm_remap(); drm_gpuva_remap(prev, next, &op->remap); if (prev) drm_gpuva_link(prev, va->vm_bo); if (next) drm_gpuva_link(next, va->vm_bo); drm_gpuva_unlink(va); break; } case DRM_GPUVA_OP_UNMAP: va = op->unmap->va; driver_vm_unmap(); drm_gpuva_unlink(va); drm_gpuva_unmap(&op->unmap); break; default: break; } } drm_gpuvm_bo_put(vm_bo); driver_unlock_va_space(); return 0; }}hj@sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:514: ./drivers/gpu/drm/drm_gpuvm.chMhjh@ubeh}(h]h ]h"]h$]h&]uh1j{hje@ubj{)}(hX Receive a callback for each :c:type:`drm_gpuva_op` to create a new mapping:: struct driver_context { struct drm_gpuvm *gpuvm; struct drm_gpuvm_bo *vm_bo; struct drm_gpuva *new_va; struct drm_gpuva *prev_va; struct drm_gpuva *next_va; }; // ops to pass to drm_gpuvm_init() static const struct drm_gpuvm_ops driver_gpuvm_ops = { .sm_step_map = driver_gpuva_map, .sm_step_remap = driver_gpuva_remap, .sm_step_unmap = driver_gpuva_unmap, }; // Typically drivers would embed the &drm_gpuvm and &drm_gpuva // structure in individual driver structures and lock the dma-resv with // drm_exec or similar helpers. int driver_mapping_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range, struct drm_gem_object *obj, u64 offset) { struct driver_context ctx; struct drm_gpuvm_bo *vm_bo; struct drm_gpuva_ops *ops; struct drm_gpuva_op *op; int ret = 0; ctx.gpuvm = gpuvm; ctx.new_va = kzalloc(sizeof(*ctx.new_va), GFP_KERNEL); ctx.prev_va = kzalloc(sizeof(*ctx.prev_va), GFP_KERNEL); ctx.next_va = kzalloc(sizeof(*ctx.next_va), GFP_KERNEL); ctx.vm_bo = drm_gpuvm_bo_create(gpuvm, obj); if (!ctx.new_va || !ctx.prev_va || !ctx.next_va || !vm_bo) { ret = -ENOMEM; goto out; } // Typically protected with a driver specific GEM gpuva lock // used in the fence signaling path for drm_gpuva_link() and // drm_gpuva_unlink(), hence pre-allocate. ctx.vm_bo = drm_gpuvm_bo_obtain_prealloc(ctx.vm_bo); driver_lock_va_space(); ret = drm_gpuvm_sm_map(gpuvm, &ctx, addr, range, obj, offset); driver_unlock_va_space(); out: drm_gpuvm_bo_put(ctx.vm_bo); kfree(ctx.new_va); kfree(ctx.prev_va); kfree(ctx.next_va); return ret; } int driver_gpuva_map(struct drm_gpuva_op *op, void *__ctx) { struct driver_context *ctx = __ctx; drm_gpuva_map(ctx->vm, ctx->new_va, &op->map); drm_gpuva_link(ctx->new_va, ctx->vm_bo); // prevent the new GPUVA from being freed in // driver_mapping_create() ctx->new_va = NULL; return 0; } int driver_gpuva_remap(struct drm_gpuva_op *op, void *__ctx) { struct driver_context *ctx = __ctx; struct drm_gpuva *va = op->remap.unmap->va; drm_gpuva_remap(ctx->prev_va, ctx->next_va, &op->remap); if (op->remap.prev) { drm_gpuva_link(ctx->prev_va, va->vm_bo); ctx->prev_va = NULL; } if (op->remap.next) { drm_gpuva_link(ctx->next_va, va->vm_bo); ctx->next_va = NULL; } drm_gpuva_unlink(va); kfree(va); return 0; } int driver_gpuva_unmap(struct drm_gpuva_op *op, void *__ctx) { drm_gpuva_unlink(op->unmap.va); drm_gpuva_unmap(&op->unmap); kfree(op->unmap.va); return 0; } h](h)}(hLReceive a callback for each :c:type:`drm_gpuva_op` to create a new mapping::h](hReceive a callback for each }(hj@hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hj@h]h drm_gpuva_op}(hj@hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:514: ./drivers/gpu/drm/drm_gpuvm.chM|hj@ubh to create a new mapping:}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj@hM|hj@ubjT)}(hX struct driver_context { struct drm_gpuvm *gpuvm; struct drm_gpuvm_bo *vm_bo; struct drm_gpuva *new_va; struct drm_gpuva *prev_va; struct drm_gpuva *next_va; }; // ops to pass to drm_gpuvm_init() static const struct drm_gpuvm_ops driver_gpuvm_ops = { .sm_step_map = driver_gpuva_map, .sm_step_remap = driver_gpuva_remap, .sm_step_unmap = driver_gpuva_unmap, }; // Typically drivers would embed the &drm_gpuvm and &drm_gpuva // structure in individual driver structures and lock the dma-resv with // drm_exec or similar helpers. int driver_mapping_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range, struct drm_gem_object *obj, u64 offset) { struct driver_context ctx; struct drm_gpuvm_bo *vm_bo; struct drm_gpuva_ops *ops; struct drm_gpuva_op *op; int ret = 0; ctx.gpuvm = gpuvm; ctx.new_va = kzalloc(sizeof(*ctx.new_va), GFP_KERNEL); ctx.prev_va = kzalloc(sizeof(*ctx.prev_va), GFP_KERNEL); ctx.next_va = kzalloc(sizeof(*ctx.next_va), GFP_KERNEL); ctx.vm_bo = drm_gpuvm_bo_create(gpuvm, obj); if (!ctx.new_va || !ctx.prev_va || !ctx.next_va || !vm_bo) { ret = -ENOMEM; goto out; } // Typically protected with a driver specific GEM gpuva lock // used in the fence signaling path for drm_gpuva_link() and // drm_gpuva_unlink(), hence pre-allocate. ctx.vm_bo = drm_gpuvm_bo_obtain_prealloc(ctx.vm_bo); driver_lock_va_space(); ret = drm_gpuvm_sm_map(gpuvm, &ctx, addr, range, obj, offset); driver_unlock_va_space(); out: drm_gpuvm_bo_put(ctx.vm_bo); kfree(ctx.new_va); kfree(ctx.prev_va); kfree(ctx.next_va); return ret; } int driver_gpuva_map(struct drm_gpuva_op *op, void *__ctx) { struct driver_context *ctx = __ctx; drm_gpuva_map(ctx->vm, ctx->new_va, &op->map); drm_gpuva_link(ctx->new_va, ctx->vm_bo); // prevent the new GPUVA from being freed in // driver_mapping_create() ctx->new_va = NULL; return 0; } int driver_gpuva_remap(struct drm_gpuva_op *op, void *__ctx) { struct driver_context *ctx = __ctx; struct drm_gpuva *va = op->remap.unmap->va; drm_gpuva_remap(ctx->prev_va, ctx->next_va, &op->remap); if (op->remap.prev) { drm_gpuva_link(ctx->prev_va, va->vm_bo); ctx->prev_va = NULL; } if (op->remap.next) { drm_gpuva_link(ctx->next_va, va->vm_bo); ctx->next_va = NULL; } drm_gpuva_unlink(va); kfree(va); return 0; } int driver_gpuva_unmap(struct drm_gpuva_op *op, void *__ctx) { drm_gpuva_unlink(op->unmap.va); drm_gpuva_unmap(&op->unmap); kfree(op->unmap.va); return 0; }h]hX struct driver_context { struct drm_gpuvm *gpuvm; struct drm_gpuvm_bo *vm_bo; struct drm_gpuva *new_va; struct drm_gpuva *prev_va; struct drm_gpuva *next_va; }; // ops to pass to drm_gpuvm_init() static const struct drm_gpuvm_ops driver_gpuvm_ops = { .sm_step_map = driver_gpuva_map, .sm_step_remap = driver_gpuva_remap, .sm_step_unmap = driver_gpuva_unmap, }; // Typically drivers would embed the &drm_gpuvm and &drm_gpuva // structure in individual driver structures and lock the dma-resv with // drm_exec or similar helpers. int driver_mapping_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range, struct drm_gem_object *obj, u64 offset) { struct driver_context ctx; struct drm_gpuvm_bo *vm_bo; struct drm_gpuva_ops *ops; struct drm_gpuva_op *op; int ret = 0; ctx.gpuvm = gpuvm; ctx.new_va = kzalloc(sizeof(*ctx.new_va), GFP_KERNEL); ctx.prev_va = kzalloc(sizeof(*ctx.prev_va), GFP_KERNEL); ctx.next_va = kzalloc(sizeof(*ctx.next_va), GFP_KERNEL); ctx.vm_bo = drm_gpuvm_bo_create(gpuvm, obj); if (!ctx.new_va || !ctx.prev_va || !ctx.next_va || !vm_bo) { ret = -ENOMEM; goto out; } // Typically protected with a driver specific GEM gpuva lock // used in the fence signaling path for drm_gpuva_link() and // drm_gpuva_unlink(), hence pre-allocate. ctx.vm_bo = drm_gpuvm_bo_obtain_prealloc(ctx.vm_bo); driver_lock_va_space(); ret = drm_gpuvm_sm_map(gpuvm, &ctx, addr, range, obj, offset); driver_unlock_va_space(); out: drm_gpuvm_bo_put(ctx.vm_bo); kfree(ctx.new_va); kfree(ctx.prev_va); kfree(ctx.next_va); return ret; } int driver_gpuva_map(struct drm_gpuva_op *op, void *__ctx) { struct driver_context *ctx = __ctx; drm_gpuva_map(ctx->vm, ctx->new_va, &op->map); drm_gpuva_link(ctx->new_va, ctx->vm_bo); // prevent the new GPUVA from being freed in // driver_mapping_create() ctx->new_va = NULL; return 0; } int driver_gpuva_remap(struct drm_gpuva_op *op, void *__ctx) { struct driver_context *ctx = __ctx; struct drm_gpuva *va = op->remap.unmap->va; drm_gpuva_remap(ctx->prev_va, ctx->next_va, &op->remap); if (op->remap.prev) { drm_gpuva_link(ctx->prev_va, va->vm_bo); ctx->prev_va = NULL; } if (op->remap.next) { drm_gpuva_link(ctx->next_va, va->vm_bo); ctx->next_va = NULL; } drm_gpuva_unlink(va); kfree(va); return 0; } int driver_gpuva_unmap(struct drm_gpuva_op *op, void *__ctx) { drm_gpuva_unlink(op->unmap.va); drm_gpuva_unmap(&op->unmap); kfree(op->unmap.va); return 0; }}hj@sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:514: ./drivers/gpu/drm/drm_gpuvm.chM~hj@ubeh}(h]h ]h"]h$]h&]uh1j{hje@ubeh}(h]h ]h"]h$]h&]jG=jH=jI=hjJ=juh1j~:hj@hhhNhNubeh}(h]examplesah ]h"]examplesah$]h&]uh1hhj0hhhhhMubh)}(hhh](h)}(hDRM GPUVM Function Referencesh]hDRM GPUVM Function References}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj AhhhhhMubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_flags (C enum)c.drm_gpuva_flagshNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_flagsh]j>)}(henum drm_gpuva_flagsh](jD)}(hjGh]henum}(hj6AhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj2AhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKubjV)}(h h]h }(hjDAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2AhhhjCAhKubjg)}(hdrm_gpuva_flagsh]jm)}(hj0Ah]hdrm_gpuva_flags}(hjVAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRAubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj2AhhhjCAhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj.AhhhjCAhKubah}(h]j)Aah ](jjeh"]h$]h&]jj)jhuh1j7hjCAhKhj+Ahhubj)}(hhh]h)}(hflags for struct drm_gpuvah]hflags for struct drm_gpuva}(hjxAhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK+hjuAhhubah}(h]h ]h"]h$]h&]uh1jhj+AhhhjCAhKubeh}(h]h ](jenumeh"]h$]h&]jjjjAjjAjjjuh1j2hhhj AhNhNubj)}(h**Constants** ``DRM_GPUVA_INVALIDATED`` Flag indicating that the :c:type:`drm_gpuva`'s backing GEM is invalidated. ``DRM_GPUVA_SPARSE`` Flag indicating that the :c:type:`drm_gpuva` is a sparse mapping. ``DRM_GPUVA_USERBITS`` user defined bitsh](h)}(h **Constants**h]j)}(hjAh]h Constants}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK/hjAubj)}(hhh](j)}(he``DRM_GPUVA_INVALIDATED`` Flag indicating that the :c:type:`drm_gpuva`'s backing GEM is invalidated. h](j)}(h``DRM_GPUVA_INVALIDATED``h]j)}(hjAh]hDRM_GPUVA_INVALIDATED}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK2hjAubj )}(hhh]h)}(hJFlag indicating that the :c:type:`drm_gpuva`'s backing GEM is invalidated.h](hFlag indicating that the }(hjAhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjAh]h drm_gpuva}(hjAhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjAhK2hjAubh ’s backing GEM is invalidated.}(hjAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjAhK2hjAubah}(h]h ]h"]h$]h&]uh1j hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhK2hjAubj)}(hW``DRM_GPUVA_SPARSE`` Flag indicating that the :c:type:`drm_gpuva` is a sparse mapping. h](j)}(h``DRM_GPUVA_SPARSE``h]j)}(hjBh]hDRM_GPUVA_SPARSE}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK5hjBubj )}(hhh]h)}(hAFlag indicating that the :c:type:`drm_gpuva` is a sparse mapping.h](hFlag indicating that the }(hj.BhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj8Bh]h drm_gpuva}(hj:BhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj6Bubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj*BhK5hj.Bubh is a sparse mapping.}(hj.BhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj*BhK5hj+Bubah}(h]h ]h"]h$]h&]uh1j hjBubeh}(h]h ]h"]h$]h&]uh1jhj*BhK5hjAubj)}(h(``DRM_GPUVA_USERBITS`` user defined bitsh](j)}(h``DRM_GPUVA_USERBITS``h]j)}(hjqBh]hDRM_GPUVA_USERBITS}(hjsBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoBubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK7hjkBubj )}(hhh]h)}(huser defined bitsh]huser defined bits}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK8hjBubah}(h]h ]h"]h$]h&]uh1j hjkBubeh}(h]h ]h"]h$]h&]uh1jhjBhK7hjAubeh}(h]h ]h"]h$]h&]uh1jhjAubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva (C struct) c.drm_gpuvahNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuvah]j>)}(hstruct drm_gpuvah](jD)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjBhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK=ubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBhhhjBhK=ubjg)}(h drm_gpuvah]jm)}(hjBh]h drm_gpuva}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjBhhhjBhK=ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjBhhhjBhK=ubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1j7hjBhK=hjBhhubj)}(hhh]h)}(h#structure to track a GPU VA mappingh]h#structure to track a GPU VA mapping}(hj ChhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKChj Chhubah}(h]h ]h"]h$]h&]uh1jhjBhhhjBhK=ubeh}(h]h ](jstructeh"]h$]h&]jjjj%Cjj%Cjjjuh1j2hhhj AhNhNubj)}(hX**Definition**:: struct drm_gpuva { struct drm_gpuvm *vm; struct drm_gpuvm_bo *vm_bo; enum drm_gpuva_flags flags; struct { u64 addr; u64 range; } va; struct { u64 offset; struct drm_gem_object *obj; struct list_head entry; } gem; struct { struct rb_node node; struct list_head entry; u64 __subtree_last; } rb; }; **Members** ``vm`` the :c:type:`drm_gpuvm` this object is associated with ``vm_bo`` the :c:type:`drm_gpuvm_bo` abstraction for the mapped :c:type:`drm_gem_object` ``flags`` the :c:type:`drm_gpuva_flags` for this mapping ``va`` structure containing the address and range of the :c:type:`drm_gpuva` ``va.addr`` the start address ``gem`` structure containing the :c:type:`drm_gem_object` and its offset ``gem.offset`` the offset within the :c:type:`drm_gem_object` ``gem.obj`` the mapped :c:type:`drm_gem_object` ``gem.entry`` the :c:type:`list_head` to attach this object to a :c:type:`drm_gpuvm_bo` ``rb`` structure containing data to store :c:type:`drm_gpuvas` in a rb-tree ``rb.node`` the rb-tree node ``rb.entry`` The :c:type:`list_head` to additionally connect :c:type:`drm_gpuvas` in the same order they appear in the interval tree. This is useful to keep iterating :c:type:`drm_gpuvas` from a start node found through the rb-tree while doing modifications on the rb-tree itself. ``rb.__subtree_last`` needed by the interval tree, holding last-in-subtreeh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj1ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-Cubh:}(hj-ChhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKGhj)CubjT)}(hXstruct drm_gpuva { struct drm_gpuvm *vm; struct drm_gpuvm_bo *vm_bo; enum drm_gpuva_flags flags; struct { u64 addr; u64 range; } va; struct { u64 offset; struct drm_gem_object *obj; struct list_head entry; } gem; struct { struct rb_node node; struct list_head entry; u64 __subtree_last; } rb; };h]hXstruct drm_gpuva { struct drm_gpuvm *vm; struct drm_gpuvm_bo *vm_bo; enum drm_gpuva_flags flags; struct { u64 addr; u64 range; } va; struct { u64 offset; struct drm_gem_object *obj; struct list_head entry; } gem; struct { struct rb_node node; struct list_head entry; u64 __subtree_last; } rb; };}hjJCsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKIhj)Cubh)}(h **Members**h]j)}(hj[Ch]hMembers}(hj]ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYCubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK]hj)Cubj)}(hhh](j)}(h>``vm`` the :c:type:`drm_gpuvm` this object is associated with h](j)}(h``vm``h]j)}(hjzCh]hvm}(hj|ChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxCubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKMhjtCubj )}(hhh]h)}(h6the :c:type:`drm_gpuvm` this object is associated withh](hthe }(hjChhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjCh]h drm_gpuvm}(hjChhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjChKMhjCubh this object is associated with}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChKMhjCubah}(h]h ]h"]h$]h&]uh1j hjtCubeh}(h]h ]h"]h$]h&]uh1jhjChKMhjqCubj)}(hY``vm_bo`` the :c:type:`drm_gpuvm_bo` abstraction for the mapped :c:type:`drm_gem_object` h](j)}(h ``vm_bo``h]j)}(hjCh]hvm_bo}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKShjCubj )}(hhh]h)}(hNthe :c:type:`drm_gpuvm_bo` abstraction for the mapped :c:type:`drm_gem_object`h](hthe }(hjChhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjCh]h drm_gpuvm_bo}(hjChhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKRhjCubh abstraction for the mapped }(hjChhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjDh]hdrm_gem_object}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjDhKRhjCubeh}(h]h ]h"]h$]h&]uh1hhjDhKRhjCubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhjChKShjqCubj)}(h9``flags`` the :c:type:`drm_gpuva_flags` for this mapping h](j)}(h ``flags``h]j)}(hjRDh]hflags}(hjTDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPDubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKXhjLDubj )}(hhh]h)}(h.the :c:type:`drm_gpuva_flags` for this mappingh](hthe }(hjkDhhhNhNubh)}(h:c:type:`drm_gpuva_flags`h]j)}(hjuDh]hdrm_gpuva_flags}(hjwDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjsDubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_flagsuh1hhjgDhKXhjkDubh for this mapping}(hjkDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjgDhKXhjhDubah}(h]h ]h"]h$]h&]uh1j hjLDubeh}(h]h ]h"]h$]h&]uh1jhjgDhKXhjqCubj)}(hM``va`` structure containing the address and range of the :c:type:`drm_gpuva` h](j)}(h``va``h]j)}(hjDh]hva}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhK]hjDubj )}(hhh]h)}(hEstructure containing the address and range of the :c:type:`drm_gpuva`h](h2structure containing the address and range of the }(hjDhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjDh]h drm_gpuva}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjDhK]hjDubeh}(h]h ]h"]h$]h&]uh1hhjDhK]hjDubah}(h]h ]h"]h$]h&]uh1j hjDubeh}(h]h ]h"]h$]h&]uh1jhjDhK]hjqCubj)}(h``va.addr`` the start address h](j)}(h ``va.addr``h]j)}(hjEh]hva.addr}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKahjEubj )}(hhh]h)}(hthe start addressh]hthe start address}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEhKahjEubah}(h]h ]h"]h$]h&]uh1j hjEubeh}(h]h ]h"]h$]h&]uh1jhjEhKahjqCubj)}(hI``gem`` structure containing the :c:type:`drm_gem_object` and its offset h](j)}(h``gem``h]j)}(hj?Eh]hgem}(hjAEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=Eubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKlhj9Eubj )}(hhh]h)}(h@structure containing the :c:type:`drm_gem_object` and its offseth](hstructure containing the }(hjXEhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjbEh]hdrm_gem_object}(hjdEhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj`Eubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjTEhKlhjXEubh and its offset}(hjXEhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjTEhKlhjUEubah}(h]h ]h"]h$]h&]uh1j hj9Eubeh}(h]h ]h"]h$]h&]uh1jhjTEhKlhjqCubj)}(h>``gem.offset`` the offset within the :c:type:`drm_gem_object` h](j)}(h``gem.offset``h]j)}(hjEh]h gem.offset}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKphjEubj )}(hhh]h)}(h.the offset within the :c:type:`drm_gem_object`h](hthe offset within the }(hjEhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjEh]hdrm_gem_object}(hjEhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjEhKphjEubeh}(h]h ]h"]h$]h&]uh1hhjEhKphjEubah}(h]h ]h"]h$]h&]uh1j hjEubeh}(h]h ]h"]h$]h&]uh1jhjEhKphjqCubj)}(h0``gem.obj`` the mapped :c:type:`drm_gem_object` h](j)}(h ``gem.obj``h]j)}(hjEh]hgem.obj}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKuhjEubj )}(hhh]h)}(h#the mapped :c:type:`drm_gem_object`h](h the mapped }(hj FhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjFh]hdrm_gem_object}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjFhKuhj Fubeh}(h]h ]h"]h$]h&]uh1hhjFhKuhj Fubah}(h]h ]h"]h$]h&]uh1j hjEubeh}(h]h ]h"]h$]h&]uh1jhjFhKuhjqCubj)}(hX``gem.entry`` the :c:type:`list_head` to attach this object to a :c:type:`drm_gpuvm_bo` h](j)}(h ``gem.entry``h]j)}(hjKFh]h gem.entry}(hjMFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIFubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKzhjEFubj )}(hhh]h)}(hIthe :c:type:`list_head` to attach this object to a :c:type:`drm_gpuvm_bo`h](hthe }(hjdFhhhNhNubh)}(h:c:type:`list_head`h]j)}(hjnFh]h list_head}(hjpFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjlFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headuh1hhj`FhKzhjdFubh to attach this object to a }(hjdFhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjFh]h drm_gpuvm_bo}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj`FhKzhjdFubeh}(h]h ]h"]h$]h&]uh1hhj`FhKzhjaFubah}(h]h ]h"]h$]h&]uh1j hjEFubeh}(h]h ]h"]h$]h&]uh1jhj`FhKzhjqCubj)}(hL``rb`` structure containing data to store :c:type:`drm_gpuvas` in a rb-tree h](j)}(h``rb``h]j)}(hjFh]hrb}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjFubj )}(hhh]h)}(hDstructure containing data to store :c:type:`drm_gpuvas` in a rb-treeh](h#structure containing data to store }(hjFhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjFh]h drm_gpuvas}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhjFhKhjFubh in a rb-tree}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjFhKhjFubah}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhjFhKhjqCubj)}(h``rb.node`` the rb-tree node h](j)}(h ``rb.node``h]j)}(hj"Gh]hrb.node}(hj$GhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Gubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjGubj )}(hhh]h)}(hthe rb-tree nodeh]hthe rb-tree node}(hj;GhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7GhKhj8Gubah}(h]h ]h"]h$]h&]uh1j hjGubeh}(h]h ]h"]h$]h&]uh1jhj7GhKhjqCubj)}(hX``rb.entry`` The :c:type:`list_head` to additionally connect :c:type:`drm_gpuvas` in the same order they appear in the interval tree. This is useful to keep iterating :c:type:`drm_gpuvas` from a start node found through the rb-tree while doing modifications on the rb-tree itself. h](j)}(h ``rb.entry``h]j)}(hj[Gh]hrb.entry}(hj]GhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYGubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjUGubj )}(hhh]h)}(hX The :c:type:`list_head` to additionally connect :c:type:`drm_gpuvas` in the same order they appear in the interval tree. This is useful to keep iterating :c:type:`drm_gpuvas` from a start node found through the rb-tree while doing modifications on the rb-tree itself.h](hThe }(hjtGhhhNhNubh)}(h:c:type:`list_head`h]j)}(hj~Gh]h list_head}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|Gubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjtGubh to additionally connect }(hjtGhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjGh]h drm_gpuvas}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhjGhKhjtGubhV in the same order they appear in the interval tree. This is useful to keep iterating }(hjtGhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjGh]h drm_gpuvas}(hjGhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhjGhKhjtGubh] from a start node found through the rb-tree while doing modifications on the rb-tree itself.}(hjtGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjGhKhjqGubah}(h]h ]h"]h$]h&]uh1j hjUGubeh}(h]h ]h"]h$]h&]uh1jhjpGhKhjqCubj)}(hJ``rb.__subtree_last`` needed by the interval tree, holding last-in-subtreeh](j)}(h``rb.__subtree_last``h]j)}(hjGh]hrb.__subtree_last}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjGubj )}(hhh]h)}(h4needed by the interval tree, holding last-in-subtreeh]h4needed by the interval tree, holding last-in-subtree}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjHubah}(h]h ]h"]h$]h&]uh1j hjGubeh}(h]h ]h"]h$]h&]uh1jhjHhKhjqCubeh}(h]h ]h"]h$]h&]uh1jhj)Cubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjAHh]h Description}(hjCHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?Hubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhj Ahhubh)}(hXThis structure represents a GPU VA mapping and is associated with a :c:type:`drm_gpuvm`.h](hDThis structure represents a GPU VA mapping and is associated with a }(hjWHhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjaHh]h drm_gpuvm}(hjcHhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj_Hubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKDhjWHubh.}(hjWHhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~HhKDhj Ahhubh)}(hBTypically, this structure is embedded in bigger driver structures.h]hBTypically, this structure is embedded in bigger driver structures.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKGhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gpuva_invalidate (C function)c.drm_gpuva_invalidatehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hAvoid drm_gpuva_invalidate (struct drm_gpuva *va, bool invalidate)h]j>)}(h@void drm_gpuva_invalidate(struct drm_gpuva *va, bool invalidate)h](j)}(hvoidh]hvoid}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHhhhjHhKubjg)}(hdrm_gpuva_invalidateh]jm)}(hdrm_gpuva_invalidateh]hdrm_gpuva_invalidate}(hjHhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjHhhhjHhKubj)}(h'(struct drm_gpuva *va, bool invalidate)h](j)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hjHhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjHubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hj IhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj Iubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjImodnameN classnameNjj)}j]j )}jjHsbc.drm_gpuva_invalidateasbuh1hhjHubjV)}(h h]h }(hj,IhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubj4)}(hj7h]h*}(hj:IhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjHubjm)}(hvah]hva}(hjGIhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubj)}(hbool invalidateh](j)}(hj*h]hbool}(hj`IhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\IubjV)}(h h]h }(hjmIhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\Iubjm)}(h invalidateh]h invalidate}(hj{IhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\Iubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubeh}(h]h ]h"]h$]h&]jjuh1jhjHhhhjHhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjHhhhjHhKubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1j7hjHhKhjHhhubj)}(hhh]h)}(hGsets whether the backing GEM of this :c:type:`drm_gpuva` is invalidatedh](h%sets whether the backing GEM of this }(hjIhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjIh]h drm_gpuva}(hjIhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j(Ic.drm_gpuva_invalidateasbjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjIubh is invalidated}(hjIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjIhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhjHhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjIjjIjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to set the invalidate flag for ``bool invalidate`` indicates whether the :c:type:`drm_gpuva` is invalidatedh](h)}(h**Parameters**h]j)}(hjIh]h Parameters}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjIubj)}(hhh](j)}(hP``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to set the invalidate flag for h](j)}(h``struct drm_gpuva *va``h]j)}(hjJh]hstruct drm_gpuva *va}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj Jubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhj Jubj )}(hhh]h)}(h6the :c:type:`drm_gpuva` to set the invalidate flag forh](hthe }(hj(JhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj2Jh]h drm_gpuva}(hj4JhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj0Jubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj$JhKhj(Jubh to set the invalidate flag for}(hj(JhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$JhKhj%Jubah}(h]h ]h"]h$]h&]uh1j hj Jubeh}(h]h ]h"]h$]h&]uh1jhj$JhKhjJubj)}(hL``bool invalidate`` indicates whether the :c:type:`drm_gpuva` is invalidatedh](j)}(h``bool invalidate``h]j)}(hjkJh]hbool invalidate}(hjmJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiJubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjeJubj )}(hhh]h)}(h8indicates whether the :c:type:`drm_gpuva` is invalidatedh](hindicates whether the }(hjJhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjJh]h drm_gpuva}(hjJhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjJubh is invalidated}(hjJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjJhKhjJubah}(h]h ]h"]h$]h&]uh1j hjeJubeh}(h]h ]h"]h$]h&]uh1jhjJhKhjJubeh}(h]h ]h"]h$]h&]uh1jhjIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gpuva_invalidated (C function)c.drm_gpuva_invalidatedhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h1bool drm_gpuva_invalidated (struct drm_gpuva *va)h]j>)}(h0bool drm_gpuva_invalidated(struct drm_gpuva *va)h](j)}(hj*h]hbool}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhjJhKubjg)}(hdrm_gpuva_invalidatedh]jm)}(hdrm_gpuva_invalidatedh]hdrm_gpuva_invalidated}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjKubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjJhhhjJhKubj)}(h(struct drm_gpuva *va)h]j)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hj$KhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj KubjV)}(h h]h }(hj1KhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj Kubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjBKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?Kubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjDKmodnameN classnameNjj)}j]j )}jj Ksbc.drm_gpuva_invalidatedasbuh1hhj KubjV)}(h h]h }(hjbKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj Kubj4)}(hj7h]h*}(hjpKhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj Kubjm)}(hvah]hva}(hj}KhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj Kubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjKubah}(h]h ]h"]h$]h&]jjuh1jhjJhhhjJhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjJhhhjJhKubah}(h]jJah ](jjeh"]h$]h&]jj)jhuh1j7hjJhKhjJhhubj)}(hhh]h)}(hKindicates whether the backing BO of this :c:type:`drm_gpuva` is invalidatedh](h)indicates whether the backing BO of this }(hjKhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjKh]h drm_gpuva}(hjKhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j^Kc.drm_gpuva_invalidatedasbjM drm_gpuvauh1hhjIhKhjKubh is invalidated}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjKhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjJhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjKjjKjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to check **Return** ``true`` if the GPU VA is invalidated, ``false`` otherwiseh](h)}(h**Parameters**h]j)}(hjKh]h Parameters}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjKubj)}(hhh]j)}(h:``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to check h](j)}(h``struct drm_gpuva *va``h]j)}(hjLh]hstruct drm_gpuva *va}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhj Lubj )}(hhh]h)}(h the :c:type:`drm_gpuva` to checkh](hthe }(hj)LhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj3Lh]h drm_gpuva}(hj5LhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1Lubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj%LhKhj)Lubh to check}(hj)LhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj%LhKhj&Lubah}(h]h ]h"]h$]h&]uh1j hj Lubeh}(h]h ]h"]h$]h&]uh1jhj%LhKhjLubah}(h]h ]h"]h$]h&]uh1jhjKubh)}(h **Return**h]j)}(hjnLh]hReturn}(hjpLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlLubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjKubh)}(h:``true`` if the GPU VA is invalidated, ``false`` otherwiseh](j)}(h``true``h]htrue}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubh if the GPU VA is invalidated, }(hjLhhhNhNubj)}(h ``false``h]hfalse}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubh otherwise}(hjLhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_flags (C enum)c.drm_gpuvm_flagshNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_flagsh]j>)}(henum drm_gpuvm_flagsh](jD)}(hjGh]henum}(hjLhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjLhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLhhhjLhKubjg)}(hdrm_gpuvm_flagsh]jm)}(hjLh]hdrm_gpuvm_flags}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjLhhhjLhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjLhhhjLhKubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1j7hjLhKhjLhhubj)}(hhh]h)}(hflags for struct drm_gpuvmh]hflags for struct drm_gpuvm}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjMhhubah}(h]h ]h"]h$]h&]uh1jhjLhhhjLhKubeh}(h]h ](jenumeh"]h$]h&]jjjj-Mjj-Mjjjuh1j2hhhj AhNhNubj)}(hX**Constants** ``DRM_GPUVM_RESV_PROTECTED`` GPUVM is protected externally by the GPUVM's :c:type:`dma_resv` lock ``DRM_GPUVM_IMMEDIATE_MODE`` use the locking scheme for GEMs designed for modifying the GPUVM during the fence signalling path When set, gpuva.lock is used to protect gpuva.list in all GEM objects associated with this GPUVM. Otherwise, the GEMs dma-resv is used. ``DRM_GPUVM_USERBITS`` user defined bitsh](h)}(h **Constants**h]j)}(hj7Mh]h Constants}(hj9MhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5Mubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhj1Mubj)}(hhh](j)}(hb``DRM_GPUVM_RESV_PROTECTED`` GPUVM is protected externally by the GPUVM's :c:type:`dma_resv` lock h](j)}(h``DRM_GPUVM_RESV_PROTECTED``h]j)}(hjVMh]hDRM_GPUVM_RESV_PROTECTED}(hjXMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTMubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjPMubj )}(hhh]h)}(hDGPUVM is protected externally by the GPUVM's :c:type:`dma_resv` lockh](h/GPUVM is protected externally by the GPUVM’s }(hjoMhhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjyMh]hdma_resv}(hj{MhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjwMubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjoMubh lock}(hjoMhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjMhKhjlMubah}(h]h ]h"]h$]h&]uh1j hjPMubeh}(h]h ]h"]h$]h&]uh1jhjkMhKhjMMubj)}(hX``DRM_GPUVM_IMMEDIATE_MODE`` use the locking scheme for GEMs designed for modifying the GPUVM during the fence signalling path When set, gpuva.lock is used to protect gpuva.list in all GEM objects associated with this GPUVM. Otherwise, the GEMs dma-resv is used. h](j)}(h``DRM_GPUVM_IMMEDIATE_MODE``h]j)}(hjMh]hDRM_GPUVM_IMMEDIATE_MODE}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjMubj )}(hhh](h)}(hause the locking scheme for GEMs designed for modifying the GPUVM during the fence signalling pathh]hause the locking scheme for GEMs designed for modifying the GPUVM during the fence signalling path}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjMubh)}(hWhen set, gpuva.lock is used to protect gpuva.list in all GEM objects associated with this GPUVM. Otherwise, the GEMs dma-resv is used.h]hWhen set, gpuva.lock is used to protect gpuva.list in all GEM objects associated with this GPUVM. Otherwise, the GEMs dma-resv is used.}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjMubeh}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjMhKhjMMubj)}(h(``DRM_GPUVM_USERBITS`` user defined bitsh](j)}(h``DRM_GPUVM_USERBITS``h]j)}(hjMh]hDRM_GPUVM_USERBITS}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjMubj )}(hhh]h)}(huser defined bitsh]huser defined bits}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjNubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjNhKhjMMubeh}(h]h ]h"]h$]h&]uh1jhj1Mubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm (C struct) c.drm_gpuvmhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuvmh]j>)}(hstruct drm_gpuvmh](jD)}(hjh]hstruct}(hjVNhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjRNhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKubjV)}(h h]h }(hjdNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRNhhhjcNhKubjg)}(h drm_gpuvmh]jm)}(hjPNh]h drm_gpuvm}(hjvNhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjrNubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjRNhhhjcNhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjNNhhhjcNhKubah}(h]jINah ](jjeh"]h$]h&]jj)jhuh1j7hjcNhKhjKNhhubj)}(hhh]h)}(hDRM GPU VA Managerh]hDRM GPU VA Manager}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjNhhubah}(h]h ]h"]h$]h&]uh1jhjKNhhhjcNhKubeh}(h]h ](jstructeh"]h$]h&]jjjjNjjNjjjuh1j2hhhj AhNhNubj)}(hX]**Definition**:: struct drm_gpuvm { const char *name; enum drm_gpuvm_flags flags; struct drm_device *drm; u64 mm_start; u64 mm_range; struct { struct rb_root_cached tree; struct list_head list; } rb; struct kref kref; struct drm_gpuva kernel_alloc_node; const struct drm_gpuvm_ops *ops; struct drm_gem_object *r_obj; struct { struct list_head list; struct list_head *local_list; spinlock_t lock; } extobj; struct { struct list_head list; struct list_head *local_list; spinlock_t lock; } evict; struct llist_head bo_defer; }; **Members** ``name`` the name of the DRM GPU VA space ``flags`` the :c:type:`drm_gpuvm_flags` of this GPUVM ``drm`` the :c:type:`drm_device` this VM lives in ``mm_start`` start of the VA space ``mm_range`` length of the VA space ``rb`` structures to track :c:type:`drm_gpuva` entries ``rb.tree`` the rb-tree to track GPU VA mappings ``rb.list`` the :c:type:`list_head` to track GPU VA mappings ``kref`` reference count of this object ``kernel_alloc_node`` :c:type:`drm_gpuva` representing the address space cutout reserved for the kernel ``ops`` :c:type:`drm_gpuvm_ops` providing the split/merge steps to drivers ``r_obj`` Resv GEM object; representing the GPUVM's common :c:type:`dma_resv`. ``extobj`` structure holding the extobj list ``extobj.list`` :c:type:`list_head` storing :c:type:`drm_gpuvm_bos` serving as external object ``extobj.local_list`` pointer to the local list temporarily storing entries from the external object list ``extobj.lock`` spinlock to protect the extobj list ``evict`` structure holding the evict list and evict list lock ``evict.list`` :c:type:`list_head` storing :c:type:`drm_gpuvm_bos` currently being evicted ``evict.local_list`` pointer to the local list temporarily storing entries from the evicted object list ``evict.lock`` spinlock to protect the evict list ``bo_defer`` structure holding vm_bos that need to be destroyedh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubh:}(hjNhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjNubjT)}(hX{struct drm_gpuvm { const char *name; enum drm_gpuvm_flags flags; struct drm_device *drm; u64 mm_start; u64 mm_range; struct { struct rb_root_cached tree; struct list_head list; } rb; struct kref kref; struct drm_gpuva kernel_alloc_node; const struct drm_gpuvm_ops *ops; struct drm_gem_object *r_obj; struct { struct list_head list; struct list_head *local_list; spinlock_t lock; } extobj; struct { struct list_head list; struct list_head *local_list; spinlock_t lock; } evict; struct llist_head bo_defer; };h]hX{struct drm_gpuvm { const char *name; enum drm_gpuvm_flags flags; struct drm_device *drm; u64 mm_start; u64 mm_range; struct { struct rb_root_cached tree; struct list_head list; } rb; struct kref kref; struct drm_gpuva kernel_alloc_node; const struct drm_gpuvm_ops *ops; struct drm_gem_object *r_obj; struct { struct list_head list; struct list_head *local_list; spinlock_t lock; } extobj; struct { struct list_head list; struct list_head *local_list; spinlock_t lock; } evict; struct llist_head bo_defer; };}hjNsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjNubh)}(h **Members**h]j)}(hjNh]hMembers}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjNubj)}(hhh](j)}(h*``name`` the name of the DRM GPU VA space h](j)}(h``name``h]j)}(hjOh]hname}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjNubj )}(hhh]h)}(h the name of the DRM GPU VA spaceh]h the name of the DRM GPU VA space}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjOhKhjOubah}(h]h ]h"]h$]h&]uh1j hjNubeh}(h]h ]h"]h$]h&]uh1jhjOhKhjNubj)}(h6``flags`` the :c:type:`drm_gpuvm_flags` of this GPUVM h](j)}(h ``flags``h]j)}(hj>Oh]hflags}(hj@OhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj representing the address space cutout reserved for the kernel}(hjQhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjQhMhjQubah}(h]h ]h"]h$]h&]uh1j hjQubeh}(h]h ]h"]h$]h&]uh1jhjQhMhjNubj)}(hK``ops`` :c:type:`drm_gpuvm_ops` providing the split/merge steps to drivers h](j)}(h``ops``h]j)}(hjQh]hops}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjQubj )}(hhh]h)}(hB:c:type:`drm_gpuvm_ops` providing the split/merge steps to driversh](h)}(h:c:type:`drm_gpuvm_ops`h]j)}(hj Rh]h drm_gpuvm_ops}(hj RhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhjRhMhjRubh+ providing the split/merge steps to drivers}(hjRhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjRhMhjRubah}(h]h ]h"]h$]h&]uh1j hjQubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjNubj)}(hO``r_obj`` Resv GEM object; representing the GPUVM's common :c:type:`dma_resv`. h](j)}(h ``r_obj``h]j)}(hjCRh]hr_obj}(hjERhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjARubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM"hj=Rubj )}(hhh]h)}(hDResv GEM object; representing the GPUVM's common :c:type:`dma_resv`.h](h3Resv GEM object; representing the GPUVM’s common }(hj\RhhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjfRh]hdma_resv}(hjhRhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjdRubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhjXRhM"hj\Rubh.}(hj\RhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjXRhM"hjYRubah}(h]h ]h"]h$]h&]uh1j hj=Rubeh}(h]h ]h"]h$]h&]uh1jhjXRhM"hjNubj)}(h-``extobj`` structure holding the extobj list h](j)}(h ``extobj``h]j)}(hjRh]hextobj}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM'hjRubj )}(hhh]h)}(h!structure holding the extobj listh]h!structure holding the extobj list}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhM'hjRubah}(h]h ]h"]h$]h&]uh1j hjRubeh}(h]h ]h"]h$]h&]uh1jhjRhM'hjNubj)}(h_``extobj.list`` :c:type:`list_head` storing :c:type:`drm_gpuvm_bos` serving as external object h](j)}(h``extobj.list``h]j)}(hjRh]h extobj.list}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM,hjRubj )}(hhh]h)}(hN:c:type:`list_head` storing :c:type:`drm_gpuvm_bos` serving as external objecth](h)}(h:c:type:`list_head`h]j)}(hjRh]h list_head}(hjRhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM+hjRubh storing }(hjRhhhNhNubh)}(h:c:type:`drm_gpuvm_bos`h]j)}(hjSh]h drm_gpuvm_bos}(hjShhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bosuh1hhjShM+hjRubh serving as external object}(hjRhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjShM+hjRubah}(h]h ]h"]h$]h&]uh1j hjRubeh}(h]h ]h"]h$]h&]uh1jhjRhM,hjNubj)}(hj``extobj.local_list`` pointer to the local list temporarily storing entries from the external object list h](j)}(h``extobj.local_list``h]j)}(hjTSh]hextobj.local_list}(hjVShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRSubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM2hjNSubj )}(hhh]h)}(hSpointer to the local list temporarily storing entries from the external object listh]hSpointer to the local list temporarily storing entries from the external object list}(hjmShhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM1hjjSubah}(h]h ]h"]h$]h&]uh1j hjNSubeh}(h]h ]h"]h$]h&]uh1jhjiShM2hjNubj)}(h4``extobj.lock`` spinlock to protect the extobj list h](j)}(h``extobj.lock``h]j)}(hjSh]h extobj.lock}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM7hjSubj )}(hhh]h)}(h#spinlock to protect the extobj listh]h#spinlock to protect the extobj list}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShM7hjSubah}(h]h ]h"]h$]h&]uh1j hjSubeh}(h]h ]h"]h$]h&]uh1jhjShM7hjNubj)}(h?``evict`` structure holding the evict list and evict list lock h](j)}(h ``evict``h]j)}(hjSh]hevict}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM=hjSubj )}(hhh]h)}(h4structure holding the evict list and evict list lockh]h4structure holding the evict list and evict list lock}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShM=hjSubah}(h]h ]h"]h$]h&]uh1j hjSubeh}(h]h ]h"]h$]h&]uh1jhjShM=hjNubj)}(h[``evict.list`` :c:type:`list_head` storing :c:type:`drm_gpuvm_bos` currently being evicted h](j)}(h``evict.list``h]j)}(hjTh]h evict.list}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMBhjSubj )}(hhh]h)}(hK:c:type:`list_head` storing :c:type:`drm_gpuvm_bos` currently being evictedh](h)}(h:c:type:`list_head`h]j)}(hjTh]h list_head}(hj!ThhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMAhjTubh storing }(hjThhhNhNubh)}(h:c:type:`drm_gpuvm_bos`h]j)}(hjCTh]h drm_gpuvm_bos}(hjEThhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjATubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bosuh1hhj)}(h8struct drm_gpuvm *drm_gpuvm_get(struct drm_gpuvm *gpuvm)h](jD)}(hjh]hstruct}(hjUhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjUhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM`ubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUhhhjUhM`ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjUmodnameN classnameNjj)}j]j )}j drm_gpuvm_getsbc.drm_gpuvm_getasbuh1hhjUhhhjUhM`ubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUhhhjUhM`ubj4)}(hj7h]h*}(hjUhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjUhhhjUhM`ubjg)}(h drm_gpuvm_geth]jm)}(hjUh]h drm_gpuvm_get}(hjVhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj Vubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjUhhhjUhM`ubj)}(h(struct drm_gpuvm *gpuvm)h]j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj+VhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj'VubjV)}(h h]h }(hj8VhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj'Vubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjIVhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFVubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjKVmodnameN classnameNjj)}j]jUc.drm_gpuvm_getasbuh1hhj'VubjV)}(h h]h }(hjgVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj'Vubj4)}(hj7h]h*}(hjuVhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj'Vubjm)}(hgpuvmh]hgpuvm}(hjVhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj'Vubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj#Vubah}(h]h ]h"]h$]h&]jjuh1jhjUhhhjUhM`ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjUhhhjUhM`ubah}(h]jUah ](jjeh"]h$]h&]jj)jhuh1j7hjUhM`hjUhhubj)}(hhh]h)}(h$acquire a struct drm_gpuvm referenceh]h$acquire a struct drm_gpuvm reference}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM`hjVhhubah}(h]h ]h"]h$]h&]uh1jhjUhhhjUhM`ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjVjjVjjjuh1j2hhhj AhNhNubj)}(hXC**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to acquire the reference of **Description** This function acquires an additional reference to **gpuvm**. It is illegal to call this without already holding a reference. No locks required. **Return** the :c:type:`struct drm_gpuvm ` pointerh](h)}(h**Parameters**h]j)}(hjVh]h Parameters}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMdhjVubj)}(hhh]j)}(hP``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to acquire the reference of h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjVh]hstruct drm_gpuvm *gpuvm}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMahjVubj )}(hhh]h)}(h3the :c:type:`drm_gpuvm` to acquire the reference ofh](hthe }(hjWhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjWh]h drm_gpuvm}(hjWhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjWhMahjWubh to acquire the reference of}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjWhMahjWubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjWhMahjVubah}(h]h ]h"]h$]h&]uh1jhjVubh)}(h**Description**h]j)}(hjKWh]h Description}(hjMWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIWubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMchjVubh)}(hThis function acquires an additional reference to **gpuvm**. It is illegal to call this without already holding a reference. No locks required.h](h2This function acquires an additional reference to }(hjaWhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hjiWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaWubhT. It is illegal to call this without already holding a reference. No locks required.}(hjaWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMbhjVubh)}(h **Return**h]j)}(hjWh]hReturn}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMehjVubh)}(h2the :c:type:`struct drm_gpuvm ` pointerh](hthe }(hjWhhhNhNubh)}(h&:c:type:`struct drm_gpuvm `h]j)}(hjWh]hstruct drm_gpuvm}(hjWhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMfhjWubh pointer}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjWhMfhjVubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gpuvm_resv_protected (C function)c.drm_gpuvm_resv_protectedhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h7bool drm_gpuvm_resv_protected (struct drm_gpuvm *gpuvm)h]j>)}(h6bool drm_gpuvm_resv_protected(struct drm_gpuvm *gpuvm)h](j)}(hj*h]hbool}(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMyubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWhhhjWhMyubjg)}(hdrm_gpuvm_resv_protectedh]jm)}(hdrm_gpuvm_resv_protectedh]hdrm_gpuvm_resv_protected}(hj XhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjWhhhjWhMyubj)}(h(struct drm_gpuvm *gpuvm)h]j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj(XhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$XubjV)}(h h]h }(hj5XhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$Xubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjFXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCXubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjHXmodnameN classnameNjj)}j]j )}jjXsbc.drm_gpuvm_resv_protectedasbuh1hhj$XubjV)}(h h]h }(hjfXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$Xubj4)}(hj7h]h*}(hjtXhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$Xubjm)}(hgpuvmh]hgpuvm}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$Xubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj Xubah}(h]h ]h"]h$]h&]jjuh1jhjWhhhjWhMyubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjWhhhjWhMyubah}(h]jWah ](jjeh"]h$]h&]jj)jhuh1j7hjWhMyhjWhhubj)}(hhh]h)}(h;indicates whether :c:type:`DRM_GPUVM_RESV_PROTECTED` is seth](hindicates whether }(hjXhhhNhNubh)}(h":c:type:`DRM_GPUVM_RESV_PROTECTED`h]j)}(hjXh]hDRM_GPUVM_RESV_PROTECTED}(hjXhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jbXc.drm_gpuvm_resv_protectedasbjMDRM_GPUVM_RESV_PROTECTEDuh1hhjIhKhjXubh is set}(hjXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMyhjXhhubah}(h]h ]h"]h$]h&]uh1jhjWhhhjWhMyubeh}(h]h ](jfunctioneh"]h$]h&]jjjjXjjXjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` **Return** true if :c:type:`DRM_GPUVM_RESV_PROTECTED` is set, false otherwise.h](h)}(h**Parameters**h]j)}(hjXh]h Parameters}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM}hjXubj)}(hhh]j)}(h4``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjYh]hstruct drm_gpuvm *gpuvm}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM{hjYubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hj-YhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj7Yh]h drm_gpuvm}(hj9YhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj5Yubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj)YhM{hj-Yubeh}(h]h ]h"]h$]h&]uh1hhj)YhM{hj*Yubah}(h]h ]h"]h$]h&]uh1j hjYubeh}(h]h ]h"]h$]h&]uh1jhj)YhM{hj Yubah}(h]h ]h"]h$]h&]uh1jhjXubh)}(h **Return**h]j)}(hjnYh]hReturn}(hjpYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlYubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM}hjXubh)}(hCtrue if :c:type:`DRM_GPUVM_RESV_PROTECTED` is set, false otherwise.h](htrue if }(hjYhhhNhNubh)}(h":c:type:`DRM_GPUVM_RESV_PROTECTED`h]j)}(hjYh]hDRM_GPUVM_RESV_PROTECTED}(hjYhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_GPUVM_RESV_PROTECTEDuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM}hjYubh is set, false otherwise.}(hjYhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjYhM}hjXubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gpuvm_immediate_mode (C function)c.drm_gpuvm_immediate_modehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h7bool drm_gpuvm_immediate_mode (struct drm_gpuvm *gpuvm)h]j>)}(h6bool drm_gpuvm_immediate_mode(struct drm_gpuvm *gpuvm)h](j)}(hj*h]hbool}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjYhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjYhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjYhhhjYhMubjg)}(hdrm_gpuvm_immediate_modeh]jm)}(hdrm_gpuvm_immediate_modeh]hdrm_gpuvm_immediate_mode}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjYhhhjYhMubj)}(h(struct drm_gpuvm *gpuvm)h]j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjZhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjZubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj0ZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-Zubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj2ZmodnameN classnameNjj)}j]j )}jjYsbc.drm_gpuvm_immediate_modeasbuh1hhjZubjV)}(h h]h }(hjPZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubj4)}(hj7h]h*}(hj^ZhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjZubjm)}(hgpuvmh]hgpuvm}(hjkZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj Zubah}(h]h ]h"]h$]h&]jjuh1jhjYhhhjYhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjYhhhjYhMubah}(h]jYah ](jjeh"]h$]h&]jj)jhuh1j7hjYhMhjYhhubj)}(hhh]h)}(h;indicates whether :c:type:`DRM_GPUVM_IMMEDIATE_MODE` is seth](hindicates whether }(hjZhhhNhNubh)}(h":c:type:`DRM_GPUVM_IMMEDIATE_MODE`h]j)}(hjZh]hDRM_GPUVM_IMMEDIATE_MODE}(hjZhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jLZc.drm_gpuvm_immediate_modeasbjMDRM_GPUVM_IMMEDIATE_MODEuh1hhjIhKhjZubh is set}(hjZhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjZhhubah}(h]h ]h"]h$]h&]uh1jhjYhhhjYhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjZjjZjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` **Return** true if :c:type:`DRM_GPUVM_IMMEDIATE_MODE` is set, false otherwise.h](h)}(h**Parameters**h]j)}(hjZh]h Parameters}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjZubj)}(hhh]j)}(h4``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjZh]hstruct drm_gpuvm *gpuvm}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjZubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hj[hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj![h]h drm_gpuvm}(hj#[hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj[hMhj[ubeh}(h]h ]h"]h$]h&]uh1hhj[hMhj[ubah}(h]h ]h"]h$]h&]uh1j hjZubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjZubah}(h]h ]h"]h$]h&]uh1jhjZubh)}(h **Return**h]j)}(hjX[h]hReturn}(hjZ[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjV[ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjZubh)}(hCtrue if :c:type:`DRM_GPUVM_IMMEDIATE_MODE` is set, false otherwise.h](htrue if }(hjn[hhhNhNubh)}(h":c:type:`DRM_GPUVM_IMMEDIATE_MODE`h]j)}(hjx[h]hDRM_GPUVM_IMMEDIATE_MODE}(hjz[hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjv[ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMDRM_GPUVM_IMMEDIATE_MODEuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjn[ubh is set, false otherwise.}(hjn[hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj[hMhjZubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_resv (C macro)c.drm_gpuvm_resvhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_resvh]j>)}(hdrm_gpuvm_resvh]jg)}(hdrm_gpuvm_resvh]jm)}(hj[h]hdrm_gpuvm_resv}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj[hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj[hhhj[hMubah}(h]j[ah ](jjeh"]h$]h&]jj)jhuh1j7hj[hMhj[hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj[hhhj[hMubeh}(h]h ](jmacroeh"]h$]h&]jjjj[jj[jjjuh1j2hhhj AhNhNubh)}(h``drm_gpuvm_resv (gpuvm__)``h]j)}(hj[h]hdrm_gpuvm_resv (gpuvm__)}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h5returns the :c:type:`drm_gpuvm`'s :c:type:`dma_resv` h]h)}(h4returns the :c:type:`drm_gpuvm`'s :c:type:`dma_resv`h](h returns the }(hj\hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj\h]h drm_gpuvm}(hj\hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj\ubh’s }(hj\hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj>\h]hdma_resv}(hj@\hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<\ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhj7\hMhj\ubeh}(h]h ]h"]h$]h&]uh1hhj7\hMhj \ubah}(h]h ]h"]h$]h&]uh1jhj7\hMhj Ahhubj)}(h**Parameters** ``gpuvm__`` the :c:type:`drm_gpuvm` **Return** a pointer to the :c:type:`drm_gpuvm`'s shared :c:type:`dma_resv`h](h)}(h**Parameters**h]j)}(hjm\h]h Parameters}(hjo\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjk\ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjg\ubj)}(hhh]j)}(h$``gpuvm__`` the :c:type:`drm_gpuvm` h](j)}(h ``gpuvm__``h]j)}(hj\h]hgpuvm__}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj\ubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hj\hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj\h]h drm_gpuvm}(hj\hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj\hMhj\ubeh}(h]h ]h"]h$]h&]uh1hhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1j hj\ubeh}(h]h ]h"]h$]h&]uh1jhj\hMhj\ubah}(h]h ]h"]h$]h&]uh1jhjg\ubh)}(h **Return**h]j)}(hj\h]hReturn}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjg\ubh)}(h@a pointer to the :c:type:`drm_gpuvm`'s shared :c:type:`dma_resv`h](ha pointer to the }(hj\hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj]h]h drm_gpuvm}(hj]hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj\ubh ’s shared }(hj\hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj*]h]hdma_resv}(hj,]hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj(]ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhj#]hMhj\ubeh}(h]h ]h"]h$]h&]uh1hhj#]hMhjg\ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_resv_obj (C macro)c.drm_gpuvm_resv_objhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_resv_objh]j>)}(hdrm_gpuvm_resv_objh]jg)}(hdrm_gpuvm_resv_objh]jm)}(hjg]h]hdrm_gpuvm_resv_obj}(hjq]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjm]ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhji]hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhje]hhhj]hMubah}(h]j`]ah ](jjeh"]h$]h&]jj)jhuh1j7hj]hMhjb]hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjb]hhhj]hMubeh}(h]h ](jmacroeh"]h$]h&]jjjj]jj]jjjuh1j2hhhj AhNhNubh)}(h ``drm_gpuvm_resv_obj (gpuvm__)``h]j)}(hj]h]hdrm_gpuvm_resv_obj (gpuvm__)}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(hZreturns the :c:type:`drm_gem_object` holding the :c:type:`drm_gpuvm`'s :c:type:`dma_resv` h]h)}(hYreturns the :c:type:`drm_gem_object` holding the :c:type:`drm_gpuvm`'s :c:type:`dma_resv`h](h returns the }(hj]hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj]h]hdrm_gem_object}(hj]hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj]ubh holding the }(hj]hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj]h]h drm_gpuvm}(hj]hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj]hMhj]ubh’s }(hj]hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj^h]hdma_resv}(hj^hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ^ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhj]hMhj]ubeh}(h]h ]h"]h$]h&]uh1hhj]hMhj]ubah}(h]h ]h"]h$]h&]uh1jhj]hMhj Ahhubj)}(h**Parameters** ``gpuvm__`` the :c:type:`drm_gpuvm` **Return** a pointer to the :c:type:`drm_gem_object` holding the :c:type:`drm_gpuvm`'s shared :c:type:`dma_resv`h](h)}(h**Parameters**h]j)}(hj=^h]h Parameters}(hj?^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;^ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj7^ubj)}(hhh]j)}(h$``gpuvm__`` the :c:type:`drm_gpuvm` h](j)}(h ``gpuvm__``h]j)}(hj\^h]hgpuvm__}(hj^^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZ^ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjV^ubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hju^hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj^h]h drm_gpuvm}(hj^hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj}^ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjq^hMhju^ubeh}(h]h ]h"]h$]h&]uh1hhjq^hMhjr^ubah}(h]h ]h"]h$]h&]uh1j hjV^ubeh}(h]h ]h"]h$]h&]uh1jhjq^hMhjS^ubah}(h]h ]h"]h$]h&]uh1jhj7^ubh)}(h **Return**h]j)}(hj^h]hReturn}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj7^ubh)}(hea pointer to the :c:type:`drm_gem_object` holding the :c:type:`drm_gpuvm`'s shared :c:type:`dma_resv`h](ha pointer to the }(hj^hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj^h]hdrm_gem_object}(hj^hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj^ubh holding the }(hj^hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj^h]h drm_gpuvm}(hj^hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj^hMhj^ubh ’s shared }(hj^hhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hj_h]hdma_resv}(hj_hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhj^hMhj^ubeh}(h]h ]h"]h$]h&]uh1hhj^hMhj7^ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gpuvm_is_extobj (C function)c.drm_gpuvm_is_extobjhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hNbool drm_gpuvm_is_extobj (struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h]j>)}(hMbool drm_gpuvm_is_extobj(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](j)}(hj*h]hbool}(hj`_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\_hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjn_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\_hhhjm_hMubjg)}(hdrm_gpuvm_is_extobjh]jm)}(hdrm_gpuvm_is_extobjh]hdrm_gpuvm_is_extobj}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|_ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj\_hhhjm_hMubj)}(h5(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_modnameN classnameNjj)}j]j )}jj_sbc.drm_gpuvm_is_extobjasbuh1hhj_ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_ubj4)}(hj7h]h*}(hj_hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj_ubjm)}(hgpuvmh]hgpuvm}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj_ubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj`hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj `ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj `ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj,`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)`ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj.`modnameN classnameNjj)}j]j_c.drm_gpuvm_is_extobjasbuh1hhj `ubjV)}(h h]h }(hjJ`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj `ubj4)}(hj7h]h*}(hjX`hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj `ubjm)}(hobjh]hobj}(hje`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj `ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj_ubeh}(h]h ]h"]h$]h&]jjuh1jhj\_hhhjm_hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjX_hhhjm_hMubah}(h]jS_ah ](jjeh"]h$]h&]jj)jhuh1j7hjm_hMhjU_hhubj)}(hhh]h)}(hJindicates whether the given :c:type:`drm_gem_object` is an external objecth](hindicates whether the given }(hj`hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj`h]hdrm_gem_object}(hj`hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j_c.drm_gpuvm_is_extobjasbjMdrm_gem_objectuh1hhjIhKhj`ubh is an external object}(hj`hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj`hhubah}(h]h ]h"]h$]h&]uh1jhjU_hhhjm_hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj`jj`jjjuh1j2hhhj AhNhNubj)}(hX%**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to check ``struct drm_gem_object *obj`` the :c:type:`drm_gem_object` to check **Return** true if the :c:type:`drm_gem_object` :c:type:`dma_resv` differs from the :c:type:`drm_gpuvms` :c:type:`dma_resv`, false otherwiseh](h)}(h**Parameters**h]j)}(hj`h]h Parameters}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj`ubj)}(hhh](j)}(h=``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to check h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj`h]hstruct drm_gpuvm *gpuvm}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj`ubj )}(hhh]h)}(h the :c:type:`drm_gpuvm` to checkh](hthe }(hjahhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjah]h drm_gpuvm}(hjahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj ahMhjaubh to check}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj ahMhjaubah}(h]h ]h"]h$]h&]uh1j hj`ubeh}(h]h ]h"]h$]h&]uh1jhj ahMhj`ubj)}(hE``struct drm_gem_object *obj`` the :c:type:`drm_gem_object` to check h](j)}(h``struct drm_gem_object *obj``h]j)}(hjTah]hstruct drm_gem_object *obj}(hjVahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRaubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjNaubj )}(hhh]h)}(h%the :c:type:`drm_gem_object` to checkh](hthe }(hjmahhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjwah]hdrm_gem_object}(hjyahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjuaubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjiahMhjmaubh to check}(hjmahhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjiahMhjjaubah}(h]h ]h"]h$]h&]uh1j hjNaubeh}(h]h ]h"]h$]h&]uh1jhjiahMhj`ubeh}(h]h ]h"]h$]h&]uh1jhj`ubh)}(h **Return**h]j)}(hjah]hReturn}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj`ubh)}(htrue if the :c:type:`drm_gem_object` :c:type:`dma_resv` differs from the :c:type:`drm_gpuvms` :c:type:`dma_resv`, false otherwiseh](h true if the }(hjahhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjah]hdrm_gem_object}(hjahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjaubh }(hjahhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjah]hdma_resv}(hjahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhjahMhjaubh differs from the }(hjahhhNhNubh)}(h:c:type:`drm_gpuvms`h]j)}(hjbh]h drm_gpuvms}(hjbhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmsuh1hhjahMhjaubh }hjasbh)}(h:c:type:`dma_resv`h]j)}(hjbhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj:bubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhjahMhjaubh, false otherwise}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjahMhj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gpuvm_for_each_va_range (C macro)c.drm_gpuvm_for_each_va_rangehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_for_each_va_rangeh]j>)}(hdrm_gpuvm_for_each_va_rangeh]jg)}(hdrm_gpuvm_for_each_va_rangeh]jm)}(hj}bh]hdrm_gpuvm_for_each_va_range}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjbhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj{bhhhjbhMubah}(h]jvbah ](jjeh"]h$]h&]jj)jhuh1j7hjbhMhjxbhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjxbhhhjbhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjbjjbjjjuh1j2hhhj AhNhNubh)}(h?``drm_gpuvm_for_each_va_range (va__, gpuvm__, start__, end__)``h]j)}(hjbh]h;drm_gpuvm_for_each_va_range (va__, gpuvm__, start__, end__)}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h-iterate over a range of :c:type:`drm_gpuvas` h]h)}(h,iterate over a range of :c:type:`drm_gpuvas`h](hiterate over a range of }(hjbhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjbh]h drm_gpuvas}(hjbhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjbubeh}(h]h ]h"]h$]h&]uh1hhjbhMhjbubah}(h]h ]h"]h$]h&]uh1jhjbhMhj Ahhubj)}(hX8**Parameters** ``va__`` :c:type:`drm_gpuva` structure to assign to in each iteration step ``gpuvm__`` :c:type:`drm_gpuvm` to walk over ``start__`` starting offset, the first gpuva will overlap this ``end__`` ending offset, the last gpuva will start before this (but may overlap) **Description** This iterator walks over all :c:type:`drm_gpuvas` in the :c:type:`drm_gpuvm` that lie between **start__** and **end__**. It is implemented similarly to list_for_each(), but is using the :c:type:`drm_gpuvm`'s internal interval tree to accelerate the search for the starting :c:type:`drm_gpuva`, and hence isn't safe against removal of elements. It assumes that **end__** is within (or is the upper limit of) the :c:type:`drm_gpuvm`. This iterator does not skip over the :c:type:`drm_gpuvm`'s **kernel_alloc_node**.h](h)}(h**Parameters**h]j)}(hj ch]h Parameters}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj cubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjcubj)}(hhh](j)}(hK``va__`` :c:type:`drm_gpuva` structure to assign to in each iteration step h](j)}(h``va__``h]j)}(hj,ch]hva__}(hj.chhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*cubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj&cubj )}(hhh]h)}(hA:c:type:`drm_gpuva` structure to assign to in each iteration steph](h)}(h:c:type:`drm_gpuva`h]j)}(hjKch]h drm_gpuva}(hjMchhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjIcubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjAchMhjEcubh. structure to assign to in each iteration step}(hjEchhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjAchMhjBcubah}(h]h ]h"]h$]h&]uh1j hj&cubeh}(h]h ]h"]h$]h&]uh1jhjAchMhj#cubj)}(h-``gpuvm__`` :c:type:`drm_gpuvm` to walk over h](j)}(h ``gpuvm__``h]j)}(hjch]hgpuvm__}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj~cubj )}(hhh]h)}(h :c:type:`drm_gpuvm` to walk overh](h)}(h:c:type:`drm_gpuvm`h]j)}(hjch]h drm_gpuvm}(hjchhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjchMhjcubh to walk over}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjchMhjcubah}(h]h ]h"]h$]h&]uh1j hj~cubeh}(h]h ]h"]h$]h&]uh1jhjchMhj#cubj)}(h?``start__`` starting offset, the first gpuva will overlap this h](j)}(h ``start__``h]j)}(hjch]hstart__}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjcubj )}(hhh]h)}(h2starting offset, the first gpuva will overlap thish]h2starting offset, the first gpuva will overlap this}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchMhjcubah}(h]h ]h"]h$]h&]uh1j hjcubeh}(h]h ]h"]h$]h&]uh1jhjchMhj#cubj)}(hQ``end__`` ending offset, the last gpuva will start before this (but may overlap) h](j)}(h ``end__``h]j)}(hjdh]hend__}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjdubj )}(hhh]h)}(hFending offset, the last gpuva will start before this (but may overlap)h]hFending offset, the last gpuva will start before this (but may overlap)}(hj.dhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj+dubah}(h]h ]h"]h$]h&]uh1j hjdubeh}(h]h ]h"]h$]h&]uh1jhj*dhMhj#cubeh}(h]h ]h"]h$]h&]uh1jhjcubh)}(h**Description**h]j)}(hjQdh]h Description}(hjSdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOdubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjcubh)}(hXThis iterator walks over all :c:type:`drm_gpuvas` in the :c:type:`drm_gpuvm` that lie between **start__** and **end__**. It is implemented similarly to list_for_each(), but is using the :c:type:`drm_gpuvm`'s internal interval tree to accelerate the search for the starting :c:type:`drm_gpuva`, and hence isn't safe against removal of elements. It assumes that **end__** is within (or is the upper limit of) the :c:type:`drm_gpuvm`. This iterator does not skip over the :c:type:`drm_gpuvm`'s **kernel_alloc_node**.h](hThis iterator walks over all }(hjgdhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjqdh]h drm_gpuvas}(hjsdhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjodubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjgdubh in the }(hjgdhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjdh]h drm_gpuvm}(hjdhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjdhMhjgdubh that lie between }(hjgdhhhNhNubj)}(h **start__**h]hstart__}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgdubh and }(hjgdhhhNhNubj)}(h **end__**h]hend__}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgdubhC. It is implemented similarly to list_for_each(), but is using the }(hjgdhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjdh]h drm_gpuvm}(hjdhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjdhMhjgdubhF’s internal interval tree to accelerate the search for the starting }(hjgdhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjdh]h drm_gpuva}(hjehhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjdhMhjgdubhF, and hence isn’t safe against removal of elements. It assumes that }(hjgdhhhNhNubj)}(h **end__**h]hend__}(hj ehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgdubh* is within (or is the upper limit of) the }(hjgdhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj4eh]h drm_gpuvm}(hj6ehhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj2eubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjdhMhjgdubh'. This iterator does not skip over the }(hjgdhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjWeh]h drm_gpuvm}(hjYehhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjUeubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjdhMhjgdubh’s }(hjgdhhhNhNubj)}(h**kernel_alloc_node**h]hkernel_alloc_node}(hjxehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgdubh.}(hjgdhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjdhMhjcubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gpuvm_for_each_va_range_safe (C macro)"c.drm_gpuvm_for_each_va_range_safehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuvm_for_each_va_range_safeh]j>)}(h drm_gpuvm_for_each_va_range_safeh]jg)}(h drm_gpuvm_for_each_va_range_safeh]jm)}(hjeh]h drm_gpuvm_for_each_va_range_safe}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjehhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjehhhjehMubah}(h]jeah ](jjeh"]h$]h&]jj)jhuh1j7hjehMhjehhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjehhhjehMubeh}(h]h ](jmacroeh"]h$]h&]jjjjejjejjjuh1j2hhhj AhNhNubh)}(hL``drm_gpuvm_for_each_va_range_safe (va__, next__, gpuvm__, start__, end__)``h]j)}(hjeh]hHdrm_gpuvm_for_each_va_range_safe (va__, next__, gpuvm__, start__, end__)}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h4safely iterate over a range of :c:type:`drm_gpuvas` h]h)}(h3safely iterate over a range of :c:type:`drm_gpuvas`h](hsafely iterate over a range of }(hjfhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hj fh]h drm_gpuvas}(hj fhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjfubeh}(h]h ]h"]h$]h&]uh1hhj'fhMhjeubah}(h]h ]h"]h$]h&]uh1jhj'fhMhj Ahhubj)}(hXv**Parameters** ``va__`` :c:type:`drm_gpuva` to assign to in each iteration step ``next__`` another :c:type:`drm_gpuva` to use as temporary storage ``gpuvm__`` :c:type:`drm_gpuvm` to walk over ``start__`` starting offset, the first gpuva will overlap this ``end__`` ending offset, the last gpuva will start before this (but may overlap) **Description** This iterator walks over all :c:type:`drm_gpuvas` in the :c:type:`drm_gpuvm` that lie between **start__** and **end__**. It is implemented similarly to list_for_each_safe(), but is using the :c:type:`drm_gpuvm`'s internal interval tree to accelerate the search for the starting :c:type:`drm_gpuva`, and hence is safe against removal of elements. It assumes that **end__** is within (or is the upper limit of) the :c:type:`drm_gpuvm`. This iterator does not skip over the :c:type:`drm_gpuvm`'s **kernel_alloc_node**.h](h)}(h**Parameters**h]j)}(hj:fh]h Parameters}(hj)}(hdrm_gpuvm_for_each_vah]jg)}(hdrm_gpuvm_for_each_vah]jm)}(hj3ih]hdrm_gpuvm_for_each_va}(hj=ihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9iubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj5ihhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj1ihhhjPihMubah}(h]j,iah ](jjeh"]h$]h&]jj)jhuh1j7hjPihMhj.ihhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj.ihhhjPihMubeh}(h]h ](jmacroeh"]h$]h&]jjjjiijjiijjjuh1j2hhhj AhNhNubh)}(h)``drm_gpuvm_for_each_va (va__, gpuvm__)``h]j)}(hjoih]h%drm_gpuvm_for_each_va (va__, gpuvm__)}(hjqihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmiubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h&iterate over all :c:type:`drm_gpuvas` h]h)}(h%iterate over all :c:type:`drm_gpuvas`h](hiterate over all }(hjihhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjih]h drm_gpuvas}(hjihhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjiubeh}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1jhjihMhj Ahhubj)}(h**Parameters** ``va__`` :c:type:`drm_gpuva` to assign to in each iteration step ``gpuvm__`` :c:type:`drm_gpuvm` to walk over **Description** This iterator walks over all :c:type:`drm_gpuva` structures associated with the given :c:type:`drm_gpuvm`.h](h)}(h**Parameters**h]j)}(hjih]h Parameters}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjiubj)}(hhh](j)}(hA``va__`` :c:type:`drm_gpuva` to assign to in each iteration step h](j)}(h``va__``h]j)}(hjih]hva__}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjiubj )}(hhh]h)}(h7:c:type:`drm_gpuva` to assign to in each iteration steph](h)}(h:c:type:`drm_gpuva`h]j)}(hjjh]h drm_gpuva}(hjjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjihMhjiubh$ to assign to in each iteration step}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjihMhjiubah}(h]h ]h"]h$]h&]uh1j hjiubeh}(h]h ]h"]h$]h&]uh1jhjihMhjiubj)}(h-``gpuvm__`` :c:type:`drm_gpuvm` to walk over h](j)}(h ``gpuvm__``h]j)}(hj:jh]hgpuvm__}(hj)}(hdrm_gpuvm_for_each_va_safeh]jg)}(hdrm_gpuvm_for_each_va_safeh]jm)}(hjkh]hdrm_gpuvm_for_each_va_safe}(hj#khhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjkhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjkhhhj6khMubah}(h]jkah ](jjeh"]h$]h&]jj)jhuh1j7hj6khMhjkhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjkhhhj6khMubeh}(h]h ](jmacroeh"]h$]h&]jjjjOkjjOkjjjuh1j2hhhj AhNhNubh)}(h6``drm_gpuvm_for_each_va_safe (va__, next__, gpuvm__)``h]j)}(hjUkh]h2drm_gpuvm_for_each_va_safe (va__, next__, gpuvm__)}(hjWkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSkubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h-safely iterate over all :c:type:`drm_gpuvas` h]h)}(h,safely iterate over all :c:type:`drm_gpuvas`h](hsafely iterate over all }(hjokhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjykh]h drm_gpuvas}(hj{khhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjwkubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjokubeh}(h]h ]h"]h$]h&]uh1hhjkhMhjkkubah}(h]h ]h"]h$]h&]uh1jhjkhMhj Ahhubj)}(hX**Parameters** ``va__`` :c:type:`drm_gpuva` to assign to in each iteration step ``next__`` another :c:type:`drm_gpuva` to use as temporary storage ``gpuvm__`` :c:type:`drm_gpuvm` to walk over **Description** This iterator walks over all :c:type:`drm_gpuva` structures associated with the given :c:type:`drm_gpuvm`. It is implemented with list_for_each_entry_safe(), and hence safe against the removal of elements.h](h)}(h**Parameters**h]j)}(hjkh]h Parameters}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjkubj)}(hhh](j)}(hA``va__`` :c:type:`drm_gpuva` to assign to in each iteration step h](j)}(h``va__``h]j)}(hjkh]hva__}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjkubj )}(hhh]h)}(h7:c:type:`drm_gpuva` to assign to in each iteration steph](h)}(h:c:type:`drm_gpuva`h]j)}(hjkh]h drm_gpuva}(hjkhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjkhMhjkubh$ to assign to in each iteration step}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjkhMhjkubah}(h]h ]h"]h$]h&]uh1j hjkubeh}(h]h ]h"]h$]h&]uh1jhjkhMhjkubj)}(hC``next__`` another :c:type:`drm_gpuva` to use as temporary storage h](j)}(h ``next__``h]j)}(hj lh]hnext__}(hj"lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjlubj )}(hhh]h)}(h7another :c:type:`drm_gpuva` to use as temporary storageh](hanother }(hj9lhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjClh]h drm_gpuva}(hjElhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjAlubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj5lhMhj9lubh to use as temporary storage}(hj9lhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5lhMhj6lubah}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhj5lhMhjkubj)}(h-``gpuvm__`` :c:type:`drm_gpuvm` to walk over h](j)}(h ``gpuvm__``h]j)}(hj|lh]hgpuvm__}(hj~lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzlubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjvlubj )}(hhh]h)}(h :c:type:`drm_gpuvm` to walk overh](h)}(h:c:type:`drm_gpuvm`h]j)}(hjlh]h drm_gpuvm}(hjlhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjlhMhjlubh to walk over}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjlhMhjlubah}(h]h ]h"]h$]h&]uh1j hjvlubeh}(h]h ]h"]h$]h&]uh1jhjlhMhjkubeh}(h]h ]h"]h$]h&]uh1jhjkubh)}(h**Description**h]j)}(hjlh]h Description}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjkubh)}(hThis iterator walks over all :c:type:`drm_gpuva` structures associated with the given :c:type:`drm_gpuvm`. It is implemented with list_for_each_entry_safe(), and hence safe against the removal of elements.h](hThis iterator walks over all }(hjlhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjlh]h drm_gpuva}(hjlhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjlubh& structures associated with the given }(hjlhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjmh]h drm_gpuvm}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjmhMhjlubhd. It is implemented with list_for_each_entry_safe(), and hence safe against the removal of elements.}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjmhMhjkubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_exec (C struct)c.drm_gpuvm_exechNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_exech]j>)}(hstruct drm_gpuvm_exech](jD)}(hjh]hstruct}(hjamhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj]mhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM ubjV)}(h h]h }(hjomhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]mhhhjnmhM ubjg)}(hdrm_gpuvm_exech]jm)}(hj[mh]hdrm_gpuvm_exec}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}mubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj]mhhhjnmhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjYmhhhjnmhM ubah}(h]jTmah ](jjeh"]h$]h&]jj)jhuh1j7hjnmhM hjVmhhubj)}(hhh]h)}(h5:c:type:`drm_gpuvm` abstraction of :c:type:`drm_exec`h](h)}(h:c:type:`drm_gpuvm`h]j)}(hjmh]h drm_gpuvm}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j )}jj[msbc.drm_gpuvm_execasbjM drm_gpuvmuh1hhjIhKhjmubh abstraction of }(hjmhhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjmh]hdrm_exec}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjmjMdrm_execuh1hhjIhKhjmubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjmhhubah}(h]h ]h"]h$]h&]uh1jhjVmhhhjnmhM ubeh}(h]h ](jstructeh"]h$]h&]jjjjnjjnjjjuh1j2hhhj AhNhNubj)}(hX0**Definition**:: struct drm_gpuvm_exec { struct drm_exec exec; u32 flags; struct drm_gpuvm *vm; unsigned int num_fences; struct { int (*fn)(struct drm_gpuvm_exec *vm_exec); void *priv; } extra; }; **Members** ``exec`` the :c:type:`drm_exec` structure ``flags`` the flags for the struct drm_exec ``vm`` the :c:type:`drm_gpuvm` to lock its DMA reservations ``num_fences`` the number of fences to reserve for the :c:type:`dma_resv` of the locked :c:type:`drm_gem_objects` ``extra`` Callback and corresponding private data for the driver to lock arbitrary additional :c:type:`drm_gem_objects`. ``extra.fn`` The driver callback to lock additional :c:type:`drm_gem_objects`. ``extra.priv`` driver private data for the **fn** callbackh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj nhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubh:}(hjnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjnubjT)}(hstruct drm_gpuvm_exec { struct drm_exec exec; u32 flags; struct drm_gpuvm *vm; unsigned int num_fences; struct { int (*fn)(struct drm_gpuvm_exec *vm_exec); void *priv; } extra; };h]hstruct drm_gpuvm_exec { struct drm_exec exec; u32 flags; struct drm_gpuvm *vm; unsigned int num_fences; struct { int (*fn)(struct drm_gpuvm_exec *vm_exec); void *priv; } extra; };}hj%nsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjnubh)}(h **Members**h]j)}(hj6nh]hMembers}(hj8nhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4nubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hjnubj)}(hhh](j)}(h*``exec`` the :c:type:`drm_exec` structure h](j)}(h``exec``h]j)}(hjUnh]hexec}(hjWnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSnubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjOnubj )}(hhh]h)}(h the :c:type:`drm_exec` structureh](hthe }(hjnnhhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjxnh]hdrm_exec}(hjznhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjvnubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhjjnhMhjnnubh structure}(hjnnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjjnhMhjknubah}(h]h ]h"]h$]h&]uh1j hjOnubeh}(h]h ]h"]h$]h&]uh1jhjjnhMhjLnubj)}(h,``flags`` the flags for the struct drm_exec h](j)}(h ``flags``h]j)}(hjnh]hflags}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjnubj )}(hhh]h)}(h!the flags for the struct drm_exech]h!the flags for the struct drm_exec}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjnubah}(h]h ]h"]h$]h&]uh1j hjnubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjLnubj)}(h<``vm`` the :c:type:`drm_gpuvm` to lock its DMA reservations h](j)}(h``vm``h]j)}(hjnh]hvm}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM"hjnubj )}(hhh]h)}(h4the :c:type:`drm_gpuvm` to lock its DMA reservationsh](hthe }(hjohhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj oh]h drm_gpuvm}(hjohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj oubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjnhM"hjoubh to lock its DMA reservations}(hjohhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjnhM"hjoubah}(h]h ]h"]h$]h&]uh1j hjnubeh}(h]h ]h"]h$]h&]uh1jhjnhM"hjLnubj)}(hr``num_fences`` the number of fences to reserve for the :c:type:`dma_resv` of the locked :c:type:`drm_gem_objects` h](j)}(h``num_fences``h]j)}(hjFoh]h num_fences}(hjHohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDoubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM(hj@oubj )}(hhh]h)}(hbthe number of fences to reserve for the :c:type:`dma_resv` of the locked :c:type:`drm_gem_objects`h](h(the number of fences to reserve for the }(hj_ohhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjioh]hdma_resv}(hjkohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjgoubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM'hj_oubh of the locked }(hj_ohhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjoh]hdrm_gem_objects}(hjohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhjohM'hj_oubeh}(h]h ]h"]h$]h&]uh1hhjohM'hj\oubah}(h]h ]h"]h$]h&]uh1j hj@oubeh}(h]h ]h"]h$]h&]uh1jhj[ohM(hjLnubj)}(hy``extra`` Callback and corresponding private data for the driver to lock arbitrary additional :c:type:`drm_gem_objects`. h](j)}(h ``extra``h]j)}(hjoh]hextra}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM.hjoubj )}(hhh]h)}(hnCallback and corresponding private data for the driver to lock arbitrary additional :c:type:`drm_gem_objects`.h](hTCallback and corresponding private data for the driver to lock arbitrary additional }(hjohhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjoh]hdrm_gem_objects}(hjohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM-hjoubh.}(hjohhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjphM-hjoubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjohM.hjLnubj)}(hO``extra.fn`` The driver callback to lock additional :c:type:`drm_gem_objects`. h](j)}(h ``extra.fn``h]j)}(hjph]hextra.fn}(hj!phhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM3hjpubj )}(hhh]h)}(hAThe driver callback to lock additional :c:type:`drm_gem_objects`.h](h'The driver callback to lock additional }(hj8phhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjBph]hdrm_gem_objects}(hjDphhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@pubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM2hj8pubh.}(hj8phhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj_phM2hj5pubah}(h]h ]h"]h$]h&]uh1j hjpubeh}(h]h ]h"]h$]h&]uh1jhj4phM3hjLnubj)}(h:``extra.priv`` driver private data for the **fn** callbackh](j)}(h``extra.priv``h]j)}(hj|ph]h extra.priv}(hj~phhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzpubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM7hjvpubj )}(hhh]h)}(h+driver private data for the **fn** callbackh](hdriver private data for the }(hjphhhNhNubj)}(h**fn**h]hfn}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubh callback}(hjphhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM8hjpubah}(h]h ]h"]h$]h&]uh1j hjvpubeh}(h]h ]h"]h$]h&]uh1jhjphM7hjLnubeh}(h]h ]h"]h$]h&]uh1jhjnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjph]h Description}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM;hj Ahhubh)}(hNThis structure should be created on the stack as :c:type:`drm_exec` should be.h](h1This structure should be created on the stack as }(hjphhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjph]hdrm_exec}(hjphhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjpubh should be.}(hjphhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjqhMhj Ahhubh)}(hWOptionally, **extra** can be set in order to lock additional :c:type:`drm_gem_objects`.h](h Optionally, }(hjqhhhNhNubj)}(h **extra**h]hextra}(hj!qhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjqubh( can be set in order to lock additional }(hjqhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hj5qh]hdrm_gem_objects}(hj7qhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj3qubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjqubh.}(hjqhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjRqhMhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gpuvm_exec_unlock (C function)c.drm_gpuvm_exec_unlockhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h;void drm_gpuvm_exec_unlock (struct drm_gpuvm_exec *vm_exec)h]j>)}(h:void drm_gpuvm_exec_unlock(struct drm_gpuvm_exec *vm_exec)h](j)}(hvoidh]hvoid}(hjvqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjrqhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMTubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjrqhhhjqhMTubjg)}(hdrm_gpuvm_exec_unlockh]jm)}(hdrm_gpuvm_exec_unlockh]hdrm_gpuvm_exec_unlock}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjrqhhhjqhMTubj)}(h (struct drm_gpuvm_exec *vm_exec)h]j)}(hstruct drm_gpuvm_exec *vm_exech](jD)}(hjh]hstruct}(hjqhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubh)}(hhh]jm)}(hdrm_gpuvm_exech]hdrm_gpuvm_exec}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]j )}jjqsbc.drm_gpuvm_exec_unlockasbuh1hhjqubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubj4)}(hj7h]h*}(hjqhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjqubjm)}(hvm_exech]hvm_exec}(hj rhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjqubah}(h]h ]h"]h$]h&]jjuh1jhjrqhhhjqhMTubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjnqhhhjqhMTubah}(h]jiqah ](jjeh"]h$]h&]jj)jhuh1j7hjqhMThjkqhhubj)}(hhh]h)}(h(lock all dma-resv of all assoiciated BOsh]h(lock all dma-resv of all assoiciated BOs}(hj6rhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMThj3rhhubah}(h]h ]h"]h$]h&]uh1jhjkqhhhjqhMTubeh}(h]h ](jfunctioneh"]h$]h&]jjjjNrjjNrjjjuh1j2hhhj AhNhNubj)}(hX&**Parameters** ``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper **Description** Releases all dma-resv locks of all :c:type:`drm_gem_objects` previously acquired through drm_gpuvm_exec_lock() or its variants. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjXrh]h Parameters}(hjZrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVrubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMXhjRrubj)}(hhh]j)}(hH``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper h](j)}(h"``struct drm_gpuvm_exec *vm_exec``h]j)}(hjwrh]hstruct drm_gpuvm_exec *vm_exec}(hjyrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjurubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMUhjqrubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm_exec` wrapperh](hthe }(hjrhhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hjrh]hdrm_gpuvm_exec}(hjrhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhjrhMUhjrubh wrapper}(hjrhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjrhMUhjrubah}(h]h ]h"]h$]h&]uh1j hjqrubeh}(h]h ]h"]h$]h&]uh1jhjrhMUhjnrubah}(h]h ]h"]h$]h&]uh1jhjRrubh)}(h**Description**h]j)}(hjrh]h Description}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMWhjRrubh)}(hReleases all dma-resv locks of all :c:type:`drm_gem_objects` previously acquired through drm_gpuvm_exec_lock() or its variants.h](h#Releases all dma-resv locks of all }(hjrhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjrh]hdrm_gem_objects}(hjrhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMVhjrubhC previously acquired through drm_gpuvm_exec_lock() or its variants.}(hjrhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjshMVhjRrubh)}(h **Return**h]j)}(hjsh]hReturn}(hj!shhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMYhjRrubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hj5shhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMZhjRrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gpuvm_exec_resv_add_fence (C function)c.drm_gpuvm_exec_resv_add_fencehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hvoid drm_gpuvm_exec_resv_add_fence (struct drm_gpuvm_exec *vm_exec, struct dma_fence *fence, enum dma_resv_usage private_usage, enum dma_resv_usage extobj_usage)h]j>)}(hvoid drm_gpuvm_exec_resv_add_fence(struct drm_gpuvm_exec *vm_exec, struct dma_fence *fence, enum dma_resv_usage private_usage, enum dma_resv_usage extobj_usage)h](j)}(hvoidh]hvoid}(hjdshhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`shhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMjubjV)}(h h]h }(hjsshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`shhhjrshMjubjg)}(hdrm_gpuvm_exec_resv_add_fenceh]jm)}(hdrm_gpuvm_exec_resv_add_fenceh]hdrm_gpuvm_exec_resv_add_fence}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj`shhhjrshMjubj)}(h~(struct drm_gpuvm_exec *vm_exec, struct dma_fence *fence, enum dma_resv_usage private_usage, enum dma_resv_usage extobj_usage)h](j)}(hstruct drm_gpuvm_exec *vm_exech](jD)}(hjh]hstruct}(hjshhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjsubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubh)}(hhh]jm)}(hdrm_gpuvm_exech]hdrm_gpuvm_exec}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjsmodnameN classnameNjj)}j]j )}jjssbc.drm_gpuvm_exec_resv_add_fenceasbuh1hhjsubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubj4)}(hj7h]h*}(hjshhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjsubjm)}(hvm_exech]hvm_exec}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hjthhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjtubjV)}(h h]h }(hj thhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hj1thhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.tubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj3tmodnameN classnameNjj)}j]jsc.drm_gpuvm_exec_resv_add_fenceasbuh1hhjtubjV)}(h h]h }(hjOthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubj4)}(hj7h]h*}(hj]thhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjtubjm)}(hfenceh]hfence}(hjjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(h!enum dma_resv_usage private_usageh](jD)}(hjGh]henum}(hjthhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjtubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubh)}(hhh]jm)}(hdma_resv_usageh]hdma_resv_usage}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]jsc.drm_gpuvm_exec_resv_add_fenceasbuh1hhjtubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubjm)}(h private_usageh]h private_usage}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubj)}(h enum dma_resv_usage extobj_usageh](jD)}(hjGh]henum}(hjthhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjtubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubh)}(hhh]jm)}(hdma_resv_usageh]hdma_resv_usage}(hjuhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjumodnameN classnameNjj)}j]jsc.drm_gpuvm_exec_resv_add_fenceasbuh1hhjtubjV)}(h h]h }(hj"uhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubjm)}(h extobj_usageh]h extobj_usage}(hj0uhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjsubeh}(h]h ]h"]h$]h&]jjuh1jhj`shhhjrshMjubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj\shhhjrshMjubah}(h]jWsah ](jjeh"]h$]h&]jj)jhuh1j7hjrshMjhjYshhubj)}(hhh]h)}(h#add fence to private and all extobjh]h#add fence to private and all extobj}(hjZuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMjhjWuhhubah}(h]h ]h"]h$]h&]uh1jhjYshhhjrshMjubeh}(h]h ](jfunctioneh"]h$]h&]jjjjrujjrujjjuh1j2hhhj AhNhNubj)}(hX5**Parameters** ``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper ``struct dma_fence *fence`` fence to add ``enum dma_resv_usage private_usage`` private dma-resv usage ``enum dma_resv_usage extobj_usage`` extobj dma-resv usage **Description** See drm_gpuvm_resv_add_fence().h](h)}(h**Parameters**h]j)}(hj|uh]h Parameters}(hj~uhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzuubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMnhjvuubj)}(hhh](j)}(hH``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper h](j)}(h"``struct drm_gpuvm_exec *vm_exec``h]j)}(hjuh]hstruct drm_gpuvm_exec *vm_exec}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMkhjuubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm_exec` wrapperh](hthe }(hjuhhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hjuh]hdrm_gpuvm_exec}(hjuhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhjuhMkhjuubh wrapper}(hjuhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjuhMkhjuubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjuhMkhjuubj)}(h)``struct dma_fence *fence`` fence to add h](j)}(h``struct dma_fence *fence``h]j)}(hjuh]hstruct dma_fence *fence}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMlhjuubj )}(hhh]h)}(h fence to addh]h fence to add}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj vhMlhj vubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhj vhMlhjuubj)}(h=``enum dma_resv_usage private_usage`` private dma-resv usage h](j)}(h%``enum dma_resv_usage private_usage``h]j)}(hj0vh]h!enum dma_resv_usage private_usage}(hj2vhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.vubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMmhj*vubj )}(hhh]h)}(hprivate dma-resv usageh]hprivate dma-resv usage}(hjIvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEvhMmhjFvubah}(h]h ]h"]h$]h&]uh1j hj*vubeh}(h]h ]h"]h$]h&]uh1jhjEvhMmhjuubj)}(h;``enum dma_resv_usage extobj_usage`` extobj dma-resv usage h](j)}(h$``enum dma_resv_usage extobj_usage``h]j)}(hjivh]h enum dma_resv_usage extobj_usage}(hjkvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgvubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMnhjcvubj )}(hhh]h)}(hextobj dma-resv usageh]hextobj dma-resv usage}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~vhMnhjvubah}(h]h ]h"]h$]h&]uh1j hjcvubeh}(h]h ]h"]h$]h&]uh1jhj~vhMnhjuubeh}(h]h ]h"]h$]h&]uh1jhjvuubh)}(h**Description**h]j)}(hjvh]h Description}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMphjvuubh)}(hSee drm_gpuvm_resv_add_fence().h]hSee drm_gpuvm_resv_add_fence().}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMohjvuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gpuvm_exec_validate (C function)c.drm_gpuvm_exec_validatehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h)}(h;int drm_gpuvm_exec_validate(struct drm_gpuvm_exec *vm_exec)h](j)}(hinth]hint}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjvhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM}ubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjvhhhjvhM}ubjg)}(hdrm_gpuvm_exec_validateh]jm)}(hdrm_gpuvm_exec_validateh]hdrm_gpuvm_exec_validate}(hj whhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjwubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjvhhhjvhM}ubj)}(h (struct drm_gpuvm_exec *vm_exec)h]j)}(hstruct drm_gpuvm_exec *vm_exech](jD)}(hjh]hstruct}(hj&whhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj"wubjV)}(h h]h }(hj3whhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"wubh)}(hhh]jm)}(hdrm_gpuvm_exech]hdrm_gpuvm_exec}(hjDwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAwubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFwmodnameN classnameNjj)}j]j )}jj wsbc.drm_gpuvm_exec_validateasbuh1hhj"wubjV)}(h h]h }(hjdwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"wubj4)}(hj7h]h*}(hjrwhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj"wubjm)}(hvm_exech]hvm_exec}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"wubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjwubah}(h]h ]h"]h$]h&]jjuh1jhjvhhhjvhM}ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjvhhhjvhM}ubah}(h]jvah ](jjeh"]h$]h&]jj)jhuh1j7hjvhM}hjvhhubj)}(hhh]h)}(h"validate all BOs marked as evictedh]h"validate all BOs marked as evicted}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM}hjwhhubah}(h]h ]h"]h$]h&]uh1jhjvhhhjvhM}ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjwjjwjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper **Description** See drm_gpuvm_validate(). **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjwh]h Parameters}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubj)}(hhh]j)}(hH``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper h](j)}(h"``struct drm_gpuvm_exec *vm_exec``h]j)}(hjwh]hstruct drm_gpuvm_exec *vm_exec}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM~hjwubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm_exec` wrapperh](hthe }(hjxhhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hj xh]hdrm_gpuvm_exec}(hjxhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj xubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhjwhM~hjxubh wrapper}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjwhM~hjxubah}(h]h ]h"]h$]h&]uh1j hjwubeh}(h]h ]h"]h$]h&]uh1jhjwhM~hjwubah}(h]h ]h"]h$]h&]uh1jhjwubh)}(h**Description**h]j)}(hjHxh]h Description}(hjJxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFxubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubh)}(hSee drm_gpuvm_validate().h]hSee drm_gpuvm_validate().}(hj^xhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubh)}(h **Return**h]j)}(hjoxh]hReturn}(hjqxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmxubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_bo (C struct)c.drm_gpuvm_bohNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuvm_boh]j>)}(hstruct drm_gpuvm_boh](jD)}(hjh]hstruct}(hjxhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjxhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjxhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxhhhjxhMubjg)}(h drm_gpuvm_boh]jm)}(hjxh]h drm_gpuvm_bo}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjxhhhjxhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjxhhhjxhMubah}(h]jxah ](jjeh"]h$]h&]jj)jhuh1j7hjxhMhjxhhubj)}(hhh]h)}(hUstructure representing a :c:type:`drm_gpuvm` and :c:type:`drm_gem_object` combinationh](hstructure representing a }(hjxhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjyh]h drm_gpuvm}(hjyhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j )}jjxsbc.drm_gpuvm_boasbjM drm_gpuvmuh1hhjIhKhjxubh and }(hjxhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj*yh]hdrm_gem_object}(hj,yhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj(yubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjyjMdrm_gem_objectuh1hhjIhKhjxubh combination}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjxhhubah}(h]h ]h"]h$]h&]uh1jhjxhhhjxhMubeh}(h]h ](jstructeh"]h$]h&]jjjj[yjj[yjjjuh1j2hhhj AhNhNubj)}(hX**Definition**:: struct drm_gpuvm_bo { struct drm_gpuvm *vm; struct drm_gem_object *obj; bool evicted; struct kref kref; struct { struct list_head gpuva; struct { struct list_head gem; struct list_head extobj; struct list_head evict; struct llist_node bo_defer; } entry; } list; }; **Members** ``vm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. This is a reference counted pointer. ``obj`` The :c:type:`drm_gem_object` being mapped in **vm**. This is a reference counted pointer. ``evicted`` Indicates whether the :c:type:`drm_gem_object` is evicted; field protected by the :c:type:`drm_gem_object`'s dma-resv lock. ``kref`` The reference count for this :c:type:`drm_gpuvm_bo`. ``list`` Structure containing all :c:type:`list_heads`. ``list.gpuva`` The list of linked :c:type:`drm_gpuvas`. It is safe to access entries from this list as long as the GEM's gpuva lock is held. See also struct drm_gem_object. ``list.entry`` Structure containing all :c:type:`list_heads` serving as entry. ``list.entry.gem`` List entry to attach to the :c:type:`drm_gem_objects` gpuva list. ``list.entry.evict`` List entry to attach to the :c:type:`drm_gpuvms` evict list. ``list.entry.bo_defer`` List entry to attach to the :c:type:`drm_gpuvms` bo_defer list.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjgyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcyubh:}(hjcyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj_yubjT)}(hXhstruct drm_gpuvm_bo { struct drm_gpuvm *vm; struct drm_gem_object *obj; bool evicted; struct kref kref; struct { struct list_head gpuva; struct { struct list_head gem; struct list_head extobj; struct list_head evict; struct llist_node bo_defer; } entry; } list; };h]hXhstruct drm_gpuvm_bo { struct drm_gpuvm *vm; struct drm_gem_object *obj; bool evicted; struct kref kref; struct { struct list_head gpuva; struct { struct list_head gem; struct list_head extobj; struct list_head evict; struct llist_node bo_defer; } entry; } list; };}hjysbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj_yubh)}(h **Members**h]j)}(hjyh]hMembers}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj_yubj)}(hhh](j)}(h^``vm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. This is a reference counted pointer. h](j)}(h``vm``h]j)}(hjyh]hvm}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjyubj )}(hhh]h)}(hVThe :c:type:`drm_gpuvm` the **obj** is mapped in. This is a reference counted pointer.h](hThe }(hjyhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjyh]h drm_gpuvm}(hjyhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjyubh the }(hjyhhhNhNubj)}(h**obj**h]hobj}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubh3 is mapped in. This is a reference counted pointer.}(hjyhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjyhMhjyubah}(h]h ]h"]h$]h&]uh1j hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhMhjyubj)}(hb``obj`` The :c:type:`drm_gem_object` being mapped in **vm**. This is a reference counted pointer. h](j)}(h``obj``h]j)}(hjzh]hobj}(hj!zhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjzubj )}(hhh]h)}(hYThe :c:type:`drm_gem_object` being mapped in **vm**. This is a reference counted pointer.h](hThe }(hj8zhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjBzh]hdrm_gem_object}(hjDzhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@zubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj8zubh being mapped in }(hj8zhhhNhNubj)}(h**vm**h]hvm}(hjdzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8zubh&. This is a reference counted pointer.}(hj8zhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj_zhMhj5zubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhj4zhMhjyubj)}(h``evicted`` Indicates whether the :c:type:`drm_gem_object` is evicted; field protected by the :c:type:`drm_gem_object`'s dma-resv lock. h](j)}(h ``evicted``h]j)}(hjzh]hevicted}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjzubj )}(hhh]h)}(h{Indicates whether the :c:type:`drm_gem_object` is evicted; field protected by the :c:type:`drm_gem_object`'s dma-resv lock.h](hIndicates whether the }(hjzhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjzh]hdrm_gem_object}(hjzhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjzubh$ is evicted; field protected by the }(hjzhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjzh]hdrm_gem_object}(hjzhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjzhMhjzubh’s dma-resv lock.}(hjzhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjzhMhjzubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhjzhMhjyubj)}(h>``kref`` The reference count for this :c:type:`drm_gpuvm_bo`. h](j)}(h``kref``h]j)}(hj{h]hkref}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj {ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj{ubj )}(hhh]h)}(h4The reference count for this :c:type:`drm_gpuvm_bo`.h](hThe reference count for this }(hj'{hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj1{h]h drm_gpuvm_bo}(hj3{hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj/{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj#{hMhj'{ubh.}(hj'{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj#{hMhj${ubah}(h]h ]h"]h$]h&]uh1j hj{ubeh}(h]h ]h"]h$]h&]uh1jhj#{hMhjyubj)}(h8``list`` Structure containing all :c:type:`list_heads`. h](j)}(h``list``h]j)}(hjj{h]hlist}(hjl{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjh{ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjd{ubj )}(hhh]h)}(h.Structure containing all :c:type:`list_heads`.h](hStructure containing all }(hj{hhhNhNubh)}(h:c:type:`list_heads`h]j)}(hj{h]h list_heads}(hj{hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headsuh1hhj{hMhj{ubh.}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj{hMhj{ubah}(h]h ]h"]h$]h&]uh1j hjd{ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjyubj)}(h``list.gpuva`` The list of linked :c:type:`drm_gpuvas`. It is safe to access entries from this list as long as the GEM's gpuva lock is held. See also struct drm_gem_object. h](j)}(h``list.gpuva``h]j)}(hj{h]h list.gpuva}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj{ubj )}(hhh](h)}(h(The list of linked :c:type:`drm_gpuvas`.h](hThe list of linked }(hj{hhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hj{h]h drm_gpuvas}(hj{hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj{ubh.}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hMhj{ubh)}(htIt is safe to access entries from this list as long as the GEM's gpuva lock is held. See also struct drm_gem_object.h]hvIt is safe to access entries from this list as long as the GEM’s gpuva lock is held. See also struct drm_gem_object.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj{ubeh}(h]h ]h"]h$]h&]uh1j hj{ubeh}(h]h ]h"]h$]h&]uh1jhj{hMhjyubj)}(hO``list.entry`` Structure containing all :c:type:`list_heads` serving as entry. h](j)}(h``list.entry``h]j)}(hj2|h]h list.entry}(hj4|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0|ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj,|ubj )}(hhh]h)}(h?Structure containing all :c:type:`list_heads` serving as entry.h](hStructure containing all }(hjK|hhhNhNubh)}(h:c:type:`list_heads`h]j)}(hjU|h]h list_heads}(hjW|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjS|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjK|ubh serving as entry.}(hjK|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjr|hMhjH|ubah}(h]h ]h"]h$]h&]uh1j hj,|ubeh}(h]h ]h"]h$]h&]uh1jhjG|hMhjyubj)}(hU``list.entry.gem`` List entry to attach to the :c:type:`drm_gem_objects` gpuva list. h](j)}(h``list.entry.gem``h]j)}(hj|h]hlist.entry.gem}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj|ubj )}(hhh]h)}(hAList entry to attach to the :c:type:`drm_gem_objects` gpuva list.h](hList entry to attach to the }(hj|hhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hj|h]hdrm_gem_objects}(hj|hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj|ubh gpuva list.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hMhj|ubah}(h]h ]h"]h$]h&]uh1j hj|ubeh}(h]h ]h"]h$]h&]uh1jhj|hMhjyubj)}(hR``list.entry.evict`` List entry to attach to the :c:type:`drm_gpuvms` evict list. h](j)}(h``list.entry.evict``h]j)}(hj|h]hlist.entry.evict}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj|ubj )}(hhh]h)}(h)}(hAstruct drm_gpuvm_bo *drm_gpuvm_bo_get(struct drm_gpuvm_bo *vm_bo)h](jD)}(hjh]hstruct}(hj~hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj~hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~hhhj~hMubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~modnameN classnameNjj)}j]j )}jdrm_gpuvm_bo_getsbc.drm_gpuvm_bo_getasbuh1hhj~hhhj~hMubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~hhhj~hMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj~hhhj~hMubjg)}(hdrm_gpuvm_bo_geth]jm)}(hj~h]hdrm_gpuvm_bo_get}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj~hhhj~hMubj)}(h(struct drm_gpuvm_bo *vm_bo)h]j)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hj3hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj/ubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjQhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjSmodnameN classnameNjj)}j]j~c.drm_gpuvm_bo_getasbuh1hhj/ubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubj4)}(hj7h]h*}(hj}hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj/ubjm)}(hvm_boh]hvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj+ubah}(h]h ]h"]h$]h&]jjuh1jhj~hhhj~hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj~hhhj~hMubah}(h]j~ah ](jjeh"]h$]h&]jj)jhuh1j7hj~hMhj~hhubj)}(hhh]h)}(h'acquire a struct drm_gpuvm_bo referenceh]h'acquire a struct drm_gpuvm_bo reference}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhj~hhhj~hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXA**Parameters** ``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to acquire the reference of **Description** This function acquires an additional reference to **vm_bo**. It is illegal to call this without already holding a reference. No locks required. **Return** the :c:type:`struct vm_bo ` pointerh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh]j)}(hV``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to acquire the reference of h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjh]hstruct drm_gpuvm_bo *vm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h6the :c:type:`drm_gpuvm_bo` to acquire the reference ofh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj hMhjubh to acquire the reference of}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjSh]h Description}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hThis function acquires an additional reference to **vm_bo**. It is illegal to call this without already holding a reference. No locks required.h](h2This function acquires an additional reference to }(hjihhhNhNubj)}(h **vm_bo**h]hvm_bo}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubhT. It is illegal to call this without already holding a reference. No locks required.}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(h*the :c:type:`struct vm_bo ` pointerh](hthe }(hjhhhNhNubh)}(h:c:type:`struct vm_bo `h]j)}(hjh]h struct vm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMvm_bouh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh pointer}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjɀhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gpuvm_bo_gem_evict (C function)c.drm_gpuvm_bo_gem_evicthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hDvoid drm_gpuvm_bo_gem_evict (struct drm_gem_object *obj, bool evict)h]j>)}(hCvoid drm_gpuvm_bo_gem_evict(struct drm_gem_object *obj, bool evict)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuvm_bo_gem_evicth]jm)}(hdrm_gpuvm_bo_gem_evicth]hdrm_gpuvm_bo_gem_evict}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h((struct drm_gem_object *obj, bool evict)h](j)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj1hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj-ubjV)}(h h]h }(hj>hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjQmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_bo_gem_evictasbuh1hhj-ubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubj4)}(hj7h]h*}(hj}hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj-ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj)ubj)}(h bool evicth](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hevicth]hevict}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj)ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(haadd/remove all :c:type:`drm_gpuvm_bo`'s in the list to/from the :c:type:`drm_gpuvms` evicted listh](hadd/remove all }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jkc.drm_gpuvm_bo_gem_evictasbjM drm_gpuvm_bouh1hhjIhKhjubh’s in the list to/from the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvms`h]j)}(hjh]h drm_gpuvms}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjM drm_gpuvmsuh1hhjIhKhjubh evicted list}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjKjjKjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gem_object *obj`` the :c:type:`drm_gem_object` ``bool evict`` indicates whether **obj** is evicted **Description** See drm_gpuvm_bo_evict().h](h)}(h**Parameters**h]j)}(hjUh]h Parameters}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjSubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjOubj)}(hhh](j)}(h<``struct drm_gem_object *obj`` the :c:type:`drm_gem_object` h](j)}(h``struct drm_gem_object *obj``h]j)}(hjth]hstruct drm_gem_object *obj}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjnubj )}(hhh]h)}(hthe :c:type:`drm_gem_object`h](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjnubeh}(h]h ]h"]h$]h&]uh1jhjhMhjkubj)}(h4``bool evict`` indicates whether **obj** is evicted h](j)}(h``bool evict``h]j)}(hĵh]h bool evict}(hj΂hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjʂubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjƂubj )}(hhh]h)}(h$indicates whether **obj** is evictedh](hindicates whether }(hjhhhNhNubj)}(h**obj**h]hobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is evicted}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjƂubeh}(h]h ]h"]h$]h&]uh1jhjhMhjkubeh}(h]h ]h"]h$]h&]uh1jhjOubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hjOubh)}(hSee drm_gpuvm_bo_evict().h]hSee drm_gpuvm_bo_evict().}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjOubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gpuvm_bo_for_each_va (C macro)c.drm_gpuvm_bo_for_each_vahNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_bo_for_each_vah]j>)}(hdrm_gpuvm_bo_for_each_vah]jg)}(hdrm_gpuvm_bo_for_each_vah]jm)}(hjXh]hdrm_gpuvm_bo_for_each_va}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjZhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjVhhhjuhMubah}(h]jQah ](jjeh"]h$]h&]jj)jhuh1j7hjuhMhjShhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjShhhjuhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubh)}(h,``drm_gpuvm_bo_for_each_va (va__, vm_bo__)``h]j)}(hjh]h(drm_gpuvm_bo_for_each_va (va__, vm_bo__)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h4iterator to walk over a list of :c:type:`drm_gpuva` h]h)}(h3iterator to walk over a list of :c:type:`drm_gpuva`h](h iterator to walk over a list of }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjՃhMhjubah}(h]h ]h"]h$]h&]uh1jhjՃhMhj Ahhubj)}(hX`**Parameters** ``va__`` :c:type:`drm_gpuva` structure to assign to in each iteration step ``vm_bo__`` the :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuva` to walk are associated with **Description** This iterator walks over all :c:type:`drm_gpuva` structures associated with the :c:type:`drm_gpuvm_bo`. The caller must hold the GEM's gpuva lock.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh](j)}(hK``va__`` :c:type:`drm_gpuva` structure to assign to in each iteration step h](j)}(h``va__``h]j)}(hjh]hva__}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(hA:c:type:`drm_gpuva` structure to assign to in each iteration steph](h)}(h:c:type:`drm_gpuva`h]j)}(hj&h]h drm_gpuva}(hj(hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhMhj ubh. structure to assign to in each iteration step}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h[``vm_bo__`` the :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuva` to walk are associated with h](j)}(h ``vm_bo__``h]j)}(hj_h]hvm_bo__}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjYubj )}(hhh]h)}(hNthe :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuva` to walk are associated withh](hthe }(hjxhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjthMhjxubh the }(hjxhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjthMhjxubh to walk are associated with}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjthMhjuubah}(h]h ]h"]h$]h&]uh1j hjYubeh}(h]h ]h"]h$]h&]uh1jhjthMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjބubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hgThis iterator walks over all :c:type:`drm_gpuva` structures associated with the :c:type:`drm_gpuvm_bo`.h](hThis iterator walks over all }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh structures associated with the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj$h]h drm_gpuvm_bo}(hj&hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h*The caller must hold the GEM's gpuva lock.h]h,The caller must hold the GEM’s gpuva lock.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gpuvm_bo_for_each_va_safe (C macro)c.drm_gpuvm_bo_for_each_va_safehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_bo_for_each_va_safeh]j>)}(hdrm_gpuvm_bo_for_each_va_safeh]jg)}(hdrm_gpuvm_bo_for_each_va_safeh]jm)}(hjth]hdrm_gpuvm_bo_for_each_va_safe}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjvhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM&ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjrhhhjhM&ubah}(h]jmah ](jjeh"]h$]h&]jj)jhuh1j7hjhM&hjohhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjohhhjhM&ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubh)}(h9``drm_gpuvm_bo_for_each_va_safe (va__, next__, vm_bo__)``h]j)}(hjh]h5drm_gpuvm_bo_for_each_va_safe (va__, next__, vm_bo__)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM(hj Ahhubj)}(h;iterator to safely walk over a list of :c:type:`drm_gpuva` h]h)}(h:iterator to safely walk over a list of :c:type:`drm_gpuva`h](h'iterator to safely walk over a list of }(hjʅhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjԅh]h drm_gpuva}(hjօhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj҅ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM&hjʅubeh}(h]h ]h"]h$]h&]uh1hhjhM&hjƅubah}(h]h ]h"]h$]h&]uh1jhjhM&hj Ahhubj)}(hX **Parameters** ``va__`` :c:type:`drm_gpuva` structure to assign to in each iteration step ``next__`` :c:type:`next` :c:type:`drm_gpuva` to store the next step ``vm_bo__`` the :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuva` to walk are associated with **Description** This iterator walks over all :c:type:`drm_gpuva` structures associated with the :c:type:`drm_gpuvm_bo`. It is implemented with list_for_each_entry_safe(), hence it is save against removal of elements. The caller must hold the GEM's gpuva lock.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM*hjubj)}(hhh](j)}(hK``va__`` :c:type:`drm_gpuva` structure to assign to in each iteration step h](j)}(h``va__``h]j)}(hj#h]hva__}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM(hjubj )}(hhh]h)}(hA:c:type:`drm_gpuva` structure to assign to in each iteration steph](h)}(h:c:type:`drm_gpuva`h]j)}(hjBh]h drm_gpuva}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj8hM(hj<ubh. structure to assign to in each iteration step}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hM(hj9ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM(hjubj)}(hE``next__`` :c:type:`next` :c:type:`drm_gpuva` to store the next step h](j)}(h ``next__``h]j)}(hj{h]hnext__}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM)hjuubj )}(hhh]h)}(h9:c:type:`next` :c:type:`drm_gpuva` to store the next steph](h)}(h:c:type:`next`h]j)}(hjh]hnext}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMnextuh1hhjhM)hjubh }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhM)hjubh to store the next step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM)hjubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(h[``vm_bo__`` the :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuva` to walk are associated with h](j)}(h ``vm_bo__``h]j)}(hjh]hvm_bo__}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM*hjubj )}(hhh]h)}(hNthe :c:type:`drm_gpuvm_bo` the :c:type:`drm_gpuva` to walk are associated withh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj hM*hjubh the }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj<h]h drm_gpuva}(hj>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj hM*hjubh to walk are associated with}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hM*hj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hM*hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjwh]h Description}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM,hjubh)}(hThis iterator walks over all :c:type:`drm_gpuva` structures associated with the :c:type:`drm_gpuvm_bo`. It is implemented with list_for_each_entry_safe(), hence it is save against removal of elements.h](hThis iterator walks over all }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM+hjubh structures associated with the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhM+hjubhb. It is implemented with list_for_each_entry_safe(), hence it is save against removal of elements.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM+hjubh)}(h*The caller must hold the GEM's gpuva lock.h]h,The caller must hold the GEM’s gpuva lock.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM/hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_op_type (C enum)c.drm_gpuva_op_typehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_op_typeh]j>)}(henum drm_gpuva_op_typeh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM4ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhM4ubjg)}(hdrm_gpuva_op_typeh]jm)}(hj h]hdrm_gpuva_op_type}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhM4ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhjhM4ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM4hjhhubj)}(hhh]h)}(hGPU VA operation typeh]hGPU VA operation type}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM6hjPhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM4ubeh}(h]h ](jenumeh"]h$]h&]jjjjkjjkjjjuh1j2hhhj AhNhNubj)}(h**Constants** ``DRM_GPUVA_OP_MAP`` the map op type ``DRM_GPUVA_OP_REMAP`` the remap op type ``DRM_GPUVA_OP_UNMAP`` the unmap op type ``DRM_GPUVA_OP_PREFETCH`` the prefetch op type ``DRM_GPUVA_OP_DRIVER`` the driver defined op typeh](h)}(h **Constants**h]j)}(hjuh]h Constants}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM:hjoubj)}(hhh](j)}(h%``DRM_GPUVA_OP_MAP`` the map op type h](j)}(h``DRM_GPUVA_OP_MAP``h]j)}(hjh]hDRM_GPUVA_OP_MAP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM=hjubj )}(hhh]h)}(hthe map op typeh]hthe map op type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM=hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM=hjubj)}(h)``DRM_GPUVA_OP_REMAP`` the remap op type h](j)}(h``DRM_GPUVA_OP_REMAP``h]j)}(hj͈h]hDRM_GPUVA_OP_REMAP}(hjψhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjˈubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM@hjLjubj )}(hhh]h)}(hthe remap op typeh]hthe remap op type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM@hjubah}(h]h ]h"]h$]h&]uh1j hjLjubeh}(h]h ]h"]h$]h&]uh1jhjhM@hjubj)}(h)``DRM_GPUVA_OP_UNMAP`` the unmap op type h](j)}(h``DRM_GPUVA_OP_UNMAP``h]j)}(hjh]hDRM_GPUVA_OP_UNMAP}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMChjubj )}(hhh]h)}(hthe unmap op typeh]hthe unmap op type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMChjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMChjubj)}(h/``DRM_GPUVA_OP_PREFETCH`` the prefetch op type h](j)}(h``DRM_GPUVA_OP_PREFETCH``h]j)}(hj?h]hDRM_GPUVA_OP_PREFETCH}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMFhj9ubj )}(hhh]h)}(hthe prefetch op typeh]hthe prefetch op type}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMFhjUubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThMFhjubj)}(h2``DRM_GPUVA_OP_DRIVER`` the driver defined op typeh](j)}(h``DRM_GPUVA_OP_DRIVER``h]j)}(hjxh]hDRM_GPUVA_OP_DRIVER}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMHhjrubj )}(hhh]h)}(hthe driver defined op typeh]hthe driver defined op type}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMIhjubah}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhMHhjubeh}(h]h ]h"]h$]h&]uh1jhjoubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMKhj Ahhubh)}(hKOperations to alter the GPU VA mappings tracked by the :c:type:`drm_gpuvm`.h](h7Operations to alter the GPU VA mappings tracked by the }(hjщhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjۉh]h drm_gpuvm}(hj݉hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjىubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM7hjщubh.}(hjщhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM7hj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_op_map (C struct)c.drm_gpuva_op_maphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_op_maph]j>)}(hstruct drm_gpuva_op_maph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM<ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj)hM<ubjg)}(hdrm_gpuva_op_maph]jm)}(hjh]hdrm_gpuva_op_map}(hj<hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj8ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj)hM<ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj)hM<ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj)hM<hjhhubj)}(hhh]h)}(hGPU VA map operationh]hGPU VA map operation}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMVhj[hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj)hM<ubeh}(h]h ](jstructeh"]h$]h&]jjjjvjjvjjjuh1j2hhhj AhNhNubj)}(hXA**Definition**:: struct drm_gpuva_op_map { struct { u64 addr; u64 range; } va; struct { u64 offset; struct drm_gem_object *obj; } gem; }; **Members** ``va`` structure containing address and range of a map operation ``va.addr`` the base address of the new mapping ``va.range`` the range of the new mapping ``gem`` structure containing the :c:type:`drm_gem_object` and its offset ``gem.offset`` the offset within the :c:type:`drm_gem_object` ``gem.obj`` the :c:type:`drm_gem_object` to maph](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubh:}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMZhjzubjT)}(hstruct drm_gpuva_op_map { struct { u64 addr; u64 range; } va; struct { u64 offset; struct drm_gem_object *obj; } gem; };h]hstruct drm_gpuva_op_map { struct { u64 addr; u64 range; } va; struct { u64 offset; struct drm_gem_object *obj; } gem; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM\hjzubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMghjzubj)}(hhh](j)}(hA``va`` structure containing address and range of a map operation h](j)}(h``va``h]j)}(hjˊh]hva}(hj͊hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjɊubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM_hjŊubj )}(hhh]h)}(h9structure containing address and range of a map operationh]h9structure containing address and range of a map operation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM^hjubah}(h]h ]h"]h$]h&]uh1j hjŊubeh}(h]h ]h"]h$]h&]uh1jhjhM_hjŠubj)}(h0``va.addr`` the base address of the new mapping h](j)}(h ``va.addr``h]j)}(hjh]hva.addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMchjubj )}(hhh]h)}(h#the base address of the new mappingh]h#the base address of the new mapping}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMchjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMchjŠubj)}(h*``va.range`` the range of the new mapping h](j)}(h ``va.range``h]j)}(hj>h]hva.range}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhhj8ubj )}(hhh]h)}(hthe range of the new mappingh]hthe range of the new mapping}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjShMhhjTubah}(h]h ]h"]h$]h&]uh1j hj8ubeh}(h]h ]h"]h$]h&]uh1jhjShMhhjŠubj)}(hI``gem`` structure containing the :c:type:`drm_gem_object` and its offset h](j)}(h``gem``h]j)}(hjwh]hgem}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMnhjqubj )}(hhh]h)}(h@structure containing the :c:type:`drm_gem_object` and its offseth](hstructure containing the }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMnhjubh and its offset}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMnhjubah}(h]h ]h"]h$]h&]uh1j hjqubeh}(h]h ]h"]h$]h&]uh1jhjhMnhjŠubj)}(h>``gem.offset`` the offset within the :c:type:`drm_gem_object` h](j)}(h``gem.offset``h]j)}(hjӋh]h gem.offset}(hjՋhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjыubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMrhj͋ubj )}(hhh]h)}(h.the offset within the :c:type:`drm_gem_object`h](hthe offset within the }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMrhjubeh}(h]h ]h"]h$]h&]uh1hhjhMrhjubah}(h]h ]h"]h$]h&]uh1j hj͋ubeh}(h]h ]h"]h$]h&]uh1jhjhMrhjŠubj)}(h/``gem.obj`` the :c:type:`drm_gem_object` to maph](j)}(h ``gem.obj``h]j)}(hj+h]hgem.obj}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMvhj%ubj )}(hhh]h)}(h#the :c:type:`drm_gem_object` to maph](hthe }(hjDhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjNh]hdrm_gem_object}(hjPhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMwhjDubh to map}(hjDhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjkhMwhjAubah}(h]h ]h"]h$]h&]uh1j hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMvhjŠubeh}(h]h ]h"]h$]h&]uh1jhjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMzhj Ahhubh)}(hUThis structure represents a single map operation generated by the DRM GPU VA manager.h]hUThis structure represents a single map operation generated by the DRM GPU VA manager.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMWhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_op_unmap (C struct)c.drm_gpuva_op_unmaphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_op_unmaph]j>)}(hstruct drm_gpuva_op_unmaph](jD)}(hjh]hstruct}(hjόhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjˌhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM]ubjV)}(h h]h }(hj݌hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjˌhhhj܌hM]ubjg)}(hdrm_gpuva_op_unmaph]jm)}(hjɌh]hdrm_gpuva_op_unmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjˌhhhj܌hM]ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjnjhhhj܌hM]ubah}(h]jŒah ](jjeh"]h$]h&]jj)jhuh1j7hj܌hM]hjČhhubj)}(hhh]h)}(hGPU VA unmap operationh]hGPU VA unmap operation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM}hjhhubah}(h]h ]h"]h$]h&]uh1jhjČhhhj܌hM]ubeh}(h]h ](jstructeh"]h$]h&]jjjj)jj)jjjuh1j2hhhj AhNhNubj)}(hX**Definition**:: struct drm_gpuva_op_unmap { struct drm_gpuva *va; bool keep; }; **Members** ``va`` the :c:type:`drm_gpuva` to unmap ``keep`` Indicates whether this :c:type:`drm_gpuva` is physically contiguous with the original mapping request. Optionally, if :c:type:`keep` is set, drivers may keep the actual page table mappings for this :c:type:`drm_gpuva`, adding the missing page table entries only and update the :c:type:`drm_gpuvm` accordingly.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubh:}(hj1hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj-ubjT)}(hGstruct drm_gpuva_op_unmap { struct drm_gpuva *va; bool keep; };h]hGstruct drm_gpuva_op_unmap { struct drm_gpuva *va; bool keep; };}hjNsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj-ubh)}(h **Members**h]j)}(hj_h]hMembers}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj-ubj)}(hhh](j)}(h(``va`` the :c:type:`drm_gpuva` to unmap h](j)}(h``va``h]j)}(hj~h]hva}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjxubj )}(hhh]h)}(h the :c:type:`drm_gpuva` to unmaph](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhMhjubh to unmap}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMhjuubj)}(hX?``keep`` Indicates whether this :c:type:`drm_gpuva` is physically contiguous with the original mapping request. Optionally, if :c:type:`keep` is set, drivers may keep the actual page table mappings for this :c:type:`drm_gpuva`, adding the missing page table entries only and update the :c:type:`drm_gpuvm` accordingly.h](j)}(h``keep``h]j)}(hjڍh]hkeep}(hj܍hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj؍ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjԍubj )}(hhh](h)}(hfIndicates whether this :c:type:`drm_gpuva` is physically contiguous with the original mapping request.h](hIndicates whether this }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh< is physically contiguous with the original mapping request.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hOptionally, if :c:type:`keep` is set, drivers may keep the actual page table mappings for this :c:type:`drm_gpuva`, adding the missing page table entries only and update the :c:type:`drm_gpuvm` accordingly.h](hOptionally, if }(hj%hhhNhNubh)}(h:c:type:`keep`h]j)}(hj/h]hkeep}(hj1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMkeepuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj%ubhB is set, drivers may keep the actual page table mappings for this }(hj%hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjSh]h drm_gpuva}(hjUhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjLhMhj%ubh<, adding the missing page table entries only and update the }(hj%hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjvh]h drm_gpuvm}(hjxhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjLhMhj%ubh accordingly.}(hj%hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjLhMhjubeh}(h]h ]h"]h$]h&]uh1j hjԍubeh}(h]h ]h"]h$]h&]uh1jhjhMhjuubeh}(h]h ]h"]h$]h&]uh1jhj-ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hWThis structure represents a single unmap operation generated by the DRM GPU VA manager.h]hWThis structure represents a single unmap operation generated by the DRM GPU VA manager.}(hjΎhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM~hj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_op_remap (C struct)c.drm_gpuva_op_remaphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_op_remaph]j>)}(hstruct drm_gpuva_op_remaph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuva_op_remaph]jm)}(hjh]hdrm_gpuva_op_remap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hGPU VA remap operationh]hGPU VA remap operation}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj5hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jstructeh"]h$]h&]jjjjPjjPjjjuh1j2hhhj AhNhNubj)}(hX[**Definition**:: struct drm_gpuva_op_remap { struct drm_gpuva_op_map *prev; struct drm_gpuva_op_map *next; struct drm_gpuva_op_unmap *unmap; }; **Members** ``prev`` the preceding part of a split mapping ``next`` the subsequent part of a split mapping ``unmap`` the unmap operation for the original existing mappingh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubh:}(hjXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjTubjT)}(hstruct drm_gpuva_op_remap { struct drm_gpuva_op_map *prev; struct drm_gpuva_op_map *next; struct drm_gpuva_op_unmap *unmap; };h]hstruct drm_gpuva_op_remap { struct drm_gpuva_op_map *prev; struct drm_gpuva_op_map *next; struct drm_gpuva_op_unmap *unmap; };}hjusbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjTubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjTubj)}(hhh](j)}(h/``prev`` the preceding part of a split mapping h](j)}(h``prev``h]j)}(hjh]hprev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h%the preceding part of a split mappingh]h%the preceding part of a split mapping}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h0``next`` the subsequent part of a split mapping h](j)}(h``next``h]j)}(hjޏh]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj܏ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj؏ubj )}(hhh]h)}(h&the subsequent part of a split mappingh]h&the subsequent part of a split mapping}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hj؏ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h?``unmap`` the unmap operation for the original existing mappingh](j)}(h ``unmap``h]j)}(hjh]hunmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h5the unmap operation for the original existing mappingh]h5the unmap operation for the original existing mapping}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj-ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj,hMhjubeh}(h]h ]h"]h$]h&]uh1jhjTubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjZh]h Description}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hMThis represents a single remap operation generated by the DRM GPU VA manager.h]hMThis represents a single remap operation generated by the DRM GPU VA manager.}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hA remap operation is generated when an existing GPU VA mmapping is split up by inserting a new GPU VA mapping or by partially unmapping existent mapping(s), hence it consists of a maximum of two map and one unmap operation.h]hA remap operation is generated when an existing GPU VA mmapping is split up by inserting a new GPU VA mapping or by partially unmapping existent mapping(s), hence it consists of a maximum of two map and one unmap operation.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hThe **unmap** operation takes care of removing the original existing mapping. **prev** is used to remap the preceding part, **next** the subsequent part.h](hThe }(hjhhhNhNubj)}(h **unmap**h]hunmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhA operation takes care of removing the original existing mapping. }(hjhhhNhNubj)}(h**prev**h]hprev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh& is used to remap the preceding part, }(hjhhhNhNubj)}(h**next**h]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh the subsequent part.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hIf either a new mapping's start address is aligned with the start address of the old mapping or the new mapping's end address is aligned with the end address of the old mapping, either **prev** or **next** is NULL.h](hIf either a new mapping’s start address is aligned with the start address of the old mapping or the new mapping’s end address is aligned with the end address of the old mapping, either }(hjӐhhhNhNubj)}(h**prev**h]hprev}(hjېhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjӐubh or }(hjӐhhhNhNubj)}(h**next**h]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjӐubh is NULL.}(hjӐhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hX<Note, the reason for a dedicated remap operation, rather than arbitrary unmap and map operations, is to give drivers the chance of extracting driver specific data for creating the new mappings from the unmap operations's :c:type:`drm_gpuva` structure which typically is embedded in larger driver specific structures.h](hNote, the reason for a dedicated remap operation, rather than arbitrary unmap and map operations, is to give drivers the chance of extracting driver specific data for creating the new mappings from the unmap operations’s }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubhL structure which typically is embedded in larger driver specific structures.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj-hMhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gpuva_op_prefetch (C struct)c.drm_gpuva_op_prefetchhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_op_prefetchh]j>)}(hstruct drm_gpuva_op_prefetchh](jD)}(hjh]hstruct}(hjQhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjMhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMhhhj^hMubjg)}(hdrm_gpuva_op_prefetchh]jm)}(hjKh]hdrm_gpuva_op_prefetch}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjMhhhj^hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjIhhhj^hMubah}(h]jDah ](jjeh"]h$]h&]jj)jhuh1j7hj^hMhjFhhubj)}(hhh]h)}(hGPU VA prefetch operationh]hGPU VA prefetch operation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjFhhhj^hMubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(h**Definition**:: struct drm_gpuva_op_prefetch { struct drm_gpuva *va; }; **Members** ``va`` the :c:type:`drm_gpuva` to prefetchh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubjT)}(h;struct drm_gpuva_op_prefetch { struct drm_gpuva *va; };h]h;struct drm_gpuva_op_prefetch { struct drm_gpuva *va; };}hjБsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjߑubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh]j)}(h*``va`` the :c:type:`drm_gpuva` to prefetchh](j)}(h``va``h]j)}(hjh]hva}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h#the :c:type:`drm_gpuva` to prefetchh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj#h]h drm_gpuva}(hj%hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh to prefetch}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj@hMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hjfh]h Description}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hZThis structure represents a single prefetch operation generated by the DRM GPU VA manager.h]hZThis structure represents a single prefetch operation generated by the DRM GPU VA manager.}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_op (C struct)c.drm_gpuva_ophNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuva_oph]j>)}(hstruct drm_gpuva_oph](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(h drm_gpuva_oph]jm)}(hjh]h drm_gpuva_op}(hjĒhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hGPU VA operationh]hGPU VA operation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX}**Definition**:: struct drm_gpuva_op { struct list_head entry; enum drm_gpuva_op_type op; union { struct drm_gpuva_op_map map; struct drm_gpuva_op_remap remap; struct drm_gpuva_op_unmap unmap; struct drm_gpuva_op_prefetch prefetch; }; }; **Members** ``entry`` The :c:type:`list_head` used to distribute instances of this struct within :c:type:`drm_gpuva_ops`. ``op`` the type of the operation ``{unnamed_union}`` anonymous ``map`` the map operation ``remap`` the remap operation ``unmap`` the unmap operation ``prefetch`` the prefetch operationh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubjT)}(hX struct drm_gpuva_op { struct list_head entry; enum drm_gpuva_op_type op; union { struct drm_gpuva_op_map map; struct drm_gpuva_op_remap remap; struct drm_gpuva_op_unmap unmap; struct drm_gpuva_op_prefetch prefetch; }; };h]hX struct drm_gpuva_op { struct list_head entry; enum drm_gpuva_op_type op; union { struct drm_gpuva_op_map map; struct drm_gpuva_op_remap remap; struct drm_gpuva_op_unmap unmap; struct drm_gpuva_op_prefetch prefetch; }; };}hj#sbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(h **Members**h]j)}(hj4h]hMembers}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh](j)}(hn``entry`` The :c:type:`list_head` used to distribute instances of this struct within :c:type:`drm_gpuva_ops`. h](j)}(h ``entry``h]j)}(hjSh]hentry}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjMubj )}(hhh]h)}(hcThe :c:type:`list_head` used to distribute instances of this struct within :c:type:`drm_gpuva_ops`.h](hThe }(hjlhhhNhNubh)}(h:c:type:`list_head`h]j)}(hjvh]h list_head}(hjxhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjlubh4 used to distribute instances of this struct within }(hjlhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhjhMhjlubh.}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjiubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjJubj)}(h!``op`` the type of the operation h](j)}(h``op``h]j)}(hjӓh]hop}(hjՓhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjѓubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj͓ubj )}(hhh]h)}(hthe type of the operationh]hthe type of the operation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hj͓ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjJubj)}(h``{unnamed_union}`` anonymous h](j)}(h``{unnamed_union}``h]j)}(hj h]h{unnamed_union}}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhKhjubj )}(hhh]h)}(h anonymoush]h anonymous}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hKhj"ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj!hKhjJubj)}(h``map`` the map operation h](j)}(h``map``h]j)}(hjEh]hmap}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj?ubj )}(hhh]h)}(hthe map operationh]hthe map operation}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhMhj[ubah}(h]h ]h"]h$]h&]uh1j hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhMhjJubj)}(h``remap`` the remap operation h](j)}(h ``remap``h]j)}(hj~h]hremap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjxubj )}(hhh]h)}(hthe remap operationh]hthe remap operation}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhMhjJubj)}(h``unmap`` the unmap operation h](j)}(h ``unmap``h]j)}(hjh]hunmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(hthe unmap operationh]hthe unmap operation}(hjДhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj̔hMhj͔ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj̔hMhjJubj)}(h#``prefetch`` the prefetch operationh](j)}(h ``prefetch``h]j)}(hjh]hprefetch}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(hthe prefetch operationh]hthe prefetch operation}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjJubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hj3h]h Description}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(h5This structure represents a single generic operation.h]h5This structure represents a single generic operation.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(h:The particular type of the operation is defined by **op**.h](h3The particular type of the operation is defined by }(hjXhhhNhNubj)}(h**op**h]hop}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubh.}(hjXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_ops (C struct)c.drm_gpuva_opshNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuva_opsh]j>)}(hstruct drm_gpuva_opsh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(h drm_gpuva_opsh]jm)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h&wraps a list of :c:type:`drm_gpuva_op`h](hwraps a list of }(hjԕhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjޕh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjܕubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j )}jjsbc.drm_gpuva_opsasbjM drm_gpuva_opuh1hhjIhKhjԕubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjѕhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(h}**Definition**:: struct drm_gpuva_ops { struct list_head list; }; **Members** ``list`` the :c:type:`list_head`h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubjT)}(h4struct drm_gpuva_ops { struct list_head list; };h]h4struct drm_gpuva_ops { struct list_head list; };}hj7sbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(h **Members**h]j)}(hjHh]hMembers}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh]j)}(h ``list`` the :c:type:`list_head`h](j)}(h``list``h]j)}(hjgh]hlist}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjaubj )}(hhh]h)}(hthe :c:type:`list_head`h](hthe }(hjhhhNhNubh)}(h:c:type:`list_head`h]j)}(hjh]h list_head}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM list_headuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhj}ubah}(h]h ]h"]h$]h&]uh1j hjaubeh}(h]h ]h"]h$]h&]uh1jhj|hMhj^ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_for_each_op (C macro)c.drm_gpuva_for_each_ophNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_for_each_oph]j>)}(hdrm_gpuva_for_each_oph]jg)}(hdrm_gpuva_for_each_oph]jm)}(hjږh]hdrm_gpuva_for_each_op}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjܖhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjؖhhhjhMubah}(h]jӖah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjՖhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjՖhhhjhMubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubh)}(h#``drm_gpuva_for_each_op (op, ops)``h]j)}(hjh]hdrm_gpuva_for_each_op (op, ops)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h.iterator to walk over :c:type:`drm_gpuva_ops` h]h)}(h-iterator to walk over :c:type:`drm_gpuva_ops`h](hiterator to walk over }(hj0hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj:h]h drm_gpuva_ops}(hj<hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj0ubeh}(h]h ]h"]h$]h&]uh1hhjWhMhj,ubah}(h]h ]h"]h$]h&]uh1jhjWhMhj Ahhubj)}(h**Parameters** ``op`` :c:type:`drm_gpuva_op` to assign in each iteration step ``ops`` :c:type:`drm_gpuva_ops` to walk **Description** This iterator walks over all ops within a given list of operations.h](h)}(h**Parameters**h]j)}(hjjh]h Parameters}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjdubj)}(hhh](j)}(h?``op`` :c:type:`drm_gpuva_op` to assign in each iteration step h](j)}(h``op``h]j)}(hjh]hop}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h7:c:type:`drm_gpuva_op` to assign in each iteration steph](h)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhjhMhjubh! to assign in each iteration step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h(``ops`` :c:type:`drm_gpuva_ops` to walk h](j)}(h``ops``h]j)}(hjh]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjߗubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjۗubj )}(hhh]h)}(h:c:type:`drm_gpuva_ops` to walkh](h)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhjhMhjubh to walk}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjۗubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjdubh)}(h**Description**h]j)}(hj;h]h Description}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjdubh)}(hCThis iterator walks over all ops within a given list of operations.h]hCThis iterator walks over all ops within a given list of operations.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjdubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gpuva_for_each_op_safe (C macro)c.drm_gpuva_for_each_op_safehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_for_each_op_safeh]j>)}(hdrm_gpuva_for_each_op_safeh]jg)}(hdrm_gpuva_for_each_op_safeh]jm)}(hjzh]hdrm_gpuva_for_each_op_safe}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj|hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjxhhhjhM ubah}(h]jsah ](jjeh"]h$]h&]jj)jhuh1j7hjhM hjuhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjuhhhjhM ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubh)}(h.``drm_gpuva_for_each_op_safe (op, next, ops)``h]j)}(hjh]h*drm_gpuva_for_each_op_safe (op, next, ops)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hj Ahhubj)}(h5iterator to safely walk over :c:type:`drm_gpuva_ops` h]h)}(h4iterator to safely walk over :c:type:`drm_gpuva_ops`h](hiterator to safely walk over }(hjИhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjژh]h drm_gpuva_ops}(hjܘhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjؘubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hjИubeh}(h]h ]h"]h$]h&]uh1hhjhM hj̘ubah}(h]h ]h"]h$]h&]uh1jhjhM hj Ahhubj)}(hXl**Parameters** ``op`` :c:type:`drm_gpuva_op` to assign in each iteration step ``next`` :c:type:`next` :c:type:`drm_gpuva_op` to store the next step ``ops`` :c:type:`drm_gpuva_ops` to walk **Description** This iterator walks over all ops within a given list of operations. It is implemented with list_for_each_safe(), so save against removal of elements.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh](j)}(h?``op`` :c:type:`drm_gpuva_op` to assign in each iteration step h](j)}(h``op``h]j)}(hj)h]hop}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hj#ubj )}(hhh]h)}(h7:c:type:`drm_gpuva_op` to assign in each iteration steph](h)}(h:c:type:`drm_gpuva_op`h]j)}(hjHh]h drm_gpuva_op}(hjJhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhj>hM hjBubh! to assign in each iteration step}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj>hM hj?ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM hj ubj)}(hF``next`` :c:type:`next` :c:type:`drm_gpuva_op` to store the next step h](j)}(h``next``h]j)}(hjh]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hj{ubj )}(hhh]h)}(h<:c:type:`next` :c:type:`drm_gpuva_op` to store the next steph](h)}(h:c:type:`next`h]j)}(hjh]hnext}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMnextuh1hhjhM hjubh }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjÙh]h drm_gpuva_op}(hjřhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhjhM hjubh to store the next step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hj{ubeh}(h]h ]h"]h$]h&]uh1jhjhM hj ubj)}(h(``ops`` :c:type:`drm_gpuva_ops` to walk h](j)}(h``ops``h]j)}(hjh]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM hjubj )}(hhh]h)}(h:c:type:`drm_gpuva_ops` to walkh](h)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhjhM hjubh to walk}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hj ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjVh]h Description}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hThis iterator walks over all ops within a given list of operations. It is implemented with list_for_each_safe(), so save against removal of elements.h]hThis iterator walks over all ops within a given list of operations. It is implemented with list_for_each_safe(), so save against removal of elements.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.,drm_gpuva_for_each_op_from_reverse (C macro)$c.drm_gpuva_for_each_op_from_reversehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h"drm_gpuva_for_each_op_from_reverseh]j>)}(h"drm_gpuva_for_each_op_from_reverseh]jg)}(h"drm_gpuva_for_each_op_from_reverseh]jm)}(hjh]h"drm_gpuva_for_each_op_from_reverse}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jmacroeh"]h$]h&]jjjj˚jj˚jjjuh1j2hhhj AhNhNubh)}(h0``drm_gpuva_for_each_op_from_reverse (op, ops)``h]j)}(hjњh]h,drm_gpuva_for_each_op_from_reverse (op, ops)}(hjӚhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjϚubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubj)}(h'iterate backwards from the given point h]h)}(h&iterate backwards from the given pointh]h&iterate backwards from the given point}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubah}(h]h ]h"]h$]h&]uh1jhjhMhj Ahhubj)}(hX**Parameters** ``op`` :c:type:`drm_gpuva_op` to assign in each iteration step ``ops`` :c:type:`drm_gpuva_ops` to walk **Description** This iterator walks over all ops within a given list of operations beginning from the given operation in reverse order.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj)}(hhh](j)}(h?``op`` :c:type:`drm_gpuva_op` to assign in each iteration step h](j)}(h``op``h]j)}(hj%h]hop}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h7:c:type:`drm_gpuva_op` to assign in each iteration steph](h)}(h:c:type:`drm_gpuva_op`h]j)}(hjDh]h drm_gpuva_op}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhj:hMhj>ubh! to assign in each iteration step}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj:hMhj;ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj:hMhjubj)}(h(``ops`` :c:type:`drm_gpuva_ops` to walk h](j)}(h``ops``h]j)}(hj}h]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubj )}(hhh]h)}(h:c:type:`drm_gpuva_ops` to walkh](h)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhjhMhjubh to walk}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjwubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjכh]h Description}(hjٛhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj՛ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hwThis iterator walks over all ops within a given list of operations beginning from the given operation in reverse order.h]hwThis iterator walks over all ops within a given list of operations beginning from the given operation in reverse order.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gpuva_for_each_op_reverse (C macro)c.drm_gpuva_for_each_op_reversehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_for_each_op_reverseh]j>)}(hdrm_gpuva_for_each_op_reverseh]jg)}(hdrm_gpuva_for_each_op_reverseh]jm)}(hjh]hdrm_gpuva_for_each_op_reverse}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM!ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj3hM!ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj3hM!hjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhj3hM!ubeh}(h]h ](jmacroeh"]h$]h&]jjjjLjjLjjjuh1j2hhhj AhNhNubh)}(h+``drm_gpuva_for_each_op_reverse (op, ops)``h]j)}(hjRh]h'drm_gpuva_for_each_op_reverse (op, ops)}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM#hj Ahhubj)}(h9iterator to walk over :c:type:`drm_gpuva_ops` in reverse h]h)}(h8iterator to walk over :c:type:`drm_gpuva_ops` in reverseh](hiterator to walk over }(hjlhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjvh]h drm_gpuva_ops}(hjxhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM!hjlubh in reverse}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM!hjhubah}(h]h ]h"]h$]h&]uh1jhjhM!hj Ahhubj)}(h**Parameters** ``op`` :c:type:`drm_gpuva_op` to assign in each iteration step ``ops`` :c:type:`drm_gpuva_ops` to walk **Description** This iterator walks over all ops within a given list of operations in reverseh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM%hjubj)}(hhh](j)}(h?``op`` :c:type:`drm_gpuva_op` to assign in each iteration step h](j)}(h``op``h]j)}(hjɜh]hop}(hj˜hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjǜubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM"hjÜubj )}(hhh]h)}(h7:c:type:`drm_gpuva_op` to assign in each iteration steph](h)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhjޜhM"hjubh! to assign in each iteration step}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjޜhM"hjߜubah}(h]h ]h"]h$]h&]uh1j hjÜubeh}(h]h ]h"]h$]h&]uh1jhjޜhM"hjubj)}(h(``ops`` :c:type:`drm_gpuva_ops` to walk h](j)}(h``ops``h]j)}(hj!h]hops}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM#hjubj )}(hhh]h)}(h:c:type:`drm_gpuva_ops` to walkh](h)}(h:c:type:`drm_gpuva_ops`h]j)}(hj@h]h drm_gpuva_ops}(hjBhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhj6hM#hj:ubh to walk}(hj:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj6hM#hj7ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj6hM#hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj{h]h Description}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM%hjubh)}(hMThis iterator walks over all ops within a given list of operations in reverseh]hMThis iterator walks over all ops within a given list of operations in reverse}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_first_op (C macro)c.drm_gpuva_first_ophNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_first_oph]j>)}(hdrm_gpuva_first_oph]jg)}(hdrm_gpuva_first_oph]jm)}(hjh]hdrm_gpuva_first_op}(hjĝhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM+ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjםhM+ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjםhM+hjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjםhM+ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubh)}(h``drm_gpuva_first_op (ops)``h]j)}(hjh]hdrm_gpuva_first_op (ops)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM-hj Ahhubj)}(hFreturns the first :c:type:`drm_gpuva_op` from :c:type:`drm_gpuva_ops` h]h)}(hEreturns the first :c:type:`drm_gpuva_op` from :c:type:`drm_gpuva_ops`h](hreturns the first }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM+hjubh from }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj>h]h drm_gpuva_ops}(hj@hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhj7hM+hjubeh}(h]h ]h"]h$]h&]uh1hhj7hM+hj ubah}(h]h ]h"]h$]h&]uh1jhj7hM+hj Ahhubj)}(ha**Parameters** ``ops`` the :c:type:`drm_gpuva_ops` to get the fist :c:type:`drm_gpuva_op` fromh](h)}(h**Parameters**h]j)}(hjmh]h Parameters}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM/hjgubj)}(hhh]j)}(hO``ops`` the :c:type:`drm_gpuva_ops` to get the fist :c:type:`drm_gpuva_op` fromh](j)}(h``ops``h]j)}(hjh]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM1hjubj )}(hhh]h)}(hGthe :c:type:`drm_gpuva_ops` to get the fist :c:type:`drm_gpuva_op` fromh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM,hjubh to get the fist }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjӞh]h drm_gpuva_op}(hj՞hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjўubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhj̞hM,hjubh from}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj̞hM,hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjubah}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_last_op (C macro)c.drm_gpuva_last_ophNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_last_oph]j>)}(hdrm_gpuva_last_oph]jg)}(hdrm_gpuva_last_oph]jm)}(hj&h]hdrm_gpuva_last_op}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj(hhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM2ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj$hhhjChM2ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjChM2hj!hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj!hhhjChM2ubeh}(h]h ](jmacroeh"]h$]h&]jjjj\jj\jjjuh1j2hhhj AhNhNubh)}(h``drm_gpuva_last_op (ops)``h]j)}(hjbh]hdrm_gpuva_last_op (ops)}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM4hj Ahhubj)}(hEreturns the last :c:type:`drm_gpuva_op` from :c:type:`drm_gpuva_ops` h]h)}(hDreturns the last :c:type:`drm_gpuva_op` from :c:type:`drm_gpuva_ops`h](hreturns the last }(hj|hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM2hj|ubh from }(hj|hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhjhM2hj|ubeh}(h]h ]h"]h$]h&]uh1hhjhM2hjxubah}(h]h ]h"]h$]h&]uh1jhjhM2hj Ahhubj)}(ha**Parameters** ``ops`` the :c:type:`drm_gpuva_ops` to get the last :c:type:`drm_gpuva_op` fromh](h)}(h**Parameters**h]j)}(hjٟh]h Parameters}(hj۟hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjןubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM6hjӟubj)}(hhh]j)}(hO``ops`` the :c:type:`drm_gpuva_ops` to get the last :c:type:`drm_gpuva_op` fromh](j)}(h``ops``h]j)}(hjh]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM8hjubj )}(hhh]h)}(hGthe :c:type:`drm_gpuva_ops` to get the last :c:type:`drm_gpuva_op` fromh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjh]h drm_gpuva_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM3hjubh to get the last }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hj?h]h drm_gpuva_op}(hjAhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhj8hM3hjubh from}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hM3hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hM8hjubah}(h]h ]h"]h$]h&]uh1jhjӟubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_prev_op (C macro)c.drm_gpuva_prev_ophNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_prev_oph]j>)}(hdrm_gpuva_prev_oph]jg)}(hdrm_gpuva_prev_oph]jm)}(hjh]hdrm_gpuva_prev_op}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM9ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM9ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM9hjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjhM9ubeh}(h]h ](jmacroeh"]h$]h&]jjjjȠjjȠjjjuh1j2hhhj AhNhNubh)}(h``drm_gpuva_prev_op (op)``h]j)}(hjΠh]hdrm_gpuva_prev_op (op)}(hjРhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj̠ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM;hj Ahhubj)}(h,previous :c:type:`drm_gpuva_op` in the list h]h)}(h+previous :c:type:`drm_gpuva_op` in the listh](h previous }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM9hjubh in the list}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM9hjubah}(h]h ]h"]h$]h&]uh1jhjhM9hj Ahhubj)}(h;**Parameters** ``op`` the current :c:type:`drm_gpuva_op`h](h)}(h**Parameters**h]j)}(hj&h]h Parameters}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM=hj ubj)}(hhh]j)}(h)``op`` the current :c:type:`drm_gpuva_op`h](j)}(h``op``h]j)}(hjEh]hop}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM?hj?ubj )}(hhh]h)}(h"the current :c:type:`drm_gpuva_op`h](h the current }(hj^hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjhh]h drm_gpuva_op}(hjjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM:hj^ubeh}(h]h ]h"]h$]h&]uh1hhjhM:hj[ubah}(h]h ]h"]h$]h&]uh1j hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhM?hj<ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_next_op (C macro)c.drm_gpuva_next_ophNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuva_next_oph]j>)}(hdrm_gpuva_next_oph]jg)}(hdrm_gpuva_next_oph]jm)}(hjh]hdrm_gpuva_next_op}(hj¡hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM?ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjաhM?ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjաhM?hjhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjhhhjաhM?ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubh)}(h``drm_gpuva_next_op (op)``h]j)}(hjh]hdrm_gpuva_next_op (op)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMAhj Ahhubj)}(h(next :c:type:`drm_gpuva_op` in the list h]h)}(h'next :c:type:`drm_gpuva_op` in the listh](hnext }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM?hjubh in the list}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj5hM?hj ubah}(h]h ]h"]h$]h&]uh1jhj5hM?hj Ahhubj)}(h;**Parameters** ``op`` the current :c:type:`drm_gpuva_op`h](h)}(h**Parameters**h]j)}(hjLh]h Parameters}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMChjFubj)}(hhh]j)}(h)``op`` the current :c:type:`drm_gpuva_op`h](j)}(h``op``h]j)}(hjkh]hop}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMEhjeubj )}(hhh]h)}(h"the current :c:type:`drm_gpuva_op`h](h the current }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjh]h drm_gpuva_op}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM@hjubeh}(h]h ]h"]h$]h&]uh1hhjhM@hjubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMEhjbubah}(h]h ]h"]h$]h&]uh1jhjFubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_map_req (C struct)c.drm_gpuvm_map_reqhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hdrm_gpuvm_map_reqh]j>)}(hstruct drm_gpuvm_map_reqh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMEubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMEubjg)}(hdrm_gpuvm_map_reqh]jm)}(hjޢh]hdrm_gpuvm_map_req}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMEubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjܢhhhjhMEubah}(h]jעah ](jjeh"]h$]h&]jj)jhuh1j7hjhMEhj٢hhubj)}(hhh]h)}(h3arguments passed to drm_gpuvm_sm_map[_ops_create]()h]h3arguments passed to drm_gpuvm_sm_map[_ops_create]()}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMEhj#hhubah}(h]h ]h"]h$]h&]uh1jhj٢hhhjhMEubeh}(h]h ](jstructeh"]h$]h&]jjjj>jj>jjjuh1j2hhhj AhNhNubj)}(h**Definition**:: struct drm_gpuvm_map_req { struct drm_gpuva_op_map map; }; **Members** ``map`` struct drm_gpuva_op_maph](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubh:}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMIhjBubjT)}(h>struct drm_gpuvm_map_req { struct drm_gpuva_op_map map; };h]h>struct drm_gpuvm_map_req { struct drm_gpuva_op_map map; };}hjcsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMKhjBubh)}(h **Members**h]j)}(hjth]hMembers}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMOhjBubj)}(hhh]j)}(h``map`` struct drm_gpuva_op_maph](j)}(h``map``h]j)}(hjh]hmap}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMIhjubj )}(hhh]h)}(hstruct drm_gpuva_op_maph]hstruct drm_gpuva_op_map}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMJhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMIhjubah}(h]h ]h"]h$]h&]uh1jhjBubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_ops (C struct)c.drm_gpuvm_opshNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h drm_gpuvm_opsh]j>)}(hstruct drm_gpuvm_opsh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMPubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMPubjg)}(h drm_gpuvm_opsh]jm)}(hjh]h drm_gpuvm_ops}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMPubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMPubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMPhjhhubj)}(hhh]h)}(hcallbacks for split/merge stepsh]hcallbacks for split/merge steps}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMmhj,hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMPubeh}(h]h ](jstructeh"]h$]h&]jjjjGjjGjjjuh1j2hhhj AhNhNubj)}(hX9**Definition**:: struct drm_gpuvm_ops { void (*vm_free)(struct drm_gpuvm *gpuvm); struct drm_gpuva_op *(*op_alloc)(void); void (*op_free)(struct drm_gpuva_op *op); struct drm_gpuvm_bo *(*vm_bo_alloc)(void); void (*vm_bo_free)(struct drm_gpuvm_bo *vm_bo); int (*vm_bo_validate)(struct drm_gpuvm_bo *vm_bo, struct drm_exec *exec); int (*sm_step_map)(struct drm_gpuva_op *op, void *priv); int (*sm_step_remap)(struct drm_gpuva_op *op, void *priv); int (*sm_step_unmap)(struct drm_gpuva_op *op, void *priv); }; **Members** ``vm_free`` called when the last reference of a struct drm_gpuvm is dropped This callback is mandatory. ``op_alloc`` called when the :c:type:`drm_gpuvm` allocates a struct drm_gpuva_op Some drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can allocate memory accordingly. This callback is optional. ``op_free`` called when the :c:type:`drm_gpuvm` frees a struct drm_gpuva_op Some drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly. This callback is optional. ``vm_bo_alloc`` called when the :c:type:`drm_gpuvm` allocates a struct drm_gpuvm_bo Some drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can allocate memory accordingly. This callback is optional. ``vm_bo_free`` called when the :c:type:`drm_gpuvm` frees a struct drm_gpuvm_bo Some drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly. This callback is optional. ``vm_bo_validate`` called from drm_gpuvm_validate() Drivers receive this callback for every evicted :c:type:`drm_gem_object` being mapped in the corresponding :c:type:`drm_gpuvm`. Typically, drivers would call their driver specific variant of ttm_bo_validate() from within this callback. ``sm_step_map`` called from :c:type:`drm_gpuvm_sm_map` to finally insert the mapping once all previous steps were completed The :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively. Can be NULL if :c:type:`drm_gpuvm_sm_map` is used. ``sm_step_remap`` called from :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to split up an existent mapping This callback is called when existent mapping needs to be split up. This is the case when either a newly requested mapping overlaps or is enclosed by an existent mapping or a partial unmap of an existent mapping is requested. The :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively. Can be NULL if neither :c:type:`drm_gpuvm_sm_map` nor :c:type:`drm_gpuvm_sm_unmap` is used. ``sm_step_unmap`` called from :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to unmap an existing mapping This callback is called when existing mapping needs to be unmapped. This is the case when either a newly requested mapping encloses an existing mapping or an unmap of an existing mapping is requested. The :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively. Can be NULL if neither :c:type:`drm_gpuvm_sm_map` nor :c:type:`drm_gpuvm_sm_unmap` is used.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubh:}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMqhjKubjT)}(hX struct drm_gpuvm_ops { void (*vm_free)(struct drm_gpuvm *gpuvm); struct drm_gpuva_op *(*op_alloc)(void); void (*op_free)(struct drm_gpuva_op *op); struct drm_gpuvm_bo *(*vm_bo_alloc)(void); void (*vm_bo_free)(struct drm_gpuvm_bo *vm_bo); int (*vm_bo_validate)(struct drm_gpuvm_bo *vm_bo, struct drm_exec *exec); int (*sm_step_map)(struct drm_gpuva_op *op, void *priv); int (*sm_step_remap)(struct drm_gpuva_op *op, void *priv); int (*sm_step_unmap)(struct drm_gpuva_op *op, void *priv); };h]hX struct drm_gpuvm_ops { void (*vm_free)(struct drm_gpuvm *gpuvm); struct drm_gpuva_op *(*op_alloc)(void); void (*op_free)(struct drm_gpuva_op *op); struct drm_gpuvm_bo *(*vm_bo_alloc)(void); void (*vm_bo_free)(struct drm_gpuvm_bo *vm_bo); int (*vm_bo_validate)(struct drm_gpuvm_bo *vm_bo, struct drm_exec *exec); int (*sm_step_map)(struct drm_gpuva_op *op, void *priv); int (*sm_step_remap)(struct drm_gpuva_op *op, void *priv); int (*sm_step_unmap)(struct drm_gpuva_op *op, void *priv); };}hjlsbah}(h]h ]h"]h$]h&]jjuh1jShS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMshjKubh)}(h **Members**h]j)}(hj}h]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjKubj)}(hhh](j)}(hi``vm_free`` called when the last reference of a struct drm_gpuvm is dropped This callback is mandatory. h](j)}(h ``vm_free``h]j)}(hjh]hvm_free}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMyhjubj )}(hhh](h)}(h?called when the last reference of a struct drm_gpuvm is droppedh]h?called when the last reference of a struct drm_gpuvm is dropped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMvhjubh)}(hThis callback is mandatory.h]hThis callback is mandatory.}(hjĤhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMyhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMyhjubj)}(hX ``op_alloc`` called when the :c:type:`drm_gpuvm` allocates a struct drm_gpuva_op Some drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can allocate memory accordingly. This callback is optional. h](j)}(h ``op_alloc``h]j)}(hjh]hop_alloc}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjޤubj )}(hhh](h)}(hCcalled when the :c:type:`drm_gpuvm` allocates a struct drm_gpuva_oph](hcalled when the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhM~hjubh allocates a struct drm_gpuva_op}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$hM~hjubh)}(hSome drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can allocate memory accordingly.h]hSome drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can allocate memory accordingly.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hThis callback is optional.h]hThis callback is optional.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1j hjޤubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``op_free`` called when the :c:type:`drm_gpuvm` frees a struct drm_gpuva_op Some drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly. This callback is optional. h](j)}(h ``op_free``h]j)}(hj^h]hop_free}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjXubj )}(hhh](h)}(h?called when the :c:type:`drm_gpuvm` frees a struct drm_gpuva_oph](hcalled when the }(hjwhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjwubh frees a struct drm_gpuva_op}(hjwhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjtubh)}(hSome drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly.h]hSome drivers may want to embed struct drm_gpuva_op into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjtubh)}(hThis callback is optional.h]hThis callback is optional.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshMhjtubeh}(h]h ]h"]h$]h&]uh1j hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMhjubj)}(hX ``vm_bo_alloc`` called when the :c:type:`drm_gpuvm` allocates a struct drm_gpuvm_bo Some drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can allocate memory accordingly. This callback is optional. h](j)}(h``vm_bo_alloc``h]j)}(hjإh]h vm_bo_alloc}(hjڥhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj֥ubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjҥubj )}(hhh](h)}(hCcalled when the :c:type:`drm_gpuvm` allocates a struct drm_gpuvm_boh](hcalled when the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh allocates a struct drm_gpuvm_bo}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hSome drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can allocate memory accordingly.h]hSome drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can allocate memory accordingly.}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hThis callback is optional.h]hThis callback is optional.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1j hjҥubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX``vm_bo_free`` called when the :c:type:`drm_gpuvm` frees a struct drm_gpuvm_bo Some drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly. This callback is optional. h](j)}(h``vm_bo_free``h]j)}(hjRh]h vm_bo_free}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjLubj )}(hhh](h)}(h?called when the :c:type:`drm_gpuvm` frees a struct drm_gpuvm_boh](hcalled when the }(hjkhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjuh]h drm_gpuvm}(hjwhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjkubh frees a struct drm_gpuvm_bo}(hjkhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjhubh)}(hSome drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly.h]hSome drivers may want to embed struct drm_gpuvm_bo into driver specific structures. By implementing this callback drivers can free the previously allocated memory accordingly.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjhubh)}(hThis callback is optional.h]hThis callback is optional.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghMhjhubeh}(h]h ]h"]h$]h&]uh1j hjLubeh}(h]h ]h"]h$]h&]uh1jhjghMhjubj)}(hX"``vm_bo_validate`` called from drm_gpuvm_validate() Drivers receive this callback for every evicted :c:type:`drm_gem_object` being mapped in the corresponding :c:type:`drm_gpuvm`. Typically, drivers would call their driver specific variant of ttm_bo_validate() from within this callback. h](j)}(h``vm_bo_validate``h]j)}(hj̦h]hvm_bo_validate}(hjΦhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjʦubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjƦubj )}(hhh](h)}(h called from drm_gpuvm_validate()h]h called from drm_gpuvm_validate()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hDrivers receive this callback for every evicted :c:type:`drm_gem_object` being mapped in the corresponding :c:type:`drm_gpuvm`.h](h0Drivers receive this callback for every evicted }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh# being mapped in the corresponding }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj"h]h drm_gpuvm}(hj$hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hkTypically, drivers would call their driver specific variant of ttm_bo_validate() from within this callback.h]hkTypically, drivers would call their driver specific variant of ttm_bo_validate() from within this callback.}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubeh}(h]h ]h"]h$]h&]uh1j hjƦubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX;``sm_step_map`` called from :c:type:`drm_gpuvm_sm_map` to finally insert the mapping once all previous steps were completed The :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively. Can be NULL if :c:type:`drm_gpuvm_sm_map` is used. h](j)}(h``sm_step_map``h]j)}(hjjh]h sm_step_map}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjdubj )}(hhh](h)}(hkcalled from :c:type:`drm_gpuvm_sm_map` to finally insert the mapping once all previous steps were completedh](h called from }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjh]hdrm_gpuvm_sm_map}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubhE to finally insert the mapping once all previous steps were completed}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hThe :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively.h](hThe }(hjhhhNhNubh)}(h:c:type:`priv`h]j)}(hjh]hpriv}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMprivuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh. pointer matches the one the driver passed to }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjh]hdrm_gpuvm_sm_map}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhjܧhMhjubh or }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjܧhMhjubh, respectively.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjܧhMhjubh)}(h2Can be NULL if :c:type:`drm_gpuvm_sm_map` is used.h](hCan be NULL if }(hj-hhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hj7h]hdrm_gpuvm_sm_map}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhjhMhj-ubh is used.}(hj-hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1j hjdubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hXE``sm_step_remap`` called from :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to split up an existent mapping This callback is called when existent mapping needs to be split up. This is the case when either a newly requested mapping overlaps or is enclosed by an existent mapping or a partial unmap of an existent mapping is requested. The :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively. Can be NULL if neither :c:type:`drm_gpuvm_sm_map` nor :c:type:`drm_gpuvm_sm_unmap` is used. h](j)}(h``sm_step_remap``h]j)}(hjph]h sm_step_remap}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjjubj )}(hhh](h)}(hgcalled from :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to split up an existent mappingh](h called from }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjh]hdrm_gpuvm_sm_map}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh and }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjhMhjubh to split up an existent mapping}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(hThis callback is called when existent mapping needs to be split up. This is the case when either a newly requested mapping overlaps or is enclosed by an existent mapping or a partial unmap of an existent mapping is requested.h]hThis callback is called when existent mapping needs to be split up. This is the case when either a newly requested mapping overlaps or is enclosed by an existent mapping or a partial unmap of an existent mapping is requested.}(hjިhhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hThe :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively.h](hThe }(hjhhhNhNubh)}(h:c:type:`priv`h]j)}(hjh]hpriv}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMprivuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh. pointer matches the one the driver passed to }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjh]hdrm_gpuvm_sm_map}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhjhMhjubh or }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hj>h]hdrm_gpuvm_sm_unmap}(hj@hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjhMhjubh, respectively.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h[Can be NULL if neither :c:type:`drm_gpuvm_sm_map` nor :c:type:`drm_gpuvm_sm_unmap` is used.h](hCan be NULL if neither }(hjehhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjoh]hdrm_gpuvm_sm_map}(hjqhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjeubh nor }(hjehhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjhMhjeubh is used.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1j hjjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hX(``sm_step_unmap`` called from :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to unmap an existing mapping This callback is called when existing mapping needs to be unmapped. This is the case when either a newly requested mapping encloses an existing mapping or an unmap of an existing mapping is requested. The :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively. Can be NULL if neither :c:type:`drm_gpuvm_sm_map` nor :c:type:`drm_gpuvm_sm_unmap` is used.h](j)}(h``sm_step_unmap``h]j)}(hj̩h]h sm_step_unmap}(hjΩhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjʩubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjƩubj )}(hhh](h)}(hdcalled from :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to unmap an existing mappingh](h called from }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjh]hdrm_gpuvm_sm_map}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh and }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhj hMhjubh to unmap an existing mapping}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhjubh)}(hThis callback is called when existing mapping needs to be unmapped. This is the case when either a newly requested mapping encloses an existing mapping or an unmap of an existing mapping is requested.h]hThis callback is called when existing mapping needs to be unmapped. This is the case when either a newly requested mapping encloses an existing mapping or an unmap of an existing mapping is requested.}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubh)}(hThe :c:type:`priv` pointer matches the one the driver passed to :c:type:`drm_gpuvm_sm_map` or :c:type:`drm_gpuvm_sm_unmap`, respectively.h](hThe }(hjIhhhNhNubh)}(h:c:type:`priv`h]j)}(hjSh]hpriv}(hjUhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMprivuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjIubh. pointer matches the one the driver passed to }(hjIhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjwh]hdrm_gpuvm_sm_map}(hjyhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhjphMhjIubh or }(hjIhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjphMhjIubh, respectively.}(hjIhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjphMhjubh)}(h[Can be NULL if neither :c:type:`drm_gpuvm_sm_map` nor :c:type:`drm_gpuvm_sm_unmap` is used.h](hCan be NULL if neither }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hj˪h]hdrm_gpuvm_sm_map}(hjͪhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjɪubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhjhMhjubh nor }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjhMhjubh is used.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1j hjƩubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubh)}(h**Description**h]j)}(hj0h]h Description}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj Ahhubh)}(hThis structure defines the callbacks used by :c:type:`drm_gpuvm_sm_map` and :c:type:`drm_gpuvm_sm_unmap` to provide the split/merge steps for map and unmap operations to drivers.h](h-This structure defines the callbacks used by }(hjFhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjPh]hdrm_gpuvm_sm_map}(hjRhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMnhjFubh and }(hjFhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjth]hdrm_gpuvm_sm_unmap}(hjvhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjmhMnhjFubhJ to provide the split/merge steps for map and unmap operations to drivers.}(hjFhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjmhMnhj Ahhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j..drm_gpuva_op_remap_to_unmap_range (C function)#c.drm_gpuva_op_remap_to_unmap_rangehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hivoid drm_gpuva_op_remap_to_unmap_range (const struct drm_gpuva_op_remap *op, u64 *start_addr, u64 *range)h]j>)}(hhvoid drm_gpuva_op_remap_to_unmap_range(const struct drm_gpuva_op_remap *op, u64 *start_addr, u64 *range)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMubjV)}(h h]h }(hjëhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj«hMubjg)}(h!drm_gpuva_op_remap_to_unmap_rangeh]jm)}(h!drm_gpuva_op_remap_to_unmap_rangeh]h!drm_gpuva_op_remap_to_unmap_range}(hjիhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjѫubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj«hMubj)}(hB(const struct drm_gpuva_op_remap *op, u64 *start_addr, u64 *range)h](j)}(h#const struct drm_gpuva_op_remap *oph](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpuva_op_remaph]hdrm_gpuva_op_remap}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj'ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,modnameN classnameNjj)}j]j )}jj׫sb#c.drm_gpuva_op_remap_to_unmap_rangeasbuh1hhjubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjXhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hoph]hop}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 *start_addrh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jF#c.drm_gpuva_op_remap_to_unmap_rangeasbuh1hhjzubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjzubjm)}(h start_addrh]h start_addr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 *rangeh](h)}(hhh]jm)}(hu64h]hu64}(hj֬hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjӬubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjجmodnameN classnameNjj)}j]jF#c.drm_gpuva_op_remap_to_unmap_rangeasbuh1hhjϬubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjϬubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjϬubjm)}(hrangeh]hrange}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjϬubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj«hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj«hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj«hMhjhhubj)}(hhh]h)}(hCHelper to get the start and range of the unmap stage of a remap op.h]hCHelper to get the start and range of the unmap stage of a remap op.}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhj6hhubah}(h]h ]h"]h$]h&]uh1jhjhhhj«hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjQjjQjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``const struct drm_gpuva_op_remap *op`` Remap op. ``u64 *start_addr`` Output pointer for the start of the required unmap. ``u64 *range`` Output pointer for the length of the required unmap. **Description** The given start address and range will be set such that they represent the range of the address space that was previously covered by the mapping being re-mapped, but is now empty.h](h)}(h**Parameters**h]j)}(hj[h]h Parameters}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjUubj)}(hhh](j)}(h2``const struct drm_gpuva_op_remap *op`` Remap op. h](j)}(h'``const struct drm_gpuva_op_remap *op``h]j)}(hjzh]h#const struct drm_gpuva_op_remap *op}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjtubj )}(hhh]h)}(h Remap op.h]h Remap op.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjtubeh}(h]h ]h"]h$]h&]uh1jhjhMhjqubj)}(hH``u64 *start_addr`` Output pointer for the start of the required unmap. h](j)}(h``u64 *start_addr``h]j)}(hjh]hu64 *start_addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h3Output pointer for the start of the required unmap.h]h3Output pointer for the start of the required unmap.}(hj̭hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjȭhMhjɭubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjȭhMhjqubj)}(hD``u64 *range`` Output pointer for the length of the required unmap. h](j)}(h``u64 *range``h]j)}(hjh]h u64 *range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjubj )}(hhh]h)}(h4Output pointer for the length of the required unmap.h]h4Output pointer for the length of the required unmap.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjqubeh}(h]h ]h"]h$]h&]uh1jhjUubh)}(h**Description**h]j)}(hj'h]h Description}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjUubh)}(hThe given start address and range will be set such that they represent the range of the address space that was previously covered by the mapping being re-mapped, but is now empty.h]hThe given start address and range will be set such that they represent the range of the address space that was previously covered by the mapping being re-mapped, but is now empty.}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhS/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:520: ./include/drm/drm_gpuvm.hhMhjUubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_gpuvm_range_valid (C function)c.drm_gpuvm_range_validhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hIbool drm_gpuvm_range_valid (struct drm_gpuvm *gpuvm, u64 addr, u64 range)h]j>)}(hHbool drm_gpuvm_range_valid(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hj*h]hbool}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhhjyhMubjg)}(hdrm_gpuvm_range_validh]jm)}(hdrm_gpuvm_range_validh]hdrm_gpuvm_range_valid}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhhjyhMubj)}(h.(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjƮhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjîubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjȮmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_range_validasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_range_validasbuh1hhjubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(haddrh]haddr}(hjIhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]jc.drm_gpuvm_range_validasbuh1hhj^ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj^ubjm)}(hrangeh]hrange}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhhjyhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjdhhhjyhMubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1j7hjyhMhjahhubj)}(hhh]h)}(hIchecks whether the given range is valid for the given :c:type:`drm_gpuvm`h](h6checks whether the given range is valid for the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjůh]h drm_gpuvm}(hjǯhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjïubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuvm_range_validasbjM drm_gpuvmuh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjahhhjyhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX3**Parameters** ``struct drm_gpuvm *gpuvm`` the GPUVM to check the range for ``u64 addr`` the base address ``u64 range`` the range starting from the base address **Description** Checks whether the range is within the GPUVM's managed boundaries. **Return** true for a valid range, false otherwiseh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(h=``struct drm_gpuvm *gpuvm`` the GPUVM to check the range for h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj h]hstruct drm_gpuvm *gpuvm}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h the GPUVM to check the range forh]h the GPUVM to check the range for}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMhj6ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMhjubj)}(h``u64 addr`` the base address h](j)}(h ``u64 addr``h]j)}(hjYh]hu64 addr}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjSubj )}(hhh]h)}(hthe base addressh]hthe base address}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMhjoubah}(h]h ]h"]h$]h&]uh1j hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMhjubj)}(h7``u64 range`` the range starting from the base address h](j)}(h ``u64 range``h]j)}(hjh]h u64 range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h(the range starting from the base addressh]h(the range starting from the base address}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjͰh]h Description}(hjϰhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj˰ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hBChecks whether the range is within the GPUVM's managed boundaries.h]hDChecks whether the range is within the GPUVM’s managed boundaries.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h'true for a valid range, false otherwiseh]h'true for a valid range, false otherwise}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gpuvm_resv_object_alloc (C function)c.drm_gpuvm_resv_object_allochNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hLstruct drm_gem_object * drm_gpuvm_resv_object_alloc (struct drm_device *drm)h]j>)}(hJstruct drm_gem_object *drm_gpuvm_resv_object_alloc(struct drm_device *drm)h](jD)}(hjh]hstruct}(hj9hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj5hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5hhhjFhMubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjZmodnameN classnameNjj)}j]j )}jdrm_gpuvm_resv_object_allocsbc.drm_gpuvm_resv_object_allocasbuh1hhj5hhhjFhMubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5hhhjFhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj5hhhjFhMubjg)}(hdrm_gpuvm_resv_object_alloch]jm)}(hjvh]hdrm_gpuvm_resv_object_alloc}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj5hhhjFhMubj)}(h(struct drm_device *drm)h]j)}(hstruct drm_device *drmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjѱhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjαubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjӱmodnameN classnameNjj)}j]jtc.drm_gpuvm_resv_object_allocasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hdrmh]hdrm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj5hhhjFhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj1hhhjFhMubah}(h]j,ah ](jjeh"]h$]h&]jj)jhuh1j7hjFhMhj.hhubj)}(hhh]h)}(h)allocate a dummy :c:type:`drm_gem_object`h](hallocate a dummy }(hj4hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj>h]hdrm_gem_object}(hj@hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jtc.drm_gpuvm_resv_object_allocasbjMdrm_gem_objectuh1hhjyhMhj4ubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj1hhubah}(h]h ]h"]h$]h&]uh1jhj.hhhjFhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjpjjpjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_device *drm`` the drivers :c:type:`drm_device` **Description** Allocates a dummy :c:type:`drm_gem_object` which can be passed to drm_gpuvm_init() in order to serve as root GEM object providing the :c:type:`drm_resv` shared across :c:type:`drm_gem_objects` local to a single GPUVM. **Return** the :c:type:`drm_gem_object` on success, NULL on failureh](h)}(h**Parameters**h]j)}(hjzh]h Parameters}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjtubj)}(hhh]j)}(h<``struct drm_device *drm`` the drivers :c:type:`drm_device` h](j)}(h``struct drm_device *drm``h]j)}(hjh]hstruct drm_device *drm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h the drivers :c:type:`drm_device`h](h the drivers }(hjhhhNhNubh)}(h:c:type:`drm_device`h]j)}(hjh]h drm_device}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjtubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjtubh)}(hAllocates a dummy :c:type:`drm_gem_object` which can be passed to drm_gpuvm_init() in order to serve as root GEM object providing the :c:type:`drm_resv` shared across :c:type:`drm_gem_objects` local to a single GPUVM.h](hAllocates a dummy }(hj hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubh\ which can be passed to drm_gpuvm_init() in order to serve as root GEM object providing the }(hj hhhNhNubh)}(h:c:type:`drm_resv`h]j)}(hj7h]hdrm_resv}(hj9hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_resvuh1hhj0hMhj ubh shared across }(hj hhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjZh]hdrm_gem_objects}(hj\hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhj0hMhj ubh local to a single GPUVM.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj0hMhjtubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjtubh)}(h8the :c:type:`drm_gem_object` on success, NULL on failureh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubh on success, NULL on failure}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjtubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_init (C function)c.drm_gpuvm_inithNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hvoid drm_gpuvm_init (struct drm_gpuvm *gpuvm, const char *name, enum drm_gpuvm_flags flags, struct drm_device *drm, struct drm_gem_object *r_obj, u64 start_offset, u64 range, u64 reserve_offset, u64 reserve_range, const struct drm_gpuvm_ops *ops)h]j>)}(hvoid drm_gpuvm_init(struct drm_gpuvm *gpuvm, const char *name, enum drm_gpuvm_flags flags, struct drm_device *drm, struct drm_gem_object *r_obj, u64 start_offset, u64 range, u64 reserve_offset, u64 reserve_range, const struct drm_gpuvm_ops *ops)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM3ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM3ubjg)}(hdrm_gpuvm_inith]jm)}(hdrm_gpuvm_inith]hdrm_gpuvm_init}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM3ubj)}(h(struct drm_gpuvm *gpuvm, const char *name, enum drm_gpuvm_flags flags, struct drm_device *drm, struct drm_gem_object *r_obj, u64 start_offset, u64 range, u64 reserve_offset, u64 reserve_range, const struct drm_gpuvm_ops *ops)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj(hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj$ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjFhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjHmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_initasbuh1hhj$ubjV)}(h h]h }(hjfhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$ubj4)}(hj7h]h*}(hjthhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj$ubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst char *nameh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hcharh]hchar}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjôhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjѴhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnameh]hname}(hj޴hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(henum drm_gpuvm_flags flagsh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpuvm_flagsh]hdrm_gpuvm_flags}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhjubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hflagsh]hflags}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct drm_device *drmh](jD)}(hjh]hstruct}(hjZhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjVubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubh)}(hhh]jm)}(h drm_deviceh]h drm_device}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjzmodnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhjVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjVubjm)}(hdrmh]hdrm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct drm_gem_object *r_objh](jD)}(hjh]hstruct}(hjʵhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjƵubjV)}(h h]h }(hj׵hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjƵubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhjƵubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjƵubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjƵubjm)}(hr_objh]hr_obj}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjƵubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 start_offseth](h)}(hhh]jm)}(hu64h]hu64}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj?modnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhj6ubjV)}(h h]h }(hj[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6ubjm)}(h start_offseth]h start_offset}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhj~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj~ubjm)}(hrangeh]hrange}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 reserve_offseth](h)}(hhh]jm)}(hu64h]hu64}(hjͶhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjʶubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj϶modnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhjƶubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjƶubjm)}(hreserve_offseth]hreserve_offset}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjƶubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 reserve_rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhjubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h reserve_rangeh]h reserve_range}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hconst struct drm_gpuvm_ops *opsh](jD)}(hj h]hconst}(hjZhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjVubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubjD)}(hjh]hstruct}(hjuhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubh)}(hhh]jm)}(h drm_gpuvm_opsh]h drm_gpuvm_ops}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jbc.drm_gpuvm_initasbuh1hhjVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjVubjm)}(hopsh]hops}(hj̷hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM3ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM3ubah}(h]j޳ah ](jjeh"]h$]h&]jj)jhuh1j7hjhM3hjhhubj)}(hhh]h)}(h initialize a :c:type:`drm_gpuvm`h](h initialize a }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jbc.drm_gpuvm_initasbjM drm_gpuvmuh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM3hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM3ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj2jj2jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` pointer to the :c:type:`drm_gpuvm` to initialize ``const char *name`` the name of the GPU VA space ``enum drm_gpuvm_flags flags`` the :c:type:`drm_gpuvm_flags` for this GPUVM ``struct drm_device *drm`` the :c:type:`drm_device` this VM resides in ``struct drm_gem_object *r_obj`` the resv :c:type:`drm_gem_object` providing the GPUVM's common :c:type:`dma_resv` ``u64 start_offset`` the start offset of the GPU VA space ``u64 range`` the size of the GPU VA space ``u64 reserve_offset`` the start of the kernel reserved GPU VA area ``u64 reserve_range`` the size of the kernel reserved GPU VA area ``const struct drm_gpuvm_ops *ops`` :c:type:`drm_gpuvm_ops` called on :c:type:`drm_gpuvm_sm_map` / :c:type:`drm_gpuvm_sm_unmap` **Description** The :c:type:`drm_gpuvm` must be initialized with this function before use. Note that **gpuvm** must be cleared to 0 before calling this function. The given :c:type:`name` is expected to be managed by the surrounding driver structures.h](h)}(h**Parameters**h]j)}(hj<h]h Parameters}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM7hj6ubj)}(hhh](j)}(hM``struct drm_gpuvm *gpuvm`` pointer to the :c:type:`drm_gpuvm` to initialize h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj[h]hstruct drm_gpuvm *gpuvm}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM4hjUubj )}(hhh]h)}(h0pointer to the :c:type:`drm_gpuvm` to initializeh](hpointer to the }(hjthhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj~h]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjphM4hjtubh to initialize}(hjthhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjphM4hjqubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjphM4hjRubj)}(h2``const char *name`` the name of the GPU VA space h](j)}(h``const char *name``h]j)}(hjh]hconst char *name}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM5hjubj )}(hhh]h)}(hthe name of the GPU VA spaceh]hthe name of the GPU VA space}(hjиhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj̸hM5hj͸ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj̸hM5hjRubj)}(hL``enum drm_gpuvm_flags flags`` the :c:type:`drm_gpuvm_flags` for this GPUVM h](j)}(h``enum drm_gpuvm_flags flags``h]j)}(hjh]henum drm_gpuvm_flags flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM6hjubj )}(hhh]h)}(h,the :c:type:`drm_gpuvm_flags` for this GPUVMh](hthe }(hj hhhNhNubh)}(h:c:type:`drm_gpuvm_flags`h]j)}(hjh]hdrm_gpuvm_flags}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_flagsuh1hhjhM6hj ubh for this GPUVM}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM6hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM6hjRubj)}(hG``struct drm_device *drm`` the :c:type:`drm_device` this VM resides in h](j)}(h``struct drm_device *drm``h]j)}(hjLh]hstruct drm_device *drm}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM7hjFubj )}(hhh]h)}(h+the :c:type:`drm_device` this VM resides inh](hthe }(hjehhhNhNubh)}(h:c:type:`drm_device`h]j)}(hjoh]h drm_device}(hjqhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_deviceuh1hhjahM7hjeubh this VM resides in}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjahM7hjbubah}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhjahM7hjRubj)}(hs``struct drm_gem_object *r_obj`` the resv :c:type:`drm_gem_object` providing the GPUVM's common :c:type:`dma_resv` h](j)}(h ``struct drm_gem_object *r_obj``h]j)}(hjh]hstruct drm_gem_object *r_obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM8hjubj )}(hhh]h)}(hQthe resv :c:type:`drm_gem_object` providing the GPUVM's common :c:type:`dma_resv`h](h the resv }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hj˹h]hdrm_gem_object}(hj͹hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjɹubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhM8hjubh providing the GPUVM’s common }(hjhhhNhNubh)}(h:c:type:`dma_resv`h]j)}(hjh]hdma_resv}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdma_resvuh1hhjhM8hjubeh}(h]h ]h"]h$]h&]uh1hhjhM8hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM8hjRubj)}(h:``u64 start_offset`` the start offset of the GPU VA space h](j)}(h``u64 start_offset``h]j)}(hj#h]hu64 start_offset}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM9hjubj )}(hhh]h)}(h$the start offset of the GPU VA spaceh]h$the start offset of the GPU VA space}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj8hM9hj9ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM9hjRubj)}(h+``u64 range`` the size of the GPU VA space h](j)}(h ``u64 range``h]j)}(hj\h]h u64 range}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM:hjVubj )}(hhh]h)}(hthe size of the GPU VA spaceh]hthe size of the GPU VA space}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqhM:hjrubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhM:hjRubj)}(hD``u64 reserve_offset`` the start of the kernel reserved GPU VA area h](j)}(h``u64 reserve_offset``h]j)}(hjh]hu64 reserve_offset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM;hjubj )}(hhh]h)}(h,the start of the kernel reserved GPU VA areah]h,the start of the kernel reserved GPU VA area}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM;hjRubj)}(hB``u64 reserve_range`` the size of the kernel reserved GPU VA area h](j)}(h``u64 reserve_range``h]j)}(hjκh]hu64 reserve_range}(hjкhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj̺ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM<hjȺubj )}(hhh]h)}(h+the size of the kernel reserved GPU VA areah]h+the size of the kernel reserved GPU VA area}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM<hjubah}(h]h ]h"]h$]h&]uh1j hjȺubeh}(h]h ]h"]h$]h&]uh1jhjhM<hjRubj)}(h``const struct drm_gpuvm_ops *ops`` :c:type:`drm_gpuvm_ops` called on :c:type:`drm_gpuvm_sm_map` / :c:type:`drm_gpuvm_sm_unmap` h](j)}(h#``const struct drm_gpuvm_ops *ops``h]j)}(hjh]hconst struct drm_gpuvm_ops *ops}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM=hjubj )}(hhh]h)}(h[:c:type:`drm_gpuvm_ops` called on :c:type:`drm_gpuvm_sm_map` / :c:type:`drm_gpuvm_sm_unmap`h](h)}(h:c:type:`drm_gpuvm_ops`h]j)}(hj&h]h drm_gpuvm_ops}(hj(hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhjhM=hj ubh called on }(hj hhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hjIh]hdrm_gpuvm_sm_map}(hjKhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhjhM=hj ubh / }(hj hhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjlh]hdrm_gpuvm_sm_unmap}(hjnhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhjhM=hj ubeh}(h]h ]h"]h$]h&]uh1hhjhM=hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM=hjRubeh}(h]h ]h"]h$]h&]uh1jhj6ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM?hj6ubh)}(hJThe :c:type:`drm_gpuvm` must be initialized with this function before use.h](hThe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjûh]h drm_gpuvm}(hjŻhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM>hjubh3 must be initialized with this function before use.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM>hj6ubh)}(hNote that **gpuvm** must be cleared to 0 before calling this function. The given :c:type:`name` is expected to be managed by the surrounding driver structures.h](h Note that }(hjhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh> must be cleared to 0 before calling this function. The given }(hjhhhNhNubh)}(h:c:type:`name`h]j)}(hjh]hname}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMnameuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM@hjubh@ is expected to be managed by the surrounding driver structures.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$hM@hj6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_put (C function)c.drm_gpuvm_puthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h,void drm_gpuvm_put (struct drm_gpuvm *gpuvm)h]j>)}(h+void drm_gpuvm_put(struct drm_gpuvm *gpuvm)h](j)}(hvoidh]hvoid}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjKhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj^hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjKhhhj]hMubjg)}(h drm_gpuvm_puth]jm)}(h drm_gpuvm_puth]h drm_gpuvm_put}(hjphhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjlubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjKhhhj]hMubj)}(h(struct drm_gpuvm *gpuvm)h]j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjrsbc.drm_gpuvm_putasbuh1hhjubjV)}(h h]h }(hjʼhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjؼhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjKhhhj]hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjGhhhj]hMubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1j7hj]hMhjDhhubj)}(hhh]h)}(h!drop a struct drm_gpuvm referenceh]h!drop a struct drm_gpuvm reference}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjDhhhj]hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj'jj'jjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to release the reference of **Description** This releases a reference to **gpuvm**. This function may be called from atomic context.h](h)}(h**Parameters**h]j)}(hj1h]h Parameters}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj+ubj)}(hhh]j)}(hP``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to release the reference of h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjPh]hstruct drm_gpuvm *gpuvm}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjJubj )}(hhh]h)}(h3the :c:type:`drm_gpuvm` to release the reference ofh](hthe }(hjihhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjsh]h drm_gpuvm}(hjuhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjqubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjehMhjiubh to release the reference of}(hjihhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjehMhjfubah}(h]h ]h"]h$]h&]uh1j hjJubeh}(h]h ]h"]h$]h&]uh1jhjehMhjGubah}(h]h ]h"]h$]h&]uh1jhj+ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj+ubh)}(h'This releases a reference to **gpuvm**.h](hThis releases a reference to }(hjĽhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hj̽hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjĽubh.}(hjĽhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj+ubh)}(h0This function may be called from atomic context.h]h0This function may be called from atomic context.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj+ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gpuvm_prepare_vm (C function)c.drm_gpuvm_prepare_vmhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hbint drm_gpuvm_prepare_vm (struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences)h]j>)}(haint drm_gpuvm_prepare_vm(struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj"hMubjg)}(hdrm_gpuvm_prepare_vmh]jm)}(hdrm_gpuvm_prepare_vmh]hdrm_gpuvm_prepare_vm}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj"hMubj)}(hI(struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjQhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjMubjV)}(h h]h }(hj^hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjlubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]j )}jj7sbc.drm_gpuvm_prepare_vmasbuh1hhjMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjMubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjþhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjоhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj޾ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_prepare_vmasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubj)}(hunsigned int num_fencesh](j)}(hunsignedh]hunsigned}(hj3hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubj)}(hinth]hint}(hjOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/ubjm)}(h num_fencesh]h num_fences}(hjkhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjIubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj"hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj"hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj"hMhj hhubj)}(hhh]h)}(h"prepare the GPUVMs common dma-resvh]h"prepare the GPUVMs common dma-resv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj hhhj"hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX!**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` ``struct drm_exec *exec`` the :c:type:`drm_exec` context ``unsigned int num_fences`` the amount of :c:type:`dma_fences` to reserve **Description** Calls drm_exec_prepare_obj() for the GPUVMs dummy :c:type:`drm_gem_object`; if **num_fences** is zero drm_exec_lock_obj() is called instead. Using this function directly, it is the drivers responsibility to call drm_exec_init() and drm_exec_fini() accordingly. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(h4``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjֿh]hstruct drm_gpuvm *gpuvm}(hjؿhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjԿubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjпubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjпubeh}(h]h ]h"]h$]h&]uh1jhjhMhjͿubj)}(h9``struct drm_exec *exec`` the :c:type:`drm_exec` context h](j)}(h``struct drm_exec *exec``h]j)}(hj.h]hstruct drm_exec *exec}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj(ubj )}(hhh]h)}(hthe :c:type:`drm_exec` contexth](hthe }(hjGhhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjQh]hdrm_exec}(hjShhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhjChMhjGubh context}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChMhjDubah}(h]h ]h"]h$]h&]uh1j hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChMhjͿubj)}(hJ``unsigned int num_fences`` the amount of :c:type:`dma_fences` to reserve h](j)}(h``unsigned int num_fences``h]j)}(hjh]hunsigned int num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h-the amount of :c:type:`dma_fences` to reserveh](hthe amount of }(hjhhhNhNubh)}(h:c:type:`dma_fences`h]j)}(hjh]h dma_fences}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_fencesuh1hhjhMhjubh to reserve}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjͿubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hCalls drm_exec_prepare_obj() for the GPUVMs dummy :c:type:`drm_gem_object`; if **num_fences** is zero drm_exec_lock_obj() is called instead.h](h2Calls drm_exec_prepare_obj() for the GPUVMs dummy }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh; if }(hjhhhNhNubj)}(h**num_fences**h]h num_fences}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh/ is zero drm_exec_lock_obj() is called instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj%hMhjubh)}(hwUsing this function directly, it is the drivers responsibility to call drm_exec_init() and drm_exec_fini() accordingly.h]hwUsing this function directly, it is the drivers responsibility to call drm_exec_init() and drm_exec_fini() accordingly.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h **Return**h]j)}(hjSh]hReturn}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gpuvm_prepare_objects (C function)c.drm_gpuvm_prepare_objectshNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hgint drm_gpuvm_prepare_objects (struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences)h]j>)}(hfint drm_gpuvm_prepare_objects(struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuvm_prepare_objectsh]jm)}(hdrm_gpuvm_prepare_objectsh]hdrm_gpuvm_prepare_objects}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hI(struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_prepare_objectsasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj!hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjGhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjCubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]jc.drm_gpuvm_prepare_objectsasbuh1hhjCubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjCubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_fencesh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h num_fencesh]h num_fences}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hprepare all associated BOsh]hprepare all associated BOs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj1jj1jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` ``struct drm_exec *exec`` the :c:type:`drm_exec` locking context ``unsigned int num_fences`` the amount of :c:type:`dma_fences` to reserve **Description** Calls drm_exec_prepare_obj() for all :c:type:`drm_gem_objects` the given :c:type:`drm_gpuvm` contains mappings of; if **num_fences** is zero drm_exec_lock_obj() is called instead. Using this function directly, it is the drivers responsibility to call drm_exec_init() and drm_exec_fini() accordingly. **Note** This function is safe against concurrent insertion and removal of external objects, however it is not safe against concurrent usage itself. Drivers need to make sure to protect this case with either an outer VM lock or by calling drm_gpuvm_prepare_vm() before this function within the drm_exec_until_all_locked() loop, such that the GPUVM's dma-resv lock ensures mutual exclusion. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hj;h]h Parameters}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubj)}(hhh](j)}(h4``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjZh]hstruct drm_gpuvm *gpuvm}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjTubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hjshhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj}h]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjohMhjsubeh}(h]h ]h"]h$]h&]uh1hhjohMhjpubah}(h]h ]h"]h$]h&]uh1j hjTubeh}(h]h ]h"]h$]h&]uh1jhjohMhjQubj)}(hA``struct drm_exec *exec`` the :c:type:`drm_exec` locking context h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h&the :c:type:`drm_exec` locking contexth](hthe }(hjhhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjh]hdrm_exec}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhjhMhjubh locking context}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjQubj)}(hJ``unsigned int num_fences`` the amount of :c:type:`dma_fences` to reserve h](j)}(h``unsigned int num_fences``h]j)}(hjh]hunsigned int num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h-the amount of :c:type:`dma_fences` to reserveh](hthe amount of }(hj'hhhNhNubh)}(h:c:type:`dma_fences`h]j)}(hj1h]h dma_fences}(hj3hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_fencesuh1hhj#hMhj'ubh to reserve}(hj'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj#hMhj$ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj#hMhjQubeh}(h]h ]h"]h$]h&]uh1jhj5ubh)}(h**Description**h]j)}(hjlh]h Description}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubh)}(hCalls drm_exec_prepare_obj() for all :c:type:`drm_gem_objects` the given :c:type:`drm_gpuvm` contains mappings of; if **num_fences** is zero drm_exec_lock_obj() is called instead.h](h%Calls drm_exec_prepare_obj() for all }(hjhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjh]hdrm_gem_objects}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh contains mappings of; if }(hjhhhNhNubj)}(h**num_fences**h]h num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh/ is zero drm_exec_lock_obj() is called instead.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj5ubh)}(hwUsing this function directly, it is the drivers responsibility to call drm_exec_init() and drm_exec_fini() accordingly.h]hwUsing this function directly, it is the drivers responsibility to call drm_exec_init() and drm_exec_fini() accordingly.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubh)}(h**Note**h]j)}(hjh]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubh)}(hThis function is safe against concurrent insertion and removal of external objects, however it is not safe against concurrent usage itself.h]hThis function is safe against concurrent insertion and removal of external objects, however it is not safe against concurrent usage itself.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubh)}(hDrivers need to make sure to protect this case with either an outer VM lock or by calling drm_gpuvm_prepare_vm() before this function within the drm_exec_until_all_locked() loop, such that the GPUVM's dma-resv lock ensures mutual exclusion.h]hDrivers need to make sure to protect this case with either an outer VM lock or by calling drm_gpuvm_prepare_vm() before this function within the drm_exec_until_all_locked() loop, such that the GPUVM’s dma-resv lock ensures mutual exclusion.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubh)}(h **Return**h]j)}(hj0h]hReturn}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj5ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gpuvm_prepare_range (C function)c.drm_gpuvm_prepare_rangehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hzint drm_gpuvm_prepare_range (struct drm_gpuvm *gpuvm, struct drm_exec *exec, u64 addr, u64 range, unsigned int num_fences)h]j>)}(hyint drm_gpuvm_prepare_range(struct drm_gpuvm *gpuvm, struct drm_exec *exec, u64 addr, u64 range, unsigned int num_fences)h](j)}(hinth]hint}(hjuhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjqhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqhhhjhMubjg)}(hdrm_gpuvm_prepare_rangeh]jm)}(hdrm_gpuvm_prepare_rangeh]hdrm_gpuvm_prepare_range}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjqhhhjhMubj)}(h^(struct drm_gpuvm *gpuvm, struct drm_exec *exec, u64 addr, u64 range, unsigned int num_fences)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_prepare_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hj$hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjDmodnameN classnameNjj)}j]jc.drm_gpuvm_prepare_rangeasbuh1hhj ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjnhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hexech]hexec}(hj{hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_prepare_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_prepare_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hrangeh]hrange}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_fencesh](j)}(hunsignedh]hunsigned}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj)}(hinth]hint}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(h num_fencesh]h num_fences}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjqhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjmhhhjhMubah}(h]jhah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjjhhubj)}(hhh]h)}(h+prepare all BOs mapped within a given rangeh]h+prepare all BOs mapped within a given range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXE**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` ``struct drm_exec *exec`` the :c:type:`drm_exec` locking context ``u64 addr`` the start address within the VA space ``u64 range`` the range to iterate within the VA space ``unsigned int num_fences`` the amount of :c:type:`dma_fences` to reserve **Description** Calls drm_exec_prepare_obj() for all :c:type:`drm_gem_objects` mapped between **addr** and **addr** + **range**; if **num_fences** is zero drm_exec_lock_obj() is called instead. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(h4``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hA``struct drm_exec *exec`` the :c:type:`drm_exec` locking context h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h&the :c:type:`drm_exec` locking contexth](hthe }(hj8hhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjBh]hdrm_exec}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhj4hMhj8ubh locking context}(hj8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj4hMhj5ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj4hMhjubj)}(h3``u64 addr`` the start address within the VA space h](j)}(h ``u64 addr``h]j)}(hj{h]hu64 addr}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjuubj )}(hhh]h)}(h%the start address within the VA spaceh]h%the start address within the VA space}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h7``u64 range`` the range to iterate within the VA space h](j)}(h ``u64 range``h]j)}(hjh]h u64 range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h(the range to iterate within the VA spaceh]h(the range to iterate within the VA space}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hJ``unsigned int num_fences`` the amount of :c:type:`dma_fences` to reserve h](j)}(h``unsigned int num_fences``h]j)}(hjh]hunsigned int num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h-the amount of :c:type:`dma_fences` to reserveh](hthe amount of }(hjhhhNhNubh)}(h:c:type:`dma_fences`h]j)}(hjh]h dma_fences}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM dma_fencesuh1hhjhMhjubh to reserve}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjKh]h Description}(hjMhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hCalls drm_exec_prepare_obj() for all :c:type:`drm_gem_objects` mapped between **addr** and **addr** + **range**; if **num_fences** is zero drm_exec_lock_obj() is called instead.h](h%Calls drm_exec_prepare_obj() for all }(hjahhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjkh]hdrm_gem_objects}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjaubh mapped between }(hjahhhNhNubj)}(h**addr**h]haddr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubh and }(hjahhhNhNubj)}(h**addr**h]haddr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubh + }(hjahhhNhNubj)}(h **range**h]hrange}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubh; if }(hjahhhNhNubj)}(h**num_fences**h]h num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubh/ is zero drm_exec_lock_obj() is called instead.}(hjahhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gpuvm_exec_lock (C function)c.drm_gpuvm_exec_lockhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h8int drm_gpuvm_exec_lock (struct drm_gpuvm_exec *vm_exec)h]j>)}(h7int drm_gpuvm_exec_lock(struct drm_gpuvm_exec *vm_exec)h](j)}(hinth]hint}(hj"hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM7ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj0hM7ubjg)}(hdrm_gpuvm_exec_lockh]jm)}(hdrm_gpuvm_exec_lockh]hdrm_gpuvm_exec_lock}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj0hM7ubj)}(h (struct drm_gpuvm_exec *vm_exec)h]j)}(hstruct drm_gpuvm_exec *vm_exech](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj[ubjV)}(h h]h }(hjlhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubh)}(hhh]jm)}(hdrm_gpuvm_exech]hdrm_gpuvm_exec}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjEsbc.drm_gpuvm_exec_lockasbuh1hhj[ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj[ubjm)}(hvm_exech]hvm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjWubah}(h]h ]h"]h$]h&]jjuh1jhjhhhj0hM7ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj0hM7ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj0hM7hjhhubj)}(hhh]h)}(h'lock all dma-resv of all associated BOsh]h'lock all dma-resv of all associated BOs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM7hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj0hM7ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX@**Parameters** ``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper **Description** Acquires all dma-resv locks of all :c:type:`drm_gem_objects` the given :c:type:`drm_gpuvm` contains mappings of. Additionally, when calling this function with struct drm_gpuvm_exec::extra being set the driver receives the given **fn** callback to lock additional dma-resv in the context of the :c:type:`drm_gpuvm_exec` instance. Typically, drivers would call drm_exec_prepare_obj() from within this callback. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM;hjubj)}(hhh]j)}(hH``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper h](j)}(h"``struct drm_gpuvm_exec *vm_exec``h]j)}(hj#h]hstruct drm_gpuvm_exec *vm_exec}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM8hjubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm_exec` wrapperh](hthe }(hj<hhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hjFh]hdrm_gpuvm_exec}(hjHhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhj8hM8hj<ubh wrapper}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hM8hj9ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj8hM8hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM:hjubh)}(hpAcquires all dma-resv locks of all :c:type:`drm_gem_objects` the given :c:type:`drm_gpuvm` contains mappings of.h](h#Acquires all dma-resv locks of all }(hjhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjh]hdrm_gem_objects}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM9hjubh the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhM9hjubh contains mappings of.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM9hjubh)}(hX'Additionally, when calling this function with struct drm_gpuvm_exec::extra being set the driver receives the given **fn** callback to lock additional dma-resv in the context of the :c:type:`drm_gpuvm_exec` instance. Typically, drivers would call drm_exec_prepare_obj() from within this callback.h](hsAdditionally, when calling this function with struct drm_gpuvm_exec::extra being set the driver receives the given }(hjhhhNhNubj)}(h**fn**h]hfn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh< callback to lock additional dma-resv in the context of the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hjh]hdrm_gpuvm_exec}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM<hjubhZ instance. Typically, drivers would call drm_exec_prepare_obj() from within this callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj%hM<hjubh)}(h **Return**h]j)}(hj2h]hReturn}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMAhjubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMBhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gpuvm_exec_lock_array (C function)c.drm_gpuvm_exec_lock_arrayhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hsint drm_gpuvm_exec_lock_array (struct drm_gpuvm_exec *vm_exec, struct drm_gem_object **objs, unsigned int num_objs)h]j>)}(hrint drm_gpuvm_exec_lock_array(struct drm_gpuvm_exec *vm_exec, struct drm_gem_object **objs, unsigned int num_objs)h](j)}(hinth]hint}(hjwhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjshhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMvubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjshhhjhMvubjg)}(hdrm_gpuvm_exec_lock_arrayh]jm)}(hdrm_gpuvm_exec_lock_arrayh]hdrm_gpuvm_exec_lock_array}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjshhhjhMvubj)}(hU(struct drm_gpuvm_exec *vm_exec, struct drm_gem_object **objs, unsigned int num_objs)h](j)}(hstruct drm_gpuvm_exec *vm_exech](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpuvm_exech]hdrm_gpuvm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_exec_lock_arrayasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvm_exech]hvm_exec}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object **objsh](jD)}(hjh]hstruct}(hj&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj"ubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFmodnameN classnameNjj)}j]jc.drm_gpuvm_exec_lock_arrayasbuh1hhj"ubjV)}(h h]h }(hjbhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubj4)}(hj7h]h*}(hjphhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj"ubj4)}(hj7h]h*}(hj}hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj"ubjm)}(hobjsh]hobjs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_objsh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hnum_objsh]hnum_objs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjshhhjhMvubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjohhhjhMvubah}(h]jjah ](jjeh"]h$]h&]jj)jhuh1j7hjhMvhjlhhubj)}(hhh]h)}(h'lock all dma-resv of all associated BOsh]h'lock all dma-resv of all associated BOs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMvhjhhubah}(h]h ]h"]h$]h&]uh1jhjlhhhjhMvubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper ``struct drm_gem_object **objs`` additional :c:type:`drm_gem_objects` to lock ``unsigned int num_objs`` the number of additional :c:type:`drm_gem_objects` to lock **Description** Acquires all dma-resv locks of all :c:type:`drm_gem_objects` the given :c:type:`drm_gpuvm` contains mappings of, plus the ones given through **objs**. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hj'h]h Parameters}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMzhj!ubj)}(hhh](j)}(hH``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper h](j)}(h"``struct drm_gpuvm_exec *vm_exec``h]j)}(hjFh]hstruct drm_gpuvm_exec *vm_exec}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMwhj@ubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm_exec` wrapperh](hthe }(hj_hhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hjih]hdrm_gpuvm_exec}(hjkhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhj[hMwhj_ubh wrapper}(hj_hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj[hMwhj\ubah}(h]h ]h"]h$]h&]uh1j hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMwhj=ubj)}(hN``struct drm_gem_object **objs`` additional :c:type:`drm_gem_objects` to lock h](j)}(h ``struct drm_gem_object **objs``h]j)}(hjh]hstruct drm_gem_object **objs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMxhjubj )}(hhh]h)}(h,additional :c:type:`drm_gem_objects` to lockh](h additional }(hjhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjh]hdrm_gem_objects}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhjhMxhjubh to lock}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMxhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMxhj=ubj)}(hU``unsigned int num_objs`` the number of additional :c:type:`drm_gem_objects` to lock h](j)}(h``unsigned int num_objs``h]j)}(hjh]hunsigned int num_objs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMyhjubj )}(hhh]h)}(h:the number of additional :c:type:`drm_gem_objects` to lockh](hthe number of additional }(hjhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hj!h]hdrm_gem_objects}(hj#hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhjhMyhjubh to lock}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMyhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMyhj=ubeh}(h]h ]h"]h$]h&]uh1jhj!ubh)}(h**Description**h]j)}(hj\h]h Description}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM{hj!ubh)}(hAcquires all dma-resv locks of all :c:type:`drm_gem_objects` the given :c:type:`drm_gpuvm` contains mappings of, plus the ones given through **objs**.h](h#Acquires all dma-resv locks of all }(hjrhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hj|h]hdrm_gem_objects}(hj~hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMzhjrubh the given }(hjrhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMzhjrubh3 contains mappings of, plus the ones given through }(hjrhhhNhNubj)}(h**objs**h]hobjs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubh.}(hjrhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMzhj!ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM}hj!ubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM~hj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gpuvm_exec_lock_range (C function)c.drm_gpuvm_exec_lock_rangehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hSint drm_gpuvm_exec_lock_range (struct drm_gpuvm_exec *vm_exec, u64 addr, u64 range)h]j>)}(hRint drm_gpuvm_exec_lock_range(struct drm_gpuvm_exec *vm_exec, u64 addr, u64 range)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj.hMubjg)}(hdrm_gpuvm_exec_lock_rangeh]jm)}(hdrm_gpuvm_exec_lock_rangeh]hdrm_gpuvm_exec_lock_range}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj=ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj.hMubj)}(h5(struct drm_gpuvm_exec *vm_exec, u64 addr, u64 range)h](j)}(hstruct drm_gpuvm_exec *vm_exech](jD)}(hjh]hstruct}(hj]hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjYubjV)}(h h]h }(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjYubh)}(hhh]jm)}(hdrm_gpuvm_exech]hdrm_gpuvm_exec}(hj{hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj}modnameN classnameNjj)}j]j )}jjCsbc.drm_gpuvm_exec_lock_rangeasbuh1hhjYubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjYubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjYubjm)}(hvm_exech]hvm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjUubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_exec_lock_rangeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjUubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_exec_lock_rangeasbuh1hhjubjV)}(h h]h }(hj8hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hrangeh]hrange}(hjFhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjUubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj.hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj.hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj.hMhjhhubj)}(hhh]h)}(h+prepare all BOs mapped within a given rangeh]h+prepare all BOs mapped within a given range}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjmhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj.hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper ``u64 addr`` the start address within the VA space ``u64 range`` the range to iterate within the VA space **Description** Acquires all dma-resv locks of all :c:type:`drm_gem_objects` mapped between **addr** and **addr** + **range**. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(hH``struct drm_gpuvm_exec *vm_exec`` the :c:type:`drm_gpuvm_exec` wrapper h](j)}(h"``struct drm_gpuvm_exec *vm_exec``h]j)}(hjh]hstruct drm_gpuvm_exec *vm_exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm_exec` wrapperh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_exec`h]j)}(hjh]hdrm_gpuvm_exec}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_execuh1hhjhMhjubh wrapper}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h3``u64 addr`` the start address within the VA space h](j)}(h ``u64 addr``h]j)}(hj h]hu64 addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h%the start address within the VA spaceh]h%the start address within the VA space}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj"hMhj#ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj"hMhjubj)}(h7``u64 range`` the range to iterate within the VA space h](j)}(h ``u64 range``h]j)}(hjFh]h u64 range}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj@ubj )}(hhh]h)}(h(the range to iterate within the VA spaceh]h(the range to iterate within the VA space}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMhj\ubah}(h]h ]h"]h$]h&]uh1j hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hnAcquires all dma-resv locks of all :c:type:`drm_gem_objects` mapped between **addr** and **addr** + **range**.h](h#Acquires all dma-resv locks of all }(hjhhhNhNubh)}(h:c:type:`drm_gem_objects`h]j)}(hjh]hdrm_gem_objects}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh mapped between }(hjhhhNhNubj)}(h**addr**h]haddr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h**addr**h]haddr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh + }(hjhhhNhNubj)}(h **range**h]hrange}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_validate (C function)c.drm_gpuvm_validatehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hGint drm_gpuvm_validate (struct drm_gpuvm *gpuvm, struct drm_exec *exec)h]j>)}(hFint drm_gpuvm_validate(struct drm_gpuvm *gpuvm, struct drm_exec *exec)h](j)}(hinth]hint}(hjFhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBhhhjThMubjg)}(hdrm_gpuvm_validateh]jm)}(hdrm_gpuvm_validateh]hdrm_gpuvm_validate}(hjghhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjcubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjBhhhjThMubj)}(h0(struct drm_gpuvm *gpuvm, struct drm_exec *exec)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjisbc.drm_gpuvm_validateasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_validateasbuh1hhjubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj?hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubeh}(h]h ]h"]h$]h&]jjuh1jhjBhhhjThMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj>hhhjThMubah}(h]j9ah ](jjeh"]h$]h&]jj)jhuh1j7hjThMhj;hhubj)}(hhh]h)}(h"validate all BOs marked as evictedh]h"validate all BOs marked as evicted}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjshhubah}(h]h ]h"]h$]h&]uh1jhj;hhhjThMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to validate evicted BOs ``struct drm_exec *exec`` the :c:type:`drm_exec` instance used for locking the GPUVM **Description** Calls the :c:type:`drm_gpuvm_ops`::vm_bo_validate callback for all evicted buffer objects being mapped in the given :c:type:`drm_gpuvm`. **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(hL``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to validate evicted BOs h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h/the :c:type:`drm_gpuvm` to validate evicted BOsh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh to validate evicted BOs}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hU``struct drm_exec *exec`` the :c:type:`drm_exec` instance used for locking the GPUVM h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubj )}(hhh]h)}(h:the :c:type:`drm_exec` instance used for locking the GPUVMh](hthe }(hj,hhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hj6h]hdrm_exec}(hj8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhj(hMhj,ubh$ instance used for locking the GPUVM}(hj,hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj(hMhj)ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj(hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjqh]h Description}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hCalls the :c:type:`drm_gpuvm_ops`::vm_bo_validate callback for all evicted buffer objects being mapped in the given :c:type:`drm_gpuvm`.h](h Calls the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_ops`h]j)}(hjh]h drm_gpuvm_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubhS::vm_bo_validate callback for all evicted buffer objects being mapped in the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h-0 on success, negative error code on failure.h]h-0 on success, negative error code on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gpuvm_resv_add_fence (C function)c.drm_gpuvm_resv_add_fencehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hvoid drm_gpuvm_resv_add_fence (struct drm_gpuvm *gpuvm, struct drm_exec *exec, struct dma_fence *fence, enum dma_resv_usage private_usage, enum dma_resv_usage extobj_usage)h]j>)}(hvoid drm_gpuvm_resv_add_fence(struct drm_gpuvm *gpuvm, struct drm_exec *exec, struct dma_fence *fence, enum dma_resv_usage private_usage, enum dma_resv_usage extobj_usage)h](j)}(hvoidh]hvoid}(hj#hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj1hMubjg)}(hdrm_gpuvm_resv_add_fenceh]jm)}(hdrm_gpuvm_resv_add_fenceh]hdrm_gpuvm_resv_add_fence}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj1hMubj)}(h(struct drm_gpuvm *gpuvm, struct drm_exec *exec, struct dma_fence *fence, enum dma_resv_usage private_usage, enum dma_resv_usage extobj_usage)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj`hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj\ubjV)}(h h]h }(hjmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjFsbc.drm_gpuvm_resv_add_fenceasbuh1hhj\ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbaQh"]h$]h&]uh1jUhj\ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj\ubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_resv_add_fenceasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj>ubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]jc.drm_gpuvm_resv_add_fenceasbuh1hhj>ubjV)}(h h]h }(hj~hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>ubjm)}(hfenceh]hfence}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h!enum dma_resv_usage private_usageh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_resv_usageh]hdma_resv_usage}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_resv_add_fenceasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h private_usageh]h private_usage}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubj)}(h enum dma_resv_usage extobj_usageh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_resv_usageh]hdma_resv_usage}(hj3hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]jc.drm_gpuvm_resv_add_fenceasbuh1hhjubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h extobj_usageh]h extobj_usage}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjXubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhj1hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj1hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj1hMhjhhubj)}(hhh]h)}(h,add fence to private and all extobj dma-resvh]h,add fence to private and all extobj dma-resv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj1hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXE**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to add a fence to ``struct drm_exec *exec`` the :c:type:`drm_exec` locking context ``struct dma_fence *fence`` fence to add ``enum dma_resv_usage private_usage`` private dma-resv usage ``enum dma_resv_usage extobj_usage`` extobj dma-resv usageh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(hF``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to add a fence to h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h)the :c:type:`drm_gpuvm` to add a fence toh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh to add a fence to}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hA``struct drm_exec *exec`` the :c:type:`drm_exec` locking context h](j)}(h``struct drm_exec *exec``h]j)}(hj&h]hstruct drm_exec *exec}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubj )}(hhh]h)}(h&the :c:type:`drm_exec` locking contexth](hthe }(hj?hhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hjIh]hdrm_exec}(hjKhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhj;hMhj?ubh locking context}(hj?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;hMhj<ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj;hMhjubj)}(h)``struct dma_fence *fence`` fence to add h](j)}(h``struct dma_fence *fence``h]j)}(hjh]hstruct dma_fence *fence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj|ubj )}(hhh]h)}(h fence to addh]h fence to add}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h=``enum dma_resv_usage private_usage`` private dma-resv usage h](j)}(h%``enum dma_resv_usage private_usage``h]j)}(hjh]h!enum dma_resv_usage private_usage}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hprivate dma-resv usageh]hprivate dma-resv usage}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h:``enum dma_resv_usage extobj_usage`` extobj dma-resv usageh](j)}(h$``enum dma_resv_usage extobj_usage``h]j)}(hjh]h enum dma_resv_usage extobj_usage}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hextobj dma-resv usageh]hextobj dma-resv usage}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gpuvm_bo_create (C function)c.drm_gpuvm_bo_createhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h_struct drm_gpuvm_bo * drm_gpuvm_bo_create (struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h]j>)}(h]struct drm_gpuvm_bo *drm_gpuvm_bo_create(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](jD)}(hjh]hstruct}(hjNhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjJhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhj[hMubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjomodnameN classnameNjj)}j]j )}jdrm_gpuvm_bo_createsbc.drm_gpuvm_bo_createasbuh1hhjJhhhj[hMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhj[hMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjJhhhj[hMubjg)}(hdrm_gpuvm_bo_createh]jm)}(hjh]hdrm_gpuvm_bo_create}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjJhhhj[hMubj)}(h5(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_bo_createasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4ubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjVhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjXmodnameN classnameNjj)}j]jc.drm_gpuvm_bo_createasbuh1hhj4ubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj4ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjJhhhj[hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjFhhhj[hMubah}(h]jAah ](jjeh"]h$]h&]jj)jhuh1j7hj[hMhjChhubj)}(hhh]h)}(h,create a new instance of struct drm_gpuvm_boh]h,create a new instance of struct drm_gpuvm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjChhhj[hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. ``struct drm_gem_object *obj`` The :c:type:`drm_gem_object` being mapped in the **gpuvm**. **Description** If provided by the driver, this function uses the :c:type:`drm_gpuvm_ops` vm_bo_alloc() callback to allocate. **Return** a pointer to the :c:type:`drm_gpuvm_bo` on success, NULL on failureh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM!hjubj)}(hhh](j)}(hN``struct drm_gpuvm *gpuvm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h1The :c:type:`drm_gpuvm` the **obj** is mapped in.h](hThe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh the }(hjhhhNhNubj)}(h**obj**h]hobj}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh is mapped in.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h[``struct drm_gem_object *obj`` The :c:type:`drm_gem_object` being mapped in the **gpuvm**. h](j)}(h``struct drm_gem_object *obj``h]j)}(hjhh]hstruct drm_gem_object *obj}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjbubj )}(hhh]h)}(h;The :c:type:`drm_gem_object` being mapped in the **gpuvm**.h](hThe }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhj}hMhjubh being mapped in the }(hjhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj}hMhj~ubah}(h]h ]h"]h$]h&]uh1j hjbubeh}(h]h ]h"]h$]h&]uh1jhj}hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM!hjubh)}(hmIf provided by the driver, this function uses the :c:type:`drm_gpuvm_ops` vm_bo_alloc() callback to allocate.h](h2If provided by the driver, this function uses the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_ops`h]j)}(hjh]h drm_gpuvm_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubh$ vm_bo_alloc() callback to allocate.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubh)}(h **Return**h]j)}(hj"h]hReturn}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM#hjubh)}(hCa pointer to the :c:type:`drm_gpuvm_bo` on success, NULL on failureh](ha pointer to the }(hj8hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjBh]h drm_gpuvm_bo}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM$hj8ubh on success, NULL on failure}(hj8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj_hM$hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_bo_put (C function)c.drm_gpuvm_bo_puthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h2bool drm_gpuvm_bo_put (struct drm_gpuvm_bo *vm_bo)h]j>)}(h1bool drm_gpuvm_bo_put(struct drm_gpuvm_bo *vm_bo)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM~ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM~ubjg)}(hdrm_gpuvm_bo_puth]jm)}(hdrm_gpuvm_bo_puth]hdrm_gpuvm_bo_put}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM~ubj)}(h(struct drm_gpuvm_bo *vm_bo)h]j)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_bo_putasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvm_boh]hvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM~ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM~ubah}(h]j}ah ](jjeh"]h$]h&]jj)jhuh1j7hjhM~hjhhubj)}(hhh]h)}(h$drop a struct drm_gpuvm_bo referenceh]h$drop a struct drm_gpuvm_bo reference}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM~hjFhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM~ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjajjajjjuh1j2hhhj AhNhNubj)}(hXc**Parameters** ``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to release the reference of **Description** This releases a reference to **vm_bo**. If the reference count drops to zero, the :c:type:`gpuvm_bo` is destroyed, which includes removing it from the GEMs gpuva list. Hence, if a call to this function can potentially let the reference count drop to zero the caller must hold the lock that the GEM uses for its gpuva list (either the GEM's dma-resv or gpuva.lock mutex). This function may only be called from non-atomic context. **Return** true if vm_bo was destroyed, false otherwise.h](h)}(h**Parameters**h]j)}(hjkh]h Parameters}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubj)}(hhh]j)}(hV``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to release the reference of h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjh]hstruct drm_gpuvm_bo *vm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h6the :c:type:`drm_gpuvm_bo` to release the reference ofh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMhjubh to release the reference of}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjeubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubh)}(h'This releases a reference to **vm_bo**.h](hThis releases a reference to }(hjhhhNhNubj)}(h **vm_bo**h]hvm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubh)}(hXJIf the reference count drops to zero, the :c:type:`gpuvm_bo` is destroyed, which includes removing it from the GEMs gpuva list. Hence, if a call to this function can potentially let the reference count drop to zero the caller must hold the lock that the GEM uses for its gpuva list (either the GEM's dma-resv or gpuva.lock mutex).h](h*If the reference count drops to zero, the }(hjhhhNhNubh)}(h:c:type:`gpuvm_bo`h]j)}(hj)h]hgpuvm_bo}(hj+hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMgpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubhX is destroyed, which includes removing it from the GEMs gpuva list. Hence, if a call to this function can potentially let the reference count drop to zero the caller must hold the lock that the GEM uses for its gpuva list (either the GEM’s dma-resv or gpuva.lock mutex).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjFhMhjeubh)}(h9This function may only be called from non-atomic context.h]h9This function may only be called from non-atomic context.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubh)}(h **Return**h]j)}(hjbh]hReturn}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubh)}(h-true if vm_bo was destroyed, false otherwise.h]h-true if vm_bo was destroyed, false otherwise.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_gpuvm_bo_put_deferred (C function)c.drm_gpuvm_bo_put_deferredhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h;bool drm_gpuvm_bo_put_deferred (struct drm_gpuvm_bo *vm_bo)h]j>)}(h:bool drm_gpuvm_bo_put_deferred(struct drm_gpuvm_bo *vm_bo)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuvm_bo_put_deferredh]jm)}(hdrm_gpuvm_bo_put_deferredh]hdrm_gpuvm_bo_put_deferred}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h(struct drm_gpuvm_bo *vm_bo)h]j)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_bo_put_deferredasbuh1hhjubjV)}(h h]h }(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj/hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvm_boh]hvm_bo}(hj<hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h:drop a struct drm_gpuvm_bo reference with deferred cleanuph]h:drop a struct drm_gpuvm_bo reference with deferred cleanup}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjchhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj~jj~jjjuh1j2hhhj AhNhNubj)}(hXj**Parameters** ``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to release the reference of **Description** This releases a reference to **vm_bo**. This might take and release the GEMs GPUVA lock. You should call drm_gpuvm_bo_deferred_cleanup() later to complete the cleanup process. **Return** true if vm_bo is being destroyed, false otherwise.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh]j)}(hV``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to release the reference of h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjh]hstruct drm_gpuvm_bo *vm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h6the :c:type:`drm_gpuvm_bo` to release the reference ofh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMhjubh to release the reference of}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h'This releases a reference to **vm_bo**.h](hThis releases a reference to }(hjhhhNhNubj)}(h **vm_bo**h]hvm_bo}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hThis might take and release the GEMs GPUVA lock. You should call drm_gpuvm_bo_deferred_cleanup() later to complete the cleanup process.h]hThis might take and release the GEMs GPUVA lock. You should call drm_gpuvm_bo_deferred_cleanup() later to complete the cleanup process.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h **Return**h]j)}(hjMh]hReturn}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(h2true if vm_bo is being destroyed, false otherwise.h]h2true if vm_bo is being destroyed, false otherwise.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gpuvm_bo_deferred_cleanup (C function)c.drm_gpuvm_bo_deferred_cleanuphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h)}(h;void drm_gpuvm_bo_deferred_cleanup(struct drm_gpuvm *gpuvm)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuvm_bo_deferred_cleanuph]jm)}(hdrm_gpuvm_bo_deferred_cleanuph]hdrm_gpuvm_bo_deferred_cleanup}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h(struct drm_gpuvm *gpuvm)h]j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_bo_deferred_cleanupasbuh1hhjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h2clean up BOs in the deferred list deferred cleanuph]h2clean up BOs in the deferred list deferred cleanup}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjOhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm *gpuvm`` the VM to clean up **Description** Cleans up :c:type:`drm_gpuvm_bo` instances in the deferred cleanup list.h](h)}(h**Parameters**h]j)}(hjth]h Parameters}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjnubj)}(hhh]j)}(h/``struct drm_gpuvm *gpuvm`` the VM to clean up h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe VM to clean uph]hthe VM to clean up}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjnubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjnubh)}(hHCleans up :c:type:`drm_gpuvm_bo` instances in the deferred cleanup list.h](h Cleans up }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh( instances in the deferred cleanup list.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhjnubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_bo_find (C function)c.drm_gpuvm_bo_findhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h]struct drm_gpuvm_bo * drm_gpuvm_bo_find (struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h]j>)}(h[struct drm_gpuvm_bo *drm_gpuvm_bo_find(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](jD)}(hjh]hstruct}(hj6hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj2hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjDhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2hhhjChMubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]j )}jdrm_gpuvm_bo_findsbc.drm_gpuvm_bo_findasbuh1hhj2hhhjChMubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2hhhjChMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj2hhhjChMubjg)}(hdrm_gpuvm_bo_findh]jm)}(hjsh]hdrm_gpuvm_bo_find}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj2hhhjChMubj)}(h5(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jqc.drm_gpuvm_bo_findasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj>hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@modnameN classnameNjj)}j]jqc.drm_gpuvm_bo_findasbuh1hhjubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj2hhhjChMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj.hhhjChMubah}(h]j)ah ](jjeh"]h$]h&]jj)jhuh1j7hjChMhj+hhubj)}(hhh]h)}(h^find the :c:type:`drm_gpuvm_bo` for the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`h](h find the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jqc.drm_gpuvm_bo_findasbjM drm_gpuvm_bouh1hhjyhMhjubh for the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjM drm_gpuvmuh1hhjyhMhjubh and }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjMdrm_gem_objectuh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj+hhhjChMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj#jj#jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. ``struct drm_gem_object *obj`` The :c:type:`drm_gem_object` being mapped in the **gpuvm**. **Description** Find the :c:type:`drm_gpuvm_bo` representing the combination of the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`. If found, increases the reference count of the :c:type:`drm_gpuvm_bo` accordingly. **Return** a pointer to the :c:type:`drm_gpuvm_bo` on success, NULL on failureh](h)}(h**Parameters**h]j)}(hj-h]h Parameters}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj'ubj)}(hhh](j)}(hN``struct drm_gpuvm *gpuvm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjLh]hstruct drm_gpuvm *gpuvm}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjFubj )}(hhh]h)}(h1The :c:type:`drm_gpuvm` the **obj** is mapped in.h](hThe }(hjehhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjoh]h drm_gpuvm}(hjqhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjahMhjeubh the }(hjehhhNhNubj)}(h**obj**h]hobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubh is mapped in.}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjahMhjbubah}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhjahMhjCubj)}(h[``struct drm_gem_object *obj`` The :c:type:`drm_gem_object` being mapped in the **gpuvm**. h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h;The :c:type:`drm_gem_object` being mapped in the **gpuvm**.h](hThe }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMhjubh being mapped in the }(hjhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjCubeh}(h]h ]h"]h$]h&]uh1jhj'ubh)}(h**Description**h]j)}(hj*h]h Description}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj'ubh)}(hFind the :c:type:`drm_gpuvm_bo` representing the combination of the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`. If found, increases the reference count of the :c:type:`drm_gpuvm_bo` accordingly.h](h Find the }(hj@hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjJh]h drm_gpuvm_bo}(hjLhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj@ubh+ representing the combination of the given }(hj@hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjnh]h drm_gpuvm}(hjphhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjghMhj@ubh and }(hj@hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjghMhj@ubh1. If found, increases the reference count of the }(hj@hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjghMhj@ubh accordingly.}(hj@hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjghMhj'ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj'ubh)}(hCa pointer to the :c:type:`drm_gpuvm_bo` on success, NULL on failureh](ha pointer to the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubh on success, NULL on failure}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hj'ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gpuvm_bo_obtain_locked (C function)c.drm_gpuvm_bo_obtain_lockedhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hfstruct drm_gpuvm_bo * drm_gpuvm_bo_obtain_locked (struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h]j>)}(hdstruct drm_gpuvm_bo *drm_gpuvm_bo_obtain_locked(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](jD)}(hjh]hstruct}(hjEhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjAhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM-ubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAhhhjRhM-ubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfmodnameN classnameNjj)}j]j )}jdrm_gpuvm_bo_obtain_lockedsbc.drm_gpuvm_bo_obtain_lockedasbuh1hhjAhhhjRhM-ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAhhhjRhM-ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjAhhhjRhM-ubjg)}(hdrm_gpuvm_bo_obtain_lockedh]jm)}(hjh]hdrm_gpuvm_bo_obtain_locked}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjAhhhjRhM-ubj)}(h5(struct drm_gpuvm *gpuvm, struct drm_gem_object *obj)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuvm_bo_obtain_lockedasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj/hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj+ubjV)}(h h]h }(hj<hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjJubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjOmodnameN classnameNjj)}j]jc.drm_gpuvm_bo_obtain_lockedasbuh1hhj+ubjV)}(h h]h }(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj+ubj4)}(hj7h]h*}(hjyhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj+ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjAhhhjRhM-ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj=hhhjRhM-ubah}(h]j8ah ](jjeh"]h$]h&]jj)jhuh1j7hjRhM-hj:hhubj)}(hhh]h)}(hpobtains an instance of the :c:type:`drm_gpuvm_bo` for the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`h](hobtains an instance of the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuvm_bo_obtain_lockedasbjM drm_gpuvm_bouh1hhjyhMhjubh for the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjM drm_gpuvmuh1hhjyhMhjubh and }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjMdrm_gem_objectuh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM-hjhhubah}(h]h ]h"]h$]h&]uh1jhj:hhhjRhM-ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj2jj2jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. ``struct drm_gem_object *obj`` The :c:type:`drm_gem_object` being mapped in the **gpuvm**. **Description** Find the :c:type:`drm_gpuvm_bo` representing the combination of the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`. If found, increases the reference count of the :c:type:`drm_gpuvm_bo` accordingly. If not found, allocates a new :c:type:`drm_gpuvm_bo`. Requires the lock for the GEMs gpuva list. A new :c:type:`drm_gpuvm_bo` is added to the GEMs gpuva list. **Return** a pointer to the :c:type:`drm_gpuvm_bo` on success, an ERR_PTR on failureh](h)}(h**Parameters**h]j)}(hj<h]h Parameters}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM1hj6ubj)}(hhh](j)}(hN``struct drm_gpuvm *gpuvm`` The :c:type:`drm_gpuvm` the **obj** is mapped in. h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj[h]hstruct drm_gpuvm *gpuvm}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM/hjUubj )}(hhh]h)}(h1The :c:type:`drm_gpuvm` the **obj** is mapped in.h](hThe }(hjthhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj~h]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjphM/hjtubh the }(hjthhhNhNubj)}(h**obj**h]hobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubh is mapped in.}(hjthhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjphM/hjqubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjphM/hjRubj)}(h[``struct drm_gem_object *obj`` The :c:type:`drm_gem_object` being mapped in the **gpuvm**. h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM0hjubj )}(hhh]h)}(h;The :c:type:`drm_gem_object` being mapped in the **gpuvm**.h](hThe }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhM0hjubh being mapped in the }(hjhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM0hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM0hjRubeh}(h]h ]h"]h$]h&]uh1jhj6ubh)}(h**Description**h]j)}(hj9h]h Description}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM2hj6ubh)}(hXFind the :c:type:`drm_gpuvm_bo` representing the combination of the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`. If found, increases the reference count of the :c:type:`drm_gpuvm_bo` accordingly. If not found, allocates a new :c:type:`drm_gpuvm_bo`.h](h Find the }(hjOhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjYh]h drm_gpuvm_bo}(hj[hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM1hjOubh+ representing the combination of the given }(hjOhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj}h]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjvhM1hjOubh and }(hjOhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjvhM1hjOubh1. If found, increases the reference count of the }(hjOhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjvhM1hjOubh, accordingly. If not found, allocates a new }(hjOhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjvhM1hjOubh.}(hjOhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjvhM1hj6ubh)}(h*Requires the lock for the GEMs gpuva list.h]h*Requires the lock for the GEMs gpuva list.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM6hj6ubh)}(h=A new :c:type:`drm_gpuvm_bo` is added to the GEMs gpuva list.h](hA new }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj&h]h drm_gpuvm_bo}(hj(hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM8hjubh! is added to the GEMs gpuva list.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChM8hj6ubh)}(h **Return**h]j)}(hjPh]hReturn}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM:hj6ubh)}(hIa pointer to the :c:type:`drm_gpuvm_bo` on success, an ERR_PTR on failureh](ha pointer to the }(hjfhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjph]h drm_gpuvm_bo}(hjrhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM;hjfubh" on success, an ERR_PTR on failure}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM;hj6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_gpuvm_bo_obtain_prealloc (C function)c.drm_gpuvm_bo_obtain_preallochNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hQstruct drm_gpuvm_bo * drm_gpuvm_bo_obtain_prealloc (struct drm_gpuvm_bo *__vm_bo)h]j>)}(hOstruct drm_gpuvm_bo *drm_gpuvm_bo_obtain_prealloc(struct drm_gpuvm_bo *__vm_bo)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM[ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM[ubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gpuvm_bo_obtain_preallocsbc.drm_gpuvm_bo_obtain_preallocasbuh1hhjhhhjhM[ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM[ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhM[ubjg)}(hdrm_gpuvm_bo_obtain_prealloch]jm)}(hjh]hdrm_gpuvm_bo_obtain_prealloc}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM[ubj)}(h(struct drm_gpuvm_bo *__vm_bo)h]j)}(hstruct drm_gpuvm_bo *__vm_boh](jD)}(hjh]hstruct}(hj2hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj.ubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjRmodnameN classnameNjj)}j]jc.drm_gpuvm_bo_obtain_preallocasbuh1hhj.ubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj.ubj4)}(hj7h]h*}(hj|hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj.ubjm)}(h__vm_boh]h__vm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj.ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj*ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM[ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM[ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM[hjhhubj)}(hhh]h)}(hpobtains an instance of the :c:type:`drm_gpuvm_bo` for the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`h](hobtains an instance of the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuvm_bo_obtain_preallocasbjM drm_gpuvm_bouh1hhjyhMhjubh for the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjM drm_gpuvmuh1hhjyhMhjubh and }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjMdrm_gem_objectuh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM[hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM[ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj5jj5jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm_bo *__vm_bo`` A pre-allocated struct drm_gpuvm_bo. **Description** Find the :c:type:`drm_gpuvm_bo` representing the combination of the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`. If found, increases the reference count of the found :c:type:`drm_gpuvm_bo` accordingly, while the **__vm_bo** reference count is decreased. If not found **__vm_bo** is returned without further increase of the reference count. The provided **__vm_bo** must not already be in the gpuva, evict, or extobj lists prior to calling this method. A new :c:type:`drm_gpuvm_bo` is added to the GEMs gpuva list. **Return** a pointer to the found :c:type:`drm_gpuvm_bo` or **__vm_bo** if no existing :c:type:`drm_gpuvm_bo` was foundh](h)}(h**Parameters**h]j)}(hj?h]h Parameters}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM_hj9ubj)}(hhh]j)}(hF``struct drm_gpuvm_bo *__vm_bo`` A pre-allocated struct drm_gpuvm_bo. h](j)}(h ``struct drm_gpuvm_bo *__vm_bo``h]j)}(hj^h]hstruct drm_gpuvm_bo *__vm_bo}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM]hjXubj )}(hhh]h)}(h$A pre-allocated struct drm_gpuvm_bo.h]h$A pre-allocated struct drm_gpuvm_bo.}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshM]hjtubah}(h]h ]h"]h$]h&]uh1j hjXubeh}(h]h ]h"]h$]h&]uh1jhjshM]hjUubah}(h]h ]h"]h$]h&]uh1jhj9ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM_hj9ubh)}(hX^Find the :c:type:`drm_gpuvm_bo` representing the combination of the given :c:type:`drm_gpuvm` and :c:type:`drm_gem_object`. If found, increases the reference count of the found :c:type:`drm_gpuvm_bo` accordingly, while the **__vm_bo** reference count is decreased. If not found **__vm_bo** is returned without further increase of the reference count.h](h Find the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM^hjubh+ representing the combination of the given }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhM^hjubh and }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhM^hjubh7. If found, increases the reference count of the found }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj#h]h drm_gpuvm_bo}(hj%hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhM^hjubh accordingly, while the }(hjhhhNhNubj)}(h **__vm_bo**h]h__vm_bo}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, reference count is decreased. If not found }(hjhhhNhNubj)}(h **__vm_bo**h]h__vm_bo}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh= is returned without further increase of the reference count.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM^hj9ubh)}(hoThe provided **__vm_bo** must not already be in the gpuva, evict, or extobj lists prior to calling this method.h](h The provided }(hjnhhhNhNubj)}(h **__vm_bo**h]h__vm_bo}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubhW must not already be in the gpuva, evict, or extobj lists prior to calling this method.}(hjnhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMdhj9ubh)}(h=A new :c:type:`drm_gpuvm_bo` is added to the GEMs gpuva list.h](hA new }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMghjubh! is added to the GEMs gpuva list.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMghj9ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMihj9ubh)}(hla pointer to the found :c:type:`drm_gpuvm_bo` or **__vm_bo** if no existing :c:type:`drm_gpuvm_bo` was foundh](ha pointer to the found }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMjhjubh or }(hjhhhNhNubj)}(h **__vm_bo**h]h__vm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh if no existing }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMjhjubh was found}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMjhj9ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_gpuvm_bo_extobj_add (C function)c.drm_gpuvm_bo_extobj_addhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h9void drm_gpuvm_bo_extobj_add (struct drm_gpuvm_bo *vm_bo)h]j>)}(h8void drm_gpuvm_bo_extobj_add(struct drm_gpuvm_bo *vm_bo)h](j)}(hvoidh]hvoid}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\hhhjnhMubjg)}(hdrm_gpuvm_bo_extobj_addh]jm)}(hdrm_gpuvm_bo_extobj_addh]hdrm_gpuvm_bo_extobj_add}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj\hhhjnhMubj)}(h(struct drm_gpuvm_bo *vm_bo)h]j)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_bo_extobj_addasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvm_boh]hvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj\hhhjnhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjXhhhjnhMubah}(h]jSah ](jjeh"]h$]h&]jj)jhuh1j7hjnhMhjUhhubj)}(hhh]h)}(hHadds the :c:type:`drm_gpuvm_bo` to its :c:type:`drm_gpuvm`'s extobj listh](h adds the }(hj hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj*h]h drm_gpuvm_bo}(hj,hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuvm_bo_extobj_addasbjM drm_gpuvm_bouh1hhjyhMhj ubh to its }(hj hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjRh]h drm_gpuvm}(hjThhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjFjM drm_gpuvmuh1hhjyhMhj ubh’s extobj list}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjUhhhjnhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXB**Parameters** ``struct drm_gpuvm_bo *vm_bo`` The :c:type:`drm_gpuvm_bo` to add to its :c:type:`drm_gpuvm`'s the extobj list. **Description** Adds the given **vm_bo** to its :c:type:`drm_gpuvm`'s extobj list if not on the list already and if the corresponding :c:type:`drm_gem_object` is an external object, actually.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh]j)}(ho``struct drm_gpuvm_bo *vm_bo`` The :c:type:`drm_gpuvm_bo` to add to its :c:type:`drm_gpuvm`'s the extobj list. h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjh]hstruct drm_gpuvm_bo *vm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hOThe :c:type:`drm_gpuvm_bo` to add to its :c:type:`drm_gpuvm`'s the extobj list.h](hThe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjhMhjubh to add to its }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh’s the extobj list.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj-h]h Description}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hAdds the given **vm_bo** to its :c:type:`drm_gpuvm`'s extobj list if not on the list already and if the corresponding :c:type:`drm_gem_object` is an external object, actually.h](hAdds the given }(hjChhhNhNubj)}(h **vm_bo**h]hvm_bo}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubh to its }(hjChhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj_h]h drm_gpuvm}(hjahhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjCubhE’s extobj list if not on the list already and if the corresponding }(hjChhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhj|hMhjCubh! is an external object, actually.}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj|hMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_bo_evict (C function)c.drm_gpuvm_bo_evicthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h@void drm_gpuvm_bo_evict (struct drm_gpuvm_bo *vm_bo, bool evict)h]j>)}(h?void drm_gpuvm_bo_evict(struct drm_gpuvm_bo *vm_bo, bool evict)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuvm_bo_evicth]jm)}(hdrm_gpuvm_bo_evicth]hdrm_gpuvm_bo_evict}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h((struct drm_gpuvm_bo *vm_bo, bool evict)h](j)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hj%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj'modnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_bo_evictasbuh1hhjubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjShhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvm_boh]hvm_bo}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h bool evicth](j)}(hj*h]hbool}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjuubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjuubjm)}(hevicth]hevict}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hUadd / remove a :c:type:`drm_gpuvm_bo` to / from the :c:type:`drm_gpuvms` evicted listh](hadd / remove a }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jAc.drm_gpuvm_bo_evictasbjM drm_gpuvm_bouh1hhjyhMhjubh to / from the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvms`h]j)}(hjh]h drm_gpuvms}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjjM drm_gpuvmsuh1hhjyhMhjubh evicted list}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj!jj!jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to add or remove ``bool evict`` indicates whether the object is evicted **Description** Adds a :c:type:`drm_gpuvm_bo` to or removes it from the :c:type:`drm_gpuvm`'s evicted list.h](h)}(h**Parameters**h]j)}(hj+h]h Parameters}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj%ubj)}(hhh](j)}(hK``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to add or remove h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjJh]hstruct drm_gpuvm_bo *vm_bo}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjDubj )}(hhh]h)}(h+the :c:type:`drm_gpuvm_bo` to add or removeh](hthe }(hjchhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjmh]h drm_gpuvm_bo}(hjohhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjkubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj_hMhjcubh to add or remove}(hjchhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj_hMhj`ubah}(h]h ]h"]h$]h&]uh1j hjDubeh}(h]h ]h"]h$]h&]uh1jhj_hMhjAubj)}(h7``bool evict`` indicates whether the object is evicted h](j)}(h``bool evict``h]j)}(hjh]h bool evict}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h'indicates whether the object is evictedh]h'indicates whether the object is evicted}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjAubeh}(h]h ]h"]h$]h&]uh1jhj%ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj%ubh)}(h[Adds a :c:type:`drm_gpuvm_bo` to or removes it from the :c:type:`drm_gpuvm`'s evicted list.h](hAdds a }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh to or removes it from the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj%h]h drm_gpuvm}(hj'hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh’s evicted list.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_insert (C function)c.drm_gpuva_inserthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hDint drm_gpuva_insert (struct drm_gpuvm *gpuvm, struct drm_gpuva *va)h]j>)}(hCint drm_gpuva_insert(struct drm_gpuvm *gpuvm, struct drm_gpuva *va)h](j)}(hinth]hint}(hjlhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhhjzhMubjg)}(hdrm_gpuva_inserth]jm)}(hdrm_gpuva_inserth]hdrm_gpuva_insert}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhhjzhMubj)}(h/(struct drm_gpuvm *gpuvm, struct drm_gpuva *va)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuva_insertasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj;modnameN classnameNjj)}j]jc.drm_gpuva_insertasbuh1hhjubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjehhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvah]hva}(hjrhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhhjzhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjdhhhjzhMubah}(h]j_ah ](jjeh"]h$]h&]jj)jhuh1j7hjzhMhjahhubj)}(hhh]h)}(hinsert a :c:type:`drm_gpuva`h](h insert a }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_insertasbjM drm_gpuvauh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjahhhjzhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to insert the :c:type:`drm_gpuva` in ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to insert **Description** Insert a :c:type:`drm_gpuva` with a given address and range into a :c:type:`drm_gpuvm`. It is safe to use this function using the safe versions of iterating the GPU VA space, such as drm_gpuvm_for_each_va_safe() and drm_gpuvm_for_each_va_range_safe(). **Return** 0 on success, negative error code on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(hY``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to insert the :c:type:`drm_gpuva` in h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h)}(h+void drm_gpuva_remove(struct drm_gpuva *va)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuva_removeh]jm)}(hdrm_gpuva_removeh]hdrm_gpuva_remove}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h(struct drm_gpuva *va)h]j)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuva_removeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj(hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvah]hva}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hremove a :c:type:`drm_gpuva`h](h remove a }(hj_hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjih]h drm_gpuva}(hjkhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_removeasbjM drm_gpuvauh1hhjyhMhj_ubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj\hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXA**Parameters** ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to remove **Description** This removes the given :c:type:`va` from the underlying tree. It is safe to use this function using the safe versions of iterating the GPU VA space, such as drm_gpuvm_for_each_va_safe() and drm_gpuvm_for_each_va_range_safe().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubj)}(hhh]j)}(h;``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to remove h](j)}(h``struct drm_gpuva *va``h]j)}(hjh]hstruct drm_gpuva *va}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h!the :c:type:`drm_gpuva` to removeh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhMhjubh to remove}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj"h]h Description}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubh)}(h=This removes the given :c:type:`va` from the underlying tree.h](hThis removes the given }(hj8hhhNhNubh)}(h :c:type:`va`h]j)}(hjBh]hva}(hjDhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj8ubh from the underlying tree.}(hj8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj_hMhjubh)}(hIt is safe to use this function using the safe versions of iterating the GPU VA space, such as drm_gpuvm_for_each_va_safe() and drm_gpuvm_for_each_va_range_safe().h]hIt is safe to use this function using the safe versions of iterating the GPU VA space, such as drm_gpuvm_for_each_va_safe() and drm_gpuvm_for_each_va_range_safe().}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_link (C function)c.drm_gpuva_linkhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hFvoid drm_gpuva_link (struct drm_gpuva *va, struct drm_gpuvm_bo *vm_bo)h]j>)}(hEvoid drm_gpuva_link(struct drm_gpuva *va, struct drm_gpuvm_bo *vm_bo)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM ubjg)}(hdrm_gpuva_linkh]jm)}(hdrm_gpuva_linkh]hdrm_gpuva_link}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM ubj)}(h2(struct drm_gpuva *va, struct drm_gpuvm_bo *vm_bo)h](j)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuva_linkasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj"hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvah]hva}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hjHhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjDubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hjfhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjcubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjhmodnameN classnameNjj)}j]jc.drm_gpuva_linkasbuh1hhjDubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjDubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjDubjm)}(hvm_boh]hvm_bo}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjDubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM hjhhubj)}(hhh]h)}(hlink a :c:type:`drm_gpuva`h](hlink a }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_linkasbjM drm_gpuvauh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXm**Parameters** ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to link ``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to add the :c:type:`drm_gpuva` to **Description** This adds the given :c:type:`va` to the GPU VA list of the :c:type:`drm_gpuvm_bo` and the :c:type:`drm_gpuvm_bo` to the :c:type:`drm_gem_object` it is associated with. For every :c:type:`drm_gpuva` entry added to the :c:type:`drm_gpuvm_bo` an additional reference of the latter is taken. This function expects the caller to protect the GEM's GPUVA list against concurrent access using either the GEM's dma-resv or gpuva.lock mutex.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM$hj ubj)}(hhh](j)}(h9``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to link h](j)}(h``struct drm_gpuva *va``h]j)}(hj.h]hstruct drm_gpuva *va}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM!hj(ubj )}(hhh]h)}(hthe :c:type:`drm_gpuva` to linkh](hthe }(hjGhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjQh]h drm_gpuva}(hjShhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjChM!hjGubh to link}(hjGhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjChM!hjDubah}(h]h ]h"]h$]h&]uh1j hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChM!hj%ubj)}(h\``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` to add the :c:type:`drm_gpuva` to h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjh]hstruct drm_gpuvm_bo *vm_bo}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM"hjubj )}(hhh]h)}(h)}(h+void drm_gpuva_unlink(struct drm_gpuva *va)h](j)}(hvoidh]hvoid}(hj@hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj<hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM@ubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<hhhjNhM@ubjg)}(hdrm_gpuva_unlinkh]jm)}(hdrm_gpuva_unlinkh]hdrm_gpuva_unlink}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj<hhhjNhM@ubj)}(h(struct drm_gpuva *va)h]j)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hj}hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjyubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjcsbc.drm_gpuva_unlinkasbuh1hhjyubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjyubjm)}(hvah]hva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjuubah}(h]h ]h"]h$]h&]jjuh1jhj<hhhjNhM@ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj8hhhjNhM@ubah}(h]j3ah ](jjeh"]h$]h&]jj)jhuh1j7hjNhM@hj5hhubj)}(hhh]h)}(hunlink a :c:type:`drm_gpuva`h](h unlink a }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj h]h drm_gpuva}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_unlinkasbjM drm_gpuvauh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM@hjhhubah}(h]h ]h"]h$]h&]uh1jhj5hhhjNhM@ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj<jj<jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to unlink **Description** This removes the given :c:type:`va` from the GPU VA list of the :c:type:`drm_gem_object` it is associated with. This removes the given :c:type:`va` from the GPU VA list of the :c:type:`drm_gpuvm_bo` and the :c:type:`drm_gpuvm_bo` from the :c:type:`drm_gem_object` it is associated with in case this call unlinks the last :c:type:`drm_gpuva` from the :c:type:`drm_gpuvm_bo`. For every :c:type:`drm_gpuva` entry removed from the :c:type:`drm_gpuvm_bo` a reference of the latter is dropped. This function expects the caller to protect the GEM's GPUVA list against concurrent access using either the GEM's dma-resv or gpuva.lock mutex.h](h)}(h**Parameters**h]j)}(hjFh]h Parameters}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMDhj@ubj)}(hhh]j)}(h;``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to unlink h](j)}(h``struct drm_gpuva *va``h]j)}(hjeh]hstruct drm_gpuva *va}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMAhj_ubj )}(hhh]h)}(h!the :c:type:`drm_gpuva` to unlinkh](hthe }(hj~hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjzhMAhj~ubh to unlink}(hj~hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjzhMAhj{ubah}(h]h ]h"]h$]h&]uh1j hj_ubeh}(h]h ]h"]h$]h&]uh1jhjzhMAhj\ubah}(h]h ]h"]h$]h&]uh1jhj@ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMChj@ubh)}(hoThis removes the given :c:type:`va` from the GPU VA list of the :c:type:`drm_gem_object` it is associated with.h](hThis removes the given }(hjhhhNhNubh)}(h :c:type:`va`h]j)}(hjh]hva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMBhjubh from the GPU VA list of the }(hjhhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjhMBhjubh it is associated with.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMBhj@ubh)}(hXThis removes the given :c:type:`va` from the GPU VA list of the :c:type:`drm_gpuvm_bo` and the :c:type:`drm_gpuvm_bo` from the :c:type:`drm_gem_object` it is associated with in case this call unlinks the last :c:type:`drm_gpuva` from the :c:type:`drm_gpuvm_bo`.h](hThis removes the given }(hj.hhhNhNubh)}(h :c:type:`va`h]j)}(hj8h]hva}(hj:hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMEhj.ubh from the GPU VA list of the }(hj.hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj\h]h drm_gpuvm_bo}(hj^hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjUhMEhj.ubh and the }(hj.hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjUhMEhj.ubh from the }(hj.hhhNhNubh)}(h:c:type:`drm_gem_object`h]j)}(hjh]hdrm_gem_object}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gem_objectuh1hhjUhMEhj.ubh: it is associated with in case this call unlinks the last }(hj.hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjUhMEhj.ubh from the }hj.sbh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjh]h drm_gpuvm_bo}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhjUhMEhj.ubh.}(hj.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjUhMEhj@ubh)}(hqFor every :c:type:`drm_gpuva` entry removed from the :c:type:`drm_gpuvm_bo` a reference of the latter is dropped.h](h For every }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMIhjubh entry removed from the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hj=h]h drm_gpuvm_bo}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj6hMIhjubh& a reference of the latter is dropped.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj6hMIhj@ubh)}(hThis function expects the caller to protect the GEM's GPUVA list against concurrent access using either the GEM's dma-resv or gpuva.lock mutex.h]hThis function expects the caller to protect the GEM’s GPUVA list against concurrent access using either the GEM’s dma-resv or gpuva.lock mutex.}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMLhj@ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_gpuva_unlink_defer (C function)c.drm_gpuva_unlink_deferhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h2void drm_gpuva_unlink_defer (struct drm_gpuva *va)h]j>)}(h1void drm_gpuva_unlink_defer(struct drm_gpuva *va)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMbubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMbubjg)}(hdrm_gpuva_unlink_deferh]jm)}(hdrm_gpuva_unlink_deferh]hdrm_gpuva_unlink_defer}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMbubj)}(h(struct drm_gpuva *va)h]j)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuva_unlink_deferasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvah]hva}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMbubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMbubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMbhjhhubj)}(hhh]h)}(h8unlink a :c:type:`drm_gpuva` with deferred vm_bo cleanuph](h unlink a }(hjShhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj]h]h drm_gpuva}(hj_hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j c.drm_gpuva_unlink_deferasbjM drm_gpuvauh1hhjyhMhjSubh with deferred vm_bo cleanup}(hjShhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMbhjPhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMbubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to unlink **Description** Similar to drm_gpuva_unlink(), but uses drm_gpuvm_bo_put_deferred() and takes the lock for the caller.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMfhjubj)}(hhh]j)}(h;``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to unlink h](j)}(h``struct drm_gpuva *va``h]j)}(hjh]hstruct drm_gpuva *va}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMchjubj )}(hhh]h)}(h!the :c:type:`drm_gpuva` to unlinkh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhMchjubh to unlink}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMchjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMchjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMehjubh)}(hfSimilar to drm_gpuva_unlink(), but uses drm_gpuvm_bo_put_deferred() and takes the lock for the caller.h]hfSimilar to drm_gpuva_unlink(), but uses drm_gpuvm_bo_put_deferred() and takes the lock for the caller.}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMdhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_gpuva_find_first (C function)c.drm_gpuva_find_firsthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hVstruct drm_gpuva * drm_gpuva_find_first (struct drm_gpuvm *gpuvm, u64 addr, u64 range)h]j>)}(hTstruct drm_gpuva *drm_gpuva_find_first(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](jD)}(hjh]hstruct}(hj_hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj[hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjmhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[hhhjlhMubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hj~hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gpuva_find_firstsbc.drm_gpuva_find_firstasbuh1hhj[hhhjlhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[hhhjlhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj[hhhjlhMubjg)}(hdrm_gpuva_find_firsth]jm)}(hjh]hdrm_gpuva_find_first}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj[hhhjlhMubj)}(h.(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuva_find_firstasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj#hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjIubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjNmodnameN classnameNjj)}j]jc.drm_gpuva_find_firstasbuh1hhjEubjV)}(h h]h }(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubjm)}(haddrh]haddr}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuva_find_firstasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hrangeh]hrange}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj[hhhjlhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjWhhhjlhMubah}(h]jRah ](jjeh"]h$]h&]jj)jhuh1j7hjlhMhjThhubj)}(hhh]h)}(h5find the first :c:type:`drm_gpuva` in the given rangeh](hfind the first }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_find_firstasbjM drm_gpuvauh1hhjyhMhjubh in the given range}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjThhhjlhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj*jj*jjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in ``u64 addr`` the :c:type:`drm_gpuvas` address ``u64 range`` the :c:type:`drm_gpuvas` range **Return** the first :c:type:`drm_gpuva` within the given rangeh](h)}(h**Parameters**h]j)}(hj4h]h Parameters}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj.ubj)}(hhh](j)}(hA``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjSh]hstruct drm_gpuvm *gpuvm}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjMubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm` to search inh](hthe }(hjlhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjvh]h drm_gpuvm}(hjxhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhhMhjlubh to search in}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhhMhjiubah}(h]h ]h"]h$]h&]uh1j hjMubeh}(h]h ]h"]h$]h&]uh1jhjhhMhjJubj)}(h.``u64 addr`` the :c:type:`drm_gpuvas` address h](j)}(h ``u64 addr``h]j)}(hjh]hu64 addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h the :c:type:`drm_gpuvas` addressh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjh]h drm_gpuvas}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhjhMhjubh address}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjJubj)}(h-``u64 range`` the :c:type:`drm_gpuvas` range h](j)}(h ``u64 range``h]j)}(hj h]h u64 range}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe :c:type:`drm_gpuvas` rangeh](hthe }(hj$hhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hj.h]h drm_gpuvas}(hj0hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhj hMhj$ubh range}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhj!ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjJubeh}(h]h ]h"]h$]h&]uh1jhj.ubh)}(h **Return**h]j)}(hjih]hReturn}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj.ubh)}(h4the first :c:type:`drm_gpuva` within the given rangeh](h the first }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh within the given range}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_find (C function)c.drm_gpuva_findhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hPstruct drm_gpuva * drm_gpuva_find (struct drm_gpuvm *gpuvm, u64 addr, u64 range)h]j>)}(hNstruct drm_gpuva *drm_gpuva_find(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jdrm_gpuva_findsbc.drm_gpuva_findasbuh1hhjhhhjhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhMubjg)}(hdrm_gpuva_findh]jm)}(hjh]hdrm_gpuva_find}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h.(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjKhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjGubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjGubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjihhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjfubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjkmodnameN classnameNjj)}j]j c.drm_gpuva_findasbuh1hhjGubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjGubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjGubjm)}(hgpuvmh]hgpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjGubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j c.drm_gpuva_findasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j c.drm_gpuva_findasbuh1hhjubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hrangeh]hrange}(hj2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjCubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hfind a :c:type:`drm_gpuva`h](hfind a }(hj\hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjfh]h drm_gpuva}(hjhhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j c.drm_gpuva_findasbjM drm_gpuvauh1hhjyhMhj\ubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjYhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in ``u64 addr`` the :c:type:`drm_gpuvas` address ``u64 range`` the :c:type:`drm_gpuvas` range **Return** the :c:type:`drm_gpuva` at a given :c:type:`addr` and with a given :c:type:`range`h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(hA``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm` to search inh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubh to search in}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h.``u64 addr`` the :c:type:`drm_gpuvas` address h](j)}(h ``u64 addr``h]j)}(hjh]hu64 addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(h the :c:type:`drm_gpuvas` addressh](hthe }(hj6hhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hj@h]h drm_gpuvas}(hjBhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhj2hMhj6ubh address}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj2hMhj3ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMhjubj)}(h-``u64 range`` the :c:type:`drm_gpuvas` range h](j)}(h ``u64 range``h]j)}(hjyh]h u64 range}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjsubj )}(hhh]h)}(hthe :c:type:`drm_gpuvas` rangeh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvas`h]j)}(hjh]h drm_gpuvas}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvasuh1hhjhMhjubh range}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjsubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hRthe :c:type:`drm_gpuva` at a given :c:type:`addr` and with a given :c:type:`range`h](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh at a given }(hjhhhNhNubh)}(h:c:type:`addr`h]j)}(hj h]haddr}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMaddruh1hhj hMhjubh and with a given }(hjhhhNhNubh)}(h:c:type:`range`h]j)}(hj> h]hrange}(hj@ hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj< ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMrangeuh1hhj hMhjubeh}(h]h ]h"]h$]h&]uh1hhj hMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gpuva_find_prev (C function)c.drm_gpuva_find_prevhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hKstruct drm_gpuva * drm_gpuva_find_prev (struct drm_gpuvm *gpuvm, u64 start)h]j>)}(hIstruct drm_gpuva *drm_gpuva_find_prev(struct drm_gpuvm *gpuvm, u64 start)h](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj} hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj} hhhj hMubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jdrm_gpuva_find_prevsbc.drm_gpuva_find_prevasbuh1hhj} hhhj hMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj} hhhj hMubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj} hhhj hMubjg)}(hdrm_gpuva_find_prevh]jm)}(hj h]hdrm_gpuva_find_prev}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj} hhhj hMubj)}(h$(struct drm_gpuvm *gpuvm, u64 start)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j c.drm_gpuva_find_prevasbuh1hhj ubjV)}(h h]h }(hj7 hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjE hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hgpuvmh]hgpuvm}(hjR hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u64 starth](h)}(hhh]jm)}(hu64h]hu64}(hjn hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjk ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjp modnameN classnameNjj)}j]j c.drm_gpuva_find_prevasbuh1hhjg ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjg ubjm)}(hstarth]hstart}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjg ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhj} hhhj hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjy hhhj hMubah}(h]jt ah ](jjeh"]h$]h&]jj)jhuh1j7hj hMhjv hhubj)}(hhh]h)}(h5find the :c:type:`drm_gpuva` before the given addressh](h find the }(hj hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj h]h drm_gpuva}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j c.drm_gpuva_find_prevasbjM drm_gpuvauh1hhjyhMhj ubh before the given address}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjv hhhj hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in ``u64 start`` the given GPU VA's start address **Description** Find the adjacent :c:type:`drm_gpuva` before the GPU VA with given :c:type:`start` address. Note that if there is any free space between the GPU VA mappings no mapping is returned. **Return** a pointer to the found :c:type:`drm_gpuva` or NULL if none was foundh](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubj)}(hhh](j)}(hA``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj- h]hstruct drm_gpuvm *gpuvm}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj' ubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm` to search inh](hthe }(hjF hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjP h]h drm_gpuvm}(hjR hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjN ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjB hMhjF ubh to search in}(hjF hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjB hMhjC ubah}(h]h ]h"]h$]h&]uh1j hj' ubeh}(h]h ]h"]h$]h&]uh1jhjB hMhj$ ubj)}(h/``u64 start`` the given GPU VA's start address h](j)}(h ``u64 start``h]j)}(hj h]h u64 start}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubj )}(hhh]h)}(h the given GPU VA's start addressh]h"the given GPU VA’s start address}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhj$ ubeh}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubh)}(h[Find the adjacent :c:type:`drm_gpuva` before the GPU VA with given :c:type:`start` address.h](hFind the adjacent }(hj hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj h]h drm_gpuva}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubh before the GPU VA with given }(hj hhhNhNubh)}(h:c:type:`start`h]j)}(hj h]hstart}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMstartuh1hhj hMhj ubh address.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhj ubh)}(hXNote that if there is any free space between the GPU VA mappings no mapping is returned.h]hXNote that if there is any free space between the GPU VA mappings no mapping is returned.}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubh)}(h **Return**h]j)}(hj@ h]hReturn}(hjB hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj> ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubh)}(hDa pointer to the found :c:type:`drm_gpuva` or NULL if none was foundh](ha pointer to the found }(hjV hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj` h]h drm_gpuva}(hjb hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj^ ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjV ubh or NULL if none was found}(hjV hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj} hMhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_gpuva_find_next (C function)c.drm_gpuva_find_nexthNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hIstruct drm_gpuva * drm_gpuva_find_next (struct drm_gpuvm *gpuvm, u64 end)h]j>)}(hGstruct drm_gpuva *drm_gpuva_find_next(struct drm_gpuvm *gpuvm, u64 end)h](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hMubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jdrm_gpuva_find_nextsbc.drm_gpuva_find_nextasbuh1hhj hhhj hMubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hMubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj hhhj hMubjg)}(hdrm_gpuva_find_nexth]jm)}(hj h]hdrm_gpuva_find_next}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj hMubj)}(h"(struct drm_gpuvm *gpuvm, u64 end)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj" hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj/ hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj@ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj= ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjB modnameN classnameNjj)}j]j c.drm_gpuva_find_nextasbuh1hhj ubjV)}(h h]h }(hj^ hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjl hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hgpuvmh]hgpuvm}(hjy hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hu64 endh](h)}(hhh]jm)}(hu64h]hu64}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j c.drm_gpuva_find_nextasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubjm)}(hendh]hend}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hMubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj hMhj hhubj)}(hhh]h)}(h4find the :c:type:`drm_gpuva` after the given addressh](h find the }(hj hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj h]h drm_gpuva}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j c.drm_gpuva_find_nextasbjM drm_gpuvauh1hhjyhMhj ubh after the given address}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj+jj+jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in ``u64 end`` the given GPU VA's end address **Description** Find the adjacent :c:type:`drm_gpuva` after the GPU VA with given :c:type:`end` address. Note that if there is any free space between the GPU VA mappings no mapping is returned. **Return** a pointer to the found :c:type:`drm_gpuva` or NULL if none was foundh](h)}(h**Parameters**h]j)}(hj5h]h Parameters}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj/ubj)}(hhh](j)}(hA``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to search in h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjTh]hstruct drm_gpuvm *gpuvm}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjNubj )}(hhh]h)}(h$the :c:type:`drm_gpuvm` to search inh](hthe }(hjmhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjwh]h drm_gpuvm}(hjyhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjihMhjmubh to search in}(hjmhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjihMhjjubah}(h]h ]h"]h$]h&]uh1j hjNubeh}(h]h ]h"]h$]h&]uh1jhjihMhjKubj)}(h+``u64 end`` the given GPU VA's end address h](j)}(h ``u64 end``h]j)}(hjh]hu64 end}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe given GPU VA's end addressh]h the given GPU VA’s end address}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjKubeh}(h]h ]h"]h$]h&]uh1jhj/ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj/ubh)}(hXFind the adjacent :c:type:`drm_gpuva` after the GPU VA with given :c:type:`end` address.h](hFind the adjacent }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj h]h drm_gpuva}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh after the GPU VA with given }(hjhhhNhNubh)}(h :c:type:`end`h]j)}(hj/h]hend}(hj1hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMenduh1hhj(hMhjubh address.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj(hMhj/ubh)}(hXNote that if there is any free space between the GPU VA mappings no mapping is returned.h]hXNote that if there is any free space between the GPU VA mappings no mapping is returned.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj/ubh)}(h **Return**h]j)}(hjgh]hReturn}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj/ubh)}(hDa pointer to the found :c:type:`drm_gpuva` or NULL if none was foundh](ha pointer to the found }(hj}hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj}ubh or NULL if none was found}(hj}hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj/ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_gpuvm_interval_empty (C function)c.drm_gpuvm_interval_emptyhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hLbool drm_gpuvm_interval_empty (struct drm_gpuvm *gpuvm, u64 addr, u64 range)h]j>)}(hKbool drm_gpuvm_interval_empty(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_gpuvm_interval_emptyh]jm)}(hdrm_gpuvm_interval_emptyh]hdrm_gpuvm_interval_empty}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h.(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_interval_emptyasbuh1hhjubjV)}(h h]h }(hjIhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjWhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jEc.drm_gpuvm_interval_emptyasbuh1hhjyubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubjm)}(haddrh]haddr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jEc.drm_gpuvm_interval_emptyasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hrangeh]hrange}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h:indicate whether a given interval of the VA space is emptyh]h:indicate whether a given interval of the VA space is empty}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj6jj6jjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to check the range for ``u64 addr`` the start address of the range ``u64 range`` the range of the interval **Return** true if the interval is empty, false otherwiseh](h)}(h**Parameters**h]j)}(hj@h]h Parameters}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj:ubj)}(hhh](j)}(hK``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` to check the range for h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj_h]hstruct drm_gpuvm *gpuvm}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjYubj )}(hhh]h)}(h.the :c:type:`drm_gpuvm` to check the range forh](hthe }(hjxhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjthMhjxubh to check the range for}(hjxhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjthMhjuubah}(h]h ]h"]h$]h&]uh1j hjYubeh}(h]h ]h"]h$]h&]uh1jhjthMhjVubj)}(h,``u64 addr`` the start address of the range h](j)}(h ``u64 addr``h]j)}(hjh]hu64 addr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe start address of the rangeh]hthe start address of the range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjVubj)}(h(``u64 range`` the range of the interval h](j)}(h ``u64 range``h]j)}(hjh]h u64 range}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe range of the intervalh]hthe range of the interval}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjVubeh}(h]h ]h"]h$]h&]uh1jhj:ubh)}(h **Return**h]j)}(hj/h]hReturn}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj:ubh)}(h.true if the interval is empty, false otherwiseh]h.true if the interval is empty, false otherwise}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj:ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_map (C function)c.drm_gpuva_maphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hevoid drm_gpuva_map (struct drm_gpuvm *gpuvm, struct drm_gpuva *va, const struct drm_gpuva_op_map *op)h]j>)}(hdvoid drm_gpuva_map(struct drm_gpuvm *gpuvm, struct drm_gpuva *va, const struct drm_gpuva_op_map *op)h](j)}(hvoidh]hvoid}(hjthhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjphhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjphhhjhMubjg)}(h drm_gpuva_maph]jm)}(h drm_gpuva_maph]h drm_gpuva_map}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjphhhjhMubj)}(hR(struct drm_gpuvm *gpuvm, struct drm_gpuva *va, const struct drm_gpuva_op_map *op)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuva_mapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gpuva *vah](jD)}(hjh]hstruct}(hj#hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjCmodnameN classnameNjj)}j]jc.drm_gpuva_mapasbuh1hhjubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjmhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hvah]hva}(hjzhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h!const struct drm_gpuva_op_map *oph](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpuva_op_maph]hdrm_gpuva_op_map}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuva_mapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hoph]hop}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjphhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjlhhhjhMubah}(h]jgah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjihhubj)}(hhh]h)}(hPhelper to insert a :c:type:`drm_gpuva` according to a :c:type:`drm_gpuva_op_map`h](hhelper to insert a }(hj/hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj9h]h drm_gpuva}(hj;hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_mapasbjM drm_gpuvauh1hhjyhMhj/ubh according to a }(hj/hhhNhNubh)}(h:c:type:`drm_gpuva_op_map`h]j)}(hjah]hdrm_gpuva_op_map}(hjchhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjUjMdrm_gpuva_op_mapuh1hhjyhMhj/ubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj,hhubah}(h]h ]h"]h$]h&]uh1jhjihhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXG**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` ``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to insert ``const struct drm_gpuva_op_map *op`` the :c:type:`drm_gpuva_op_map` to initialize **va** with **Description** Initializes the **va** from the **op** and inserts it into the given **gpuvm**.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj)}(hhh](j)}(h4``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubj )}(hhh]h)}(hthe :c:type:`drm_gpuvm`h](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMhjubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h;``struct drm_gpuva *va`` the :c:type:`drm_gpuva` to insert h](j)}(h``struct drm_gpuva *va``h]j)}(hjh]hstruct drm_gpuva *va}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhj ubj )}(hhh]h)}(h!the :c:type:`drm_gpuva` to inserth](hthe }(hj(hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hj2h]h drm_gpuva}(hj4hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj$hMhj(ubh to insert}(hj(hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$hMhj%ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj$hMhjubj)}(h_``const struct drm_gpuva_op_map *op`` the :c:type:`drm_gpuva_op_map` to initialize **va** with h](j)}(h%``const struct drm_gpuva_op_map *op``h]j)}(hjkh]h!const struct drm_gpuva_op_map *op}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjeubj )}(hhh]h)}(h8the :c:type:`drm_gpuva_op_map` to initialize **va** withh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op_map`h]j)}(hjh]hdrm_gpuva_op_map}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_op_mapuh1hhjhMhjubh to initialize }(hjhhhNhNubj)}(h**va**h]hva}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh with}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubh)}(hOInitializes the **va** from the **op** and inserts it into the given **gpuvm**.h](hInitializes the }(hjhhhNhNubj)}(h**va**h]hva}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh from the }(hjhhhNhNubj)}(h**op**h]hop}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and inserts it into the given }(hjhhhNhNubj)}(h **gpuvm**h]hgpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_remap (C function)c.drm_gpuva_remaphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hjvoid drm_gpuva_remap (struct drm_gpuva *prev, struct drm_gpuva *next, const struct drm_gpuva_op_remap *op)h]j>)}(hivoid drm_gpuva_remap(struct drm_gpuva *prev, struct drm_gpuva *next, const struct drm_gpuva_op_remap *op)h](j)}(hvoidh]hvoid}(hjVhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hjehhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRhhhjdhM ubjg)}(hdrm_gpuva_remaph]jm)}(hdrm_gpuva_remaph]hdrm_gpuva_remap}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjRhhhjdhM ubj)}(hU(struct drm_gpuva *prev, struct drm_gpuva *next, const struct drm_gpuva_op_remap *op)h](j)}(hstruct drm_gpuva *prevh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjysbc.drm_gpuva_remapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hprevh]hprev}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gpuva *nexth](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvah]h drm_gpuva}(hj#hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]jc.drm_gpuva_remapasbuh1hhjubjV)}(h h]h }(hjAhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjOhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hnexth]hnext}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h#const struct drm_gpuva_op_remap *oph](jD)}(hj h]hconst}(hjuhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubh)}(hhh]jm)}(hdrm_gpuva_op_remaph]hdrm_gpuva_op_remap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_gpuva_remapasbuh1hhjqubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjqubjm)}(hoph]hop}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjRhhhjdhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjNhhhjdhM ubah}(h]jIah ](jjeh"]h$]h&]jj)jhuh1j7hjdhM hjKhhubj)}(hhh]h)}(hQhelper to remap a :c:type:`drm_gpuva` according to a :c:type:`drm_gpuva_op_remap`h](hhelper to remap a }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_remapasbjM drm_gpuvauh1hhjyhMhjubh according to a }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op_remap`h]j)}(hjCh]hdrm_gpuva_op_remap}(hjEhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj7jMdrm_gpuva_op_remapuh1hhjyhMhjubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjhhubah}(h]h ]h"]h$]h&]uh1jhjKhhhjdhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjpjjpjjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuva *prev`` the :c:type:`drm_gpuva` to remap when keeping the start of a mapping ``struct drm_gpuva *next`` the :c:type:`drm_gpuva` to remap when keeping the end of a mapping ``const struct drm_gpuva_op_remap *op`` the :c:type:`drm_gpuva_op_remap` to initialize **prev** and **next** with **Description** Removes the currently mapped :c:type:`drm_gpuva` and remaps it using **prev** and/or **next**.h](h)}(h**Parameters**h]j)}(hjzh]h Parameters}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjtubj)}(hhh](j)}(h```struct drm_gpuva *prev`` the :c:type:`drm_gpuva` to remap when keeping the start of a mapping h](j)}(h``struct drm_gpuva *prev``h]j)}(hjh]hstruct drm_gpuva *prev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubj )}(hhh]h)}(hDthe :c:type:`drm_gpuva` to remap when keeping the start of a mappingh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhM hjubh- to remap when keeping the start of a mapping}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubj)}(h^``struct drm_gpuva *next`` the :c:type:`drm_gpuva` to remap when keeping the end of a mapping h](j)}(h``struct drm_gpuva *next``h]j)}(hjh]hstruct drm_gpuva *next}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubj )}(hhh]h)}(hBthe :c:type:`drm_gpuva` to remap when keeping the end of a mappingh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhj hM hjubh+ to remap when keeping the end of a mapping}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hM hj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hM hjubj)}(hr``const struct drm_gpuva_op_remap *op`` the :c:type:`drm_gpuva_op_remap` to initialize **prev** and **next** with h](j)}(h'``const struct drm_gpuva_op_remap *op``h]j)}(hjQh]h#const struct drm_gpuva_op_remap *op}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjKubj )}(hhh]h)}(hIthe :c:type:`drm_gpuva_op_remap` to initialize **prev** and **next** withh](hthe }(hjjhhhNhNubh)}(h:c:type:`drm_gpuva_op_remap`h]j)}(hjth]hdrm_gpuva_op_remap}(hjvhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_op_remapuh1hhjfhM hjjubh to initialize }(hjjhhhNhNubj)}(h**prev**h]hprev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubh and }(hjjhhhNhNubj)}(h**next**h]hnext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubh with}(hjjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjfhM hjgubah}(h]h ]h"]h$]h&]uh1j hjKubeh}(h]h ]h"]h$]h&]uh1jhjfhM hjubeh}(h]h ]h"]h$]h&]uh1jhjtubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjtubh)}(h^Removes the currently mapped :c:type:`drm_gpuva` and remaps it using **prev** and/or **next**.h](hRemoves the currently mapped }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjubh and remaps it using }(hjhhhNhNubj)}(h**prev**h]hprev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and/or }(hjhhhNhNubj)}(h**next**h]hnext}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM hjtubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_unmap (C function)c.drm_gpuva_unmaphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h:void drm_gpuva_unmap (const struct drm_gpuva_op_unmap *op)h]j>)}(h9void drm_gpuva_unmap(const struct drm_gpuva_op_unmap *op)h](j)}(hvoidh]hvoid}(hj_hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM" ubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[hhhjmhM" ubjg)}(hdrm_gpuva_unmaph]jm)}(hdrm_gpuva_unmaph]hdrm_gpuva_unmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj[hhhjmhM" ubj)}(h%(const struct drm_gpuva_op_unmap *op)h]j)}(h#const struct drm_gpuva_op_unmap *oph](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpuva_op_unmaph]hdrm_gpuva_op_unmap}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_gpuva_unmapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hoph]hop}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhj[hhhjmhM" ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjWhhhjmhM" ubah}(h]jRah ](jjeh"]h$]h&]jj)jhuh1j7hjmhM" hjThhubj)}(hhh]h)}(hRhelper to remove a :c:type:`drm_gpuva` according to a :c:type:`drm_gpuva_op_unmap`h](hhelper to remove a }(hj:hhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjDh]h drm_gpuva}(hjFhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jc.drm_gpuva_unmapasbjM drm_gpuvauh1hhjyhMhj:ubh according to a }(hj:hhhNhNubh)}(h:c:type:`drm_gpuva_op_unmap`h]j)}(hjlh]hdrm_gpuva_op_unmap}(hjnhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj`jMdrm_gpuva_op_unmapuh1hhjyhMhj:ubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM" hj7hhubah}(h]h ]h"]h$]h&]uh1jhjThhhjmhM" ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(h**Parameters** ``const struct drm_gpuva_op_unmap *op`` the :c:type:`drm_gpuva_op_unmap` specifying the :c:type:`drm_gpuva` to remove **Description** Removes the :c:type:`drm_gpuva` associated with the :c:type:`drm_gpuva_op_unmap`.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM& hjubj)}(hhh]j)}(hv``const struct drm_gpuva_op_unmap *op`` the :c:type:`drm_gpuva_op_unmap` specifying the :c:type:`drm_gpuva` to remove h](j)}(h'``const struct drm_gpuva_op_unmap *op``h]j)}(hjh]h#const struct drm_gpuva_op_unmap *op}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM$ hjubj )}(hhh]h)}(hMthe :c:type:`drm_gpuva_op_unmap` specifying the :c:type:`drm_gpuva` to removeh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuva_op_unmap`h]j)}(hjh]hdrm_gpuva_op_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_op_unmapuh1hhjhM$ hjubh specifying the }(hjhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjh]h drm_gpuva}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhjhM$ hjubh to remove}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM$ hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM$ hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjCh]h Description}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM& hjubh)}(hQRemoves the :c:type:`drm_gpuva` associated with the :c:type:`drm_gpuva_op_unmap`.h](h Removes the }(hjYhhhNhNubh)}(h:c:type:`drm_gpuva`h]j)}(hjch]h drm_gpuva}(hjehhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvauh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM% hjYubh associated with the }(hjYhhhNhNubh)}(h:c:type:`drm_gpuva_op_unmap`h]j)}(hjh]hdrm_gpuva_op_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_op_unmapuh1hhjhM% hjYubh.}(hjYhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhM% hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_sm_map (C function)c.drm_gpuvm_sm_maphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(h_int drm_gpuvm_sm_map (struct drm_gpuvm *gpuvm, void *priv, const struct drm_gpuvm_map_req *req)h]j>)}(h^int drm_gpuvm_sm_map(struct drm_gpuvm *gpuvm, void *priv, const struct drm_gpuvm_map_req *req)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMQ ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMQ ubjg)}(hdrm_gpuvm_sm_maph]jm)}(hdrm_gpuvm_sm_maph]hdrm_gpuvm_sm_map}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMQ ubj)}(hJ(struct drm_gpuvm *gpuvm, void *priv, const struct drm_gpuvm_map_req *req)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]j )}jjsbc.drm_gpuvm_sm_mapasbuh1hhjubjV)}(h h]h }(hjIhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjWhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hgpuvmh]hgpuvm}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h void *privh](j)}(hvoidh]hvoid}(hj}hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjyubjm)}(hprivh]hpriv}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h#const struct drm_gpuvm_map_req *reqh](jD)}(hj h]hconst}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpuvm_map_reqh]hdrm_gpuvm_map_req}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jEc.drm_gpuvm_sm_mapasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj$hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hreqh]hreq}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMQ ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMQ ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMQ hjhhubj)}(hhh]h)}(h2calls the :c:type:`drm_gpuva_op` split/merge stepsh](h calls the }(hj[hhhNhNubh)}(h:c:type:`drm_gpuva_op`h]j)}(hjeh]h drm_gpuva_op}(hjghhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjcubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jEc.drm_gpuvm_sm_mapasbjM drm_gpuva_opuh1hhjyhMhj[ubh split/merge steps}(hj[hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMQ hjXhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMQ ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhj AhNhNubj)}(hXy**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``void *priv`` pointer to a driver private data structure ``const struct drm_gpuvm_map_req *req`` ptr to struct drm_gpuvm_map_req **Description** This function iterates the given range of the GPU VA space. It utilizes the :c:type:`drm_gpuvm_ops` to call back into the driver providing the split and merge steps. Drivers may use these callbacks to update the GPU VA space right away within the callback. In case the driver decides to copy and store the operations for later processing neither this function nor :c:type:`drm_gpuvm_sm_unmap` is allowed to be called before the :c:type:`drm_gpuvm`'s view of the GPU VA space was updated with the previous set of operations. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used. A sequence of callbacks can contain map, unmap and remap operations, but the sequence of callbacks might also be empty if no operation is required, e.g. if the requested mapping already exists in the exact same way. There can be an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The latter one represents the original map operation requested by the caller. **Return** 0 on success or a negative error codeh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMU hjubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hjh]hstruct drm_gpuvm *gpuvm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMR hjubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjh]h drm_gpuvm}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjhMR hjubh representing the GPU VA space}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMR hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMR hjubj)}(h:``void *priv`` pointer to a driver private data structure h](j)}(h``void *priv``h]j)}(hj h]h void *priv}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMS hjubj )}(hhh]h)}(h*pointer to a driver private data structureh]h*pointer to a driver private data structure}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5hMS hj6ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj5hMS hjubj)}(hH``const struct drm_gpuvm_map_req *req`` ptr to struct drm_gpuvm_map_req h](j)}(h'``const struct drm_gpuvm_map_req *req``h]j)}(hjYh]h#const struct drm_gpuvm_map_req *req}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMT hjSubj )}(hhh]h)}(hptr to struct drm_gpuvm_map_reqh]hptr to struct drm_gpuvm_map_req}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhMT hjoubah}(h]h ]h"]h$]h&]uh1j hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhMT hjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMV hjubh)}(hThis function iterates the given range of the GPU VA space. It utilizes the :c:type:`drm_gpuvm_ops` to call back into the driver providing the split and merge steps.h](hLThis function iterates the given range of the GPU VA space. It utilizes the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_ops`h]j)}(hjh]h drm_gpuvm_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMU hjubhB to call back into the driver providing the split and merge steps.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMU hjubh)}(hXDrivers may use these callbacks to update the GPU VA space right away within the callback. In case the driver decides to copy and store the operations for later processing neither this function nor :c:type:`drm_gpuvm_sm_unmap` is allowed to be called before the :c:type:`drm_gpuvm`'s view of the GPU VA space was updated with the previous set of operations. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.h](hDrivers may use these callbacks to update the GPU VA space right away within the callback. In case the driver decides to copy and store the operations for later processing neither this function nor }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm_sm_unmap`h]j)}(hjh]hdrm_gpuvm_sm_unmap}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_unmapuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMY hjubh$ is allowed to be called before the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj h]h drm_gpuvm}(hj hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj hMY hjubh]’s view of the GPU VA space was updated with the previous set of operations. To update the }(hjhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj- h]h drm_gpuvm}(hj/ hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj+ ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj hMY hjubh’s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMY hjubh)}(hA sequence of callbacks can contain map, unmap and remap operations, but the sequence of callbacks might also be empty if no operation is required, e.g. if the requested mapping already exists in the exact same way.h]hA sequence of callbacks can contain map, unmap and remap operations, but the sequence of callbacks might also be empty if no operation is required, e.g. if the requested mapping already exists in the exact same way.}(hjT hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMb hjubh)}(hThere can be an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The latter one represents the original map operation requested by the caller.h]hThere can be an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The latter one represents the original map operation requested by the caller.}(hjc hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMf hjubh)}(h **Return**h]j)}(hjt h]hReturn}(hjv hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjr ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMj hjubh)}(h%0 on success or a negative error codeh]h%0 on success or a negative error code}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMk hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuvm_sm_unmap (C function)c.drm_gpuvm_sm_unmaphNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hYint drm_gpuvm_sm_unmap (struct drm_gpuvm *gpuvm, void *priv, u64 req_addr, u64 req_range)h]j>)}(hXint drm_gpuvm_sm_unmap(struct drm_gpuvm *gpuvm, void *priv, u64 req_addr, u64 req_range)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM} ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hM} ubjg)}(hdrm_gpuvm_sm_unmaph]jm)}(hdrm_gpuvm_sm_unmaph]hdrm_gpuvm_sm_unmap}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj hM} ubj)}(hB(struct drm_gpuvm *gpuvm, void *priv, u64 req_addr, u64 req_range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]j )}jj sbc.drm_gpuvm_sm_unmapasbuh1hhj ubjV)}(h h]h }(hj4!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjB!hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hgpuvmh]hgpuvm}(hjO!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h void *privh](j)}(hvoidh]hvoid}(hjh!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjd!ubjV)}(h h]h }(hjv!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjd!ubj4)}(hj7h]h*}(hj!hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjd!ubjm)}(hprivh]hpriv}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjd!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u64 req_addrh](h)}(hhh]jm)}(hu64h]hu64}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]j0!c.drm_gpuvm_sm_unmapasbuh1hhj!ubjV)}(h h]h }(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!ubjm)}(hreq_addrh]hreq_addr}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u64 req_rangeh](h)}(hhh]jm)}(hu64h]hu64}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj!modnameN classnameNjj)}j]j0!c.drm_gpuvm_sm_unmapasbuh1hhj!ubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj!ubjm)}(h req_rangeh]h req_range}(hj!"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj!ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj hM} ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hM} ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj hM} hj hhubj)}(hhh]h)}(h3calls the :c:type:`drm_gpuva_ops` to split on unmaph](h calls the }(hjK"hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjU"h]h drm_gpuva_ops}(hjW"hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjS"ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j0!c.drm_gpuvm_sm_unmapasbjM drm_gpuva_opsuh1hhjyhMhjK"ubh to split on unmap}(hjK"hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM} hjH"hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hM} ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj"jj"jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``void *priv`` pointer to a driver private data structure ``u64 req_addr`` the start address of the range to unmap ``u64 req_range`` the range of the mappings to unmap **Description** This function iterates the given range of the GPU VA space. It utilizes the :c:type:`drm_gpuvm_ops` to call back into the driver providing the operations to unmap and, if required, split existing mappings. Drivers may use these callbacks to update the GPU VA space right away within the callback. In case the driver decides to copy and store the operations for later processing neither this function nor :c:type:`drm_gpuvm_sm_map` is allowed to be called before the :c:type:`drm_gpuvm`'s view of the GPU VA space was updated with the previous set of operations. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used. A sequence of callbacks can contain unmap and remap operations, depending on whether there are actual overlapping mappings to split. There can be an arbitrary amount of unmap operations and a maximum of two remap operations. **Return** 0 on success or a negative error codeh](h)}(h**Parameters**h]j)}(hj"h]h Parameters}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj"ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj"h]hstruct drm_gpuvm *gpuvm}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM~ hj"ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj"hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj"h]h drm_gpuvm}(hj"hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj"hM~ hj"ubh representing the GPU VA space}(hj"hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj"hM~ hj"ubah}(h]h ]h"]h$]h&]uh1j hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"hM~ hj"ubj)}(h:``void *priv`` pointer to a driver private data structure h](j)}(h``void *priv``h]j)}(hj#h]h void *priv}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj #ubj )}(hhh]h)}(h*pointer to a driver private data structureh]h*pointer to a driver private data structure}(hj)#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj%#hM hj&#ubah}(h]h ]h"]h$]h&]uh1j hj #ubeh}(h]h ]h"]h$]h&]uh1jhj%#hM hj"ubj)}(h9``u64 req_addr`` the start address of the range to unmap h](j)}(h``u64 req_addr``h]j)}(hjI#h]h u64 req_addr}(hjK#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjG#ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjC#ubj )}(hhh]h)}(h'the start address of the range to unmaph]h'the start address of the range to unmap}(hjb#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^#hM hj_#ubah}(h]h ]h"]h$]h&]uh1j hjC#ubeh}(h]h ]h"]h$]h&]uh1jhj^#hM hj"ubj)}(h5``u64 req_range`` the range of the mappings to unmap h](j)}(h``u64 req_range``h]j)}(hj#h]h u64 req_range}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj|#ubj )}(hhh]h)}(h"the range of the mappings to unmaph]h"the range of the mappings to unmap}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj#hM hj#ubah}(h]h ]h"]h$]h&]uh1j hj|#ubeh}(h]h ]h"]h$]h&]uh1jhj#hM hj"ubeh}(h]h ]h"]h$]h&]uh1jhj"ubh)}(h**Description**h]j)}(hj#h]h Description}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj"ubh)}(hThis function iterates the given range of the GPU VA space. It utilizes the :c:type:`drm_gpuvm_ops` to call back into the driver providing the operations to unmap and, if required, split existing mappings.h](hLThis function iterates the given range of the GPU VA space. It utilizes the }(hj#hhhNhNubh)}(h:c:type:`drm_gpuvm_ops`h]j)}(hj#h]h drm_gpuvm_ops}(hj#hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj#ubhj to call back into the driver providing the operations to unmap and, if required, split existing mappings.}(hj#hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj#hM hj"ubh)}(hXDrivers may use these callbacks to update the GPU VA space right away within the callback. In case the driver decides to copy and store the operations for later processing neither this function nor :c:type:`drm_gpuvm_sm_map` is allowed to be called before the :c:type:`drm_gpuvm`'s view of the GPU VA space was updated with the previous set of operations. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.h](hDrivers may use these callbacks to update the GPU VA space right away within the callback. In case the driver decides to copy and store the operations for later processing neither this function nor }(hj$hhhNhNubh)}(h:c:type:`drm_gpuvm_sm_map`h]j)}(hj$h]hdrm_gpuvm_sm_map}(hj$hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj $ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuvm_sm_mapuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj$ubh$ is allowed to be called before the }(hj$hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj3$h]h drm_gpuvm}(hj5$hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj1$ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj,$hM hj$ubh]’s view of the GPU VA space was updated with the previous set of operations. To update the }(hj$hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjV$h]h drm_gpuvm}(hjX$hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjT$ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj,$hM hj$ubh’s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj,$hM hj"ubh)}(hA sequence of callbacks can contain unmap and remap operations, depending on whether there are actual overlapping mappings to split.h]hA sequence of callbacks can contain unmap and remap operations, depending on whether there are actual overlapping mappings to split.}(hj}$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj"ubh)}(h[There can be an arbitrary amount of unmap operations and a maximum of two remap operations.h]h[There can be an arbitrary amount of unmap operations and a maximum of two remap operations.}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj"ubh)}(h **Return**h]j)}(hj$h]hReturn}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj"ubh)}(h%0 on success or a negative error codeh]h%0 on success or a negative error code}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj"ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_gpuvm_sm_map_exec_lock (C function)c.drm_gpuvm_sm_map_exec_lockhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hint drm_gpuvm_sm_map_exec_lock (struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences, struct drm_gpuvm_map_req *req)h]j>)}(hint drm_gpuvm_sm_map_exec_lock(struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences, struct drm_gpuvm_map_req *req)h](j)}(hinth]hint}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj$hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj$hhhj$hM ubjg)}(hdrm_gpuvm_sm_map_exec_lockh]jm)}(hdrm_gpuvm_sm_map_exec_lockh]hdrm_gpuvm_sm_map_exec_lock}(hj%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj$hhhj$hM ubj)}(hh(struct drm_gpuvm *gpuvm, struct drm_exec *exec, unsigned int num_fences, struct drm_gpuvm_map_req *req)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj%hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj%ubjV)}(h h]h }(hj,%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj=%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj:%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj?%modnameN classnameNjj)}j]j )}jj%sbc.drm_gpuvm_sm_map_exec_lockasbuh1hhj%ubjV)}(h h]h }(hj]%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubj4)}(hj7h]h*}(hjk%hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj%ubjm)}(hgpuvmh]hgpuvm}(hjx%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hj%hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj%ubjV)}(h h]h }(hj%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hj%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]jY%c.drm_gpuvm_sm_map_exec_lockasbuh1hhj%ubjV)}(h h]h }(hj%hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubj4)}(hj7h]h*}(hj%hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj%ubjm)}(hexech]hexec}(hj%hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubj)}(hunsigned int num_fencesh](j)}(hunsignedh]hunsigned}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubj)}(hinth]hint}(hj&hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj%ubjV)}(h h]h }(hj+&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubjm)}(h num_fencesh]h num_fences}(hj9&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubj)}(hstruct drm_gpuvm_map_req *reqh](jD)}(hjh]hstruct}(hjR&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjN&ubjV)}(h h]h }(hj_&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjN&ubh)}(hhh]jm)}(hdrm_gpuvm_map_reqh]hdrm_gpuvm_map_req}(hjp&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjm&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjr&modnameN classnameNjj)}j]jY%c.drm_gpuvm_sm_map_exec_lockasbuh1hhjN&ubjV)}(h h]h }(hj&hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjN&ubj4)}(hj7h]h*}(hj&hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjN&ubjm)}(hreqh]hreq}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjN&ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj%ubeh}(h]h ]h"]h$]h&]jjuh1jhj$hhhj$hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj$hhhj$hM ubah}(h]j$ah ](jjeh"]h$]h&]jj)jhuh1j7hj$hM hj$hhubj)}(hhh]h)}(h1locks the objects touched by a drm_gpuvm_sm_map()h]h1locks the objects touched by a drm_gpuvm_sm_map()}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&hhubah}(h]h ]h"]h$]h&]uh1jhj$hhhj$hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj&jj&jjjuh1j2hhhj AhNhNubj)}(hX}**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``struct drm_exec *exec`` the :c:type:`drm_exec` locking context ``unsigned int num_fences`` for newly mapped objects, the # of fences to reserve ``struct drm_gpuvm_map_req *req`` ptr to drm_gpuvm_map_req struct **Description** This function locks (drm_exec_lock_obj()) objects that will be unmapped/ remapped, and locks+prepares (drm_exec_prepare_object()) objects that will be newly mapped. The expected usage is:: vm_bind { struct drm_exec exec; // IGNORE_DUPLICATES is required, INTERRUPTIBLE_WAIT is recommended: drm_exec_init(&exec, IGNORE_DUPLICATES | INTERRUPTIBLE_WAIT, 0); drm_exec_until_all_locked (&exec) { for_each_vm_bind_operation { switch (op->op) { case DRIVER_OP_UNMAP: ret = drm_gpuvm_sm_unmap_exec_lock(gpuvm, &exec, op->addr, op->range); break; case DRIVER_OP_MAP: ret = drm_gpuvm_sm_map_exec_lock(gpuvm, &exec, num_fences, &req); break; } drm_exec_retry_on_contention(&exec); if (ret) return ret; } } } This enables all locking to be performed before the driver begins modifying the VM. This is safe to do in the case of overlapping DRIVER_VM_BIND_OPs, where an earlier op can alter the sequence of steps generated for a later op, because the later altered step will involve the same GEM object(s) already seen in the earlier locking step. For example: 1) An earlier driver DRIVER_OP_UNMAP op removes the need for a DRM_GPUVA_OP_REMAP/UNMAP step. This is safe because we've already locked the GEM object in the earlier DRIVER_OP_UNMAP op. 2) An earlier DRIVER_OP_MAP op overlaps with a later DRIVER_OP_MAP/UNMAP op, introducing a DRM_GPUVA_OP_REMAP/UNMAP that wouldn't have been required without the earlier DRIVER_OP_MAP. This is safe because we've already locked the GEM object in the earlier DRIVER_OP_MAP step. **Return** 0 on success or a negative error codeh](h)}(h**Parameters**h]j)}(hj&h]h Parameters}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj'h]hstruct drm_gpuvm *gpuvm}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj'ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj-'hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj7'h]h drm_gpuvm}(hj9'hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj5'ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj)'hM hj-'ubh representing the GPU VA space}(hj-'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj)'hM hj*'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj)'hM hj 'ubj)}(hA``struct drm_exec *exec`` the :c:type:`drm_exec` locking context h](j)}(h``struct drm_exec *exec``h]j)}(hjp'h]hstruct drm_exec *exec}(hjr'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjn'ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjj'ubj )}(hhh]h)}(h&the :c:type:`drm_exec` locking contexth](hthe }(hj'hhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hj'h]hdrm_exec}(hj'hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhj'hM hj'ubh locking context}(hj'hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj'hM hj'ubah}(h]h ]h"]h$]h&]uh1j hjj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM hj 'ubj)}(hQ``unsigned int num_fences`` for newly mapped objects, the # of fences to reserve h](j)}(h``unsigned int num_fences``h]j)}(hj'h]hunsigned int num_fences}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj'ubj )}(hhh]h)}(h4for newly mapped objects, the # of fences to reserveh]h4for newly mapped objects, the # of fences to reserve}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj'hM hj'ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj'hM hj 'ubj)}(hB``struct drm_gpuvm_map_req *req`` ptr to drm_gpuvm_map_req struct h](j)}(h!``struct drm_gpuvm_map_req *req``h]j)}(hj(h]hstruct drm_gpuvm_map_req *req}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj'ubj )}(hhh]h)}(hptr to drm_gpuvm_map_req structh]hptr to drm_gpuvm_map_req struct}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj(hM hj(ubah}(h]h ]h"]h$]h&]uh1j hj'ubeh}(h]h ]h"]h$]h&]uh1jhj(hM hj 'ubeh}(h]h ]h"]h$]h&]uh1jhj&ubh)}(h**Description**h]j)}(hj@(h]h Description}(hjB(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>(ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubh)}(hThis function locks (drm_exec_lock_obj()) objects that will be unmapped/ remapped, and locks+prepares (drm_exec_prepare_object()) objects that will be newly mapped.h]hThis function locks (drm_exec_lock_obj()) objects that will be unmapped/ remapped, and locks+prepares (drm_exec_prepare_object()) objects that will be newly mapped.}(hjV(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubh)}(hThe expected usage is::h]hThe expected usage is:}(hje(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubjT)}(hXvm_bind { struct drm_exec exec; // IGNORE_DUPLICATES is required, INTERRUPTIBLE_WAIT is recommended: drm_exec_init(&exec, IGNORE_DUPLICATES | INTERRUPTIBLE_WAIT, 0); drm_exec_until_all_locked (&exec) { for_each_vm_bind_operation { switch (op->op) { case DRIVER_OP_UNMAP: ret = drm_gpuvm_sm_unmap_exec_lock(gpuvm, &exec, op->addr, op->range); break; case DRIVER_OP_MAP: ret = drm_gpuvm_sm_map_exec_lock(gpuvm, &exec, num_fences, &req); break; } drm_exec_retry_on_contention(&exec); if (ret) return ret; } } }h]hXvm_bind { struct drm_exec exec; // IGNORE_DUPLICATES is required, INTERRUPTIBLE_WAIT is recommended: drm_exec_init(&exec, IGNORE_DUPLICATES | INTERRUPTIBLE_WAIT, 0); drm_exec_until_all_locked (&exec) { for_each_vm_bind_operation { switch (op->op) { case DRIVER_OP_UNMAP: ret = drm_gpuvm_sm_unmap_exec_lock(gpuvm, &exec, op->addr, op->range); break; case DRIVER_OP_MAP: ret = drm_gpuvm_sm_map_exec_lock(gpuvm, &exec, num_fences, &req); break; } drm_exec_retry_on_contention(&exec); if (ret) return ret; } } }}hjt(sbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubh)}(hX_This enables all locking to be performed before the driver begins modifying the VM. This is safe to do in the case of overlapping DRIVER_VM_BIND_OPs, where an earlier op can alter the sequence of steps generated for a later op, because the later altered step will involve the same GEM object(s) already seen in the earlier locking step. For example:h]hX_This enables all locking to be performed before the driver begins modifying the VM. This is safe to do in the case of overlapping DRIVER_VM_BIND_OPs, where an earlier op can alter the sequence of steps generated for a later op, because the later altered step will involve the same GEM object(s) already seen in the earlier locking step. For example:}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubj:)}(hhh](j{)}(hAn earlier driver DRIVER_OP_UNMAP op removes the need for a DRM_GPUVA_OP_REMAP/UNMAP step. This is safe because we've already locked the GEM object in the earlier DRIVER_OP_UNMAP op. h]h)}(hAn earlier driver DRIVER_OP_UNMAP op removes the need for a DRM_GPUVA_OP_REMAP/UNMAP step. This is safe because we've already locked the GEM object in the earlier DRIVER_OP_UNMAP op.h]hAn earlier driver DRIVER_OP_UNMAP op removes the need for a DRM_GPUVA_OP_REMAP/UNMAP step. This is safe because we’ve already locked the GEM object in the earlier DRIVER_OP_UNMAP op.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj(ubah}(h]h ]h"]h$]h&]uh1j{hj(ubj{)}(hXAn earlier DRIVER_OP_MAP op overlaps with a later DRIVER_OP_MAP/UNMAP op, introducing a DRM_GPUVA_OP_REMAP/UNMAP that wouldn't have been required without the earlier DRIVER_OP_MAP. This is safe because we've already locked the GEM object in the earlier DRIVER_OP_MAP step. h]h)}(hXAn earlier DRIVER_OP_MAP op overlaps with a later DRIVER_OP_MAP/UNMAP op, introducing a DRM_GPUVA_OP_REMAP/UNMAP that wouldn't have been required without the earlier DRIVER_OP_MAP. This is safe because we've already locked the GEM object in the earlier DRIVER_OP_MAP step.h]hXAn earlier DRIVER_OP_MAP op overlaps with a later DRIVER_OP_MAP/UNMAP op, introducing a DRM_GPUVA_OP_REMAP/UNMAP that wouldn’t have been required without the earlier DRIVER_OP_MAP. This is safe because we’ve already locked the GEM object in the earlier DRIVER_OP_MAP step.}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj(ubah}(h]h ]h"]h$]h&]uh1j{hj(ubeh}(h]h ]h"]h$]h&]jG=jH=jI=hjJ=juh1j~:hj&ubh)}(h **Return**h]j)}(hj(h]hReturn}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubh)}(h%0 on success or a negative error codeh]h%0 on success or a negative error code}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj&ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_gpuvm_sm_unmap_exec_lock (C function)c.drm_gpuvm_sm_unmap_exec_lockhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hnint drm_gpuvm_sm_unmap_exec_lock (struct drm_gpuvm *gpuvm, struct drm_exec *exec, u64 req_addr, u64 req_range)h]j>)}(hmint drm_gpuvm_sm_unmap_exec_lock(struct drm_gpuvm *gpuvm, struct drm_exec *exec, u64 req_addr, u64 req_range)h](j)}(hinth]hint}(hj)hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hj#)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)hhhj")hM ubjg)}(hdrm_gpuvm_sm_unmap_exec_lockh]jm)}(hdrm_gpuvm_sm_unmap_exec_lockh]hdrm_gpuvm_sm_unmap_exec_lock}(hj5)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1)ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj)hhhj")hM ubj)}(hM(struct drm_gpuvm *gpuvm, struct drm_exec *exec, u64 req_addr, u64 req_range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjQ)hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjM)ubjV)}(h h]h }(hj^)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjM)ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjo)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjl)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjq)modnameN classnameNjj)}j]j )}jj7)sbc.drm_gpuvm_sm_unmap_exec_lockasbuh1hhjM)ubjV)}(h h]h }(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjM)ubj4)}(hj7h]h*}(hj)hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjM)ubjm)}(hgpuvmh]hgpuvm}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjM)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjI)ubj)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hj)hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj)ubjV)}(h h]h }(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj)modnameN classnameNjj)}j]j)c.drm_gpuvm_sm_unmap_exec_lockasbuh1hhj)ubjV)}(h h]h }(hj)hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubj4)}(hj7h]h*}(hj *hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj)ubjm)}(hexech]hexec}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjI)ubj)}(h u64 req_addrh](h)}(hhh]jm)}(hu64h]hu64}(hj6*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj3*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj8*modnameN classnameNjj)}j]j)c.drm_gpuvm_sm_unmap_exec_lockasbuh1hhj/*ubjV)}(h h]h }(hjT*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/*ubjm)}(hreq_addrh]hreq_addr}(hjb*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjI)ubj)}(h u64 req_rangeh](h)}(hhh]jm)}(hu64h]hu64}(hj~*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{*ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj*modnameN classnameNjj)}j]j)c.drm_gpuvm_sm_unmap_exec_lockasbuh1hhjw*ubjV)}(h h]h }(hj*hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjw*ubjm)}(h req_rangeh]h req_range}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjw*ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjI)ubeh}(h]h ]h"]h$]h&]jjuh1jhj)hhhj")hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj )hhhj")hM ubah}(h]j)ah ](jjeh"]h$]h&]jj)jhuh1j7hj")hM hj )hhubj)}(hhh]h)}(h1locks the objects touched by drm_gpuvm_sm_unmap()h]h1locks the objects touched by drm_gpuvm_sm_unmap()}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*hhubah}(h]h ]h"]h$]h&]uh1jhj )hhhj")hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj*jj*jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``struct drm_exec *exec`` the :c:type:`drm_exec` locking context ``u64 req_addr`` the start address of the range to unmap ``u64 req_range`` the range of the mappings to unmap **Description** This function locks (drm_exec_lock_obj()) objects that will be unmapped/ remapped by drm_gpuvm_sm_unmap(). See drm_gpuvm_sm_map_exec_lock() for expected usage. **Return** 0 on success or a negative error codeh](h)}(h**Parameters**h]j)}(hj*h]h Parameters}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj+h]hstruct drm_gpuvm *gpuvm}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj+ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj.+hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj8+h]h drm_gpuvm}(hj:+hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj6+ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj*+hM hj.+ubh representing the GPU VA space}(hj.+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj*+hM hj++ubah}(h]h ]h"]h$]h&]uh1j hj+ubeh}(h]h ]h"]h$]h&]uh1jhj*+hM hj +ubj)}(hA``struct drm_exec *exec`` the :c:type:`drm_exec` locking context h](j)}(h``struct drm_exec *exec``h]j)}(hjq+h]hstruct drm_exec *exec}(hjs+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjo+ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjk+ubj )}(hhh]h)}(h&the :c:type:`drm_exec` locking contexth](hthe }(hj+hhhNhNubh)}(h:c:type:`drm_exec`h]j)}(hj+h]hdrm_exec}(hj+hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_execuh1hhj+hM hj+ubh locking context}(hj+hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj+hM hj+ubah}(h]h ]h"]h$]h&]uh1j hjk+ubeh}(h]h ]h"]h$]h&]uh1jhj+hM hj +ubj)}(h9``u64 req_addr`` the start address of the range to unmap h](j)}(h``u64 req_addr``h]j)}(hj+h]h u64 req_addr}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj+ubj )}(hhh]h)}(h'the start address of the range to unmaph]h'the start address of the range to unmap}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj+hM hj+ubah}(h]h ]h"]h$]h&]uh1j hj+ubeh}(h]h ]h"]h$]h&]uh1jhj+hM hj +ubj)}(h5``u64 req_range`` the range of the mappings to unmap h](j)}(h``u64 req_range``h]j)}(hj,h]h u64 req_range}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj,ubj )}(hhh]h)}(h"the range of the mappings to unmaph]h"the range of the mappings to unmap}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj,hM hj,ubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhj,hM hj +ubeh}(h]h ]h"]h$]h&]uh1jhj*ubh)}(h**Description**h]j)}(hjA,h]h Description}(hjC,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?,ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*ubh)}(hjThis function locks (drm_exec_lock_obj()) objects that will be unmapped/ remapped by drm_gpuvm_sm_unmap().h]hjThis function locks (drm_exec_lock_obj()) objects that will be unmapped/ remapped by drm_gpuvm_sm_unmap().}(hjW,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*ubh)}(h4See drm_gpuvm_sm_map_exec_lock() for expected usage.h]h4See drm_gpuvm_sm_map_exec_lock() for expected usage.}(hjf,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*ubh)}(h **Return**h]j)}(hjw,h]hReturn}(hjy,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhju,ubah}(h]h ]h"]h$+]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*ubh)}(h%0 on success or a negative error codeh]h%0 on success or a negative error code}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj*ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_gpuvm_sm_map_ops_create (C function)c.drm_gpuvm_sm_map_ops_createhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hqstruct drm_gpuva_ops * drm_gpuvm_sm_map_ops_create (struct drm_gpuvm *gpuvm, const struct drm_gpuvm_map_req *req)h]j>)}(hostruct drm_gpuva_ops *drm_gpuvm_sm_map_ops_create(struct drm_gpuvm *gpuvm, const struct drm_gpuvm_map_req *req)h](jD)}(hjh]hstruct}(hj,hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj,hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,hhhj,hM ubh)}(hhh]jm)}(h drm_gpuva_opsh]h drm_gpuva_ops}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj,modnameN classnameNjj)}j]j )}jdrm_gpuvm_sm_map_ops_createsbc.drm_gpuvm_sm_map_ops_createasbuh1hhj,hhhj,hM ubjV)}(h h]h }(hj,hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj,hhhj,hM ubj4)}(hj7h]h*}(hj -hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj,hhhj,hM ubjg)}(hdrm_gpuvm_sm_map_ops_createh]jm)}(hj,h]hdrm_gpuvm_sm_map_ops_create}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj,hhhj,hM ubj)}(h>(struct drm_gpuvm *gpuvm, const struct drm_gpuvm_map_req *req)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj6-hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj2-ubjV)}(h h]h }(hjC-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2-ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjT-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQ-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjV-modnameN classnameNjj)}j]j,c.drm_gpuvm_sm_map_ops_createasbuh1hhj2-ubjV)}(h h]h }(hjr-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2-ubj4)}(hj7h]h*}(hj-hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj2-ubjm)}(hgpuvmh]hgpuvm}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj2-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.-ubj)}(h#const struct drm_gpuvm_map_req *reqh](jD)}(hj h]hconst}(hj-hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj-ubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubjD)}(hjh]hstruct}(hj-hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj-ubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubh)}(hhh]jm)}(hdrm_gpuvm_map_reqh]hdrm_gpuvm_map_req}(hj-hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj-modnameN classnameNjj)}j]j,c.drm_gpuvm_sm_map_ops_createasbuh1hhj-ubjV)}(h h]h }(hj-hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj-ubj4)}(hj7h]h*}(hj .hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj-ubjm)}(hreqh]hreq}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.-ubeh}(h]h ]h"]h$]h&]jjuh1jhj,hhhj,hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj,hhhj,hM ubah}(h]j,ah ](jjeh"]h$]h&]jj)jhuh1j7hj,hM hj,hhubj)}(hhh]h)}(h6creates the :c:type:`drm_gpuva_ops` to split and mergeh](h creates the }(hjB.hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjL.h]h drm_gpuva_ops}(hjN.hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjJ.ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j,c.drm_gpuvm_sm_map_ops_createasbjM drm_gpuva_opsuh1hhjyhMhjB.ubh to split and merge}(hjB.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj?.hhubah}(h]h ]h"]h$]h&]uh1jhj,hhhj,hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj.jj.jjjuh1j2hhhj AhNhNubj)}(hXj**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``const struct drm_gpuvm_map_req *req`` map request arguments **Description** This function creates a list of operations to perform splitting and merging of existing mapping(s) with the newly requested one. The list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain map, unmap and remap operations, but it also can be empty if no operation is required, e.g. if the requested mapping already exists in the exact same way. There can be an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The latter one represents the original map operation requested by the caller. Note that before calling this function again with another mapping request it is necessary to update the :c:type:`drm_gpuvm`'s view of the GPU VA space. The previously obtained operations must be either processed or abandoned. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used. After the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`. **Return** a pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](h)}(h**Parameters**h]j)}(hj.h]h Parameters}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj.ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj.h]hstruct drm_gpuvm *gpuvm}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj.ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj.hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj.h]h drm_gpuvm}(hj.hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj.hM hj.ubh representing the GPU VA space}(hj.hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj.hM hj.ubah}(h]h ]h"]h$]h&]uh1j hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.hM hj.ubj)}(h>``const struct drm_gpuvm_map_req *req`` map request arguments h](j)}(h'``const struct drm_gpuvm_map_req *req``h]j)}(hj/h]h#const struct drm_gpuvm_map_req *req}(hj /hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj/ubj )}(hhh]h)}(hmap request argumentsh]hmap request arguments}(hj /hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/hM hj/ubah}(h]h ]h"]h$]h&]uh1j hj/ubeh}(h]h ]h"]h$]h&]uh1jhj/hM hj.ubeh}(h]h ]h"]h$]h&]uh1jhj.ubh)}(h**Description**h]j)}(hjB/h]h Description}(hjD/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@/ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj.ubh)}(hThis function creates a list of operations to perform splitting and merging of existing mapping(s) with the newly requested one.h]hThis function creates a list of operations to perform splitting and merging of existing mapping(s) with the newly requested one.}(hjX/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj.ubh)}(hXThe list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain map, unmap and remap operations, but it also can be empty if no operation is required, e.g. if the requested mapping already exists in the exact same way.h](hThe list can be iterated with }(hjg/hhhNhNubh)}(h:c:type:`drm_gpuva_for_each_op`h]j)}(hjq/h]hdrm_gpuva_for_each_op}(hjs/hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjo/ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_for_each_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjg/ubh and must be processed in the given order. It can contain map, unmap and remap operations, but it also can be empty if no operation is required, e.g. if the requested mapping already exists in the exact same way.}(hjg/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj/hM hj.ubh)}(hThere can be an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The latter one represents the original map operation requested by the caller.h]hThere can be an arbitrary amount of unmap operations, a maximum of two remap operations and a single map operation. The latter one represents the original map operation requested by the caller.}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj.ubh)}(hXNote that before calling this function again with another mapping request it is necessary to update the :c:type:`drm_gpuvm`'s view of the GPU VA space. The previously obtained operations must be either processed or abandoned. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.h](hhNote that before calling this function again with another mapping request it is necessary to update the }(hj/hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj/h]h drm_gpuvm}(hj/hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj/ubhw’s view of the GPU VA space. The previously obtained operations must be either processed or abandoned. To update the }(hj/hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj/h]h drm_gpuvm}(hj/hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj/hM hj/ubh’s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.}(hj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj/hM hj.ubh)}(hAfter the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`.h](h2After the caller finished processing the returned }(hj/hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj0h]h drm_gpuva_ops}(hj 0hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj/ubh, they must be freed with }(hj/hhhNhNubh)}(h:c:type:`drm_gpuva_ops_free`h]j)}(hj+0h]hdrm_gpuva_ops_free}(hj-0hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj)0ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_ops_freeuh1hhj$0hM hj/ubh.}(hj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$0hM hj.ubh)}(h **Return**h]j)}(hjT0h]hReturn}(hjV0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR0ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj.ubh)}(hJa pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](ha pointer to the }(hjj0hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjt0h]h drm_gpuva_ops}(hjv0hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjr0ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjj0ubh" on success, an ERR_PTR on failure}(hjj0hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj0hM hj.ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_gpuvm_madvise_ops_create (C function)c.drm_gpuvm_madvise_ops_createhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hrstruct drm_gpuva_ops * drm_gpuvm_madvise_ops_create (struct drm_gpuvm *gpuvm, const struct drm_gpuvm_map_req *req)h]j>)}(hpstruct drm_gpuva_ops *drm_gpuvm_madvise_ops_create(struct drm_gpuvm *gpuvm, const struct drm_gpuvm_map_req *req)h](jD)}(hjh]hstruct}(hj0hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj0hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0hhhj0hM ubh)}(hhh]jm)}(h drm_gpuva_opsh]h drm_gpuva_ops}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]j )}jdrm_gpuvm_madvise_ops_createsbc.drm_gpuvm_madvise_ops_createasbuh1hhj0hhhj0hM ubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj0hhhj0hM ubj4)}(hj7h]h*}(hj 1hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj0hhhj0hM ubjg)}(hdrm_gpuvm_madvise_ops_createh]jm)}(hj0h]hdrm_gpuvm_madvise_ops_create}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj0hhhj0hM ubj)}(h>(struct drm_gpuvm *gpuvm, const struct drm_gpuvm_map_req *req)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj61hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj21ubjV)}(h h]h }(hjC1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj21ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjT1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQ1ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjV1modnameN classnameNjj)}j]j0c.drm_gpuvm_madvise_ops_createasbuh1hhj21ubjV)}(h h]h }(hjr1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj21ubj4)}(hj7h]h*}(hj1hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj21ubjm)}(hgpuvmh]hgpuvm}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj21ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.1ubj)}(h#const struct drm_gpuvm_map_req *reqh](jD)}(hj h]hconst}(hj1hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj1ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubjD)}(hjh]hstruct}(hj1hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj1ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubh)}(hhh]jm)}(hdrm_gpuvm_map_reqh]hdrm_gpuvm_map_req}(hj1hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]j0c.drm_gpuvm_madvise_ops_createasbuh1hhj1ubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj1ubj4)}(hj7h]h*}(hj 2hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj1ubjm)}(hreqh]hreq}(hj2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.1ubeh}(h]h ]h"]h$]h&]jjuh1jhj0hhhj0hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj0hhhj0hM ubah}(h]j0ah ](jjeh"]h$]h&]jj)jhuh1j7hj0hM hj0hhubj)}(hhh]h)}(h,creates the :c:type:`drm_gpuva_ops` to splith](h creates the }(hjB2hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjL2h]h drm_gpuva_ops}(hjN2hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjJ2ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j0c.drm_gpuvm_madvise_ops_createasbjM drm_gpuva_opsuh1hhjyhMhjB2ubh to split}(hjB2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj?2hhubah}(h]h ]h"]h$]h&]uh1jhj0hhhj0hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj2jj2jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``const struct drm_gpuvm_map_req *req`` map request arguments **Description** This function creates a list of operations to perform splitting of existent mapping(s) at start or end, based on the request map. The list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain map and remap operations, but it also can be empty if no operation is required, e.g. if the requested mapping already exists is the exact same way. There will be no unmap operations, a maximum of two remap operations and two map operations. The two map operations correspond to: one from start to the end of drm_gpuvaX, and another from the start of drm_gpuvaY to end. Note that before calling this function again with another mapping request it is necessary to update the :c:type:`drm_gpuvm`'s view of the GPU VA space. The previously obtained operations must be either processed or abandoned. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used. After the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`. **Return** a pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](h)}(h**Parameters**h]j)}(hj2h]h Parameters}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj2ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj2h]hstruct drm_gpuvm *gpuvm}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj2ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj2hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj2h]h drm_gpuvm}(hj2hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj2hM hj2ubh representing the GPU VA space}(hj2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj2hM hj2ubah}(h]h ]h"]h$]h&]uh1j hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2hM hj2ubj)}(h>``const struct drm_gpuvm_map_req *req`` map request arguments h](j)}(h'``const struct drm_gpuvm_map_req *req``h]j)}(hj3h]h#const struct drm_gpuvm_map_req *req}(hj 3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj3ubj )}(hhh]h)}(hmap request argumentsh]hmap request arguments}(hj 3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj3hM hj3ubah}(h]h ]h"]h$]h&]uh1j hj3ubeh}(h]h ]h"]h$]h&]uh1jhj3hM hj2ubeh}(h]h ]h"]h$]h&]uh1jhj2ubh)}(h**Description**h]j)}(hjB3h]h Description}(hjD3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@3ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj2ubh)}(hThis function creates a list of operations to perform splitting of existent mapping(s) at start or end, based on the request map.h]hThis function creates a list of operations to perform splitting of existent mapping(s) at start or end, based on the request map.}(hjX3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj2ubh)}(hX The list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain map and remap operations, but it also can be empty if no operation is required, e.g. if the requested mapping already exists is the exact same way.h](hThe list can be iterated with }(hjg3hhhNhNubh)}(h:c:type:`drm_gpuva_for_each_op`h]j)}(hjq3h]hdrm_gpuva_for_each_op}(hjs3hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjo3ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_for_each_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjg3ubh and must be processed in the given order. It can contain map and remap operations, but it also can be empty if no operation is required, e.g. if the requested mapping already exists is the exact same way.}(hjg3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj3hM hj2ubh)}(hThere will be no unmap operations, a maximum of two remap operations and two map operations. The two map operations correspond to: one from start to the end of drm_gpuvaX, and another from the start of drm_gpuvaY to end.h]hThere will be no unmap operations, a maximum of two remap operations and two map operations. The two map operations correspond to: one from start to the end of drm_gpuvaX, and another from the start of drm_gpuvaY to end.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj2ubh)}(hXNote that before calling this function again with another mapping request it is necessary to update the :c:type:`drm_gpuvm`'s view of the GPU VA space. The previously obtained operations must be either processed or abandoned. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.h](hhNote that before calling this function again with another mapping request it is necessary to update the }(hj3hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj3h]h drm_gpuvm}(hj3hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj3ubhw’s view of the GPU VA space. The previously obtained operations must be either processed or abandoned. To update the }(hj3hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj3h]h drm_gpuvm}(hj3hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj3ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj3hM hj3ubh’s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj3hM hj2ubh)}(hAfter the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`.h](h2After the caller finished processing the returned }(hj3hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj4h]h drm_gpuva_ops}(hj 4hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj3ubh, they must be freed with }(hj3hhhNhNubh)}(h:c:type:`drm_gpuva_ops_free`h]j)}(hj+4h]hdrm_gpuva_ops_free}(hj-4hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj)4ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_ops_freeuh1hhj$4hM hj3ubh.}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj$4hM hj2ubh)}(h **Return**h]j)}(hjT4h]hReturn}(hjV4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjR4ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj2ubh)}(hJa pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](ha pointer to the }(hjj4hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjt4h]h drm_gpuva_ops}(hjv4hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjr4ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjj4ubh" on success, an ERR_PTR on failure}(hjj4hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj4hM hj2ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gpuvm_sm_unmap_ops_create (C function)c.drm_gpuvm_sm_unmap_ops_createhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hkstruct drm_gpuva_ops * drm_gpuvm_sm_unmap_ops_create (struct drm_gpuvm *gpuvm, u64 req_addr, u64 req_range)h]j>)}(histruct drm_gpuva_ops *drm_gpuvm_sm_unmap_ops_create(struct drm_gpuvm *gpuvm, u64 req_addr, u64 req_range)h](jD)}(hjh]hstruct}(hj4hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hj4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4hhhj4hM ubh)}(hhh]jm)}(h drm_gpuva_opsh]h drm_gpuva_ops}(hj4hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj4modnameN classnameNjj)}j]j )}jdrm_gpuvm_sm_unmap_ops_createsbc.drm_gpuvm_sm_unmap_ops_createasbuh1hhj4hhhj4hM ubjV)}(h h]h }(hj4hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4hhhj4hM ubj4)}(hj7h]h*}(hj 5hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj4hhhj4hM ubjg)}(hdrm_gpuvm_sm_unmap_ops_createh]jm)}(hj4h]hdrm_gpuvm_sm_unmap_ops_create}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj4hhhj4hM ubj)}(h6(struct drm_gpuvm *gpuvm, u64 req_addr, u64 req_range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj65hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj25ubjV)}(h h]h }(hjC5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj25ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hjT5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQ5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjV5modnameN classnameNjj)}j]j4c.drm_gpuvm_sm_unmap_ops_createasbuh1hhj25ubjV)}(h h]h }(hjr5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj25ubj4)}(hj7h]h*}(hj5hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj25ubjm)}(hgpuvmh]hgpuvm}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj25ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.5ubj)}(h u64 req_addrh](h)}(hhh]jm)}(hu64h]hu64}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j4c.drm_gpuvm_sm_unmap_ops_createasbuh1hhj5ubjV)}(h h]h }(hj5hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubjm)}(hreq_addrh]hreq_addr}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.5ubj)}(h u64 req_rangeh](h)}(hhh]jm)}(hu64h]hu64}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j4c.drm_gpuvm_sm_unmap_ops_createasbuh1hhj5ubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj5ubjm)}(h req_rangeh]h req_range}(hj6hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj.5ubeh}(h]h ]h"]h$]h&]jjuh1jhj4hhhj4hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj4hhhj4hM ubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1j7hj4hM hj4hhubj)}(hhh]h)}(h5creates the :c:type:`drm_gpuva_ops` to split on unmaph](h creates the }(hjG6hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjQ6h]h drm_gpuva_ops}(hjS6hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjO6ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j4c.drm_gpuvm_sm_unmap_ops_createasbjM drm_gpuva_opsuh1hhjyhMhjG6ubh to split on unmap}(hjG6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjD6hhubah}(h]h ]h"]h$]h&]uh1jhj4hhhj4hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj6jj6jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``u64 req_addr`` the start address of the range to unmap ``u64 req_range`` the range of the mappings to unmap **Description** This function creates a list of operations to perform unmapping and, if required, splitting of the mappings overlapping the unmap range. The list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain unmap and remap operations, depending on whether there are actual overlapping mappings to split. There can be an arbitrary amount of unmap operations and a maximum of two remap operations. Note that before calling this function again with another range to unmap it is necessary to update the :c:type:`drm_gpuvm`'s view of the GPU VA space. The previously obtained operations must be processed or abandoned. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used. After the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`. **Return** a pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](h)}(h**Parameters**h]j)}(hj6h]h Parameters}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj6ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj6h]hstruct drm_gpuvm *gpuvm}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj6ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj6hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj6h]h drm_gpuvm}(hj6hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj6ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj6hM hj6ubh representing the GPU VA space}(hj6hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj6hM hj6ubah}(h]h ]h"]h$]h&]uh1j hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6hM hj6ubj)}(h9``u64 req_addr`` the start address of the range to unmap h](j)}(h``u64 req_addr``h]j)}(hj 7h]h u64 req_addr}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj 7ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj7ubj )}(hhh]h)}(h'the start address of the range to unmaph]h'the start address of the range to unmap}(hj%7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!7hM hj"7ubah}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhj!7hM hj6ubj)}(h5``u64 req_range`` the range of the mappings to unmap h](j)}(h``u64 req_range``h]j)}(hjE7h]h u64 req_range}(hjG7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjC7ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj?7ubj )}(hhh]h)}(h"the range of the mappings to unmaph]h"the range of the mappings to unmap}(hj^7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZ7hM hj[7ubah}(h]h ]h"]h$]h&]uh1j hj?7ubeh}(h]h ]h"]h$]h&]uh1jhjZ7hM hj6ubeh}(h]h ]h"]h$]h&]uh1jhj6ubh)}(h**Description**h]j)}(hj7h]h Description}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~7ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj6ubh)}(hThis function creates a list of operations to perform unmapping and, if required, splitting of the mappings overlapping the unmap range.h]hThis function creates a list of operations to perform unmapping and, if required, splitting of the mappings overlapping the unmap range.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj6ubh)}(hThe list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain unmap and remap operations, depending on whether there are actual overlapping mappings to split.h](hThe list can be iterated with }(hj7hhhNhNubh)}(h:c:type:`drm_gpuva_for_each_op`h]j)}(hj7h]hdrm_gpuva_for_each_op}(hj7hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_for_each_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj7ubh and must be processed in the given order. It can contain unmap and remap operations, depending on whether there are actual overlapping mappings to split.}(hj7hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj7hM hj6ubh)}(h[There can be an arbitrary amount of unmap operations and a maximum of two remap operations.h]h[There can be an arbitrary amount of unmap operations and a maximum of two remap operations.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj6ubh)}(hXyNote that before calling this function again with another range to unmap it is necessary to update the :c:type:`drm_gpuvm`'s view of the GPU VA space. The previously obtained operations must be processed or abandoned. To update the :c:type:`drm_gpuvm`'s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.h](hgNote that before calling this function again with another range to unmap it is necessary to update the }(hj7hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj7h]h drm_gpuvm}(hj7hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj7ubhp’s view of the GPU VA space. The previously obtained operations must be processed or abandoned. To update the }(hj7hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj8h]h drm_gpuvm}(hj8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj 8hM hj7ubh’s view of the GPU VA space drm_gpuva_insert(), drm_gpuva_destroy_locked() and/or drm_gpuva_destroy_unlocked() should be used.}(hj7hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj 8hM hj6ubh)}(hAfter the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`.h](h2After the caller finished processing the returned }(hj;8hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjE8h]h drm_gpuva_ops}(hjG8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjC8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj;8ubh, they must be freed with }(hj;8hhhNhNubh)}(h:c:type:`drm_gpuva_ops_free`h]j)}(hji8h]hdrm_gpuva_ops_free}(hjk8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjg8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_ops_freeuh1hhjb8hM hj;8ubh.}(hj;8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjb8hM hj6ubh)}(h **Return**h]j)}(hj8h]hReturn}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj6ubh)}(hJa pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](ha pointer to the }(hj8hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj8h]h drm_gpuva_ops}(hj8hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj8ubh" on success, an ERR_PTR on failure}(hj8hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hM hj6ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gpuvm_prefetch_ops_create (C function)c.drm_gpuvm_prefetch_ops_createhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hcstruct drm_gpuva_ops * drm_gpuvm_prefetch_ops_create (struct drm_gpuvm *gpuvm, u64 addr, u64 range)h]j>)}(hastruct drm_gpuva_ops *drm_gpuvm_prefetch_ops_create(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](jD)}(hjh]hstruct}(hj8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj8hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM" ubjV)}(h h]h }(hj9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8hhhj9hM" ubh)}(hhh]jm)}(h drm_gpuva_opsh]h drm_gpuva_ops}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj9modnameN classnameNjj)}j]j )}jdrm_gpuvm_prefetch_ops_createsbc.drm_gpuvm_prefetch_ops_createasbuh1hhj8hhhj9hM" ubjV)}(h h]h }(hj:9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj8hhhj9hM" ubj4)}(hj7h]h*}(hjH9hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj8hhhj9hM" ubjg)}(hdrm_gpuvm_prefetch_ops_createh]jm)}(hj79h]hdrm_gpuvm_prefetch_ops_create}(hjY9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjU9ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj8hhhj9hM" ubj)}(h.(struct drm_gpuvm *gpuvm, u64 addr, u64 range)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hjt9hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjp9ubjV)}(h h]h }(hj9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjp9ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj9modnameN classnameNjj)}j]j59c.drm_gpuvm_prefetch_ops_createasbuh1hhjp9ubjV)}(h h]h }(hj9hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjp9ubj4)}(hj7h]h*}(hj9hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjp9ubjm)}(hgpuvmh]hgpuvm}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjp9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjl9ubj)}(hu64 addrh](h)}(hhh]jm)}(hu64h]hu64}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj9modnameN classnameNjj)}j]j59c.drm_gpuvm_prefetch_ops_createasbuh1hhj9ubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj9ubjm)}(haddrh]haddr}(hj:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjl9ubj)}(h u64 rangeh](h)}(hhh]jm)}(hu64h]hu64}(hj/:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,:ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1:modnameN classnameNjj)}j]j59c.drm_gpuvm_prefetch_ops_createasbuh1hhj(:ubjV)}(h h]h }(hjM:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj(:ubjm)}(hrangeh]hrange}(hj[:hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj(:ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjl9ubeh}(h]h ]h"]h$]h&]jjuh1jhj8hhhj9hM" ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj8hhhj9hM" ubah}(h]j8ah ](jjeh"]h$]h&]jj)jhuh1j7hj9hM" hj8hhubj)}(hhh]h)}(h/creates the :c:type:`drm_gpuva_ops` to prefetchh](h creates the }(hj:hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj:h]h drm_gpuva_ops}(hj:hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j59c.drm_gpuvm_prefetch_ops_createasbjM drm_gpuva_opsuh1hhjyhMhj:ubh to prefetch}(hj:hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM" hj:hhubah}(h]h ]h"]h$]h&]uh1jhj8hhhj9hM" ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj:jj:jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space ``u64 addr`` the start address of the range to prefetch ``u64 range`` the range of the mappings to prefetch **Description** This function creates a list of operations to perform prefetching. The list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain prefetch operations. There can be an arbitrary amount of prefetch operations. After the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`. **Return** a pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](h)}(h**Parameters**h]j)}(hj:h]h Parameters}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM& hj:ubj)}(hhh](j)}(hR``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` representing the GPU VA space h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj:h]hstruct drm_gpuvm *gpuvm}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj:ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM# hj:ubj )}(hhh]h)}(h5the :c:type:`drm_gpuvm` representing the GPU VA spaceh](hthe }(hj;hhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hj;h]h drm_gpuvm}(hj;hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhj;hM# hj;ubh representing the GPU VA space}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj;hM# hj;ubah}(h]h ]h"]h$]h&]uh1j hj:ubeh}(h]h ]h"]h$]h&]uh1jhj;hM# hj:ubj)}(h8``u64 addr`` the start address of the range to prefetch h](j)}(h ``u64 addr``h]j)}(hjJ;h]hu64 addr}(hjL;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjH;ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM$ hjD;ubj )}(hhh]h)}(h*the start address of the range to prefetchh]h*the start address of the range to prefetch}(hjc;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_;hM$ hj`;ubah}(h]h ]h"]h$]h&]uh1j hjD;ubeh}(h]h ]h"]h$]h&]uh1jhj_;hM$ hj:ubj)}(h4``u64 range`` the range of the mappings to prefetch h](j)}(h ``u64 range``h]j)}(hj;h]h u64 range}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM% hj};ubj )}(hhh]h)}(h%the range of the mappings to prefetchh]h%the range of the mappings to prefetch}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hM% hj;ubah}(h]h ]h"]h$]h&]uh1j hj};ubeh}(h]h ]h"]h$]h&]uh1jhj;hM% hj:ubeh}(h]h ]h"]h$]h&]uh1jhj:ubh)}(h**Description**h]j)}(hj;h]h Description}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM' hj:ubh)}(hBThis function creates a list of operations to perform prefetching.h]hBThis function creates a list of operations to perform prefetching.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM& hj:ubh)}(hThe list can be iterated with :c:type:`drm_gpuva_for_each_op` and must be processed in the given order. It can contain prefetch operations.h](hThe list can be iterated with }(hj;hhhNhNubh)}(h:c:type:`drm_gpuva_for_each_op`h]j)}(hj;h]hdrm_gpuva_for_each_op}(hj;hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_for_each_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM( hj;ubhN and must be processed in the given order. It can contain prefetch operations.}(hj;hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj <hM( hj:ubh)}(h8There can be an arbitrary amount of prefetch operations.h]h8There can be an arbitrary amount of prefetch operations.}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM+ hj:ubh)}(hAfter the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`.h](h2After the caller finished processing the returned }(hj$<hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj.<h]h drm_gpuva_ops}(hj0<hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj,<ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM- hj$<ubh, they must be freed with }(hj$<hhhNhNubh)}(h:c:type:`drm_gpuva_ops_free`h]j)}(hjR<h]hdrm_gpuva_ops_free}(hjT<hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjP<ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_ops_freeuh1hhjK<hM- hj$<ubh.}(hj$<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjK<hM- hj:ubh)}(h **Return**h]j)}(hj{<h]hReturn}(hj}<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjy<ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM0 hj:ubh)}(hJa pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](ha pointer to the }(hj<hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj<h]h drm_gpuva_ops}(hj<hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM1 hj<ubh" on success, an ERR_PTR on failure}(hj<hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj<hM1 hj:ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_gpuvm_bo_unmap_ops_create (C function)c.drm_gpuvm_bo_unmap_ops_createhNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hQstruct drm_gpuva_ops * drm_gpuvm_bo_unmap_ops_create (struct drm_gpuvm_bo *vm_bo)h]j>)}(hOstruct drm_gpuva_ops *drm_gpuvm_bo_unmap_ops_create(struct drm_gpuvm_bo *vm_bo)h](jD)}(hjh]hstruct}(hj<hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj<hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMX ubjV)}(h h]h }(hj<hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<hhhj<hMX ubh)}(hhh]jm)}(h drm_gpuva_opsh]h drm_gpuva_ops}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj<ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj=modnameN classnameNjj)}j]j )}jdrm_gpuvm_bo_unmap_ops_createsbc.drm_gpuvm_bo_unmap_ops_createasbuh1hhj<hhhj<hMX ubjV)}(h h]h }(hj#=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj<hhhj<hMX ubj4)}(hj7h]h*}(hj1=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj<hhhj<hMX ubjg)}(hdrm_gpuvm_bo_unmap_ops_createh]jm)}(hj =h]hdrm_gpuvm_bo_unmap_ops_create}(hjB=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>=ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj<hhhj<hMX ubj)}(h(struct drm_gpuvm_bo *vm_bo)h]j)}(hstruct drm_gpuvm_bo *vm_boh](jD)}(hjh]hstruct}(hj]=hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjY=ubjV)}(h h]h }(hjj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjY=ubh)}(hhh]jm)}(h drm_gpuvm_boh]h drm_gpuvm_bo}(hj{=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjx=ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj}=modnameN classnameNjj)}j]j=c.drm_gpuvm_bo_unmap_ops_createasbuh1hhjY=ubjV)}(h h]h }(hj=hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjY=ubj4)}(hj7h]h*}(hj=hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjY=ubjm)}(hvm_boh]hvm_bo}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjY=ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjU=ubah}(h]h ]h"]h$]h&]jjuh1jhj<hhhj<hMX ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj<hhhj<hMX ubah}(h]j<ah ](jjeh"]h$]h&]jj)jhuh1j7hj<hMX hj<hhubj)}(hhh]h)}(h2creates the :c:type:`drm_gpuva_ops` to unmap a GEMh](h creates the }(hj=hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj=h]h drm_gpuva_ops}(hj=hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]j=c.drm_gpuvm_bo_unmap_ops_createasbjM drm_gpuva_opsuh1hhjyhMhj=ubh to unmap a GEM}(hj=hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMX hj=hhubah}(h]h ]h"]h$]h&]uh1jhj<hhhj<hMX ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj>jj>jjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` abstraction **Description** This function creates a list of operations to perform unmapping for every GPUVA attached to a GEM. The list can be iterated with :c:type:`drm_gpuva_for_each_op` and consists out of an arbitrary amount of unmap operations. After the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`. This function expects the caller to protect the GEM's GPUVA list against concurrent access using either the GEM's dma-resv or gpuva.lock mutex. **Return** a pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](h)}(h**Parameters**h]j)}(hj(>h]h Parameters}(hj*>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&>ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM\ hj">ubj)}(hhh]j)}(hF``struct drm_gpuvm_bo *vm_bo`` the :c:type:`drm_gpuvm_bo` abstraction h](j)}(h``struct drm_gpuvm_bo *vm_bo``h]j)}(hjG>h]hstruct drm_gpuvm_bo *vm_bo}(hjI>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjE>ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMY hjA>ubj )}(hhh]h)}(h&the :c:type:`drm_gpuvm_bo` abstractionh](hthe }(hj`>hhhNhNubh)}(h:c:type:`drm_gpuvm_bo`h]j)}(hjj>h]h drm_gpuvm_bo}(hjl>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjh>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvm_bouh1hhj\>hMY hj`>ubh abstraction}(hj`>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj\>hMY hj]>ubah}(h]h ]h"]h$]h&]uh1j hjA>ubeh}(h]h ]h"]h$]h&]uh1jhj\>hMY hj>>ubah}(h]h ]h"]h$]h&]uh1jhj">ubh)}(h**Description**h]j)}(hj>h]h Description}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM[ hj">ubh)}(hbThis function creates a list of operations to perform unmapping for every GPUVA attached to a GEM.h]hbThis function creates a list of operations to perform unmapping for every GPUVA attached to a GEM.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMZ hj">ubh)}(hzThe list can be iterated with :c:type:`drm_gpuva_for_each_op` and consists out of an arbitrary amount of unmap operations.h](hThe list can be iterated with }(hj>hhhNhNubh)}(h:c:type:`drm_gpuva_for_each_op`h]j)}(hj>h]hdrm_gpuva_for_each_op}(hj>hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_for_each_opuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM] hj>ubh= and consists out of an arbitrary amount of unmap operations.}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj>hM] hj">ubh)}(hAfter the caller finished processing the returned :c:type:`drm_gpuva_ops`, they must be freed with :c:type:`drm_gpuva_ops_free`.h](h2After the caller finished processing the returned }(hj>hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj?h]h drm_gpuva_ops}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM` hj>ubh, they must be freed with }(hj>hhhNhNubh)}(h:c:type:`drm_gpuva_ops_free`h]j)}(hj*?h]hdrm_gpuva_ops_free}(hj,?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj(?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpuva_ops_freeuh1hhj#?hM` hj>ubh.}(hj>hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj#?hM` hj">ubh)}(hThis function expects the caller to protect the GEM's GPUVA list against concurrent access using either the GEM's dma-resv or gpuva.lock mutex.h]hThis function expects the caller to protect the GEM’s GPUVA list against concurrent access using either the GEM’s dma-resv or gpuva.lock mutex.}(hjQ?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMc hj">ubh)}(h **Return**h]j)}(hjb?h]hReturn}(hjd?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`?ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMf hj">ubh)}(hJa pointer to the :c:type:`drm_gpuva_ops` on success, an ERR_PTR on failureh](ha pointer to the }(hjx?hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj?h]h drm_gpuva_ops}(hj?hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chMg hjx?ubh" on success, an ERR_PTR on failure}(hjx?hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj?hMg hj">ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpuva_ops_free (C function)c.drm_gpuva_ops_freehNtauh1j!hj AhhhNhNubj3)}(hhh](j8)}(hLvoid drm_gpuva_ops_free (struct drm_gpuvm *gpuvm, struct drm_gpuva_ops *ops)h]j>)}(hKvoid drm_gpuva_ops_free(struct drm_gpuvm *gpuvm, struct drm_gpuva_ops *ops)h](j)}(hvoidh]hvoid}(hj?hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj?hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM ubjV)}(h h]h }(hj?hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?hhhj?hM ubjg)}(hdrm_gpuva_ops_freeh]jm)}(hdrm_gpuva_ops_freeh]hdrm_gpuva_ops_free}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj?hhhj?hM ubj)}(h4(struct drm_gpuvm *gpuvm, struct drm_gpuva_ops *ops)h](j)}(hstruct drm_gpuvm *gpuvmh](jD)}(hjh]hstruct}(hj@hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj@ubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubh)}(hhh]jm)}(h drm_gpuvmh]h drm_gpuvm}(hj%@hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"@ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj'@modnameN classnameNjj)}j]j )}jj?sbc.drm_gpuva_ops_freeasbuh1hhj@ubjV)}(h h]h }(hjE@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubj4)}(hj7h]h*}(hjS@hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj@ubjm)}(hgpuvmh]hgpuvm}(hj`@hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubj)}(hstruct drm_gpuva_ops *opsh](jD)}(hjh]hstruct}(hjy@hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChju@ubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhju@ubh)}(hhh]jm)}(h drm_gpuva_opsh]h drm_gpuva_ops}(hj@hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj@modnameN classnameNjj)}j]jA@c.drm_gpuva_ops_freeasbuh1hhju@ubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhju@ubj4)}(hj7h]h*}(hj@hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hju@ubjm)}(hopsh]hops}(hj@hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhju@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubeh}(h]h ]h"]h$]h&]jjuh1jhj?hhhj?hM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj?hhhj?hM ubah}(h]j?ah ](jjeh"]h$]h&]jj)jhuh1j7hj?hM hj?hhubj)}(hhh]h)}(h&free the given :c:type:`drm_gpuva_ops`h](hfree the given }(hj@hhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjAh]h drm_gpuva_ops}(hjAhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjj)}j]jA@c.drm_gpuva_ops_freeasbjM drm_gpuva_opsuh1hhjyhMhj@ubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj@hhubah}(h]h ]h"]h$]h&]uh1jhj?hhhj?hM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj6Ajj6Ajjjuh1j2hhhj AhNhNubj)}(hX**Parameters** ``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` the ops were created for ``struct drm_gpuva_ops *ops`` the :c:type:`drm_gpuva_ops` to free **Description** Frees the given :c:type:`drm_gpuva_ops` structure including all the ops associated with it.h](h)}(h**Parameters**h]j)}(hj@Ah]h Parameters}(hjBAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>Aubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj:Aubj)}(hhh](j)}(hM``struct drm_gpuvm *gpuvm`` the :c:type:`drm_gpuvm` the ops were created for h](j)}(h``struct drm_gpuvm *gpuvm``h]j)}(hj_Ah]hstruct drm_gpuvm *gpuvm}(hjaAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]Aubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjYAubj )}(hhh]h)}(h0the :c:type:`drm_gpuvm` the ops were created forh](hthe }(hjxAhhhNhNubh)}(h:c:type:`drm_gpuvm`h]j)}(hjAh]h drm_gpuvm}(hjAhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuvmuh1hhjtAhM hjxAubh the ops were created for}(hjxAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjtAhM hjuAubah}(h]h ]h"]h$]h&]uh1j hjYAubeh}(h]h ]h"]h$]h&]uh1jhjtAhM hjVAubj)}(hB``struct drm_gpuva_ops *ops`` the :c:type:`drm_gpuva_ops` to free h](j)}(h``struct drm_gpuva_ops *ops``h]j)}(hjAh]hstruct drm_gpuva_ops *ops}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hjAubj )}(hhh]h)}(h#the :c:type:`drm_gpuva_ops` to freeh](hthe }(hjAhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hjAh]h drm_gpuva_ops}(hjAhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjAubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhjAhM hjAubh to free}(hjAhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjAhM hjAubah}(h]h ]h"]h$]h&]uh1j hjAubeh}(h]h ]h"]h$]h&]uh1jhjAhM hjVAubeh}(h]h ]h"]h$]h&]uh1jhj:Aubh)}(h**Description**h]j)}(hjBh]h Description}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj:Aubh)}(h[Frees the given :c:type:`drm_gpuva_ops` structure including all the ops associated with it.h](hFrees the given }(hj/BhhhNhNubh)}(h:c:type:`drm_gpuva_ops`h]j)}(hj9Bh]h drm_gpuva_ops}(hj;BhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj7Bubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_gpuva_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:523: ./drivers/gpu/drm/drm_gpuvm.chM hj/Bubh4 structure including all the ops associated with it.}(hj/BhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjVBhM hj:Aubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj AhhhNhNubeh}(h]drm-gpuvm-function-referencesah ]h"]drm gpuvm function referencesah$]h&]uh1hhj0hhhhhMubeh}(h](j0id2eh ]h"]( drm gpuvm drm_gpuvmeh$]h&]uh1hhhhhhhhMj}jvBj0sj}j0j0subh)}(hhh](h)}(hDRM Buddy Allocatorh]hDRM Buddy Allocator}(hj~BhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj{BhhhhhMubh)}(hhh](h)}(hDRM Buddy Function Referencesh]hDRM Buddy Function References}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjBhhhhhMubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_buddy_init (C function)c.drm_buddy_inithNtauh1j!hjBhhhNhNubj3)}(hhh](j8)}(hCint drm_buddy_init (struct drm_buddy *mm, u64 size, u64 chunk_size)h]j>)}(hBint drm_buddy_init(struct drm_buddy *mm, u64 size, u64 chunk_size)h](j)}(hinth]hint}(hjBhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjBhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM ubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBhhhjBhM ubjg)}(hdrm_buddy_inith]jm)}(hdrm_buddy_inith]hdrm_buddy_init}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjBhhhjBhM ubj)}(h0(struct drm_buddy *mm, u64 size, u64 chunk_size)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjBubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjCmodnameN classnameNjj)}j]j )}jjBsbc.drm_buddy_initasbuh1hhjBubjV)}(h h]h }(hj1ChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBubj4)}(hj7h]h*}(hj?ChhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjBubjm)}(hmmh]hmm}(hjLChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjhChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeCubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjCmodnameN classnameNjj)}j]j-Cc.drm_buddy_initasbuh1hhjaCubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjaCubjm)}(hsizeh]hsize}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjaCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubj)}(hu64 chunk_sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjCmodnameN classnameNjj)}j]j-Cc.drm_buddy_initasbuh1hhjCubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubjm)}(h chunk_sizeh]h chunk_size}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubeh}(h]h ]h"]h$]h&]jjuh1jhjBhhhjBhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjBhhhjBhM ubah}(h]jBah ](jjeh"]h$]h&]jj)jhuh1j7hjBhM hjBhhubj)}(hhh]h)}(hinit memory managerh]hinit memory manager}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM hjDhhubah}(h]h ]h"]h$]h&]uh1jhjBhhhjBhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjDjjDjjjuh1j2hhhjBhNhNubj)}(hX-**Parameters** ``struct drm_buddy *mm`` DRM buddy manager to initialize ``u64 size`` size in bytes to manage ``u64 chunk_size`` minimum page size in bytes for our allocations **Description** Initializes the memory manager and its resources. **Return** 0 on success, error code on failure.h](h)}(h**Parameters**h]j)}(hj(Dh]h Parameters}(hj*DhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&Dubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM$hj"Dubj)}(hhh](j)}(h9``struct drm_buddy *mm`` DRM buddy manager to initialize h](j)}(h``struct drm_buddy *mm``h]j)}(hjGDh]hstruct drm_buddy *mm}(hjIDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEDubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM"hjADubj )}(hhh]h)}(hDRM buddy manager to initializeh]hDRM buddy manager to initialize}(hj`DhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj\DhM"hj]Dubah}(h]h ]h"]h$]h&]uh1j hjADubeh}(h]h ]h"]h$]h&]uh1jhj\DhM"hj>Dubj)}(h%``u64 size`` size in bytes to manage h](j)}(h ``u64 size``h]j)}(hjDh]hu64 size}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~Dubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM#hjzDubj )}(hhh]h)}(hsize in bytes to manageh]hsize in bytes to manage}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhM#hjDubah}(h]h ]h"]h$]h&]uh1j hjzDubeh}(h]h ]h"]h$]h&]uh1jhjDhM#hj>Dubj)}(hB``u64 chunk_size`` minimum page size in bytes for our allocations h](j)}(h``u64 chunk_size``h]j)}(hjDh]hu64 chunk_size}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM$hjDubj )}(hhh]h)}(h.minimum page size in bytes for our allocationsh]h.minimum page size in bytes for our allocations}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjDhM$hjDubah}(h]h ]h"]h$]h&]uh1j hjDubeh}(h]h ]h"]h$]h&]uh1jhjDhM$hj>Dubeh}(h]h ]h"]h$]h&]uh1jhj"Dubh)}(h**Description**h]j)}(hjDh]h Description}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM&hj"Dubh)}(h1Initializes the memory manager and its resources.h]h1Initializes the memory manager and its resources.}(hj EhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM%hj"Dubh)}(h **Return**h]j)}(hjEh]hReturn}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM'hj"Dubh)}(h$0 on success, error code on failure.h]h$0 on success, error code on failure.}(hj1EhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM(hj"Dubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjBhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_buddy_fini (C function)c.drm_buddy_finihNtauh1j!hjBhhhNhNubj3)}(hhh](j8)}(h*void drm_buddy_fini (struct drm_buddy *mm)h]j>)}(h)void drm_buddy_fini(struct drm_buddy *mm)h](j)}(hvoidh]hvoid}(hj`EhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\EhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMubjV)}(h h]h }(hjoEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\EhhhjnEhMubjg)}(hdrm_buddy_finih]jm)}(hdrm_buddy_finih]hdrm_buddy_fini}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}Eubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj\EhhhjnEhMubj)}(h(struct drm_buddy *mm)h]j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjEhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjEubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjEmodnameN classnameNjj)}j]j )}jjEsbc.drm_buddy_finiasbuh1hhjEubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjEubj4)}(hj7h]h*}(hjEhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjEubjm)}(hmmh]hmm}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjEubah}(h]h ]h"]h$]h&]jjuh1jhj\EhhhjnEhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjXEhhhjnEhMubah}(h]jSEah ](jjeh"]h$]h&]jj)jhuh1j7hjnEhMhjUEhhubj)}(hhh]h)}(htear down the memory managerh]htear down the memory manager}(hj FhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjFhhubah}(h]h ]h"]h$]h&]uh1jhjUEhhhjnEhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj8Fjj8Fjjjuh1j2hhhjBhNhNubj)}(h**Parameters** ``struct drm_buddy *mm`` DRM buddy manager to free **Description** Cleanup memory manager resources and the freetreeh](h)}(h**Parameters**h]j)}(hjBFh]h Parameters}(hjDFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@Fubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj)}(hDstruct drm_buddy_block *drm_get_buddy(struct drm_buddy_block *block)h](jD)}(hjh]hstruct}(hjFhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjFhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMubjV)}(h h]h }(hjFhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFhhhjFhMubh)}(hhh]jm)}(hdrm_buddy_blockh]hdrm_buddy_block}(hjGhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjGmodnameN classnameNjj)}j]j )}j drm_get_buddysbc.drm_get_buddyasbuh1hhjFhhhjFhMubjV)}(h h]h }(hj!GhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFhhhjFhMubj4)}(hj7h]h*}(hj/GhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjFhhhjFhMubjg)}(h drm_get_buddyh]jm)}(hjGh]h drm_get_buddy}(hj@GhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)}(h?void drm_buddy_reset_clear(struct drm_buddy *mm, bool is_clear)h](j)}(hvoidh]hvoid}(hjHhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjHhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHhhhjHhMubjg)}(hdrm_buddy_reset_clearh]jm)}(hdrm_buddy_reset_clearh]hdrm_buddy_reset_clear}(hjHhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjHhhhjHhMubj)}(h%(struct drm_buddy *mm, bool is_clear)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjHhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjHubjV)}(h h]h }(hjHhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hj IhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjIubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj ImodnameN classnameNjj)}j]j )}jjHsbc.drm_buddy_reset_clearasbuh1hhjHubjV)}(h h]h }(hj*IhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjHubj4)}(hj7h]h*}(hj8IhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjHubjm)}(hmmh]hmm}(hjEIhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjHubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubj)}(h bool is_clearh](j)}(hj*h]hbool}(hj^IhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjZIubjV)}(h h]h }(hjkIhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZIubjm)}(his_clearh]his_clear}(hjyIhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZIubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjHubeh}(h]h ]h"]h$]h&]jjuh1jhjHhhhjHhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjHhhhjHhMubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1j7hjHhMhjHhhubj)}(hhh]h)}(hreset blocks clear stateh]hreset blocks clear state}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjIhhubah}(h]h ]h"]h$]h&]uh1jhjHhhhjHhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjIjjIjjjuh1j2hhhjBhNhNubj)}(h**Parameters** ``struct drm_buddy *mm`` DRM buddy manager ``bool is_clear`` blocks clear state **Description** Reset the clear state based on **is_clear** value for each block in the freetree.h](h)}(h**Parameters**h]j)}(hjIh]h Parameters}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjIubj)}(hhh](j)}(h+``struct drm_buddy *mm`` DRM buddy manager h](j)}(h``struct drm_buddy *mm``h]j)}(hjIh]hstruct drm_buddy *mm}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjIubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjIubj )}(hhh]h)}(hDRM buddy managerh]hDRM buddy manager}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjIhMhjIubah}(h]h ]h"]h$]h&]uh1j hjIubeh}(h]h ]h"]h$]h&]uh1jhjIhMhjIubj)}(h%``bool is_clear`` blocks clear state h](j)}(h``bool is_clear``h]j)}(hjJh]h bool is_clear}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjJubj )}(hhh]h)}(hblocks clear stateh]hblocks clear state}(hj6JhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2JhMhj3Jubah}(h]h ]h"]h$]h&]uh1j hjJubeh}(h]h ]h"]h$]h&]uh1jhj2JhMhjIubeh}(h]h ]h"]h$]h&]uh1jhjIubh)}(h**Description**h]j)}(hjXJh]h Description}(hjZJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVJubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjIubh)}(hQReset the clear state based on **is_clear** value for each block in the freetree.h](hReset the clear state based on }(hjnJhhhNhNubj)}(h **is_clear**h]his_clear}(hjvJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnJubh& value for each block in the freetree.}(hjnJhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjIubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjBhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_buddy_free_block (C function)c.drm_buddy_free_blockhNtauh1j!hjBhhhNhNubj3)}(hhh](j8)}(hOvoid drm_buddy_free_block (struct drm_buddy *mm, struct drm_buddy_block *block)h]j>)}(hNvoid drm_buddy_free_block(struct drm_buddy *mm, struct drm_buddy_block *block)h](j)}(hvoidh]hvoid}(hjJhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjJhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM ubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJhhhjJhM ubjg)}(hdrm_buddy_free_blockh]jm)}(hdrm_buddy_free_blockh]hdrm_buddy_free_block}(hjJhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjJubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjJhhhjJhM ubj)}(h5(struct drm_buddy *mm, struct drm_buddy_block *block)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjJubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hj KhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjKubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj KmodnameN classnameNjj)}j]j )}jjJsbc.drm_buddy_free_blockasbuh1hhjJubjV)}(h h]h }(hj*KhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjJubj4)}(hj7h]h*}(hj8KhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjJubjm)}(hmmh]hmm}(hjEKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjJubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJubj)}(hstruct drm_buddy_block *blockh](jD)}(hjh]hstruct}(hj^KhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjZKubjV)}(h h]h }(hjkKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZKubh)}(hhh]jm)}(hdrm_buddy_blockh]hdrm_buddy_block}(hj|KhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyKubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj~KmodnameN classnameNjj)}j]j&Kc.drm_buddy_free_blockasbuh1hhjZKubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZKubj4)}(hj7h]h*}(hjKhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjZKubjm)}(hblockh]hblock}(hjKhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZKubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjJubeh}(h]h ]h"]h$]h&]jjuh1jhjJhhhjJhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjJhhhjJhM ubah}(h]jJah ](jjeh"]h$]h&]jj)jhuh1j7hjJhM hjJhhubj)}(hhh]h)}(h free a blockh]h free a block}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM hjKhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjJhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjKjjKjjjuh1j2hhhjBhNhNubj)}(hs**Parameters** ``struct drm_buddy *mm`` DRM buddy manager ``struct drm_buddy_block *block`` block to be freedh](h)}(h**Parameters**h]j)}(hjLh]h Parameters}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjKubj)}(hhh](j)}(h+``struct drm_buddy *mm`` DRM buddy manager h](j)}(h``struct drm_buddy *mm``h]j)}(hj Lh]hstruct drm_buddy *mm}(hj"LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjLubj )}(hhh]h)}(hDRM buddy managerh]hDRM buddy manager}(hj9LhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj5LhMhj6Lubah}(h]h ]h"]h$]h&]uh1j hjLubeh}(h]h ]h"]h$]h&]uh1jhj5LhMhjLubj)}(h3``struct drm_buddy_block *block`` block to be freedh](j)}(h!``struct drm_buddy_block *block``h]j)}(hjYLh]hstruct drm_buddy_block *block}(hj[LhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWLubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjSLubj )}(hhh]h)}(hblock to be freedh]hblock to be freed}(hjrLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjoLubah}(h]h ]h"]h$]h&]uh1j hjSLubeh}(h]h ]h"]h$]h&]uh1jhjnLhMhjLubeh}(h]h ]h"]h$]h&]uh1jhjKubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjBhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_buddy_free_list (C function)c.drm_buddy_free_listhNtauh1j!hjBhhhNhNubj3)}(hhh](j8)}(h^void drm_buddy_free_list (struct drm_buddy *mm, struct list_head *objects, unsigned int flags)h]j>)}(h]void drm_buddy_free_list(struct drm_buddy *mm, struct list_head *objects, unsigned int flags)h](j)}(hvoidh]hvoid}(hjLhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjLhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM=ubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLhhhjLhM=ubjg)}(hdrm_buddy_free_listh]jm)}(hdrm_buddy_free_listh]hdrm_buddy_free_list}(hjLhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjLubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjLhhhjLhM=ubj)}(hE(struct drm_buddy *mm, struct list_head *objects, unsigned int flags)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjLhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjLubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj Mubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjMmodnameN classnameNjj)}j]j )}jjLsbc.drm_buddy_free_listasbuh1hhjLubjV)}(h h]h }(hj.MhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjLubj4)}(hj7h]h*}(hj)}(hbint drm_buddy_block_trim(struct drm_buddy *mm, u64 *start, u64 new_size, struct list_head *blocks)h](j)}(hinth]hint}(hjAOhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=OhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMubjV)}(h h]h }(hjPOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=OhhhjOOhMubjg)}(hdrm_buddy_block_trimh]jm)}(hdrm_buddy_block_trimh]hdrm_buddy_block_trim}(hjbOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^Oubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj=OhhhjOOhMubj)}(hJ(struct drm_buddy *mm, u64 *start, u64 new_size, struct list_head *blocks)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hj~OhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjzOubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzOubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjOubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjOmodnameN classnameNjj)}j]j )}jjdOsbc.drm_buddy_block_trimasbuh1hhjzOubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzOubj4)}(hj7h]h*}(hjOhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjzOubjm)}(hmmh]hmm}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvOubj)}(h u64 *starth](h)}(hhh]jm)}(hu64h]hu64}(hjOhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjOubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjOmodnameN classnameNjj)}j]jOc.drm_buddy_block_trimasbuh1hhjOubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjOubj4)}(hj7h]h*}(hjPhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjOubjm)}(hstarth]hstart}(hj,PhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjOubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvOubj)}(h u64 new_sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjHPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjEPubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjJPmodnameN classnameNjj)}j]jOc.drm_buddy_block_trimasbuh1hhjAPubjV)}(h h]h }(hjfPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjAPubjm)}(hnew_sizeh]hnew_size}(hjtPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAPubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvOubj)}(hstruct list_head *blocksh](jD)}(hjh]hstruct}(hjPhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjPubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjPubh)}(hhh]jm)}(h list_headh]h list_head}(hjPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjPmodnameN classnameNjj)}j]jOc.drm_buddy_block_trimasbuh1hhjPubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjPubj4)}(hj7h]h*}(hjPhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjPubjm)}(hblocksh]hblocks}(hjPhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvOubeh}(h]h ]h"]h$]h&]jjuh1jhj=OhhhjOOhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj9OhhhjOOhMubah}(h]j4Oah ](jjeh"]h$]h&]jj)jhuh1j7hjOOhMhj6Ohhubj)}(hhh]h)}(hfree unused pagesh]hfree unused pages}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj Qhhubah}(h]h ]h"]h$]h&]uh1jhj6OhhhjOOhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj&Qjj&Qjjjuh1j2hhhjBhNhNubj)}(hX**Parameters** ``struct drm_buddy *mm`` DRM buddy manager ``u64 *start`` start address to begin the trimming. ``u64 new_size`` original size requested ``struct list_head *blocks`` Input and output list of allocated blocks. MUST contain single block as input to be trimmed. On success will contain the newly allocated blocks making up the **new_size**. Blocks always appear in ascending order **Description** For contiguous allocation, we round up the size to the nearest power of two value, drivers consume *actual* size, so remaining portions are unused and can be optionally freed with this function **Return** 0 on success, error code on failure.h](h)}(h**Parameters**h]j)}(hj0Qh]h Parameters}(hj2QhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.Qubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj*Qubj)}(hhh](j)}(h+``struct drm_buddy *mm`` DRM buddy manager h](j)}(h``struct drm_buddy *mm``h]j)}(hjOQh]hstruct drm_buddy *mm}(hjQQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjMQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjIQubj )}(hhh]h)}(hDRM buddy managerh]hDRM buddy manager}(hjhQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjdQhMhjeQubah}(h]h ]h"]h$]h&]uh1j hjIQubeh}(h]h ]h"]h$]h&]uh1jhjdQhMhjFQubj)}(h4``u64 *start`` start address to begin the trimming. h](j)}(h``u64 *start``h]j)}(hjQh]h u64 *start}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjQubj )}(hhh]h)}(h$start address to begin the trimming.h]h$start address to begin the trimming.}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhMhjQubah}(h]h ]h"]h$]h&]uh1j hjQubeh}(h]h ]h"]h$]h&]uh1jhjQhMhjFQubj)}(h)``u64 new_size`` original size requested h](j)}(h``u64 new_size``h]j)}(hjQh]h u64 new_size}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjQubj )}(hhh]h)}(horiginal size requestedh]horiginal size requested}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjQhMhjQubah}(h]h ]h"]h$]h&]uh1j hjQubeh}(h]h ]h"]h$]h&]uh1jhjQhMhjFQubj)}(h``struct list_head *blocks`` Input and output list of allocated blocks. MUST contain single block as input to be trimmed. On success will contain the newly allocated blocks making up the **new_size**. Blocks always appear in ascending order h](j)}(h``struct list_head *blocks``h]j)}(hjQh]hstruct list_head *blocks}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjQubj )}(hhh]h)}(hInput and output list of allocated blocks. MUST contain single block as input to be trimmed. On success will contain the newly allocated blocks making up the **new_size**. Blocks always appear in ascending orderh](hInput and output list of allocated blocks. MUST contain single block as input to be trimmed. On success will contain the newly allocated blocks making up the }(hjRhhhNhNubj)}(h **new_size**h]hnew_size}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubh). Blocks always appear in ascending order}(hjRhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhjRubah}(h]h ]h"]h$]h&]uh1j hjQubeh}(h]h ]h"]h$]h&]uh1jhjRhMhjFQubeh}(h]h ]h"]h$]h&]uh1jhj*Qubh)}(h**Description**h]j)}(hjHRh]h Description}(hjJRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFRubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj*Qubh)}(hFor contiguous allocation, we round up the size to the nearest power of two value, drivers consume *actual* size, so remaining portions are unused and can be optionally freed with this functionh](hcFor contiguous allocation, we round up the size to the nearest power of two value, drivers consume }(hj^RhhhNhNubj)}(h*actual*h]hactual}(hjfRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^RubhV size, so remaining portions are unused and can be optionally freed with this function}(hj^RhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj*Qubh)}(h **Return**h]j)}(hjRh]hReturn}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjRubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj*Qubh)}(h$0 on success, error code on failure.h]h$0 on success, error code on failure.}(hjRhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj*Qubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjBhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_buddy_alloc_blocks (C function)c.drm_buddy_alloc_blockshNtauh1j!hjBhhhNhNubj3)}(hhh](j8)}(hint drm_buddy_alloc_blocks (struct drm_buddy *mm, u64 start, u64 end, u64 size, u64 min_block_size, struct list_head *blocks, unsigned long flags)h]j>)}(hint drm_buddy_alloc_blocks(struct drm_buddy *mm, u64 start, u64 end, u64 size, u64 min_block_size, struct list_head *blocks, unsigned long flags)h](j)}(hinth]hint}(hjRhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjRhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM8ubjV)}(h h]h }(hjRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRhhhjRhM8ubjg)}(hdrm_buddy_alloc_blocksh]jm)}(hdrm_buddy_alloc_blocksh]hdrm_buddy_alloc_blocks}(hjRhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjRhhhjRhM8ubj)}(hw(struct drm_buddy *mm, u64 start, u64 end, u64 size, u64 min_block_size, struct list_head *blocks, unsigned long flags)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjShhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjRubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hj!ShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#SmodnameN classnameNjj)}j]j )}jjRsbc.drm_buddy_alloc_blocksasbuh1hhjRubjV)}(h h]h }(hjAShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRubj4)}(hj7h]h*}(hjOShhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjRubjm)}(hmmh]hmm}(hj\ShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(h u64 starth](h)}(hhh]jm)}(hu64h]hu64}(hjxShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjzSmodnameN classnameNjj)}j]j=Sc.drm_buddy_alloc_blocksasbuh1hhjqSubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqSubjm)}(hstarth]hstart}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqSubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(hu64 endh](h)}(hhh]jm)}(hu64h]hu64}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjSmodnameN classnameNjj)}j]j=Sc.drm_buddy_alloc_blocksasbuh1hhjSubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjSubjm)}(hendh]hend}(hjShhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(hu64 sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj TmodnameN classnameNjj)}j]j=Sc.drm_buddy_alloc_blocksasbuh1hhjTubjV)}(h h]h }(hj&ThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubjm)}(hsizeh]hsize}(hj4ThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(hu64 min_block_sizeh](h)}(hhh]jm)}(hu64h]hu64}(hjPThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjMTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjRTmodnameN classnameNjj)}j]j=Sc.drm_buddy_alloc_blocksasbuh1hhjITubjV)}(h h]h }(hjnThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjITubjm)}(hmin_block_sizeh]hmin_block_size}(hj|ThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjITubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(hstruct list_head *blocksh](jD)}(hjh]hstruct}(hjThhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjTubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubh)}(hhh]jm)}(h list_headh]h list_head}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjTmodnameN classnameNjj)}j]j=Sc.drm_buddy_alloc_blocksasbuh1hhjTubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjTubj4)}(hj7h]h*}(hjThhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjTubjm)}(hblocksh]hblocks}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjTubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubj)}(hunsigned long flagsh](j)}(hunsignedh]hunsigned}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubjV)}(h h]h }(hjUhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUubj)}(hlongh]hlong}(hj!UhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUubjV)}(h h]h }(hj/UhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUubjm)}(hflagsh]hflags}(hj=UhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjUubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjRubeh}(h]h ]h"]h$]h&]jjuh1jhjRhhhjRhM8ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjRhhhjRhM8ubah}(h]jRah ](jjeh"]h$]h&]jj)jhuh1j7hjRhM8hjRhhubj)}(hhh]h)}(hallocate power-of-two blocksh]hallocate power-of-two blocks}(hjgUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM8hjdUhhubah}(h]h ]h"]h$]h&]uh1jhjRhhhjRhM8ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjUjjUjjjuh1j2hhhjBhNhNubj)}(hX**Parameters** ``struct drm_buddy *mm`` DRM buddy manager to allocate from ``u64 start`` start of the allowed range for this block ``u64 end`` end of the allowed range for this block ``u64 size`` size of the allocation in bytes ``u64 min_block_size`` alignment of the allocation ``struct list_head *blocks`` output list head to add allocated blocks ``unsigned long flags`` DRM_BUDDY_*_ALLOCATION flags **Description** alloc_range_bias() called on range limitations, which traverses the tree and returns the desired block. alloc_from_freetree() called when *no* range restrictions are enforced, which picks the block from the freetree. **Return** 0 on success, error code on failure.h](h)}(h**Parameters**h]j)}(hjUh]h Parameters}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM<hjUubj)}(hhh](j)}(h<``struct drm_buddy *mm`` DRM buddy manager to allocate from h](j)}(h``struct drm_buddy *mm``h]j)}(hjUh]hstruct drm_buddy *mm}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM:hjUubj )}(hhh]h)}(h"DRM buddy manager to allocate fromh]h"DRM buddy manager to allocate from}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhM:hjUubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhM:hjUubj)}(h8``u64 start`` start of the allowed range for this block h](j)}(h ``u64 start``h]j)}(hjUh]h u64 start}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM;hjUubj )}(hhh]h)}(h)start of the allowed range for this blockh]h)start of the allowed range for this block}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjUhM;hjUubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjUhM;hjUubj)}(h4``u64 end`` end of the allowed range for this block h](j)}(h ``u64 end``h]j)}(hjVh]hu64 end}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM<hjVubj )}(hhh]h)}(h'end of the allowed range for this blockh]h'end of the allowed range for this block}(hj3VhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj/VhM<hj0Vubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhj/VhM<hjUubj)}(h-``u64 size`` size of the allocation in bytes h](j)}(h ``u64 size``h]j)}(hjSVh]hu64 size}(hjUVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQVubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM=hjMVubj )}(hhh]h)}(hsize of the allocation in bytesh]hsize of the allocation in bytes}(hjlVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhVhM=hjiVubah}(h]h ]h"]h$]h&]uh1j hjMVubeh}(h]h ]h"]h$]h&]uh1jhjhVhM=hjUubj)}(h3``u64 min_block_size`` alignment of the allocation h](j)}(h``u64 min_block_size``h]j)}(hjVh]hu64 min_block_size}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM>hjVubj )}(hhh]h)}(halignment of the allocationh]halignment of the allocation}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM>hjVubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhM>hjUubj)}(hF``struct list_head *blocks`` output list head to add allocated blocks h](j)}(h``struct list_head *blocks``h]j)}(hjVh]hstruct list_head *blocks}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM?hjVubj )}(hhh]h)}(h(output list head to add allocated blocksh]h(output list head to add allocated blocks}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjVhM?hjVubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjVhM?hjUubj)}(h5``unsigned long flags`` DRM_BUDDY_*_ALLOCATION flags h](j)}(h``unsigned long flags``h]j)}(hjVh]hunsigned long flags}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chM@hjVubj )}(hhh]h)}(hDRM_BUDDY_*_ALLOCATION flagsh]hDRM_BUDDY_*_ALLOCATION flags}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhM@hjWubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjWhM@hjUubeh}(h]h ]h"]h$]h&]uh1jhjUubh)}(h**Description**h]j)}(hj9Wh]h Description}(hj;WhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj7Wubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMBhjUubh)}(hgalloc_range_bias() called on range limitations, which traverses the tree and returns the desired block.h]hgalloc_range_bias() called on range limitations, which traverses the tree and returns the desired block.}(hjOWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMAhjUubh)}(hpalloc_from_freetree() called when *no* range restrictions are enforced, which picks the block from the freetree.h](h"alloc_from_freetree() called when }(hj^WhhhNhNubj)}(h*no*h]hno}(hjfWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^WubhJ range restrictions are enforced, which picks the block from the freetree.}(hj^WhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMDhjUubh)}(h **Return**h]j)}(hjWh]hReturn}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMGhjUubh)}(h$0 on success, error code on failure.h]h$0 on success, error code on failure.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMHhjUubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjBhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_buddy_block_print (C function)c.drm_buddy_block_printhNtauh1j!hjBhhhNhNubj3)}(hhh](j8)}(hgvoid drm_buddy_block_print (struct drm_buddy *mm, struct drm_buddy_block *block, struct drm_printer *p)h]j>)}(hfvoid drm_buddy_block_print(struct drm_buddy *mm, struct drm_buddy_block *block, struct drm_printer *p)h](j)}(hvoidh]hvoid}(hjWhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWhhhjWhMubjg)}(hdrm_buddy_block_printh]jm)}(hdrm_buddy_block_printh]hdrm_buddy_block_print}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjWhhhjWhMubj)}(hL(struct drm_buddy *mm, struct drm_buddy_block *block, struct drm_printer *p)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjXhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjWubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hj!XhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#XmodnameN classnameNjj)}j]j )}jjWsbc.drm_buddy_block_printasbuh1hhjWubjV)}(h h]h }(hjAXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjWubj4)}(hj7h]h*}(hjOXhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjWubjm)}(hmmh]hmm}(hj\XhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjWubj)}(hstruct drm_buddy_block *blockh](jD)}(hjh]hstruct}(hjuXhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqXubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqXubh)}(hhh]jm)}(hdrm_buddy_blockh]hdrm_buddy_block}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjXmodnameN classnameNjj)}j]j=Xc.drm_buddy_block_printasbuh1hhjqXubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqXubj4)}(hj7h]h*}(hjXhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjqXubjm)}(hblockh]hblock}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjWubj)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hjXhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjXubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjYubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjYmodnameN classnameNjj)}j]j=Xc.drm_buddy_block_printasbuh1hhjXubjV)}(h h]h }(hj!YhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubj4)}(hj7h]h*}(hj/YhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjXubjm)}(hj@h]hp}(hj)}(hAvoid drm_buddy_print(struct drm_buddy *mm, struct drm_printer *p)h](j)}(hvoidh]hvoid}(hjrZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnZhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnZhhhjZhMubjg)}(hdrm_buddy_printh]jm)}(hdrm_buddy_printh]hdrm_buddy_print}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjnZhhhjZhMubj)}(h-(struct drm_buddy *mm, struct drm_printer *p)h](j)}(hstruct drm_buddy *mmh](jD)}(hjh]hstruct}(hjZhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjZubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubh)}(hhh]jm)}(h drm_buddyh]h drm_buddy}(hjZhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjZmodnameN classnameNjj)}j]j )}jjZsbc.drm_buddy_printasbuh1hhjZubjV)}(h h]h }(hjZhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjZubj4)}(hj7h]h*}(hjZhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjZubjm)}(hmmh]hmm}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubj)}(hstruct drm_printer *ph](jD)}(hjh]hstruct}(hj![hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj[ubjV)}(h h]h }(hj.[hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubh)}(hhh]jm)}(h drm_printerh]h drm_printer}(hj?[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj<[ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjA[modnameN classnameNjj)}j]jZc.drm_buddy_printasbuh1hhj[ubjV)}(h h]h }(hj][hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj[ubj4)}(hj7h]h*}(hjk[hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj[ubjm)}(hj@h]hp}(hjx[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjZubeh}(h]h ]h"]h$]h&]jjuh1jhjnZhhhjZhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjjZhhhjZhMubah}(h]jeZah ](jjeh"]h$]h&]jj)jhuh1j7hjZhMhjgZhhubj)}(hhh]h)}(hprint allocator stateh]hprint allocator state}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj[hhubah}(h]h ]h"]h$]h&]uh1jhjgZhhhjZhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj[jj[jjjuh1j2hhhjBhNhNubj)}(hl**Parameters** ``struct drm_buddy *mm`` DRM buddy manager ``struct drm_printer *p`` DRM printer to useh](h)}(h**Parameters**h]j)}(hj[h]h Parameters}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj[ubj)}(hhh](j)}(h+``struct drm_buddy *mm`` DRM buddy manager h](j)}(h``struct drm_buddy *mm``h]j)}(hj[h]hstruct drm_buddy *mm}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj[ubj )}(hhh]h)}(hDRM buddy managerh]hDRM buddy manager}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMhj[ubah}(h]h ]h"]h$]h&]uh1j hj[ubeh}(h]h ]h"]h$]h&]uh1jhj[hMhj[ubj)}(h,``struct drm_printer *p`` DRM printer to useh](j)}(h``struct drm_printer *p``h]j)}(hj\h]hstruct drm_printer *p}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj\ubj )}(hhh]h)}(hDRM printer to useh]hDRM printer to use}(hj4\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:532: ./drivers/gpu/drm/drm_buddy.chMhj1\ubah}(h]h ]h"]h$]h&]uh1j hj\ubeh}(h]h ]h"]h$]h&]uh1jhj0\hMhj[ubeh}(h]h ]h"]h$]h&]uh1jhj[ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjBhhhNhNubeh}(h]drm-buddy-function-referencesah ]h"]drm buddy function referencesah$]h&]uh1hhj{BhhhhhMubeh}(h]drm-buddy-allocatorah ]h"]drm buddy allocatorah$]h&]uh1hhhhhhhhMubh)}(hhh](h)}(h'DRM Cache Handling and Fast WC memcpy()h]h'DRM Cache Handling and Fast WC memcpy()}(hjo\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjl\hhhhhMubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_clflush_pages (C function)c.drm_clflush_pageshNtauh1j!hjl\hhhNhNubj3)}(hhh](j8)}(hFvoid drm_clflush_pages (struct page *pages[], unsigned long num_pages)h]j>)}(hEvoid drm_clflush_pages(struct page *pages[], unsigned long num_pages)h](j)}(hvoidh]hvoid}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj\hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKOubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\hhhj\hKOubjg)}(hdrm_clflush_pagesh]jm)}(hdrm_clflush_pagesh]hdrm_clflush_pages}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj\hhhj\hKOubj)}(h/(struct page *pages[], unsigned long num_pages)h](j)}(hstruct page *pages[]h](jD)}(hjh]hstruct}(hj\hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj\ubjV)}(h h]h }(hj\hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubh)}(hhh]jm)}(hpageh]hpage}(hj\hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj\modnameN classnameNjj)}j]j )}jj\sbc.drm_clflush_pagesasbuh1hhj\ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\ubj4)}(hj7h]h*}(hj]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj\ubjm)}(hpagesh]hpages}(hj,]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\ubj4)}(h[h]h[}(hj:]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj\ubj4)}(h]h]h]}(hjH]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj\ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj\ubj)}(hunsigned long num_pagesh](j)}(hunsignedh]hunsigned}(hja]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]]ubjV)}(h h]h }(hjo]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]]ubj)}(hlongh]hlong}(hj}]hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]]ubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]]ubjm)}(h num_pagesh]h num_pages}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj\ubeh}(h]h ]h"]h$]h&]jjuh1jhj\hhhj\hKOubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj\hhhj\hKOubah}(h]j\ah ](jjeh"]h$]h&]jj)jhuh1j7hj\hKOhj\hhubj)}(hhh]h)}(h%Flush dcache lines of a set of pages.h]h%Flush dcache lines of a set of pages.}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKOhj]hhubah}(h]h ]h"]h$]h&]uh1jhj\hhhj\hKOubeh}(h]h ](jfunctioneh"]h$]h&]jjjj]jj]jjjuh1j2hhhjl\hNhNubj)}(h**Parameters** ``struct page *pages[]`` List of pages to be flushed. ``unsigned long num_pages`` Number of pages in the array. **Description** Flush every data cache line entry that points to an address belonging to a page in the array.h](h)}(h**Parameters**h]j)}(hj]h]h Parameters}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKShj]ubj)}(hhh](j)}(h6``struct page *pages[]`` List of pages to be flushed. h](j)}(h``struct page *pages[]``h]j)}(hj^h]hstruct page *pages[]}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKPhj]ubj )}(hhh]h)}(hList of pages to be flushed.h]hList of pages to be flushed.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hKPhj^ubah}(h]h ]h"]h$]h&]uh1j hj]ubeh}(h]h ]h"]h$]h&]uh1jhj^hKPhj]ubj)}(h:``unsigned long num_pages`` Number of pages in the array. h](j)}(h``unsigned long num_pages``h]j)}(hj=^h]hunsigned long num_pages}(hj?^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;^ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKQhj7^ubj )}(hhh]h)}(hNumber of pages in the array.h]hNumber of pages in the array.}(hjV^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjR^hKQhjS^ubah}(h]h ]h"]h$]h&]uh1j hj7^ubeh}(h]h ]h"]h$]h&]uh1jhjR^hKQhj]ubeh}(h]h ]h"]h$]h&]uh1jhj]ubh)}(h**Description**h]j)}(hjx^h]h Description}(hjz^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjv^ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKShj]ubh)}(h]Flush every data cache line entry that points to an address belonging to a page in the array.h]h]Flush every data cache line entry that points to an address belonging to a page in the array.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKRhj]ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl\hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_clflush_sg (C function)c.drm_clflush_sghNtauh1j!hjl\hhhNhNubj3)}(hhh](j8)}(h)void drm_clflush_sg (struct sg_table *st)h]j>)}(h(void drm_clflush_sg(struct sg_table *st)h](j)}(hvoidh]hvoid}(hj^hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj^hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKxubjV)}(h h]h }(hj^hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj^hhhj^hKxubjg)}(hdrm_clflush_sgh]jm)}(hdrm_clflush_sgh]hdrm_clflush_sg}(hj^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj^hhhj^hKxubj)}(h(struct sg_table *st)h]j)}(hstruct sg_table *sth](jD)}(hjh]hstruct}(hj^hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj^ubjV)}(h h]h }(hj_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj^ubh)}(hhh]jm)}(hsg_tableh]hsg_table}(hj_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_modnameN classnameNjj)}j]j )}jj^sbc.drm_clflush_sgasbuh1hhj^ubjV)}(h h]h }(hj8_hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj^ubj4)}(hj7h]h*}(hjF_hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj^ubjm)}(hsth]hst}(hjS_hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj^ubah}(h]h ]h"]h$]h&]jjuh1jhj^hhhj^hKxubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj^hhhj^hKxubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hj^hKxhj^hhubj)}(hhh]h)}(h0Flush dcache lines pointing to a scather-gather.h]h0Flush dcache lines pointing to a scather-gather.}(hj}_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKxhjz_hhubah}(h]h ]h"]h$]h&]uh1jhj^hhhj^hKxubeh}(h]h ](jfunctioneh"]h$]h&]jjjj_jj_jjjuh1j2hhhjl\hNhNubj)}(h**Parameters** ``struct sg_table *st`` struct sg_table. **Description** Flush every data cache line entry that points to an address in the sg.h](h)}(h**Parameters**h]j)}(hj_h]h Parameters}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chK|hj_ubj)}(hhh]j)}(h)``struct sg_table *st`` struct sg_table. h](j)}(h``struct sg_table *st``h]j)}(hj_h]hstruct sg_table *st}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKyhj_ubj )}(hhh]h)}(hstruct sg_table.h]hstruct sg_table.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hKyhj_ubah}(h]h ]h"]h$]h&]uh1j hj_ubeh}(h]h ]h"]h$]h&]uh1jhj_hKyhj_ubah}(h]h ]h"]h$]h&]uh1jhj_ubh)}(h**Description**h]j)}(hj_h]h Description}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chK{hj_ubh)}(hFFlush every data cache line entry that points to an address in the sg.h]hFFlush every data cache line entry that points to an address in the sg.}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKzhj_ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl\hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_clflush_virt_range (C function)c.drm_clflush_virt_rangehNtauh1j!hjl\hhhNhNubj3)}(hhh](j8)}(h>void drm_clflush_virt_range (void *addr, unsigned long length)h]j>)}(h=void drm_clflush_virt_range(void *addr, unsigned long length)h](j)}(hvoidh]hvoid}(hj>`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj:`hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKubjV)}(h h]h }(hjM`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj:`hhhjL`hKubjg)}(hdrm_clflush_virt_rangeh]jm)}(hdrm_clflush_virt_rangeh]hdrm_clflush_virt_range}(hj_`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj[`ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj:`hhhjL`hKubj)}(h"(void *addr, unsigned long length)h](j)}(h void *addrh](j)}(hvoidh]hvoid}(hj{`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjw`ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjw`ubj4)}(hj7h]h*}(hj`hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjw`ubjm)}(haddrh]haddr}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjw`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjs`ubj)}(hunsigned long lengthh](j)}(hunsignedh]hunsigned}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`ubj)}(hlongh]hlong}(hj`hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj`ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`ubjm)}(hlengthh]hlength}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjs`ubeh}(h]h ]h"]h$]h&]jjuh1jhj:`hhhjL`hKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj6`hhhjL`hKubah}(h]j1`ah ](jjeh"]h$]h&]jj)jhuh1j7hjL`hKhj3`hhubj)}(hhh]h)}(hFlush dcache lines of a regionh]hFlush dcache lines of a region}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKhjahhubah}(h]h ]h"]h$]h&]uh1jhj3`hhhjL`hKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj7ajj7ajjjuh1j2hhhjl\hNhNubj)}(h**Parameters** ``void *addr`` Initial kernel memory address. ``unsigned long length`` Region size. **Description** Flush every data cache line entry that points to an address in the region requested.h](h)}(h**Parameters**h]j)}(hjAah]h Parameters}(hjCahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?aubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKhj;aubj)}(hhh](j)}(h.``void *addr`` Initial kernel memory address. h](j)}(h``void *addr``h]j)}(hj`ah]h void *addr}(hjbahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj^aubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKhjZaubj )}(hhh]h)}(hInitial kernel memory address.h]hInitial kernel memory address.}(hjyahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuahKhjvaubah}(h]h ]h"]h$]h&]uh1j hjZaubeh}(h]h ]h"]h$]h&]uh1jhjuahKhjWaubj)}(h&``unsigned long length`` Region size. h](j)}(h``unsigned long length``h]j)}(hjah]hunsigned long length}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKhjaubj )}(hhh]h)}(h Region size.h]h Region size.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahKhjaubah}(h]h ]h"]h$]h&]uh1j hjaubeh}(h]h ]h"]h$]h&]uh1jhjahKhjWaubeh}(h]h ]h"]h$]h&]uh1jhj;aubh)}(h**Description**h]j)}(hjah]h Description}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKhj;aubh)}(hTFlush every data cache line entry that points to an address in the region requested.h]hTFlush every data cache line entry that points to an address in the region requested.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chKhj;aubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjl\hhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_memcpy_from_wc (C function)c.drm_memcpy_from_wchNtauh1j!hjl\hhhNhNubj3)}(hhh](j8)}(h_void drm_memcpy_from_wc (struct iosys_map *dst, const struct iosys_map *src, unsigned long len)h]j>)}(h^void drm_memcpy_from_wc(struct iosys_map *dst, const struct iosys_map *src, unsigned long len)h](j)}(hvoidh]hvoid}(hjbhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:538: ./drivers/gpu/drm/drm_cache.chM%ubjV)}(h h]h }(hj(bhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbhhhj'bhM%ubjg)}(hdrm_memcpy_from_wch]jm)}(hdrm_memcpy_from_wch]hdrm_memcpy_from_wc}(hj:bhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6bubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjbhhhj'bhM%ubj)}(hG(struct iosys_map *dst, const struct iosys_map *src, unsigned long len)h](j)}(hstruct iosys_map *dsth](jD)}(hjh]hstruct}(hjVbhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjRbubjV)}(h h]h }(hjcbhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjRbubh)}(hhh]jm)}(h iosys_maph]h iosys_map}(hjtbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjvbmodnameN classnameNjj)}j]j )}jj)}(hstruct drm_syncobjh](jD)}(hjh]hstruct}(hjkhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjkhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKubjV)}(h h]h }(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjkhhhjkhKubjg)}(h drm_syncobjh]jm)}(hjkh]h drm_syncobj}(hjkhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjkubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjkhhhjkhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjkhhhjkhKubah}(h]jkah ](jjeh"]h$]h&]jj)jhuh1j7hjkhKhjkhhubj)}(hhh]h)}(h sync object.h]h sync object.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK#hjlhhubah}(h]h ]h"]h$]h&]uh1jhjkhhhjkhKubeh}(h]h ](jstructeh"]h$]h&]jjjj,ljj,ljjjuh1j2hhhjdhNhNubj)}(hX**Definition**:: struct drm_syncobj { struct kref refcount; struct dma_fence *fence; struct list_head cb_list; struct list_head ev_fd_list; spinlock_t lock; struct file *file; }; **Members** ``refcount`` Reference count of this object. ``fence`` NULL or a pointer to the fence bound to this object. This field should not be used directly. Use drm_syncobj_fence_get() and drm_syncobj_replace_fence() instead. ``cb_list`` List of callbacks to call when the :c:type:`fence` gets replaced. ``ev_fd_list`` List of registered eventfd. ``lock`` Protects :c:type:`cb_list` and :c:type:`ev_fd_list`, and write-locks :c:type:`fence`. ``file`` A file backing for this syncobj.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj8lhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4lubh:}(hj4lhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK'hj0lubjT)}(hstruct drm_syncobj { struct kref refcount; struct dma_fence *fence; struct list_head cb_list; struct list_head ev_fd_list; spinlock_t lock; struct file *file; };h]hstruct drm_syncobj { struct kref refcount; struct dma_fence *fence; struct list_head cb_list; struct list_head ev_fd_list; spinlock_t lock; struct file *file; };}hjQlsbah}(h]h ]h"]h$]h&]jjuh1jShU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK)hj0lubh)}(h **Members**h]j)}(hjblh]hMembers}(hjdlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`lubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK2hj0lubj)}(hhh](j)}(h-``refcount`` Reference count of this object. h](j)}(h ``refcount``h]j)}(hjlh]hrefcount}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK*hj{lubj )}(hhh]h)}(hReference count of this object.h]hReference count of this object.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjlhK*hjlubah}(h]h ]h"]h$]h&]uh1j hj{lubeh}(h]h ]h"]h$]h&]uh1jhjlhK*hjxlubj)}(h``fence`` NULL or a pointer to the fence bound to this object. This field should not be used directly. Use drm_syncobj_fence_get() and drm_syncobj_replace_fence() instead. h](j)}(h ``fence``h]j)}(hjlh]hfence}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK1hjlubj )}(hhh](h)}(h4NULL or a pointer to the fence bound to this object.h]h4NULL or a pointer to the fence bound to this object.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK.hjlubh)}(hlThis field should not be used directly. Use drm_syncobj_fence_get() and drm_syncobj_replace_fence() instead.h]hlThis field should not be used directly. Use drm_syncobj_fence_get() and drm_syncobj_replace_fence() instead.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK0hjlubeh}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhjlhK1hjxlubj)}(hN``cb_list`` List of callbacks to call when the :c:type:`fence` gets replaced. h](j)}(h ``cb_list``h]j)}(hjmh]hcb_list}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK6hjlubj )}(hhh]h)}(hAList of callbacks to call when the :c:type:`fence` gets replaced.h](h#List of callbacks to call when the }(hjmhhhNhNubh)}(h:c:type:`fence`h]j)}(hj&mh]hfence}(hj(mhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj$mubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfenceuh1hhjmhK6hjmubh gets replaced.}(hjmhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjmhK6hjmubah}(h]h ]h"]h$]h&]uh1j hjlubeh}(h]h ]h"]h$]h&]uh1jhjmhK6hjxlubj)}(h+``ev_fd_list`` List of registered eventfd. h](j)}(h``ev_fd_list``h]j)}(hj_mh]h ev_fd_list}(hjamhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]mubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK:hjYmubj )}(hhh]h)}(hList of registered eventfd.h]hList of registered eventfd.}(hjxmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjtmhK:hjumubah}(h]h ]h"]h$]h&]uh1j hjYmubeh}(h]h ]h"]h$]h&]uh1jhjtmhK:hjxlubj)}(h_``lock`` Protects :c:type:`cb_list` and :c:type:`ev_fd_list`, and write-locks :c:type:`fence`. h](j)}(h``lock``h]j)}(hjmh]hlock}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK>hjmubj )}(hhh]h)}(hUProtects :c:type:`cb_list` and :c:type:`ev_fd_list`, and write-locks :c:type:`fence`.h](h Protects }(hjmhhhNhNubh)}(h:c:type:`cb_list`h]j)}(hjmh]hcb_list}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMcb_listuh1hhjmhK>hjmubh and }(hjmhhhNhNubh)}(h:c:type:`ev_fd_list`h]j)}(hjmh]h ev_fd_list}(hjmhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM ev_fd_listuh1hhjmhK>hjmubh, and write-locks }(hjmhhhNhNubh)}(h:c:type:`fence`h]j)}(hjnh]hfence}(hjnhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMfenceuh1hhjmhK>hjmubh.}(hjmhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjmhK>hjmubah}(h]h ]h"]h$]h&]uh1j hjmubeh}(h]h ]h"]h$]h&]uh1jhjmhK>hjxlubj)}(h)``file`` A file backing for this syncobj.h](j)}(h``file``h]j)}(hj:nh]hfile}(hj)}(h-void drm_syncobj_get(struct drm_syncobj *obj)h](j)}(hvoidh]hvoid}(hjnhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKIubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnhhhjnhKIubjg)}(hdrm_syncobj_geth]jm)}(hdrm_syncobj_geth]hdrm_syncobj_get}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjnhhhjnhKIubj)}(h(struct drm_syncobj *obj)h]j)}(hstruct drm_syncobj *objh](jD)}(hjh]hstruct}(hjohhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjoubjV)}(h h]h }(hj(ohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hj9ohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj6oubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj;omodnameN classnameNjj)}j]j )}jjosbc.drm_syncobj_getasbuh1hhjoubjV)}(h h]h }(hjYohhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjoubj4)}(hj7h]h*}(hjgohhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjoubjm)}(hobjh]hobj}(hjtohhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjoubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubah}(h]h ]h"]h$]h&]jjuh1jhjnhhhjnhKIubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjnhhhjnhKIubah}(h]jnah ](jjeh"]h$]h&]jj)jhuh1j7hjnhKIhjnhhubj)}(hhh]h)}(hacquire a syncobj referenceh]hacquire a syncobj reference}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKIhjohhubah}(h]h ]h"]h$]h&]uh1jhjnhhhjnhKIubeh}(h]h ](jfunctioneh"]h$]h&]jjjjojjojjjuh1j2hhhjdhNhNubj)}(h**Parameters** ``struct drm_syncobj *obj`` sync object **Description** This acquires an additional reference to **obj**. It is illegal to call this without already holding a reference. No locks required.h](h)}(h**Parameters**h]j)}(hjoh]h Parameters}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKMhjoubj)}(hhh]j)}(h(``struct drm_syncobj *obj`` sync object h](j)}(h``struct drm_syncobj *obj``h]j)}(hjoh]hstruct drm_syncobj *obj}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKJhjoubj )}(hhh]h)}(h sync objecth]h sync object}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjohKJhjoubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjohKJhjoubah}(h]h ]h"]h$]h&]uh1jhjoubh)}(h**Description**h]j)}(hjph]h Description}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKLhjoubh)}(hThis acquires an additional reference to **obj**. It is illegal to call this without already holding a reference. No locks required.h](h)This acquires an additional reference to }(hj0phhhNhNubj)}(h**obj**h]hobj}(hj8phhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0pubhT. It is illegal to call this without already holding a reference. No locks required.}(hj0phhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKKhjoubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_syncobj_put (C function)c.drm_syncobj_puthNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(h.void drm_syncobj_put (struct drm_syncobj *obj)h]j>)}(h-void drm_syncobj_put(struct drm_syncobj *obj)h](j)}(hvoidh]hvoid}(hjqphhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmphhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKVubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmphhhjphKVubjg)}(hdrm_syncobj_puth]jm)}(hdrm_syncobj_puth]hdrm_syncobj_put}(hjphhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjmphhhjphKVubj)}(h(struct drm_syncobj *obj)h]j)}(hstruct drm_syncobj *objh](jD)}(hjh]hstruct}(hjphhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjpubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjpubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjphhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjpmodnameN classnameNjj)}j]j )}jjpsbc.drm_syncobj_putasbuh1hhjpubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjpubj4)}(hj7h]h*}(hjphhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjpubjm)}(hobjh]hobj}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjpubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjpubah}(h]h ]h"]h$]h&]jjuh1jhjmphhhjphKVubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjiphhhjphKVubah}(h]jdpah ](jjeh"]h$]h&]jj)jhuh1j7hjphKVhjfphhubj)}(hhh]h)}(h%release a reference to a sync object.h]h%release a reference to a sync object.}(hj1qhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKVhj.qhhubah}(h]h ]h"]h$]h&]uh1jhjfphhhjphKVubeh}(h]h ](jfunctioneh"]h$]h&]jjjjIqjjIqjjjuh1j2hhhjdhNhNubj)}(h:**Parameters** ``struct drm_syncobj *obj`` sync object.h](h)}(h**Parameters**h]j)}(hjSqh]h Parameters}(hjUqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjQqubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKZhjMqubj)}(hhh]j)}(h(``struct drm_syncobj *obj`` sync object.h](j)}(h``struct drm_syncobj *obj``h]j)}(hjrqh]hstruct drm_syncobj *obj}(hjtqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjpqubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK\hjlqubj )}(hhh]h)}(h sync object.h]h sync object.}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKWhjqubah}(h]h ]h"]h$]h&]uh1j hjlqubeh}(h]h ]h"]h$]h&]uh1jhjqhK\hjiqubah}(h]h ]h"]h$]h&]uh1jhjMqubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_syncobj_fence_get (C function)c.drm_syncobj_fence_gethNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hFstruct dma_fence * drm_syncobj_fence_get (struct drm_syncobj *syncobj)h]j>)}(hDstruct dma_fence *drm_syncobj_fence_get(struct drm_syncobj *syncobj)h](jD)}(hjh]hstruct}(hjqhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjqhhhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK`ubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqhhhjqhK`ubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjqubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjqmodnameN classnameNjj)}j]j )}jdrm_syncobj_fence_getsbc.drm_syncobj_fence_getasbuh1hhjqhhhjqhK`ubjV)}(h h]h }(hj rhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjqhhhjqhK`ubj4)}(hj7h]h*}(hjrhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjqhhhjqhK`ubjg)}(hdrm_syncobj_fence_geth]jm)}(hj rh]hdrm_syncobj_fence_get}(hj+rhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj'rubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjqhhhjqhK`ubj)}(h(struct drm_syncobj *syncobj)h]j)}(hstruct drm_syncobj *syncobjh](jD)}(hjh]hstruct}(hjFrhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjBrubjV)}(h h]h }(hjSrhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBrubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjdrhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjarubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjfrmodnameN classnameNjj)}j]jrc.drm_syncobj_fence_getasbuh1hhjBrubjV)}(h h]h }(hjrhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjBrubj4)}(hj7h]h*}(hjrhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjBrubjm)}(hsyncobjh]hsyncobj}(hjrhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjBrubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj>rubah}(h]h ]h"]h$]h&]jjuh1jhjqhhhjqhK`ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjqhhhjqhK`ubah}(h]jqah ](jjeh"]h$]h&]jj)jhuh1j7hjqhK`hjqhhubj)}(hhh]h)}(h+get a reference to a fence in a sync objecth]h+get a reference to a fence in a sync object}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhK`hjrhhubah}(h]h ]h"]h$]h&]uh1jhjqhhhjqhK`ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjrjjrjjjuh1j2hhhjdhNhNubj)}(hXX**Parameters** ``struct drm_syncobj *syncobj`` sync object. **Description** This acquires additional reference to :c:type:`drm_syncobj.fence ` contained in **obj**, if not NULL. It is illegal to call this without already holding a reference. No locks required. **Return** Either the fence of **obj** or NULL if there's none.h](h)}(h**Parameters**h]j)}(hjrh]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKdhjrubj)}(hhh]j)}(h-``struct drm_syncobj *syncobj`` sync object. h](j)}(h``struct drm_syncobj *syncobj``h]j)}(hjsh]hstruct drm_syncobj *syncobj}(hj shhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKahjsubj )}(hhh]h)}(h sync object.h]h sync object.}(hj!shhhNhNubah}(h]h ]h"]h$]h&]uh1hhjshKahjsubah}(h]h ]h"]h$]h&]uh1j hjsubeh}(h]h ]h"]h$]h&]uh1jhjshKahjrubah}(h]h ]h"]h$]h&]uh1jhjrubh)}(h**Description**h]j)}(hjCsh]h Description}(hjEshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAsubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKchjrubh)}(hThis acquires additional reference to :c:type:`drm_syncobj.fence ` contained in **obj**, if not NULL. It is illegal to call this without already holding a reference. No locks required.h](h&This acquires additional reference to }(hjYshhhNhNubh)}(h):c:type:`drm_syncobj.fence `h]j)}(hjcsh]hdrm_syncobj.fence}(hjeshhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjasubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_syncobjuh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKbhjYsubh contained in }(hjYshhhNhNubj)}(h**obj**h]hobj}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYsubha, if not NULL. It is illegal to call this without already holding a reference. No locks required.}(hjYshhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjshKbhjrubh)}(h **Return**h]j)}(hjsh]hReturn}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKfhjrubh)}(h4Either the fence of **obj** or NULL if there's none.h](hEither the fence of }(hjshhhNhNubj)}(h**obj**h]hobj}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubh or NULL if there’s none.}(hjshhhNhNubeh}(h]h ]h"]h$]h&]uh1hhU/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:549: ./include/drm/drm_syncobj.hhKghjrubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_syncobj_find (C function)c.drm_syncobj_findhNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hQstruct drm_syncobj * drm_syncobj_find (struct drm_file *file_private, u32 handle)h]j>)}(hOstruct drm_syncobj *drm_syncobj_find(struct drm_file *file_private, u32 handle)h](jD)}(hjh]hstruct}(hjshhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjshhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjshhhjthKubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]j )}jdrm_syncobj_findsbc.drm_syncobj_findasbuh1hhjshhhjthKubjV)}(h h]h }(hj6thhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjshhhjthKubj4)}(hj7h]h*}(hjDthhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjshhhjthKubjg)}(hdrm_syncobj_findh]jm)}(hj3th]hdrm_syncobj_find}(hjUthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQtubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjshhhjthKubj)}(h+(struct drm_file *file_private, u32 handle)h](j)}(hstruct drm_file *file_privateh](jD)}(hjh]hstruct}(hjpthhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjltubjV)}(h h]h }(hj}thhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjltubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]j1tc.drm_syncobj_findasbuh1hhjltubjV)}(h h]h }(hjthhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjltubj4)}(hj7h]h*}(hjthhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjltubjm)}(h file_privateh]h file_private}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjltubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhtubj)}(h u32 handleh](h)}(hhh]jm)}(hu32h]hu32}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjtmodnameN classnameNjj)}j]j1tc.drm_syncobj_findasbuh1hhjtubjV)}(h h]h }(hjuhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjtubjm)}(hhandleh]hhandle}(hjuhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjtubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhtubeh}(h]h ]h"]h$]h&]jjuh1jhjshhhjthKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjshhhjthKubah}(h]jsah ](jjeh"]h$]h&]jj)jhuh1j7hjthKhjshhubj)}(hhh]h)}(h#lookup and reference a sync object.h]h#lookup and reference a sync object.}(hj9uhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKhj6uhhubah}(h]h ]h"]h$]h&]uh1jhjshhhjthKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjQujjQujjjuh1j2hhhjdhNhNubj)}(hX **Parameters** ``struct drm_file *file_private`` drm file private pointer ``u32 handle`` sync object handle to lookup. **Description** Returns a reference to the syncobj pointed to by handle or NULL. The reference must be released by calling drm_syncobj_put().h](h)}(h**Parameters**h]j)}(hj[uh]h Parameters}(hj]uhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYuubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKhjUuubj)}(hhh](j)}(h;``struct drm_file *file_private`` drm file private pointer h](j)}(h!``struct drm_file *file_private``h]j)}(hjzuh]hstruct drm_file *file_private}(hj|uhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxuubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKhjtuubj )}(hhh]h)}(hdrm file private pointerh]hdrm file private pointer}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhKhjuubah}(h]h ]h"]h$]h&]uh1j hjtuubeh}(h]h ]h"]h$]h&]uh1jhjuhKhjquubj)}(h-``u32 handle`` sync object handle to lookup. h](j)}(h``u32 handle``h]j)}(hjuh]h u32 handle}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKhjuubj )}(hhh]h)}(hsync object handle to lookup.h]hsync object handle to lookup.}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjuhKhjuubah}(h]h ]h"]h$]h&]uh1j hjuubeh}(h]h ]h"]h$]h&]uh1jhjuhKhjquubeh}(h]h ]h"]h$]h&]uh1jhjUuubh)}(h**Description**h]j)}(hjuh]h Description}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKhjUuubh)}(h}Returns a reference to the syncobj pointed to by handle or NULL. The reference must be released by calling drm_syncobj_put().h]h}Returns a reference to the syncobj pointed to by handle or NULL. The reference must be released by calling drm_syncobj_put().}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chKhjUuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_syncobj_add_point (C function)c.drm_syncobj_add_pointhNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hvoid drm_syncobj_add_point (struct drm_syncobj *syncobj, struct dma_fence_chain *chain, struct dma_fence *fence, uint64_t point)h]j>)}(hvoid drm_syncobj_add_point(struct drm_syncobj *syncobj, struct dma_fence_chain *chain, struct dma_fence *fence, uint64_t point)h](j)}(hvoidh]hvoid}(hj3vhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj/vhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMEubjV)}(h h]h }(hjBvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj/vhhhjAvhMEubjg)}(hdrm_syncobj_add_pointh]jm)}(hdrm_syncobj_add_pointh]hdrm_syncobj_add_point}(hjTvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjPvubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj/vhhhjAvhMEubj)}(he(struct drm_syncobj *syncobj, struct dma_fence_chain *chain, struct dma_fence *fence, uint64_t point)h](j)}(hstruct drm_syncobj *syncobjh](jD)}(hjh]hstruct}(hjpvhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjlvubjV)}(h h]h }(hj}vhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjlvubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjvmodnameN classnameNjj)}j]j )}jjVvsbc.drm_syncobj_add_pointasbuh1hhjlvubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjlvubj4)}(hj7h]h*}(hjvhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjlvubjm)}(hsyncobjh]hsyncobj}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjlvubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhvubj)}(hstruct dma_fence_chain *chainh](jD)}(hjh]hstruct}(hjvhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjvubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjvubh)}(hhh]jm)}(hdma_fence_chainh]hdma_fence_chain}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjwmodnameN classnameNjj)}j]jvc.drm_syncobj_add_pointasbuh1hhjvubjV)}(h h]h }(hjwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjvubj4)}(hj7h]h*}(hj,whhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjvubjm)}(hchainh]hchain}(hj9whhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjvubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhvubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hjRwhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjNwubjV)}(h h]h }(hj_whhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNwubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hjpwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmwubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjrwmodnameN classnameNjj)}j]jvc.drm_syncobj_add_pointasbuh1hhjNwubjV)}(h h]h }(hjwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjNwubj4)}(hj7h]h*}(hjwhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjNwubjm)}(hfenceh]hfence}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjNwubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhvubj)}(huint64_t pointh](h)}(hhh]jm)}(huint64_th]huint64_t}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjwubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjwmodnameN classnameNjj)}j]jvc.drm_syncobj_add_pointasbuh1hhjwubjV)}(h h]h }(hjwhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjwubjm)}(hpointh]hpoint}(hjwhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjwubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjhvubeh}(h]h ]h"]h$]h&]jjuh1jhj/vhhhjAvhMEubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj+vhhhjAvhMEubah}(h]j&vah ](jjeh"]h$]h&]jj)jhuh1j7hjAvhMEhj(vhhubj)}(hhh]h)}(h%add new timeline point to the syncobjh]h%add new timeline point to the syncobj}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMEhjxhhubah}(h]h ]h"]h$]h&]uh1jhj(vhhhjAvhMEubeh}(h]h ](jfunctioneh"]h$]h&]jjjj3xjj3xjjjuh1j2hhhjdhNhNubj)}(hXj**Parameters** ``struct drm_syncobj *syncobj`` sync object to add timeline point do ``struct dma_fence_chain *chain`` chain node to use to add the point ``struct dma_fence *fence`` fence to encapsulate in the chain node ``uint64_t point`` sequence number to use for the point **Description** Add the chain node as new timeline point to the syncobj.h](h)}(h**Parameters**h]j)}(hj=xh]h Parameters}(hj?xhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;xubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMIhj7xubj)}(hhh](j)}(hE``struct drm_syncobj *syncobj`` sync object to add timeline point do h](j)}(h``struct drm_syncobj *syncobj``h]j)}(hj\xh]hstruct drm_syncobj *syncobj}(hj^xhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZxubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMFhjVxubj )}(hhh]h)}(h$sync object to add timeline point doh]h$sync object to add timeline point do}(hjuxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjqxhMFhjrxubah}(h]h ]h"]h$]h&]uh1j hjVxubeh}(h]h ]h"]h$]h&]uh1jhjqxhMFhjSxubj)}(hE``struct dma_fence_chain *chain`` chain node to use to add the point h](j)}(h!``struct dma_fence_chain *chain``h]j)}(hjxh]hstruct dma_fence_chain *chain}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMGhjxubj )}(hhh]h)}(h"chain node to use to add the pointh]h"chain node to use to add the point}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMGhjxubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhMGhjSxubj)}(hC``struct dma_fence *fence`` fence to encapsulate in the chain node h](j)}(h``struct dma_fence *fence``h]j)}(hjxh]hstruct dma_fence *fence}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMHhjxubj )}(hhh]h)}(h&fence to encapsulate in the chain nodeh]h&fence to encapsulate in the chain node}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhMHhjxubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjxhMHhjSxubj)}(h8``uint64_t point`` sequence number to use for the point h](j)}(h``uint64_t point``h]j)}(hjyh]huint64_t point}(hj yhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMIhjyubj )}(hhh]h)}(h$sequence number to use for the pointh]h$sequence number to use for the point}(hj yhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMIhjyubah}(h]h ]h"]h$]h&]uh1j hjyubeh}(h]h ]h"]h$]h&]uh1jhjyhMIhjSxubeh}(h]h ]h"]h$]h&]uh1jhj7xubh)}(h**Description**h]j)}(hjByh]h Description}(hjDyhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@yubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMKhj7xubh)}(h8Add the chain node as new timeline point to the syncobj.h]h8Add the chain node as new timeline point to the syncobj.}(hjXyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMJhj7xubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_syncobj_replace_fence (C function)c.drm_syncobj_replace_fencehNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hUvoid drm_syncobj_replace_fence (struct drm_syncobj *syncobj, struct dma_fence *fence)h]j>)}(hTvoid drm_syncobj_replace_fence(struct drm_syncobj *syncobj, struct dma_fence *fence)h](j)}(hvoidh]hvoid}(hjyhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjyhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMnubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyhhhjyhMnubjg)}(hdrm_syncobj_replace_fenceh]jm)}(hdrm_syncobj_replace_fenceh]hdrm_syncobj_replace_fence}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjyhhhjyhMnubj)}(h6(struct drm_syncobj *syncobj, struct dma_fence *fence)h](j)}(hstruct drm_syncobj *syncobjh](jD)}(hjh]hstruct}(hjyhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjyubjV)}(h h]h }(hjyhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjymodnameN classnameNjj)}j]j )}jjysbc.drm_syncobj_replace_fenceasbuh1hhjyubjV)}(h h]h }(hjzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjyubj4)}(hj7h]h*}(hjzhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjyubjm)}(hsyncobjh]hsyncobj}(hjzhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hj6zhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj2zubjV)}(h h]h }(hjCzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2zubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hjTzhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQzubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjVzmodnameN classnameNjj)}j]jyc.drm_syncobj_replace_fenceasbuh1hhj2zubjV)}(h h]h }(hjrzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2zubj4)}(hj7h]h*}(hjzhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj2zubjm)}(hfenceh]hfence}(hjzhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj2zubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjyubeh}(h]h ]h"]h$]h&]jjuh1jhjyhhhjyhMnubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjyhhhjyhMnubah}(h]jzyah ](jjeh"]h$]h&]jj)jhuh1j7hjyhMnhj|yhhubj)}(hhh]h)}(hreplace fence in a sync object.h]hreplace fence in a sync object.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMnhjzhhubah}(h]h ]h"]h$]h&]uh1jhj|yhhhjyhMnubeh}(h]h ](jfunctioneh"]h$]h&]jjjjzjjzjjjuh1j2hhhjdhNhNubj)}(h**Parameters** ``struct drm_syncobj *syncobj`` Sync object to replace fence in ``struct dma_fence *fence`` fence to install in sync file. **Description** This replaces the fence on a sync object.h](h)}(h**Parameters**h]j)}(hjzh]h Parameters}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMrhjzubj)}(hhh](j)}(h@``struct drm_syncobj *syncobj`` Sync object to replace fence in h](j)}(h``struct drm_syncobj *syncobj``h]j)}(hjzh]hstruct drm_syncobj *syncobj}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMohjzubj )}(hhh]h)}(hSync object to replace fence inh]hSync object to replace fence in}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj {hMohj{ubah}(h]h ]h"]h$]h&]uh1j hjzubeh}(h]h ]h"]h$]h&]uh1jhj {hMohjzubj)}(h;``struct dma_fence *fence`` fence to install in sync file. h](j)}(h``struct dma_fence *fence``h]j)}(hj1{h]hstruct dma_fence *fence}(hj3{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/{ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMphj+{ubj )}(hhh]h)}(hfence to install in sync file.h]hfence to install in sync file.}(hjJ{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjF{hMphjG{ubah}(h]h ]h"]h$]h&]uh1j hj+{ubeh}(h]h ]h"]h$]h&]uh1jhjF{hMphjzubeh}(h]h ]h"]h$]h&]uh1jhjzubh)}(h**Description**h]j)}(hjl{h]h Description}(hjn{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjj{ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMrhjzubh)}(h)This replaces the fence on a sync object.h]h)This replaces the fence on a sync object.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMqhjzubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_syncobj_find_fence (C function)c.drm_syncobj_find_fencehNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hvint drm_syncobj_find_fence (struct drm_file *file_private, u32 handle, u64 point, u64 flags, struct dma_fence **fence)h]j>)}(huint drm_syncobj_find_fence(struct drm_file *file_private, u32 handle, u64 point, u64 flags, struct dma_fence **fence)h](j)}(hinth]hint}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj{hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{hhhj{hMubjg)}(hdrm_syncobj_find_fenceh]jm)}(hdrm_syncobj_find_fenceh]hdrm_syncobj_find_fence}(hj{hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj{hhhj{hMubj)}(h[(struct drm_file *file_private, u32 handle, u64 point, u64 flags, struct dma_fence **fence)h](j)}(hstruct drm_file *file_privateh](jD)}(hjh]hstruct}(hj{hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj{ubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj |hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj |ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj|modnameN classnameNjj)}j]j )}jj{sbc.drm_syncobj_find_fenceasbuh1hhj{ubjV)}(h h]h }(hj,|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj{ubj4)}(hj7h]h*}(hj:|hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj{ubjm)}(h file_privateh]h file_private}(hjG|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj{ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(h u32 handleh](h)}(hhh]jm)}(hu32h]hu32}(hjc|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetje|modnameN classnameNjj)}j]j(|c.drm_syncobj_find_fenceasbuh1hhj\|ubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj\|ubjm)}(hhandleh]hhandle}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj\|ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(h u64 pointh](h)}(hhh]jm)}(hu64h]hu64}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj|modnameN classnameNjj)}j]j(|c.drm_syncobj_find_fenceasbuh1hhj|ubjV)}(h h]h }(hj|hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj|ubjm)}(hpointh]hpoint}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(h u64 flagsh](h)}(hhh]jm)}(hu64h]hu64}(hj|hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj|modnameN classnameNjj)}j]j(|c.drm_syncobj_find_fenceasbuh1hhj|ubjV)}(h h]h }(hj}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj|ubjm)}(hflagsh]hflags}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubj)}(hstruct dma_fence **fenceh](jD)}(hjh]hstruct}(hj8}hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4}ubjV)}(h h]h }(hjE}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4}ubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hjV}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjS}ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjX}modnameN classnameNjj)}j]j(|c.drm_syncobj_find_fenceasbuh1hhj4}ubjV)}(h h]h }(hjt}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4}ubj4)}(hj7h]h*}(hj}hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj4}ubj4)}(hj7h]h*}(hj}hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj4}ubjm)}(hfenceh]hfence}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4}ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj{ubeh}(h]h ]h"]h$]h&]jjuh1jhj{hhhj{hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj{hhhj{hMubah}(h]j{ah ](jjeh"]h$]h&]jj)jhuh1j7hj{hMhj{hhubj)}(hhh]h)}(h/lookup and reference the fence in a sync objecth]h/lookup and reference the fence in a sync object}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj}hhubah}(h]h ]h"]h$]h&]uh1jhj{hhhj{hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj}jj}jjjuh1j2hhhjdhNhNubj)}(hX2**Parameters** ``struct drm_file *file_private`` drm file private pointer ``u32 handle`` sync object handle to lookup. ``u64 point`` timeline point ``u64 flags`` DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT or not ``struct dma_fence **fence`` out parameter for the fence **Description** This is just a convenience function that combines drm_syncobj_find() and drm_syncobj_fence_get(). Returns 0 on success or a negative error value on failure. On success **fence** contains a reference to the fence, which must be released by calling dma_fence_put().h](h)}(h**Parameters**h]j)}(hj}h]h Parameters}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj}ubj)}(hhh](j)}(h;``struct drm_file *file_private`` drm file private pointer Jh](j)}(h!``struct drm_file *file_private``h]j)}(hj~h]hstruct drm_file *file_private}(hj ~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj~ubj )}(hhh]h)}(hdrm file private pointerh]hdrm file private pointer}(hj ~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubah}(h]h ]h"]h$]h&]uh1j hj~ubeh}(h]h ]h"]h$]h&]uh1jhj~hMhj}ubj)}(h-``u32 handle`` sync object handle to lookup. h](j)}(h``u32 handle``h]j)}(hj@~h]h u32 handle}(hjB~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>~ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj:~ubj )}(hhh]h)}(hsync object handle to lookup.h]hsync object handle to lookup.}(hjY~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjU~hMhjV~ubah}(h]h ]h"]h$]h&]uh1j hj:~ubeh}(h]h ]h"]h$]h&]uh1jhjU~hMhj}ubj)}(h``u64 point`` timeline point h](j)}(h ``u64 point``h]j)}(hjy~h]h u64 point}(hj{~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjw~ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjs~ubj )}(hhh]h)}(htimeline pointh]htimeline point}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubah}(h]h ]h"]h$]h&]uh1j hjs~ubeh}(h]h ]h"]h$]h&]uh1jhj~hMhj}ubj)}(h<``u64 flags`` DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT or not h](j)}(h ``u64 flags``h]j)}(hj~h]h u64 flags}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj~ubj )}(hhh]h)}(h-DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT or noth]h-DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT or not}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hMhj~ubah}(h]h ]h"]h$]h&]uh1j hj~ubeh}(h]h ]h"]h$]h&]uh1jhj~hMhj}ubj)}(h9``struct dma_fence **fence`` out parameter for the fence h](j)}(h``struct dma_fence **fence``h]j)}(hj~h]hstruct dma_fence **fence}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj~ubj )}(hhh]h)}(hout parameter for the fenceh]hout parameter for the fence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hj~ubeh}(h]h ]h"]h$]h&]uh1jhjhMhj}ubeh}(h]h ]h"]h$]h&]uh1jhj}ubh)}(h**Description**h]j)}(hj&h]h Description}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj$ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj}ubh)}(haThis is just a convenience function that combines drm_syncobj_find() and drm_syncobj_fence_get().h]haThis is just a convenience function that combines drm_syncobj_find() and drm_syncobj_fence_get().}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj}ubh)}(hReturns 0 on success or a negative error value on failure. On success **fence** contains a reference to the fence, which must be released by calling dma_fence_put().h](hFReturns 0 on success or a negative error value on failure. On success }(hjKhhhNhNubj)}(h **fence**h]hfence}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubhV contains a reference to the fence, which must be released by calling dma_fence_put().}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj}ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_syncobj_free (C function)c.drm_syncobj_freehNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(h)void drm_syncobj_free (struct kref *kref)h]j>)}(h(void drm_syncobj_free(struct kref *kref)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM ubjg)}(hdrm_syncobj_freeh]jm)}(hdrm_syncobj_freeh]hdrm_syncobj_free}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM ubj)}(h(struct kref *kref)h]j)}(hstruct kref *krefh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hkrefh]hkref}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_syncobj_freeasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hkrefh]hkref}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM hjhhubj)}(hhh]h)}(hfree a sync object.h]hfree a sync object.}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM hjIhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjdjjdjjjuh1j2hhhjdhNhNubj)}(h{**Parameters** ``struct kref *kref`` kref to free. **Description** Only to be called from kref_put in drm_syncobj_put.h](h)}(h**Parameters**h]j)}(hjnh]h Parameters}(hjphhhNhNubah}(h]h ]h"]h$]h&]uh1jhjlubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM hjhubj)}(hhh]j)}(h$``struct kref *kref`` kref to free. h](j)}(h``struct kref *kref``h]j)}(hjh]hstruct kref *kref}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM hjubj )}(hhh]h)}(h kref to free.h]h kref to free.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjubah}(h]h ]h"]h$]h&]uh1jhjhubh)}(h**Description**h]j)}(hjȀh]h Description}(hjʀhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjƀubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM hjhubh)}(h3Only to be called from kref_put in drm_syncobj_put.h]h3Only to be called from kref_put in drm_syncobj_put.}(hjހhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM hjhubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_syncobj_create (C function)c.drm_syncobj_createhNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hbint drm_syncobj_create (struct drm_syncobj **out_syncobj, uint32_t flags, struct dma_fence *fence)h]j>)}(haint drm_syncobj_create(struct drm_syncobj **out_syncobj, uint32_t flags, struct dma_fence *fence)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhjhMubjg)}(hdrm_syncobj_createh]jm)}(hdrm_syncobj_createh]hdrm_syncobj_create}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj*ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhjhMubj)}(hK(struct drm_syncobj **out_syncobj, uint32_t flags, struct dma_fence *fence)h](j)}(h struct drm_syncobj **out_syncobjh](jD)}(hjh]hstruct}(hjJhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjFubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjeubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjjmodnameN classnameNjj)}j]j )}jj0sbc.drm_syncobj_createasbuh1hhjFubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjFubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjFubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjFubjm)}(h out_syncobjh]h out_syncobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjFubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubj)}(huint32_t flagsh](h)}(hhh]jm)}(huint32_th]huint32_t}(hj́hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjɁubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj΁modnameN classnameNjj)}j]jc.drm_syncobj_createasbuh1hhjŁubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjŁubjm)}(hflagsh]hflags}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjŁubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]jc.drm_syncobj_createasbuh1hhj ubjV)}(h h]h }(hjMhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj[hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hfenceh]hfence}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjBubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hcreate a new syncobjh]hcreate a new syncobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjdhNhNubj)}(hX**Parameters** ``struct drm_syncobj **out_syncobj`` returned syncobj ``uint32_t flags`` DRM_SYNCOBJ_* flags ``struct dma_fence *fence`` if non-NULL, the syncobj will represent this fence **Description** This is the first function to create a sync object. After creating, drivers probably want to make it available to userspace, either through drm_syncobj_get_handle() or drm_syncobj_get_fd(). Returns 0 on success or a negative error value on failure.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM#hjubj)}(hhh](j)}(h6``struct drm_syncobj **out_syncobj`` returned syncobj h](j)}(h$``struct drm_syncobj **out_syncobj``h]j)}(hjӂh]h struct drm_syncobj **out_syncobj}(hjՂhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjтubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM hj͂ubj )}(hhh]h)}(hreturned syncobjh]hreturned syncobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hj͂ubeh}(h]h ]h"]h$]h&]uh1jhjhM hjʂubj)}(h'``uint32_t flags`` DRM_SYNCOBJ_* flags h](j)}(h``uint32_t flags``h]j)}(hj h]huint32_t flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM!hjubj )}(hhh]h)}(hDRM_SYNCOBJ_* flagsh]hDRM_SYNCOBJ_* flags}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hM!hj"ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj!hM!hjʂubj)}(hO``struct dma_fence *fence`` if non-NULL, the syncobj will represent this fence h](j)}(h``struct dma_fence *fence``h]j)}(hjEh]hstruct dma_fence *fence}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM"hj?ubj )}(hhh]h)}(h2if non-NULL, the syncobj will represent this fenceh]h2if non-NULL, the syncobj will represent this fence}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM"hj[ubah}(h]h ]h"]h$]h&]uh1j hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhM"hjʂubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM$hjubh)}(hThis is the first function to create a sync object. After creating, drivers probably want to make it available to userspace, either through drm_syncobj_get_handle() or drm_syncobj_get_fd().h]hThis is the first function to create a sync object. After creating, drivers probably want to make it available to userspace, either through drm_syncobj_get_handle() or drm_syncobj_get_fd().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM#hjubh)}(h:Returns 0 on success or a negative error value on failure.h]h:Returns 0 on success or a negative error value on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chM'hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_syncobj_get_handle (C function)c.drm_syncobj_get_handlehNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(hdint drm_syncobj_get_handle (struct drm_file *file_private, struct drm_syncobj *syncobj, u32 *handle)h]j>)}(hcint drm_syncobj_get_handle(struct drm_file *file_private, struct drm_syncobj *syncobj, u32 *handle)h](j)}(hinth]hint}(hjԃhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjЃhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMJubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjЃhhhjhMJubjg)}(hdrm_syncobj_get_handleh]jm)}(hdrm_syncobj_get_handleh]hdrm_syncobj_get_handle}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjЃhhhjhMJubj)}(hI(struct drm_file *file_private, struct drm_syncobj *syncobj, u32 *handle)h](j)}(hstruct drm_file *file_privateh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj,ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj1modnameN classnameNjj)}j]j )}jjsbc.drm_syncobj_get_handleasbuh1hhj ubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj]hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(h file_privateh]h file_private}(hjjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct drm_syncobj *syncobjh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jKc.drm_syncobj_get_handleasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj̈́hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hsyncobjh]hsyncobj}(hjڄhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(h u32 *handleh](h)}(hhh]jm)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jKc.drm_syncobj_get_handleasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj"hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hhandleh]hhandle}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjЃhhhjhMJubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj̃hhhjhMJubah}(h]jǃah ](jjeh"]h$]h&]jj)jhuh1j7hjhMJhjɃhhubj)}(hhh]h)}(hget a handle from a syncobjh]hget a handle from a syncobj}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMJhjVhhubah}(h]h ]h"]h$]h&]uh1jhjɃhhhjhMJubeh}(h]h ](jfunctioneh"]h$]h&]jjjjqjjqjjjuh1j2hhhjdhNhNubj)}(hXn**Parameters** ``struct drm_file *file_private`` drm file private pointer ``struct drm_syncobj *syncobj`` Sync object to export ``u32 *handle`` out parameter with the new handle **Description** Exports a sync object created with drm_syncobj_create() as a handle on **file_private** to userspace. Returns 0 on success or a negative error value on failure.h](h)}(h**Parameters**h]j)}(hj{h]h Parameters}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMNhjuubj)}(hhh](j)}(h;``struct drm_file *file_private`` drm file private pointer h](j)}(h!``struct drm_file *file_private``h]j)}(hjh]hstruct drm_file *file_private}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMKhjubj )}(hhh]h)}(hdrm file private pointerh]hdrm file private pointer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMKhjubj)}(h6``struct drm_syncobj *syncobj`` Sync object to export h](j)}(h``struct drm_syncobj *syncobj``h]j)}(hjӅh]hstruct drm_syncobj *syncobj}(hjՅhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjхubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMLhjͅubj )}(hhh]h)}(hSync object to exporth]hSync object to export}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMLhjubah}(h]h ]h"]h$]h&]uh1j hjͅubeh}(h]h ]h"]h$]h&]uh1jhjhMLhjubj)}(h2``u32 *handle`` out parameter with the new handle h](j)}(h``u32 *handle``h]j)}(hj h]h u32 *handle}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMMhjubj )}(hhh]h)}(h!out parameter with the new handleh]h!out parameter with the new handle}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj!hMMhj"ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj!hMMhjubeh}(h]h ]h"]h$]h&]uh1jhjuubh)}(h**Description**h]j)}(hjGh]h Description}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjEubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMOhjuubh)}(heExports a sync object created with drm_syncobj_create() as a handle on **file_private** to userspace.h](hGExports a sync object created with drm_syncobj_create() as a handle on }(hj]hhhNhNubj)}(h**file_private**h]h file_private}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubh to userspace.}(hj]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMNhjuubh)}(h:Returns 0 on success or a negative error value on failure.h]h:Returns 0 on success or a negative error value on failure.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMQhjuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_syncobj_get_fd (C function)c.drm_syncobj_get_fdhNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(h?int drm_syncobj_get_fd (struct drm_syncobj *syncobj, int *p_fd)h]j>)}(h>int drm_syncobj_get_fd(struct drm_syncobj *syncobj, int *p_fd)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_syncobj_get_fdh]jm)}(hdrm_syncobj_get_fdh]hdrm_syncobj_get_fd}(hjΆhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjʆubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h((struct drm_syncobj *syncobj, int *p_fd)h](j)}(hstruct drm_syncobj *syncobjh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_syncobjh]h drm_syncobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jjІsbc.drm_syncobj_get_fdasbuh1hhjubjV)}(h h]h }(hj(hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj6hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hsyncobjh]hsyncobj}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h int *p_fdh](j)}(hinth]hint}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXubjV)}(h h]h }(hjjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXubj4)}(hj7h]h*}(hjxhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjXubjm)}(hp_fdh]hp_fd}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h$get a file descriptor from a syncobjh]h$get a file descriptor from a syncobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjLJjjLJjjjuh1j2hhhjdhNhNubj)}(hX**Parameters** ``struct drm_syncobj *syncobj`` Sync object to export ``int *p_fd`` out parameter with the new file descriptor **Description** Exports a sync object created with drm_syncobj_create() as a file descriptor. Returns 0 on success or a negative error value on failure.h](h)}(h**Parameters**h]j)}(hjчh]h Parameters}(hjӇhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjχubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjˇubj)}(hhh](j)}(h6``struct drm_syncobj *syncobj`` Sync object to export h](j)}(h``struct drm_syncobj *syncobj``h]j)}(hjh]hstruct drm_syncobj *syncobj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjubj )}(hhh]h)}(hSync object to exporth]hSync object to export}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h9``int *p_fd`` out parameter with the new file descriptor h](j)}(h ``int *p_fd``h]j)}(hj)h]h int *p_fd}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhj#ubj )}(hhh]h)}(h*out parameter with the new file descriptorh]h*out parameter with the new file descriptor}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj>hMhj?ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hMhjubeh}(h]h ]h"]h$]h&]uh1jhjˇubh)}(h**Description**h]j)}(hjdh]h Description}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjˇubh)}(hMExports a sync object created with drm_syncobj_create() as a file descriptor.h]hMExports a sync object created with drm_syncobj_create() as a file descriptor.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjˇubh)}(h:Returns 0 on success or a negative error value on failure.h]h:Returns 0 on success or a negative error value on failure.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhY/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:552: ./drivers/gpu/drm/drm_syncobj.chMhjˇubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjdhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.'drm_timeout_abs_to_jiffies (C function)c.drm_timeout_abs_to_jiffieshNtauh1j!hjdhhhNhNubj3)}(hhh](j8)}(h=signed long drm_timeout_abs_to_jiffies (int64_t timeout_nsec)h]j>)}(hresv, fence, DMA_RESV_USAGE_READ); ... } drm_exec_fini(&exec);h]hX`struct drm_gem_object *obj; struct drm_exec exec; unsigned long index; int ret; drm_exec_init(&exec, DRM_EXEC_INTERRUPTIBLE_WAIT); drm_exec_until_all_locked(&exec) { ret = drm_exec_prepare_obj(&exec, boA, 1); drm_exec_retry_on_contention(&exec); if (ret) goto error; ret = drm_exec_prepare_obj(&exec, boB, 1); drm_exec_retry_on_contention(&exec); if (ret) goto error; } drm_exec_for_each_locked_object(&exec, index, obj) { dma_resv_add_fence(obj->resv, fence, DMA_RESV_USAGE_READ); ... } drm_exec_fini(&exec);}hjlsbah}(h]h ]h"]h$]h&]jjuh1jShV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:558: ./drivers/gpu/drm/drm_exec.chKhjhhubh)}(h%See struct dma_exec for more details.h]h%See struct dma_exec for more details.}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:558: ./drivers/gpu/drm/drm_exec.chK/hjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_exec (C struct) c.drm_exechNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_exech]j>)}(hstruct drm_exech](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_exech]jm)}(hjh]hdrm_exec}(hjÊhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhjhhubj)}(hhh]h)}(hExecution contexth]hExecution context}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Definition**:: struct drm_exec { u32 flags; struct ww_acquire_ctx ticket; unsigned int num_objects; unsigned int max_objects; struct drm_gem_object **objects; struct drm_gem_object *contended; struct drm_gem_object *prelocked; }; **Members** ``flags`` Flags to control locking behavior ``ticket`` WW ticket used for acquiring locks ``num_objects`` number of objects locked ``max_objects`` maximum objects in array ``objects`` array of the locked objects ``contended`` contended GEM object we backed off for ``prelocked`` already locked GEM object due to contentionh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjubjT)}(hXstruct drm_exec { u32 flags; struct ww_acquire_ctx ticket; unsigned int num_objects; unsigned int max_objects; struct drm_gem_object **objects; struct drm_gem_object *contended; struct drm_gem_object *prelocked; };h]hXstruct drm_exec { u32 flags; struct ww_acquire_ctx ticket; unsigned int num_objects; unsigned int max_objects; struct drm_gem_object **objects; struct drm_gem_object *contended; struct drm_gem_object *prelocked; };}hj"sbah}(h]h ]h"]h$]h&]jjuh1jShR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjubh)}(h **Members**h]j)}(hj3h]hMembers}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjubj)}(hhh](j)}(h,``flags`` Flags to control locking behavior h](j)}(h ``flags``h]j)}(hjRh]hflags}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1jhjPubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjLubj )}(hhh]h)}(h!Flags to control locking behaviorh]h!Flags to control locking behavior}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjghKhjhubah}(h]h ]h"]h$]h&]uh1j hjLubeh}(h]h ]h"]h$]h&]uh1jhjghKhjIubj)}(h.``ticket`` WW ticket used for acquiring locks h](j)}(h ``ticket``h]j)}(hjh]hticket}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjubj )}(hhh]h)}(h"WW ticket used for acquiring locksh]h"WW ticket used for acquiring locks}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjIubj)}(h)``num_objects`` number of objects locked h](j)}(h``num_objects``h]j)}(hjċh]h num_objects}(hjƋhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj‹ubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjubj )}(hhh]h)}(hnumber of objects lockedh]hnumber of objects locked}(hj݋hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjًhKhjڋubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjًhKhjIubj)}(h)``max_objects`` maximum objects in array h](j)}(h``max_objects``h]j)}(hjh]h max_objects}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK#hjubj )}(hhh]h)}(hmaximum objects in arrayh]hmaximum objects in array}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK#hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK#hjIubj)}(h(``objects`` array of the locked objects h](j)}(h ``objects``h]j)}(hj6h]hobjects}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK(hj0ubj )}(hhh]h)}(harray of the locked objectsh]harray of the locked objects}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhK(hjLubah}(h]h ]h"]h$]h&]uh1j hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhK(hjIubj)}(h5``contended`` contended GEM object we backed off for h](j)}(h ``contended``h]j)}(hjoh]h contended}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK-hjiubj )}(hhh]h)}(h&contended GEM object we backed off forh]h&contended GEM object we backed off for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK-hjubah}(h]h ]h"]h$]h&]uh1j hjiubeh}(h]h ]h"]h$]h&]uh1jhjhK-hjIubj)}(h9``prelocked`` already locked GEM object due to contentionh](j)}(h ``prelocked``h]j)}(hjh]h prelocked}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK1hjubj )}(hhh]h)}(h+already locked GEM object due to contentionh]h+already locked GEM object due to contention}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK2hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK1hjIubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_exec_obj (C function)c.drm_exec_objhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hQstruct drm_gem_object * drm_exec_obj (struct drm_exec *exec, unsigned long index)h]j>)}(hOstruct drm_gem_object *drm_exec_obj(struct drm_exec *exec, unsigned long index)h](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK7ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhK7ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj#modnameN classnameNjj)}j]j )}j drm_exec_objsbc.drm_exec_objasbuh1hhjhhhjhK7ubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhK7ubj4)}(hj7h]h*}(hjPhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjhhhjhK7ubjg)}(h drm_exec_objh]jm)}(hj?h]h drm_exec_obj}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhK7ubj)}(h,(struct drm_exec *exec, unsigned long index)h](j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hj|hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjxubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j=c.drm_exec_objasbuh1hhjxubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjxubj4)}(hj7h]h*}(hjƍhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjxubjm)}(hexech]hexec}(hjӍhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjxubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubj)}(hunsigned long indexh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hindexh]hindex}(hj$hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjtubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhK7ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhK7ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhK7hjhhubj)}(hhh]h)}(h+Return the object for a give drm_exec indexh]h+Return the object for a give drm_exec index}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK7hjKhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhK7ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjfjjfjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_exec *exec`` Pointer to the drm_exec context ``unsigned long index`` The index. **Return** Pointer to the locked object corresponding to **index** if index is within the number of locked objects. NULL otherwise.h](h)}(h**Parameters**h]j)}(hjph]h Parameters}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK;hjjubj)}(hhh](j)}(h:``struct drm_exec *exec`` Pointer to the drm_exec context h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK8hjubj )}(hhh]h)}(hPointer to the drm_exec contexth]hPointer to the drm_exec context}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK8hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK8hjubj)}(h#``unsigned long index`` The index. h](j)}(h``unsigned long index``h]j)}(hjȎh]hunsigned long index}(hjʎhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjƎubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK9hjŽubj )}(hhh]h)}(h The index.h]h The index.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjݎhK9hjގubah}(h]h ]h"]h$]h&]uh1j hjŽubeh}(h]h ]h"]h$]h&]uh1jhjݎhK9hjubeh}(h]h ]h"]h$]h&]uh1jhjjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK;hjjubh)}(hxPointer to the locked object corresponding to **index** if index is within the number of locked objects. NULL otherwise.h](h.Pointer to the locked object corresponding to }(hjhhhNhNubj)}(h **index**h]hindex}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhA if index is within the number of locked objects. NULL otherwise.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK;hjjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_exec_for_each_locked_object (C macro)!c.drm_exec_for_each_locked_objecthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_exec_for_each_locked_objecth]j>)}(hdrm_exec_for_each_locked_objecth]jg)}(hdrm_exec_for_each_locked_objecth]jm)}(hjTh]hdrm_exec_for_each_locked_object}(hj^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjVhhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKEubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjRhhhjqhKEubah}(h]jMah ](jjeh"]h$]h&]jj)jhuh1j7hjqhKEhjOhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjOhhhjqhKEubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubh)}(h6``drm_exec_for_each_locked_object (exec, index, obj)``h]j)}(hjh]h2drm_exec_for_each_locked_object (exec, index, obj)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKGhjhhubj)}(h$iterate over all the locked objects h]h)}(h#iterate over all the locked objectsh]h#iterate over all the locked objects}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKEhjubah}(h]h ]h"]h$]h&]uh1jhjhKEhjhhubj)}(h**Parameters** ``exec`` drm_exec object ``index`` unsigned long index for the iteration ``obj`` the current GEM object **Description** Iterate over all the locked GEM objects inside the drm_exec object.h](h)}(h**Parameters**h]j)}(hjŏh]h Parameters}(hjǏhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjÏubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKIhjubj)}(hhh](j)}(h``exec`` drm_exec object h](j)}(h``exec``h]j)}(hjh]hexec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKFhjޏubj )}(hhh]h)}(hdrm_exec objecth]hdrm_exec object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKFhjubah}(h]h ]h"]h$]h&]uh1j hjޏubeh}(h]h ]h"]h$]h&]uh1jhjhKFhjۏubj)}(h0``index`` unsigned long index for the iteration h](j)}(h ``index``h]j)}(hjh]hindex}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKGhjubj )}(hhh]h)}(h%unsigned long index for the iterationh]h%unsigned long index for the iteration}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hKGhj3ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj2hKGhjۏubj)}(h``obj`` the current GEM object h](j)}(h``obj``h]j)}(hjVh]hobj}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKHhjPubj )}(hhh]h)}(hthe current GEM objecth]hthe current GEM object}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhKHhjlubah}(h]h ]h"]h$]h&]uh1j hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhKHhjۏubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKJhjubh)}(hCIterate over all the locked GEM objects inside the drm_exec object.h]hCIterate over all the locked GEM objects inside the drm_exec object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKIhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.1drm_exec_for_each_locked_object_reverse (C macro))c.drm_exec_for_each_locked_object_reversehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h'drm_exec_for_each_locked_object_reverseh]j>)}(h'drm_exec_for_each_locked_object_reverseh]jg)}(h'drm_exec_for_each_locked_object_reverseh]jm)}(hjАh]h'drm_exec_for_each_locked_object_reverse}(hjڐhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj֐ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjҐhhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKPubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjΐhhhjhKPubah}(h]jɐah ](jjeh"]h$]h&]jj)jhuh1j7hjhKPhjːhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjːhhhjhKPubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubh)}(h>``drm_exec_for_each_locked_object_reverse (exec, index, obj)``h]j)}(hj h]h:drm_exec_for_each_locked_object_reverse (exec, index, obj)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKRhjhhubj)}(h=iterate over all the locked objects in reverse locking order h]h)}(h)}(hdrm_exec_until_all_lockedh]jg)}(hdrm_exec_until_all_lockedh]jm)}(hj^h]hdrm_exec_until_all_locked}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj`hhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK_ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj\hhhj{hK_ubah}(h]jWah ](jjeh"]h$]h&]jj)jhuh1j7hj{hK_hjYhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjYhhhj{hK_ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubh)}(h$``drm_exec_until_all_locked (exec)``h]j)}(hjh]h drm_exec_until_all_locked (exec)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKahjhhubj)}(h&loop until all GEM objects are locked h]h)}(h%loop until all GEM objects are lockedh]h%loop until all GEM objects are locked}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK_hjubah}(h]h ]h"]h$]h&]uh1jhj’hK_hjhhubj)}(hX**Parameters** ``exec`` drm_exec object **Description** Core functionality of the drm_exec object. Loops until all GEM objects are locked and no more contention exists. At the beginning of the loop it is guaranteed that no GEM object is locked. Since labels can't be defined local to the loops body we use a jump pointer to make sure that the retry is only used from within the loops body.h](h)}(h**Parameters**h]j)}(hjϒh]h Parameters}(hjђhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj͒ubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKchjɒubj)}(hhh]j)}(h``exec`` drm_exec object h](j)}(h``exec``h]j)}(hjh]hexec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhK`hjubj )}(hhh]h)}(hdrm_exec objecth]hdrm_exec object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK`hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK`hjubah}(h]h ]h"]h$]h&]uh1jhjɒubh)}(h**Description**h]j)}(hj)h]h Description}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKbhjɒubh)}(hCore functionality of the drm_exec object. Loops until all GEM objects are locked and no more contention exists. At the beginning of the loop it is guaranteed that no GEM object is locked.h]hCore functionality of the drm_exec object. Loops until all GEM objects are locked and no more contention exists. At the beginning of the loop it is guaranteed that no GEM object is locked.}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKahjɒubh)}(hSince labels can't be defined local to the loops body we use a jump pointer to make sure that the retry is only used from within the loops body.h]hSince labels can’t be defined local to the loops body we use a jump pointer to make sure that the retry is only used from within the loops body.}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKehjɒubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_exec_retry_on_contention (C macro)c.drm_exec_retry_on_contentionhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_exec_retry_on_contentionh]j>)}(hdrm_exec_retry_on_contentionh]jg)}(hdrm_exec_retry_on_contentionh]jm)}(hjwh]hdrm_exec_retry_on_contention}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj}ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjyhhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKrubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjuhhhjhKrubah}(h]jpah ](jjeh"]h$]h&]jj)jhuh1j7hjhKrhjrhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjrhhhjhKrubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubh)}(h'``drm_exec_retry_on_contention (exec)``h]j)}(hjh]h#drm_exec_retry_on_contention (exec)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKthjhhubj)}(h#restart the loop to grap all locks h]h)}(h"restart the loop to grap all locksh]h"restart the loop to grap all locks}(hj͓hhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKrhjɓubah}(h]h ]h"]h$]h&]uh1jhjۓhKrhjhhubj)}(h**Parameters** ``exec`` drm_exec object **Description** Control flow helper to continue when a contention was detected and we need to clean up and re-start the loop to prepare all GEM objects.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKvhjubj)}(hhh]j)}(h``exec`` drm_exec object h](j)}(h``exec``h]j)}(hjh]hexec}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKshjubj )}(hhh]h)}(hdrm_exec objecth]hdrm_exec object}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKshjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKshjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjBh]h Description}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKuhjubh)}(hControl flow helper to continue when a contention was detected and we need to clean up and re-start the loop to prepare all GEM objects.h]hControl flow helper to continue when a contention was detected and we need to clean up and re-start the loop to prepare all GEM objects.}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKthjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_exec_is_contended (C function)c.drm_exec_is_contendedhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h2bool drm_exec_is_contended (struct drm_exec *exec)h]j>)}(h1bool drm_exec_is_contended(struct drm_exec *exec)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_exec_is_contendedh]jm)}(hdrm_exec_is_contendedh]hdrm_exec_is_contended}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h(struct drm_exec *exec)h]j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjÔhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjДhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjޔubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_exec_is_contendedasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhj|hhubj)}(hhh]h)}(hcheck for contentionh]hcheck for contention}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjChhubah}(h]h ]h"]h$]h&]uh1jhj|hhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_exec *exec`` drm_exec object **Description** Returns true if the drm_exec object has run into some contention while locking a GEM object and needs to clean up.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjbubj)}(hhh]j)}(h*``struct drm_exec *exec`` drm_exec object h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjubj )}(hhh]h)}(hdrm_exec objecth]hdrm_exec object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj~ubah}(h]h ]h"]h$]h&]uh1jhjbubh)}(h**Description**h]j)}(hj•h]h Description}(hjĕhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjbubh)}(hrReturns true if the drm_exec object has run into some contention while locking a GEM object and needs to clean up.h]hrReturns true if the drm_exec object has run into some contention while locking a GEM object and needs to clean up.}(hjؕhhhNhNubah}(h]h ]h"]h$]h&]uh1hhR/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:561: ./include/drm/drm_exec.hhKhjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_exec_init (C function)c.drm_exec_inithNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hBvoid drm_exec_init (struct drm_exec *exec, u32 flags, unsigned nr)h]j>)}(hAvoid drm_exec_init(struct drm_exec *exec, u32 flags, unsigned nr)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKGubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKGubjg)}(h drm_exec_inith]jm)}(h drm_exec_inith]h drm_exec_init}(hj(hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj$ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKGubj)}(h/(struct drm_exec *exec, u32 flags, unsigned nr)h](j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjDhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj@ubjV)}(h h]h }(hjQhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj_ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjdmodnameN classnameNjj)}j]j )}jj*sbc.drm_exec_initasbuh1hhj@ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj@ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj@ubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj@ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubj)}(h u32 flagsh](h)}(hhh]jm)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j~c.drm_exec_initasbuh1hhjubjV)}(h h]h }(hjזhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hflagsh]hflags}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubj)}(h unsigned nrh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hnrh]hnr}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj<ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKGubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKGubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKGhjhhubj)}(hhh]h)}(hinitialize a drm_exec objecth]hinitialize a drm_exec object}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKGhjAhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKGubeh}(h]h ](jfunctioneh"]h$]h&]jjjj\jj\jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_exec *exec`` the drm_exec object to initialize ``u32 flags`` controls locking behavior, see DRM_EXEC_* defines ``unsigned nr`` the initial # of objects **Description** Initialize the object and make sure that we can track locked objects. If nr is non-zero then it is used as the initial objects table size. In either case, the table will grow (be re-allocated) on demand.h](h)}(h**Parameters**h]j)}(hjfh]h Parameters}(hjhhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjdubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKKhj`ubj)}(hhh](j)}(h<``struct drm_exec *exec`` the drm_exec object to initialize h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKHhjubj )}(hhh]h)}(h!the drm_exec object to initializeh]h!the drm_exec object to initialize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKHhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKHhj|ubj)}(h@``u32 flags`` controls locking behavior, see DRM_EXEC_* defines h](j)}(h ``u32 flags``h]j)}(hjh]h u32 flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKIhjubj )}(hhh]h)}(h1controls locking behavior, see DRM_EXEC_* definesh]h1controls locking behavior, see DRM_EXEC_* defines}(hjחhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjӗhKIhjԗubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjӗhKIhj|ubj)}(h)``unsigned nr`` the initial # of objects h](j)}(h``unsigned nr``h]j)}(hjh]h unsigned nr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKJhjubj )}(hhh]h)}(hthe initial # of objectsh]hthe initial # of objects}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKJhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hKJhj|ubeh}(h]h ]h"]h$]h&]uh1jhj`ubh)}(h**Description**h]j)}(hj2h]h Description}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKLhj`ubh)}(hEInitialize the object and make sure that we can track locked objects.h]hEInitialize the object and make sure that we can track locked objects.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKKhj`ubh)}(hIf nr is non-zero then it is used as the initial objects table size. In either case, the table will grow (be re-allocated) on demand.h]hIf nr is non-zero then it is used as the initial objects table size. In either case, the table will grow (be re-allocated) on demand.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKMhj`ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_exec_fini (C function)c.drm_exec_finihNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h*void drm_exec_fini (struct drm_exec *exec)h]j>)}(h)void drm_exec_fini(struct drm_exec *exec)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKbubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKbubjg)}(h drm_exec_finih]jm)}(h drm_exec_finih]h drm_exec_fini}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKbubj)}(h(struct drm_exec *exec)h]j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjØhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjИhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjޘubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_exec_finiasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKbubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj~hhhjhKbubah}(h]jyah ](jjeh"]h$]h&]jj)jhuh1j7hjhKbhj{hhubj)}(hhh]h)}(hfinalize a drm_exec objecth]hfinalize a drm_exec object}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKbhjChhubah}(h]h ]h"]h$]h&]uh1jhj{hhhjhKbubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_exec *exec`` the drm_exec object to finalize **Description** Unlock all locked objects, drop the references to objects and free all memory used for tracking the state.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKfhjbubj)}(hhh]j)}(h:``struct drm_exec *exec`` the drm_exec object to finalize h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKchjubj )}(hhh]h)}(hthe drm_exec object to finalizeh]hthe drm_exec object to finalize}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKchjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKchj~ubah}(h]h ]h"]h$]h&]uh1jhjbubh)}(h**Description**h]j)}(hj™h]h Description}(hjęhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKehjbubh)}(hjUnlock all locked objects, drop the references to objects and free all memory used for tracking the state.h]hjUnlock all locked objects, drop the references to objects and free all memory used for tracking the state.}(hjؙhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKdhjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_exec_cleanup (C function)c.drm_exec_cleanuphNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h-bool drm_exec_cleanup (struct drm_exec *exec)h]j>)}(h,bool drm_exec_cleanup(struct drm_exec *exec)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKtubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKtubjg)}(hdrm_exec_cleanuph]jm)}(hdrm_exec_cleanuph]hdrm_exec_cleanup}(hj'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj#ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKtubj)}(h(struct drm_exec *exec)h]j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjChhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj?ubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjcmodnameN classnameNjj)}j]j )}jj)sbc.drm_exec_cleanupasbuh1hhj?ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj?ubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj;ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKtubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKtubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhKthjhhubj)}(hhh]h)}(h#cleanup when contention is detectedh]h#cleanup when contention is detected}(hjƚhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKthjÚhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKtubeh}(h]h ](jfunctioneh"]h$]h&]jjjjޚjjޚjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_exec *exec`` the drm_exec object to cleanup **Description** Cleanup the current state and return true if we should stay inside the retry loop, false if there wasn't any contention detected and we can keep the objects locked.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKxhjubj)}(hhh]j)}(h9``struct drm_exec *exec`` the drm_exec object to cleanup h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKuhjubj )}(hhh]h)}(hthe drm_exec object to cleanuph]hthe drm_exec object to cleanup}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKuhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKuhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjBh]h Description}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKwhjubh)}(hCleanup the current state and return true if we should stay inside the retry loop, false if there wasn't any contention detected and we can keep the objects locked.h]hCleanup the current state and return true if we should stay inside the retry loop, false if there wasn’t any contention detected and we can keep the objects locked.}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKvhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_exec_lock_obj (C function)c.drm_exec_lock_objhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hIint drm_exec_lock_obj (struct drm_exec *exec, struct drm_gem_object *obj)h]j>)}(hHint drm_exec_lock_obj(struct drm_exec *exec, struct drm_gem_object *obj)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhKubjg)}(hdrm_exec_lock_objh]jm)}(hdrm_exec_lock_objh]hdrm_exec_lock_obj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhKubj)}(h3(struct drm_exec *exec, struct drm_gem_object *obj)h](j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjěhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjћhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjߛubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_exec_lock_objasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hj6hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj2ubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2ubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjThhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjQubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjVmodnameN classnameNjj)}j]jc.drm_exec_lock_objasbuh1hhj2ubjV)}(h h]h }(hjrhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj2ubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj2ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhKubah}(h]jzah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhj|hhubj)}(hhh]h)}(hlock a GEM object for useh]hlock a GEM object for use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhj|hhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjϜjjϜjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_exec *exec`` the drm_exec object with the state ``struct drm_gem_object *obj`` the GEM object to lock **Description** Lock a GEM object for use and grab a reference to it. **Return** -EDEADLK if a contention is detected, -EALREADY when object is already locked (can be suppressed by setting the DRM_EXEC_IGNORE_DUPLICATES flag), -ENOMEM when memory allocation failed and zero for success.h](h)}(h**Parameters**h]j)}(hjٜh]h Parameters}(hjۜhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjלubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjӜubj)}(hhh](j)}(h=``struct drm_exec *exec`` the drm_exec object with the state h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjubj )}(hhh]h)}(h"the drm_exec object with the stateh]h"the drm_exec object with the state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hKhjubj)}(h6``struct drm_gem_object *obj`` the GEM object to lock h](j)}(h``struct drm_gem_object *obj``h]j)}(hj1h]hstruct drm_gem_object *obj}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhj+ubj )}(hhh]h)}(hthe GEM object to lockh]hthe GEM object to lock}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhKhjGubah}(h]h ]h"]h$]h&]uh1j hj+ubeh}(h]h ]h"]h$]h&]uh1jhjFhKhjubeh}(h]h ]h"]h$]h&]uh1jhjӜubh)}(h**Description**h]j)}(hjlh]h Description}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjӜubh)}(h5Lock a GEM object for use and grab a reference to it.h]h5Lock a GEM object for use and grab a reference to it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjӜubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjӜubh)}(h-EDEADLK if a contention is detected, -EALREADY when object is already locked (can be suppressed by setting the DRM_EXEC_IGNORE_DUPLICATES flag), -ENOMEM when memory allocation failed and zero for success.h]h-EDEADLK if a contention is detected, -EALREADY when object is already locked (can be suppressed by setting the DRM_EXEC_IGNORE_DUPLICATES flag), -ENOMEM when memory allocation failed and zero for success.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjӜubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_exec_unlock_obj (C function)c.drm_exec_unlock_objhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hLvoid drm_exec_unlock_obj (struct drm_exec *exec, struct drm_gem_object *obj)h]j>)}(hKvoid drm_exec_unlock_obj(struct drm_exec *exec, struct drm_gem_object *obj)h](j)}(hvoidh]hvoid}(hj؝hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjԝhhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjԝhhhjhKubjg)}(hdrm_exec_unlock_objh]jm)}(hdrm_exec_unlock_objh]hdrm_exec_unlock_obj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjԝhhhjhKubj)}(h3(struct drm_exec *exec, struct drm_gem_object *obj)h](j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hj3hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j )}jjsbc.drm_exec_unlock_objasbuh1hhjubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjahhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jOc.drm_exec_unlock_objasbuh1hhjubjV)}(h h]h }(hjÞhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjўhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjޞhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubeh}(h]h ]h"]h$]h&]jjuh1jhjԝhhhjhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjНhhhjhKubah}(h]j˝ah ](jjeh"]h$]h&]jj)jhuh1j7hjhKhj͝hhubj)}(hhh]h)}(h(unlock a GEM object in this exec contexth]h(unlock a GEM object in this exec context}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhj͝hhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhjhNhNubj)}(hXa**Parameters** ``struct drm_exec *exec`` the drm_exec object with the state ``struct drm_gem_object *obj`` the GEM object to unlock **Description** Unlock the GEM object and remove it from the collection of locked objects. Should only be used to unlock the most recently locked objects. It's not time efficient to unlock objects locked long ago.h](h)}(h**Parameters**h]j)}(hj*h]h Parameters}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhj$ubj)}(hhh](j)}(h=``struct drm_exec *exec`` the drm_exec object with the state h](j)}(h``struct drm_exec *exec``h]j)}(hjIh]hstruct drm_exec *exec}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chKhjCubj )}(hhh]h)}(h"the drm_exec object with the stateh]h"the drm_exec object with the state}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj^hKhj_ubah}(h]h ]h"]h$]h&]uh1j hjCubeh}(h]h ]h"]h$]h&]uh1jhj^hKhj@ubj)}(h8``struct drm_gem_object *obj`` the GEM object to unlock h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhj|ubj )}(hhh]h)}(hthe GEM object to unlockh]hthe GEM object to unlock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hj|ubeh}(h]h ]h"]h$]h&]uh1jhjhMhj@ubeh}(h]h ]h"]h$]h&]uh1jhj$ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhj$ubh)}(hUnlock the GEM object and remove it from the collection of locked objects. Should only be used to unlock the most recently locked objects. It's not time efficient to unlock objects locked long ago.h]hUnlock the GEM object and remove it from the collection of locked objects. Should only be used to unlock the most recently locked objects. It’s not time efficient to unlock objects locked long ago.}(hjӟhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhj$ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_exec_prepare_obj (C function)c.drm_exec_prepare_objhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(heint drm_exec_prepare_obj (struct drm_exec *exec, struct drm_gem_object *obj, unsigned int num_fences)h]j>)}(hdint drm_exec_prepare_obj(struct drm_exec *exec, struct drm_gem_object *obj, unsigned int num_fences)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_exec_prepare_objh]jm)}(hdrm_exec_prepare_objh]hdrm_exec_prepare_obj}(hj#hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hL(struct drm_exec *exec, struct drm_gem_object *obj, unsigned int num_fences)h](j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hj?hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj;ubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;ubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjZubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj_modnameN classnameNjj)}j]j )}jj%sbc.drm_exec_prepare_objasbuh1hhj;ubjV)}(h h]h }(hj}hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj;ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj;ubjm)}(hexech]hexec}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj;ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjϠhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj̠ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjѠmodnameN classnameNjj)}j]jyc.drm_exec_prepare_objasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubj)}(hunsigned int num_fencesh](j)}(hunsignedh]hunsigned}(hj!hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj/hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hj=hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjKhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h num_fencesh]h num_fences}(hjYhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj7ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hprepare a GEM object for useh]hprepare a GEM object for use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_exec *exec`` the drm_exec object with the state ``struct drm_gem_object *obj`` the GEM object to prepare ``unsigned int num_fences`` how many fences to reserve **Description** Prepare a GEM object for use by locking it and reserving fence slots. **Return** -EDEADLK if a contention is detected, -EALREADY when object is already locked, -ENOMEM when memory allocation failed and zero for success.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjubj)}(hhh](j)}(h=``struct drm_exec *exec`` the drm_exec object with the state h](j)}(h``struct drm_exec *exec``h]j)}(hjġh]hstruct drm_exec *exec}(hjơhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj¡ubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjubj )}(hhh]h)}(h"the drm_exec object with the stateh]h"the drm_exec object with the state}(hjݡhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj١hMhjڡubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj١hMhjubj)}(h9``struct drm_gem_object *obj`` the GEM object to prepare h](j)}(h``struct drm_gem_object *obj``h]j)}(hjh]hstruct drm_gem_object *obj}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjubj )}(hhh]h)}(hthe GEM object to prepareh]hthe GEM object to prepare}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h7``unsigned int num_fences`` how many fences to reserve h](j)}(h``unsigned int num_fences``h]j)}(hj6h]hunsigned int num_fences}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhj0ubj )}(hhh]h)}(hhow many fences to reserveh]hhow many fences to reserve}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhMhjLubah}(h]h ]h"]h$]h&]uh1j hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjqh]h Description}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jhjoubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjubh)}(hEPrepare a GEM object for use by locking it and reserving fence slots.h]hEPrepare a GEM object for use by locking it and reserving fence slots.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chMhjubh)}(h-EDEADLK if a contention is detected, -EALREADY when object is already locked, -ENOMEM when memory allocation failed and zero for success.h]h-EDEADLK if a contention is detected, -EALREADY when object is already locked, -ENOMEM when memory allocation failed and zero for success.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_exec_prepare_array (C function)c.drm_exec_prepare_arrayhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hint drm_exec_prepare_array (struct drm_exec *exec, struct drm_gem_object **objects, unsigned int num_objects, unsigned int num_fences)h]j>)}(hint drm_exec_prepare_array(struct drm_exec *exec, struct drm_gem_object **objects, unsigned int num_objects, unsigned int num_fences)h](j)}(hinth]hint}(hjݢhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj٢hhhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM7ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj٢hhhjhM7ubjg)}(hdrm_exec_prepare_arrayh]jm)}(hdrm_exec_prepare_arrayh]hdrm_exec_prepare_array}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj٢hhhjhM7ubj)}(hk(struct drm_exec *exec, struct drm_gem_object **objects, unsigned int num_objects, unsigned int num_fences)h](j)}(hstruct drm_exec *exech](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj'hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_exech]hdrm_exec}(hj8hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj:modnameN classnameNjj)}j]j )}jjsbc.drm_exec_prepare_arrayasbuh1hhjubjV)}(h h]h }(hjXhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjfhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hexech]hexec}(hjshhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_gem_object **objectsh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jTc.drm_exec_prepare_arrayasbuh1hhjubjV)}(h h]h }(hjȣhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj֣hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjectsh]hobjects}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_objectsh](j)}(hunsignedh]hunsigned}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hj%hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h num_objectsh]h num_objects}(hjAhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_fencesh](j)}(hunsignedh]hunsigned}(hjZhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjVubjV)}(h h]h }(hjhhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubj)}(hinth]hint}(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjVubjm)}(h num_fencesh]h num_fences}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjVubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj٢hhhjhM7ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjբhhhjhM7ubah}(h]jТah ](jjeh"]h$]h&]jj)jhuh1j7hjhM7hjҢhhubj)}(hhh]h)}(h%helper to prepare an array of objectsh]h%helper to prepare an array of objects}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM7hjhhubah}(h]h ]h"]h$]h&]uh1jhjҢhhhjhM7ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjԤjjԤjjjuh1j2hhhjhNhNubj)}(hX=**Parameters** ``struct drm_exec *exec`` the drm_exec object with the state ``struct drm_gem_object **objects`` array of GEM object to prepare ``unsigned int num_objects`` number of GEM objects in the array ``unsigned int num_fences`` number of fences to reserve on each GEM object **Description** Prepares all GEM objects in an array, aborts on first error. Reserves **num_fences** on each GEM object after locking it. **Return** -EDEADLOCK on contention, -EALREADY when object is already locked, -ENOMEM when memory allocation failed and zero for success.h](h)}(h**Parameters**h]j)}(hjޤh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjܤubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM;hjؤubj)}(hhh](j)}(h=``struct drm_exec *exec`` the drm_exec object with the state h](j)}(h``struct drm_exec *exec``h]j)}(hjh]hstruct drm_exec *exec}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM8hjubj )}(hhh]h)}(h"the drm_exec object with the stateh]h"the drm_exec object with the state}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM8hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM8hjubj)}(hC``struct drm_gem_object **objects`` array of GEM object to prepare h](j)}(h#``struct drm_gem_object **objects``h]j)}(hj6h]hstruct drm_gem_object **objects}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj4ubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM9hj0ubj )}(hhh]h)}(harray of GEM object to prepareh]harray of GEM object to prepare}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjKhM9hjLubah}(h]h ]h"]h$]h&]uh1j hj0ubeh}(h]h ]h"]h$]h&]uh1jhjKhM9hjubj)}(h@``unsigned int num_objects`` number of GEM objects in the array h](j)}(h``unsigned int num_objects``h]j)}(hjoh]hunsigned int num_objects}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjmubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM:hjiubj )}(hhh]h)}(h"number of GEM objects in the arrayh]h"number of GEM objects in the array}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM:hjubah}(h]h ]h"]h$]h&]uh1j hjiubeh}(h]h ]h"]h$]h&]uh1jhjhM:hjubj)}(hK``unsigned int num_fences`` number of fences to reserve on each GEM object h](j)}(h``unsigned int num_fences``h]j)}(hjh]hunsigned int num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM;hjubj )}(hhh]h)}(h.number of fences to reserve on each GEM objecth]h.number of fences to reserve on each GEM object}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM;hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM;hjubeh}(h]h ]h"]h$]h&]uh1jhjؤubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM=hjؤubh)}(hyPrepares all GEM objects in an array, aborts on first error. Reserves **num_fences** on each GEM object after locking it.h](hFPrepares all GEM objects in an array, aborts on first error. Reserves }(hjhhhNhNubj)}(h**num_fences**h]h num_fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh% on each GEM object after locking it.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM<hjؤubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM?hjؤubh)}(h~-EDEADLOCK on contention, -EALREADY when object is already locked, -ENOMEM when memory allocation failed and zero for success.h]h~-EDEADLOCK on contention, -EALREADY when object is already locked, -ENOMEM when memory allocation failed and zero for success.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhV/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:564: ./drivers/gpu/drm/drm_exec.chM@hjؤubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]drm-execution-contextah ]h"]drm execution contextah$]h&]uh1hhhhhhhhM,ubh)}(hhh](h)}(h GPU Schedulerh]h GPU Scheduler}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhhhhhM8ubh)}(hhh](h)}(hOverviewh]hOverview}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjahhhhhM;ubh)}(hXThe GPU scheduler provides entities which allow userspace to push jobs into software queues which are then scheduled on a hardware run queue. The software queues have a priority among them. The scheduler selects the entities from the run queue using a FIFO. The scheduler provides dependency handling features among jobs. The driver is supposed to provide callback functions for backend operations to the scheduler like submitting a job to hardware run queue, returning the dependencies of a job etc.h]hXThe GPU scheduler provides entities which allow userspace to push jobs into software queues which are then scheduled on a hardware run queue. The software queues have a priority among them. The scheduler selects the entities from the run queue using a FIFO. The scheduler provides dependency handling features among jobs. The driver is supposed to provide callback functions for backend operations to the scheduler like submitting a job to hardware run queue, returning the dependencies of a job etc.}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:573: ./drivers/gpu/drm/scheduler/sched_main.chKhjahhubh)}(h3The organisation of the scheduler is the following:h]h3The organisation of the scheduler is the following:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:573: ./drivers/gpu/drm/scheduler/sched_main.chK!hjahhubj:)}(hhh](j{)}(h#Each hw run queue has one schedulerh]h)}(hjh]h#Each hw run queue has one scheduler}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:573: ./drivers/gpu/drm/scheduler/sched_main.chK#hjubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(hhEach scheduler has multiple run queues with different priorities (e.g., HIGH_HW,HIGH_SW, KERNEL, NORMAL)h]h)}(hhEach scheduler has multiple run queues with different priorities (e.g., HIGH_HW,HIGH_SW, KERNEL, NORMAL)h]hhEach scheduler has multiple run queues with different priorities (e.g., HIGH_HW,HIGH_SW, KERNEL, NORMAL)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:573: ./drivers/gpu/drm/scheduler/sched_main.chK$hjubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(h)}(hDRM_SCHED_FENCE_DONT_PIPELINEh]jg)}(hDRM_SCHED_FENCE_DONT_PIPELINEh]jm)}(hjӧh]hDRM_SCHED_FENCE_DONT_PIPELINE}(hjݧhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj٧ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjէhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK$ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjѧhhhjhK$ubah}(h]j̧ah ](jjeh"]h$]h&]jj)jhuh1j7hjhK$hjΧhhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhjΧhhhjhK$ubeh}(h]h ](jmacroeh"]h$]h&]jjjj jj jjjuh1j2hhhjhNhNubh)}(h!``DRM_SCHED_FENCE_DONT_PIPELINE``h]j)}(hjh]hDRM_SCHED_FENCE_DONT_PIPELINE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK&hjhhubj)}(h Prevent dependency pipelining **Description** Setting this flag on a scheduler fence prevents pipelining of jobs depending on this fence. In other words we always insert a full CPU round trip before dependent jobs are pushed to the hw queue. h](j)}(hPrevent dependency pipelining h]h)}(hPrevent dependency pipeliningh]hPrevent dependency pipelining}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK$hj)ubah}(h]h ]h"]h$]h&]uh1jhj;hK$hj%ubh)}(h**Description**h]j)}(hjDh]h Description}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK&hj%ubh)}(hSetting this flag on a scheduler fence prevents pipelining of jobs depending on this fence. In other words we always insert a full CPU round trip before dependent jobs are pushed to the hw queue.h]hSetting this flag on a scheduler fence prevents pipelining of jobs depending on this fence. In other words we always insert a full CPU round trip before dependent jobs are pushed to the hw queue.}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK%hj%ubeh}(h]h ]h"]h$]h&]uh1jhj;hK$hjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j./DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BIT (C macro)'c.DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BIThNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h%DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BITh]j>)}(h%DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BITh]jg)}(h%DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BITh]jm)}(hjh]h%DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BIT}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK-ubah}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhK-ubah}(h]j{ah ](jjeh"]h$]h&]jj)jhuh1j7hjhK-hj}hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj}hhhjhK-ubeh}(h]h ](jmacroeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubh)}(h)``DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BIT``h]j)}(hjh]h%DRM_SCHED_FENCE_FLAG_HAS_DEADLINE_BIT}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK/hjhhubj)}(h A fence deadline hint has been set **Description** Because we could have a deadline hint can be set before the backing hw fence is created, we need to keep track of whether a deadline has already been set. h](j)}(h#A fence deadline hint has been set h]h)}(h"A fence deadline hint has been seth]h"A fence deadline hint has been set}(hjܨhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK-hjبubah}(h]h ]h"]h$]h&]uh1jhjhK-hjԨubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK/hjԨubh)}(hBecause we could have a deadline hint can be set before the backing hw fence is created, we need to keep track of whether a deadline has already been set.h]hBecause we could have a deadline hint can be set before the backing hw fence is created, we need to keep track of whether a deadline has already been set.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK.hjԨubeh}(h]h ]h"]h$]h&]uh1jhjhK-hjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_entity (C struct)c.drm_sched_entityhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_sched_entityh]j>)}(hstruct drm_sched_entityh](jD)}(hjh]hstruct}(hj7hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj3hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK5ubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj3hhhjDhK5ubjg)}(hdrm_sched_entityh]jm)}(hj1h]hdrm_sched_entity}(hjWhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjSubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj3hhhjDhK5ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj/hhhjDhK5ubah}(h]j*ah ](jjeh"]h$]h&]jj)jhuh1j7hjDhK5hj,hhubj)}(hhh]h)}(hGA wrapper around a job queue (typically attached to the DRM file_priv).h]hGA wrapper around a job queue (typically attached to the DRM file_priv).}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKKhjvhhubah}(h]h ]h"]h$]h&]uh1jhj,hhhjDhK5ubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX **Definition**:: struct drm_sched_entity { struct list_head list; spinlock_t lock; struct drm_sched_rq *rq; struct drm_gpu_scheduler **sched_list; unsigned int num_sched_list; enum drm_sched_priority priority; struct spsc_queue job_queue; atomic_t fence_seq; uint64_t fence_context; struct dma_fence *dependency; struct dma_fence_cb cb; atomic_t *guilty; struct dma_fence *last_scheduled; struct task_struct *last_user; bool stopped; struct completion entity_idle; ktime_t oldest_job_waiting; struct rb_node rb_tree_node; }; **Members** ``list`` Used to append this struct to the list of entities in the runqueue **rq** under :c:type:`drm_sched_rq.entities `. Protected by :c:type:`drm_sched_rq.lock ` of **rq**. ``lock`` Lock protecting the run-queue (**rq**) to which this entity belongs, **priority** and the list of schedulers (**sched_list**, **num_sched_list**). ``rq`` Runqueue on which this entity is currently scheduled. FIXME: Locking is very unclear for this. Writers are protected by **lock**, but readers are generally lockless and seem to just race with not even a READ_ONCE. ``sched_list`` A list of schedulers (struct drm_gpu_scheduler). Jobs from this entity can be scheduled on any scheduler on this list. This can be modified by calling drm_sched_entity_modify_sched(). Locking is entirely up to the driver, see the above function for more details. This will be set to NULL if :c:type:`num_sched_list` equals 1 and **rq** has been set already. FIXME: This means priority changes through drm_sched_entity_set_priority() will be lost henceforth in this case. ``num_sched_list`` Number of drm_gpu_schedulers in the **sched_list**. ``priority`` Priority of the entity. This can be modified by calling drm_sched_entity_set_priority(). Protected by **lock**. ``job_queue`` the list of jobs of this entity. ``fence_seq`` A linearly increasing seqno incremented with each new :c:type:`drm_sched_fence` which is part of the entity. FIXME: Callers of drm_sched_job_arm() need to ensure correct locking, this doesn't need to be atomic. ``fence_context`` A unique context for all the fences which belong to this entity. The :c:type:`drm_sched_fence.scheduled ` uses the fence_context but :c:type:`drm_sched_fence.finished ` uses fence_context + 1. ``dependency`` The dependency fence of the job which is on the top of the job queue. ``cb`` Callback for the dependency fence above. ``guilty`` Points to entities' guilty. ``last_scheduled`` Points to the finished fence of the last scheduled job. Only written by drm_sched_entity_pop_job(). Can be accessed locklessly from drm_sched_job_arm() if the queue is empty. ``last_user`` last group leader pushing a job into the entity. ``stopped`` Marks the enity as removed from rq and destined for termination. This is set by calling drm_sched_entity_flush() and by drm_sched_fini(). ``entity_idle`` Signals when entity is not in use, used to sequence entity cleanup in drm_sched_entity_fini(). ``oldest_job_waiting`` Marks earliest job waiting in SW queue ``rb_tree_node`` The node used to insert this entity into time based priority queueh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKOhjubjT)}(hXstruct drm_sched_entity { struct list_head list; spinlock_t lock; struct drm_sched_rq *rq; struct drm_gpu_scheduler **sched_list; unsigned int num_sched_list; enum drm_sched_priority priority; struct spsc_queue job_queue; atomic_t fence_seq; uint64_t fence_context; struct dma_fence *dependency; struct dma_fence_cb cb; atomic_t *guilty; struct dma_fence *last_scheduled; struct task_struct *last_user; bool stopped; struct completion entity_idle; ktime_t oldest_job_waiting; struct rb_node rb_tree_node; };h]hXstruct drm_sched_entity { struct list_head list; spinlock_t lock; struct drm_sched_rq *rq; struct drm_gpu_scheduler **sched_list; unsigned int num_sched_list; enum drm_sched_priority priority; struct spsc_queue job_queue; atomic_t fence_seq; uint64_t fence_context; struct dma_fence *dependency; struct dma_fence_cb cb; atomic_t *guilty; struct dma_fence *last_scheduled; struct task_struct *last_user; bool stopped; struct completion entity_idle; ktime_t oldest_job_waiting; struct rb_node rb_tree_node; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKQhjubh)}(h **Members**h]j)}(hjǩh]hMembers}(hjɩhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjũubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKfhjubj)}(hhh](j)}(h``list`` Used to append this struct to the list of entities in the runqueue **rq** under :c:type:`drm_sched_rq.entities `. Protected by :c:type:`drm_sched_rq.lock ` of **rq**. h](j)}(h``list``h]j)}(hjh]hlist}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKXhjubj )}(hhh](h)}(hUsed to append this struct to the list of entities in the runqueue **rq** under :c:type:`drm_sched_rq.entities `.h](hCUsed to append this struct to the list of entities in the runqueue }(hjhhhNhNubj)}(h**rq**h]hrq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh under }(hjhhhNhNubh)}(h.:c:type:`drm_sched_rq.entities `h]j)}(hjh]hdrm_sched_rq.entities}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_sched_rquh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKUhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj8hKUhjubh)}(hBProtected by :c:type:`drm_sched_rq.lock ` of **rq**.h](h Protected by }(hjChhhNhNubh)}(h*:c:type:`drm_sched_rq.lock `h]j)}(hjMh]hdrm_sched_rq.lock}(hjOhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_sched_rquh1hhjhKXhjCubh of }(hjChhhNhNubj)}(h**rq**h]hrq}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubh.}(hjChhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKXhjubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKXhjݩubj)}(h``lock`` Lock protecting the run-queue (**rq**) to which this entity belongs, **priority** and the list of schedulers (**sched_list**, **num_sched_list**). h](j)}(h``lock``h]j)}(hjh]hlock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK`hjubj )}(hhh]h)}(hLock protecting the run-queue (**rq**) to which this entity belongs, **priority** and the list of schedulers (**sched_list**, **num_sched_list**).h](hLock protecting the run-queue (}(hjhhhNhNubj)}(h**rq**h]hrq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh ) to which this entity belongs, }(hjhhhNhNubj)}(h **priority**h]hpriority}(hj˪hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and the list of schedulers (}(hjhhhNhNubj)}(h**sched_list**h]h sched_list}(hjݪhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, }(hjhhhNhNubj)}(h**num_sched_list**h]hnum_sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK_hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK`hjݩubj)}(h``rq`` Runqueue on which this entity is currently scheduled. FIXME: Locking is very unclear for this. Writers are protected by **lock**, but readers are generally lockless and seem to just race with not even a READ_ONCE. h](j)}(h``rq``h]j)}(hjh]hrq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKkhjubj )}(hhh](h)}(h5Runqueue on which this entity is currently scheduled.h]h5Runqueue on which this entity is currently scheduled.}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKghj0ubh)}(hFIXME: Locking is very unclear for this. Writers are protected by **lock**, but readers are generally lockless and seem to just race with not even a READ_ONCE.h](hBFIXME: Locking is very unclear for this. Writers are protected by }(hjBhhhNhNubj)}(h**lock**h]hlock}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubhU, but readers are generally lockless and seem to just race with not even a READ_ONCE.}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKihj0ubeh}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj/hKkhjݩubj)}(hX``sched_list`` A list of schedulers (struct drm_gpu_scheduler). Jobs from this entity can be scheduled on any scheduler on this list. This can be modified by calling drm_sched_entity_modify_sched(). Locking is entirely up to the driver, see the above function for more details. This will be set to NULL if :c:type:`num_sched_list` equals 1 and **rq** has been set already. FIXME: This means priority changes through drm_sched_entity_set_priority() will be lost henceforth in this case. h](j)}(h``sched_list``h]j)}(hjuh]h sched_list}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK}hjoubj )}(hhh](h)}(hwA list of schedulers (struct drm_gpu_scheduler). Jobs from this entity can be scheduled on any scheduler on this list.h]hwA list of schedulers (struct drm_gpu_scheduler). Jobs from this entity can be scheduled on any scheduler on this list.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKrhjubh)}(hThis can be modified by calling drm_sched_entity_modify_sched(). Locking is entirely up to the driver, see the above function for more details.h]hThis can be modified by calling drm_sched_entity_modify_sched(). Locking is entirely up to the driver, see the above function for more details.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKuhjubh)}(h^This will be set to NULL if :c:type:`num_sched_list` equals 1 and **rq** has been set already.h](hThis will be set to NULL if }(hjhhhNhNubh)}(h:c:type:`num_sched_list`h]j)}(hjh]hnum_sched_list}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMnum_sched_listuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKyhjubh equals 1 and }(hjhhhNhNubj)}(h**rq**h]hrq}(hjثhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh has been set already.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjӫhKyhjubh)}(hpFIXME: This means priority changes through drm_sched_entity_set_priority() will be lost henceforth in this case.h]hpFIXME: This means priority changes through drm_sched_entity_set_priority() will be lost henceforth in this case.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhK|hjubeh}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjhK}hjݩubj)}(hG``num_sched_list`` Number of drm_gpu_schedulers in the **sched_list**. h](j)}(h``num_sched_list``h]j)}(hjh]hnum_sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhj ubj )}(hhh]h)}(h3Number of drm_gpu_schedulers in the **sched_list**.h](h$Number of drm_gpu_schedulers in the }(hj*hhhNhNubj)}(h**sched_list**h]h sched_list}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj*ubh.}(hj*hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj&hKhj'ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hKhjݩubj)}(h}``priority`` Priority of the entity. This can be modified by calling drm_sched_entity_set_priority(). Protected by **lock**. h](j)}(h ``priority``h]j)}(hj\h]hpriority}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjZubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjVubj )}(hhh]h)}(hoPriority of the entity. This can be modified by calling drm_sched_entity_set_priority(). Protected by **lock**.h](hfPriority of the entity. This can be modified by calling drm_sched_entity_set_priority(). Protected by }(hjuhhhNhNubj)}(h**lock**h]hlock}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjuubh.}(hjuhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjrubah}(h]h ]h"]h$]h&]uh1j hjVubeh}(h]h ]h"]h$]h&]uh1jhjqhKhjݩubj)}(h/``job_queue`` the list of jobs of this entity. h](j)}(h ``job_queue``h]j)}(hjh]h job_queue}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h the list of jobs of this entity.h]h the list of jobs of this entity.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubj)}(h``fence_seq`` A linearly increasing seqno incremented with each new :c:type:`drm_sched_fence` which is part of the entity. FIXME: Callers of drm_sched_job_arm() need to ensure correct locking, this doesn't need to be atomic. h](j)}(h ``fence_seq``h]j)}(hjh]h fence_seq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj߬ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhj۬ubj )}(hhh](h)}(hlA linearly increasing seqno incremented with each new :c:type:`drm_sched_fence` which is part of the entity.h](h6A linearly increasing seqno incremented with each new }(hjhhhNhNubh)}(h:c:type:`drm_sched_fence`h]j)}(hjh]hdrm_sched_fence}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_fenceuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubh which is part of the entity.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj!hKhjubh)}(heFIXME: Callers of drm_sched_job_arm() need to ensure correct locking, this doesn't need to be atomic.h]hgFIXME: Callers of drm_sched_job_arm() need to ensure correct locking, this doesn’t need to be atomic.}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubeh}(h]h ]h"]h$]h&]uh1j hj۬ubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubj)}(h``fence_context`` A unique context for all the fences which belong to this entity. The :c:type:`drm_sched_fence.scheduled ` uses the fence_context but :c:type:`drm_sched_fence.finished ` uses fence_context + 1. h](j)}(h``fence_context``h]j)}(hjMh]h fence_context}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjGubj )}(hhh]h)}(hA unique context for all the fences which belong to this entity. The :c:type:`drm_sched_fence.scheduled ` uses the fence_context but :c:type:`drm_sched_fence.finished ` uses fence_context + 1.h](hFA unique context for all the fences which belong to this entity. The }(hjfhhhNhNubh)}(h5:c:type:`drm_sched_fence.scheduled `h]j)}(hjph]hdrm_sched_fence.scheduled}(hjrhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_fenceuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjfubh uses the fence_context but }(hjfhhhNhNubh)}(h4:c:type:`drm_sched_fence.finished `h]j)}(hjh]hdrm_sched_fence.finished}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_fenceuh1hhjhKhjfubh uses fence_context + 1.}(hjfhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjcubah}(h]h ]h"]h$]h&]uh1j hjGubeh}(h]h ]h"]h$]h&]uh1jhjbhKhjݩubj)}(hU``dependency`` The dependency fence of the job which is on the top of the job queue. h](j)}(h``dependency``h]j)}(hjͭh]h dependency}(hjϭhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj˭ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjǭubj )}(hhh]h)}(hEThe dependency fence of the job which is on the top of the job queue.h]hEThe dependency fence of the job which is on the top of the job queue.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjǭubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubj)}(h0``cb`` Callback for the dependency fence above. h](j)}(h``cb``h]j)}(hjh]hcb}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h(Callback for the dependency fence above.h]h(Callback for the dependency fence above.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubj)}(h'``guilty`` Points to entities' guilty. h](j)}(h ``guilty``h]j)}(hj?h]hguilty}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhj9ubj )}(hhh]h)}(hPoints to entities' guilty.h]hPoints to entities’ guilty.}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThKhjUubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThKhjݩubj)}(h``last_scheduled`` Points to the finished fence of the last scheduled job. Only written by drm_sched_entity_pop_job(). Can be accessed locklessly from drm_sched_job_arm() if the queue is empty. h](j)}(h``last_scheduled``h]j)}(hjxh]hlast_scheduled}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjrubj )}(hhh]h)}(hPoints to the finished fence of the last scheduled job. Only written by drm_sched_entity_pop_job(). Can be accessed locklessly from drm_sched_job_arm() if the queue is empty.h]hPoints to the finished fence of the last scheduled job. Only written by drm_sched_entity_pop_job(). Can be accessed locklessly from drm_sched_job_arm() if the queue is empty.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubj)}(h?``last_user`` last group leader pushing a job into the entity. h](j)}(h ``last_user``h]j)}(hjh]h last_user}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h0last group leader pushing a job into the entity.h]h0last group leader pushing a job into the entity.}(hjˮhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjǮhKhjȮubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjǮhKhjݩubj)}(h``stopped`` Marks the enity as removed from rq and destined for termination. This is set by calling drm_sched_entity_flush() and by drm_sched_fini(). h](j)}(h ``stopped``h]j)}(hjh]hstopped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(hMarks the enity as removed from rq and destined for termination. This is set by calling drm_sched_entity_flush() and by drm_sched_fini().h]hMarks the enity as removed from rq and destined for termination. This is set by calling drm_sched_entity_flush() and by drm_sched_fini().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubj)}(ho``entity_idle`` Signals when entity is not in use, used to sequence entity cleanup in drm_sched_entity_fini(). h](j)}(h``entity_idle``h]j)}(hj%h]h entity_idle}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h^Signals when entity is not in use, used to sequence entity cleanup in drm_sched_entity_fini().h]h^Signals when entity is not in use, used to sequence entity cleanup in drm_sched_entity_fini().}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhj;ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj:hKhjݩubj)}(h>``oldest_job_waiting`` Marks earliest job waiting in SW queue h](j)}(h``oldest_job_waiting``h]j)}(hj_h]holdest_job_waiting}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhj]ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjYubj )}(hhh]h)}(h&Marks earliest job waiting in SW queueh]h&Marks earliest job waiting in SW queue}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjthKhjuubah}(h]h ]h"]h$]h&]uh1j hjYubeh}(h]h ]h"]h$]h&]uh1jhjthKhjݩubj)}(hS``rb_tree_node`` The node used to insert this entity into time based priority queueh](j)}(h``rb_tree_node``h]j)}(hjh]h rb_tree_node}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(hBThe node used to insert this entity into time based priority queueh]hBThe node used to insert this entity into time based priority queue}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjݩubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubh)}(h**Description**h]j)}(hjۯh]h Description}(hjݯhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjٯubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjhhubh)}(hEntities will emit jobs in order to their corresponding hardware ring, and the scheduler will alternate between entities based on scheduling policy.h]hEntities will emit jobs in order to their corresponding hardware ring, and the scheduler will alternate between entities based on scheduling policy.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKLhjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_rq (C struct)c.drm_sched_rqhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h drm_sched_rqh]j>)}(hstruct drm_sched_rqh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKSubjV)}(h h]h }(hj'hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj&hKSubjg)}(h drm_sched_rqh]jm)}(hjh]h drm_sched_rq}(hj9hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj5ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj&hKSubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj&hKSubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj&hKShjhhubj)}(hhh]h)}(h"queue of entities to be scheduled.h]h"queue of entities to be scheduled.}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjXhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj&hKSubeh}(h]h ](jstructeh"]h$]h&]jjjjsjjsjjjuh1j2hhhjhNhNubj)}(hXf**Definition**:: struct drm_sched_rq { struct drm_gpu_scheduler *sched; spinlock_t lock; struct drm_sched_entity *current_entity; struct list_head entities; struct rb_root_cached rb_tree_root; }; **Members** ``sched`` the scheduler to which this rq belongs to. ``lock`` protects **entities**, **rb_tree_root** and **current_entity**. ``current_entity`` the entity which is to be scheduled. ``entities`` list of the entities to be scheduled. ``rb_tree_root`` root of time based priority queue of entities for FIFO schedulingh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubh:}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjwubjT)}(hstruct drm_sched_rq { struct drm_gpu_scheduler *sched; spinlock_t lock; struct drm_sched_entity *current_entity; struct list_head entities; struct rb_root_cached rb_tree_root; };h]hstruct drm_sched_rq { struct drm_gpu_scheduler *sched; spinlock_t lock; struct drm_sched_entity *current_entity; struct list_head entities; struct rb_root_cached rb_tree_root; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjwubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjwubj)}(hhh](j)}(h5``sched`` the scheduler to which this rq belongs to. h](j)}(h ``sched``h]j)}(hjȰh]hsched}(hjʰhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjưubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhj°ubj )}(hhh]h)}(h*the scheduler to which this rq belongs to.h]h*the scheduler to which this rq belongs to.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjݰhKhjްubah}(h]h ]h"]h$]h&]uh1j hj°ubeh}(h]h ]h"]h$]h&]uh1jhjݰhKhjubj)}(hI``lock`` protects **entities**, **rb_tree_root** and **current_entity**. h](j)}(h``lock``h]j)}(hjh]hlock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h?protects **entities**, **rb_tree_root** and **current_entity**.h](h protects }(hjhhhNhNubj)}(h **entities**h]hentities}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, }(hjhhhNhNubj)}(h**rb_tree_root**h]h rb_tree_root}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h**current_entity**h]hcurrent_entity}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h8``current_entity`` the entity which is to be scheduled. h](j)}(h``current_entity``h]j)}(hjph]hcurrent_entity}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjjubj )}(hhh]h)}(h$the entity which is to be scheduled.h]h$the entity which is to be scheduled.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(h3``entities`` list of the entities to be scheduled. h](j)}(h ``entities``h]j)}(hjh]hentities}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h%list of the entities to be scheduled.h]h%list of the entities to be scheduled.}(hj±hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubj)}(hR``rb_tree_root`` root of time based priority queue of entities for FIFO schedulingh](j)}(h``rb_tree_root``h]j)}(hjh]h rb_tree_root}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjܱubj )}(hhh]h)}(hAroot of time based priority queue of entities for FIFO schedulingh]hAroot of time based priority queue of entities for FIFO scheduling}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubah}(h]h ]h"]h$]h&]uh1j hjܱubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubeh}(h]h ]h"]h$]h&]uh1jhjwubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubh)}(h**Description**h]j)}(hj%h]h Description}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjhhubh)}(hRun queue is a set of entities scheduling command submissions for one specific ring. It implements the scheduling policy that selects the next entity to emit commands from.h]hRun queue is a set of entities scheduling command submissions for one specific ring. It implements the scheduling policy that selects the next entity to emit commands from.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_fence (C struct)c.drm_sched_fencehNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_sched_fenceh]j>)}(hstruct drm_sched_fenceh](jD)}(hjh]hstruct}(hjchhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj_hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj_hhhjphKubjg)}(hdrm_sched_fenceh]jm)}(hj]h]hdrm_sched_fence}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj_hhhjphKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj[hhhjphKubah}(h]jVah ](jjeh"]h$]h&]jj)jhuh1j7hjphKhjXhhubj)}(hhh]h)}(h0fences corresponding to the scheduling of a job.h]h0fences corresponding to the scheduling of a job.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjXhhhjphKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Definition**:: struct drm_sched_fence { struct dma_fence scheduled; struct dma_fence finished; ktime_t deadline; struct dma_fence *parent; struct drm_gpu_scheduler *sched; spinlock_t lock; void *owner; uint64_t drm_client_id; }; **Members** ``scheduled`` this fence is what will be signaled by the scheduler when the job is scheduled. ``finished`` this fence is what will be signaled by the scheduler when the job is completed. When setting up an out fence for the job, you should use this, since it's available immediately upon drm_sched_job_init(), and the fence returned by the driver from run_job() won't be created until the dependencies have resolved. ``deadline`` deadline set on :c:type:`drm_sched_fence.finished ` which potentially needs to be propagated to :c:type:`drm_sched_fence.parent ` ``parent`` the fence returned by :c:type:`drm_sched_backend_ops.run_job ` when scheduling the job on hardware. We signal the :c:type:`drm_sched_fence.finished ` fence once parent is signalled. ``sched`` the scheduler instance to which the job having this struct belongs to. ``lock`` the lock used by the scheduled and the finished fences. ``owner`` job owner for debugging ``drm_client_id`` The client_id of the drm_file which owns the job.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjɲhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjŲubh:}(hjŲhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hjubjT)}(hX)struct drm_sched_fence { struct dma_fence scheduled; struct dma_fence finished; ktime_t deadline; struct dma_fence *parent; struct drm_gpu_scheduler *sched; spinlock_t lock; void *owner; uint64_t drm_client_id; };h]hX)struct drm_sched_fence { struct dma_fence scheduled; struct dma_fence finished; ktime_t deadline; struct dma_fence *parent; struct drm_gpu_scheduler *sched; spinlock_t lock; void *owner; uint64_t drm_client_id; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj)}(hhh](j)}(h^``scheduled`` this fence is what will be signaled by the scheduler when the job is scheduled. h](j)}(h ``scheduled``h]j)}(hjh]h scheduled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hj ubj )}(hhh]h)}(hOthis fence is what will be signaled by the scheduler when the job is scheduled.h]hOthis fence is what will be signaled by the scheduler when the job is scheduled.}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hj(ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj'hM hj ubj)}(hXD``finished`` this fence is what will be signaled by the scheduler when the job is completed. When setting up an out fence for the job, you should use this, since it's available immediately upon drm_sched_job_init(), and the fence returned by the driver from run_job() won't be created until the dependencies have resolved. h](j)}(h ``finished``h]j)}(hjLh]hfinished}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjJubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjFubj )}(hhh](h)}(hOthis fence is what will be signaled by the scheduler when the job is completed.h]hOthis fence is what will be signaled by the scheduler when the job is completed.}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjbubh)}(hWhen setting up an out fence for the job, you should use this, since it's available immediately upon drm_sched_job_init(), and the fence returned by the driver from run_job() won't be created until the dependencies have resolved.h]hWhen setting up an out fence for the job, you should use this, since it’s available immediately upon drm_sched_job_init(), and the fence returned by the driver from run_job() won’t be created until the dependencies have resolved.}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjbubeh}(h]h ]h"]h$]h&]uh1j hjFubeh}(h]h ]h"]h$]h&]uh1jhjahMhj ubj)}(h``deadline`` deadline set on :c:type:`drm_sched_fence.finished ` which potentially needs to be propagated to :c:type:`drm_sched_fence.parent ` h](j)}(h ``deadline``h]j)}(hjh]hdeadline}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(hdeadline set on :c:type:`drm_sched_fence.finished ` which potentially needs to be propagated to :c:type:`drm_sched_fence.parent `h](hdeadline set on }(hjhhhNhNubh)}(h4:c:type:`drm_sched_fence.finished `h]j)}(hjh]hdrm_sched_fence.finished}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_fenceuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh- which potentially needs to be propagated to }(hjhhhNhNubh)}(h2:c:type:`drm_sched_fence.parent `h]j)}(hjܳh]hdrm_sched_fence.parent}(hj޳hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjڳubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_fenceuh1hhjճhMhjubeh}(h]h ]h"]h$]h&]uh1hhjճhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhj ubj)}(h``parent`` the fence returned by :c:type:`drm_sched_backend_ops.run_job ` when scheduling the job on hardware. We signal the :c:type:`drm_sched_fence.finished ` fence once parent is signalled. h](j)}(h ``parent``h]j)}(hjh]hparent}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM%hj ubj )}(hhh]h)}(hthe fence returned by :c:type:`drm_sched_backend_ops.run_job ` when scheduling the job on hardware. We signal the :c:type:`drm_sched_fence.finished ` fence once parent is signalled.h](hthe fence returned by }(hj*hhhNhNubh)}(h?:c:type:`drm_sched_backend_ops.run_job `h]j)}(hj4h]hdrm_sched_backend_ops.run_job}(hj6hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj2ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM#hj*ubh4 when scheduling the job on hardware. We signal the }(hj*hhhNhNubh)}(h4:c:type:`drm_sched_fence.finished `h]j)}(hjXh]hdrm_sched_fence.finished}(hjZhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjVubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_fenceuh1hhjQhM#hj*ubh fence once parent is signalled.}(hj*hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjQhM#hj'ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj&hM%hj ubj)}(hQ``sched`` the scheduler instance to which the job having this struct belongs to. h](j)}(h ``sched``h]j)}(hjh]hsched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM*hjubj )}(hhh]h)}(hFthe scheduler instance to which the job having this struct belongs to.h]hFthe scheduler instance to which the job having this struct belongs to.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM)hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM*hj ubj)}(hA``lock`` the lock used by the scheduled and the finished fences. h](j)}(h``lock``h]j)}(hj˴h]hlock}(hjʹhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjɴubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM.hjŴubj )}(hhh]h)}(h7the lock used by the scheduled and the finished fences.h]h7the lock used by the scheduled and the finished fences.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM.hjubah}(h]h ]h"]h$]h&]uh1j hjŴubeh}(h]h ]h"]h$]h&]uh1jhjhM.hj ubj)}(h"``owner`` job owner for debugging h](j)}(h ``owner``h]j)}(hjh]howner}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM2hjubj )}(hhh]h)}(hjob owner for debuggingh]hjob owner for debugging}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM2hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM2hj ubj)}(hC``drm_client_id`` The client_id of the drm_file which owns the job.h](j)}(h``drm_client_id``h]j)}(hj=h]h drm_client_id}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM6hj7ubj )}(hhh]h)}(h1The client_id of the drm_file which owns the job.h]h1The client_id of the drm_file which owns the job.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM7hjSubah}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhM6hj ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_job (C struct)c.drm_sched_jobhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h drm_sched_jobh]j>)}(hstruct drm_sched_jobh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM=ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM=ubjg)}(h drm_sched_jobh]jm)}(hjh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM=ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM=ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM=hjhhubj)}(hhh]h)}(hA job to be run by an entity.h]hA job to be run by an entity.}(hjٵhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM@hjֵhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM=ubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hXU**Definition**:: struct drm_sched_job { ktime_t submit_ts; struct drm_gpu_scheduler *sched; struct drm_sched_fence *s_fence; struct drm_sched_entity *entity; enum drm_sched_priority s_priority; u32 credits; unsigned int last_dependency; atomic_t karma; struct spsc_node queue_node; struct list_head list; union { struct dma_fence_cb finish_cb; struct work_struct work; }; struct dma_fence_cb cb; struct xarray dependencies; }; **Members** ``submit_ts`` When the job was pushed into the entity queue. ``sched`` The scheduler this job is or will be scheduled on. Gets set by drm_sched_job_arm(). Valid until drm_sched_backend_ops.free_job() has finished. ``s_fence`` contains the fences for the scheduling of job. ``entity`` the entity to which this job belongs. ``s_priority`` the priority of the job. ``credits`` the number of credits this job contributes to the scheduler ``last_dependency`` tracks **dependencies** as they signal ``karma`` increment on every hang caused by this job. If this exceeds the hang limit of the scheduler then the job is marked guilty and will not be scheduled further. ``queue_node`` used to append this struct to the queue of jobs in an entity. ``list`` a job participates in a "pending" and "done" lists. ``{unnamed_union}`` anonymous ``finish_cb`` the callback for the finished fence. ``work`` Helper to reschedule job kill to different context. ``cb`` the callback for the parent fence in s_fence. ``dependencies`` Contains the dependencies as struct dma_fence for this job, see drm_sched_job_add_dependency() and drm_sched_job_add_implicit_dependencies().h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMDhjubjT)}(hXYstruct drm_sched_job { ktime_t submit_ts; struct drm_gpu_scheduler *sched; struct drm_sched_fence *s_fence; struct drm_sched_entity *entity; enum drm_sched_priority s_priority; u32 credits; unsigned int last_dependency; atomic_t karma; struct spsc_node queue_node; struct list_head list; union { struct dma_fence_cb finish_cb; struct work_struct work; }; struct dma_fence_cb cb; struct xarray dependencies; };h]hXYstruct drm_sched_job { ktime_t submit_ts; struct drm_gpu_scheduler *sched; struct drm_sched_fence *s_fence; struct drm_sched_entity *entity; enum drm_sched_priority s_priority; u32 credits; unsigned int last_dependency; atomic_t karma; struct spsc_node queue_node; struct list_head list; union { struct dma_fence_cb finish_cb; struct work_struct work; }; struct dma_fence_cb cb; struct xarray dependencies; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMFhjubh)}(h **Members**h]j) }(hj'h]hMembers}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMYhjubj)}(hhh](j)}(h=``submit_ts`` When the job was pushed into the entity queue. h](j)}(h ``submit_ts``h]j)}(hjFh]h submit_ts}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjDubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMWhj@ubj )}(hhh]h)}(h.When the job was pushed into the entity queue.h]h.When the job was pushed into the entity queue.}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj[hMWhj\ubah}(h]h ]h"]h$]h&]uh1j hj@ubeh}(h]h ]h"]h$]h&]uh1jhj[hMWhj=ubj)}(h``sched`` The scheduler this job is or will be scheduled on. Gets set by drm_sched_job_arm(). Valid until drm_sched_backend_ops.free_job() has finished. h](j)}(h ``sched``h]j)}(hjh]hsched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj}ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM`hjyubj )}(hhh]h)}(hThe scheduler this job is or will be scheduled on. Gets set by drm_sched_job_arm(). Valid until drm_sched_backend_ops.free_job() has finished.h]hThe scheduler this job is or will be scheduled on. Gets set by drm_sched_job_arm(). Valid until drm_sched_backend_ops.free_job() has finished.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM^hjubah}(h]h ]h"]h$]h&]uh1j hjyubeh}(h]h ]h"]h$]h&]uh1jhjhM`hj=ubj)}(h;``s_fence`` contains the fences for the scheduling of job. h](j)}(h ``s_fence``h]j)}(hjh]hs_fence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMFhjubj )}(hhh]h)}(h.contains the fences for the scheduling of job.h]h.contains the fences for the scheduling of job.}(hjҶhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjζhMFhj϶ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjζhMFhj=ubj)}(h1``entity`` the entity to which this job belongs. h](j)}(h ``entity``h]j)}(hjh]hentity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMNhjubj )}(hhh]h)}(h%the entity to which this job belongs.h]h%the entity to which this job belongs.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMNhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMNhj=ubj)}(h(``s_priority`` the priority of the job. h](j)}(h``s_priority``h]j)}(hj+h]h s_priority}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMMhj%ubj )}(hhh]h)}(hthe priority of the job.h]hthe priority of the job.}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@hMMhjAubah}(h]h ]h"]h$]h&]uh1j hj%ubeh}(h]h ]h"]h$]h&]uh1jhj@hMMhj=ubj)}(hH``credits`` the number of credits this job contributes to the scheduler h](j)}(h ``credits``h]j)}(hjdh]hcredits}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjbubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMHhj^ubj )}(hhh]h)}(h;the number of credits this job contributes to the schedulerh]h;the number of credits this job contributes to the scheduler}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjyhMHhjzubah}(h]h ]h"]h$]h&]uh1j hj^ubeh}(h]h ]h"]h$]h&]uh1jhjyhMHhj=ubj)}(h;``last_dependency`` tracks **dependencies** as they signal h](j)}(h``last_dependency``h]j)}(hjh]hlast_dependency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMkhjubj )}(hhh]h)}(h&tracks **dependencies** as they signalh](htracks }(hjhhhNhNubj)}(h**dependencies**h]h dependencies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh as they signal}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMkhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMkhj=ubj)}(h``karma`` increment on every hang caused by this job. If this exceeds the hang limit of the scheduler then the job is marked guilty and will not be scheduled further. h](j)}(h ``karma``h]j)}(hjh]hkarma}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMLhjubj )}(hhh]h)}(hincrement on every hang caused by this job. If this exceeds the hang limit of the scheduler then the job is marked guilty and will not be scheduled further.h]hincrement on every hang caused by this job. If this exceeds the hang limit of the scheduler then the job is marked guilty and will not be scheduled further.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMJhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMLhj=ubj)}(hM``queue_node`` used to append this struct to the queue of jobs in an entity. h](j)}(h``queue_node``h]j)}(hj"h]h queue_node}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMChjubj )}(hhh]h)}(h=used to append this struct to the queue of jobs in an entity.h]h=used to append this struct to the queue of jobs in an entity.}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj7hMChj8ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj7hMChj=ubj)}(h=``list`` a job participates in a "pending" and "done" lists. h](j)}(h``list``h]j)}(hj[h]hlist}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMDhjUubj )}(hhh]h)}(h3a job participates in a "pending" and "done" lists.h]h;a job participates in a “pending” and “done” lists.}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhjphMDhjqubah}(h]h ]h"]h$]h&]uh1j hjUubeh}(h]h ]h"]h$]h&]uh1jhjphMDhj=ubj)}(h``{unnamed_union}`` anonymous h](j)}(h``{unnamed_union}``h]j)}(hjh]h{unnamed_union}}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhKhjubj )}(hhh]h)}(h anonymoush]h anonymous}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhKhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhKhj=ubj)}(h3``finish_cb`` the callback for the finished fence. h](j)}(h ``finish_cb``h]j)}(hj͸h]h finish_cb}(hjϸhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj˸ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMGhjǸubj )}(hhh]h)}(h$the callback for the finished fence.h]h$the callback for the finished fence.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMGhjubah}(h]h ]h"]h$]h&]uh1j hjǸubeh}(h]h ]h"]h$]h&]uh1jhjhMGhj=ubj)}(h=``work`` Helper to reschedule job kill to different context. h](j)}(h``work``h]j)}(hjh]hwork}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMIhjubj )}(hhh]h)}(h3Helper to reschedule job kill to different context.h]h3Helper to reschedule job kill to different context.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMIhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMIhj=ubj)}(h5``cb`` the callback for the parent fence in s_fence. h](j)}(h``cb``h]j)}(hj?h]hcb}(hjAhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj=ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMOhj9ubj )}(hhh]h)}(h-the callback for the parent fence in s_fence.h]h-the callback for the parent fence in s_fence.}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjThMOhjUubah}(h]h ]h"]h$]h&]uh1j hj9ubeh}(h]h ]h"]h$]h&]uh1jhjThMOhj=ubj)}(h``dependencies`` Contains the dependencies as struct dma_fence for this job, see drm_sched_job_add_dependency() and drm_sched_job_add_implicit_dependencies().h](j)}(h``dependencies``h]j)}(hjxh]h dependencies}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjrubj )}(hhh]h)}(hContains the dependencies as struct dma_fence for this job, see drm_sched_job_add_dependency() and drm_sched_job_add_implicit_dependencies().h]hContains the dependencies as struct dma_fence for this job, see drm_sched_job_add_dependency() and drm_sched_job_add_implicit_dependencies().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM~hjubah}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhMhj=ubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjhhubh)}(hA job is created by the driver using drm_sched_job_init(), and should call drm_sched_entity_push_job() once it wants the scheduler to schedule the job.h]hA job is created by the driver using drm_sched_job_init(), and should call drm_sched_entity_push_job() once it wants the scheduler to schedule the job.}(hjѹhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMOhjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpu_sched_stat (C enum)c.drm_gpu_sched_stathNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_gpu_sched_stath]j>)}(henum drm_gpu_sched_stath](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMVubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMVubjg)}(hdrm_gpu_sched_stath]jm)}(hjh]hdrm_gpu_sched_stat}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMVubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMVubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMVhjhhubj)}(hhh]h)}(hthe scheduler's statush]hthe scheduler’s status}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj8hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMVubeh}(h]h ](jenumeh"]h$]h&]jjjjSjjSjjjuh1j2hhhjhNhNubj)}(hXC**Constants** ``DRM_GPU_SCHED_STAT_NONE`` Reserved. Do not use. ``DRM_GPU_SCHED_STAT_RESET`` The GPU hung and successfully reset. ``DRM_GPU_SCHED_STAT_ENODEV`` Error: Device is not available anymore. ``DRM_GPU_SCHED_STAT_NO_HANG`` Contrary to scheduler's assumption, the GPU did not hang and is still running.h](h)}(h **Constants**h]j)}(hj]h]h Constants}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjWubj)}(hhh](j)}(h2``DRM_GPU_SCHED_STAT_NONE`` Reserved. Do not use. h](j)}(h``DRM_GPU_SCHED_STAT_NONE``h]j)}(hj|h]hDRM_GPU_SCHED_STAT_NONE}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjvubj )}(hhh]h)}(hReserved. Do not use.h]hReserved. Do not use.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjvubeh}(h]h ]h"]h$]h&]uh1jhjhMhjsubj)}(hB``DRM_GPU_SCHED_STAT_RESET`` The GPU hung and successfully reset. h](j)}(h``DRM_GPU_SCHED_STAT_RESET``h]j)}(hjh]hDRM_GPU_SCHED_STAT_RESET}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h$The GPU hung and successfully reset.h]h$The GPU hung and successfully reset.}(hjκhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjʺhMhj˺ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjʺhMhjsubj)}(hF``DRM_GPU_SCHED_STAT_ENODEV`` Error: Device is not available anymore. h](j)}(h``DRM_GPU_SCHED_STAT_ENODEV``h]j)}(hjh]hDRM_GPU_SCHED_STAT_ENODEV}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h'Error: Device is not available anymore.h]h'Error: Device is not available anymore.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjsubj)}(hm``DRM_GPU_SCHED_STAT_NO_HANG`` Contrary to scheduler's assumption, the GPU did not hang and is still running.h](j)}(h``DRM_GPU_SCHED_STAT_NO_HANG``h]j)}(hj'h]hDRM_GPU_SCHED_STAT_NO_HANG}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj!ubj )}(hhh]h)}(hNContrary to scheduler's assumption, the GPU did not hang and is still running.h]hPContrary to scheduler’s assumption, the GPU did not hang and is still running.}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj=ubah}(h]h ]h"]h$]h&]uh1j hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhjsubeh}(h]h ]h"]h$]h&]uh1jhjWubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_sched_backend_ops (C struct)c.drm_sched_backend_opshNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_sched_backend_opsh]j>)}(hstruct drm_sched_backend_opsh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj|hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj|hhhjhMubjg)}(hdrm_sched_backend_opsh]jm)}(hjzh]hdrm_sched_backend_ops}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj|hhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjxhhhjhMubah}(h]jsah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjuhhubj)}(hhh]h)}(h5Define the backend operations called by the schedulerh]h5Define the backend operations called by the scheduler}(hj»hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjhhubah}(h]h ]h"]h$]h&]uh1jhjuhhhjhMubeh}(h]h ](jstructeh"]h$]h&]jjjjڻjjڻjjjuh1j2hhhjhNhNubj)}(hX**Definition**:: struct drm_sched_backend_ops { struct dma_fence *(*prepare_job)(struct drm_sched_job *sched_job, struct drm_sched_entity *s_entity); struct dma_fence *(*run_job)(struct drm_sched_job *sched_job); enum drm_gpu_sched_stat (*timedout_job)(struct drm_sched_job *sched_job); void (*free_job)(struct drm_sched_job *sched_job); void (*cancel_job)(struct drm_sched_job *sched_job); }; **Members** ``prepare_job`` Called when the scheduler is considering scheduling this job next, to get another struct dma_fence for this job to block on. Once it returns NULL, run_job() may be called. Can be NULL if no additional preparation to the dependencies are necessary. Skipped when jobs are killed instead of run. ``run_job`` Called to execute the job once all of the dependencies have been resolved. **sched_job**: the job to run The deprecated drm_sched_resubmit_jobs() (called by :c:type:`struct drm_sched_backend_ops `.timedout_job) can invoke this again with the same parameters. Using this is discouraged because it violates dma_fence rules, notably dma_fence_init() has to be called on already initialized fences for a second time. Moreover, this is dangerous because attempts to allocate memory might deadlock with memory management code waiting for the reset to complete. TODO: Document what drivers should do / use instead. This method is called in a workqueue context - either from the submit_wq the driver passed through drm_sched_init(), or, if the driver passed NULL, a separate, ordered workqueue the scheduler allocated. Note that the scheduler expects to 'inherit' its own reference to this fence from the callback. It does not invoke an extra dma_fence_get() on it. Consequently, this callback must take a reference for the scheduler, and additional ones for the driver's respective needs. Return: * On success: dma_fence the driver must signal once the hardware has completed the job ("hardware fence"). * On failure: NULL or an ERR_PTR. ``timedout_job`` Called when a job has taken too long to execute, to trigger GPU recovery. **sched_job**: The job that has timed out Drivers typically issue a reset to recover from GPU hangs. This procedure looks very different depending on whether a firmware or a hardware scheduler is being used. For a FIRMWARE SCHEDULER, each ring has one scheduler, and each scheduler has one entity. Hence, the steps taken typically look as follows: 1. Stop the scheduler using drm_sched_stop(). This will pause the scheduler workqueues and cancel the timeout work, guaranteeing that nothing is queued while the ring is being removed. 2. Remove the ring. The firmware will make sure that the corresponding parts of the hardware are resetted, and that other rings are not impacted. 3. Kill the entity and the associated scheduler. For a HARDWARE SCHEDULER, a scheduler instance schedules jobs from one or more entities to one ring. This implies that all entities associated with the affected scheduler cannot be torn down, because this would effectively also affect innocent userspace processes which did not submit faulty jobs (for example). Consequently, the procedure to recover with a hardware scheduler should look like this: 1. Stop all schedulers impacted by the reset using drm_sched_stop(). 2. Kill the entity the faulty job stems from. 3. Issue a GPU reset on all faulty rings (driver-specific). 4. Re-submit jobs on all schedulers impacted by re-submitting them to the entities which are still alive. 5. Restart all schedulers that were stopped in step #1 using drm_sched_start(). Note that some GPUs have distinct hardware queues but need to reset the GPU globally, which requires extra synchronization between the timeout handlers of different schedulers. One way to achieve this synchronization is to create an ordered workqueue (using alloc_ordered_workqueue()) at the driver level, and pass this queue as drm_sched_init()'s **timeout_wq** parameter. This will guarantee that timeout handlers are executed sequentially. Return: The scheduler's status, defined by :c:type:`enum drm_gpu_sched_stat ` ``free_job`` Called once the job's finished fence has been signaled and it's time to clean it up. ``cancel_job`` Used by the scheduler to guarantee remaining jobs' fences get signaled in drm_sched_fini(). Used by the scheduler to cancel all jobs that have not been executed with :c:type:`struct drm_sched_backend_ops `.run_job by the time drm_sched_fini() gets invoked. Drivers need to signal the passed job's hardware fence with an appropriate error code (e.g., -ECANCELED) in this callback. They must not free the job. The scheduler will only call this callback once it stopped calling all other callbacks forever, with the exception of :c:type:`struct drm_sched_backend_ops `.free_job.h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj޻ubjT)}(hXstruct drm_sched_backend_ops { struct dma_fence *(*prepare_job)(struct drm_sched_job *sched_job, struct drm_sched_entity *s_entity); struct dma_fence *(*run_job)(struct drm_sched_job *sched_job); enum drm_gpu_sched_stat (*timedout_job)(struct drm_sched_job *sched_job); void (*free_job)(struct drm_sched_job *sched_job); void (*cancel_job)(struct drm_sched_job *sched_job); };h]hXstruct drm_sched_backend_ops { struct dma_fence *(*prepare_job)(struct drm_sched_job *sched_job, struct drm_sched_entity *s_entity); struct dma_fence *(*run_job)(struct drm_sched_job *sched_job); enum drm_gpu_sched_stat (*timedout_job)(struct drm_sched_job *sched_job); void (*free_job)(struct drm_sched_job *sched_job); void (*cancel_job)(struct drm_sched_job *sched_job); };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj޻ubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj޻ubj)}(hhh](j)}(hX7``prepare_job`` Called when the scheduler is considering scheduling this job next, to get another struct dma_fence for this job to block on. Once it returns NULL, run_job() may be called. Can be NULL if no additional preparation to the dependencies are necessary. Skipped when jobs are killed instead of run. h](j)}(h``prepare_job``h]j)}(hj/h]h prepare_job}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj)ubj )}(hhh](h)}(hCalled when the scheduler is considering scheduling this job next, to get another struct dma_fence for this job to block on. Once it returns NULL, run_job() may be called.h]hCalled when the scheduler is considering scheduling this job next, to get another struct dma_fence for this job to block on. Once it returns NULL, run_job() may be called.}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjEubh)}(hxCan be NULL if no additional preparation to the dependencies are necessary. Skipped when jobs are killed instead of run.h]hxCan be NULL if no additional preparation to the dependencies are necessary. Skipped when jobs are killed instead of run.}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjEubeh}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhMhj&ubj)}(hX``run_job`` Called to execute the job once all of the dependencies have been resolved. **sched_job**: the job to run The deprecated drm_sched_resubmit_jobs() (called by :c:type:`struct drm_sched_backend_ops `.timedout_job) can invoke this again with the same parameters. Using this is discouraged because it violates dma_fence rules, notably dma_fence_init() has to be called on already initialized fences for a second time. Moreover, this is dangerous because attempts to allocate memory might deadlock with memory management code waiting for the reset to complete. TODO: Document what drivers should do / use instead. This method is called in a workqueue context - either from the submit_wq the driver passed through drm_sched_init(), or, if the driver passed NULL, a separate, ordered workqueue the scheduler allocated. Note that the scheduler expects to 'inherit' its own reference to this fence from the callback. It does not invoke an extra dma_fence_get() on it. Consequently, this callback must take a reference for the scheduler, and additional ones for the driver's respective needs. Return: * On success: dma_fence the driver must signal once the hardware has completed the job ("hardware fence"). * On failure: NULL or an ERR_PTR. h](j)}(h ``run_job``h]j)}(hjxh]hrun_job}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjvubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjrubj )}(hhh](h)}(hJCalled to execute the job once all of the dependencies have been resolved.h]hJCalled to execute the job once all of the dependencies have been resolved.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(h**sched_job**: the job to runh](j)}(h **sched_job**h]h sched_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh: the job to run}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(hXThe deprecated drm_sched_resubmit_jobs() (called by :c:type:`struct drm_sched_backend_ops `.timedout_job) can invoke this again with the same parameters. Using this is discouraged because it violates dma_fence rules, notably dma_fence_init() has to be called on already initialized fences for a second time. Moreover, this is dangerous because attempts to allocate memory might deadlock with memory management code waiting for the reset to complete.h](h4The deprecated drm_sched_resubmit_jobs() (called by }(hjhhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hjǼh]hstruct drm_sched_backend_ops}(hjɼhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjżubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubhXf.timedout_job) can invoke this again with the same parameters. Using this is discouraged because it violates dma_fence rules, notably dma_fence_init() has to be called on already initialized fences for a second time. Moreover, this is dangerous because attempts to allocate memory might deadlock with memory management code waiting for the reset to complete.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjubh)}(h4TODO: Document what drivers should do / use instead.h]h4TODO: Document what drivers should do / use instead.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(hThis method is called in a workqueue context - either from the submit_wq the driver passed through drm_sched_init(), or, if the driver passed NULL, a separate, ordered workqueue the scheduler allocated.h]hThis method is called in a workqueue context - either from the submit_wq the driver passed through drm_sched_init(), or, if the driver passed NULL, a separate, ordered workqueue the scheduler allocated.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(hXNote that the scheduler expects to 'inherit' its own reference to this fence from the callback. It does not invoke an extra dma_fence_get() on it. Consequently, this callback must take a reference for the scheduler, and additional ones for the driver's respective needs.h]hXNote that the scheduler expects to ‘inherit’ its own reference to this fence from the callback. It does not invoke an extra dma_fence_get() on it. Consequently, this callback must take a reference for the scheduler, and additional ones for the driver’s respective needs.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(hReturn: * On success: dma_fence the driver must signal once the hardware has completed the job ("hardware fence"). * On failure: NULL or an ERR_PTR.h]hReturn: * On success: dma_fence the driver must signal once the hardware has completed the job (“hardware fence”). * On failure: NULL or an ERR_PTR.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubeh}(h]h ]h"]h$]h&]uh1j hjrubeh}(h]h ]h"]h$]h&]uh1jhjhMhj&ubj)}(hXe``timedout_job`` Called when a job has taken too long to execute, to trigger GPU recovery. **sched_job**: The job that has timed out Drivers typically issue a reset to recover from GPU hangs. This procedure looks very different depending on whether a firmware or a hardware scheduler is being used. For a FIRMWARE SCHEDULER, each ring has one scheduler, and each scheduler has one entity. Hence, the steps taken typically look as follows: 1. Stop the scheduler using drm_sched_stop(). This will pause the scheduler workqueues and cancel the timeout work, guaranteeing that nothing is queued while the ring is being removed. 2. Remove the ring. The firmware will make sure that the corresponding parts of the hardware are resetted, and that other rings are not impacted. 3. Kill the entity and the associated scheduler. For a HARDWARE SCHEDULER, a scheduler instance schedules jobs from one or more entities to one ring. This implies that all entities associated with the affected scheduler cannot be torn down, because this would effectively also affect innocent userspace processes which did not submit faulty jobs (for example). Consequently, the procedure to recover with a hardware scheduler should look like this: 1. Stop all schedulers impacted by the reset using drm_sched_stop(). 2. Kill the entity the faulty job stems from. 3. Issue a GPU reset on all faulty rings (driver-specific). 4. Re-submit jobs on all schedulers impacted by re-submitting them to the entities which are still alive. 5. Restart all schedulers that were stopped in step #1 using drm_sched_start(). Note that some GPUs have distinct hardware queues but need to reset the GPU globally, which requires extra synchronization between the timeout handlers of different schedulers. One way to achieve this synchronization is to create an ordered workqueue (using alloc_ordered_workqueue()) at the driver level, and pass this queue as drm_sched_init()'s **timeout_wq** parameter. This will guarantee that timeout handlers are executed sequentially. Return: The scheduler's status, defined by :c:type:`enum drm_gpu_sched_stat ` h](j)}(h``timedout_job``h]j)}(hj=h]h timedout_job}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj;ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj7ubj )}(hhh](h)}(hICalled when a job has taken too long to execute, to trigger GPU recovery.h]hICalled when a job has taken too long to execute, to trigger GPU recovery.}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubh)}(h)**sched_job**: The job that has timed outh](j)}(h **sched_job**h]h sched_job}(hjihhhNhNubah}(h]h ]h"]h$]h&]uh1jhjeubh: The job that has timed out}(hjehhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubh)}(hDrivers typically issue a reset to recover from GPU hangs. This procedure looks very different depending on whether a firmware or a hardware scheduler is being used.h]hDrivers typically issue a reset to recover from GPU hangs. This procedure looks very different depending on whether a firmware or a hardware scheduler is being used.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubh)}(hFor a FIRMWARE SCHEDULER, each ring has one scheduler, and each scheduler has one entity. Hence, the steps taken typically look as follows:h]hFor a FIRMWARE SCHEDULER, each ring has one scheduler, and each scheduler has one entity. Hence, the steps taken typically look as follows:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubj:)}(hhh](j{)}(hStop the scheduler using drm_sched_stop(). This will pause the scheduler workqueues and cancel the timeout work, guaranteeing that nothing is queued while the ring is being removed.h]h)}(hStop the scheduler using drm_sched_stop(). This will pause the scheduler workqueues and cancel the timeout work, guaranteeing that nothing is queued while the ring is being removed.h]hStop the scheduler using drm_sched_stop(). This will pause the scheduler workqueues and cancel the timeout work, guaranteeing that nothing is queued while the ring is being removed.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(hRemove the ring. The firmware will make sure that the corresponding parts of the hardware are resetted, and that other rings are not impacted.h]h)}(hRemove the ring. The firmware will make sure that the corresponding parts of the hardware are resetted, and that other rings are not impacted.h]hRemove the ring. The firmware will make sure that the corresponding parts of the hardware are resetted, and that other rings are not impacted.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(h/Kill the entity and the associated scheduler. h]h)}(h-Kill the entity and the associated scheduler.h]h-Kill the entity and the associated scheduler.}(hjٽhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjսubah}(h]h ]h"]h$]h&]uh1j{hjubeh}(h]h ]h"]h$]h&]jG=jH=jI=hjJ=juh1j~:hjSubh)}(hX7For a HARDWARE SCHEDULER, a scheduler instance schedules jobs from one or more entities to one ring. This implies that all entities associated with the affected scheduler cannot be torn down, because this would effectively also affect innocent userspace processes which did not submit faulty jobs (for example).h]hX7For a HARDWARE SCHEDULER, a scheduler instance schedules jobs from one or more entities to one ring. This implies that all entities associated with the affected scheduler cannot be torn down, because this would effectively also affect innocent userspace processes which did not submit faulty jobs (for example).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubh)}(hWConsequently, the procedure to recover with a hardware scheduler should look like this:h]hWConsequently, the procedure to recover with a hardware scheduler should look like this:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubj:)}(hhh](j{)}(hAStop all schedulers impacted by the reset using drm_sched_stop().h]h)}(hjh]hAStop all schedulers impacted by the reset using drm_sched_stop().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(h*Kill the entity the faulty job stems from.h]h)}(hj/h]h*Kill the entity the faulty job stems from.}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj-ubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(h8Issue a GPU reset on all faulty rings (driver-specific).h]h)}(hjGh]h8Issue a GPU reset on all faulty rings (driver-specific).}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjEubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(hfRe-submit jobs on all schedulers impacted by re-submitting them to the entities which are still alive.h]h)}(hfRe-submit jobs on all schedulers impacted by re-submitting them to the entities which are still alive.h]hfRe-submit jobs on all schedulers impacted by re-submitting them to the entities which are still alive.}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj]ubah}(h]h ]h"]h$]h&]uh1j{hjubj{)}(hMRestart all schedulers that were stopped in step #1 using drm_sched_start(). h]h)}(hLRestart all schedulers that were stopped in step #1 using drm_sched_start().h]hLRestart all schedulers that were stopped in step #1 using drm_sched_start().}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjvubah}(h]h ]h"]h$]h&]uh1j{hjubeh}(h]h ]h"]h$]h&]jG=jH=jI=hjJ=juh1j~:hjSubh)}(hXNote that some GPUs have distinct hardware queues but need to reset the GPU globally, which requires extra synchronization between the timeout handlers of different schedulers. One way to achieve this synchronization is to create an ordered workqueue (using alloc_ordered_workqueue()) at the driver level, and pass this queue as drm_sched_init()'s **timeout_wq** parameter. This will guarantee that timeout handlers are executed sequentially.h](hX^Note that some GPUs have distinct hardware queues but need to reset the GPU globally, which requires extra synchronization between the timeout handlers of different schedulers. One way to achieve this synchronization is to create an ordered workqueue (using alloc_ordered_workqueue()) at the driver level, and pass this queue as drm_sched_init()’s }(hjhhhNhNubj)}(h**timeout_wq**h]h timeout_wq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhP parameter. This will guarantee that timeout handlers are executed sequentially.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjSubh)}(haReturn: The scheduler's status, defined by :c:type:`enum drm_gpu_sched_stat `h](h-Return: The scheduler’s status, defined by }(hjhhhNhNubh)}(h6:c:type:`enum drm_gpu_sched_stat `h]j)}(hjh]henum drm_gpu_sched_stat}(hj¾hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpu_sched_statuh1hhjRhMhjubeh}(h]h ]h"]h$]h&]uh1hhjRhMhjSubeh}(h]h ]h"]h$]h&]uh1j hj7ubeh}(h]h ]h"]h$]h&]uh1jhjRhMhj&ubj)}(hb``free_job`` Called once the job's finished fence has been signaled and it's time to clean it up. h](j)}(h ``free_job``h]j)}(hjh]hfree_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(hTCalled once the job's finished fence has been signaled and it's time to clean it up.h]hXCalled once the job’s finished fence has been signaled and it’s time to clean it up.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhj&ubj)}(hX``cancel_job`` Used by the scheduler to guarantee remaining jobs' fences get signaled in drm_sched_fini(). Used by the scheduler to cancel all jobs that have not been executed with :c:type:`struct drm_sched_backend_ops `.run_job by the time drm_sched_fini() gets invoked. Drivers need to signal the passed job's hardware fence with an appropriate error code (e.g., -ECANCELED) in this callback. They must not free the job. The scheduler will only call this callback once it stopped calling all other callbacks forever, with the exception of :c:type:`struct drm_sched_backend_ops `.free_job.h](j)}(h``cancel_job``h]j)}(hj/h]h cancel_job}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj-ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj)ubj )}(hhh](h)}(h[Used by the scheduler to guarantee remaining jobs' fences get signaled in drm_sched_fini().h]h]Used by the scheduler to guarantee remaining jobs’ fences get signaled in drm_sched_fini().}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hjEubh)}(hUsed by the scheduler to cancel all jobs that have not been executed with :c:type:`struct drm_sched_backend_ops `.run_job by the time drm_sched_fini() gets invoked.h](hJUsed by the scheduler to cancel all jobs that have not been executed with }(hjWhhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hjah]hstruct drm_sched_backend_ops}(hjchhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hjWubh3.run_job by the time drm_sched_fini() gets invoked.}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj~hM hjEubh)}(hDrivers need to signal the passed job's hardware fence with an appropriate error code (e.g., -ECANCELED) in this callback. They must not free the job.h]hDrivers need to signal the passed job’s hardware fence with an appropriate error code (e.g., -ECANCELED) in this callback. They must not free the job.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjEubh)}(hThe scheduler will only call this callback once it stopped calling all other callbacks forever, with the exception of :c:type:`struct drm_sched_backend_ops `.free_job.h](hvThe scheduler will only call this callback once it stopped calling all other callbacks forever, with the exception of }(hjhhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hjh]hstruct drm_sched_backend_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh .free_job.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhjEubeh}(h]h ]h"]h$]h&]uh1j hj)ubeh}(h]h ]h"]h$]h&]uh1jhjDhMhj&ubeh}(h]h ]h"]h$]h&]uh1jhj޻ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjhhubh)}(h9These functions should be implemented in the driver side.h]h9These functions should be implemented in the driver side.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_gpu_scheduler (C struct)c.drm_gpu_schedulerhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_gpu_schedulerh]j>)}(hstruct drm_gpu_schedulerh](jD)}(hjh]hstruct}(hj#hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMubjV)}(h h]h }(hj1hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj0hMubjg)}(hdrm_gpu_schedulerh]jm)}(hjh]hdrm_gpu_scheduler}(hjChhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj0hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj0hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj0hMhjhhubj)}(hhh]h)}(h scheduler instance-specific datah]h scheduler instance-specific data}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjbhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj0hMubeh}(h]h ](jstructeh"]h$]h&]jjjj}jj}jjjuh1j2hhhjhNhNubj)}(hX **Definition**:: struct drm_gpu_scheduler { const struct drm_sched_backend_ops *ops; u32 credit_limit; atomic_t credit_count; long timeout; const char *name; u32 num_rqs; struct drm_sched_rq **sched_rq; wait_queue_head_t job_scheduled; atomic64_t job_id_count; struct workqueue_struct *submit_wq; struct workqueue_struct *timeout_wq; struct work_struct work_run_job; struct work_struct work_free_job; struct delayed_work work_tdr; struct list_head pending_list; spinlock_t job_list_lock; int hang_limit; atomic_t *score; atomic_t _score; bool ready; bool free_guilty; bool pause_submit; bool own_submit_wq; struct device *dev; }; **Members** ``ops`` backend operations provided by the driver. ``credit_limit`` the credit limit of this scheduler ``credit_count`` the current credit count of this scheduler ``timeout`` the time after which a job is removed from the scheduler. ``name`` name of the ring for which this scheduler is being used. ``num_rqs`` Number of run-queues. This is at most DRM_SCHED_PRIORITY_COUNT, as there's usually one run-queue per priority, but could be less. ``sched_rq`` An allocated array of run-queues of size **num_rqs**; ``job_scheduled`` once drm_sched_entity_flush() is called the scheduler waits on this wait queue until all the scheduled jobs are finished. ``job_id_count`` used to assign unique id to the each job. ``submit_wq`` workqueue used to queue **work_run_job** and **work_free_job** ``timeout_wq`` workqueue used to queue **work_tdr** ``work_run_job`` work which calls run_job op of each scheduler. ``work_free_job`` work which calls free_job op of each scheduler. ``work_tdr`` schedules a delayed call to **drm_sched_job_timedout** after the timeout interval is over. ``pending_list`` the list of jobs which are currently in the job queue. ``job_list_lock`` lock to protect the pending_list. ``hang_limit`` once the hangs by a job crosses this limit then it is marked guilty and it will no longer be considered for scheduling. ``score`` score to help loadbalancer pick a idle sched ``_score`` score used when the driver doesn't provide one ``ready`` marks if the underlying HW is ready to work ``free_guilty`` A hit to time out handler to free the guilty job. ``pause_submit`` pause queuing of **work_run_job** on **submit_wq** ``own_submit_wq`` scheduler owns allocation of **submit_wq** ``dev`` system :c:type:`struct device `h](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubjT)}(hXAstruct drm_gpu_scheduler { const struct drm_sched_backend_ops *ops; u32 credit_limit; atomic_t credit_count; long timeout; const char *name; u32 num_rqs; struct drm_sched_rq **sched_rq; wait_queue_head_t job_scheduled; atomic64_t job_id_count; struct workqueue_struct *submit_wq; struct workqueue_struct *timeout_wq; struct work_struct work_run_job; struct work_struct work_free_job; struct delayed_work work_tdr; struct list_head pending_list; spinlock_t job_list_lock; int hang_limit; atomic_t *score; atomic_t _score; bool ready; bool free_guilty; bool pause_submit; bool own_submit_wq; struct device *dev; };h]hXAstruct drm_gpu_scheduler { const struct drm_sched_backend_ops *ops; u32 credit_limit; atomic_t credit_count; long timeout; const char *name; u32 num_rqs; struct drm_sched_rq **sched_rq; wait_queue_head_t job_scheduled; atomic64_t job_id_count; struct workqueue_struct *submit_wq; struct workqueue_struct *timeout_wq; struct work_struct work_run_job; struct work_struct work_free_job; struct delayed_work work_tdr; struct list_head pending_list; spinlock_t job_list_lock; int hang_limit; atomic_t *score; atomic_t _score; bool ready; bool free_guilty; bool pause_submit; bool own_submit_wq; struct device *dev; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM!hjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM<hjubj)}(hhh](j)}(h3``ops`` backend operations provided by the driver. h](j)}(h``ops``h]j)}(hjh]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h*backend operations provided by the driver.h]h*backend operations provided by the driver.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h4``credit_limit`` the credit limit of this scheduler h](j)}(h``credit_limit``h]j)}(hj h]h credit_limit}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h"the credit limit of this schedulerh]h"the credit limit of this scheduler}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj!ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(h<``credit_count`` the current credit count of this scheduler h](j)}(h``credit_count``h]j)}(hjDh]h credit_count}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM hj>ubj )}(hhh]h)}(h*the current credit count of this schedulerh]h*the current credit count of this scheduler}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjYhM hjZubah}(h]h ]h"]h$]h&]uh1j hj>ubeh}(h]h ]h"]h$]h&]uh1jhjYhM hjubj)}(hF``timeout`` the time after which a job is removed from the scheduler. h](j)}(h ``timeout``h]j)}(hj}h]htimeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM!hjwubj )}(hhh]h)}(h9the time after which a job is removed from the scheduler.h]h9the time after which a job is removed from the scheduler.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM!hjubah}(h]h ]h"]h$]h&]uh1j hjwubeh}(h]h ]h"]h$]h&]uh1jhjhM!hjubj)}(hB``name`` name of the ring for which this scheduler is being used. h](j)}(h``name``h]j)}(hjh]hname}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM"hjubj )}(hhh]h)}(h8name of the ring for which this scheduler is being used.h]h8name of the ring for which this scheduler is being used.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM"hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM"hjubj)}(h``num_rqs`` Number of run-queues. This is at most DRM_SCHED_PRIORITY_COUNT, as there's usually one run-queue per priority, but could be less. h](j)}(h ``num_rqs``h]j)}(hjh]hnum_rqs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM$hjubj )}(hhh]h)}(hNumber of run-queues. This is at most DRM_SCHED_PRIORITY_COUNT, as there's usually one run-queue per priority, but could be less.h]hNumber of run-queues. This is at most DRM_SCHED_PRIORITY_COUNT, as there’s usually one run-queue per priority, but could be less.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM#hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM$hjubj)}(hC``sched_rq`` An allocated array of run-queues of size **num_rqs**; h](j)}(h ``sched_rq``h]j)}(hj)h]hsched_rq}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM%hj#ubj )}(hhh]h)}(h5An allocated array of run-queues of size **num_rqs**;h](h)An allocated array of run-queues of size }(hjBhhhNhNubj)}(h **num_rqs**h]hnum_rqs}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubh;}(hjBhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj>hM%hj?ubah}(h]h ]h"]h$]h&]uh1j hj#ubeh}(h]h ]h"]h$]h&]uh1jhj>hM%hjubj)}(h``job_scheduled`` once drm_sched_entity_flush() is called the scheduler waits on this wait queue until all the scheduled jobs are finished. h](j)}(h``job_scheduled``h]j)}(hjth]h job_scheduled}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjrubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM(hjnubj )}(hhh]h)}(hyonce drm_sched_entity_flush() is called the scheduler waits on this wait queue until all the scheduled jobs are finished.h]hyonce drm_sched_entity_flush() is called the scheduler waits on this wait queue until all the scheduled jobs are finished.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM&hjubah}(h]h ]h"]h$]h&]uh1j hjnubeh}(h]h ]h"]h$]h&]uh1jhjhM(hjubj)}(h;``job_id_count`` used to assign unique id to the each job. h](j)}(h``job_id_count``h]j)}(hjh]h job_id_count}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM)hjubj )}(hhh]h)}(h)used to assign unique id to the each job.h]h)used to assign unique id to the each job.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM)hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM)hjubj)}(hM``submit_wq`` workqueue used to queue **work_run_job** and **work_free_job** h](j)}(h ``submit_wq``h]j)}(hjh]h submit_wq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM*hjubj )}(hhh]h)}(h>workqueue used to queue **work_run_job** and **work_free_job**h](hworkqueue used to queue }(hjhhhNhNubj)}(h**work_run_job**h]h work_run_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h**work_free_job**h]h work_free_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhM*hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM*hjubj)}(h4``timeout_wq`` workqueue used to queue **work_tdr** h](j)}(h``timeout_wq``h]j)}(hj@h]h timeout_wq}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj>ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM+hj:ubj )}(hhh]h)}(h$workqueue used to queue **work_tdr**h](hworkqueue used to queue }(hjYhhhNhNubj)}(h **work_tdr**h]hwork_tdr}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jhjYubeh}(h]h ]h"]h$]h&]uh1hhjUhM+hjVubah}(h]h ]h"]h$]h&]uh1j hj:ubeh}(h]h ]h"]h$]h&]uh1jhjUhM+hjubj)}(h@``work_run_job`` work which calls run_job op of each scheduler. h](j)}(h``work_run_job``h]j)}(hjh]h work_run_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM,hjubj )}(hhh]h)}(h.work which calls run_job op of each scheduler.h]h.work which calls run_job op of each scheduler.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM,hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM,hjubj)}(hB``work_free_job`` work which calls free_job op of each scheduler. h](j)}(h``work_free_job``h]j)}(hjh]h work_free_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM-hjubj )}(hhh]h)}(h/work which calls free_job op of each scheduler.h]h/work which calls free_job op of each scheduler.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM-hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM-hjubj)}(hh``work_tdr`` schedules a delayed call to **drm_sched_job_timedout** after the timeout interval is over. h](j)}(h ``work_tdr``h]j)}(hjh]hwork_tdr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM/hjubj )}(hhh]h)}(hZschedules a delayed call to **drm_sched_job_timedout** after the timeout interval is over.h](hschedules a delayed call to }(hjhhhNhNubj)}(h**drm_sched_job_timedout**h]hdrm_sched_job_timedout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh$ after the timeout interval is over.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM.hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM/hjubj)}(hH``pending_list`` the list of jobs which are currently in the job queue. h](j)}(h``pending_list``h]j)}(hjEh]h pending_list}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM0hj?ubj )}(hhh]h)}(h6the list of jobs which are currently in the job queue.h]h6the list of jobs which are currently in the job queue.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjZhM0hj[ubah}(h]h ]h"]h$]h&]uh1j hj?ubeh}(h]h ]h"]h$]h&]uh1jhjZhM0hjubj)}(h4``job_list_lock`` lock to protect the pending_list. h](j)}(h``job_list_lock``h]j)}(hj~h]h job_list_lock}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM1hjxubj )}(hhh]h)}(h!lock to protect the pending_list.h]h!lock to protect the pending_list.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM1hjubah}(h]h ]h"]h$]h&]uh1j hjxubeh}(h]h ]h"]h$]h&]uh1jhjhM1hjubj)}(h``hang_limit`` once the hangs by a job crosses this limit then it is marked guilty and it will no longer be considered for scheduling. h](j)}(h``hang_limit``h]j)}(hjh]h hang_limit}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM3hjubj )}(hhh]h)}(hwonce the hangs by a job crosses this limit then it is marked guilty and it will no longer be considered for scheduling.h]hwonce the hangs by a job crosses this limit then it is marked guilty and it will no longer be considered for scheduling.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM2hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM3hjubj)}(h7``score`` score to help loadbalancer pick a idle sched h](j)}(h ``score``h]j)}(hjh]hscore}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM4hjubj )}(hhh]h)}(h,score to help loadbalancer pick a idle schedh]h,score to help loadbalancer pick a idle sched}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM4hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM4hjubj)}(h:``_score`` score used when the driver doesn't provide one h](j)}(h ``_score``h]j)}(hj*h]h_score}(hj,hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj(ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM5hj$ubj )}(hhh]h)}(h.score used when the driver doesn't provide oneh]h0score used when the driver doesn’t provide one}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj?hM5hj@ubah}(h]h ]h"]h$]h&]uh1j hj$ubeh}(h]h ]h"]h$]h&]uh1jhj?hM5hjubj)}(h6``ready`` marks if the underlying HW is ready to work h](j)}(h ``ready``h]j)}(hjch]hready}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1jhjaubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM6hj]ubj )}(hhh]h)}(h+marks if the underlying HW is ready to workh]h+marks if the underlying HW is ready to work}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjxhM6hjyubah}(h]h ]h"]h$]h&]uh1j hj]ubeh}(h]h ]h"]h$]h&]uh1jhjxhM6hjubj)}(hB``free_guilty`` A hit to time out handler to free the guilty job. h](j)}(h``free_guilty``h]j)}(hjh]h free_guilty}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM7hjubj )}(hhh]h)}(h1A hit to time out handler to free the guilty job.h]h1A hit to time out handler to free the guilty job.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM7hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM7hjubj)}(hD``pause_submit`` pause queuing of **work_run_job** on **submit_wq** h](j)}(h``pause_submit``h]j)}(hjh]h pause_submit}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM8hjubj )}(hhh]h)}(h2pause queuing of **work_run_job** on **submit_wq**h](hpause queuing of }(hjhhhNhNubj)}(h**work_run_job**h]h work_run_job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh on }(hjhhhNhNubj)}(h **submit_wq**h]h submit_wq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1hhjhM8hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM8hjubj)}(h=``own_submit_wq`` scheduler owns allocation of **submit_wq** h](j)}(h``own_submit_wq``h]j)}(hj.h]h own_submit_wq}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM9hj(ubj )}(hhh]h)}(h*scheduler owns allocation of **submit_wq**h](hscheduler owns allocation of }(hjGhhhNhNubj)}(h **submit_wq**h]h submit_wq}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjGubeh}(h]h ]h"]h$]h&]uh1hhjChM9hjDubah}(h]h ]h"]h$]h&]uh1j hj(ubeh}(h]h ]h"]h$]h&]uh1jhjChM9hjubj)}(h/``dev`` system :c:type:`struct device `h](j)}(h``dev``h]j)}(hjuh]hdev}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjsubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM9hjoubj )}(hhh]h)}(h'system :c:type:`struct device `h](hsystem }(hjhhhNhNubh)}(h :c:type:`struct device `h]j)}(hjh]h struct device}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdeviceuh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM:hjubeh}(h]h ]h"]h$]h&]uh1hhjhM:hjubah}(h]h ]h"]h$]h&]uh1j hjoubeh}(h]h ]h"]h$]h&]uh1jhjhM9hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM=hjhhubh)}(h4One scheduler is implemented for each hardware ring.h]h4One scheduler is implemented for each hardware ring.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM:hjhhubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_init_args (C struct)c.drm_sched_init_argshNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_sched_init_argsh]j>)}(hstruct drm_sched_init_argsh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM?ubjV)}(h h]h }(hj#hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj"hM?ubjg)}(hdrm_sched_init_argsh]jm)}(hjh]hdrm_sched_init_args}(hj5hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj1ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj"hM?ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj"hM?ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj"hM?hj hhubj)}(hhh]h)}(h/parameters for initializing a DRM GPU schedulerh]h/parameters for initializing a DRM GPU scheduler}(hjWhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMYhjThhubah}(h]h ]h"]h$]h&]uh1jhj hhhj"hM?ubeh}(h]h ](jstructeh"]h$]h&]jjjjojjojjjuh1j2hhhjhNhNubj)}(hX**Definition**:: struct drm_sched_init_args { const struct drm_sched_backend_ops *ops; struct workqueue_struct *submit_wq; struct workqueue_struct *timeout_wq; u32 num_rqs; u32 credit_limit; unsigned int hang_limit; long timeout; atomic_t *score; const char *name; struct device *dev; }; **Members** ``ops`` backend operations provided by the driver ``submit_wq`` workqueue to use for submission. If NULL, an ordered wq is allocated and used. ``timeout_wq`` workqueue to use for timeout work. If NULL, the system_wq is used. ``num_rqs`` Number of run-queues. This may be at most DRM_SCHED_PRIORITY_COUNT, as there's usually one run-queue per priority, but may be less. ``credit_limit`` the number of credits this scheduler can hold from all jobs ``hang_limit`` number of times to allow a job to hang before dropping it. This mechanism is DEPRECATED. Set it to 0. ``timeout`` timeout value in jiffies for submitted jobs. ``score`` score atomic shared with other schedulers. May be NULL. ``name`` name (typically the driver's name). Used for debugging ``dev`` associated device. Used for debuggingh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjwubh:}(hjwhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM]hjsubjT)}(hX6struct drm_sched_init_args { const struct drm_sched_backend_ops *ops; struct workqueue_struct *submit_wq; struct workqueue_struct *timeout_wq; u32 num_rqs; u32 credit_limit; unsigned int hang_limit; long timeout; atomic_t *score; const char *name; struct device *dev; };h]hX6struct drm_sched_init_args { const struct drm_sched_backend_ops *ops; struct workqueue_struct *submit_wq; struct workqueue_struct *timeout_wq; u32 num_rqs; u32 credit_limit; unsigned int hang_limit; long timeout; atomic_t *score; const char *name; struct device *dev; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM_hjsubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMlhjsubj)}(hhh](j)}(h2``ops`` backend operations provided by the driver h](j)}(h``ops``h]j)}(hjh]hops}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM\hjubj )}(hhh]h)}(h)backend operations provided by the driverh]h)backend operations provided by the driver}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM\hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM\hjubj)}(h]``submit_wq`` workqueue to use for submission. If NULL, an ordered wq is allocated and used. h](j)}(h ``submit_wq``h]j)}(hjh]h submit_wq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM^hjubj )}(hhh]h)}(hNworkqueue to use for submission. If NULL, an ordered wq is allocated and used.h]hNworkqueue to use for submission. If NULL, an ordered wq is allocated and used.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM]hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM^hjubj)}(hR``timeout_wq`` workqueue to use for timeout work. If NULL, the system_wq is used. h](j)}(h``timeout_wq``h]j)}(hj7h]h timeout_wq}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMehj1ubj )}(hhh]h)}(hBworkqueue to use for timeout work. If NULL, the system_wq is used.h]hBworkqueue to use for timeout work. If NULL, the system_wq is used.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjLhMehjMubah}(h]h ]h"]h$]h&]uh1j hj1ubeh}(h]h ]h"]h$]h&]uh1jhjLhMehjubj)}(h``num_rqs`` Number of run-queues. This may be at most DRM_SCHED_PRIORITY_COUNT, as there's usually one run-queue per priority, but may be less. h](j)}(h ``num_rqs``h]j)}(hjph]hnum_rqs}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjnubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM`hjjubj )}(hhh]h)}(hNumber of run-queues. This may be at most DRM_SCHED_PRIORITY_COUNT, as there's usually one run-queue per priority, but may be less.h]hNumber of run-queues. This may be at most DRM_SCHED_PRIORITY_COUNT, as there’s usually one run-queue per priority, but may be less.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhM_hjubah}(h]h ]h"]h$]h&]uh1j hjjubeh}(h]h ]h"]h$]h&]uh1jhjhM`hjubj)}(hM``credit_limit`` the number of credits this scheduler can hold from all jobs h](j)}(h``credit_limit``h]j)}(hjh]h credit_limit}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMahjubj )}(hhh]h)}(h;the number of credits this scheduler can hold from all jobsh]h;the number of credits this scheduler can hold from all jobs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMahjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMahjubj)}(hu``hang_limit`` number of times to allow a job to hang before dropping it. This mechanism is DEPRECATED. Set it to 0. h](j)}(h``hang_limit``h]j)}(hjh]h hang_limit}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMchjubj )}(hhh]h)}(henumber of times to allow a job to hang before dropping it. This mechanism is DEPRECATED. Set it to 0.h]henumber of times to allow a job to hang before dropping it. This mechanism is DEPRECATED. Set it to 0.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMbhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMchjubj)}(h9``timeout`` timeout value in jiffies for submitted jobs. h](j)}(h ``timeout``h]j)}(hjh]htimeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMdhjubj )}(hhh]h)}(h,timeout value in jiffies for submitted jobs.h]h,timeout value in jiffies for submitted jobs.}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj2hMdhj3ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj2hMdhjubj)}(hB``score`` score atomic shared with other schedulers. May be NULL. h](j)}(h ``score``h]j)}(hjVh]hscore}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMfhjPubj )}(hhh]h)}(h7score atomic shared with other schedulers. May be NULL.h]h7score atomic shared with other schedulers. May be NULL.}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMfhjlubah}(h]h ]h"]h$]h&]uh1j hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhMfhjubj)}(h@``name`` name (typically the driver's name). Used for debugging h](j)}(h``name``h]j)}(hjh]hname}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMghjubj )}(hhh]h)}(h6name (typically the driver's name). Used for debuggingh]h8name (typically the driver’s name). Used for debugging}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMghjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMghjubj)}(h-``dev`` associated device. Used for debuggingh](j)}(h``dev``h]j)}(hjh]hdev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMghjubj )}(hhh]h)}(h%associated device. Used for debuggingh]h%associated device. Used for debugging}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMghjubeh}(h]h ]h"]h$]h&]uh1jhjsubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_sched_pending_job_iter (C struct)c.drm_sched_pending_job_iterhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_sched_pending_job_iterh]j>)}(h!struct drm_sched_pending_job_iterh](jD)}(hjh]hstruct}(hj"hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjhhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMnubjV)}(h h]h }(hj0hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhj/hMnubjg)}(hdrm_sched_pending_job_iterh]jm)}(hjh]hdrm_sched_pending_job_iter}(hjBhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhj/hMnubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj/hMnubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj/hMnhjhhubj)}(hhh]h)}(h(DRM scheduler pending job iterator stateh]h(DRM scheduler pending job iterator state}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjahhubah}(h]h ]h"]h$]h&]uh1jhjhhhj/hMnubeh}(h]h ](jstructeh"]h$]h&]jjjj|jj|jjjuh1j2hhhjhNhNubj)}(h**Definition**:: struct drm_sched_pending_job_iter { struct drm_gpu_scheduler *sched; }; **Members** ``sched`` DRM scheduler associated with pending job iteratorh](h)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubjT)}(hKstruct drm_sched_pending_job_iter { struct drm_gpu_scheduler *sched; };h]hKstruct drm_sched_pending_job_iter { struct drm_gpu_scheduler *sched; };}hjsbah}(h]h ]h"]h$]h&]jjuh1jShW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj)}(hhh]j)}(h<``sched`` DRM scheduler associated with pending job iteratorh](j)}(h ``sched``h]j)}(hjh]hsched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h2DRM scheduler associated with pending job iteratorh]h2DRM scheduler associated with pending job iterator}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.(drm_sched_for_each_pending_job (C macro) c.drm_sched_for_each_pending_jobhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hdrm_sched_for_each_pending_jobh]j>)}(hdrm_sched_for_each_pending_jobh]jg)}(hdrm_sched_for_each_pending_jobh]jm)}(hj%h]hdrm_sched_for_each_pending_job}(hj/hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj'hhhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMubah}(h]h ]h"]h$]h&]jjjuh1j=jjhj#hhhjBhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjBhMhj hhubj)}(hhh]h}(h]h ]h"]h$]h&]uh1jhj hhhjBhMubeh}(h]h ](jmacroeh"]h$]h&]jjjj[jj[jjjuh1j2hhhjhNhNubh)}(h=``drm_sched_for_each_pending_job (__job, __sched, __entity)``h]j)}(hjah]h9drm_sched_for_each_pending_job (__job, __sched, __entity)}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj_ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjhhubj)}(h+Iterator for each pending job in scheduler h]h)}(h*Iterator for each pending job in schedulerh]h*Iterator for each pending job in scheduler}(hj{hhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjwubah}(h]h ]h"]h$]h&]uh1jhjhMhjhhubj)}(hXJ**Parameters** ``__job`` Current pending job being iterated over ``__sched`` DRM scheduler to iterate over pending jobs ``__entity`` DRM scheduler entity to filter jobs, NULL indicates no filter **Description** Iterator for each pending job in scheduler, filtering on an entity, and enforcing scheduler is fully stoppedh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj)}(hhh](j)}(h2``__job`` Current pending job being iterated over h](j)}(h ``__job``h]j)}(hjh]h__job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h'Current pending job being iterated overh]h'Current pending job being iterated over}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h7``__sched`` DRM scheduler to iterate over pending jobs h](j)}(h ``__sched``h]j)}(hjh]h__sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubj )}(hhh]h)}(h*DRM scheduler to iterate over pending jobsh]h*DRM scheduler to iterate over pending jobs}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hK``__entity`` DRM scheduler entity to filter jobs, NULL indicates no filter h](j)}(h ``__entity``h]j)}(hj'h]h__entity}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj%ubah}(h]h ]h"]h$]h&]uh1jhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhj!ubj )}(hhh]h)}(h=DRM scheduler entity to filter jobs, NULL indicates no filterh]h=DRM scheduler entity to filter jobs, NULL indicates no filter}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj<hMhj=ubah}(h]h ]h"]h$]h&]uh1j hj!ubeh}(h]h ]h"]h$]h&]uh1jhj<hMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjbh]h Description}(hjdhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj`ubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubh)}(hlIterator for each pending job in scheduler, filtering on an entity, and enforcing scheduler is fully stoppedh]hlIterator for each pending job in scheduler, filtering on an entity, and enforcing scheduler is fully stopped}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhW/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:585: ./include/drm/gpu_scheduler.hhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_sched_tdr_queue_imm (C function)c.drm_sched_tdr_queue_immhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h>void drm_sched_tdr_queue_imm (struct drm_gpu_scheduler *sched)h]j>)}(h=void drm_sched_tdr_queue_imm(struct drm_gpu_scheduler *sched)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_tdr_queue_immh]jm)}(hdrm_sched_tdr_queue_immh]hdrm_sched_tdr_queue_imm}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_tdr_queue_immasbuh1hhjubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj0hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hj=hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]j{)}(hhh]j{)}(h%immediately start job timeout handlerh]h)}(hjlh]h%immediately start job timeout handler}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjjubah}(h]h ]h"]h$]h&]uh1j{hjghhhj{hNubah}(h]h ]h"]h$]h&]jj{jk{uh1j{hj{hMhjdhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler for which the timeout handling should be started. **Description** Start timeout handling immediately for the named scheduler.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh]j)}(h```struct drm_gpu_scheduler *sched`` scheduler for which the timeout handling should be started. h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h;scheduler for which the timeout handling should be started.h]h;scheduler for which the timeout handling should be started.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h;Start timeout handling immediately for the named scheduler.h]h;Start timeout handling immediately for the named scheduler.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_fault (C function)c.drm_sched_faulthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h6void drm_sched_fault (struct drm_gpu_scheduler *sched)h]j>)}(h5void drm_sched_fault(struct drm_gpu_scheduler *sched)h](j)}(hvoidh]hvoid}(hj:hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj6hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjIhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj6hhhjHhMubjg)}(hdrm_sched_faulth]jm)}(hdrm_sched_faulth]hdrm_sched_fault}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjWubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj6hhhjHhMubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjwhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjsubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jj]sbc.drm_sched_faultasbuh1hhjsubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjsubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjsubjm)}(hschedh]hsched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjsubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjoubah}(h]h ]h"]h$]h&]jjuh1jhj6hhhjHhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj2hhhjHhMubah}(h]j-ah ](jjeh"]h$]h&]jj)jhuh1j7hjHhMhj/hhubj)}(hhh]h)}(h!immediately start timeout handlerh]h!immediately start timeout handler}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj/hhhjHhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler where the timeout handling should be started. **Description** Start timeout handling immediately when the driver detects a hardware fault.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh]j)}(h\``struct drm_gpu_scheduler *sched`` scheduler where the timeout handling should be started. h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hj;h]hstruct drm_gpu_scheduler *sched}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj5ubj )}(hhh]h)}(h7scheduler where the timeout handling should be started.h]h7scheduler where the timeout handling should be started.}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhjPhMhjQubah}(h]h ]h"]h$]h&]uh1j hj5ubeh}(h]h ]h"]h$]h&]uh1jhjPhMhj2ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjvh]h Description}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hLStart timeout handling immediately when the driver detects a hardware fault.h]hLStart timeout handling immediately when the driver detects a hardware fault.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_sched_suspend_timeout (C function)c.drm_sched_suspend_timeouthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hIunsigned long drm_sched_suspend_timeout (struct drm_gpu_scheduler *sched)h]j>)}(hHunsigned long drm_sched_suspend_timeout(struct drm_gpu_scheduler *sched)h](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubj)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_suspend_timeouth]jm)}(hdrm_sched_suspend_timeouth]hdrm_sched_suspend_timeout}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj!hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hj2hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj/ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj4modnameN classnameNjj)}j]j )}jjsbc.drm_sched_suspend_timeoutasbuh1hhjubjV)}(h h]h }(hjRhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj`hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjmhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hSuspend scheduler job timeouth]hSuspend scheduler job timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hXA**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance for which to suspend the timeout **Description** Suspend the delayed work timeout for the scheduler. This is done by modifying the delayed work timeout to an arbitrary large value, MAX_SCHEDULE_TIMEOUT in this case. Returns the timeout remainingh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh]j)}(hX``struct drm_gpu_scheduler *sched`` scheduler instance for which to suspend the timeout h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h3scheduler instance for which to suspend the timeouth]h3scheduler instance for which to suspend the timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hSuspend the delayed work timeout for the scheduler. This is done by modifying the delayed work timeout to an arbitrary large value, MAX_SCHEDULE_TIMEOUT in this case.h]hSuspend the delayed work timeout for the scheduler. This is done by modifying the delayed work timeout to an arbitrary large value, MAX_SCHEDULE_TIMEOUT in this case.}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hReturns the timeout remainingh]hReturns the timeout remaining}(hj8hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_sched_resume_timeout (C function)c.drm_sched_resume_timeouthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hXvoid drm_sched_resume_timeout (struct drm_gpu_scheduler *sched, unsigned long remaining)h]j>)}(hWvoid drm_sched_resume_timeout(struct drm_gpu_scheduler *sched, unsigned long remaining)h](j)}(hvoidh]hvoid}(hjghhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjchhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjchhhjuhMubjg)}(hdrm_sched_resume_timeouth]jm)}(hdrm_sched_resume_timeouth]hdrm_sched_resume_timeout}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjchhhjuhMubj)}(h:(struct drm_gpu_scheduler *sched, unsigned long remaining)h](j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_resume_timeoutasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned long remainingh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj$hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hlongh]hlong}(hj2hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hj@hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h remainingh]h remaining}(hjNhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjchhhjuhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj_hhhjuhMubah}(h]jZah ](jjeh"]h$]h&]jj)jhuh1j7hjuhMhj\hhubj)}(hhh]h)}(hResume scheduler job timeouth]hResume scheduler job timeout}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjuhhubah}(h]h ]h"]h$]h&]uh1jhj\hhhjuhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance for which to resume the timeout ``unsigned long remaining`` remaining timeout **Description** Resume the delayed work timeout for the scheduler.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh](j)}(hW``struct drm_gpu_scheduler *sched`` scheduler instance for which to resume the timeout h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h2scheduler instance for which to resume the timeouth]h2scheduler instance for which to resume the timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h.``unsigned long remaining`` remaining timeout h](j)}(h``unsigned long remaining``h]j)}(hjh]hunsigned long remaining}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hremaining timeouth]hremaining timeout}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj-h]h Description}(hj/hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj+ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h2Resume the delayed work timeout for the scheduler.h]h2Resume the delayed work timeout for the scheduler.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_stop (C function)c.drm_sched_stophNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hPvoid drm_sched_stop (struct drm_gpu_scheduler *sched, struct drm_sched_job *bad)h]j>)}(hOvoid drm_sched_stop(struct drm_gpu_scheduler *sched, struct drm_sched_job *bad)h](j)}(hvoidh]hvoid}(hjrhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjnhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMFubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjnhhhjhMFubjg)}(hdrm_sched_stoph]jm)}(hdrm_sched_stoph]hdrm_sched_stop}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjnhhhjhMFubj)}(h<(struct drm_gpu_scheduler *sched, struct drm_sched_job *bad)h](j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_stopasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_sched_job *badh](jD)}(hjh]hstruct}(hj!hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj.hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hj?hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj<ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjAmodnameN classnameNjj)}j]jc.drm_sched_stopasbuh1hhjubjV)}(h h]h }(hj]hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjkhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hbadh]hbad}(hjxhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjnhhhjhMFubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjjhhhjhMFubah}(h]jeah ](jjeh"]h$]h&]jj)jhuh1j7hjhMFhjghhubj)}(hhh]h)}(hstop the schedulerh]hstop the scheduler}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMFhjhhubah}(h]h ]h"]h$]h&]uh1jhjghhhjhMFubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hXb**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance ``struct drm_sched_job *bad`` job which caused the time out **Description** Stop the scheduler and also removes and frees all completed jobs. **Note** bad job will not be freed as it might be used later and so it's callers responsibility to release it manually if it's not part of the pending list any more. This function is typically used for reset recovery (see the docu of drm_sched_backend_ops.timedout_job() for details). Do not call it for scheduler teardown, i.e., before calling drm_sched_fini(). As it's only used for reset recovery, drivers must not call this function in their :c:type:`struct drm_sched_backend_ops `.timedout_job callback when they skip a reset using :c:type:`enum drm_gpu_sched_stat `.DRM_GPU_SCHED_STAT_NO_HANG.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMJhjubj)}(hhh](j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMHhjubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMHhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMHhjubj)}(h<``struct drm_sched_job *bad`` job which caused the time out h](j)}(h``struct drm_sched_job *bad``h]j)}(hjh]hstruct drm_sched_job *bad}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMIhjubj )}(hhh]h)}(hjob which caused the time outh]hjob which caused the time out}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj1hMIhj2ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj1hMIhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjWh]h Description}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMKhjubh)}(hAStop the scheduler and also removes and frees all completed jobs.h]hAStop the scheduler and also removes and frees all completed jobs.}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMJhjubh)}(h**Note**h]j)}(hj~h]hNote}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMLhjubh)}(hbad job will not be freed as it might be used later and so it's callers responsibility to release it manually if it's not part of the pending list any more.h]hbad job will not be freed as it might be used later and so it’s callers responsibility to release it manually if it’s not part of the pending list any more.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMLhjubh)}(hThis function is typically used for reset recovery (see the docu of drm_sched_backend_ops.timedout_job() for details). Do not call it for scheduler teardown, i.e., before calling drm_sched_fini().h]hThis function is typically used for reset recovery (see the docu of drm_sched_backend_ops.timedout_job() for details). Do not call it for scheduler teardown, i.e., before calling drm_sched_fini().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMPhjubh)}(hXAs it's only used for reset recovery, drivers must not call this function in their :c:type:`struct drm_sched_backend_ops `.timedout_job callback when they skip a reset using :c:type:`enum drm_gpu_sched_stat `.DRM_GPU_SCHED_STAT_NO_HANG.h](hUAs it’s only used for reset recovery, drivers must not call this function in their }(hjhhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hjh]hstruct drm_sched_backend_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMThjubh4.timedout_job callback when they skip a reset using }(hjhhhNhNubh)}(h6:c:type:`enum drm_gpu_sched_stat `h]j)}(hjh]henum drm_gpu_sched_stat}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpu_sched_statuh1hhjhMThjubh.DRM_GPU_SCHED_STAT_NO_HANG.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMThjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_start (C function)c.drm_sched_starthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hAvoid drm_sched_start (struct drm_gpu_scheduler *sched, int errno)h]j>)}(h@void drm_sched_start(struct drm_gpu_scheduler *sched, int errno)h](j)}(hvoidh]hvoid}(hj'hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj#hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hj6hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj#hhhj5hMubjg)}(hdrm_sched_starth]jm)}(hdrm_sched_starth]hdrm_sched_start}(hjHhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjDubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj#hhhj5hMubj)}(h,(struct drm_gpu_scheduler *sched, int errno)h](j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjdhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj`ubjV)}(h h]h }(hjqhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`ubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjJsbc.drm_sched_startasbuh1hhj`ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj`ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj`ubjm)}(hschedh]hsched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj`ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj\ubj)}(h int errnoh](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(herrnoh]herrno}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj\ubeh}(h]h ]h"]h$]h&]jjuh1jhj#hhhj5hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj5hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj5hMhjhhubj)}(hhh]h)}(hrecover jobs after a reseth]hrecover jobs after a reset}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj5hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj4jj4jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance ``int errno`` error to set on the pending fences **Description** This function is typically used for reset recovery (see the docu of drm_sched_backend_ops.timedout_job() for details). Do not call it for scheduler startup. The scheduler itself is fully operational after drm_sched_init() succeeded. As it's only used for reset recovery, drivers must not call this function in their :c:type:`struct drm_sched_backend_ops `.timedout_job callback when they skip a reset using :c:type:`enum drm_gpu_sched_stat `.DRM_GPU_SCHED_STAT_NO_HANG.h](h)}(h**Parameters**h]j)}(hj>h]h Parameters}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj<ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj8ubj)}(hhh](j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hj]h]hstruct drm_gpu_scheduler *sched}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjWubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjrhMhjsubah}(h]h ]h"]h$]h&]uh1j hjWubeh}(h]h ]h"]h$]h&]uh1jhjrhMhjTubj)}(h1``int errno`` error to set on the pending fences h](j)}(h ``int errno``h]j)}(hjh]h int errno}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h"error to set on the pending fencesh]h"error to set on the pending fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjTubeh}(h]h ]h"]h$]h&]uh1jhj8ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj8ubh)}(hThis function is typically used for reset recovery (see the docu of drm_sched_backend_ops.timedout_job() for details). Do not call it for scheduler startup. The scheduler itself is fully operational after drm_sched_init() succeeded.h]hThis function is typically used for reset recovery (see the docu of drm_sched_backend_ops.timedout_job() for details). Do not call it for scheduler startup. The scheduler itself is fully operational after drm_sched_init() succeeded.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj8ubh)}(hXAs it's only used for reset recovery, drivers must not call this function in their :c:type:`struct drm_sched_backend_ops `.timedout_job callback when they skip a reset using :c:type:`enum drm_gpu_sched_stat `.DRM_GPU_SCHED_STAT_NO_HANG.h](hUAs it’s only used for reset recovery, drivers must not call this function in their }(hjhhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hjh]hstruct drm_sched_backend_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh4.timedout_job callback when they skip a reset using }(hjhhhNhNubh)}(h6:c:type:`enum drm_gpu_sched_stat `h]j)}(hj$h]henum drm_gpu_sched_stat}(hj&hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj"ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_gpu_sched_statuh1hhjhMhjubh.DRM_GPU_SCHED_STAT_NO_HANG.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMhj8ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.$drm_sched_resubmit_jobs (C function)c.drm_sched_resubmit_jobshNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h>void drm_sched_resubmit_jobs (struct drm_gpu_scheduler *sched)h]j>)}(h=void drm_sched_resubmit_jobs(struct drm_gpu_scheduler *sched)h](j)}(hvoidh]hvoid}(hjkhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjghhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjzhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjghhhjyhMubjg)}(hdrm_sched_resubmit_jobsh]jm)}(hdrm_sched_resubmit_jobsh]hdrm_sched_resubmit_jobs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjghhhjyhMubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_resubmit_jobsasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjghhhjyhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjchhhjyhMubah}(h]j^ah ](jjeh"]h$]h&]jj)jhuh1j7hjyhMhj`hhubj)}(hhh]h)}(h"Deprecated, don't use in new code!h]h$Deprecated, don’t use in new code!}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj(hhubah}(h]h ]h"]h$]h&]uh1jhj`hhhjyhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjCjjCjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance **Description** Re-submitting jobs was a concept AMD came up as cheap way to implement recovery after a job timeout. This turned out to be not working very well. First of all there are many problem with the dma_fence implementation and requirements. Either the implementation is risking deadlocks with core memory management or violating documented implementation details of the dma_fence object. Drivers can still save and restore their state for recovery operations, but we shouldn't make this a general scheduler feature around the dma_fence interface. The suggested driver-side replacement is to use drm_sched_for_each_pending_job() after stopping the scheduler and implement their own recovery operations.h](h)}(h**Parameters**h]j)}(hjMh]h Parameters}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjGubj)}(hhh]j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjlh]hstruct drm_gpu_scheduler *sched}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjfubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjfubeh}(h]h ]h"]h$]h&]uh1jhjhMhjcubah}(h]h ]h"]h$]h&]uh1jhjGubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjGubh)}(hdRe-submitting jobs was a concept AMD came up as cheap way to implement recovery after a job timeout.h]hdRe-submitting jobs was a concept AMD came up as cheap way to implement recovery after a job timeout.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjGubh)}(hXThis turned out to be not working very well. First of all there are many problem with the dma_fence implementation and requirements. Either the implementation is risking deadlocks with core memory management or violating documented implementation details of the dma_fence object.h]hXThis turned out to be not working very well. First of all there are many problem with the dma_fence implementation and requirements. Either the implementation is risking deadlocks with core memory management or violating documented implementation details of the dma_fence object.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjGubh)}(hX9Drivers can still save and restore their state for recovery operations, but we shouldn't make this a general scheduler feature around the dma_fence interface. The suggested driver-side replacement is to use drm_sched_for_each_pending_job() after stopping the scheduler and implement their own recovery operations.h]hX;Drivers can still save and restore their state for recovery operations, but we shouldn’t make this a general scheduler feature around the dma_fence interface. The suggested driver-side replacement is to use drm_sched_for_each_pending_job() after stopping the scheduler and implement their own recovery operations.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjGubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_job_init (C function)c.drm_sched_job_inithNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hint drm_sched_job_init (struct drm_sched_job *job, struct drm_sched_entity *entity, u32 credits, void *owner, uint64_t drm_client_id)h]j>)}(hint drm_sched_job_init(struct drm_sched_job *job, struct drm_sched_entity *entity, u32 credits, void *owner, uint64_t drm_client_id)h](j)}(hinth]hint}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_job_inith]jm)}(hdrm_sched_job_inith]hdrm_sched_job_init}(hj+hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj'ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hn(struct drm_sched_job *job, struct drm_sched_entity *entity, u32 credits, void *owner, uint64_t drm_client_id)h](j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjGhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjCubjV)}(h h]h }(hjThhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjgmodnameN classnameNjj)}j]j )}jj-sbc.drm_sched_job_initasbuh1hhjCubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjCubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjCubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjCubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubj)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_sched_job_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hentityh]hentity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubj)}(h u32 creditsh](h)}(hhh]jm)}(hu32h]hu32}(hj,hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj.modnameN classnameNjj)}j]jc.drm_sched_job_initasbuh1hhj%ubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj%ubjm)}(hcreditsh]hcredits}(hjXhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj%ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubj)}(h void *ownerh](j)}(hvoidh]hvoid}(hjqhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjmubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjmubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjmubjm)}(hownerh]howner}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjmubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubj)}(huint64_t drm_client_idh](h)}(hhh]jm)}(huint64_th]huint64_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jc.drm_sched_job_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(h drm_client_idh]h drm_client_id}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj?ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hinit a scheduler jobh]hinit a scheduler job}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj$jj$jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_job *job`` scheduler job to init ``struct drm_sched_entity *entity`` scheduler entity to use ``u32 credits`` the number of credits this job contributes to the schedulers credit limit ``void *owner`` job owner for debugging ``uint64_t drm_client_id`` :c:type:`struct drm_file `.client_id of the owner (used by trace events) **Description** Refer to drm_sched_entity_push_job() documentation for locking considerations. Drivers must make sure drm_sched_job_cleanup() if this function returns successfully, even when **job** is aborted before drm_sched_job_arm() is called. Note that this function does not assign a valid value to each struct member of struct drm_sched_job. Take a look at that struct's documentation to see who sets which struct member with what lifetime. WARNING: amdgpu abuses :c:type:`drm_sched.ready ` to signal when the hardware has died, which can mean that there's no valid runqueue for a **entity**. This function returns -ENOENT in this case (which probably should be -EIO as a more meanigful return value). Returns 0 for success, negative error code otherwise.h](h)}(h**Parameters**h]j)}(hj.h]h Parameters}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hj(ubj)}(hhh](j)}(h4``struct drm_sched_job *job`` scheduler job to init h](j)}(h``struct drm_sched_job *job``h]j)}(hjMh]hstruct drm_sched_job *job}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjGubj )}(hhh]h)}(hscheduler job to inith]hscheduler job to init}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhMhjcubah}(h]h ]h"]h$]h&]uh1j hjGubeh}(h]h ]h"]h$]h&]uh1jhjbhMhjDubj)}(h<``struct drm_sched_entity *entity`` scheduler entity to use h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hjh]hstruct drm_sched_entity *entity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hscheduler entity to useh]hscheduler entity to use}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjDubj)}(hZ``u32 credits`` the number of credits this job contributes to the schedulers credit limit h](j)}(h``u32 credits``h]j)}(hjh]h u32 credits}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubj )}(hhh]h)}(hIthe number of credits this job contributes to the schedulers credit limith]hIthe number of credits this job contributes to the schedulers credit limit}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjDubj)}(h(``void *owner`` job owner for debugging h](j)}(h``void *owner``h]j)}(hjh]h void *owner}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubj )}(hhh]h)}(hjob owner for debuggingh]hjob owner for debugging}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM hjDubj)}(hn``uint64_t drm_client_id`` :c:type:`struct drm_file `.client_id of the owner (used by trace events) h](j)}(h``uint64_t drm_client_id``h]j)}(hj2h]huint64_t drm_client_id}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hj,ubj )}(hhh]h)}(hR:c:type:`struct drm_file `.client_id of the owner (used by trace events)h](h)}(h$:c:type:`struct drm_file `h]j)}(hjQh]hstruct drm_file}(hjShhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjOubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_fileuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjKubh..client_id of the owner (used by trace events)}(hjKhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjnhM hjHubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhM hjDubeh}(h]h ]h"]h$]h&]uh1jhj(ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj(ubh)}(hNRefer to drm_sched_entity_push_job() documentation for locking considerations.h]hNRefer to drm_sched_entity_push_job() documentation for locking considerations.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj(ubh)}(hDrivers must make sure drm_sched_job_cleanup() if this function returns successfully, even when **job** is aborted before drm_sched_job_arm() is called.h](h`Drivers must make sure drm_sched_job_cleanup() if this function returns successfully, even when }(hjhhhNhNubj)}(h**job**h]hjob}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh1 is aborted before drm_sched_job_arm() is called.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj(ubh)}(hNote that this function does not assign a valid value to each struct member of struct drm_sched_job. Take a look at that struct's documentation to see who sets which struct member with what lifetime.h]hNote that this function does not assign a valid value to each struct member of struct drm_sched_job. Take a look at that struct’s documentation to see who sets which struct member with what lifetime.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj(ubh)}(hXWARNING: amdgpu abuses :c:type:`drm_sched.ready ` to signal when the hardware has died, which can mean that there's no valid runqueue for a **entity**. This function returns -ENOENT in this case (which probably should be -EIO as a more meanigful return value).h](hWARNING: amdgpu abuses }(hjhhhNhNubh)}(h%:c:type:`drm_sched.ready `h]j)}(hjh]hdrm_sched.ready}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_scheduh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh] to signal when the hardware has died, which can mean that there’s no valid runqueue for a }(hjhhhNhNubj)}(h **entity**h]hentity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubhn. This function returns -ENOENT in this case (which probably should be -EIO as a more meanigful return value).}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhj(ubh)}(h5Returns 0 for success, negative error code otherwise.h]h5Returns 0 for success, negative error code otherwise.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj(ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_job_arm (C function)c.drm_sched_job_armhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h2void drm_sched_job_arm (struct drm_sched_job *job)h]j>)}(h1void drm_sched_job_arm(struct drm_sched_job *job)h](j)}(hvoidh]hvoid}(hjUhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjQhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMJubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjQhhhjchMJubjg)}(hdrm_sched_job_armh]jm)}(hdrm_sched_job_armh]hdrm_sched_job_arm}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjrubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjQhhhjchMJubj)}(h(struct drm_sched_job *job)h]j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjxsbc.drm_sched_job_armasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjQhhhjchMJubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjMhhhjchMJubah}(h]jHah ](jjeh"]h$]h&]jj)jhuh1j7hjchMJhjJhhubj)}(hhh]h)}(h!arm a scheduler job for executionh]h!arm a scheduler job for execution}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMJhjhhubah}(h]h ]h"]h$]h&]uh1jhjJhhhjchMJubeh}(h]h ](jfunctioneh"]h$]h&]jjjj-jj-jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_job *job`` scheduler job to arm **Description** This arms a scheduler job for execution. Specifically it initializes the :c:type:`drm_sched_job.s_fence ` of **job**, so that it can be attached to struct dma_resv or other places that need to track the completion of this job. It also initializes sequence numbers, which are fundamental for fence ordering. Refer to drm_sched_entity_push_job() documentation for locking considerations. Once this function was called, you *must* submit **job** with drm_sched_entity_push_job(). This can only be called if drm_sched_job_init() succeeded.h](h)}(h**Parameters**h]j)}(hj7h]h Parameters}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMNhj1ubj)}(hhh]j)}(h3``struct drm_sched_job *job`` scheduler job to arm h](j)}(h``struct drm_sched_job *job``h]j)}(hjVh]hstruct drm_sched_job *job}(hjXhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjTubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMKhjPubj )}(hhh]h)}(hscheduler job to armh]hscheduler job to arm}(hjohhhNhNubah}(h]h ]h"]h$]h&]uh1hhjkhMKhjlubah}(h]h ]h"]h$]h&]uh1j hjPubeh}(h]h ]h"]h$]h&]uh1jhjkhMKhjMubah}(h]h ]h"]h$]h&]uh1jhj1ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMMhj1ubh)}(hXAThis arms a scheduler job for execution. Specifically it initializes the :c:type:`drm_sched_job.s_fence ` of **job**, so that it can be attached to struct dma_resv or other places that need to track the completion of this job. It also initializes sequence numbers, which are fundamental for fence ordering.h](hIThis arms a scheduler job for execution. Specifically it initializes the }(hjhhhNhNubh)}(h/:c:type:`drm_sched_job.s_fence `h]j)}(hjh]hdrm_sched_job.s_fence}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM drm_sched_jobuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMLhjubh of }(hjhhhNhNubj)}(h**job**h]hjob}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh, so that it can be attached to struct dma_resv or other places that need to track the completion of this job. It also initializes sequence numbers, which are fundamental for fence ordering.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhMLhj1ubh)}(hNRefer to drm_sched_entity_push_job() documentation for locking considerations.h]hNRefer to drm_sched_entity_push_job() documentation for locking considerations.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMQhj1ubh)}(hZOnce this function was called, you *must* submit **job** with drm_sched_entity_push_job().h](h#Once this function was called, you }(hjhhhNhNubj)}(h*must*h]hmust}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh submit }(hjhhhNhNubj)}(h**job**h]hjob}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh" with drm_sched_entity_push_job().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMThj1ubh)}(h:This can only be called if drm_sched_job_init() succeeded.h]h:This can only be called if drm_sched_job_init() succeeded.}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMWhj1ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_sched_job_add_dependency (C function)c.drm_sched_job_add_dependencyhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hUint drm_sched_job_add_dependency (struct drm_sched_job *job, struct dma_fence *fence)h]j>)}(hTint drm_sched_job_add_dependency(struct drm_sched_job *job, struct dma_fence *fence)h](j)}(hinth]hint}(hj\hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjXhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMkubjV)}(h h]h }(hjkhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjXhhhjjhMkubjg)}(hdrm_sched_job_add_dependencyh]jm)}(hdrm_sched_job_add_dependencyh]hdrm_sched_job_add_dependency}(hj}hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjyubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjXhhhjjhMkubj)}(h4(struct drm_sched_job *job, struct dma_fence *fence)h](j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_job_add_dependencyasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]jc.drm_sched_job_add_dependencyasbuh1hhjubjV)}(h h]h }(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjUhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hfenceh]hfence}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjXhhhjjhMkubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjThhhjjhMkubah}(h]jOah ](jjeh"]h$]h&]jj)jhuh1j7hjjhMkhjQhhubj)}(hhh]h)}(h"adds the fence as a job dependencyh]h"adds the fence as a job dependency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMkhjhhubah}(h]h ]h"]h$]h&]uh1jhjQhhhjjhMkubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hXG**Parameters** ``struct drm_sched_job *job`` scheduler job to add the dependencies to ``struct dma_fence *fence`` the dma_fence to add to the list of dependencies. **Description** Note that **fence** is consumed in both the success and error cases. **Return** 0 on success, or an error on failing to expand the array.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMohjubj)}(hhh](j)}(hG``struct drm_sched_job *job`` scheduler job to add the dependencies to h](j)}(h``struct drm_sched_job *job``h]j)}(hjh]hstruct drm_sched_job *job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMlhjubj )}(hhh]h)}(h(scheduler job to add the dependencies toh]h(scheduler job to add the dependencies to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMlhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMlhjubj)}(hN``struct dma_fence *fence`` the dma_fence to add to the list of dependencies. h](j)}(h``struct dma_fence *fence``h]j)}(hjh]hstruct dma_fence *fence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMmhjubj )}(hhh]h)}(h1the dma_fence to add to the list of dependencies.h]h1the dma_fence to add to the list of dependencies.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMmhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMmhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjAh]h Description}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jhj?ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMohjubh)}(hDNote that **fence** is consumed in both the success and error cases.h](h Note that }(hjWhhhNhNubj)}(h **fence**h]hfence}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubh1 is consumed in both the success and error cases.}(hjWhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMnhjubh)}(h **Return**h]j)}(hjzh]hReturn}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjxubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMphjubh)}(h90 on success, or an error on failing to expand the array.h]h90 on success, or an error on failing to expand the array.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMqhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.1drm_sched_job_add_syncobj_dependency (C function)&c.drm_sched_job_add_syncobj_dependencyhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hrint drm_sched_job_add_syncobj_dependency (struct drm_sched_job *job, struct drm_file *file, u32 handle, u32 point)h]j>)}(hqint drm_sched_job_add_syncobj_dependency(struct drm_sched_job *job, struct drm_file *file, u32 handle, u32 point)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(h$drm_sched_job_add_syncobj_dependencyh]jm)}(h$drm_sched_job_add_syncobj_dependencyh]h$drm_sched_job_add_syncobj_dependency}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hI(struct drm_sched_job *job, struct drm_file *file, u32 handle, u32 point)h](j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsb&c.drm_sched_job_add_syncobj_dependencyasbuh1hhjubjV)}(h h]h }(hj:hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjHhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hjobh]hjob}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hstruct drm_file *fileh](jD)}(hjh]hstruct}(hjnhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjjubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjubh)}(hhh]jm)}(hdrm_fileh]hdrm_file}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j6&c.drm_sched_job_add_syncobj_dependencyasbuh1hhjjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjjubjm)}(hfileh]hfile}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u32 handleh](h)}(hhh]jm)}(hu32h]hu32}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j6&c.drm_sched_job_add_syncobj_dependencyasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hhandleh]hhandle}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h u32 pointh](h)}(hhh]jm)}(hu32h]hu32}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]j6&c.drm_sched_job_add_syncobj_dependencyasbuh1hhj"ubjV)}(h h]h }(hjGhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubjm)}(hpointh]hpoint}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h*adds a syncobj's fence as a job dependencyh]h,adds a syncobj’s fence as a job dependency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj|hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hXm**Parameters** ``struct drm_sched_job *job`` scheduler job to add the dependencies to ``struct drm_file *file`` drm file private pointer ``u32 handle`` syncobj handle to lookup ``u32 point`` timeline point **Description** This adds the fence matching the given syncobj to **job**. **Return** 0 on success, or an error on failing to expand the array.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh](j)}(hG``struct drm_sched_job *job`` scheduler job to add the dependencies to h](j)}(h``struct drm_sched_job *job``h]j)}(hjh]hstruct drm_sched_job *job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h(scheduler job to add the dependencies toh]h(scheduler job to add the dependencies to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h3``struct drm_file *file`` drm file private pointer h](j)}(h``struct drm_file *file``h]j)}(hjh]hstruct drm_file *file}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hdrm file private pointerh]hdrm file private pointer}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(h(``u32 handle`` syncobj handle to lookup h](j)}(h``u32 handle``h]j)}(hj2h]h u32 handle}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj0ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj,ubj )}(hhh]h)}(hsyncobj handle to lookuph]hsyncobj handle to lookup}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjGhMhjHubah}(h]h ]h"]h$]h&]uh1j hj,ubeh}(h]h ]h"]h$]h&]uh1jhjGhMhjubj)}(h``u32 point`` timeline point h](j)}(h ``u32 point``h]j)}(hjkh]h u32 point}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjiubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjeubj )}(hhh]h)}(htimeline pointh]htimeline point}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjeubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h:This adds the fence matching the given syncobj to **job**.h](h2This adds the fence matching the given syncobj to }(hjhhhNhNubj)}(h**job**h]hjob}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h90 on success, or an error on failing to expand the array.h]h90 on success, or an error on failing to expand the array.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.0drm_sched_job_add_resv_dependencies (C function)%c.drm_sched_job_add_resv_dependencieshNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(huint drm_sched_job_add_resv_dependencies (struct drm_sched_job *job, struct dma_resv *resv, enum dma_resv_usage usage)h]j>)}(htint drm_sched_job_add_resv_dependencies(struct drm_sched_job *job, struct dma_resv *resv, enum dma_resv_usage usage)h](j)}(hinth]hint}(hj$hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj2hMubjg)}(h#drm_sched_job_add_resv_dependenciesh]jm)}(h#drm_sched_job_add_resv_dependenciesh]h#drm_sched_job_add_resv_dependencies}(hjEhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj2hMubj)}(hM(struct drm_sched_job *job, struct dma_resv *resv, enum dma_resv_usage usage)h](j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjahhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj]ubjV)}(h h]h }(hjnhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj|ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjGsb%c.drm_sched_job_add_resv_dependenciesasbuh1hhj]ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj]ubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjYubj)}(hstruct dma_resv *resvh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdma_resvh]hdma_resv}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j%c.drm_sched_job_add_resv_dependenciesasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hresvh]hresv}(hj*hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjYubj)}(henum dma_resv_usage usageh](jD)}(hjGh]henum}(hjChhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj?ubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubh)}(hhh]jm)}(hdma_resv_usageh]hdma_resv_usage}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjcmodnameN classnameNjj)}j]j%c.drm_sched_job_add_resv_dependenciesasbuh1hhj?ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubjm)}(husageh]husage}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjYubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj2hMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhj2hMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hj2hMhjhhubj)}(hhh]h)}(h'add all fences from the resv to the jobh]h'add all fences from the resv to the job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhj2hMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_job *job`` scheduler job to add the dependencies to ``struct dma_resv *resv`` the dma_resv object to get the fences from ``enum dma_resv_usage usage`` the dma_resv_usage to use to filter the fences **Description** This adds all fences matching the given usage from **resv** to **job**. Must be called with the **resv** lock held. **Return** 0 on success, or an error on failing to expand the array.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh](j)}(hG``struct drm_sched_job *job`` scheduler job to add the dependencies to h](j)}(h``struct drm_sched_job *job``h]j)}(hjh]hstruct drm_sched_job *job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h(scheduler job to add the dependencies toh]h(scheduler job to add the dependencies to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj hMhjubj)}(hE``struct dma_resv *resv`` the dma_resv object to get the fences from h](j)}(h``struct dma_resv *resv``h]j)}(hj1h]hstruct dma_resv *resv}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj/ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj+ubj )}(hhh]h)}(h*the dma_resv object to get the fences fromh]h*the dma_resv object to get the fences from}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjFhMhjGubah}(h]h ]h"]h$]h&]uh1j hj+ubeh}(h]h ]h"]h$]h&]uh1jhjFhMhjubj)}(hM``enum dma_resv_usage usage`` the dma_resv_usage to use to filter the fences h](j)}(h``enum dma_resv_usage usage``h]j)}(hjjh]henum dma_resv_usage usage}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjdubj )}(hhh]h)}(h.the dma_resv_usage to use to filter the fencesh]h.the dma_resv_usage to use to filter the fences}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjdubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hsThis adds all fences matching the given usage from **resv** to **job**. Must be called with the **resv** lock held.h](h3This adds all fences matching the given usage from }(hjhhhNhNubj)}(h**resv**h]hresv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh to }(hjhhhNhNubj)}(h**job**h]hjob}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh. Must be called with the }(hjhhhNhNubj)}(h**resv**h]hresv}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh lock held.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h90 on success, or an error on failing to expand the array.h]h90 on success, or an error on failing to expand the array.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.4drm_sched_job_add_implicit_dependencies (C function))c.drm_sched_job_add_implicit_dependencieshNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hoint drm_sched_job_add_implicit_dependencies (struct drm_sched_job *job, struct drm_gem_object *obj, bool write)h]j>)}(hnint drm_sched_job_add_implicit_dependencies(struct drm_sched_job *job, struct drm_gem_object *obj, bool write)h](j)}(hinth]hint}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjChhhjUhMubjg)}(h'drm_sched_job_add_implicit_dependenciesh]jm)}(h'drm_sched_job_add_implicit_dependenciesh]h'drm_sched_job_add_implicit_dependencies}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjChhhjUhMubj)}(hC(struct drm_sched_job *job, struct drm_gem_object *obj, bool write)h](j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjjsb)c.drm_sched_job_add_implicit_dependenciesasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubj)}(hstruct drm_gem_object *objh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gem_objecth]hdrm_gem_object}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j)c.drm_sched_job_add_implicit_dependenciesasbuh1hhjubjV)}(h h]h }(hj2hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj@hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hobjh]hobj}(hjMhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubj)}(h bool writeh](j)}(hj*h]hbool}(hjfhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjbubjV)}(h h]h }(hjshhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjbubjm)}(hwriteh]hwrite}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjbubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubeh}(h]h ]h"]h$]h&]jjuh1jhjChhhjUhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj?hhhjUhMubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1j7hjUhMhj<hhubj)}(hhh]h)}(h.adds implicit dependencies as job dependenciesh]h.adds implicit dependencies as job dependencies}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj<hhhjUhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_job *job`` scheduler job to add the dependencies to ``struct drm_gem_object *obj`` the gem object to add new dependencies from. ``bool write`` whether the job might write the object (so we need to depend on shared fences in the reservation object). **Description** This should be called after drm_gem_lock_reservations() on your array of GEM objects used in the job but before updating the reservations with your own fences. **Return** 0 on success, or an error on failing to expand the array.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh](j)}(hG``struct drm_sched_job *job`` scheduler job to add the dependencies to h](j)}(h``struct drm_sched_job *job``h]j)}(hjh]hstruct drm_sched_job *job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h(scheduler job to add the dependencies toh]h(scheduler job to add the dependencies to}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hL``struct drm_gem_object *obj`` the gem object to add new dependencies from. h](j)}(h``struct drm_gem_object *obj``h]j)}(hj%h]hstruct drm_gem_object *obj}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj#ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.cZhMhjubj )}(hhh]h)}(h,the gem object to add new dependencies from.h]h,the gem object to add new dependencies from.}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj:hMhj;ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj:hMhjubj)}(hy``bool write`` whether the job might write the object (so we need to depend on shared fences in the reservation object). h](j)}(h``bool write``h]j)}(hj^h]h bool write}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj\ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjXubj )}(hhh]h)}(hiwhether the job might write the object (so we need to depend on shared fences in the reservation object).h]hiwhether the job might write the object (so we need to depend on shared fences in the reservation object).}(hjwhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjtubah}(h]h ]h"]h$]h&]uh1j hjXubeh}(h]h ]h"]h$]h&]uh1jhjshMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hThis should be called after drm_gem_lock_reservations() on your array of GEM objects used in the job but before updating the reservations with your own fences.h]hThis should be called after drm_gem_lock_reservations() on your array of GEM objects used in the job but before updating the reservations with your own fences.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h90 on success, or an error on failing to expand the array.h]h90 on success, or an error on failing to expand the array.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.)drm_sched_job_has_dependency (C function)c.drm_sched_job_has_dependencyhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hVbool drm_sched_job_has_dependency (struct drm_sched_job *job, struct dma_fence *fence)h]j>)}(hUbool drm_sched_job_has_dependency(struct drm_sched_job *job, struct dma_fence *fence)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_job_has_dependencyh]jm)}(hdrm_sched_job_has_dependencyh]hdrm_sched_job_has_dependency}(hj&hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h4(struct drm_sched_job *job, struct dma_fence *fence)h](j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjBhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj>ubjV)}(h h]h }(hjOhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hj`hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj]ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjbmodnameN classnameNjj)}j]j )}jj(sbc.drm_sched_job_has_dependencyasbuh1hhj>ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj>ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj>ubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj>ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubj)}(hstruct dma_fence *fenceh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h dma_fenceh]h dma_fence}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j|c.drm_sched_job_has_dependencyasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hfenceh]hfence}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj:ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(h+check whether fence is the job's dependencyh]h-check whether fence is the job’s dependency}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj2hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjMjjMjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_sched_job *job`` scheduler job to check ``struct dma_fence *fence`` fence to look for **Return** True if **fence** is found within the job's dependencies, or otherwise false.h](h)}(h**Parameters**h]j)}(hjWh]h Parameters}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjQubj)}(hhh](j)}(h5``struct drm_sched_job *job`` scheduler job to check h](j)}(h``struct drm_sched_job *job``h]j)}(hjvh]hstruct drm_sched_job *job}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjpubj )}(hhh]h)}(hscheduler job to checkh]hscheduler job to check}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjpubeh}(h]h ]h"]h$]h&]uh1jhjhMhjmubj)}(h.``struct dma_fence *fence`` fence to look for h](j)}(h``struct dma_fence *fence``h]j)}(hjh]hstruct dma_fence *fence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hfence to look forh]hfence to look for}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjmubeh}(h]h ]h"]h$]h&]uh1jhjQubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjQubh)}(hMTrue if **fence** is found within the job's dependencies, or otherwise false.h](hTrue if }(hjhhhNhNubj)}(h **fence**h]hfence}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh> is found within the job’s dependencies, or otherwise false.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjQubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_sched_job_cleanup (C function)c.drm_sched_job_cleanuphNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h6void drm_sched_job_cleanup (struct drm_sched_job *job)h]j>)}(h5void drm_sched_job_cleanup(struct drm_sched_job *job)h](j)}(hvoidh]hvoid}(hjAhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj=hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj=hhhjOhMubjg)}(hdrm_sched_job_cleanuph]jm)}(hdrm_sched_job_cleanuph]hdrm_sched_job_cleanup}(hjbhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj=hhhjOhMubj)}(h(struct drm_sched_job *job)h]j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hj~hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjzubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjdsbc.drm_sched_job_cleanupasbuh1hhjzubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjzubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjzubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjzubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjvubah}(h]h ]h"]h$]h&]jjuh1jhj=hhhjOhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj9hhhjOhMubah}(h]j4ah ](jjeh"]h$]h&]jj)jhuh1j7hjOhMhj6hhubj)}(hhh]h)}(h clean up scheduler job resourcesh]h clean up scheduler job resources}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj6hhhjOhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_job *job`` scheduler job to clean up **Description** Cleans up the resources allocated with drm_sched_job_init(). Drivers should call this from their error unwind code if **job** is aborted before drm_sched_job_arm() is called. drm_sched_job_arm() is a point of no return since it initializes the fences and their sequence number etc. Once that function has been called, you *must* submit it with drm_sched_entity_push_job() and cannot simply abort it by calling drm_sched_job_cleanup(). This function should be called in the :c:type:`drm_sched_backend_ops.free_job ` callback.h](h)}(h**Parameters**h]j)}(hj#h]h Parameters}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj!ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubj)}(hhh]j)}(h8``struct drm_sched_job *job`` scheduler job to clean up h](j)}(h``struct drm_sched_job *job``h]j)}(hjBh]hstruct drm_sched_job *job}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hj<ubj )}(hhh]h)}(hscheduler job to clean uph]hscheduler job to clean up}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjWhM hjXubah}(h]h ]h"]h$]h&]uh1j hj<ubeh}(h]h ]h"]h$]h&]uh1jhjWhM hj9ubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj}h]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj{ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubh)}(h` callback.h](h&This function should be called in the }(hjhhhNhNubh)}(h@:c:type:`drm_sched_backend_ops.free_job `h]j)}(hjh]hdrm_sched_backend_ops.free_job}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh callback.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhj hMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j. drm_sched_pick_best (C function)c.drm_sched_pick_besthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hsstruct drm_gpu_scheduler * drm_sched_pick_best (struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list)h]j>)}(hqstruct drm_gpu_scheduler *drm_sched_pick_best(struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list)h](jD)}(hjh]hstruct}(hj6hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj2hhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjDhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2hhhjChMubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjUhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjRubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjWmodnameN classnameNjj)}j]j )}jdrm_sched_pick_bestsbc.drm_sched_pick_bestasbuh1hhj2hhhjChMubjV)}(h h]h }(hjvhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj2hhhjChMubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj2hhhjChMubjg)}(hdrm_sched_pick_besth]jm)}(hjsh]hdrm_sched_pick_best}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj2hhhjChMubj)}(hD(struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list)h](j)}(h%struct drm_gpu_scheduler **sched_listh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jqc.drm_sched_pick_bestasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h sched_listh]h sched_list}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_sched_listh](j)}(hunsignedh]hunsigned}(hj-hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubjV)}(h h]h }(hj;hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubj)}(hinth]hint}(hjIhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj)ubjV)}(h h]h }(hjWhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj)ubjm)}(hnum_sched_listh]hnum_sched_list}(hjehhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj)ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj2hhhjChMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj.hhhjChMubah}(h]j)ah ](jjeh"]h$]h&]jj)jhuh1j7hjChMhj+hhubj)}(hhh]h)}(h5Get a drm sched from a sched_list with the least loadh]h5Get a drm sched from a sched_list with the least load}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj+hhhjChMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_gpu_scheduler **sched_list`` list of drm_gpu_schedulers ``unsigned int num_sched_list`` number of drm_gpu_schedulers in the sched_list **Description** Returns pointer of the sched with the least load or NULL if none of the drm_gpu_schedulers are readyh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh](j)}(hE``struct drm_gpu_scheduler **sched_list`` list of drm_gpu_schedulers h](j)}(h)``struct drm_gpu_scheduler **sched_list``h]j)}(hjh]h%struct drm_gpu_scheduler **sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hlist of drm_gpu_schedulersh]hlist of drm_gpu_schedulers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubj)}(hO``unsigned int num_sched_list`` number of drm_gpu_schedulers in the sched_list h](j)}(h``unsigned int num_sched_list``h]j)}(hj h]hunsigned int num_sched_list}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(h.number of drm_gpu_schedulers in the sched_listh]h.number of drm_gpu_schedulers in the sched_list}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjDh]h Description}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjBubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hdReturns pointer of the sched with the least load or NULL if none of the drm_gpu_schedulers are readyh]hdReturns pointer of the sched with the least load or NULL if none of the drm_gpu_schedulers are ready}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_init (C function)c.drm_sched_inithNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h\int drm_sched_init (struct drm_gpu_scheduler *sched, const struct drm_sched_init_args *args)h]j>)}(h[int drm_sched_init(struct drm_gpu_scheduler *sched, const struct drm_sched_init_args *args)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_inith]jm)}(hdrm_sched_inith]hdrm_sched_init}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(hI(struct drm_gpu_scheduler *sched, const struct drm_sched_init_args *args)h](j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h&const struct drm_sched_init_args *argsh](jD)}(hj h]hconst}(hj8hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4ubjV)}(h h]h }(hjEhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubjD)}(hjh]hstruct}(hjShhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj4ubjV)}(h h]h }(hj`hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubh)}(hhh]jm)}(hdrm_sched_init_argsh]hdrm_sched_init_args}(hjqhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjnubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjsmodnameN classnameNjj)}j]jc.drm_sched_initasbuh1hhj4ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj4ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj4ubjm)}(hargsh]hargs}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj4ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]j|ah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhj~hhubj)}(hhh]h)}(hInit a gpu scheduler instanceh]hInit a gpu scheduler instance}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj~hhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance ``const struct drm_sched_init_args *args`` scheduler initialization arguments **Description** Return 0 on success, otherwise error code.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM"hjubj)}(hhh](j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj*hM hj+ubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhj*hM hj ubj)}(hN``const struct drm_sched_init_args *args`` scheduler initialization arguments h](j)}(h*``const struct drm_sched_init_args *args``h]j)}(hjNh]h&const struct drm_sched_init_args *args}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjLubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM!hjHubj )}(hhh]h)}(h"scheduler initialization argumentsh]h"scheduler initialization arguments}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhjchM!hjdubah}(h]h ]h"]h$]h&]uh1j hjHubeh}(h]h ]h"]h$]h&]uh1jhjchM!hj ubeh}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM#hjubh)}(h*Return 0 on success, otherwise error code.h]h*Return 0 on success, otherwise error code.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM"hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.drm_sched_fini (C function)c.drm_sched_finihNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h5void drm_sched_fini (struct drm_gpu_scheduler *sched)h]j>)}(h4void drm_sched_fini(struct drm_gpu_scheduler *sched)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_finih]jm)}(hdrm_sched_finih]hdrm_sched_fini}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hj)hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj&ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj+modnameN classnameNjj)}j]j )}jjsbc.drm_sched_finiasbuh1hhjubjV)}(h h]h }(hjIhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjWhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjdhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hDestroy a gpu schedulerh]hDestroy a gpu scheduler}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX'**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance **Description** Tears down and cleans up the scheduler. This stops submission of new jobs to the hardware through :c:type:`struct drm_sched_backend_ops `.run_job. If :c:type:`struct drm_sched_backend_ops `.cancel_job is implemented, all jobs will be canceled through it and afterwards cleaned up through :c:type:`struct drm_sched_backend_ops `.free_job. If cancel_job is not implemented, memory could leak.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh]j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(h'Tears down and cleans up the scheduler.h]h'Tears down and cleans up the scheduler.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hXThis stops submission of new jobs to the hardware through :c:type:`struct drm_sched_backend_ops `.run_job. If :c:type:`struct drm_sched_backend_ops `.cancel_job is implemented, all jobs will be canceled through it and afterwards cleaned up through :c:type:`struct drm_sched_backend_ops `.free_job. If cancel_job is not implemented, memory could leak.h](h:This stops submission of new jobs to the hardware through }(hj/hhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hj9h]hstruct drm_sched_backend_ops}(hj;hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj7ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj/ubh .run_job. If }(hj/hhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hj]h]hstruct drm_sched_backend_ops}(hj_hhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj[ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhjVhMhj/ubhc.cancel_job is implemented, all jobs will be canceled through it and afterwards cleaned up through }(hj/hhhNhNubh)}(h>:c:type:`struct drm_sched_backend_ops `h]j)}(hjh]hstruct drm_sched_backend_ops}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhj~ubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjMdrm_sched_backend_opsuh1hhjVhMhj/ubh?.free_job. If cancel_job is not implemented, memory could leak.}(hj/hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjVhMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_sched_increase_karma (C function)c.drm_sched_increase_karmahNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h9void drm_sched_increase_karma (struct drm_sched_job *bad)h]j>)}(h8void drm_sched_increase_karma(struct drm_sched_job *bad)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_increase_karmah]jm)}(hdrm_sched_increase_karmah]hdrm_sched_increase_karma}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h(struct drm_sched_job *bad)h]j)}(hstruct drm_sched_job *badh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hj"hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj$modnameN classnameNjj)}j]j )}jjsbc.drm_sched_increase_karmaasbuh1hhjubjV)}(h h]h }(hjBhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjPhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hbadh]hbad}(hj]hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hUpdate sched_entity guilty flagh]hUpdate sched_entity guilty flag}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_job *bad`` The job guilty of time out **Description** Increment on every hang caused by the 'bad' job. If this exceeds the hang limit of the scheduler then the respective sched entity is marked guilty and jobs from it will not be scheduled furtherh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj)}(hhh]j)}(h9``struct drm_sched_job *bad`` The job guilty of time out h](j)}(h``struct drm_sched_job *bad``h]j)}(hjh]hstruct drm_sched_job *bad}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hThe job guilty of time outh]hThe job guilty of time out}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubh)}(hIncrement on every hang caused by the 'bad' job. If this exceeds the hang limit of the scheduler then the respective sched entity is marked guilty and jobs from it will not be scheduled furtherh]hIncrement on every hang caused by the ‘bad’ job. If this exceeds the hang limit of the scheduler then the respective sched entity is marked guilty and jobs from it will not be scheduled further}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_sched_wqueue_ready (C function)c.drm_sched_wqueue_readyhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h=bool drm_sched_wqueue_ready (struct drm_gpu_scheduler *sched)h]j>)}(h)}(h;void drm_sched_wqueue_stop(struct drm_gpu_scheduler *sched)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_wqueue_stoph]jm)}(hdrm_sched_wqueue_stoph]hdrm_sched_wqueue_stop}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hj#hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj%modnameN classnameNjj)}j]j )}jjsbc.drm_sched_wqueue_stopasbuh1hhjubjV)}(h h]h }(hjChhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjQhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hj^hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hstop scheduler submissionh]hstop scheduler submission}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance **Description** Stops the scheduler from pulling new jobs from entities. It also stops freeing jobs automatically through drm_sched_backend_ops.free_job().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubj)}(hhh]j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhMhjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhMhjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubh)}(hStops the scheduler from pulling new jobs from entities. It also stops freeing jobs automatically through drm_sched_backend_ops.free_job().h]hStops the scheduler from pulling new jobs from entities. It also stops freeing jobs automatically through drm_sched_backend_ops.free_job().}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_sched_wqueue_start (C function)c.drm_sched_wqueue_starthNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h=void drm_sched_wqueue_start (struct drm_gpu_scheduler *sched)h]j>)}(hhhubj)}(hhh]h)}(hstart scheduler submissionh]hstart scheduler submission}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjhhubah}(h]h ]h"]h$]h&]uh1jhj>hhhjWhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj!jj!jjjuh1j2hhhjhNhNubj)}(hX **Parameters** ``struct drm_gpu_scheduler *sched`` scheduler instance **Description** Restarts the scheduler after drm_sched_wqueue_stop() has stopped it. This function is not necessary for 'conventional' startup. The scheduler is fully operational after drm_sched_init() succeeded.h](h)}(h**Parameters**h]j)}(hj+h]h Parameters}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj%ubj)}(hhh]j)}(h7``struct drm_gpu_scheduler *sched`` scheduler instance h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjJh]hstruct drm_gpu_scheduler *sched}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhjDubj )}(hhh]h)}(hscheduler instanceh]hscheduler instance}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhj_hMhj`ubah}(h]h ]h"]h$]h&]uh1j hjDubeh}(h]h ]h"]h$]h&]uh1jhj_hMhjAubah}(h]h ]h"]h$]h&]uh1jhj%ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj%ubh)}(hDRestarts the scheduler after drm_sched_wqueue_stop() has stopped it.h]hDRestarts the scheduler after drm_sched_wqueue_stop() has stopped it.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj%ubh)}(hThis function is not necessary for 'conventional' startup. The scheduler is fully operational after drm_sched_init() succeeded.h]hThis function is not necessary for ‘conventional’ startup. The scheduler is fully operational after drm_sched_init() succeeded.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chMhj%ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.!drm_sched_is_stopped (C function)c.drm_sched_is_stoppedhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h;bool drm_sched_is_stopped (struct drm_gpu_scheduler *sched)h]j>)}(h:bool drm_sched_is_stopped(struct drm_gpu_scheduler *sched)h](j)}(hj*h]hbool}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM'ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM'ubjg)}(hdrm_sched_is_stoppedh]jm)}(hdrm_sched_is_stoppedh]hdrm_sched_is_stopped}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM'ubj)}(h!(struct drm_gpu_scheduler *sched)h]j)}(hstruct drm_gpu_scheduler *schedh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hj"hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hj3hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj0ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj5modnameN classnameNjj)}j]j )}jjsbc.drm_sched_is_stoppedasbuh1hhjubjV)}(h h]h }(hjShhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjahhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hschedh]hsched}(hjnhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM'ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM'ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM'hjhhubj)}(hhh]h)}(h#Checks whether drm_sched is stoppedh]h#Checks whether drm_sched is stopped}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM'hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM'ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hz**Parameters** ``struct drm_gpu_scheduler *sched`` DRM scheduler **Return** true if sched is stopped, false otherwiseh](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM+hjubj)}(hhh]j)}(h2``struct drm_gpu_scheduler *sched`` DRM scheduler h](j)}(h#``struct drm_gpu_scheduler *sched``h]j)}(hjh]hstruct drm_gpu_scheduler *sched}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM(hjubj )}(hhh]h)}(h DRM schedulerh]h DRM scheduler}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM(hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM(hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM*hjubh)}(h)true if sched is stopped, false otherwiseh]h)true if sched is stopped, false otherwise}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM*hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_sched_job_is_signaled (C function)c.drm_sched_job_is_signaledhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h:bool drm_sched_job_is_signaled (struct drm_sched_job *job)h]j>)}(h9bool drm_sched_job_is_signaled(struct drm_sched_job *job)h](j)}(hj*h]hbool}(hjYhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjUhhhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM3ubjV)}(h h]h }(hjghhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjUhhhjfhM3ubjg)}(hdrm_sched_job_is_signaledh]jm)}(hdrm_sched_job_is_signaledh]hdrm_sched_job_is_signaled}(hjyhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjuubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjUhhhjfhM3ubj)}(h(struct drm_sched_job *job)h]j)}(hstruct drm_sched_job *jobh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jj{sbc.drm_sched_job_is_signaledasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hjobh]hjob}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubah}(h]h ]h"]h$]h&]jjuh1jhjUhhhjfhM3ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjQhhhjfhM3ubah}(h]jLah ](jjeh"]h$]h&]jj)jhuh1j7hjfhM3hjNhhubj)}(hhh]h)}(hDRM scheduler job is signaledh]hDRM scheduler job is signaled}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM3hjhhubah}(h]h ]h"]h$]h&]uh1jhjNhhhjfhM3ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj0jj0jjjuh1j2hhhjhNhNubj)}(hXl**Parameters** ``struct drm_sched_job *job`` DRM scheduler job **Description** Determine if DRM scheduler job is signaled. DRM scheduler should be stopped to obtain a stable snapshot of state. Both parent fence (hardware fence) and finished fence (software fence) are checked to determine signaling state. **Return** true if job is signaled, false otherwiseh](h)}(h**Parameters**h]j)}(hj:h]h Parameters}(hj<hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj8ubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM7hj4ubj)}(hhh]j)}(h0``struct drm_sched_job *job`` DRM scheduler job h](j)}(h``struct drm_sched_job *job``h]j)}(hjYh]hstruct drm_sched_job *job}(hj[hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjWubah}(h]h ]h"]h$]h&]uh1jhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM4hjSubj )}(hhh]h)}(hDRM scheduler jobh]hDRM scheduler job}(hjrhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjnhM4hjoubah}(h]h ]h"]h$]h&]uh1j hjSubeh}(h]h ]h"]h$]h&]uh1jhjnhM4hjPubah}(h]h ]h"]h$]h&]uh1jhj4ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM6hj4ubh)}(hDetermine if DRM scheduler job is signaled. DRM scheduler should be stopped to obtain a stable snapshot of state. Both parent fence (hardware fence) and finished fence (software fence) are checked to determine signaling state.h]hDetermine if DRM scheduler job is signaled. DRM scheduler should be stopped to obtain a stable snapshot of state. Both parent fence (hardware fence) and finished fence (software fence) are checked to determine signaling state.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM5hj4ubh)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM9hj4ubh)}(h(true if job is signaled, false otherwiseh]h(true if job is signaled, false otherwise}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhb/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:588: ./drivers/gpu/drm/scheduler/sched_main.chM:hj4ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_sched_entity_init (C function)c.drm_sched_entity_inithNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hint drm_sched_entity_init (struct drm_sched_entity *entity, enum drm_sched_priority priority, struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list, atomic_t *guilty)h]j>)}(hint drm_sched_entity_init(struct drm_sched_entity *entity, enum drm_sched_priority priority, struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list, atomic_t *guilty)h](j)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK$ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhK$ubjg)}(hdrm_sched_entity_inith]jm)}(hdrm_sched_entity_inith]hdrm_sched_entity_init}(hj!hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhK$ubj)}(h(struct drm_sched_entity *entity, enum drm_sched_priority priority, struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list, atomic_t *guilty)h](j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hj=hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj9ubjV)}(h h]h }(hjJhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj9ubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hj[hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjXubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj]modnameN classnameNjj)}j]j )}jj#sbc.drm_sched_entity_initasbuh1hhj9ubjV)}(h h]h }(hj{hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj9ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj9ubjm)}(hentityh]hentity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj9ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(h enum drm_sched_priority priorityh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_sched_priorityh]hdrm_sched_priority}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jwc.drm_sched_entity_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hpriorityh]hpriority}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(h%struct drm_gpu_scheduler **sched_listh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hj0hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj-ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj2modnameN classnameNjj)}j]jwc.drm_sched_entity_initasbuh1hhjubjV)}(h h]h }(hjNhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hj\hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubj4)}(hj7h]h*}(hjihhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(h sched_listh]h sched_list}(hjvhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(hunsigned int num_sched_listh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hnum_sched_listh]hnum_sched_list}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubj)}(hatomic_t *guiltyh](h)}(hhh]jm)}(hatomic_th]hatomic_t}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]jwc.drm_sched_entity_initasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hguiltyh]hguilty}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj5ubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhK$ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhK$ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhK$hjhhubj)}(hhh]h)}(h?Init a context entity used by scheduler when submit to HW ring.h]h?Init a context entity used by scheduler when submit to HW ring.}(hjFhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK$hjChhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhK$ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj^jj^jjjuh1j2hhhjhNhNubj)}(hXt**Parameters** ``struct drm_sched_entity *entity`` scheduler entity to init ``enum drm_sched_priority priority`` priority of the entity ``struct drm_gpu_scheduler **sched_list`` the list of drm scheds on which jobs from this entity can be submitted ``unsigned int num_sched_list`` number of drm sched in sched_list ``atomic_t *guilty`` atomic_t set to 1 when a job on this queue is found to be guilty causing a timeout **Description** Note that the :c:type:`sched_list` must have at least one element to schedule the entity. For changing **priority** later on at runtime see drm_sched_entity_set_priority(). For changing the set of schedulers **sched_list** at runtime see drm_sched_entity_modify_sched(). An entity is cleaned up by calling drm_sched_entity_fini(). See also drm_sched_entity_destroy(). Returns 0 on success or a negative error code on failure.h](h)}(h**Parameters**h]j)}(hjhh]h Parameters}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjfubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK(hjbubj)}(hhh](j)}(h=``struct drm_sched_entity *entity`` scheduler entity to init h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hjh]hstruct drm_sched_entity *entity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK'hjubj )}(hhh]h)}(hscheduler entity to inith]hscheduler entity to init}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK'hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK'hj~ubj)}(h<``enum drm_sched_priority priority`` priority of the entity h](j)}(h$``enum drm_sched_priority priority``h]j)}(hjh]h enum drm_sched_priority priority}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK(hjubj )}(hhh]h)}(hpriority of the entityh]hpriority of the entity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK(hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK(hj~ubj)}(hq``struct drm_gpu_scheduler **sched_list`` the list of drm scheds on which jobs from this entity can be submitted h](j)}(h)``struct drm_gpu_scheduler **sched_list``h]j)}(hjh]h%struct drm_gpu_scheduler **sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK*hjubj )}(hhh]h)}(hFthe list of drm scheds on which jobs from this entity can be submittedh]hFthe list of drm scheds on which jobs from this entity can be submitted}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK)hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK*hj~ubj)}(hB``unsigned int num_sched_list`` number of drm sched in sched_list h](j)}(h``unsigned int num_sched_list``h]j)}(hj3h]hunsigned int num_sched_list}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj1ubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK+hj-ubj )}(hhh]h)}(h!number of drm sched in sched_listh]h!number of drm sched in sched_list}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjHhK+hjIubah}(h]h ]h"]h$]h&]uh1j hj-ubeh}(h]h ]h"]h$]h&]uh1jhjHhK+hj~ubj)}(hh``atomic_t *guilty`` atomic_t set to 1 when a job on this queue is found to be guilty causing a timeout h](j)}(h``atomic_t *guilty``h]j)}(hjlh]hatomic_t *guilty}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK-hjfubj )}(hhh]h)}(hRatomic_t set to 1 when a job on this queue is found to be guilty causing a timeouth]hRatomic_t set to 1 when a job on this queue is found to be guilty causing a timeout}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK,hjubah}(h]h ]h"]h$]h&]uh1j hjfubeh}(h]h ]h"]h$]h&]uh1jhjhK-hj~ubeh}(h]h ]h"]h$]h&]uh1jhjbubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK/hjbubh)}(hYNote that the :c:type:`sched_list` must have at least one element to schedule the entity.h](hNote that the }(hjhhhNhNubh)}(h:c:type:`sched_list`h]j)}(hjh]h sched_list}(hjhhhNhNubah}(h]h ](j8jc-typeeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdocjD refdomainjreftypetype refexplicitrefwarnjjJjM sched_listuh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK.hjubh7 must have at least one element to schedule the entity.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhjhK.hjbubh)}(hFor changing **priority** later on at runtime see drm_sched_entity_set_priority(). For changing the set of schedulers **sched_list** at runtime see drm_sched_entity_modify_sched().h](h For changing }(hjhhhNhNubj)}(h **priority**h]hpriority}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh] later on at runtime see drm_sched_entity_set_priority(). For changing the set of schedulers }(hjhhhNhNubj)}(h**sched_list**h]h sched_list}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh0 at runtime see drm_sched_entity_modify_sched().}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK0hjbubh)}(h`An entity is cleaned up by calling drm_sched_entity_fini(). See also drm_sched_entity_destroy().h]h`An entity is cleaned up by calling drm_sched_entity_fini(). See also drm_sched_entity_destroy().}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK4hjbubh)}(h9Returns 0 on success or a negative error code on failure.h]h9Returns 0 on success or a negative error code on failure.}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK7hjbubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_sched_entity_modify_sched (C function)c.drm_sched_entity_modify_schedhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hvoid drm_sched_entity_modify_sched (struct drm_sched_entity *entity, struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list)h]j>)}(hvoid drm_sched_entity_modify_sched(struct drm_sched_entity *entity, struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list)h](j)}(hvoidh]hvoid}(hjahhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj]hhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKwubjV)}(h h]h }(hjphhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj]hhhjohKwubjg)}(hdrm_sched_entity_modify_schedh]jm)}(hdrm_sched_entity_modify_schedh]hdrm_sched_entity_modify_sched}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj~ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj]hhhjohKwubj)}(he(struct drm_sched_entity *entity, struct drm_gpu_scheduler **sched_list, unsigned int num_sched_list)h](j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjsbc.drm_sched_entity_modify_schedasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hentityh]hentity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h%struct drm_gpu_scheduler **sched_listh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_gpu_schedulerh]hdrm_gpu_scheduler}(hj.hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj+ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj0modnameN classnameNjj)}j]jc.drm_sched_entity_modify_schedasbuh1hhj ubjV)}(h h]h }(hjLhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjZhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubj4)}(hj7h]h*}(hjghhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(h sched_listh]h sched_list}(hjthhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(hunsigned int num_sched_listh](j)}(hunsignedh]hunsigned}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj)}(hinth]hint}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hnum_sched_listh]hnum_sched_list}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj]hhhjohKwubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjYhhhjohKwubah}(h]jTah ](jjeh"]h$]h&]jj)jhuh1j7hjohKwhjVhhubj)}(hhh]h)}(hModify sched of an entityh]hModify sched of an entity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKwhjhhubah}(h]h ]h"]h$]h&]uh1jhjVhhhjohKwubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_entity *entity`` scheduler entity to init ``struct drm_gpu_scheduler **sched_list`` the list of new drm scheds which will replace existing entity->sched_list ``unsigned int num_sched_list`` number of drm sched in sched_list **Description** Note that this must be called under the same common lock for **entity** as drm_sched_job_arm() and drm_sched_entity_push_job(), or the driver needs to guarantee through some other means that this is never called while new jobs can be pushed to **entity**.h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK{hj ubj)}(hhh](j)}(h=``struct drm_sched_entity *entity`` scheduler entity to init h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hj0h]hstruct drm_sched_entity *entity}(hj2hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj.ubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKxhj*ubj )}(hhh]h)}(hscheduler entity to inith]hscheduler entity to init}(hjIhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjEhKxhjFubah}(h]h ]h"]h$]h&]uh1j hj*ubeh}(h]h ]h"]h$]h&]uh1jhjEhKxhj'ubj)}(ht``struct drm_gpu_scheduler **sched_list`` the list of new drm scheds which will replace existing entity->sched_list h](j)}(h)``struct drm_gpu_scheduler **sched_list``h]j)}(hjih]h%struct drm_gpu_scheduler **sched_list}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjgubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKzhjcubj )}(hhh]h)}(hIthe list of new drm scheds which will replace existing entity->sched_listh]hIthe list of new drm scheds which will replace existing entity->sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKyhjubah}(h]h ]h"]h$]h&]uh1j hjcubeh}(h]h ]h"]h$]h&]uh1jhj~hKzhj'ubj)}(hB``unsigned int num_sched_list`` number of drm sched in sched_list h](j)}(h``unsigned int num_sched_list``h]j)}(hjh]hunsigned int num_sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK{hjubj )}(hhh]h)}(h!number of drm sched in sched_listh]h!number of drm sched in sched_list}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhK{hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhK{hj'ubeh}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK}hj ubh)}(hNote that this must be called under the same common lock for **entity** as drm_sched_job_arm() and drm_sched_entity_push_job(), or the driver needs to guarantee through some other means that this is never called while new jobs can be pushed to **entity**.h](h=Note that this must be called under the same common lock for }(hjhhhNhNubj)}(h **entity**h]hentity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh as drm_sched_job_arm() and drm_sched_entity_push_job(), or the driver needs to guarantee through some other means that this is never called while new jobs can be pushed to }(hjhhhNhNubj)}(h **entity**h]hentity}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chK|hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_sched_entity_error (C function)c.drm_sched_entity_errorhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h)}(h;int drm_sched_entity_error(struct drm_sched_entity *entity)h](j)}(hinth]hint}(hjGhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjChhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKubjV)}(h h]h }(hjVhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjChhhjUhKubjg)}(hdrm_sched_entity_errorh]jm)}(hdrm_sched_entity_errorh]hdrm_sched_entity_error}(hjhhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjdubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjChhhjUhKubj)}(h!(struct drm_sched_entity *entity)h]j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j )}jjjsbc.drm_sched_entity_errorasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hjubjm)}(hentityh]hentity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj|ubah}(h]h ]h"]h$]h&]jjuh1jhjChhhjUhKubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj?hhhjUhKubah}(h]j:ah ](jjeh"]h$]h&]jj)jhuh1j7hjUhKhj<hhubj)}(hhh]h)}(h"return error of last scheduled jobh]h"return error of last scheduled job}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKhjhhubah}(h]h ]h"]h$]h&]uh1jhj<hhhjUhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_sched_entity *entity`` scheduler entity to check **Description** Opportunistically return the error of the last scheduled job. Result can change any time when new jobs are pushed to the hw.h](h)}(h**Parameters**h]j)}(hj)h]h Parameters}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj'ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKhj#ubj)}(hhh]j)}(h>``struct drm_sched_entity *entity`` scheduler entity to check h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hjHh]hstruct drm_sched_entity *entity}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKhjBubj )}(hhh]h)}(hscheduler entity to checkh]hscheduler entity to check}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhj]hKhj^ubah}(h]h ]h"]h$]h&]uh1j hjBubeh}(h]h ]h"]h$]h&]uh1jhj]hKhj?ubah}(h]h ]h"]h$]h&]uh1jhj#ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKhj#ubh)}(h|Opportunistically return the error of the last scheduled job. Result can change any time when new jobs are pushed to the hw.h]h|Opportunistically return the error of the last scheduled job. Result can change any time when new jobs are pushed to the hw.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chKhj#ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.#drm_sched_entity_flush (C function)c.drm_sched_entity_flushhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hKlong drm_sched_entity_flush (struct drm_sched_entity *entity, long timeout)h]j>)}(hJlong drm_sched_entity_flush(struct drm_sched_entity *entity, long timeout)h](j)}(hlongh]hlong}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhMubjg)}(hdrm_sched_entity_flushh]jm)}(hdrm_sched_entity_flushh]hdrm_sched_entity_flush}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhMubj)}(h/(struct drm_sched_entity *entity, long timeout)h](j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hj# hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj% modnameN classnameNjj)}j]j )}jjsbc.drm_sched_entity_flushasbuh1hhj ubjV)}(h h]h }(hjC hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjQ hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hentityh]hentity}(hj^ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h long timeouth](j)}(hlongh]hlong}(hjw hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjs ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjs ubjm)}(htimeouth]htimeout}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjs ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhjhhhjhMubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhMubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhMhjhhubj)}(hhh]h)}(hFlush a context entityh]hFlush a context entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhMubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_entity *entity`` scheduler entity ``long timeout`` time to wait in for Q to become empty in jiffies. **Description** Splitting drm_sched_entity_fini() into two functions, The first one does the waiting, removes the entity from the runqueue and returns an error when the process was killed. Returns the remaining time in jiffies left from the input timeouth](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj ubj)}(hhh](j)}(h5``struct drm_sched_entity *entity`` scheduler entity h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hj h]hstruct drm_sched_entity *entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj ubj )}(hhh]h)}(hscheduler entityh]hscheduler entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMhj ubj)}(hC``long timeout`` time to wait in for Q to become empty in jiffies. h](j)}(h``long timeout``h]j)}(hj7 h]h long timeout}(hj9 hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj5 ubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj1 ubj )}(hhh]h)}(h1time to wait in for Q to become empty in jiffies.h]h1time to wait in for Q to become empty in jiffies.}(hjP hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjL hMhjM ubah}(h]h ]h"]h$]h&]uh1j hj1 ubeh}(h]h ]h"]h$]h&]uh1jhjL hMhj ubeh}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hjr h]h Description}(hjt hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjp ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj ubh)}(hSplitting drm_sched_entity_fini() into two functions, The first one does the waiting, removes the entity from the runqueue and returns an error when the process was killed.h]hSplitting drm_sched_entity_fini() into two functions, The first one does the waiting, removes the entity from the runqueue and returns an error when the process was killed.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj ubh)}(hAReturns the remaining time in jiffies left from the input timeouth]hAReturns the remaining time in jiffies left from the input timeout}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j."drm_sched_entity_fini (C function)c.drm_sched_entity_finihNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h)}(h;void drm_sched_entity_fini(struct drm_sched_entity *entity)h](j)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM?ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hM?ubjg)}(hdrm_sched_entity_finih]jm)}(hdrm_sched_entity_finih]hdrm_sched_entity_fini}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj hM?ubj)}(h!(struct drm_sched_entity *entity)h]j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hj! hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj# modnameN classnameNjj)}j]j )}jj sbc.drm_sched_entity_finiasbuh1hhj ubjV)}(h h]h }(hjA hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hjO hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hentityh]hentity}(hj\ hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhj hhhj hM?ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hM?ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj hM?hj hhubj)}(hhh]h)}(hDestroy a context entityh]hDestroy a context entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM?hj hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hM?ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj jj jjjuh1j2hhhjhNhNubj)}(hX**Parameters** ``struct drm_sched_entity *entity`` scheduler entity **Description** Cleanups up **entity** which has been initialized by drm_sched_entity_init(). If there are potentially job still in flight or getting newly queued drm_sched_entity_flush() must be called first. This function then goes over the entity and signals all jobs with an error code if the process was killed.h](h)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMChj ubj)}(hhh]j)}(h5``struct drm_sched_entity *entity`` scheduler entity h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hj h]hstruct drm_sched_entity *entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMAhj ubj )}(hhh]h)}(hscheduler entityh]hscheduler entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hMAhj ubah}(h]h ]h"]h$]h&]uh1j hj ubeh}(h]h ]h"]h$]h&]uh1jhj hMAhj ubah}(h]h ]h"]h$]h&]uh1jhj ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMChj ubh)}(hMCleanups up **entity** which has been initialized by drm_sched_entity_init().h](h Cleanups up }(hj hhhNhNubj)}(h **entity**h]hentity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh7 which has been initialized by drm_sched_entity_init().}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMBhj ubh)}(hIf there are potentially job still in flight or getting newly queued drm_sched_entity_flush() must be called first. This function then goes over the entity and signals all jobs with an error code if the process was killed.h]hIf there are potentially job still in flight or getting newly queued drm_sched_entity_flush() must be called first. This function then goes over the entity and signals all jobs with an error code if the process was killed.}(hj9 hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMDhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.%drm_sched_entity_destroy (C function)c.drm_sched_entity_destroyhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h?void drm_sched_entity_destroy (struct drm_sched_entity *entity)h]j>)}(h>void drm_sched_entity_destroy(struct drm_sched_entity *entity)h](j)}(hvoidh]hvoid}(hjh hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjd hhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM^ubjV)}(h h]h }(hjw hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjd hhhjv hM^ubjg)}(hdrm_sched_entity_destroyh]jm)}(hdrm_sched_entity_destroyh]hdrm_sched_entity_destroy}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjd hhhjv hM^ubj)}(h!(struct drm_sched_entity *entity)h]j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj modnameN classnameNjj)}j]j )}jj sbc.drm_sched_entity_destroyasbuh1hhj ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj ubj4)}(hj7h]h*}(hj hhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj ubjm)}(hentityh]hentity}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj ubah}(h]h ]h"]h$]h&]jjuh1jhjd hhhjv hM^ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj` hhhjv hM^ubah}(h]j[ ah ](jjeh"]h$]h&]jj)jhuh1j7hjv hM^hj] hhubj)}(hhh]h)}(hDestroy a context entityh]hDestroy a context entity}(hj( hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM^hj% hhubah}(h]h ]h"]h$]h&]uh1jhj] hhhjv hM^ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj@ jj@ jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_sched_entity *entity`` scheduler entity **Description** Calls drm_sched_entity_flush() and drm_sched_entity_fini() as a convenience wrapper.h](h)}(h**Parameters**h]j)}(hjJ h]h Parameters}(hjL hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjH ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMbhjD ubj)}(hhh]j)}(h5``struct drm_sched_entity *entity`` scheduler entity h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hji h]hstruct drm_sched_entity *entity}(hjk hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjg ubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM_hjc ubj )}(hhh]h)}(hscheduler entityh]hscheduler entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~ hM_hj ubah}(h]h ]h"]h$]h&]uh1j hjc ubeh}(h]h ]h"]h$]h&]uh1jhj~ hM_hj` ubah}(h]h ]h"]h$]h&]uh1jhjD ubh)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMahjD ubh)}(hTCalls drm_sched_entity_flush() and drm_sched_entity_fini() as a convenience wrapper.h]hTCalls drm_sched_entity_flush() and drm_sched_entity_fini() as a convenience wrapper.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM`hjD ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.*drm_sched_entity_set_priority (C function)c.drm_sched_entity_set_priorityhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(hfvoid drm_sched_entity_set_priority (struct drm_sched_entity *entity, enum drm_sched_priority priority)h]j>)}(hevoid drm_sched_entity_set_priority(struct drm_sched_entity *entity, enum drm_sched_priority priority)h](j)}(hvoidh]hvoid}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj hhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM{ubjV)}(h h]h }(hj hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj hhhj hM{ubjg)}(hdrm_sched_entity_set_priorityh]jm)}(hdrm_sched_entity_set_priorityh]hdrm_sched_entity_set_priority}(hj hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ](jjeh"]h$]h&]jjuh1jfhj hhhj hM{ubj)}(hC(struct drm_sched_entity *entity, enum drm_sched_priority priority)h](j)}(hstruct drm_sched_entity *entityh](jD)}(hjh]hstruct}(hj&hhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj"ubjV)}(h h]h }(hj3hhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubh)}(hhh]jm)}(hdrm_sched_entityh]hdrm_sched_entity}(hjDhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjAubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjFmodnameN classnameNjj)}j]j )}jj sbc.drm_sched_entity_set_priorityasbuh1hhj"ubjV)}(h h]h }(hjdhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj"ubj4)}(hj7h]h*}(hjrhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj"ubjm)}(hentityh]hentity}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj"ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubj)}(h enum drm_sched_priority priorityh](jD)}(hjGh]henum}(hjhhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubh)}(hhh]jm)}(hdrm_sched_priorityh]hdrm_sched_priority}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj)}j]j`c.drm_sched_entity_set_priorityasbuh1hhjubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjubjm)}(hpriorityh]hpriority}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhjubeh}(h]h ]h"]h$]h&]noemphjjuh1jhjubeh}(h]h ]h"]h$]h&]jjuh1jhj hhhj hM{ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhj hhhj hM{ubah}(h]j ah ](jjeh"]h$]h&]jj)jhuh1j7hj hM{hj hhubj)}(hhh]h)}(hSets priority of the entityh]hSets priority of the entity}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM{hj hhubah}(h]h ]h"]h$]h&]uh1jhj hhhj hM{ubeh}(h]h ](jfunctioneh"]h$]h&]jjjj$jj$jjjuh1j2hhhjhNhNubj)}(h**Parameters** ``struct drm_sched_entity *entity`` scheduler entity ``enum drm_sched_priority priority`` scheduler priority **Description** Update the priority of runqueues used for the entity.h](h)}(h**Parameters**h]j)}(hj.h]h Parameters}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj,ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj(ubj)}(hhh](j)}(h5``struct drm_sched_entity *entity`` scheduler entity h](j)}(h#``struct drm_sched_entity *entity``h]j)}(hjMh]hstruct drm_sched_entity *entity}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjKubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM}hjGubj )}(hhh]h)}(hscheduler entityh]hscheduler entity}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjbhM}hjcubah}(h]h ]h"]h$]h&]uh1j hjGubeh}(h]h ]h"]h$]h&]uh1jhjbhM}hjDubj)}(h8``enum drm_sched_priority priority`` scheduler priority h](j)}(h$``enum drm_sched_priority priority``h]j)}(hjh]h enum drm_sched_priority priority}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM~hjubj )}(hhh]h)}(hscheduler priorityh]hscheduler priority}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM~hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM~hjDubeh}(h]h ]h"]h$]h&]uh1jhj(ubh)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj(ubh)}(h5Update the priority of runqueues used for the entity.h]h5Update the priority of runqueues used for the entity.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chMhj(ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubj")}(hhh]h}(h]h ]h"]h$]h&]entries](j.&drm_sched_entity_push_job (C function)c.drm_sched_entity_push_jobhNtauh1j!hjhhhNhNubj3)}(hhh](j8)}(h@void drm_sched_entity_push_job (struct drm_sched_job *sched_job)h]j>)}(h?void drm_sched_entity_push_job(struct drm_sched_job *sched_job)h](j)}(hvoidh]hvoid}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM8ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhjhhhjhM8ubjg)}(hdrm_sched_entity_push_jobh]jm)}(hdrm_sched_entity_push_jobh]hdrm_sched_entity_push_job}(hj'hhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj#ubah}(h]h ](jjeh"]h$]h&]jjuh1jfhjhhhjhM8ubj)}(h!(struct drm_sched_job *sched_job)h]j)}(hstruct drm_sched_job *sched_jobh](jD)}(hjh]hstruct}(hjChhhNhNubah}(h]h ]jPah"]h$]h&]uh1jChj?ubjV)}(h h]h }(hjPhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubh)}(hhh]jm)}(h drm_sched_jobh]h drm_sched_job}(hjahhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj^ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjcmodnameN classnameNjj)}j]j )}jj)sbc.drm_sched_entity_push_jobasbuh1hhj?ubjV)}(h h]h }(hjhhhNhNubah}(h]h ]jbah"]h$]h&]uh1jUhj?ubj4)}(hj7h]h*}(hjhhhNhNubah}(h]h ]j@ah"]h$]h&]uh1j3hj?ubjm)}(h sched_jobh]h sched_job}(hjhhhNhNubah}(h]h ]jxah"]h$]h&]uh1jlhj?ubeh}(h]h ]h"]h$]h&]noemphjjuh1jhj;ubah}(h]h ]h"]h$]h&]jjuh1jhjhhhjhM8ubeh}(h]h ]h"]h$]h&]jjjuh1j=jjhjhhhjhM8ubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1j7hjhM8hjhhubj)}(hhh]h)}(h&Submit a job to the entity's job queueh]h(Submit a job to the entity’s job queue}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM8hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhM8ubeh}(h]h ](jfunctioneh"]h$]h&]jjjjjjjjjuh1j2hhhjhNhNubj)}(hXM**Parameters** ``struct drm_sched_job *sched_job`` job to submit **Note** To guarantee that the order of insertion to queue matches the job's fence sequence number this function should be called with drm_sched_job_arm() under common lock for the struct drm_sched_entity that was set up for **sched_job** in drm_sched_job_init().h](h)}(h**Parameters**h]j)}(hjh]h Parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM<hjubj)}(hhh]j)}(h2``struct drm_sched_job *sched_job`` job to submit h](j)}(h#``struct drm_sched_job *sched_job``h]j)}(hjh]hstruct drm_sched_job *sched_job}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM9hjubj )}(hhh]h)}(h job to submith]h job to submit}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhM9hjubah}(h]h ]h"]h$]h&]uh1j hjubeh}(h]h ]h"]h$]h&]uh1jhjhM9hjubah}(h]h ]h"]h$]h&]uh1jhjubh)}(h**Note**h]j)}(hjBh]hNote}(hjDhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj@ubah}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM;hjubh)}(hTo guarantee that the order of insertion to queue matches the job's fence sequence number this function should be called with drm_sched_job_arm() under common lock for the struct drm_sched_entity that was set up for **sched_job** in drm_sched_job_init().h](hTo guarantee that the order of insertion to queue matches the job’s fence sequence number this function should be called with drm_sched_job_arm() under common lock for the struct drm_sched_entity that was set up for }(hjXhhhNhNubj)}(h **sched_job**h]h sched_job}(hj`hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjXubh in drm_sched_job_init().}(hjXhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhd/var/lib/git/docbuild/linux/Documentation/gpu/drm-mm:591: ./drivers/gpu/drm/scheduler/sched_entity.chM;hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhjhhhNhNubeh}(h]scheduler-function-referencesah ]h"]scheduler function referencesah$]h&]uh1hhjPhhhhhMGubeh}(h] gpu-schedulerah ]h"] gpu schedulerah$]h&]uh1hhhhhhhhM8ubeh}(h]drm-memory-managementah ]h"]drm memory managementah$]h&]uh1hhhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(hN generatorN datestampN source_linkN source_urlN toc_backlinksentryfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerjerror_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confafile_insertion_enabled raw_enabledKline_length_limitM'pep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacesyntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_linkenvNubreporterNindirect_targets]substitution_defs}substitution_names}refnames}refids}(j˫]jaj0]j0ajU=]jK=ajd]jdaunameids}(jjjzjzj j j>j;jRGjOGjjjjjzjzjājj{j{j|j|j<}j9}j}j}j$j!jKjHjrjojXjUjjjFjFj(sj%sjjjѫjΫjj˫jjj˭jȭjíjj.j+j̮jɮj&j#jjj0j0overviewNjLjIj0j0jvBj0juBjrBj[=jX=j@jU=j @j @j AjAjmBjjBji\jf\ja\j^\jdjdjjdjjjjjjjkjkjkjkjMjJjjjjjju nametypes}(jjzj j>jRGjjjzjāj{j|j<}j}j$jKjrjXjjFj(sjjѫjjj˭jíj.j̮j&jj0jjLj0jvBjuBj[=j@j @j AjmBji\ja\jdjjjjjkjkjMjjjuh}(jhjzhj0j9j jjjjFjKjjj" j' j;jjj$jjjOGjAj^jcjjj%j*jgjlj^jcjjjrjwjAjFjj jW!j\!j"j"j:%j?%j(j(j*j*j+j+j-j-j/j/jD0jI0j1j1j3j3j5j5j8j8j:j:jG=jL=j>j>j@j@jDjDjjjUGjrGjwGj2Kj7KjLjLjHNjMNjOjOjdQjiQjCSjHSj,Wj1WjXjXjZjZj+\j0\j^j_j(aj-ajbjbjcjcjfjfj&ij+ijzjjjjjjj mjmjnjnjqjqjsjsjwj wjxjxjjzj{j{j|j{j9}j|j}j?}j!j}jHj'jojNjUjujjj+j0jjjjjjj^jcjj’jƔj˔jYj^jjjljqjj j.j3j;j@jájȡjFjKjjjjjj"j1j6jjjjjj"jrjwj5j:j:j?j%j*jjjj#jjjjj:j?jjj<jAjj"jjjHjMjjjjjjjjjjjj jj[jjjjjijnjjjjjjj\jaj`jejjjjj"j'jjjjj3j8j_jdjnjsjd ji jG jL jjjjjBjGjFjjIjOjjjjj j jY"j^"j#j$j&j&jw(j|(jI)jN)j,j ,j.j.j0j0j1j1j)3j.3j4j4j7j7j':j,:j<j<j>j>j@j@j3Dj8Dj%sjFjHjHjJjJjLjLjNjNjbOjgOjSPjXPj^RjcRjaTjfTjrWjwWjXjXjZjZj]j]j<_jA_jcjcj4gj9gjijijkjljZmj_mjnpjspjj+sjWsj\sjpvjuvjyj yjy{j~{j}j}jΫjǁj/j4j8j=jjjjjjjjj֍jۍjjjjjujzj=jBj͘jҘjj#j7j<jajfjjjjj5j:j˫jԫjjԫjȭjjjhj+jέjɮj4j#jϮjj1jNjTjjjjjKjPjjj<jAjj jjjjjjjjjEjJjjjjj^jcjjj[j`jjjjj{jj5j:jjjjj0jjjjIjj0jOjljqjjjjjjjjjjj|jjPjUj4j9jjjIjNjjjjjjjM jR jN jS j j jj jjj#j(jjjujzj#j#j(&j-&j(j(j|*j*j--j2-j.j.j0j0jrBj0j7j0jX=j7jU=j^=j @j^=jAj@jjBj Aj)Aj.AjBjBjHjHjJjJjLjLjINjNNjUjUjWjWjYjYj[j[j`]je]jS_jX_jvbj{bjejej,ij1ijkjkjTmjYmjiqjnqjWsj\sjvjvjxjxj~j~jjjQjVjmjrjj jjjŒjnjjjjDjIjjjjjӖjؖjsjxjjjjjjjj$jjjjjעjܢjjjjj_jdj,j1j޳jjBjGjj jjjhjmjjjjjojjj9j>jjjAjFj}jjjjjj)j.j8j=jjjSjXjjj_jdjjjjj3j8jjjRjWjjjt jy j j jjjgjljIjNjRjWjjj j j$j$j)j )j,j,j0j0j4j4j8j8j<j<j?j?jf\j{Bj^\jBjBjBjSEjXEjFjFjHjHjJjJjLjLj4Oj9OjRjRjWjWjeZjjZjdjl\j\j\j^j^j1`j6`j bjbjdjdjjdjjj@hjkj jjkjkjkjkjnjnjdpjipjqjqjsjsj&vj+vjzyjyj{j{jjjjjǃj̃jjjjjJjjjjjjMjRjɐjΐjWj\jpjujzjjjjyj~jjjzjj˝jНjjjТjբjjPjjajj#jjj̧jѧj{jj*j/j jjVj[jjjjjsjxjjjj jjjj#jjj-j2jjjZj_jejjjjj^jcjjjHjMjOjTjjjjj:j?jjj4j9j)j.j|jjjjjj;j@jjj<jAjjjLjQjjjTjYj:j?jjj j j[ j` j j jju footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}jKsRparse_messages](hsystem_message)}(hhh]h)}(h+Duplicate implicit target name: "overview".h]h/Duplicate implicit target name: “overview”.}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj$ubah}(h]h ]h"]h$]h&]j7alevelKtypeINFOsourcehlineMuh1j"hj0hhhhhMubj#)}(hhh]h)}(h+Duplicate implicit target name: "overview".h]h/Duplicate implicit target name: “overview”.}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1hhj@ubah}(h]h ]h"]h$]h&]jalevelKtypej=sourcehlineM;uh1j"hjahhhhhM;ubetransform_messages](j#)}(hhh]h)}(hhh]h:Hyperlink target "prime-buffer-sharing" is not referenced.}hj`sbah}(h]h ]h"]h$]h&]uh1hhj]ubah}(h] h ]h"]h$]h&]levelKtypej=sourcehlineMuh1j"ubj#)}(hhh]h)}(hhh]h/Hyperlink target "drm-gpuvm" is not referenced.}hjzsbah}(h]h ]h"]h$]h&]uh1hhjwubah}(h]h ]h"]h$]h&]levelKtypej=sourcehlineMuh1j"ubj#)}(hhh]h)}(hhh]h7Hyperlink target "drm-gpuvm-locking" is not referenced.}hjsbah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]levelKtypej=sourcehlineMuh1j"ubj#)}(hhh]h)}(hhh]h6Hyperlink target "drm-sync-objects" is not referenced.}hjsbah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]levelKtypej=sourcehlineMuh1j"ube transformerN include_log] decorationNhhub.