| /linux/drivers/media/common/videobuf2/ |
| H A D | videobuf2-dma-contig.c | 53 static unsigned long vb2_dc_get_contiguous_size(struct sg_table *sgt) in vb2_dc_get_contiguous_size() argument 56 dma_addr_t expected = sg_dma_address(sgt->sgl); in vb2_dc_get_contiguous_size() 60 for_each_sgtable_dma_sg(sgt, s, i) { in vb2_dc_get_contiguous_size() 126 struct sg_table *sgt = buf->dma_sgt; in vb2_dc_prepare() local 140 dma_sync_sgtable_for_device(buf->dev, sgt, buf->dma_dir); in vb2_dc_prepare() 146 struct sg_table *sgt = buf->dma_sgt; in vb2_dc_finish() local 160 dma_sync_sgtable_for_cpu(buf->dev, sgt, buf->dma_dir); in vb2_dc_finish() 314 struct sg_table sgt; member 324 struct sg_table *sgt; in vb2_dc_dmabuf_ops_attach() local 332 sgt = &attach->sgt; in vb2_dc_dmabuf_ops_attach() [all …]
|
| H A D | videobuf2-vmalloc.c | 208 struct sg_table sgt; member 218 struct sg_table *sgt; in vb2_vmalloc_dmabuf_ops_attach() local 228 sgt = &attach->sgt; in vb2_vmalloc_dmabuf_ops_attach() 229 ret = sg_alloc_table(sgt, num_pages, GFP_KERNEL); in vb2_vmalloc_dmabuf_ops_attach() 234 for_each_sgtable_sg(sgt, sg, i) { in vb2_vmalloc_dmabuf_ops_attach() 238 sg_free_table(sgt); in vb2_vmalloc_dmabuf_ops_attach() 255 struct sg_table *sgt; in vb2_vmalloc_dmabuf_ops_detach() local 260 sgt = &attach->sgt; in vb2_vmalloc_dmabuf_ops_detach() 264 dma_unmap_sgtable(db_attach->dev, sgt, attach->dma_dir, 0); in vb2_vmalloc_dmabuf_ops_detach() 265 sg_free_table(sgt); in vb2_vmalloc_dmabuf_ops_detach() [all …]
|
| /linux/drivers/gpu/drm/tegra/ |
| H A D | gem.c | 47 static inline unsigned int sgt_dma_count_chunks(struct sg_table *sgt) in sgt_dma_count_chunks() argument 49 return sg_dma_count_chunks(sgt->sgl, sgt->nents); in sgt_dma_count_chunks() 88 map->sgt = dma_buf_map_attachment_unlocked(map->attach, direction); in tegra_bo_pin() 89 if (IS_ERR(map->sgt)) { in tegra_bo_pin() 91 err = PTR_ERR(map->sgt); in tegra_bo_pin() 92 map->sgt = NULL; in tegra_bo_pin() 96 err = sgt_dma_count_chunks(map->sgt); in tegra_bo_pin() 106 map->sgt = kzalloc_obj(*map->sgt); in tegra_bo_pin() 107 if (!map->sgt) { in tegra_bo_pin() 117 err = sg_alloc_table_from_pages(map->sgt, obj->pages, obj->num_pages, 0, gem->size, in tegra_bo_pin() [all …]
|
| /linux/drivers/gpu/drm/tests/ |
| H A D | drm_gem_shmem_test.c | 75 struct sg_table *sgt; in drm_gem_shmem_test_obj_create_private() local 83 sgt = kzalloc_obj(*sgt); in drm_gem_shmem_test_obj_create_private() 84 KUNIT_ASSERT_NOT_NULL(test, sgt); in drm_gem_shmem_test_obj_create_private() 86 ret = kunit_add_action_or_reset(test, kfree_wrapper, sgt); in drm_gem_shmem_test_obj_create_private() 89 ret = sg_alloc_table(sgt, 1, GFP_KERNEL); in drm_gem_shmem_test_obj_create_private() 92 ret = kunit_add_action_or_reset(test, sg_free_table_wrapper, sgt); in drm_gem_shmem_test_obj_create_private() 95 sg_init_one(sgt->sgl, buf, TEST_SIZE); in drm_gem_shmem_test_obj_create_private() 105 ret = dma_map_sgtable(drm_dev->dev, sgt, DMA_BIDIRECTIONAL, 0); in drm_gem_shmem_test_obj_create_private() 112 gem_obj = drm_gem_shmem_prime_import_sg_table(drm_dev, &attach_mock, sgt); in drm_gem_shmem_test_obj_create_private() 119 kunit_remove_action(test, sg_free_table_wrapper, sgt); in drm_gem_shmem_test_obj_create_private() [all …]
|
| /linux/drivers/accel/ivpu/ |
| H A D | ivpu_gem_userptr.c | 26 struct sg_table *sgt = attachment->dmabuf->priv; in ivpu_gem_userptr_dmabuf_map() local 29 ret = dma_map_sgtable(attachment->dev, sgt, direction, DMA_ATTR_SKIP_CPU_SYNC); in ivpu_gem_userptr_dmabuf_map() 33 return sgt; in ivpu_gem_userptr_dmabuf_map() 37 struct sg_table *sgt, in ivpu_gem_userptr_dmabuf_unmap() argument 40 dma_unmap_sgtable(attachment->dev, sgt, direction, DMA_ATTR_SKIP_CPU_SYNC); in ivpu_gem_userptr_dmabuf_unmap() 45 struct sg_table *sgt = dma_buf->priv; in ivpu_gem_userptr_dmabuf_release() local 49 for_each_sgtable_page(sgt, &page_iter, 0) { in ivpu_gem_userptr_dmabuf_release() 54 sg_free_table(sgt); in ivpu_gem_userptr_dmabuf_release() 55 kfree(sgt); in ivpu_gem_userptr_dmabuf_release() 70 struct sg_table *sgt; in ivpu_create_userptr_dmabuf() local [all …]
|
| /linux/drivers/gpu/drm/armada/ |
| H A D | armada_gem.c | 69 if (dobj->sgt) in armada_gem_free_object() 71 dobj->sgt, DMA_TO_DEVICE); in armada_gem_free_object() 393 struct sg_table *sgt; in armada_gem_prime_map_dma_buf() local 396 sgt = kmalloc_obj(*sgt); in armada_gem_prime_map_dma_buf() 397 if (!sgt) in armada_gem_prime_map_dma_buf() 405 if (sg_alloc_table(sgt, count, GFP_KERNEL)) in armada_gem_prime_map_dma_buf() 410 for_each_sgtable_sg(sgt, sg, i) { in armada_gem_prime_map_dma_buf() 420 if (dma_map_sgtable(attach->dev, sgt, dir, 0)) in armada_gem_prime_map_dma_buf() 424 if (sg_alloc_table(sgt, 1, GFP_KERNEL)) in armada_gem_prime_map_dma_buf() 427 sg_set_page(sgt->sgl, dobj->page, dobj->obj.size, 0); in armada_gem_prime_map_dma_buf() [all …]
|
| /linux/drivers/gpu/drm/virtio/ |
| H A D | virtgpu_vram.c | 78 struct sg_table *sgt; in virtio_gpu_vram_map_dma_buf() local 82 sgt = kzalloc_obj(*sgt); in virtio_gpu_vram_map_dma_buf() 83 if (!sgt) in virtio_gpu_vram_map_dma_buf() 93 return sgt; in virtio_gpu_vram_map_dma_buf() 96 ret = sg_alloc_table(sgt, 1, GFP_KERNEL); in virtio_gpu_vram_map_dma_buf() 107 sg_set_page(sgt->sgl, NULL, vram->vram_node.size, 0); in virtio_gpu_vram_map_dma_buf() 108 sg_dma_address(sgt->sgl) = addr; in virtio_gpu_vram_map_dma_buf() 109 sg_dma_len(sgt->sgl) = vram->vram_node.size; in virtio_gpu_vram_map_dma_buf() 111 return sgt; in virtio_gpu_vram_map_dma_buf() 113 sg_free_table(sgt); in virtio_gpu_vram_map_dma_buf() [all …]
|
| /linux/net/ceph/ |
| H A D | crypto.c | 206 static int setup_sgtable(struct sg_table *sgt, struct scatterlist *prealloc_sg, in setup_sgtable() argument 218 memset(sgt, 0, sizeof(*sgt)); in setup_sgtable() 228 ret = sg_alloc_table(sgt, chunk_cnt, GFP_NOFS); in setup_sgtable() 234 sgt->sgl = prealloc_sg; in setup_sgtable() 235 sgt->nents = sgt->orig_nents = 1; in setup_sgtable() 238 for_each_sg(sgt->sgl, sg, sgt->orig_nents, i) { in setup_sgtable() 258 static void teardown_sgtable(struct sg_table *sgt) in teardown_sgtable() argument 260 if (sgt->orig_nents > 1) in teardown_sgtable() 261 sg_free_table(sgt); in teardown_sgtable() 268 struct sg_table sgt; in ceph_aes_crypt() local [all …]
|
| /linux/fs/smb/smbdirect/ |
| H A D | mr.c | 51 mr->sgt.sgl = kzalloc_objs(struct scatterlist, sp->max_frmr_depth); in smbdirect_connection_create_mr_list() 52 if (!mr->sgt.sgl) { in smbdirect_connection_create_mr_list() 89 if (mr->sgt.nents) in smbdirect_mr_io_disable_locked() 90 ib_dma_unmap_sg(sc->ib.dev, mr->sgt.sgl, mr->sgt.nents, mr->dir); in smbdirect_mr_io_disable_locked() 91 kfree(mr->sgt.sgl); in smbdirect_mr_io_disable_locked() 94 mr->sgt.sgl = NULL; in smbdirect_mr_io_disable_locked() 95 mr->sgt.nents = 0; in smbdirect_mr_io_disable_locked() 242 struct sg_table *sgt, in smbdirect_iter_to_sgt() argument 247 memset(sgt->sgl, 0, max_sg * sizeof(struct scatterlist)); in smbdirect_iter_to_sgt() 249 ret = extract_iter_to_sg(iter, iov_iter_count(iter), sgt, max_sg, 0); in smbdirect_iter_to_sgt() [all …]
|
| /linux/drivers/xen/ |
| H A D | gntdev-dmabuf.c | 46 struct sg_table *sgt; member 65 struct sg_table *sgt; member 198 struct sg_table *sgt; in dmabuf_pages_to_sgt() local 201 sgt = kmalloc_obj(*sgt); in dmabuf_pages_to_sgt() 202 if (!sgt) { in dmabuf_pages_to_sgt() 207 ret = sg_alloc_table_from_pages(sgt, pages, nr_pages, 0, in dmabuf_pages_to_sgt() 213 return sgt; in dmabuf_pages_to_sgt() 216 kfree(sgt); in dmabuf_pages_to_sgt() 240 struct sg_table *sgt = gntdev_dmabuf_attach->sgt; in dmabuf_exp_ops_detach() local 242 if (sgt) { in dmabuf_exp_ops_detach() [all …]
|
| /linux/drivers/hwtracing/intel_th/ |
| H A D | msu-sink.c | 51 static int msu_sink_alloc_window(void *data, struct sg_table **sgt, size_t size) in msu_sink_alloc_window() argument 64 ret = sg_alloc_table(*sgt, nents, GFP_KERNEL); in msu_sink_alloc_window() 68 priv->sgts[priv->nr_sgts++] = *sgt; in msu_sink_alloc_window() 70 for_each_sg((*sgt)->sgl, sg_ptr, nents, i) { in msu_sink_alloc_window() 84 static void msu_sink_free_window(void *data, struct sg_table *sgt) in msu_sink_free_window() argument 90 for_each_sg(sgt->sgl, sg_ptr, sgt->nents, i) { in msu_sink_free_window() 95 sg_free_table(sgt); in msu_sink_free_window() 99 static int msu_sink_ready(void *data, struct sg_table *sgt, size_t bytes) in msu_sink_ready() argument 103 intel_th_msc_window_unlock(priv->dev, sgt); in msu_sink_ready()
|
| /linux/rust/kernel/ |
| H A D | scatterlist.rs | 181 /// - `sgt` is a valid pointer to a `struct sg_table` for the entire lifetime of the 183 /// - `sgt` is always DMA mapped. 185 sgt: NonNull<bindings::sg_table>, 199 /// - `sgt` must be a valid pointer to a `struct sg_table` for the entire lifetime of the 201 /// - The caller must guarantee that `sgt` remains DMA mapped for the entire lifetime of 204 sgt: NonNull<bindings::sg_table>, in new() 211 // - `sgt` is a valid pointer to a `struct sg_table`. in new() 213 bindings::dma_map_sgtable(dev.as_raw(), sgt.as_ptr(), dir.into(), 0) in new() 216 // INVARIANT: By the safety requirements of this function it is guaranteed that `sgt` is in new() 219 sgt, in new() 184 sgt: NonNull<bindings::sg_table>, global() field 272 let sgt = Opaque::zeroed(); new() localVariable 321 sgt: RawSGTable, global() field 369 let sgt = unsafe { &raw mut (*this.as_ptr()).sgt }.cast(); new() localVariable 372 let sgt = unsafe { NonNull::new_unchecked(sgt) }; new() localVariable [all...] |
| /linux/drivers/media/platform/nvidia/tegra-vde/ |
| H A D | dmabuf-cache.c | 27 struct sg_table *sgt; member 41 dma_buf_unmap_attachment_unlocked(entry->a, entry->sgt, entry->dma_dir); in tegra_vde_release_entry() 72 struct sg_table *sgt; in tegra_vde_dmabuf_cache_map() local 93 *addrp = sg_dma_address(entry->sgt->sgl); in tegra_vde_dmabuf_cache_map() 105 sgt = dma_buf_map_attachment_unlocked(attachment, dma_dir); in tegra_vde_dmabuf_cache_map() 106 if (IS_ERR(sgt)) { in tegra_vde_dmabuf_cache_map() 108 err = PTR_ERR(sgt); in tegra_vde_dmabuf_cache_map() 112 if (!vde->domain && sgt->nents > 1) { in tegra_vde_dmabuf_cache_map() 125 err = tegra_vde_iommu_map(vde, sgt, &iova, dmabuf->size); in tegra_vde_dmabuf_cache_map() 131 *addrp = sg_dma_address(sgt->sgl); in tegra_vde_dmabuf_cache_map() [all …]
|
| /linux/drivers/gpu/drm/i915/gem/ |
| H A D | i915_gem_dmabuf.c | 31 struct sg_table *sgt; in i915_gem_map_dma_buf() local 39 sgt = kmalloc_obj(*sgt); in i915_gem_map_dma_buf() 40 if (!sgt) { in i915_gem_map_dma_buf() 45 ret = sg_alloc_table(sgt, obj->mm.pages->orig_nents, GFP_KERNEL); in i915_gem_map_dma_buf() 49 dst = sgt->sgl; in i915_gem_map_dma_buf() 55 ret = dma_map_sgtable(attach->dev, sgt, dir, DMA_ATTR_SKIP_CPU_SYNC); in i915_gem_map_dma_buf() 59 return sgt; in i915_gem_map_dma_buf() 62 sg_free_table(sgt); in i915_gem_map_dma_buf() 64 kfree(sgt); in i915_gem_map_dma_buf() 239 struct sg_table *sgt; in i915_gem_object_get_pages_dmabuf() local [all …]
|
| /linux/kernel/dma/ |
| H A D | mapping.c | 333 int dma_map_sgtable(struct device *dev, struct sg_table *sgt, in dma_map_sgtable() argument 338 nents = __dma_map_sg_attrs(dev, sgt->sgl, sgt->orig_nents, dir, attrs); in dma_map_sgtable() 341 sgt->nents = nents; in dma_map_sgtable() 521 int dma_get_sgtable_attrs(struct device *dev, struct sg_table *sgt, in dma_get_sgtable_attrs() argument 528 return dma_direct_get_sgtable(dev, sgt, cpu_addr, dma_addr, in dma_get_sgtable_attrs() 531 return iommu_dma_get_sgtable(dev, sgt, cpu_addr, dma_addr, in dma_get_sgtable_attrs() 535 return ops->get_sgtable(dev, sgt, cpu_addr, dma_addr, size, attrs); in dma_get_sgtable_attrs() 783 struct sg_table *sgt; in alloc_single_sgt() local 786 sgt = kmalloc_obj(*sgt, gfp); in alloc_single_sgt() 787 if (!sgt) in alloc_single_sgt() [all …]
|
| /linux/drivers/dma-buf/ |
| H A D | dma-buf-mapping.c | 64 struct sg_table sgt; member 136 ret = sg_alloc_table(&dma->sgt, nents, GFP_KERNEL | __GFP_ZERO); in dma_buf_phys_vec_to_sgt() 140 sgl = dma->sgt.sgl; in dma_buf_phys_vec_to_sgt() 183 dma->sgt.orig_nents = 0; in dma_buf_phys_vec_to_sgt() 191 return &dma->sgt; in dma_buf_phys_vec_to_sgt() 200 for_each_sgtable_dma_sg(&dma->sgt, sgl, i) in dma_buf_phys_vec_to_sgt() 204 sg_free_table(&dma->sgt); in dma_buf_phys_vec_to_sgt() 222 void dma_buf_free_sgt(struct dma_buf_attachment *attach, struct sg_table *sgt, in dma_buf_free_sgt() argument 225 struct dma_buf_dma *dma = container_of(sgt, struct dma_buf_dma, sgt); in dma_buf_free_sgt() 238 for_each_sgtable_dma_sg(sgt, sgl, i) in dma_buf_free_sgt() [all …]
|
| /linux/drivers/gpu/drm/panthor/ |
| H A D | panthor_gem.c | 243 struct sg_table *sgt = drm_gem_map_dma_buf(attach, dir); in panthor_gem_prime_map_dma_buf() local 245 if (!IS_ERR(sgt)) in panthor_gem_prime_map_dma_buf() 246 attach->priv = sgt; in panthor_gem_prime_map_dma_buf() 248 return sgt; in panthor_gem_prime_map_dma_buf() 253 struct sg_table *sgt, in panthor_gem_prime_unmap_dma_buf() argument 257 drm_gem_unmap_dma_buf(attach, sgt, dir); in panthor_gem_prime_unmap_dma_buf() 270 if (shmem->sgt) in panthor_gem_prime_begin_cpu_access() 271 dma_sync_sgtable_for_cpu(dev->dev, shmem->sgt, dir); in panthor_gem_prime_begin_cpu_access() 277 struct sg_table *sgt = attach->priv; in panthor_gem_prime_begin_cpu_access() local 279 if (sgt) in panthor_gem_prime_begin_cpu_access() [all …]
|
| /linux/drivers/gpu/drm/lima/ |
| H A D | lima_gem.c | 29 struct sg_table sgt; in lima_heap_alloc() local 67 ret = sg_alloc_table_from_pages(&sgt, pages, i, 0, in lima_heap_alloc() 72 if (bo->base.sgt) { in lima_heap_alloc() 73 dma_unmap_sgtable(dev, bo->base.sgt, DMA_BIDIRECTIONAL, 0); in lima_heap_alloc() 74 sg_free_table(bo->base.sgt); in lima_heap_alloc() 76 bo->base.sgt = kmalloc_obj(*bo->base.sgt); in lima_heap_alloc() 77 if (!bo->base.sgt) { in lima_heap_alloc() 83 ret = dma_map_sgtable(dev, &sgt, DMA_BIDIRECTIONAL, 0); in lima_heap_alloc() 87 *bo->base.sgt = sgt; in lima_heap_alloc() 99 dma_unmap_sgtable(dev, &sgt, DMA_BIDIRECTIONAL, 0); in lima_heap_alloc() [all …]
|
| /linux/drivers/gpu/drm/rockchip/ |
| H A D | rockchip_drm_gem.c | 43 ret = iommu_map_sgtable(private->domain, rk_obj->dma_addr, rk_obj->sgt, in rockchip_gem_iommu_map() 92 rk_obj->sgt = drm_prime_pages_to_sg(rk_obj->base.dev, in rockchip_gem_get_pages() 94 if (IS_ERR(rk_obj->sgt)) { in rockchip_gem_get_pages() 95 ret = PTR_ERR(rk_obj->sgt); in rockchip_gem_get_pages() 106 for_each_sgtable_sg(rk_obj->sgt, s, i) in rockchip_gem_get_pages() 109 dma_sync_sgtable_for_device(drm->dev, rk_obj->sgt, DMA_TO_DEVICE); in rockchip_gem_get_pages() 120 sg_free_table(rk_obj->sgt); in rockchip_gem_put_pages() 121 kfree(rk_obj->sgt); in rockchip_gem_put_pages() 341 dma_unmap_sgtable(drm->dev, rk_obj->sgt, in rockchip_gem_free_object() 344 drm_prime_gem_destroy(obj, rk_obj->sgt); in rockchip_gem_free_object() [all …]
|
| /linux/drivers/gpu/drm/xe/ |
| H A D | xe_dma_buf.c | 104 struct sg_table *sgt; in xe_dma_buf_map() local 121 sgt = drm_prime_pages_to_sg(obj->dev, in xe_dma_buf_map() 124 if (IS_ERR(sgt)) in xe_dma_buf_map() 125 return sgt; in xe_dma_buf_map() 127 if (dma_map_sgtable(attach->dev, sgt, dir, in xe_dma_buf_map() 137 dir, &sgt); in xe_dma_buf_map() 145 return sgt; in xe_dma_buf_map() 148 sg_free_table(sgt); in xe_dma_buf_map() 149 kfree(sgt); in xe_dma_buf_map() 154 struct sg_table *sgt, in xe_dma_buf_unmap() argument [all …]
|
| /linux/drivers/gpu/drm/ |
| H A D | drm_gem_shmem_helper.c | 173 drm_prime_gem_destroy(obj, shmem->sgt); in drm_gem_shmem_release() 179 if (shmem->sgt) { in drm_gem_shmem_release() 180 dma_unmap_sgtable(obj->dev->dev, shmem->sgt, in drm_gem_shmem_release() 182 sg_free_table(shmem->sgt); in drm_gem_shmem_release() 183 kfree(shmem->sgt); in drm_gem_shmem_release() 504 dma_unmap_sgtable(dev->dev, shmem->sgt, DMA_BIDIRECTIONAL, 0); in drm_gem_shmem_purge_locked() 505 sg_free_table(shmem->sgt); in drm_gem_shmem_purge_locked() 506 kfree(shmem->sgt); in drm_gem_shmem_purge_locked() 507 shmem->sgt = NULL; in drm_gem_shmem_purge_locked() 802 struct sg_table *sgt; in drm_gem_shmem_get_pages_sgt_locked() local [all …]
|
| /linux/drivers/fpga/ |
| H A D | fpga-mgr.c | 96 struct sg_table *sgt) in fpga_mgr_write_sg() argument 99 return mgr->mops->write_sg(mgr, sgt); in fpga_mgr_write_sg() 182 struct sg_table *sgt) in fpga_mgr_parse_header_sg_first() argument 189 sg_miter_start(&miter, sgt->sgl, sgt->nents, SG_MITER_FROM_SG); in fpga_mgr_parse_header_sg_first() 214 struct sg_table *sgt, size_t *ret_size) in fpga_mgr_parse_header_sg() argument 236 len = sg_pcopy_to_buffer(sgt->sgl, sgt->nents, in fpga_mgr_parse_header_sg() 295 struct sg_table *sgt) in fpga_mgr_prepare_sg() argument 310 ret = fpga_mgr_parse_header_sg_first(mgr, info, sgt); in fpga_mgr_prepare_sg() 313 sg_miter_start(&miter, sgt->sgl, sgt->nents, SG_MITER_FROM_SG); in fpga_mgr_prepare_sg() 333 buf = fpga_mgr_parse_header_sg(mgr, info, sgt, &len); in fpga_mgr_prepare_sg() [all …]
|
| /linux/drivers/gpu/drm/etnaviv/ |
| H A D | etnaviv_gem.c | 24 struct sg_table *sgt = etnaviv_obj->sgt; in etnaviv_gem_scatter_map() local 31 dma_map_sgtable(dev->dev, sgt, DMA_BIDIRECTIONAL, 0); in etnaviv_gem_scatter_map() 37 struct sg_table *sgt = etnaviv_obj->sgt; in etnaviv_gem_scatterlist_unmap() local 55 dma_unmap_sgtable(dev->dev, sgt, DMA_BIDIRECTIONAL, 0); in etnaviv_gem_scatterlist_unmap() 76 if (etnaviv_obj->sgt) { in put_pages() 78 sg_free_table(etnaviv_obj->sgt); in put_pages() 79 kfree(etnaviv_obj->sgt); in put_pages() 80 etnaviv_obj->sgt = NULL; in put_pages() 102 if (!etnaviv_obj->sgt) { in etnaviv_gem_get_pages() 105 struct sg_table *sgt; in etnaviv_gem_get_pages() local [all …]
|
| /linux/drivers/infiniband/core/ |
| H A D | umem_dmabuf.c | 17 struct sg_table *sgt; in ib_umem_dmabuf_map_pages() local 29 if (umem_dmabuf->sgt) in ib_umem_dmabuf_map_pages() 32 sgt = dma_buf_map_attachment(umem_dmabuf->attach, in ib_umem_dmabuf_map_pages() 34 if (IS_ERR(sgt)) in ib_umem_dmabuf_map_pages() 35 return PTR_ERR(sgt); in ib_umem_dmabuf_map_pages() 42 for_each_sgtable_dma_sg(sgt, sg, i) { in ib_umem_dmabuf_map_pages() 65 umem_dmabuf->umem.sgt_append.sgt.sgl = umem_dmabuf->first_sg; in ib_umem_dmabuf_map_pages() 66 umem_dmabuf->umem.sgt_append.sgt.nents = nmap; in ib_umem_dmabuf_map_pages() 67 umem_dmabuf->sgt = sgt; in ib_umem_dmabuf_map_pages() 90 if (!umem_dmabuf->sgt) in ib_umem_dmabuf_unmap_pages() [all …]
|
| /linux/drivers/gpu/drm/vmwgfx/ |
| H A D | vmwgfx_ttm_buffer.c | 119 __sg_page_iter_start(&viter->iter.base, vsgt->sgt->sgl, in vmw_piter_start() 120 vsgt->sgt->orig_nents, p_offset); in vmw_piter_start() 139 dma_unmap_sgtable(dev, &vmw_tt->sgt, DMA_BIDIRECTIONAL, 0); in vmw_ttm_unmap_from_dma() 140 vmw_tt->sgt.nents = vmw_tt->sgt.orig_nents; in vmw_ttm_unmap_from_dma() 160 return dma_map_sgtable(dev, &vmw_tt->sgt, DMA_BIDIRECTIONAL, 0); in vmw_ttm_map_for_dma() 186 vsgt->sgt = NULL; in vmw_ttm_map_dma() 192 vsgt->sgt = vmw_tt->dma_ttm.sg; in vmw_ttm_map_dma() 194 vsgt->sgt = &vmw_tt->sgt; in vmw_ttm_map_dma() 195 ret = sg_alloc_table_from_pages_segment(&vmw_tt->sgt, in vmw_ttm_map_dma() 218 sg_free_table(vsgt->sgt); in vmw_ttm_map_dma() [all …]
|