[V7 12/45] drm/plane: Add COLOR PIPELINE property

Simon Ser contact at emersion.fr
Mon Jan 13 18:08:30 UTC 2025


> +int
> +drm_atomic_add_affected_colorops(struct drm_atomic_state *state,
> +				 struct drm_plane *plane)
> +{
> +	struct drm_colorop *colorop;
> +	struct drm_colorop_state *colorop_state;
> +
> +	WARN_ON(!drm_atomic_get_new_plane_state(state, plane));
> +
> +	drm_dbg_atomic(plane->dev,
> +		       "Adding all current colorops for [plane:%d:%s] to %p\n",
> +		       plane->base.id, plane->name, state);

Nit: we use upper-case "[PLANE:%d:%s]" when pretty-printing.

> +#define MAX_COLOR_PIPELINES 5

Is this kind of arbitrary, or is there a real reason behind this?

This is not strictly the max number of color pipelines, since a driver can
create more. This is the max number of choices for the COLOR_PIPELINE property.
Should this be renamed to e.g. MAX_COLOR_PIPLINE_PROP_ENTRIES?

> +/**
> + * drm_plane_create_color_pipeline_property - create a new color pipeline
> + * property
> + *
> + * @plane: drm plane
> + * @pipelines: list of pipelines
> + * @num_pipelines: number of pipelines
> + *
> + * Create the COLOR_PIPELINE plane property to specific color pipelines on
> + * the plane.
> + *
> + * RETURNS:
> + * Zero for success or -errno
> + */
> +int drm_plane_create_color_pipeline_property(struct drm_plane *plane,
> +					     struct drm_prop_enum_list *pipelines,

Nit: this argument can be const.

> +					     int num_pipelines)
> +{
> +	struct drm_prop_enum_list all_pipelines[MAX_COLOR_PIPELINES];
> +	int len = 0;
> +	int i;
> +	struct drm_property *prop;
> +
> +	if (num_pipelines > (MAX_COLOR_PIPELINES - 1))
> +		return -EINVAL;

Probably this should be a drm_WARN_ON?


More information about the dri-devel mailing list