| /linux/drivers/gpu/drm/ |
| H A D | drm_auth.c | 64 static bool drm_is_current_master_locked(struct drm_file *fpriv) in drm_is_current_master_locked() argument 66 lockdep_assert_once(lockdep_is_held(&fpriv->master_lookup_lock) || in drm_is_current_master_locked() 67 lockdep_is_held(&fpriv->minor->dev->master_mutex)); in drm_is_current_master_locked() 69 return fpriv->is_master && drm_lease_owner(fpriv->master) == fpriv->minor->dev->master; in drm_is_current_master_locked() 82 bool drm_is_current_master(struct drm_file *fpriv) in drm_is_current_master() argument 86 spin_lock(&fpriv->master_lookup_lock); in drm_is_current_master() 87 ret = drm_is_current_master_locked(fpriv); in drm_is_current_master() 88 spin_unlock(&fpriv->master_lookup_lock); in drm_is_current_master() 152 static void drm_set_master(struct drm_device *dev, struct drm_file *fpriv, in drm_set_master() argument 155 dev->master = drm_master_get(fpriv->master); in drm_set_master() [all …]
|
| /linux/drivers/gpu/drm/tegra/ |
| H A D | uapi.c | 79 struct tegra_drm_file *fpriv = file->driver_priv; in tegra_drm_ioctl_channel_open() local 138 err = xa_alloc(&fpriv->contexts, &args->context, context, XA_LIMIT(1, U32_MAX), in tegra_drm_ioctl_channel_open() 167 struct tegra_drm_file *fpriv = file->driver_priv; in tegra_drm_ioctl_channel_close() local 171 mutex_lock(&fpriv->lock); in tegra_drm_ioctl_channel_close() 173 context = xa_load(&fpriv->contexts, args->context); in tegra_drm_ioctl_channel_close() 175 mutex_unlock(&fpriv->lock); in tegra_drm_ioctl_channel_close() 179 xa_erase(&fpriv->contexts, args->context); in tegra_drm_ioctl_channel_close() 181 mutex_unlock(&fpriv->lock); in tegra_drm_ioctl_channel_close() 190 struct tegra_drm_file *fpriv = file->driver_priv; in tegra_drm_ioctl_channel_map() local 201 mutex_lock(&fpriv->lock); in tegra_drm_ioctl_channel_map() [all …]
|
| H A D | drm.c | 105 struct tegra_drm_file *fpriv; in tegra_drm_open() local 107 fpriv = kzalloc_obj(*fpriv); in tegra_drm_open() 108 if (!fpriv) in tegra_drm_open() 111 idr_init_base(&fpriv->legacy_contexts, 1); in tegra_drm_open() 112 xa_init_flags(&fpriv->contexts, XA_FLAGS_ALLOC1); in tegra_drm_open() 113 xa_init(&fpriv->syncpoints); in tegra_drm_open() 114 mutex_init(&fpriv->lock); in tegra_drm_open() 115 filp->driver_priv = fpriv; in tegra_drm_open() 429 static int tegra_client_open(struct tegra_drm_file *fpriv, in tegra_client_open() argument 445 err = idr_alloc(&fpriv->legacy_contexts, context, 1, 0, GFP_KERNEL); in tegra_client_open() [all …]
|
| H A D | submit.c | 512 struct tegra_drm_file *fpriv = file->driver_priv; in tegra_drm_ioctl_channel_submit() local 522 mutex_lock(&fpriv->lock); in tegra_drm_ioctl_channel_submit() 524 context = xa_load(&fpriv->contexts, args->context); in tegra_drm_ioctl_channel_submit() 526 mutex_unlock(&fpriv->lock); in tegra_drm_ioctl_channel_submit() 576 job = submit_create_job(context, bo, args, job_data, &fpriv->syncpoints); in tegra_drm_ioctl_channel_submit() 682 mutex_unlock(&fpriv->lock); in tegra_drm_ioctl_channel_submit()
|
| /linux/drivers/gpu/drm/amd/amdgpu/ |
| H A D | amdgpu_bo_list.c | 150 static void amdgpu_bo_list_destroy(struct amdgpu_fpriv *fpriv, int id) in amdgpu_bo_list_destroy() argument 154 mutex_lock(&fpriv->bo_list_lock); in amdgpu_bo_list_destroy() 155 list = idr_remove(&fpriv->bo_list_handles, id); in amdgpu_bo_list_destroy() 156 mutex_unlock(&fpriv->bo_list_lock); in amdgpu_bo_list_destroy() 161 int amdgpu_bo_list_get(struct amdgpu_fpriv *fpriv, int id, in amdgpu_bo_list_get() argument 165 *result = idr_find(&fpriv->bo_list_handles, id); in amdgpu_bo_list_get() 221 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_bo_list_ioctl() local 239 mutex_lock(&fpriv->bo_list_lock); in amdgpu_bo_list_ioctl() 240 r = idr_alloc(&fpriv->bo_list_handles, list, 1, 0, GFP_KERNEL); in amdgpu_bo_list_ioctl() 241 mutex_unlock(&fpriv->bo_list_lock); in amdgpu_bo_list_ioctl() [all …]
|
| H A D | amdgpu_ctx.c | 232 struct amdgpu_fpriv *fpriv; in amdgpu_ctx_init_entity() local 234 fpriv = container_of(ctx->ctx_mgr, struct amdgpu_fpriv, ctx_mgr); in amdgpu_ctx_init_entity() 235 r = amdgpu_xcp_select_scheds(adev, hw_ip, hw_prio, fpriv, in amdgpu_ctx_init_entity() 322 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_ctx_init() local 338 ctx->generation = amdgpu_vm_generation(mgr->adev, &fpriv->vm); in amdgpu_ctx_init() 351 ctx->ctx_mgr = &(fpriv->ctx_mgr); in amdgpu_ctx_init() 476 struct amdgpu_fpriv *fpriv, in amdgpu_ctx_alloc() argument 481 struct amdgpu_ctx_mgr *mgr = &fpriv->ctx_mgr; in amdgpu_ctx_alloc() 526 static int amdgpu_ctx_free(struct amdgpu_fpriv *fpriv, uint32_t id) in amdgpu_ctx_free() argument 528 struct amdgpu_ctx_mgr *mgr = &fpriv->ctx_mgr; in amdgpu_ctx_free() [all …]
|
| H A D | amdgpu_sched.c | 39 struct amdgpu_fpriv *fpriv; in amdgpu_sched_process_priority_override() local 48 r = amdgpu_file_to_fpriv(fd_file(f), &fpriv); in amdgpu_sched_process_priority_override() 52 mgr = &fpriv->ctx_mgr; in amdgpu_sched_process_priority_override() 67 struct amdgpu_fpriv *fpriv; in amdgpu_sched_context_priority_override() local 74 r = amdgpu_file_to_fpriv(fd_file(f), &fpriv); in amdgpu_sched_context_priority_override() 78 ctx = amdgpu_ctx_get(fpriv, ctx_id); in amdgpu_sched_context_priority_override()
|
| H A D | amdgpu_kms.c | 658 struct amdgpu_fpriv *fpriv; in amdgpu_info_ioctl() local 704 fpriv = (struct amdgpu_fpriv *)filp->driver_priv; in amdgpu_info_ioctl() 712 fpriv->xcp_id < adev->xcp_mgr->num_xcps) { in amdgpu_info_ioctl() 713 xcp = &adev->xcp_mgr->xcp[fpriv->xcp_id]; in amdgpu_info_ioctl() 1377 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_info_ioctl() local 1378 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_info_ioctl() 1447 struct amdgpu_fpriv *fpriv; in amdgpu_driver_open_kms() local 1466 fpriv = kzalloc(sizeof(*fpriv), GFP_KERNEL); in amdgpu_driver_open_kms() 1467 if (unlikely(!fpriv)) { in amdgpu_driver_open_kms() 1478 r = amdgpu_xcp_open_device(adev, fpriv, file_priv); in amdgpu_driver_open_kms() [all …]
|
| H A D | amdgpu_gem.c | 231 struct amdgpu_fpriv *fpriv = file_priv->driver_priv; in amdgpu_gem_object_open() local 232 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_gem_object_open() 267 r = amdgpu_eviction_fence_attach(&fpriv->evf_mgr, abo); in amdgpu_gem_object_open() 318 struct amdgpu_fpriv *fpriv = file_priv->driver_priv; in amdgpu_gem_object_close() local 319 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_gem_object_close() 340 amdgpu_eviction_fence_detach(&fpriv->evf_mgr, bo); in amdgpu_gem_object_close() 406 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_gem_create_ioctl() local 407 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_gem_create_ioctl() 457 flags, ttm_bo_type_device, resv, &gobj, fpriv->xcp_id + 1); in amdgpu_gem_create_ioctl() 500 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_gem_userptr_ioctl() local [all …]
|
| H A D | amdgpu_cs.c | 50 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_cs_parser_init() local 59 p->ctx = amdgpu_ctx_get(fpriv, cs->in.ctx_id); in amdgpu_cs_parser_init() 179 struct amdgpu_fpriv *fpriv = p->filp->driver_priv; in amdgpu_cs_pass1() local 181 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_cs_pass1() 287 switch (p->adev->enforce_isolation[fpriv->xcp_id]) { in amdgpu_cs_pass1() 343 struct amdgpu_fpriv *fpriv = p->filp->driver_priv; in amdgpu_cs_p2_ib() local 344 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_cs_p2_ib() 406 struct amdgpu_fpriv *fpriv = p->filp->driver_priv; in amdgpu_cs_p2_dependencies() local 418 ctx = amdgpu_ctx_get(fpriv, deps[i].ctx_id); in amdgpu_cs_p2_dependencies() 855 struct amdgpu_fpriv *fpriv = p->filp->driver_priv; in amdgpu_cs_parser_bos() local [all …]
|
| H A D | amdgpu_xcp.c | 434 struct amdgpu_fpriv *fpriv, in amdgpu_xcp_open_device() argument 442 fpriv->xcp_id = AMDGPU_XCP_NO_PARTITION; in amdgpu_xcp_open_device() 455 fpriv->xcp_id = i; in amdgpu_xcp_open_device() 460 fpriv->vm.mem_id = fpriv->xcp_id == AMDGPU_XCP_NO_PARTITION ? -1 : in amdgpu_xcp_open_device() 461 adev->xcp_mgr->xcp[fpriv->xcp_id].mem_id; in amdgpu_xcp_open_device() 483 struct amdgpu_fpriv *fpriv, in amdgpu_xcp_select_scheds() argument 491 if (fpriv->xcp_id == AMDGPU_XCP_NO_PARTITION) { in amdgpu_xcp_select_scheds() 494 fpriv->xcp_id = 0; in amdgpu_xcp_select_scheds() 500 fpriv->xcp_id = i; in amdgpu_xcp_select_scheds() 505 sel_xcp_id = fpriv->xcp_id; in amdgpu_xcp_select_scheds() [all …]
|
| H A D | amdgpu_userq.c | 630 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_userq_destroy() local 631 struct amdgpu_userq_mgr *uq_mgr = &fpriv->userq_mgr; in amdgpu_userq_destroy() 741 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_userq_create() local 742 struct amdgpu_userq_mgr *uq_mgr = &fpriv->userq_mgr; in amdgpu_userq_create() 774 amdgpu_userq_ensure_ev_fence(&fpriv->userq_mgr, &fpriv->evf_mgr); in amdgpu_userq_create() 794 queue->vm = &fpriv->vm; in amdgpu_userq_create() 1094 struct amdgpu_fpriv *fpriv = uq_mgr_to_fpriv(uq_mgr); in amdgpu_userq_vm_validate() local 1099 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_userq_vm_validate() 1217 ret = amdgpu_eviction_fence_replace_fence(&fpriv->evf_mgr, &exec); in amdgpu_userq_vm_validate() 1236 struct amdgpu_fpriv *fpriv = uq_mgr_to_fpriv(uq_mgr); in amdgpu_userq_restore_worker() local [all …]
|
| H A D | amdgpu_eviction_fence.c | 106 struct amdgpu_fpriv *fpriv = evf_mgr_to_fpriv(evf_mgr); in amdgpu_eviction_fence_suspend_worker() local 107 struct amdgpu_userq_mgr *uq_mgr = &fpriv->userq_mgr; in amdgpu_eviction_fence_suspend_worker()
|
| H A D | amdgpu_userq_fence.c | 462 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_userq_signal_ioctl() local 463 struct amdgpu_userq_mgr *userq_mgr = &fpriv->userq_mgr; in amdgpu_userq_signal_ioctl() 564 amdgpu_userq_ensure_ev_fence(&fpriv->userq_mgr, &fpriv->evf_mgr); in amdgpu_userq_signal_ioctl() 654 struct amdgpu_fpriv *fpriv = filp->driver_priv; in amdgpu_userq_wait_ioctl() local 655 struct amdgpu_userq_mgr *userq_mgr = &fpriv->userq_mgr; in amdgpu_userq_wait_ioctl()
|
| H A D | amdgpu_drv.c | 2970 struct amdgpu_fpriv *fpriv = file_priv->driver_priv; in amdgpu_drm_release() local 2974 if (fpriv && drm_dev_enter(dev, &idx)) { in amdgpu_drm_release() 2975 fpriv->evf_mgr.fd_closing = true; in amdgpu_drm_release() 2976 amdgpu_eviction_fence_destroy(&fpriv->evf_mgr); in amdgpu_drm_release() 2977 amdgpu_userq_mgr_fini(&fpriv->userq_mgr); in amdgpu_drm_release() 3021 struct amdgpu_fpriv *fpriv = file_priv->driver_priv; in amdgpu_flush() local 3024 timeout = amdgpu_ctx_mgr_entity_flush(&fpriv->ctx_mgr, timeout); in amdgpu_flush() 3025 timeout = amdgpu_vm_wait_idle(&fpriv->vm, timeout); in amdgpu_flush() 3048 int amdgpu_file_to_fpriv(struct file *filp, struct amdgpu_fpriv **fpriv) in amdgpu_file_to_fpriv() argument 3059 *fpriv = file->driver_priv; in amdgpu_file_to_fpriv()
|
| H A D | amdgpu_ctx.h | 73 struct amdgpu_ctx *amdgpu_ctx_get(struct amdgpu_fpriv *fpriv, uint32_t id);
|
| H A D | amdgpu_debugfs.c | 1759 struct amdgpu_fpriv *fpriv = file->driver_priv; in amdgpu_debugfs_vm_info_show() local 1760 struct amdgpu_vm *vm = &fpriv->vm; in amdgpu_debugfs_vm_info_show() 2113 struct amdgpu_fpriv *fpriv; in amdgpu_pt_info_read() local 2123 fpriv = file->driver_priv; in amdgpu_pt_info_read() 2124 if (!fpriv || !fpriv->vm.root.bo) in amdgpu_pt_info_read() 2127 root_bo = amdgpu_bo_ref(fpriv->vm.root.bo); in amdgpu_pt_info_read() 2134 seq_printf(m, "pd_address: 0x%llx\n", amdgpu_gmc_pd_addr(fpriv->vm.root.bo)); in amdgpu_pt_info_read()
|
| /linux/drivers/pci/ |
| H A D | proc.c | 199 struct pci_filp_private *fpriv = file->private_data; in proc_bus_pci_ioctl() local 216 fpriv->mmap_state = pci_mmap_io; in proc_bus_pci_ioctl() 220 fpriv->mmap_state = pci_mmap_mem; in proc_bus_pci_ioctl() 226 fpriv->write_combine = 1; in proc_bus_pci_ioctl() 228 fpriv->write_combine = 0; in proc_bus_pci_ioctl() 246 struct pci_filp_private *fpriv = file->private_data; in proc_bus_pci_mmap() local 258 if (fpriv->mmap_state == pci_mmap_io) { in proc_bus_pci_mmap() 274 if (fpriv->mmap_state == pci_mmap_mem && in proc_bus_pci_mmap() 275 fpriv->write_combine) { in proc_bus_pci_mmap() 291 fpriv->mmap_state, write_combine); in proc_bus_pci_mmap() [all …]
|
| /linux/drivers/char/tpm/ |
| H A D | tpmrm-dev.c | 37 struct file_priv *fpriv = file->private_data; in tpmrm_release() local 38 struct tpmrm_priv *priv = container_of(fpriv, struct tpmrm_priv, priv); in tpmrm_release() 40 tpm_common_release(file, fpriv); in tpmrm_release() 41 tpm2_del_space(fpriv->chip, &priv->space); in tpmrm_release()
|
| /linux/drivers/gpu/drm/i915/gem/ |
| H A D | i915_gem_context.c | 283 proto_context_create(struct drm_i915_file_private *fpriv, in proto_context_create() argument 292 pc->fpriv = fpriv; in proto_context_create() 316 static int proto_context_register_locked(struct drm_i915_file_private *fpriv, in proto_context_register_locked() argument 323 lockdep_assert_held(&fpriv->proto_context_lock); in proto_context_register_locked() 325 ret = xa_alloc(&fpriv->context_xa, id, NULL, xa_limit_32b, GFP_KERNEL); in proto_context_register_locked() 329 old = xa_store(&fpriv->proto_context_xa, *id, pc, GFP_KERNEL); in proto_context_register_locked() 331 xa_erase(&fpriv->context_xa, *id); in proto_context_register_locked() 339 static int proto_context_register(struct drm_i915_file_private *fpriv, in proto_context_register() argument 345 mutex_lock(&fpriv->proto_context_lock); in proto_context_register() 346 ret = proto_context_register_locked(fpriv, pc, id); in proto_context_register() [all …]
|
| /linux/drivers/gpu/drm/i915/gem/selftests/ |
| H A D | mock_context.c | 80 struct drm_i915_file_private *fpriv = to_drm_file(file)->driver_priv; in live_context() local 86 pc = proto_context_create(fpriv, i915, 0); in live_context() 97 err = xa_alloc(&fpriv->context_xa, &id, NULL, xa_limit_32b, GFP_KERNEL); in live_context() 101 gem_context_register(ctx, fpriv, id); in live_context()
|
| /linux/drivers/gpu/drm/radeon/ |
| H A D | radeon_kms.c | 628 struct radeon_fpriv *fpriv; in radeon_driver_open_kms() local 643 fpriv = kzalloc_obj(*fpriv); in radeon_driver_open_kms() 644 if (unlikely(!fpriv)) { in radeon_driver_open_kms() 650 vm = &fpriv->vm; in radeon_driver_open_kms() 675 file_priv->driver_priv = fpriv; in radeon_driver_open_kms() 684 kfree(fpriv); in radeon_driver_open_kms() 719 struct radeon_fpriv *fpriv = file_priv->driver_priv; in radeon_driver_postclose_kms() local 720 struct radeon_vm *vm = &fpriv->vm; in radeon_driver_postclose_kms() 733 kfree(fpriv); in radeon_driver_postclose_kms()
|
| H A D | radeon_cs.c | 553 struct radeon_fpriv *fpriv = parser->filp->driver_priv; in radeon_cs_ib_vm_chunk() local 554 struct radeon_vm *vm = &fpriv->vm; in radeon_cs_ib_vm_chunk() 622 struct radeon_fpriv *fpriv = parser->filp->driver_priv; in radeon_cs_ib_fill() local 623 vm = &fpriv->vm; in radeon_cs_ib_fill()
|
| /linux/drivers/gpu/drm/i915/ |
| H A D | i915_drm_client.c | 76 struct drm_i915_file_private *fpriv = file->driver_priv; in show_meminfo() local 77 struct i915_drm_client *client = fpriv->client; in show_meminfo() 78 struct drm_i915_private *i915 = fpriv->i915; in show_meminfo()
|
| /linux/include/drm/ |
| H A D | drm_auth.h | 135 bool drm_is_current_master(struct drm_file *fpriv);
|