[PATCH v4 1/6] drm/omap: Get rid of DRM_OMAP_NUM_CRTCS config option

Laurent Pinchart laurent.pinchart at ideasonboard.com
Thu Mar 30 21:58:38 UTC 2017


Hi Jyri,

Thank you for the patch.

On Friday 24 Mar 2017 16:47:51 Jyri Sarha wrote:
> Allocate one CRTC for each connected output and get rid of
> DRM_OMAP_NUM_CRTCS config option. We still can not create more CRTCs
> than we have DSS display managers. We also reserve one overlay per
> CRTC for primary plane so we can not have more CRTCs than we have
> overlays either.
> 
> Signed-off-by: Jyri Sarha <jsarha at ti.com>

Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

> ---
>  drivers/gpu/drm/omapdrm/Kconfig    |  9 ------
>  drivers/gpu/drm/omapdrm/omap_drv.c | 59 ++++++++---------------------------
>  2 files changed, 16 insertions(+), 52 deletions(-)
> 
> diff --git a/drivers/gpu/drm/omapdrm/Kconfig
> b/drivers/gpu/drm/omapdrm/Kconfig index 556f81f..b3d08c5 100644
> --- a/drivers/gpu/drm/omapdrm/Kconfig
> +++ b/drivers/gpu/drm/omapdrm/Kconfig
> @@ -10,15 +10,6 @@ config DRM_OMAP
> 
>  if DRM_OMAP
> 
> -config DRM_OMAP_NUM_CRTCS
> -	int "Number of CRTCs"
> -	range 1 10
> -	default 1  if ARCH_OMAP2 || ARCH_OMAP3
> -	default 2  if ARCH_OMAP4
> -	help
> -	  Select the number of video overlays which can be used as 
framebuffers.
> -	  The remaining overlays are reserved for video.
> -
>  source "drivers/gpu/drm/omapdrm/dss/Kconfig"
>  source "drivers/gpu/drm/omapdrm/displays/Kconfig"
> 
> diff --git a/drivers/gpu/drm/omapdrm/omap_drv.c
> b/drivers/gpu/drm/omapdrm/omap_drv.c index ad8d16c..b040f5f 100644
> --- a/drivers/gpu/drm/omapdrm/omap_drv.c
> +++ b/drivers/gpu/drm/omapdrm/omap_drv.c
> @@ -34,11 +34,6 @@
>  #define DRIVER_MINOR		0
>  #define DRIVER_PATCHLEVEL	0
> 
> -static int num_crtc = CONFIG_DRM_OMAP_NUM_CRTCS;
> -
> -MODULE_PARM_DESC(num_crtc, "Number of overlays to use as CRTCs");
> -module_param(num_crtc, int, 0600);
> -
>  /*
>   * mode config funcs
>   */
> @@ -319,7 +314,7 @@ static int omap_modeset_init(struct drm_device *dev)
>  	struct omap_dss_device *dssdev = NULL;
>  	int num_ovls = priv->dispc_ops->get_num_ovls();
>  	int num_mgrs = priv->dispc_ops->get_num_mgrs();
> -	int num_crtcs;
> +	int num_crtcs = 0;
>  	int i, id = 0;
>  	int ret;
>  	u32 possible_crtcs;
> @@ -331,12 +326,15 @@ static int omap_modeset_init(struct drm_device *dev)
>  		return ret;
> 
>  	/*
> -	 * We usually don't want to create a CRTC for each manager, at least
> -	 * not until we have a way to expose private planes to userspace.
> -	 * Otherwise there would not be enough video pipes left for drm 
planes.
> -	 * We use the num_crtc argument to limit the number of crtcs we 
create.
> +	 * Let's create one CRTC for each connected DSS device if we
> +	 * have display managers and overlays (for primary planes) for
> +	 * them.
>  	 */
> -	num_crtcs = min3(num_crtc, num_mgrs, num_ovls);
> +	for_each_dss_dev(dssdev)
> +		if (omapdss_device_is_connected(dssdev))
> +			num_crtcs++;
> +
> +	num_crtcs = min3(num_crtcs, num_mgrs, num_ovls);
>  	possible_crtcs = (1 << num_crtcs) - 1;
> 
>  	dssdev = NULL;
> @@ -376,11 +374,9 @@ static int omap_modeset_init(struct drm_device *dev)
>  		drm_mode_connector_attach_encoder(connector, encoder);
> 
>  		/*
> -		 * if we have reached the limit of the crtcs we are allowed to
> -		 * create, let's not try to look for a crtc for this
> -		 * panel/encoder and onwards, we will, of course, populate the
> -		 * the possible_crtcs field for all the encoders with the 
final
> -		 * set of crtcs we create
> +		 * if we have reached the limit of the crtcs we can
> +		 * create, let's not try to create a crtc for this
> +		 * panel/encoder and onwards.
>  		 */
>  		if (id == num_crtcs)
>  			continue;
> @@ -415,33 +411,6 @@ static int omap_modeset_init(struct drm_device *dev)
>  	}
> 
>  	/*
> -	 * we have allocated crtcs according to the need of the 
panels/encoders,
> -	 * adding more crtcs here if needed
> -	 */
> -	for (; id < num_crtcs; id++) {
> -
> -		/* find a free manager for this crtc */
> -		for (i = 0; i < num_mgrs; i++) {
> -			if (!channel_used(dev, i))
> -				break;
> -		}
> -
> -		if (i == num_mgrs) {
> -			/* this shouldn't really happen */
> -			dev_err(dev->dev, "no managers left for crtc\n");
> -			return -ENOMEM;
> -		}
> -
> -		ret = omap_modeset_create_crtc(dev, id, i,
> -			possible_crtcs);
> -		if (ret < 0) {
> -			dev_err(dev->dev,
> -				"could not create CRTC (channel %u)\n", i);
> -			return ret;
> -		}
> -	}
> -
> -	/*
>  	 * Create normal planes for the remaining overlays:
>  	 */
>  	for (; id < num_ovls; id++) {
> @@ -456,6 +425,10 @@ static int omap_modeset_init(struct drm_device *dev)
>  		priv->planes[priv->num_planes++] = plane;
>  	}
> 
> +	/*
> +	 * populate the the possible_crtcs field for all the encoders
> +	 * we created.
> +	 */
>  	for (i = 0; i < priv->num_encoders; i++) {
>  		struct drm_encoder *encoder = priv->encoders[i];
>  		struct omap_dss_device *dssdev =

-- 
Regards,

Laurent Pinchart



More information about the dri-devel mailing list