/linux-4.4.14/drivers/gpu/drm/ttm/ |
H A D | ttm_tt.c | 43 #include <drm/ttm/ttm_module.h> 44 #include <drm/ttm/ttm_bo_driver.h> 45 #include <drm/ttm/ttm_placement.h> 46 #include <drm/ttm/ttm_page_alloc.h> 49 * Allocates storage for pointers to the pages that back the ttm. 51 static void ttm_tt_alloc_page_directory(struct ttm_tt *ttm) ttm_tt_alloc_page_directory() argument 53 ttm->pages = drm_calloc_large(ttm->num_pages, sizeof(void*)); ttm_tt_alloc_page_directory() 56 static void ttm_dma_tt_alloc_page_directory(struct ttm_dma_tt *ttm) ttm_dma_tt_alloc_page_directory() argument 58 ttm->ttm.pages = drm_calloc_large(ttm->ttm.num_pages, ttm_dma_tt_alloc_page_directory() 59 sizeof(*ttm->ttm.pages) + ttm_dma_tt_alloc_page_directory() 60 sizeof(*ttm->dma_address) + ttm_dma_tt_alloc_page_directory() 61 sizeof(*ttm->cpu_address)); ttm_dma_tt_alloc_page_directory() 62 ttm->cpu_address = (void *) (ttm->ttm.pages + ttm->ttm.num_pages); ttm_dma_tt_alloc_page_directory() 63 ttm->dma_address = (void *) (ttm->cpu_address + ttm->ttm.num_pages); ttm_dma_tt_alloc_page_directory() 103 * for range of pages in a ttm. 106 static int ttm_tt_set_caching(struct ttm_tt *ttm, ttm_tt_set_caching() argument 113 if (ttm->caching_state == c_state) ttm_tt_set_caching() 116 if (ttm->state == tt_unpopulated) { ttm_tt_set_caching() 118 ttm->caching_state = c_state; ttm_tt_set_caching() 122 if (ttm->caching_state == tt_cached) ttm_tt_set_caching() 123 drm_clflush_pages(ttm->pages, ttm->num_pages); ttm_tt_set_caching() 125 for (i = 0; i < ttm->num_pages; ++i) { ttm_tt_set_caching() 126 cur_page = ttm->pages[i]; ttm_tt_set_caching() 129 ttm->caching_state, ttm_tt_set_caching() 136 ttm->caching_state = c_state; ttm_tt_set_caching() 142 cur_page = ttm->pages[j]; ttm_tt_set_caching() 145 ttm->caching_state); ttm_tt_set_caching() 152 int ttm_tt_set_placement_caching(struct ttm_tt *ttm, uint32_t placement) ttm_tt_set_placement_caching() argument 163 return ttm_tt_set_caching(ttm, state); ttm_tt_set_placement_caching() 167 void ttm_tt_destroy(struct ttm_tt *ttm) ttm_tt_destroy() argument 169 if (unlikely(ttm == NULL)) ttm_tt_destroy() 172 if (ttm->state == tt_bound) { ttm_tt_destroy() 173 ttm_tt_unbind(ttm); ttm_tt_destroy() 176 if (ttm->state == tt_unbound) ttm_tt_destroy() 177 ttm_tt_unpopulate(ttm); ttm_tt_destroy() 179 if (!(ttm->page_flags & TTM_PAGE_FLAG_PERSISTENT_SWAP) && ttm_tt_destroy() 180 ttm->swap_storage) ttm_tt_destroy() 181 fput(ttm->swap_storage); ttm_tt_destroy() 183 ttm->swap_storage = NULL; ttm_tt_destroy() 184 ttm->func->destroy(ttm); ttm_tt_destroy() 187 int ttm_tt_init(struct ttm_tt *ttm, struct ttm_bo_device *bdev, ttm_tt_init() argument 191 ttm->bdev = bdev; ttm_tt_init() 192 ttm->glob = bdev->glob; ttm_tt_init() 193 ttm->num_pages = (size + PAGE_SIZE - 1) >> PAGE_SHIFT; ttm_tt_init() 194 ttm->caching_state = tt_cached; ttm_tt_init() 195 ttm->page_flags = page_flags; ttm_tt_init() 196 ttm->dummy_read_page = dummy_read_page; ttm_tt_init() 197 ttm->state = tt_unpopulated; ttm_tt_init() 198 ttm->swap_storage = NULL; ttm_tt_init() 200 ttm_tt_alloc_page_directory(ttm); ttm_tt_init() 201 if (!ttm->pages) { ttm_tt_init() 202 ttm_tt_destroy(ttm); ttm_tt_init() 210 void ttm_tt_fini(struct ttm_tt *ttm) ttm_tt_fini() argument 212 drm_free_large(ttm->pages); ttm_tt_fini() 213 ttm->pages = NULL; ttm_tt_fini() 221 struct ttm_tt *ttm = &ttm_dma->ttm; ttm_dma_tt_init() local 223 ttm->bdev = bdev; ttm_dma_tt_init() 224 ttm->glob = bdev->glob; ttm_dma_tt_init() 225 ttm->num_pages = (size + PAGE_SIZE - 1) >> PAGE_SHIFT; ttm_dma_tt_init() 226 ttm->caching_state = tt_cached; ttm_dma_tt_init() 227 ttm->page_flags = page_flags; ttm_dma_tt_init() 228 ttm->dummy_read_page = dummy_read_page; ttm_dma_tt_init() 229 ttm->state = tt_unpopulated; ttm_dma_tt_init() 230 ttm->swap_storage = NULL; ttm_dma_tt_init() 234 if (!ttm->pages) { ttm_dma_tt_init() 235 ttm_tt_destroy(ttm); ttm_dma_tt_init() 245 struct ttm_tt *ttm = &ttm_dma->ttm; ttm_dma_tt_fini() local 247 drm_free_large(ttm->pages); ttm_dma_tt_fini() 248 ttm->pages = NULL; ttm_dma_tt_fini() 254 void ttm_tt_unbind(struct ttm_tt *ttm) ttm_tt_unbind() argument 258 if (ttm->state == tt_bound) { ttm_tt_unbind() 259 ret = ttm->func->unbind(ttm); ttm_tt_unbind() 261 ttm->state = tt_unbound; ttm_tt_unbind() 265 int ttm_tt_bind(struct ttm_tt *ttm, struct ttm_mem_reg *bo_mem) ttm_tt_bind() argument 269 if (!ttm) ttm_tt_bind() 272 if (ttm->state == tt_bound) ttm_tt_bind() 275 ret = ttm->bdev->driver->ttm_tt_populate(ttm); ttm_tt_bind() 279 ret = ttm->func->bind(ttm, bo_mem); ttm_tt_bind() 283 ttm->state = tt_bound; ttm_tt_bind() 289 int ttm_tt_swapin(struct ttm_tt *ttm) ttm_tt_swapin() argument 298 swap_storage = ttm->swap_storage; ttm_tt_swapin() 303 for (i = 0; i < ttm->num_pages; ++i) { ttm_tt_swapin() 309 to_page = ttm->pages[i]; ttm_tt_swapin() 317 if (!(ttm->page_flags & TTM_PAGE_FLAG_PERSISTENT_SWAP)) ttm_tt_swapin() 319 ttm->swap_storage = NULL; ttm_tt_swapin() 320 ttm->page_flags &= ~TTM_PAGE_FLAG_SWAPPED; ttm_tt_swapin() 327 int ttm_tt_swapout(struct ttm_tt *ttm, struct file *persistent_swap_storage) ttm_tt_swapout() argument 336 BUG_ON(ttm->state != tt_unbound && ttm->state != tt_unpopulated); ttm_tt_swapout() 337 BUG_ON(ttm->caching_state != tt_cached); ttm_tt_swapout() 340 swap_storage = shmem_file_setup("ttm swap", ttm_tt_swapout() 341 ttm->num_pages << PAGE_SHIFT, ttm_tt_swapout() 352 for (i = 0; i < ttm->num_pages; ++i) { ttm_tt_swapout() 353 from_page = ttm->pages[i]; ttm_tt_swapout() 367 ttm_tt_unpopulate(ttm); ttm_tt_swapout() 368 ttm->swap_storage = swap_storage; ttm_tt_swapout() 369 ttm->page_flags |= TTM_PAGE_FLAG_SWAPPED; ttm_tt_swapout() 371 ttm->page_flags |= TTM_PAGE_FLAG_PERSISTENT_SWAP; ttm_tt_swapout() 381 static void ttm_tt_clear_mapping(struct ttm_tt *ttm) ttm_tt_clear_mapping() argument 384 struct page **page = ttm->pages; ttm_tt_clear_mapping() 386 if (ttm->page_flags & TTM_PAGE_FLAG_SG) ttm_tt_clear_mapping() 389 for (i = 0; i < ttm->num_pages; ++i) { ttm_tt_clear_mapping() 395 void ttm_tt_unpopulate(struct ttm_tt *ttm) ttm_tt_unpopulate() argument 397 if (ttm->state == tt_unpopulated) ttm_tt_unpopulate() 400 ttm_tt_clear_mapping(ttm); ttm_tt_unpopulate() 401 ttm->bdev->driver->ttm_tt_unpopulate(ttm); ttm_tt_unpopulate()
|
H A D | Makefile | 5 ttm-y := ttm_agp_backend.o ttm_memory.o ttm_tt.o ttm_bo.o \ 10 obj-$(CONFIG_DRM_TTM) += ttm.o
|
H A D | ttm_agp_backend.c | 34 #include <drm/ttm/ttm_module.h> 35 #include <drm/ttm/ttm_bo_driver.h> 36 #include <drm/ttm/ttm_page_alloc.h> 38 #include <drm/ttm/ttm_placement.h> 46 struct ttm_tt ttm; member in struct:ttm_agp_backend 51 static int ttm_agp_bind(struct ttm_tt *ttm, struct ttm_mem_reg *bo_mem) ttm_agp_bind() argument 53 struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm); ttm_agp_bind() 59 mem = agp_allocate_memory(agp_be->bridge, ttm->num_pages, AGP_USER_MEMORY); ttm_agp_bind() 64 for (i = 0; i < ttm->num_pages; i++) { ttm_agp_bind() 65 struct page *page = ttm->pages[i]; ttm_agp_bind() 68 page = ttm->dummy_read_page; ttm_agp_bind() 84 static int ttm_agp_unbind(struct ttm_tt *ttm) ttm_agp_unbind() argument 86 struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm); ttm_agp_unbind() 97 static void ttm_agp_destroy(struct ttm_tt *ttm) ttm_agp_destroy() argument 99 struct ttm_agp_backend *agp_be = container_of(ttm, struct ttm_agp_backend, ttm); ttm_agp_destroy() 102 ttm_agp_unbind(ttm); ttm_agp_destroy() 103 ttm_tt_fini(ttm); ttm_agp_destroy() 126 agp_be->ttm.func = &ttm_agp_func; ttm_agp_tt_create() 128 if (ttm_tt_init(&agp_be->ttm, bdev, size, page_flags, dummy_read_page)) { ttm_agp_tt_create() 133 return &agp_be->ttm; ttm_agp_tt_create() 137 int ttm_agp_tt_populate(struct ttm_tt *ttm) ttm_agp_tt_populate() argument 139 if (ttm->state != tt_unpopulated) ttm_agp_tt_populate() 142 return ttm_pool_populate(ttm); ttm_agp_tt_populate() 146 void ttm_agp_tt_unpopulate(struct ttm_tt *ttm) ttm_agp_tt_unpopulate() argument 148 ttm_pool_unpopulate(ttm); ttm_agp_tt_unpopulate()
|
H A D | ttm_bo_util.c | 31 #include <drm/ttm/ttm_bo_driver.h> 32 #include <drm/ttm/ttm_placement.h> 51 struct ttm_tt *ttm = bo->ttm; ttm_bo_move_ttm() local 56 ttm_tt_unbind(ttm); ttm_bo_move_ttm() 63 ret = ttm_tt_set_placement_caching(ttm, new_mem->placement); ttm_bo_move_ttm() 68 ret = ttm_tt_bind(ttm, new_mem); ttm_bo_move_ttm() 250 static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src, ttm_copy_io_ttm_page() argument 254 struct page *d = ttm->pages[page]; ttm_copy_io_ttm_page() 287 static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst, ttm_copy_ttm_io_page() argument 291 struct page *s = ttm->pages[page]; ttm_copy_ttm_io_page() 329 struct ttm_tt *ttm = bo->ttm; ttm_bo_move_memcpy() local 357 (ttm == NULL || (ttm->state == tt_unpopulated && ttm_bo_move_memcpy() 358 !(ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)))) { ttm_bo_move_memcpy() 366 if (ttm && ttm->state == tt_unpopulated) { ttm_bo_move_memcpy() 367 ret = ttm->bdev->driver->ttm_tt_populate(ttm); ttm_bo_move_memcpy() 386 ret = ttm_copy_ttm_io_page(ttm, new_iomap, page, ttm_bo_move_memcpy() 391 ret = ttm_copy_io_ttm_page(ttm, old_iomap, page, ttm_bo_move_memcpy() 404 if ((man->flags & TTM_MEMTYPE_FLAG_FIXED) && (ttm != NULL)) { ttm_bo_move_memcpy() 405 ttm_tt_unbind(ttm); ttm_bo_move_memcpy() 406 ttm_tt_destroy(ttm); ttm_bo_move_memcpy() 407 bo->ttm = NULL; ttm_bo_move_memcpy() 535 struct ttm_tt *ttm = bo->ttm; ttm_bo_kmap_ttm() local 538 BUG_ON(!ttm); ttm_bo_kmap_ttm() 540 if (ttm->state == tt_unpopulated) { ttm_bo_kmap_ttm() 541 ret = ttm->bdev->driver->ttm_tt_populate(ttm); ttm_bo_kmap_ttm() 553 map->page = ttm->pages[start_page]; ttm_bo_kmap_ttm() 562 map->virtual = vmap(ttm->pages + start_page, num_pages, ttm_bo_kmap_ttm() 653 (bo->ttm != NULL)) { ttm_bo_move_accel_cleanup() 654 ttm_tt_unbind(bo->ttm); ttm_bo_move_accel_cleanup() 655 ttm_tt_destroy(bo->ttm); ttm_bo_move_accel_cleanup() 656 bo->ttm = NULL; ttm_bo_move_accel_cleanup() 683 ghost_obj->ttm = NULL; ttm_bo_move_accel_cleanup() 685 bo->ttm = NULL; ttm_bo_move_accel_cleanup()
|
H A D | ttm_page_alloc.c | 48 #include <drm/ttm/ttm_bo_driver.h> 49 #include <drm/ttm/ttm_page_alloc.h> 255 * Select the right pool or requested caching state and ttm flags. */ ttm_get_pool() 864 int ttm_pool_populate(struct ttm_tt *ttm) ttm_pool_populate() argument 866 struct ttm_mem_global *mem_glob = ttm->glob->mem_glob; ttm_pool_populate() 870 if (ttm->state != tt_unpopulated) ttm_pool_populate() 873 for (i = 0; i < ttm->num_pages; ++i) { ttm_pool_populate() 874 ret = ttm_get_pages(&ttm->pages[i], 1, ttm_pool_populate() 875 ttm->page_flags, ttm_pool_populate() 876 ttm->caching_state); ttm_pool_populate() 878 ttm_pool_unpopulate(ttm); ttm_pool_populate() 882 ret = ttm_mem_global_alloc_page(mem_glob, ttm->pages[i], ttm_pool_populate() 885 ttm_pool_unpopulate(ttm); ttm_pool_populate() 890 if (unlikely(ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)) { ttm_pool_populate() 891 ret = ttm_tt_swapin(ttm); ttm_pool_populate() 893 ttm_pool_unpopulate(ttm); ttm_pool_populate() 898 ttm->state = tt_unbound; ttm_pool_populate() 903 void ttm_pool_unpopulate(struct ttm_tt *ttm) ttm_pool_unpopulate() argument 907 for (i = 0; i < ttm->num_pages; ++i) { ttm_pool_unpopulate() 908 if (ttm->pages[i]) { ttm_pool_unpopulate() 909 ttm_mem_global_free_page(ttm->glob->mem_glob, ttm_pool_unpopulate() 910 ttm->pages[i]); ttm_pool_unpopulate() 911 ttm_put_pages(&ttm->pages[i], 1, ttm_pool_unpopulate() 912 ttm->page_flags, ttm_pool_unpopulate() 913 ttm->caching_state); ttm_pool_unpopulate() 916 ttm->state = tt_unpopulated; ttm_pool_unpopulate()
|
H A D | ttm_bo_vm.c | 33 #include <ttm/ttm_module.h> 34 #include <ttm/ttm_bo_driver.h> 35 #include <ttm/ttm_placement.h> 94 struct ttm_tt *ttm = NULL; ttm_bo_vm_fault() local 136 if (bo->ttm && (bo->ttm->page_flags & TTM_PAGE_FLAG_SG)) { ttm_bo_vm_fault() 199 ttm = bo->ttm; ttm_bo_vm_fault() 204 if (ttm->bdev->driver->ttm_tt_populate(ttm)) { ttm_bo_vm_fault() 218 page = ttm->pages[page_offset]; ttm_bo_vm_fault()
|
H A D | ttm_page_alloc_dma.c | 51 #include <drm/ttm/ttm_bo_driver.h> 52 #include <drm/ttm/ttm_page_alloc.h> 852 struct ttm_tt *ttm = &ttm_dma->ttm; ttm_dma_pool_get_pages() local 860 ttm->pages[index] = d_page->p; ttm_dma_pool_get_pages() 878 struct ttm_tt *ttm = &ttm_dma->ttm; ttm_dma_populate() local 879 struct ttm_mem_global *mem_glob = ttm->glob->mem_glob; ttm_dma_populate() 886 if (ttm->state != tt_unpopulated) ttm_dma_populate() 889 type = ttm_to_type(ttm->page_flags, ttm->caching_state); ttm_dma_populate() 890 if (ttm->page_flags & TTM_PAGE_FLAG_DMA32) ttm_dma_populate() 894 if (ttm->page_flags & TTM_PAGE_FLAG_ZERO_ALLOC) ttm_dma_populate() 906 for (i = 0; i < ttm->num_pages; ++i) { ttm_dma_populate() 913 ret = ttm_mem_global_alloc_page(mem_glob, ttm->pages[i], ttm_dma_populate() 921 if (unlikely(ttm->page_flags & TTM_PAGE_FLAG_SWAPPED)) { ttm_dma_populate() 922 ret = ttm_tt_swapin(ttm); ttm_dma_populate() 929 ttm->state = tt_unbound; ttm_dma_populate() 937 struct ttm_tt *ttm = &ttm_dma->ttm; ttm_dma_unpopulate() local 945 type = ttm_to_type(ttm->page_flags, ttm->caching_state); ttm_dma_unpopulate() 951 ttm_to_type(ttm->page_flags, tt_cached)) == pool); ttm_dma_unpopulate() 955 ttm->pages[count] = d_page->p; ttm_dma_unpopulate() 978 ttm_mem_global_free_page(ttm->glob->mem_glob, ttm_dma_unpopulate() 984 ttm_mem_global_free_page(ttm->glob->mem_glob, ttm_dma_unpopulate() 985 ttm->pages[i]); ttm_dma_unpopulate() 990 for (i = 0; i < ttm->num_pages; i++) { ttm_dma_unpopulate() 991 ttm->pages[i] = NULL; ttm_dma_unpopulate() 999 ttm->state = tt_unpopulated; ttm_dma_unpopulate()
|
H A D | ttm_module.c | 34 #include <drm/ttm/ttm_module.h> 41 .name = "ttm", 69 ret = dev_set_name(&ttm_drm_class_device, "ttm"); ttm_init()
|
H A D | ttm_bo.c | 33 #include <drm/ttm/ttm_module.h> 34 #include <drm/ttm/ttm_bo_driver.h> 35 #include <drm/ttm/ttm_placement.h> 150 if (bo->ttm) ttm_bo_release_list() 151 ttm_tt_destroy(bo->ttm); ttm_bo_release_list() 179 if (bo->ttm != NULL) { ttm_bo_add_to_lru() 242 bo->ttm = NULL; ttm_bo_add_ttm() 252 bo->ttm = bdev->driver->ttm_tt_create(bdev, bo->num_pages << PAGE_SHIFT, ttm_bo_add_ttm() 254 if (unlikely(bo->ttm == NULL)) ttm_bo_add_ttm() 258 bo->ttm = bdev->driver->ttm_tt_create(bdev, bo->num_pages << PAGE_SHIFT, ttm_bo_add_ttm() 261 if (unlikely(bo->ttm == NULL)) { ttm_bo_add_ttm() 265 bo->ttm->sg = bo->sg; ttm_bo_add_ttm() 298 * Create and bind a ttm if required. ttm_bo_handle_move_mem() 302 if (bo->ttm == NULL) { ttm_bo_handle_move_mem() 309 ret = ttm_tt_set_placement_caching(bo->ttm, mem->placement); ttm_bo_handle_move_mem() 314 ret = ttm_tt_bind(bo->ttm, mem); ttm_bo_handle_move_mem() 374 if ((new_man->flags & TTM_MEMTYPE_FLAG_FIXED) && bo->ttm) { ttm_bo_handle_move_mem() 375 ttm_tt_unbind(bo->ttm); ttm_bo_handle_move_mem() 376 ttm_tt_destroy(bo->ttm); ttm_bo_handle_move_mem() 377 bo->ttm = NULL; ttm_bo_handle_move_mem() 396 if (bo->ttm) { ttm_bo_cleanup_memtype_use() 397 ttm_tt_unbind(bo->ttm); ttm_bo_cleanup_memtype_use() 398 ttm_tt_destroy(bo->ttm); ttm_bo_cleanup_memtype_use() 399 bo->ttm = NULL; ttm_bo_cleanup_memtype_use() 1070 if (bo->mem.mem_type == TTM_PL_SYSTEM && bo->ttm == NULL) { ttm_bo_validate() 1677 * anyone tries to access a ttm page. ttm_bo_swapout() 1683 ret = ttm_tt_swapout(bo->ttm, bo->persistent_swap_storage); ttm_bo_swapout()
|
H A D | ttm_bo_manager.c | 31 #include <drm/ttm/ttm_module.h> 32 #include <drm/ttm/ttm_bo_driver.h> 33 #include <drm/ttm/ttm_placement.h>
|
H A D | ttm_execbuf_util.c | 28 #include <drm/ttm/ttm_execbuf_util.h> 29 #include <drm/ttm/ttm_bo_driver.h> 30 #include <drm/ttm/ttm_placement.h>
|
H A D | ttm_lock.c | 31 #include <drm/ttm/ttm_lock.h> 32 #include <drm/ttm/ttm_module.h>
|
H A D | ttm_object.c | 39 * ttm objects. Implements reference counting, minimal security checks 61 #include <drm/ttm/ttm_object.h> 62 #include <drm/ttm/ttm_module.h> 86 * This is the per-device data structure needed for ttm object management. 647 * ttm_prime_handle_to_fd - Return a dma_buf fd from a ttm prime object
|
H A D | ttm_memory.c | 30 #include <drm/ttm/ttm_memory.h> 31 #include <drm/ttm/ttm_module.h> 32 #include <drm/ttm/ttm_page_alloc.h>
|
/linux-4.4.14/drivers/gpu/drm/nouveau/ |
H A D | nouveau_sgdma.c | 11 struct ttm_dma_tt ttm; member in struct:nouveau_sgdma_be 16 nouveau_sgdma_destroy(struct ttm_tt *ttm) nouveau_sgdma_destroy() argument 18 struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm; nouveau_sgdma_destroy() 20 if (ttm) { nouveau_sgdma_destroy() 21 ttm_dma_tt_fini(&nvbe->ttm); nouveau_sgdma_destroy() 27 nv04_sgdma_bind(struct ttm_tt *ttm, struct ttm_mem_reg *mem) nv04_sgdma_bind() argument 29 struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm; nv04_sgdma_bind() 32 if (ttm->sg) { nv04_sgdma_bind() 33 node->sg = ttm->sg; nv04_sgdma_bind() 37 node->pages = nvbe->ttm.dma_address; nv04_sgdma_bind() 47 nv04_sgdma_unbind(struct ttm_tt *ttm) nv04_sgdma_unbind() argument 49 struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm; nv04_sgdma_unbind() 61 nv50_sgdma_bind(struct ttm_tt *ttm, struct ttm_mem_reg *mem) nv50_sgdma_bind() argument 63 struct nouveau_sgdma_be *nvbe = (struct nouveau_sgdma_be *)ttm; nv50_sgdma_bind() 67 if (ttm->sg) { nv50_sgdma_bind() 68 node->sg = ttm->sg; nv50_sgdma_bind() 72 node->pages = nvbe->ttm.dma_address; nv50_sgdma_bind() 79 nv50_sgdma_unbind(struct ttm_tt *ttm) nv50_sgdma_unbind() argument 104 nvbe->ttm.ttm.func = &nv04_sgdma_backend; nouveau_sgdma_create_ttm() 106 nvbe->ttm.ttm.func = &nv50_sgdma_backend; nouveau_sgdma_create_ttm() 108 if (ttm_dma_tt_init(&nvbe->ttm, bdev, size, page_flags, dummy_read_page)) nouveau_sgdma_create_ttm() 115 return &nvbe->ttm.ttm; nouveau_sgdma_create_ttm()
|
H A D | nouveau_ttm.c | 275 return ttm_bo_mmap(filp, vma, &drm->ttm.bdev); nouveau_ttm_mmap() 296 global_ref = &drm->ttm.mem_global_ref; nouveau_ttm_global_init() 305 drm->ttm.mem_global_ref.release = NULL; nouveau_ttm_global_init() 309 drm->ttm.bo_global_ref.mem_glob = global_ref->object; nouveau_ttm_global_init() 310 global_ref = &drm->ttm.bo_global_ref.ref; nouveau_ttm_global_init() 319 drm_global_item_unref(&drm->ttm.mem_global_ref); nouveau_ttm_global_init() 320 drm->ttm.mem_global_ref.release = NULL; nouveau_ttm_global_init() 330 if (drm->ttm.mem_global_ref.release == NULL) nouveau_ttm_global_release() 333 drm_global_item_unref(&drm->ttm.bo_global_ref.ref); nouveau_ttm_global_release() 334 drm_global_item_unref(&drm->ttm.mem_global_ref); nouveau_ttm_global_release() 335 drm->ttm.mem_global_ref.release = NULL; nouveau_ttm_global_release() 386 ret = ttm_bo_device_init(&drm->ttm.bdev, nouveau_ttm_init() 387 drm->ttm.bo_global_ref.ref.object, nouveau_ttm_init() 400 ret = ttm_bo_init_mm(&drm->ttm.bdev, TTM_PL_VRAM, nouveau_ttm_init() 407 drm->ttm.mtrr = arch_phys_wc_add(device->func->resource_addr(device, 1), nouveau_ttm_init() 417 ret = ttm_bo_init_mm(&drm->ttm.bdev, TTM_PL_TT, nouveau_ttm_init() 432 ttm_bo_clean_mm(&drm->ttm.bdev, TTM_PL_VRAM); nouveau_ttm_fini() 433 ttm_bo_clean_mm(&drm->ttm.bdev, TTM_PL_TT); nouveau_ttm_fini() 435 ttm_bo_device_release(&drm->ttm.bdev); nouveau_ttm_fini() 439 arch_phys_wc_del(drm->ttm.mtrr); nouveau_ttm_fini() 440 drm->ttm.mtrr = 0; nouveau_ttm_fini()
|
H A D | nouveau_ttm.h | 7 return container_of(bd, struct nouveau_drm, ttm.bdev); nouveau_bdev()
|
H A D | nouveau_drm.h | 46 #include <drm/ttm/ttm_bo_api.h> 47 #include <drm/ttm/ttm_bo_driver.h> 48 #include <drm/ttm/ttm_placement.h> 49 #include <drm/ttm/ttm_memory.h> 50 #include <drm/ttm/ttm_module.h> 51 #include <drm/ttm/ttm_page_alloc.h> 134 } ttm; member in struct:nouveau_drm
|
H A D | nouveau_bo.c | 210 nvbo->bo.bdev = &drm->ttm.bdev; nouveau_bo_new() 225 acc_size = ttm_bo_dma_acc_size(&drm->ttm.bdev, size, nouveau_bo_new() 228 ret = ttm_bo_init(&drm->ttm.bdev, &nvbo->bo, size, nouveau_bo_new() 233 /* ttm will call nouveau_bo_del_ttm if it fails.. */ nouveau_bo_new() 458 struct ttm_dma_tt *ttm_dma = (struct ttm_dma_tt *)nvbo->bo.ttm; nouveau_bo_sync_for_device() 468 for (i = 0; i < ttm_dma->ttm.num_pages; i++) nouveau_bo_sync_for_device() 478 struct ttm_dma_tt *ttm_dma = (struct ttm_dma_tt *)nvbo->bo.ttm; nouveau_bo_sync_for_cpu() 488 for (i = 0; i < ttm_dma->ttm.num_pages; i++) nouveau_bo_sync_for_cpu() 522 dma_tt = (struct ttm_dma_tt *)nvbo->bo.ttm; _nouveau_bo_mem_index() 1060 struct nouveau_channel *chan = drm->ttm.chan; nouveau_bo_move_m2mf() 1066 * old nvkm_mem node, these will get cleaned up after ttm has nouveau_bo_move_m2mf() 1078 ret = drm->ttm.move(chan, bo, &bo->mem, new_mem); nouveau_bo_move_m2mf() 1137 &drm->ttm.copy); nouveau_bo_move_init() 1139 ret = mthd->init(chan, drm->ttm.copy.handle); nouveau_bo_move_init() 1141 nvif_object_fini(&drm->ttm.copy); nouveau_bo_move_init() 1145 drm->ttm.move = mthd->exec; nouveau_bo_move_init() 1146 drm->ttm.chan = chan; nouveau_bo_move_init() 1177 ret = ttm_tt_bind(bo->ttm, &tmp_mem); nouveau_bo_move_flipd() 1232 /* ttm can now (stupidly) pass the driver bos it didn't create... */ nouveau_bo_move_ntfy() 1302 if (old_mem->mem_type == TTM_PL_SYSTEM && !bo->ttm) { nouveau_bo_move() 1310 if (drm->ttm.move) { nouveau_bo_move() 1464 nouveau_ttm_tt_populate(struct ttm_tt *ttm) nouveau_ttm_tt_populate() argument 1466 struct ttm_dma_tt *ttm_dma = (void *)ttm; nouveau_ttm_tt_populate() 1473 bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG); nouveau_ttm_tt_populate() 1475 if (ttm->state != tt_unpopulated) nouveau_ttm_tt_populate() 1478 if (slave && ttm->sg) { nouveau_ttm_tt_populate() 1480 drm_prime_sg_to_page_addr_arrays(ttm->sg, ttm->pages, nouveau_ttm_tt_populate() 1481 ttm_dma->dma_address, ttm->num_pages); nouveau_ttm_tt_populate() 1482 ttm->state = tt_unbound; nouveau_ttm_tt_populate() 1486 drm = nouveau_bdev(ttm->bdev); nouveau_ttm_tt_populate() 1496 ttm->caching_state == tt_uncached) nouveau_ttm_tt_populate() 1501 return ttm_agp_tt_populate(ttm); nouveau_ttm_tt_populate() 1507 return ttm_dma_populate((void *)ttm, dev->dev); nouveau_ttm_tt_populate() 1511 r = ttm_pool_populate(ttm); nouveau_ttm_tt_populate() 1516 for (i = 0; i < ttm->num_pages; i++) { nouveau_ttm_tt_populate() 1519 addr = dma_map_page(pdev, ttm->pages[i], 0, PAGE_SIZE, nouveau_ttm_tt_populate() 1528 ttm_pool_unpopulate(ttm); nouveau_ttm_tt_populate() 1538 nouveau_ttm_tt_unpopulate(struct ttm_tt *ttm) nouveau_ttm_tt_unpopulate() argument 1540 struct ttm_dma_tt *ttm_dma = (void *)ttm; nouveau_ttm_tt_unpopulate() 1546 bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG); nouveau_ttm_tt_unpopulate() 1551 drm = nouveau_bdev(ttm->bdev); nouveau_ttm_tt_unpopulate() 1561 ttm->caching_state == tt_uncached) { nouveau_ttm_tt_unpopulate() 1568 ttm_agp_tt_unpopulate(ttm); nouveau_ttm_tt_unpopulate() 1575 ttm_dma_unpopulate((void *)ttm, dev->dev); nouveau_ttm_tt_unpopulate() 1580 for (i = 0; i < ttm->num_pages; i++) { nouveau_ttm_tt_unpopulate() 1587 ttm_pool_unpopulate(ttm); nouveau_ttm_tt_unpopulate()
|
H A D | nouveau_prime.c | 36 return drm_prime_pages_to_sg(nvbo->bo.ttm->pages, npages); nouveau_gem_prime_get_sg_table() 80 * to the caller, instead of a normal nouveau_bo ttm reference. */ nouveau_gem_prime_import_sg_table()
|
H A D | nouveau_bo.h | 38 /* protect by the ttm reservation lock */
|
H A D | nouveau_drm.c | 149 nvif_object_fini(&drm->ttm.copy); nouveau_accel_fini() 547 ttm_bo_evict_mm(&drm->ttm.bdev, TTM_PL_VRAM); nouveau_do_suspend()
|
H A D | nouveau_gem.c | 213 * to the caller, instead of a normal nouveau_bo ttm reference. */ nouveau_gem_new()
|
/linux-4.4.14/drivers/gpu/drm/amd/amdgpu/ |
H A D | amdgpu_ttm.c | 32 #include <ttm/ttm_bo_api.h> 33 #include <ttm/ttm_bo_driver.h> 34 #include <ttm/ttm_placement.h> 35 #include <ttm/ttm_module.h> 36 #include <ttm/ttm_page_alloc.h> 306 r = ttm_tt_set_placement_caching(bo->ttm, tmp_mem.placement); amdgpu_move_vram_ram() 311 r = ttm_tt_bind(bo->ttm, &tmp_mem); amdgpu_move_vram_ram() 375 if (old_mem->mem_type == TTM_PL_SYSTEM && bo->ttm == NULL) { amdgpu_bo_move() 482 struct ttm_dma_tt ttm; member in struct:amdgpu_ttm_tt 491 static int amdgpu_ttm_tt_pin_userptr(struct ttm_tt *ttm) amdgpu_ttm_tt_pin_userptr() argument 493 struct amdgpu_device *adev = amdgpu_get_adev(ttm->bdev); amdgpu_ttm_tt_pin_userptr() 494 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_pin_userptr() 508 unsigned long end = gtt->userptr + ttm->num_pages * PAGE_SIZE; amdgpu_ttm_tt_pin_userptr() 517 unsigned num_pages = ttm->num_pages - pinned; amdgpu_ttm_tt_pin_userptr() 519 struct page **pages = ttm->pages + pinned; amdgpu_ttm_tt_pin_userptr() 528 } while (pinned < ttm->num_pages); amdgpu_ttm_tt_pin_userptr() 530 r = sg_alloc_table_from_pages(ttm->sg, ttm->pages, ttm->num_pages, 0, amdgpu_ttm_tt_pin_userptr() 531 ttm->num_pages << PAGE_SHIFT, amdgpu_ttm_tt_pin_userptr() 537 nents = dma_map_sg(adev->dev, ttm->sg->sgl, ttm->sg->nents, direction); amdgpu_ttm_tt_pin_userptr() 538 if (nents != ttm->sg->nents) amdgpu_ttm_tt_pin_userptr() 541 drm_prime_sg_to_page_addr_arrays(ttm->sg, ttm->pages, amdgpu_ttm_tt_pin_userptr() 542 gtt->ttm.dma_address, ttm->num_pages); amdgpu_ttm_tt_pin_userptr() 547 kfree(ttm->sg); amdgpu_ttm_tt_pin_userptr() 550 release_pages(ttm->pages, pinned, 0); amdgpu_ttm_tt_pin_userptr() 554 static void amdgpu_ttm_tt_unpin_userptr(struct ttm_tt *ttm) amdgpu_ttm_tt_unpin_userptr() argument 556 struct amdgpu_device *adev = amdgpu_get_adev(ttm->bdev); amdgpu_ttm_tt_unpin_userptr() 557 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_unpin_userptr() 565 if (!ttm->sg->sgl) amdgpu_ttm_tt_unpin_userptr() 569 dma_unmap_sg(adev->dev, ttm->sg->sgl, ttm->sg->nents, direction); amdgpu_ttm_tt_unpin_userptr() 571 for_each_sg_page(ttm->sg->sgl, &sg_iter, ttm->sg->nents, 0) { amdgpu_ttm_tt_unpin_userptr() 580 sg_free_table(ttm->sg); amdgpu_ttm_tt_unpin_userptr() 583 static int amdgpu_ttm_backend_bind(struct ttm_tt *ttm, amdgpu_ttm_backend_bind() argument 586 struct amdgpu_ttm_tt *gtt = (void*)ttm; amdgpu_ttm_backend_bind() 587 uint32_t flags = amdgpu_ttm_tt_pte_flags(gtt->adev, ttm, bo_mem); amdgpu_ttm_backend_bind() 591 r = amdgpu_ttm_tt_pin_userptr(ttm); amdgpu_ttm_backend_bind() 598 if (!ttm->num_pages) { amdgpu_ttm_backend_bind() 600 ttm->num_pages, bo_mem, ttm); amdgpu_ttm_backend_bind() 608 r = amdgpu_gart_bind(gtt->adev, gtt->offset, ttm->num_pages, amdgpu_ttm_backend_bind() 609 ttm->pages, gtt->ttm.dma_address, flags); amdgpu_ttm_backend_bind() 613 ttm->num_pages, (unsigned)gtt->offset); amdgpu_ttm_backend_bind() 619 static int amdgpu_ttm_backend_unbind(struct ttm_tt *ttm) amdgpu_ttm_backend_unbind() argument 621 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_backend_unbind() 625 amdgpu_gart_unbind(gtt->adev, gtt->offset, ttm->num_pages); amdgpu_ttm_backend_unbind() 628 amdgpu_ttm_tt_unpin_userptr(ttm); amdgpu_ttm_backend_unbind() 633 static void amdgpu_ttm_backend_destroy(struct ttm_tt *ttm) amdgpu_ttm_backend_destroy() argument 635 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_backend_destroy() 637 ttm_dma_tt_fini(>t->ttm); amdgpu_ttm_backend_destroy() 660 gtt->ttm.ttm.func = &amdgpu_backend_func; amdgpu_ttm_tt_create() 662 if (ttm_dma_tt_init(>t->ttm, bdev, size, page_flags, dummy_read_page)) { amdgpu_ttm_tt_create() 666 return >t->ttm.ttm; amdgpu_ttm_tt_create() 669 static int amdgpu_ttm_tt_populate(struct ttm_tt *ttm) amdgpu_ttm_tt_populate() argument 672 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_populate() 675 bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG); amdgpu_ttm_tt_populate() 677 if (ttm->state != tt_unpopulated) amdgpu_ttm_tt_populate() 681 ttm->sg = kzalloc(sizeof(struct sg_table), GFP_KERNEL); amdgpu_ttm_tt_populate() 682 if (!ttm->sg) amdgpu_ttm_tt_populate() 685 ttm->page_flags |= TTM_PAGE_FLAG_SG; amdgpu_ttm_tt_populate() 686 ttm->state = tt_unbound; amdgpu_ttm_tt_populate() 690 if (slave && ttm->sg) { amdgpu_ttm_tt_populate() 691 drm_prime_sg_to_page_addr_arrays(ttm->sg, ttm->pages, amdgpu_ttm_tt_populate() 692 gtt->ttm.dma_address, ttm->num_pages); amdgpu_ttm_tt_populate() 693 ttm->state = tt_unbound; amdgpu_ttm_tt_populate() 697 adev = amdgpu_get_adev(ttm->bdev); amdgpu_ttm_tt_populate() 701 return ttm_dma_populate(>t->ttm, adev->dev); amdgpu_ttm_tt_populate() 705 r = ttm_pool_populate(ttm); amdgpu_ttm_tt_populate() 710 for (i = 0; i < ttm->num_pages; i++) { amdgpu_ttm_tt_populate() 711 gtt->ttm.dma_address[i] = pci_map_page(adev->pdev, ttm->pages[i], amdgpu_ttm_tt_populate() 714 if (pci_dma_mapping_error(adev->pdev, gtt->ttm.dma_address[i])) { amdgpu_ttm_tt_populate() 716 pci_unmap_page(adev->pdev, gtt->ttm.dma_address[i], amdgpu_ttm_tt_populate() 718 gtt->ttm.dma_address[i] = 0; amdgpu_ttm_tt_populate() 720 ttm_pool_unpopulate(ttm); amdgpu_ttm_tt_populate() 727 static void amdgpu_ttm_tt_unpopulate(struct ttm_tt *ttm) amdgpu_ttm_tt_unpopulate() argument 730 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_unpopulate() 732 bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG); amdgpu_ttm_tt_unpopulate() 735 kfree(ttm->sg); amdgpu_ttm_tt_unpopulate() 736 ttm->page_flags &= ~TTM_PAGE_FLAG_SG; amdgpu_ttm_tt_unpopulate() 743 adev = amdgpu_get_adev(ttm->bdev); amdgpu_ttm_tt_unpopulate() 747 ttm_dma_unpopulate(>t->ttm, adev->dev); amdgpu_ttm_tt_unpopulate() 752 for (i = 0; i < ttm->num_pages; i++) { amdgpu_ttm_tt_unpopulate() 753 if (gtt->ttm.dma_address[i]) { amdgpu_ttm_tt_unpopulate() 754 pci_unmap_page(adev->pdev, gtt->ttm.dma_address[i], amdgpu_ttm_tt_unpopulate() 759 ttm_pool_unpopulate(ttm); amdgpu_ttm_tt_unpopulate() 762 int amdgpu_ttm_tt_set_userptr(struct ttm_tt *ttm, uint64_t addr, amdgpu_ttm_tt_set_userptr() argument 765 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_set_userptr() 776 bool amdgpu_ttm_tt_has_userptr(struct ttm_tt *ttm) amdgpu_ttm_tt_has_userptr() argument 778 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_has_userptr() 786 bool amdgpu_ttm_tt_affect_userptr(struct ttm_tt *ttm, unsigned long start, amdgpu_ttm_tt_affect_userptr() argument 789 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_affect_userptr() 795 if (gtt->ttm.ttm.state != tt_bound || !gtt->userptr) amdgpu_ttm_tt_affect_userptr() 798 size = (unsigned long)gtt->ttm.ttm.num_pages * PAGE_SIZE; amdgpu_ttm_tt_affect_userptr() 805 bool amdgpu_ttm_tt_is_readonly(struct ttm_tt *ttm) amdgpu_ttm_tt_is_readonly() argument 807 struct amdgpu_ttm_tt *gtt = (void *)ttm; amdgpu_ttm_tt_is_readonly() 815 uint32_t amdgpu_ttm_tt_pte_flags(struct amdgpu_device *adev, struct ttm_tt *ttm, amdgpu_ttm_tt_pte_flags() argument 826 if (ttm->caching_state == tt_cached) amdgpu_ttm_tt_pte_flags() 835 if (!amdgpu_ttm_tt_is_readonly(ttm)) amdgpu_ttm_tt_pte_flags() 977 DRM_INFO("amdgpu: ttm finalized\n"); amdgpu_ttm_fini()
|
H A D | amdgpu_prime.c | 37 return drm_prime_pages_to_sg(bo->tbo.ttm->pages, npages); amdgpu_gem_prime_get_sg_table() 124 if (amdgpu_ttm_tt_has_userptr(bo->tbo.ttm)) amdgpu_gem_prime_export()
|
H A D | amdgpu_object.h | 36 * @mem_type: ttm memory type 38 * Returns corresponding domain of the ttm mem_type
|
H A D | amdgpu.h | 39 #include <ttm/ttm_bo_api.h> 40 #include <ttm/ttm_bo_driver.h> 41 #include <ttm/ttm_placement.h> 42 #include <ttm/ttm_module.h> 43 #include <ttm/ttm_execbuf_util.h> 2313 int amdgpu_ttm_tt_set_userptr(struct ttm_tt *ttm, uint64_t addr, 2315 bool amdgpu_ttm_tt_has_userptr(struct ttm_tt *ttm); 2316 bool amdgpu_ttm_tt_affect_userptr(struct ttm_tt *ttm, unsigned long start, 2318 bool amdgpu_ttm_tt_is_readonly(struct ttm_tt *ttm); 2319 uint32_t amdgpu_ttm_tt_pte_flags(struct amdgpu_device *adev, struct ttm_tt *ttm,
|
H A D | amdgpu_gem.c | 255 r = amdgpu_ttm_tt_set_userptr(bo->tbo.ttm, args->addr, args->flags); amdgpu_gem_userptr_ioctl() 311 if (amdgpu_ttm_tt_has_userptr(robj->tbo.ttm) || amdgpu_mode_dumb_mmap() 642 if (amdgpu_ttm_tt_has_userptr(robj->tbo.ttm)) { amdgpu_gem_op_ioctl()
|
H A D | amdgpu_object.c | 370 if (amdgpu_ttm_tt_has_userptr(bo->tbo.ttm)) amdgpu_bo_pin_restricted() 488 /* this should unref the ttm bo */ amdgpu_bo_force_delete()
|
H A D | amdgpu_bo_list.c | 114 if (amdgpu_ttm_tt_has_userptr(entry->robj->tbo.ttm)) { amdgpu_bo_list_set()
|
H A D | amdgpu_mn.c | 145 if (!amdgpu_ttm_tt_affect_userptr(bo->tbo.ttm, start, amdgpu_mn_invalidate_range_start()
|
H A D | amdgpu_vm.c | 814 * @mem: ttm mem 839 flags = amdgpu_ttm_tt_pte_flags(adev, bo_va->bo->tbo.ttm, mem); amdgpu_vm_bo_update()
|
H A D | amdgpu_cs.c | 145 if (amdgpu_ttm_tt_has_userptr(p->uf.bo->tbo.ttm)) { amdgpu_cs_user_fence_chunk()
|
H A D | cik_sdma.c | 1341 * Used by the amdgpu ttm implementation to move pages if
|
H A D | sdma_v2_4.c | 1346 * Used by the amdgpu ttm implementation to move pages if
|
H A D | sdma_v3_0.c | 1507 * Used by the amdgpu ttm implementation to move pages if
|
/linux-4.4.14/drivers/gpu/drm/radeon/ |
H A D | radeon_ttm.c | 32 #include <ttm/ttm_bo_api.h> 33 #include <ttm/ttm_bo_driver.h> 34 #include <ttm/ttm_placement.h> 35 #include <ttm/ttm_module.h> 36 #include <ttm/ttm_page_alloc.h> 238 if (radeon_ttm_tt_has_userptr(bo->ttm)) radeon_verify_access() 337 r = ttm_tt_set_placement_caching(bo->ttm, tmp_mem.placement); radeon_move_vram_ram() 342 r = ttm_tt_bind(bo->ttm, &tmp_mem); radeon_move_vram_ram() 406 if (old_mem->mem_type == TTM_PL_SYSTEM && bo->ttm == NULL) { radeon_bo_move() 520 struct ttm_dma_tt ttm; member in struct:radeon_ttm_tt 530 static int radeon_ttm_tt_pin_userptr(struct ttm_tt *ttm) radeon_ttm_tt_pin_userptr() argument 532 struct radeon_device *rdev = radeon_get_rdev(ttm->bdev); radeon_ttm_tt_pin_userptr() 533 struct radeon_ttm_tt *gtt = (void *)ttm; radeon_ttm_tt_pin_userptr() 547 unsigned long end = gtt->userptr + ttm->num_pages * PAGE_SIZE; radeon_ttm_tt_pin_userptr() 555 unsigned num_pages = ttm->num_pages - pinned; radeon_ttm_tt_pin_userptr() 557 struct page **pages = ttm->pages + pinned; radeon_ttm_tt_pin_userptr() 566 } while (pinned < ttm->num_pages); radeon_ttm_tt_pin_userptr() 568 r = sg_alloc_table_from_pages(ttm->sg, ttm->pages, ttm->num_pages, 0, radeon_ttm_tt_pin_userptr() 569 ttm->num_pages << PAGE_SHIFT, radeon_ttm_tt_pin_userptr() 575 nents = dma_map_sg(rdev->dev, ttm->sg->sgl, ttm->sg->nents, direction); radeon_ttm_tt_pin_userptr() 576 if (nents != ttm->sg->nents) radeon_ttm_tt_pin_userptr() 579 drm_prime_sg_to_page_addr_arrays(ttm->sg, ttm->pages, radeon_ttm_tt_pin_userptr() 580 gtt->ttm.dma_address, ttm->num_pages); radeon_ttm_tt_pin_userptr() 585 kfree(ttm->sg); radeon_ttm_tt_pin_userptr() 588 release_pages(ttm->pages, pinned, 0); radeon_ttm_tt_pin_userptr() 592 static void radeon_ttm_tt_unpin_userptr(struct ttm_tt *ttm) radeon_ttm_tt_unpin_userptr() argument 594 struct radeon_device *rdev = radeon_get_rdev(ttm->bdev); radeon_ttm_tt_unpin_userptr() 595 struct radeon_ttm_tt *gtt = (void *)ttm; radeon_ttm_tt_unpin_userptr() 603 if (!ttm->sg->sgl) radeon_ttm_tt_unpin_userptr() 607 dma_unmap_sg(rdev->dev, ttm->sg->sgl, ttm->sg->nents, direction); radeon_ttm_tt_unpin_userptr() 609 for_each_sg_page(ttm->sg->sgl, &sg_iter, ttm->sg->nents, 0) { radeon_ttm_tt_unpin_userptr() 618 sg_free_table(ttm->sg); radeon_ttm_tt_unpin_userptr() 621 static int radeon_ttm_backend_bind(struct ttm_tt *ttm, radeon_ttm_backend_bind() argument 624 struct radeon_ttm_tt *gtt = (void*)ttm; radeon_ttm_backend_bind() 630 radeon_ttm_tt_pin_userptr(ttm); radeon_ttm_backend_bind() 635 if (!ttm->num_pages) { radeon_ttm_backend_bind() 637 ttm->num_pages, bo_mem, ttm); radeon_ttm_backend_bind() 639 if (ttm->caching_state == tt_cached) radeon_ttm_backend_bind() 641 r = radeon_gart_bind(gtt->rdev, gtt->offset, ttm->num_pages, radeon_ttm_backend_bind() 642 ttm->pages, gtt->ttm.dma_address, flags); radeon_ttm_backend_bind() 645 ttm->num_pages, (unsigned)gtt->offset); radeon_ttm_backend_bind() 651 static int radeon_ttm_backend_unbind(struct ttm_tt *ttm) radeon_ttm_backend_unbind() argument 653 struct radeon_ttm_tt *gtt = (void *)ttm; radeon_ttm_backend_unbind() 655 radeon_gart_unbind(gtt->rdev, gtt->offset, ttm->num_pages); radeon_ttm_backend_unbind() 658 radeon_ttm_tt_unpin_userptr(ttm); radeon_ttm_backend_unbind() 663 static void radeon_ttm_backend_destroy(struct ttm_tt *ttm) radeon_ttm_backend_destroy() argument 665 struct radeon_ttm_tt *gtt = (void *)ttm; radeon_ttm_backend_destroy() 667 ttm_dma_tt_fini(>t->ttm); radeon_ttm_backend_destroy() 696 gtt->ttm.ttm.func = &radeon_backend_func; radeon_ttm_tt_create() 698 if (ttm_dma_tt_init(>t->ttm, bdev, size, page_flags, dummy_read_page)) { radeon_ttm_tt_create() 702 return >t->ttm.ttm; radeon_ttm_tt_create() 705 static struct radeon_ttm_tt *radeon_ttm_tt_to_gtt(struct ttm_tt *ttm) radeon_ttm_tt_to_gtt() argument 707 if (!ttm || ttm->func != &radeon_backend_func) radeon_ttm_tt_to_gtt() 709 return (struct radeon_ttm_tt *)ttm; radeon_ttm_tt_to_gtt() 712 static int radeon_ttm_tt_populate(struct ttm_tt *ttm) radeon_ttm_tt_populate() argument 714 struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(ttm); radeon_ttm_tt_populate() 718 bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG); radeon_ttm_tt_populate() 720 if (ttm->state != tt_unpopulated) radeon_ttm_tt_populate() 724 ttm->sg = kzalloc(sizeof(struct sg_table), GFP_KERNEL); radeon_ttm_tt_populate() 725 if (!ttm->sg) radeon_ttm_tt_populate() 728 ttm->page_flags |= TTM_PAGE_FLAG_SG; radeon_ttm_tt_populate() 729 ttm->state = tt_unbound; radeon_ttm_tt_populate() 733 if (slave && ttm->sg) { radeon_ttm_tt_populate() 734 drm_prime_sg_to_page_addr_arrays(ttm->sg, ttm->pages, radeon_ttm_tt_populate() 735 gtt->ttm.dma_address, ttm->num_pages); radeon_ttm_tt_populate() 736 ttm->state = tt_unbound; radeon_ttm_tt_populate() 740 rdev = radeon_get_rdev(ttm->bdev); radeon_ttm_tt_populate() 743 return ttm_agp_tt_populate(ttm); radeon_ttm_tt_populate() 749 return ttm_dma_populate(>t->ttm, rdev->dev); radeon_ttm_tt_populate() 753 r = ttm_pool_populate(ttm); radeon_ttm_tt_populate() 758 for (i = 0; i < ttm->num_pages; i++) { radeon_ttm_tt_populate() 759 gtt->ttm.dma_address[i] = pci_map_page(rdev->pdev, ttm->pages[i], radeon_ttm_tt_populate() 762 if (pci_dma_mapping_error(rdev->pdev, gtt->ttm.dma_address[i])) { radeon_ttm_tt_populate() 764 pci_unmap_page(rdev->pdev, gtt->ttm.dma_address[i], radeon_ttm_tt_populate() 766 gtt->ttm.dma_address[i] = 0; radeon_ttm_tt_populate() 768 ttm_pool_unpopulate(ttm); radeon_ttm_tt_populate() 775 static void radeon_ttm_tt_unpopulate(struct ttm_tt *ttm) radeon_ttm_tt_unpopulate() argument 778 struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(ttm); radeon_ttm_tt_unpopulate() 780 bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG); radeon_ttm_tt_unpopulate() 783 kfree(ttm->sg); radeon_ttm_tt_unpopulate() 784 ttm->page_flags &= ~TTM_PAGE_FLAG_SG; radeon_ttm_tt_unpopulate() 791 rdev = radeon_get_rdev(ttm->bdev); radeon_ttm_tt_unpopulate() 794 ttm_agp_tt_unpopulate(ttm); radeon_ttm_tt_unpopulate() 801 ttm_dma_unpopulate(>t->ttm, rdev->dev); radeon_ttm_tt_unpopulate() 806 for (i = 0; i < ttm->num_pages; i++) { radeon_ttm_tt_unpopulate() 807 if (gtt->ttm.dma_address[i]) { radeon_ttm_tt_unpopulate() 808 pci_unmap_page(rdev->pdev, gtt->ttm.dma_address[i], radeon_ttm_tt_unpopulate() 813 ttm_pool_unpopulate(ttm); radeon_ttm_tt_unpopulate() 816 int radeon_ttm_tt_set_userptr(struct ttm_tt *ttm, uint64_t addr, radeon_ttm_tt_set_userptr() argument 819 struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(ttm); radeon_ttm_tt_set_userptr() 830 bool radeon_ttm_tt_has_userptr(struct ttm_tt *ttm) radeon_ttm_tt_has_userptr() argument 832 struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(ttm); radeon_ttm_tt_has_userptr() 840 bool radeon_ttm_tt_is_readonly(struct ttm_tt *ttm) radeon_ttm_tt_is_readonly() argument 842 struct radeon_ttm_tt *gtt = radeon_ttm_tt_to_gtt(ttm); radeon_ttm_tt_is_readonly() 949 DRM_INFO("radeon: ttm finalized\n"); radeon_ttm_fini()
|
H A D | radeon_prime.c | 37 return drm_prime_pages_to_sg(bo->tbo.ttm->pages, npages); radeon_gem_prime_get_sg_table() 124 if (radeon_ttm_tt_has_userptr(bo->tbo.ttm)) radeon_gem_prime_export()
|
H A D | rv770_dma.c | 39 * Used by the radeon ttm implementation to move pages if
|
H A D | radeon_mn.c | 145 if (!bo->tbo.ttm || bo->tbo.ttm->state != tt_bound) radeon_mn_invalidate_range_start()
|
H A D | radeon_object.h | 36 * @mem_type: ttm memory type 38 * Returns corresponding domain of the ttm mem_type
|
H A D | evergreen_dma.c | 104 * Used by the radeon ttm implementation to move pages if
|
H A D | radeon_gem.c | 323 r = radeon_ttm_tt_set_userptr(bo->tbo.ttm, args->addr, args->flags); radeon_gem_userptr_ioctl() 412 if (radeon_ttm_tt_has_userptr(robj->tbo.ttm)) { radeon_mode_dumb_mmap() 712 if (radeon_ttm_tt_has_userptr(robj->tbo.ttm)) radeon_gem_op_ioctl()
|
H A D | si_dma.c | 228 * Used by the radeon ttm implementation to move pages if
|
H A D | radeon.h | 71 #include <ttm/ttm_bo_api.h> 72 #include <ttm/ttm_bo_driver.h> 73 #include <ttm/ttm_placement.h> 74 #include <ttm/ttm_module.h> 75 #include <ttm/ttm_execbuf_util.h> 2826 extern int radeon_ttm_tt_set_userptr(struct ttm_tt *ttm, uint64_t addr, 2828 extern bool radeon_ttm_tt_has_userptr(struct ttm_tt *ttm); 2829 extern bool radeon_ttm_tt_is_readonly(struct ttm_tt *ttm);
|
H A D | radeon_object.c | 334 if (radeon_ttm_tt_has_userptr(bo->tbo.ttm)) radeon_bo_pin_restricted() 442 /* this should unref the ttm bo */ radeon_bo_force_delete()
|
H A D | r600_dma.c | 436 * Used by the radeon ttm implementation to move pages if
|
H A D | radeon_vm.c | 903 * @mem: ttm mem 943 if (bo_va->bo && radeon_ttm_tt_is_readonly(bo_va->bo->tbo.ttm)) radeon_vm_bo_update()
|
H A D | radeon_cs.c | 154 if (radeon_ttm_tt_has_userptr(p->relocs[i].robj->tbo.ttm)) { radeon_cs_parser_relocs()
|
H A D | cik_sdma.c | 576 * Used by the radeon ttm implementation to move pages if
|
H A D | r600.c | 2958 * Used by the radeon ttm implementation to move pages if
|
H A D | cik.c | 4064 * Used by the radeon ttm implementation to move pages if
|
/linux-4.4.14/drivers/gpu/drm/qxl/ |
H A D | qxl_ttm.c | 26 #include <ttm/ttm_bo_api.h> 27 #include <ttm/ttm_bo_driver.h> 28 #include <ttm/ttm_placement.h> 29 #include <ttm/ttm_page_alloc.h> 30 #include <ttm/ttm_module.h> 258 struct ttm_dma_tt ttm; member in struct:qxl_ttm_tt 263 static int qxl_ttm_backend_bind(struct ttm_tt *ttm, qxl_ttm_backend_bind() argument 266 struct qxl_ttm_tt *gtt = (void *)ttm; qxl_ttm_backend_bind() 269 if (!ttm->num_pages) { qxl_ttm_backend_bind() 271 ttm->num_pages, bo_mem, ttm); qxl_ttm_backend_bind() 277 static int qxl_ttm_backend_unbind(struct ttm_tt *ttm) qxl_ttm_backend_unbind() argument 283 static void qxl_ttm_backend_destroy(struct ttm_tt *ttm) qxl_ttm_backend_destroy() argument 285 struct qxl_ttm_tt *gtt = (void *)ttm; qxl_ttm_backend_destroy() 287 ttm_dma_tt_fini(>t->ttm); qxl_ttm_backend_destroy() 297 static int qxl_ttm_tt_populate(struct ttm_tt *ttm) qxl_ttm_tt_populate() argument 301 if (ttm->state != tt_unpopulated) qxl_ttm_tt_populate() 304 r = ttm_pool_populate(ttm); qxl_ttm_tt_populate() 311 static void qxl_ttm_tt_unpopulate(struct ttm_tt *ttm) qxl_ttm_tt_unpopulate() argument 313 ttm_pool_unpopulate(ttm); qxl_ttm_tt_unpopulate() 327 gtt->ttm.ttm.func = &qxl_backend_func; qxl_ttm_tt_create() 329 if (ttm_dma_tt_init(>t->ttm, bdev, size, page_flags, qxl_ttm_tt_create() 334 return >t->ttm.ttm; qxl_ttm_tt_create() 353 if (old_mem->mem_type == TTM_PL_SYSTEM && bo->ttm == NULL) { qxl_bo_move() 441 DRM_INFO("qxl: ttm finalized\n"); qxl_ttm_fini()
|
H A D | qxl_drv.h | 41 #include <ttm/ttm_bo_api.h> 42 #include <ttm/ttm_bo_driver.h> 43 #include <ttm/ttm_placement.h> 44 #include <ttm/ttm_module.h> 49 #include <ttm/ttm_execbuf_util.h> 437 /* qxl ttm */
|
H A D | qxl_object.c | 281 /* this should unref the ttm bo */ qxl_bo_force_delete()
|
/linux-4.4.14/drivers/gpu/drm/virtio/ |
H A D | virtgpu_ttm.c | 28 #include <ttm/ttm_bo_api.h> 29 #include <ttm/ttm_bo_driver.h> 30 #include <ttm/ttm_placement.h> 31 #include <ttm/ttm_page_alloc.h> 32 #include <ttm/ttm_module.h> 289 struct ttm_dma_tt ttm; member in struct:virtio_gpu_ttm_tt 294 static int virtio_gpu_ttm_backend_bind(struct ttm_tt *ttm, virtio_gpu_ttm_backend_bind() argument 297 struct virtio_gpu_ttm_tt *gtt = (void *)ttm; virtio_gpu_ttm_backend_bind() 300 if (!ttm->num_pages) virtio_gpu_ttm_backend_bind() 302 ttm->num_pages, bo_mem, ttm); virtio_gpu_ttm_backend_bind() 308 static int virtio_gpu_ttm_backend_unbind(struct ttm_tt *ttm) virtio_gpu_ttm_backend_unbind() argument 314 static void virtio_gpu_ttm_backend_destroy(struct ttm_tt *ttm) virtio_gpu_ttm_backend_destroy() argument 316 struct virtio_gpu_ttm_tt *gtt = (void *)ttm; virtio_gpu_ttm_backend_destroy() 318 ttm_dma_tt_fini(>t->ttm); virtio_gpu_ttm_backend_destroy() 328 static int virtio_gpu_ttm_tt_populate(struct ttm_tt *ttm) virtio_gpu_ttm_tt_populate() argument 330 if (ttm->state != tt_unpopulated) virtio_gpu_ttm_tt_populate() 333 return ttm_pool_populate(ttm); virtio_gpu_ttm_tt_populate() 336 static void virtio_gpu_ttm_tt_unpopulate(struct ttm_tt *ttm) virtio_gpu_ttm_tt_unpopulate() argument 338 ttm_pool_unpopulate(ttm); virtio_gpu_ttm_tt_unpopulate() 353 gtt->ttm.ttm.func = &virtio_gpu_backend_func; virtio_gpu_ttm_tt_create() 355 if (ttm_dma_tt_init(>t->ttm, bdev, size, page_flags, virtio_gpu_ttm_tt_create() 360 return >t->ttm.ttm; virtio_gpu_ttm_tt_create() 467 DRM_INFO("virtio_gpu: ttm finalized\n"); virtio_gpu_ttm_fini()
|
H A D | virtgpu_object.c | 123 struct page **pages = bo->tbo.ttm->pages; virtio_gpu_object_get_sg_table() 130 if (bo->tbo.ttm->state == tt_unpopulated) virtio_gpu_object_get_sg_table() 131 bo->tbo.ttm->bdev->driver->ttm_tt_populate(bo->tbo.ttm); virtio_gpu_object_get_sg_table()
|
H A D | virtgpu_drv.h | 37 #include <ttm/ttm_bo_api.h> 38 #include <ttm/ttm_bo_driver.h> 39 #include <ttm/ttm_placement.h> 40 #include <ttm/ttm_module.h>
|
H A D | virtgpu_kms.c | 189 DRM_ERROR("failed to init ttm %d\n", ret); virtio_gpu_driver_load()
|
H A D | virtgpu_ioctl.c | 31 #include "ttm/ttm_execbuf_util.h"
|
/linux-4.4.14/drivers/gpu/drm/ast/ |
H A D | ast_ttm.c | 30 #include <ttm/ttm_page_alloc.h> 35 return container_of(bd, struct ast_private, ttm.bdev); ast_bdev() 55 global_ref = &ast->ttm.mem_global_ref; ast_ttm_global_init() 67 ast->ttm.bo_global_ref.mem_glob = ast_ttm_global_init() 68 ast->ttm.mem_global_ref.object; ast_ttm_global_init() 69 global_ref = &ast->ttm.bo_global_ref.ref; ast_ttm_global_init() 77 drm_global_item_unref(&ast->ttm.mem_global_ref); ast_ttm_global_init() 86 if (ast->ttm.mem_global_ref.release == NULL) ast_ttm_global_release() 89 drm_global_item_unref(&ast->ttm.bo_global_ref.ref); ast_ttm_global_release() 90 drm_global_item_unref(&ast->ttm.mem_global_ref); ast_ttm_global_release() 91 ast->ttm.mem_global_ref.release = NULL; ast_ttm_global_release() 228 static int ast_ttm_tt_populate(struct ttm_tt *ttm) ast_ttm_tt_populate() argument 230 return ttm_pool_populate(ttm); ast_ttm_tt_populate() 233 static void ast_ttm_tt_unpopulate(struct ttm_tt *ttm) ast_ttm_tt_unpopulate() argument 235 ttm_pool_unpopulate(ttm); ast_ttm_tt_unpopulate() 254 struct ttm_bo_device *bdev = &ast->ttm.bdev; ast_mm_init() 260 ret = ttm_bo_device_init(&ast->ttm.bdev, ast_mm_init() 261 ast->ttm.bo_global_ref.ref.object, ast_mm_init() 274 DRM_ERROR("Failed ttm VRAM init: %d\n", ret); ast_mm_init() 286 ttm_bo_device_release(&ast->ttm.bdev); ast_mm_fini() 332 astbo->bo.bdev = &ast->ttm.bdev; ast_bo_create() 336 acc_size = ttm_bo_dma_acc_size(&ast->ttm.bdev, size, ast_bo_create() 339 ret = ttm_bo_init(&ast->ttm.bdev, &astbo->bo, size, ast_bo_create() 434 return ttm_bo_mmap(filp, vma, &ast->ttm.bdev); ast_mmap()
|
H A D | ast_drv.h | 33 #include <drm/ttm/ttm_bo_api.h> 34 #include <drm/ttm/ttm_bo_driver.h> 35 #include <drm/ttm/ttm_placement.h> 36 #include <drm/ttm/ttm_memory.h> 37 #include <drm/ttm/ttm_module.h> 107 } ttm; member in struct:ast_private
|
/linux-4.4.14/drivers/gpu/drm/cirrus/ |
H A D | cirrus_ttm.c | 30 #include <ttm/ttm_page_alloc.h> 35 return container_of(bd, struct cirrus_device, ttm.bdev); cirrus_bdev() 55 global_ref = &cirrus->ttm.mem_global_ref; cirrus_ttm_global_init() 67 cirrus->ttm.bo_global_ref.mem_glob = cirrus_ttm_global_init() 68 cirrus->ttm.mem_global_ref.object; cirrus_ttm_global_init() 69 global_ref = &cirrus->ttm.bo_global_ref.ref; cirrus_ttm_global_init() 77 drm_global_item_unref(&cirrus->ttm.mem_global_ref); cirrus_ttm_global_init() 86 if (cirrus->ttm.mem_global_ref.release == NULL) cirrus_ttm_global_release() 89 drm_global_item_unref(&cirrus->ttm.bo_global_ref.ref); cirrus_ttm_global_release() 90 drm_global_item_unref(&cirrus->ttm.mem_global_ref); cirrus_ttm_global_release() 91 cirrus->ttm.mem_global_ref.release = NULL; cirrus_ttm_global_release() 228 static int cirrus_ttm_tt_populate(struct ttm_tt *ttm) cirrus_ttm_tt_populate() argument 230 return ttm_pool_populate(ttm); cirrus_ttm_tt_populate() 233 static void cirrus_ttm_tt_unpopulate(struct ttm_tt *ttm) cirrus_ttm_tt_unpopulate() argument 235 ttm_pool_unpopulate(ttm); cirrus_ttm_tt_unpopulate() 254 struct ttm_bo_device *bdev = &cirrus->ttm.bdev; cirrus_mm_init() 260 ret = ttm_bo_device_init(&cirrus->ttm.bdev, cirrus_mm_init() 261 cirrus->ttm.bo_global_ref.ref.object, cirrus_mm_init() 274 DRM_ERROR("Failed ttm VRAM init: %d\n", ret); cirrus_mm_init() 290 ttm_bo_device_release(&cirrus->ttm.bdev); cirrus_mm_fini() 336 cirrusbo->bo.bdev = &cirrus->ttm.bdev; cirrus_bo_create() 340 acc_size = ttm_bo_dma_acc_size(&cirrus->ttm.bdev, size, cirrus_bo_create() 343 ret = ttm_bo_init(&cirrus->ttm.bdev, &cirrusbo->bo, size, cirrus_bo_create() 418 return ttm_bo_mmap(filp, vma, &cirrus->ttm.bdev); cirrus_mmap()
|
H A D | cirrus_drv.h | 18 #include <drm/ttm/ttm_bo_api.h> 19 #include <drm/ttm/ttm_bo_driver.h> 20 #include <drm/ttm/ttm_placement.h> 21 #include <drm/ttm/ttm_memory.h> 22 #include <drm/ttm/ttm_module.h> 148 } ttm; member in struct:cirrus_device
|
/linux-4.4.14/drivers/gpu/drm/mgag200/ |
H A D | mgag200_ttm.c | 30 #include <ttm/ttm_page_alloc.h> 35 return container_of(bd, struct mga_device, ttm.bdev); mgag200_bdev() 55 global_ref = &ast->ttm.mem_global_ref; mgag200_ttm_global_init() 67 ast->ttm.bo_global_ref.mem_glob = mgag200_ttm_global_init() 68 ast->ttm.mem_global_ref.object; mgag200_ttm_global_init() 69 global_ref = &ast->ttm.bo_global_ref.ref; mgag200_ttm_global_init() 77 drm_global_item_unref(&ast->ttm.mem_global_ref); mgag200_ttm_global_init() 86 if (ast->ttm.mem_global_ref.release == NULL) mgag200_ttm_global_release() 89 drm_global_item_unref(&ast->ttm.bo_global_ref.ref); mgag200_ttm_global_release() 90 drm_global_item_unref(&ast->ttm.mem_global_ref); mgag200_ttm_global_release() 91 ast->ttm.mem_global_ref.release = NULL; mgag200_ttm_global_release() 228 static int mgag200_ttm_tt_populate(struct ttm_tt *ttm) mgag200_ttm_tt_populate() argument 230 return ttm_pool_populate(ttm); mgag200_ttm_tt_populate() 233 static void mgag200_ttm_tt_unpopulate(struct ttm_tt *ttm) mgag200_ttm_tt_unpopulate() argument 235 ttm_pool_unpopulate(ttm); mgag200_ttm_tt_unpopulate() 254 struct ttm_bo_device *bdev = &mdev->ttm.bdev; mgag200_mm_init() 260 ret = ttm_bo_device_init(&mdev->ttm.bdev, mgag200_mm_init() 261 mdev->ttm.bo_global_ref.ref.object, mgag200_mm_init() 273 DRM_ERROR("Failed ttm VRAM init: %d\n", ret); mgag200_mm_init() 285 ttm_bo_device_release(&mdev->ttm.bdev); mgag200_mm_fini() 332 mgabo->bo.bdev = &mdev->ttm.bdev; mgag200_bo_create() 336 acc_size = ttm_bo_dma_acc_size(&mdev->ttm.bdev, size, mgag200_bo_create() 339 ret = ttm_bo_init(&mdev->ttm.bdev, &mgabo->bo, size, mgag200_bo_create() 431 return ttm_bo_mmap(filp, vma, &mdev->ttm.bdev); mgag200_mmap()
|
H A D | mgag200_drv.h | 19 #include <drm/ttm/ttm_bo_api.h> 20 #include <drm/ttm/ttm_bo_driver.h> 21 #include <drm/ttm/ttm_placement.h> 22 #include <drm/ttm/ttm_memory.h> 23 #include <drm/ttm/ttm_module.h> 216 } ttm; member in struct:mga_device
|
/linux-4.4.14/include/drm/ttm/ |
H A D | ttm_page_alloc.h | 29 #include <drm/ttm/ttm_bo_driver.h> 30 #include <drm/ttm/ttm_memory.h> 46 * @ttm: The struct ttm_tt to contain the backing pages. 48 * Add backing pages to all of @ttm 50 extern int ttm_pool_populate(struct ttm_tt *ttm); 55 * @ttm: The struct ttm_tt which to free backing pages. 57 * Free all pages of @ttm 59 extern void ttm_pool_unpopulate(struct ttm_tt *ttm);
|
H A D | ttm_bo_driver.h | 33 #include <ttm/ttm_bo_api.h> 34 #include <ttm/ttm_memory.h> 35 #include <ttm/ttm_module.h> 36 #include <ttm/ttm_placement.h> 49 * @ttm: Pointer to a struct ttm_tt. 57 int (*bind) (struct ttm_tt *ttm, struct ttm_mem_reg *bo_mem); 62 * @ttm: Pointer to a struct ttm_tt. 67 int (*unbind) (struct ttm_tt *ttm); 72 * @ttm: Pointer to a struct ttm_tt. 77 void (*destroy) (struct ttm_tt *ttm); 104 * @be: Pointer to the ttm backend. 135 * @ttm: Base ttm_tt struct. 145 struct ttm_tt ttm; member in struct:ttm_dma_tt 339 * @ttm: The struct ttm_tt to contain the backing pages. 345 int (*ttm_tt_populate)(struct ttm_tt *ttm); 350 * @ttm: The struct ttm_tt to contain the backing pages. 354 void (*ttm_tt_unpopulate)(struct ttm_tt *ttm); 568 * @ttm: The struct ttm_tt. 579 extern int ttm_tt_init(struct ttm_tt *ttm, struct ttm_bo_device *bdev, 589 * @ttm: the ttm_tt structure. 593 extern void ttm_tt_fini(struct ttm_tt *ttm); 599 * @ttm: The struct ttm_tt containing backing pages. 602 * Bind the pages of @ttm to an aperture location identified by @bo_mem 604 extern int ttm_tt_bind(struct ttm_tt *ttm, struct ttm_mem_reg *bo_mem); 609 * @ttm: The struct ttm_tt. 613 extern void ttm_tt_destroy(struct ttm_tt *ttm); 618 * @ttm: The struct ttm_tt. 622 extern void ttm_tt_unbind(struct ttm_tt *ttm); 627 * @ttm: The struct ttm_tt. 631 extern int ttm_tt_swapin(struct ttm_tt *ttm); 636 * @ttm A struct ttm_tt the backing pages of which will change caching policy. 640 * the pages backing @ttm. If changing from cached to uncached or 646 extern int ttm_tt_set_placement_caching(struct ttm_tt *ttm, uint32_t placement); 647 extern int ttm_tt_swapout(struct ttm_tt *ttm, 651 * ttm_tt_unpopulate - free pages from a ttm 653 * @ttm: Pointer to the ttm_tt structure 655 * Calls the driver method to free all pages from a ttm 657 extern void ttm_tt_unpopulate(struct ttm_tt *ttm); 1055 int ttm_agp_tt_populate(struct ttm_tt *ttm); 1056 void ttm_agp_tt_unpopulate(struct ttm_tt *ttm);
|
H A D | ttm_object.h | 33 * ttm objects. Implements reference counting, minimal security checks 45 #include <ttm/ttm_memory.h> 72 * One entry per ttm object type. 300 * data structures needed for ttm base and ref objects.
|
H A D | ttm_lock.h | 52 #include <ttm/ttm_object.h> 59 * @base: ttm base object used solely to release the lock if the client
|
H A D | ttm_execbuf_util.h | 34 #include <ttm/ttm_bo_api.h>
|
H A D | ttm_bo_api.h | 170 * @ttm: TTM structure holding system pages. 220 struct ttm_tt *ttm; member in struct:ttm_buffer_object 463 * @resv: Pointer to a reservation_object, or NULL to let ttm allocate one. 646 * ttm_fbdev_mmap - mmap fbdev memory backed by a ttm buffer object. 660 * ttm_bo_mmap - mmap out of the ttm device address space. 685 * This function implements read / write into ttm buffer objects, and is
|
/linux-4.4.14/drivers/gpu/drm/bochs/ |
H A D | bochs_mm.c | 16 return container_of(bd, struct bochs_device, ttm.bdev); bochs_bdev() 34 global_ref = &bochs->ttm.mem_global_ref; bochs_ttm_global_init() 46 bochs->ttm.bo_global_ref.mem_glob = bochs_ttm_global_init() 47 bochs->ttm.mem_global_ref.object; bochs_ttm_global_init() 48 global_ref = &bochs->ttm.bo_global_ref.ref; bochs_ttm_global_init() 56 drm_global_item_unref(&bochs->ttm.mem_global_ref); bochs_ttm_global_init() 65 if (bochs->ttm.mem_global_ref.release == NULL) bochs_ttm_global_release() 68 drm_global_item_unref(&bochs->ttm.bo_global_ref.ref); bochs_ttm_global_release() 69 drm_global_item_unref(&bochs->ttm.mem_global_ref); bochs_ttm_global_release() 70 bochs->ttm.mem_global_ref.release = NULL; bochs_ttm_global_release() 219 struct ttm_bo_device *bdev = &bochs->ttm.bdev; bochs_mm_init() 226 ret = ttm_bo_device_init(&bochs->ttm.bdev, bochs_mm_init() 227 bochs->ttm.bo_global_ref.ref.object, bochs_mm_init() 240 DRM_ERROR("Failed ttm VRAM init: %d\n", ret); bochs_mm_init() 244 bochs->ttm.initialized = true; bochs_mm_init() 250 if (!bochs->ttm.initialized) bochs_mm_fini() 253 ttm_bo_device_release(&bochs->ttm.bdev); bochs_mm_fini() 255 bochs->ttm.initialized = false; bochs_mm_fini() 346 return ttm_bo_mmap(filp, vma, &bochs->ttm.bdev); bochs_mmap() 369 bochsbo->bo.bdev = &bochs->ttm.bdev; bochs_bo_create() 374 acc_size = ttm_bo_dma_acc_size(&bochs->ttm.bdev, size, bochs_bo_create() 377 ret = ttm_bo_init(&bochs->ttm.bdev, &bochsbo->bo, size, bochs_bo_create()
|
H A D | bochs.h | 12 #include <ttm/ttm_bo_driver.h> 13 #include <ttm/ttm_page_alloc.h> 80 /* ttm */ 86 } ttm; member in struct:bochs_device
|
/linux-4.4.14/drivers/gpu/drm/vmwgfx/ |
H A D | vmwgfx_buffer.c | 29 #include <drm/ttm/ttm_bo_driver.h> 30 #include <drm/ttm/ttm_placement.h> 31 #include <drm/ttm/ttm_page_alloc.h> 407 vsgt->pages = vmw_tt->dma_ttm.ttm.pages; vmw_ttm_map_dma() 408 vsgt->num_pages = vmw_tt->dma_ttm.ttm.num_pages; vmw_ttm_map_dma() 517 container_of(bo->ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_bo_map_dma() 534 container_of(bo->ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_bo_unmap_dma() 554 container_of(bo->ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_bo_sg_table() 560 static int vmw_ttm_bind(struct ttm_tt *ttm, struct ttm_mem_reg *bo_mem) vmw_ttm_bind() argument 563 container_of(ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_ttm_bind() 576 ttm->num_pages, vmw_be->gmr_id); vmw_ttm_bind() 580 vmw_mob_create(ttm->num_pages); vmw_ttm_bind() 586 &vmw_be->vsgt, ttm->num_pages, vmw_ttm_bind() 594 static int vmw_ttm_unbind(struct ttm_tt *ttm) vmw_ttm_unbind() argument 597 container_of(ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_ttm_unbind() 617 static void vmw_ttm_destroy(struct ttm_tt *ttm) vmw_ttm_destroy() argument 620 container_of(ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_ttm_destroy() 626 ttm_tt_fini(ttm); vmw_ttm_destroy() 635 static int vmw_ttm_populate(struct ttm_tt *ttm) vmw_ttm_populate() argument 638 container_of(ttm, struct vmw_ttm_tt, dma_ttm.ttm); vmw_ttm_populate() 643 if (ttm->state != tt_unpopulated) vmw_ttm_populate() 648 ttm_round_pot(ttm->num_pages * sizeof(dma_addr_t)); vmw_ttm_populate() 657 ret = ttm_pool_populate(ttm); vmw_ttm_populate() 662 static void vmw_ttm_unpopulate(struct ttm_tt *ttm) vmw_ttm_unpopulate() argument 664 struct vmw_ttm_tt *vmw_tt = container_of(ttm, struct vmw_ttm_tt, vmw_ttm_unpopulate() 665 dma_ttm.ttm); vmw_ttm_unpopulate() 678 ttm_round_pot(ttm->num_pages * sizeof(dma_addr_t)); vmw_ttm_unpopulate() 683 ttm_pool_unpopulate(ttm); vmw_ttm_unpopulate() 703 vmw_be->dma_ttm.ttm.func = &vmw_ttm_func; vmw_ttm_tt_create() 711 ret = ttm_tt_init(&vmw_be->dma_ttm.ttm, bdev, size, page_flags, vmw_ttm_tt_create() 716 return &vmw_be->dma_ttm.ttm; vmw_ttm_tt_create()
|
H A D | vmwgfx_gmrid_manager.c | 32 #include <drm/ttm/ttm_module.h> 33 #include <drm/ttm/ttm_bo_driver.h> 34 #include <drm/ttm/ttm_placement.h>
|
H A D | vmwgfx_prime.c | 35 #include <drm/ttm/ttm_object.h>
|
H A D | vmwgfx_gmr.c | 30 #include <drm/ttm/ttm_bo_driver.h>
|
H A D | vmwgfx_drv.h | 36 #include <drm/ttm/ttm_bo_driver.h> 37 #include <drm/ttm/ttm_object.h> 38 #include <drm/ttm/ttm_lock.h> 39 #include <drm/ttm/ttm_execbuf_util.h> 40 #include <drm/ttm/ttm_module.h>
|
H A D | vmwgfx_dmabuf.c | 28 #include <drm/ttm/ttm_placement.h>
|
H A D | vmwgfx_drv.c | 33 #include <drm/ttm/ttm_placement.h> 34 #include <drm/ttm/ttm_bo_driver.h> 35 #include <drm/ttm/ttm_object.h> 36 #include <drm/ttm/ttm_module.h>
|
H A D | vmwgfx_mob.c | 267 ret = vmw_bo_driver.ttm_tt_populate(batch->otable_bo->ttm); vmw_otable_batch_setup() 446 ret = vmw_bo_driver.ttm_tt_populate(mob->pt_bo->ttm); vmw_mob_pt_populate()
|
H A D | vmwgfx_overlay.c | 32 #include <drm/ttm/ttm_placement.h>
|
H A D | vmwgfx_context.c | 31 #include "ttm/ttm_placement.h"
|
H A D | vmwgfx_cotable.c | 35 #include <ttm/ttm_placement.h>
|
H A D | vmwgfx_fb.c | 35 #include <drm/ttm/ttm_placement.h>
|
H A D | vmwgfx_fifo.c | 30 #include <drm/ttm/ttm_placement.h>
|
H A D | vmwgfx_resource.c | 30 #include <drm/ttm/ttm_object.h> 31 #include <drm/ttm/ttm_placement.h>
|
H A D | vmwgfx_cmdbuf.c | 29 #include "ttm/ttm_bo_api.h"
|
H A D | vmwgfx_shader.c | 31 #include "ttm/ttm_placement.h"
|
H A D | vmwgfx_surface.c | 32 #include <ttm/ttm_placement.h>
|
H A D | vmwgfx_execbuf.c | 30 #include <drm/ttm/ttm_bo_api.h> 31 #include <drm/ttm/ttm_placement.h>
|
/linux-4.4.14/arch/powerpc/perf/ |
H A D | ppc970-pmu.c | 264 unsigned int ttm, grp; p970_compute_mmcr() local 321 ttm = unitmap[i]; p970_compute_mmcr() 322 ++ttmuse[(ttm >> 2) & 1]; p970_compute_mmcr() 323 mmcr1 |= (unsigned long)(ttm & ~4) << MMCR1_TTM1SEL_SH; p970_compute_mmcr() 335 ttm = (unitmap[unit] >> 2) & 1; p970_compute_mmcr() 337 ttm = 2; p970_compute_mmcr() 339 ttm = 3; p970_compute_mmcr() 343 mmcr1 |= (unsigned long)ttm p970_compute_mmcr()
|
H A D | power4-pmu.c | 363 unsigned int ttm, grp; p4_compute_mmcr() local 461 ttm = unit - 1; /* 2->1, 3->2 */ p4_compute_mmcr() 463 ttm = unit >> 2; p4_compute_mmcr() 464 mmcr1 |= (unsigned long)ttm p4_compute_mmcr()
|
H A D | power5+-pmu.c | 460 unsigned int ttm; power5p_compute_mmcr() local 545 ttm = unit >> 2; power5p_compute_mmcr() 546 mmcr1 |= (unsigned long)ttm power5p_compute_mmcr()
|
H A D | power5-pmu.c | 391 unsigned int ttm, grp; power5_compute_mmcr() local 485 ttm = unit >> 2; power5_compute_mmcr() 486 mmcr1 |= (unsigned long)ttm power5_compute_mmcr()
|
/linux-4.4.14/drivers/gpu/drm/ |
H A D | Makefile | 38 obj-$(CONFIG_DRM_TTM) += ttm/
|
/linux-4.4.14/include/linux/ |
H A D | reservation.h | 2 * Header file for reservations for dma-buf and ttm
|
/linux-4.4.14/arch/x86/platform/uv/ |
H A D | tlb_uv.c | 518 cycles_t ttm; uv1_wait_completion() local 535 ttm = get_cycles(); uv1_wait_completion() 543 if (cycles_2_us(ttm - bcp->send_message) < timeout_us) { uv1_wait_completion() 614 cycles_t ttm; uv2_3_wait_completion() local 634 ttm = get_cycles(); uv2_3_wait_completion() 645 if (cycles_2_us(ttm - bcp->send_message) < timeout_us) { uv2_3_wait_completion() 660 ttm = get_cycles(); uv2_3_wait_completion() 661 if ((ttm - bcp->send_message) > bcp->timeout_interval) uv2_3_wait_completion()
|
/linux-4.4.14/drivers/net/ethernet/dec/tulip/ |
H A D | eeprom.c | 117 0x00, 0x06 /* ttm bit map */ tulip_build_fake_mediatable()
|
H A D | de4x5.c | 516 u_int ttm; /* Transmit Threshold Mode for each media */ member in struct:mii_phy 4629 lp->phy[lp->active].ttm = get_unaligned_le16(p); type1_infoblock() 4710 lp->phy[lp->active].ttm = get_unaligned_le16(p); p += 2; type3_infoblock()
|
/linux-4.4.14/mm/ |
H A D | shmem.c | 3442 * for itself; although drivers/gpu/drm i915 and ttm rely upon this support.
|