[PATCH] intel: Set bo size from lseek if kernel supports it

Daniel Vetter daniel at ffwll.ch
Fri Oct 11 01:10:15 CEST 2013


On Thu, Oct 10, 2013 at 03:07:01PM -0700, Kristian Høgsberg wrote:
> The various create and open functions set the buffer size, but
> drm_intel_bo_gem_create_from_prime() is an exception.  In the 3.12 kernel
> we can now use lseek on the prime fd to determine the size of the bo.
> Use that and override the userprovided size.  If the kernel doesn't
> support this, we get an error and fall back to the user provided size.
> 
> Signed-off-by: Kristian Høgsberg <krh at bitplanet.net>

Reviewed-by: Daniel Vetter <daniel.vetter at ffwll.ch>
> ---
>  intel/intel_bufmgr_gem.c | 12 +++++++++++-
>  1 file changed, 11 insertions(+), 1 deletion(-)
> 
> diff --git a/intel/intel_bufmgr_gem.c b/intel/intel_bufmgr_gem.c
> index f98f7a7..278f5c8 100644
> --- a/intel/intel_bufmgr_gem.c
> +++ b/intel/intel_bufmgr_gem.c
> @@ -2452,7 +2452,17 @@ drm_intel_bo_gem_create_from_prime(drm_intel_bufmgr *bufmgr, int prime_fd, int s
>  	if (!bo_gem)
>  		return NULL;
>  
> -	bo_gem->bo.size = size;
> +	/* Determine size of bo.  The fd-to-handle ioctl really should
> +	 * return the size, but it doesn't.  If we have kernel 3.12 or
> +	 * later, we can lseek on the prime fd to get the size.  Older
> +	 * kernels will just fail, in which case we fall back to the
> +	 * provided (estimated or guess size). */
> +	ret = lseek(prime_fd, 0, SEEK_END);
> +	if (ret != -1)
> +		bo_gem->bo.size = ret;
> +	else
> +		bo_gem->bo.size = size;
> +
>  	bo_gem->bo.handle = handle;
>  	bo_gem->bo.bufmgr = bufmgr;
>  
> -- 
> 1.8.3.1
> 
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel

-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch


More information about the dri-devel mailing list