mirror of
git://nv-tegra.nvidia.com/linux-nvgpu.git
synced 2025-12-24 10:34:43 +03:00
gpu: nvgpu: support usermode submit buffers
Import userd and gpfifo buffers from userspace if provided via
NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX. Also supply the work submit token
(i.e., the hw channel id) to userspace.
To keep the buffers alive, store their dmabuf and attachment/sgt handles
in nvgpu_channel_linux. Our nvgpu_mem doesn't provide such data for
buffers that are mainly in kernel use. The buffers are freed via a new
API in the os_channel interface.
Fix a bug in gk20a_channel_free_usermode_buffers: also unmap the
usermode gpfifo buffer.
Bug 200145225
Bug 200541476
Change-Id: I8416af7085c91b044ac8ccd9faa38e2a6d0c3946
Signed-off-by: Konsta Holtta <kholtta@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/1795821
Signed-off-by: Debarshi Dutta <ddutta@nvidia.com>
(cherry picked from commit 99b1c6dcdf
in dev-main)
Reviewed-on: https://git-master.nvidia.com/r/2170603
GVS: Gerrit_Virtual_Submit
Reviewed-by: Bibek Basu <bbasu@nvidia.com>
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com>
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
This commit is contained in:
committed by
mobile promotions
parent
758cb76e22
commit
8b484c0b53
@@ -590,6 +590,9 @@ static u32 nvgpu_setup_bind_user_flags_to_common_flags(u32 user_flags)
|
||||
if (user_flags & NVGPU_CHANNEL_SETUP_BIND_FLAGS_REPLAYABLE_FAULTS_ENABLE)
|
||||
flags |= NVGPU_SETUP_BIND_FLAGS_REPLAYABLE_FAULTS_ENABLE;
|
||||
|
||||
if (user_flags & NVGPU_CHANNEL_SETUP_BIND_FLAGS_USERMODE_SUPPORT)
|
||||
flags |= NVGPU_SETUP_BIND_FLAGS_USERMODE_SUPPORT;
|
||||
|
||||
return flags;
|
||||
}
|
||||
|
||||
@@ -601,6 +604,14 @@ static void nvgpu_get_setup_bind_args(
|
||||
channel_setup_bind_args->num_gpfifo_entries;
|
||||
setup_bind_args->num_inflight_jobs =
|
||||
channel_setup_bind_args->num_inflight_jobs;
|
||||
setup_bind_args->userd_dmabuf_fd =
|
||||
channel_setup_bind_args->userd_dmabuf_fd;
|
||||
setup_bind_args->userd_dmabuf_offset =
|
||||
channel_setup_bind_args->userd_dmabuf_offset;
|
||||
setup_bind_args->gpfifo_dmabuf_fd =
|
||||
channel_setup_bind_args->gpfifo_dmabuf_fd;
|
||||
setup_bind_args->gpfifo_dmabuf_offset =
|
||||
channel_setup_bind_args->gpfifo_dmabuf_offset;
|
||||
setup_bind_args->flags = nvgpu_setup_bind_user_flags_to_common_flags(
|
||||
channel_setup_bind_args->flags);
|
||||
}
|
||||
@@ -1156,6 +1167,8 @@ long gk20a_channel_ioctl(struct file *filp,
|
||||
break;
|
||||
}
|
||||
err = nvgpu_channel_setup_bind(ch, &setup_bind_args);
|
||||
channel_setup_bind_args->work_submit_token =
|
||||
setup_bind_args.work_submit_token;
|
||||
gk20a_idle(ch->g);
|
||||
break;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user