Add helper function to mmap ttm bo's using &drm_gem_object_funcs.mmap(). Note that with this code path access verification is done by drm_gem_mmap() (which calls drm_vma_node_is_allowed(()). The &ttm_bo_driver.verify_access() callback is is not used. v3: use ttm_bo_mmap_obj instead of ttm_bo_mmap_vma_setup Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> Link: http://patchwork.freedesktop.org/patch/msgid/20191016115203.20095-9-kraxel@redhat.com
		
			
				
	
	
		
			74 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0-or-later
 | |
| 
 | |
| #include <linux/module.h>
 | |
| 
 | |
| #include <drm/drm_gem_ttm_helper.h>
 | |
| 
 | |
| /**
 | |
|  * DOC: overview
 | |
|  *
 | |
|  * This library provides helper functions for gem objects backed by
 | |
|  * ttm.
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * drm_gem_ttm_print_info() - Print &ttm_buffer_object info for debugfs
 | |
|  * @p: DRM printer
 | |
|  * @indent: Tab indentation level
 | |
|  * @gem: GEM object
 | |
|  *
 | |
|  * This function can be used as &drm_gem_object_funcs.print_info
 | |
|  * callback.
 | |
|  */
 | |
| void drm_gem_ttm_print_info(struct drm_printer *p, unsigned int indent,
 | |
| 			    const struct drm_gem_object *gem)
 | |
| {
 | |
| 	static const char * const plname[] = {
 | |
| 		[ TTM_PL_SYSTEM ] = "system",
 | |
| 		[ TTM_PL_TT     ] = "tt",
 | |
| 		[ TTM_PL_VRAM   ] = "vram",
 | |
| 		[ TTM_PL_PRIV   ] = "priv",
 | |
| 
 | |
| 		[ 16 ]            = "cached",
 | |
| 		[ 17 ]            = "uncached",
 | |
| 		[ 18 ]            = "wc",
 | |
| 		[ 19 ]            = "contig",
 | |
| 
 | |
| 		[ 21 ]            = "pinned", /* NO_EVICT */
 | |
| 		[ 22 ]            = "topdown",
 | |
| 	};
 | |
| 	const struct ttm_buffer_object *bo = drm_gem_ttm_of_gem(gem);
 | |
| 
 | |
| 	drm_printf_indent(p, indent, "placement=");
 | |
| 	drm_print_bits(p, bo->mem.placement, plname, ARRAY_SIZE(plname));
 | |
| 	drm_printf(p, "\n");
 | |
| 
 | |
| 	if (bo->mem.bus.is_iomem) {
 | |
| 		drm_printf_indent(p, indent, "bus.base=%lx\n",
 | |
| 				  (unsigned long)bo->mem.bus.base);
 | |
| 		drm_printf_indent(p, indent, "bus.offset=%lx\n",
 | |
| 				  (unsigned long)bo->mem.bus.offset);
 | |
| 	}
 | |
| }
 | |
| EXPORT_SYMBOL(drm_gem_ttm_print_info);
 | |
| 
 | |
| /**
 | |
|  * drm_gem_ttm_mmap() - mmap &ttm_buffer_object
 | |
|  * @gem: GEM object.
 | |
|  * @vma: vm area.
 | |
|  *
 | |
|  * This function can be used as &drm_gem_object_funcs.mmap
 | |
|  * callback.
 | |
|  */
 | |
| int drm_gem_ttm_mmap(struct drm_gem_object *gem,
 | |
| 		     struct vm_area_struct *vma)
 | |
| {
 | |
| 	struct ttm_buffer_object *bo = drm_gem_ttm_of_gem(gem);
 | |
| 
 | |
| 	return ttm_bo_mmap_obj(vma, bo);
 | |
| }
 | |
| EXPORT_SYMBOL(drm_gem_ttm_mmap);
 | |
| 
 | |
| MODULE_DESCRIPTION("DRM gem ttm helpers");
 | |
| MODULE_LICENSE("GPL");
 |