Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp21553570rwd; Thu, 29 Jun 2023 18:31:11 -0700 (PDT) X-Google-Smtp-Source: APBJJlEDOgpzN3yb+npdEF8P1IJS0dQ4sbWjfv0dsi14AP7BJc7KIWFrLXI7czeqtYK4x3knGbiw X-Received: by 2002:a17:90a:de8f:b0:25b:e07f:4c43 with SMTP id n15-20020a17090ade8f00b0025be07f4c43mr1086049pjv.10.1688088671125; Thu, 29 Jun 2023 18:31:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688088671; cv=none; d=google.com; s=arc-20160816; b=VqtfDjU6GsI2C6QhkmFsCaDneZzknvPaQWtDB31SHEcmJ6tDOI93gq1btl3bm4xQxG 1YyBTpUksiQTN991z813qI/cvydMXdeyL+akiGsIB3ogIXvbGuqq7Ne//lLM3yFZeXAa MCJ9NoaSjJ8SeolyxS+2njVlUoIUf15HxOCQhBxybuNKca7j6GqLoSEkIGtHufOjjYzk IOsLwNjUR20wUXfFfbaI8eJkn25Wwuh+eIY9PTzKC9bF2QE90kYV/cu076Lgl4tPs7Ss G5bGIncy64jN243UMGE6Xp6IP71vyuVmFI4fXTmjG0nSt93UEWkYmdxReKTuD16PrPu9 vhsQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=Jjm4S8tG5ar4dri84IyFq2aA45fAaCrDTlaVzsiNzbo=; fh=hGBUr8Eoxf0TyqCYf/kwvszGHAkVx6znvw5Xv7jyx48=; b=aD/XBOrn6pOeQmvgWV/X80TpVr1OF0PDcJrURT0je8D55o33ShxM8CMbZCCxVljNwN SclFfiO6oQfa8+m08ZHWR+vlIULDyYT+OyMJ2bfn5WTt6WZmBHr8TKxF4qX+eOLyuf7i N7ge+QLxSwitzohWcPZpSZGhCJsI//7GEW1v0m9rOpfKt9tVyVqLWu4fnCzXe4V5F0EI bUCpg6+tobHb0no6BuMhsgpAXyLcIvoX4KPMcbRKSYGdRUZVmPoQy5jW8ck56Rp46inh gUI3MRvSjqaUwGDeQRD9KDH5XAUsEVsbSoDvyM25sT07E4TYAHVd7bAkN632cnCfzYPm Zq+g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=mN3NuBGW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i36-20020a17090a3da700b0024e5ed38294si11149178pjc.66.2023.06.29.18.30.57; Thu, 29 Jun 2023 18:31:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=mN3NuBGW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231655AbjF3Amh (ORCPT + 99 others); Thu, 29 Jun 2023 20:42:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58498 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230436AbjF3Ame (ORCPT ); Thu, 29 Jun 2023 20:42:34 -0400 Received: from mail-lf1-x12f.google.com (mail-lf1-x12f.google.com [IPv6:2a00:1450:4864:20::12f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B4AE430E6 for ; Thu, 29 Jun 2023 17:42:31 -0700 (PDT) Received: by mail-lf1-x12f.google.com with SMTP id 2adb3069b0e04-4fb7589b187so2130066e87.1 for ; Thu, 29 Jun 2023 17:42:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1688085750; x=1690677750; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=Jjm4S8tG5ar4dri84IyFq2aA45fAaCrDTlaVzsiNzbo=; b=mN3NuBGWnQ2SuxJaFBhmmjVC+MXXA0giXpScNEDb4nIeSFOQ60ALerou5cZ+hiFrES Sulh7ojdUp05iydiPSuJndBLNn2iLruMGotwIf1QIRLVCmBesWrjI7kAnWuTxb1FQE/9 YxVzMd1j+/ggqz6eqp6SH8JcUi1f+O1vmaeGy/C75YOvEBF4DECL4J10WsxsVSwztTzs 4pR5T//zLgJUY250fHfWo1IH8Bn0nWNdeZ0gf/tLsMUCudbmWTInl7rhpsV55uAQCRXG kjokiKsniSBwaMxVvIIKUSa2nVvRGTJSyO9pQrqYE1/jaVj8JOBur7SWfY3iJDsP08I2 t5hg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688085750; x=1690677750; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=Jjm4S8tG5ar4dri84IyFq2aA45fAaCrDTlaVzsiNzbo=; b=F9JAs63JDvdJjEilAapAOV77qq1R6DBaBhkA7HbodRfgOC1zLXD028mHEogf7anqyE 580r84yxWnxReUNulaWQlKEIsPinG7SbG/8NEZFO5sb66uT32+dAcINZ8T5r8owwNJpT CoHDnFQa8acyfx4k8Skrm0xzdToHk3ZbTQcmYxh7Rn04AyaTloOSu4e3xSn/47R55Wh3 GIxn5c1UQKvSa1Gkc1b2By3WfALe65GvP63yHgFiJoWikeZlEKFEYZp79ZEJOihf4TGL KTg1Udy2BqfUXhhXIRHiI4bG29hf7vnHW2g/EzKRVgbqky9Bh7IgvZ8fLC/WbLKXkQuT BENQ== X-Gm-Message-State: ABy/qLbh4ZdX5X82aQso2rYsGhfos8Ogur9GAK+J6UIByon+dCrXjzP7 XCbFylIPyxTdYoBVsMSn7ES5zw== X-Received: by 2002:a05:6512:202c:b0:4fb:889c:c53d with SMTP id s12-20020a056512202c00b004fb889cc53dmr931672lfs.10.1688085749897; Thu, 29 Jun 2023 17:42:29 -0700 (PDT) Received: from ?IPV6:2001:14ba:a0db:1f00::8a5? (dzdqv0yyyyyyyyyyybcwt-3.rev.dnainternet.fi. [2001:14ba:a0db:1f00::8a5]) by smtp.gmail.com with ESMTPSA id a18-20020ac25212000000b004fb8f4df9bdsm897490lfl.226.2023.06.29.17.42.29 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 29 Jun 2023 17:42:29 -0700 (PDT) Message-ID: <6e3eec49-f798-ff91-8b4d-417d31089296@linaro.org> Date: Fri, 30 Jun 2023 03:42:28 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.11.0 Subject: Re: [PATCH RFC v4 2/7] drm: Introduce pixel_source DRM plane property Content-Language: en-GB To: Jessica Zhang , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Rob Clark , Sean Paul , Marijn Suijten Cc: quic_abhinavk@quicinc.com, ppaalanen@gmail.com, contact@emersion.fr, laurent.pinchart@ideasonboard.com, sebastian.wick@redhat.com, ville.syrjala@linux.intel.com, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, freedreno@lists.freedesktop.org, wayland-devel@lists.freedesktop.org References: <20230404-solid-fill-v4-0-f4ec0caa742d@quicinc.com> <20230404-solid-fill-v4-2-f4ec0caa742d@quicinc.com> From: Dmitry Baryshkov In-Reply-To: <20230404-solid-fill-v4-2-f4ec0caa742d@quicinc.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 30/06/2023 03:25, Jessica Zhang wrote: > Add support for pixel_source property to drm_plane and related > documentation. > > This enum property will allow user to specify a pixel source for the > plane. Possible pixel sources will be defined in the > drm_plane_pixel_source enum. > > The current possible pixel sources are DRM_PLANE_PIXEL_SOURCE_FB and > DRM_PLANE_PIXEL_SOURCE_COLOR. The default value is *_SOURCE_FB. I think, this should come before the solid fill property addition. First you tell that there is a possibility to define other pixel sources, then additional sources are defined. > > Signed-off-by: Jessica Zhang > --- > drivers/gpu/drm/drm_atomic_state_helper.c | 1 + > drivers/gpu/drm/drm_atomic_uapi.c | 4 ++ > drivers/gpu/drm/drm_blend.c | 81 +++++++++++++++++++++++++++++++ > include/drm/drm_blend.h | 2 + > include/drm/drm_plane.h | 21 ++++++++ > 5 files changed, 109 insertions(+) > > diff --git a/drivers/gpu/drm/drm_atomic_state_helper.c b/drivers/gpu/drm/drm_atomic_state_helper.c > index fe14be2bd2b2..86fb876efbe6 100644 > --- a/drivers/gpu/drm/drm_atomic_state_helper.c > +++ b/drivers/gpu/drm/drm_atomic_state_helper.c > @@ -252,6 +252,7 @@ void __drm_atomic_helper_plane_state_reset(struct drm_plane_state *plane_state, > > plane_state->alpha = DRM_BLEND_ALPHA_OPAQUE; > plane_state->pixel_blend_mode = DRM_MODE_BLEND_PREMULTI; > + plane_state->pixel_source = DRM_PLANE_PIXEL_SOURCE_FB; > > if (plane_state->solid_fill_blob) { > drm_property_blob_put(plane_state->solid_fill_blob); > diff --git a/drivers/gpu/drm/drm_atomic_uapi.c b/drivers/gpu/drm/drm_atomic_uapi.c > index a28b4ee79444..6e59c21af66b 100644 > --- a/drivers/gpu/drm/drm_atomic_uapi.c > +++ b/drivers/gpu/drm/drm_atomic_uapi.c > @@ -596,6 +596,8 @@ static int drm_atomic_plane_set_property(struct drm_plane *plane, > drm_property_blob_put(solid_fill); > > return ret; > + } else if (property == plane->pixel_source_property) { > + state->pixel_source = val; > } else if (property == plane->alpha_property) { > state->alpha = val; > } else if (property == plane->blend_mode_property) { I think, it was pointed out in the discussion that drm_mode_setplane() (a pre-atomic IOCTL to turn the plane on and off) should also reset pixel_source to FB. > @@ -671,6 +673,8 @@ drm_atomic_plane_get_property(struct drm_plane *plane, > } else if (property == plane->solid_fill_property) { > *val = state->solid_fill_blob ? > state->solid_fill_blob->base.id : 0; > + } else if (property == plane->pixel_source_property) { > + *val = state->pixel_source; > } else if (property == plane->alpha_property) { > *val = state->alpha; > } else if (property == plane->blend_mode_property) { > diff --git a/drivers/gpu/drm/drm_blend.c b/drivers/gpu/drm/drm_blend.c > index 38c3c5d6453a..8c100a957ee2 100644 > --- a/drivers/gpu/drm/drm_blend.c > +++ b/drivers/gpu/drm/drm_blend.c > @@ -189,6 +189,18 @@ > * solid_fill is set up with drm_plane_create_solid_fill_property(). It > * contains pixel data that drivers can use to fill a plane. > * > + * pixel_source: > + * pixel_source is set up with drm_plane_create_pixel_source_property(). > + * It is used to toggle the source of pixel data for the plane. > + * > + * Possible values: > + * > + * "FB": > + * Framebuffer source > + * > + * "COLOR": > + * solid_fill source > + * > * Note that all the property extensions described here apply either to the > * plane or the CRTC (e.g. for the background color, which currently is not > * exposed and assumed to be black). > @@ -648,3 +660,72 @@ int drm_plane_create_solid_fill_property(struct drm_plane *plane) > return 0; > } > EXPORT_SYMBOL(drm_plane_create_solid_fill_property); > + > +/** > + * drm_plane_create_pixel_source_property - create a new pixel source property > + * @plane: drm plane > + * @supported_sources: bitmask of supported pixel_sources for the driver (NOT > + * including DRM_PLANE_PIXEL_SOURCE_FB, as it will be supported > + * by default). I'd say this is too strong. I'd suggest either renaming this to extra_sources (mentioning that FB is enabled for all the planes) or allowing any source bitmask (mentioning that FB should be enabled by the caller, unless there is a good reason not to do so). > + * > + * This creates a new property describing the current source of pixel data for the > + * plane. > + * > + * The property is exposed to userspace as an enumeration property called > + * "pixel_source" and has the following enumeration values: > + * > + * "FB": > + * Framebuffer pixel source > + * > + * "COLOR": > + * Solid fill color pixel source > + * > + * Returns: > + * Zero on success, negative errno on failure. > + */ > +int drm_plane_create_pixel_source_property(struct drm_plane *plane, > + unsigned int supported_sources) > +{ > + struct drm_device *dev = plane->dev; > + struct drm_property *prop; > + const struct drm_prop_enum_list enum_list[] = { > + { DRM_PLANE_PIXEL_SOURCE_FB, "FB" }, > + { DRM_PLANE_PIXEL_SOURCE_COLOR, "COLOR" }, > + }; > + unsigned int valid_source_mask = BIT(DRM_PLANE_PIXEL_SOURCE_FB) | > + BIT(DRM_PLANE_PIXEL_SOURCE_COLOR); static const? > + int i; > + > + /* FB is supported by default */ > + supported_sources |= BIT(DRM_PLANE_PIXEL_SOURCE_FB); > + > + if (WARN_ON(supported_sources & ~valid_source_mask)) > + return -EINVAL; > + > + prop = drm_property_create(dev, DRM_MODE_PROP_ENUM, "pixel_source", > + hweight32(supported_sources)); > + > + if (!prop) > + return -ENOMEM; > + > + for (i = 0; i < ARRAY_SIZE(enum_list); i++) { > + int ret; > + > + if (!(BIT(enum_list[i].type) & supported_sources)) test_bit? > + continue; > + > + ret = drm_property_add_enum(prop, enum_list[i].type, enum_list[i].name); > + No need for an empty line in such cases. Please drop it. > + if (ret) { > + drm_property_destroy(dev, prop); > + > + return ret; > + } > + } > + > + drm_object_attach_property(&plane->base, prop, DRM_PLANE_PIXEL_SOURCE_FB); > + plane->pixel_source_property = prop; > + > + return 0; > +} > +EXPORT_SYMBOL(drm_plane_create_pixel_source_property); > diff --git a/include/drm/drm_blend.h b/include/drm/drm_blend.h > index 0338a860b9c8..31af7cfa5b1b 100644 > --- a/include/drm/drm_blend.h > +++ b/include/drm/drm_blend.h > @@ -59,4 +59,6 @@ int drm_atomic_normalize_zpos(struct drm_device *dev, > int drm_plane_create_blend_mode_property(struct drm_plane *plane, > unsigned int supported_modes); > int drm_plane_create_solid_fill_property(struct drm_plane *plane); > +int drm_plane_create_pixel_source_property(struct drm_plane *plane, > + unsigned int supported_sources); > #endif > diff --git a/include/drm/drm_plane.h b/include/drm/drm_plane.h > index f6ab313cb83e..73fb6cf8a5d9 100644 > --- a/include/drm/drm_plane.h > +++ b/include/drm/drm_plane.h > @@ -59,6 +59,12 @@ struct drm_solid_fill { > uint32_t b; > }; > > +enum drm_plane_pixel_source { > + DRM_PLANE_PIXEL_SOURCE_FB, > + DRM_PLANE_PIXEL_SOURCE_COLOR, > + DRM_PLANE_PIXEL_SOURCE_MAX > +}; > + > /** > * struct drm_plane_state - mutable plane state > * > @@ -152,6 +158,14 @@ struct drm_plane_state { > */ > struct drm_solid_fill solid_fill; > > + /* > + * @pixel_source: > + * > + * Source of pixel information for the plane. See > + * drm_plane_create_pixel_source_property() for more details. > + */ > + enum drm_plane_pixel_source pixel_source; > + > /** > * @alpha: > * Opacity of the plane with 0 as completely transparent and 0xffff as > @@ -742,6 +756,13 @@ struct drm_plane { > */ > struct drm_property *solid_fill_property; > > + /* > + * @pixel_source_property: > + * Optional pixel_source property for this plane. See > + * drm_plane_create_pixel_source_property(). > + */ > + struct drm_property *pixel_source_property; > + > /** > * @alpha_property: > * Optional alpha property for this plane. See > -- With best wishes Dmitry