-
- Downloads
drm/msm: Add a way for userspace to allocate GPU iova
The motivation at this point is mainly native userspace mesa driver in a VM guest. The one remaining synchronous "hotpath" is buffer allocation, because guest needs to wait to know the bo's iova before it can start emitting cmdstream/state that references the new bo. By allocating the iova in the guest userspace, we no longer need to wait for a response from the host, but can just rely on the allocation request being processed before the cmdstream submission. Allocation failures (OoM, etc) would just be treated as context-lost (ie. GL_GUILTY_CONTEXT_RESET) or subsequent allocations (or readpix, etc) can raise GL_OUT_OF_MEMORY. v2: Fix inuse check v3: Change mismatched iova case to -EBUSY Signed-off-by:Rob Clark <robdclark@chromium.org> Reviewed-by:
Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Reviewed-by:
Dmitry Osipenko <dmitry.osipenko@collabora.com> Link: https://lore.kernel.org/r/20220411215849.297838-11-robdclark@gmail.com Signed-off-by:
Rob Clark <robdclark@chromium.org>
Showing
- drivers/gpu/drm/msm/adreno/adreno_gpu.c 10 additions, 0 deletionsdrivers/gpu/drm/msm/adreno/adreno_gpu.c
- drivers/gpu/drm/msm/msm_drv.c 21 additions, 0 deletionsdrivers/gpu/drm/msm/msm_drv.c
- drivers/gpu/drm/msm/msm_gem.c 48 additions, 0 deletionsdrivers/gpu/drm/msm/msm_gem.c
- drivers/gpu/drm/msm/msm_gem.h 8 additions, 0 deletionsdrivers/gpu/drm/msm/msm_gem.h
- drivers/gpu/drm/msm/msm_gem_vma.c 2 additions, 0 deletionsdrivers/gpu/drm/msm/msm_gem_vma.c
- include/uapi/drm/msm_drm.h 3 additions, 0 deletionsinclude/uapi/drm/msm_drm.h
Loading
Please register or sign in to comment