Re: [PATCH v2 28/60] drm/omap: dss: Make omap_dss_get_next_device() more generic

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On Sat, May 26, 2018 at 08:24:46PM +0300, Laurent Pinchart wrote:
> Despite its name, the omap_dss_get_next_device() function operates on
> display devices only. Make it more generic by allowing operation on all
> devices, with a parameter to specify the device type.
> 
> While at it rename the function to omapdss_device_get_next() to match
> the naming of the other functions operating on struct omap_dss_device.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx>
> ---

Reviewed-by: Sebastian Reichel <sebastian.reichel@xxxxxxxxxxxxxxx>

-- Sebastian

>  drivers/gpu/drm/omapdrm/dss/base.c    | 52 +++++++++++++++++++++++++++++++++++
>  drivers/gpu/drm/omapdrm/dss/display.c | 49 ---------------------------------
>  drivers/gpu/drm/omapdrm/dss/omapdss.h |  6 ++--
>  3 files changed, 56 insertions(+), 51 deletions(-)
> 
> diff --git a/drivers/gpu/drm/omapdrm/dss/base.c b/drivers/gpu/drm/omapdrm/dss/base.c
> index 7cd3076c2140..f7b8958f15bc 100644
> --- a/drivers/gpu/drm/omapdrm/dss/base.c
> +++ b/drivers/gpu/drm/omapdrm/dss/base.c
> @@ -104,6 +104,58 @@ struct omap_dss_device *omapdss_find_device_by_port(struct device_node *src,
>  	return NULL;
>  }
>  
> +/*
> + * Search for the next device starting at @from. If display_only is true, skip
> + * non-display devices. Release the reference to the @from device, and acquire
> + * a reference to the returned device if found.
> + */
> +struct omap_dss_device *omapdss_device_get_next(struct omap_dss_device *from,
> +						bool display_only)
> +{
> +	struct omap_dss_device *dssdev;
> +	struct list_head *list;
> +
> +	mutex_lock(&omapdss_devices_lock);
> +
> +	if (list_empty(&omapdss_devices_list)) {
> +		dssdev = NULL;
> +		goto done;
> +	}
> +
> +	/*
> +	 * Start from the from entry if given or from omapdss_devices_list
> +	 * otherwise.
> +	 */
> +	list = from ? &from->list : &omapdss_devices_list;
> +
> +	list_for_each_entry(dssdev, list, list) {
> +		/*
> +		 * Stop if we reach the omapdss_devices_list, that's the end of
> +		 * the list.
> +		 */
> +		if (&dssdev->list == &omapdss_devices_list) {
> +			dssdev = NULL;
> +			goto done;
> +		}
> +
> +		/* Filter out non-display entries if display_only is set. */
> +		if (!display_only || dssdev->driver)
> +			goto done;
> +	}
> +
> +	dssdev = NULL;
> +
> +done:
> +	if (from)
> +		omap_dss_put_device(from);
> +	if (dssdev)
> +		omap_dss_get_device(dssdev);
> +
> +	mutex_unlock(&omapdss_devices_lock);
> +	return dssdev;
> +}
> +EXPORT_SYMBOL(omapdss_device_get_next);
> +
>  int omapdss_device_connect(struct omap_dss_device *src,
>  			   struct omap_dss_device *dst)
>  {
> diff --git a/drivers/gpu/drm/omapdrm/dss/display.c b/drivers/gpu/drm/omapdrm/dss/display.c
> index 383512c8a466..0c94d5208398 100644
> --- a/drivers/gpu/drm/omapdrm/dss/display.c
> +++ b/drivers/gpu/drm/omapdrm/dss/display.c
> @@ -92,52 +92,3 @@ void omap_dss_put_device(struct omap_dss_device *dssdev)
>  	module_put(dssdev->owner);
>  }
>  EXPORT_SYMBOL(omap_dss_put_device);
> -
> -/*
> - * ref count of the found device is incremented.
> - * ref count of from-device is decremented.
> - */
> -struct omap_dss_device *omap_dss_get_next_device(struct omap_dss_device *from)
> -{
> -	struct list_head *l;
> -	struct omap_dss_device *dssdev;
> -
> -	mutex_lock(&panel_list_mutex);
> -
> -	if (list_empty(&panel_list)) {
> -		dssdev = NULL;
> -		goto out;
> -	}
> -
> -	if (from == NULL) {
> -		dssdev = list_first_entry(&panel_list, struct omap_dss_device,
> -				panel_list);
> -		omap_dss_get_device(dssdev);
> -		goto out;
> -	}
> -
> -	omap_dss_put_device(from);
> -
> -	list_for_each(l, &panel_list) {
> -		dssdev = list_entry(l, struct omap_dss_device, panel_list);
> -		if (dssdev == from) {
> -			if (list_is_last(l, &panel_list)) {
> -				dssdev = NULL;
> -				goto out;
> -			}
> -
> -			dssdev = list_entry(l->next, struct omap_dss_device,
> -					panel_list);
> -			omap_dss_get_device(dssdev);
> -			goto out;
> -		}
> -	}
> -
> -	WARN(1, "'from' dssdev not found\n");
> -
> -	dssdev = NULL;
> -out:
> -	mutex_unlock(&panel_list_mutex);
> -	return dssdev;
> -}
> -EXPORT_SYMBOL(omap_dss_get_next_device);
> diff --git a/drivers/gpu/drm/omapdrm/dss/omapdss.h b/drivers/gpu/drm/omapdrm/dss/omapdss.h
> index a6ddc881ea72..94a3f98bdd3d 100644
> --- a/drivers/gpu/drm/omapdrm/dss/omapdss.h
> +++ b/drivers/gpu/drm/omapdrm/dss/omapdss.h
> @@ -489,11 +489,15 @@ static inline bool omapdss_is_initialized(void)
>  
>  int omapdss_register_display(struct omap_dss_device *dssdev);
>  void omapdss_unregister_display(struct omap_dss_device *dssdev);
> +#define for_each_dss_display(d) \
> +	while ((d = omapdss_device_get_next(d, true)) != NULL)
>  
>  void omapdss_device_register(struct omap_dss_device *dssdev);
>  void omapdss_device_unregister(struct omap_dss_device *dssdev);
>  struct omap_dss_device *omapdss_find_device_by_port(struct device_node *src,
>  						    unsigned int port);
> +struct omap_dss_device *omapdss_device_get_next(struct omap_dss_device *from,
> +						bool display_only);
>  int omapdss_device_connect(struct omap_dss_device *src,
>  			   struct omap_dss_device *dst);
>  void omapdss_device_disconnect(struct omap_dss_device *src,
> @@ -501,8 +505,6 @@ void omapdss_device_disconnect(struct omap_dss_device *src,
>  
>  struct omap_dss_device *omap_dss_get_device(struct omap_dss_device *dssdev);
>  void omap_dss_put_device(struct omap_dss_device *dssdev);
> -#define for_each_dss_display(d) while ((d = omap_dss_get_next_device(d)) != NULL)
> -struct omap_dss_device *omap_dss_get_next_device(struct omap_dss_device *from);
>  
>  int omap_dss_get_num_overlay_managers(void);
>  
> -- 
> Regards,
> 
> Laurent Pinchart
> 
> _______________________________________________
> dri-devel mailing list
> dri-devel@xxxxxxxxxxxxxxxxxxxxx
> https://lists.freedesktop.org/mailman/listinfo/dri-devel

Attachment: signature.asc
Description: PGP signature

_______________________________________________
dri-devel mailing list
dri-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/dri-devel

[Index of Archives]     [Linux DRI Users]     [Linux Intel Graphics]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux