[PATCH libdrm 2/2] xf86drmMode: smoke-test the atomic API

Ville Syrjälä ville.syrjala at linux.intel.com
Mon Sep 7 06:06:41 PDT 2015


On Mon, Sep 07, 2015 at 10:53:06AM +0100, Emil Velikov wrote:
> As going through the modetest patches for atomic support I've noticed
> that if we pass NULL for the drmModeAtomicReqPtr argument we'll crash.
> 
> So let's handle things appropriately if the user forgot to check the
> return value of drmModeAtomicAlloc and drmModeAtomicDuplicate or made a
> typo somewhere along the way.

I'm not sure hand-holding the user to such an extent is actually useful.
OTOH I guess one NULL check per function call isn't all that expensive
either.

> 
> Cc: Ville Syrjälä <ville.syrjala at linux.intel.com>
> Cc: Rob Clark <robclark at freedesktop.org>
> Cc: Daniel Stone <daniels at collabora.com>
> Signed-off-by: Emil Velikov <emil.l.velikov at gmail.com>
> ---
>  xf86drmMode.c | 17 ++++++++++++++++-
>  1 file changed, 16 insertions(+), 1 deletion(-)
> 
> diff --git a/xf86drmMode.c b/xf86drmMode.c
> index 23800dd..ab6b519 100644
> --- a/xf86drmMode.c
> +++ b/xf86drmMode.c
> @@ -1189,6 +1189,9 @@ drmModeAtomicReqPtr drmModeAtomicDuplicate(drmModeAtomicReqPtr old)
>  {
>  	drmModeAtomicReqPtr new;
>  
> +	if (!old)
> +		return NULL;
> +
>  	new = drmMalloc(sizeof *new);
>  	if (!new)
>  		return NULL;
> @@ -1213,6 +1216,9 @@ drmModeAtomicReqPtr drmModeAtomicDuplicate(drmModeAtomicReqPtr old)
>  
>  int drmModeAtomicMerge(drmModeAtomicReqPtr base, drmModeAtomicReqPtr augment)
>  {
> +	if (!base)
> +		return -EINVAL;
> +
>  	if (!augment || augment->cursor == 0)
>  		return 0;
>  
> @@ -1239,12 +1245,15 @@ int drmModeAtomicMerge(drmModeAtomicReqPtr base, drmModeAtomicReqPtr augment)
>  
>  int drmModeAtomicGetCursor(drmModeAtomicReqPtr req)
>  {
> +	if (!req)
> +		return -EINVAL;
>  	return req->cursor;
>  }
>  
>  void drmModeAtomicSetCursor(drmModeAtomicReqPtr req, int cursor)
>  {
> -	req->cursor = cursor;
> +	if (req)
> +		req->cursor = cursor;
>  }
>  
>  int drmModeAtomicAddProperty(drmModeAtomicReqPtr req,
> @@ -1252,6 +1261,9 @@ int drmModeAtomicAddProperty(drmModeAtomicReqPtr req,
>  			     uint32_t property_id,
>  			     uint64_t value)
>  {
> +	if (!req)
> +		return -EINVAL;
> +
>  	if (req->cursor >= req->size_items) {
>  		drmModeAtomicReqItemPtr new;
>  
> @@ -1309,6 +1321,9 @@ int drmModeAtomicCommit(int fd, drmModeAtomicReqPtr req, uint32_t flags,
>  	int obj_idx = -1;
>  	int ret = -1;
>  
> +	if (!req)
> +		return -EINVAL;
> +
>  	if (req->cursor == 0)
>  		return 0;
>  
> -- 
> 2.5.0

-- 
Ville Syrjälä
Intel OTC


More information about the dri-devel mailing list