Received: by 2002:a05:6359:6284:b0:131:369:b2a3 with SMTP id se4csp3222634rwb; Mon, 7 Aug 2023 09:59:30 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFUxf/WFfenAl4wsdXZ95kycrcVjiisil4bg+L56KY33yLiJQtCubfqN5NhphFX1Pv4lhzq X-Received: by 2002:a05:6a20:7d87:b0:140:7b6a:6910 with SMTP id v7-20020a056a207d8700b001407b6a6910mr8133492pzj.34.1691427569972; Mon, 07 Aug 2023 09:59:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691427569; cv=none; d=google.com; s=arc-20160816; b=o1oGNm8xmomwg8+wtO6+Qil8dsv6UFmpbbBeXhJvs0oa35xBtUn79/BjVkyiBO3NXo m5FlMm8JPhz6AOBGvXJ48rUrw6KeonY//Yxr8pSyGUlgBTg00q0Q1fbMRULyGtajn+oY kUVnFUNjDVZ+PaH/sHvs4zh5ryR0x+opTAGCTXaXqEGQE/5uYst6HJTuFB5WfIcwsPRf COhmeE7CHDbDJnLC5iaiLLZQIzWpk/HLFQ0SC1/DCESmTIuXNUtzC7s5uWZ2D8sqWdTN KxLY7e+Gh+gi+oxyUi3k9uJdMoG8bUE9bzLaFYvUUUnU+TniYBLLQmGH/2SlYmmTYsyu PK8A== 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=dl6S2e8Ejt023XPbv1iI7cVSS2l+GoaShhvHi/XlJjQ=; fh=F8lVNpxk98idztpyGcy/LB4Ppx/Sm3/5Xgv6pFU8zyE=; b=LxcLT8y3dVn3UZ6fad8+uBHyWVR7cCov++9rr/ARF3dwcSoWQuQYO1CkvI0exiw4HW D9GRfZJo7WT5YU+eSwhWT3uKsKxCIwPCEcazF7lRrBijRhhbV3sYxid5MvhHselZoVb9 cyju9TePzv38BzeWhESrVaXM273wE+v5QXrpkE1At3I5SEFvy3LkSpNQDNn5fYmnwqtr a58X2j5H6x+qHM4P5oNkbiHmsLxzQm9w8daUQ+TaagXJsLK2XE0OXPA+fFxXa9gx/nuz ZkZu95iihQIVO/kVBcoXwivXdgtR4KQF6fXqYir3rjO0kYEW/uMlPzkMtvKS1uFQazNJ PiuA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b="N5FF/nh3"; 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=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q20-20020a63cc54000000b00563e652b076si5633385pgi.448.2023.08.07.09.59.17; Mon, 07 Aug 2023 09:59:29 -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=@quicinc.com header.s=qcppdkim1 header.b="N5FF/nh3"; 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=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231444AbjHGQfE (ORCPT + 99 others); Mon, 7 Aug 2023 12:35:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42586 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231411AbjHGQfA (ORCPT ); Mon, 7 Aug 2023 12:35:00 -0400 Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 03F1B19AB; Mon, 7 Aug 2023 09:34:29 -0700 (PDT) Received: from pps.filterd (m0279873.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 377FLI70026617; Mon, 7 Aug 2023 16:33:58 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h=message-id : date : mime-version : subject : to : cc : references : from : in-reply-to : content-type : content-transfer-encoding; s=qcppdkim1; bh=dl6S2e8Ejt023XPbv1iI7cVSS2l+GoaShhvHi/XlJjQ=; b=N5FF/nh3NPoJUehVw1mekHTIN/sMhCNhqiTNaIkg361Qwv7W/OBA97vgPSo0D51feDUw rsDhiiLDO3zxTY/31Vc6WYIlQceukJXZm2FY9l3FCzKNiGGp9xk34GC5jcP2GLP9+EmJ 8Twvp6t5i7VQr6G6DQ+1KRAIL0IhV99kOkBnkLE2CGYkX3FFkbFYarudDbQx8731+zsR AIU8tPpemxel/Fle5U8Rvufq7XdvpIiVJyima5YMNys89uhQvKc7yzQ+QubQL6FdRndk Ak/wEDqHA1LjGObe5MS2pvRXZhO6GK7f1MyU8j4gxYiNCC6IiQX+hRVdUMdVZLaAqoqK hw== Received: from nasanppmta04.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3s9bsuv5jx-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 07 Aug 2023 16:33:58 +0000 Received: from nasanex01b.na.qualcomm.com (nasanex01b.na.qualcomm.com [10.46.141.250]) by NASANPPMTA04.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 377GXuuB020164 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 7 Aug 2023 16:33:56 GMT Received: from [10.71.109.168] (10.80.80.8) by nasanex01b.na.qualcomm.com (10.46.141.250) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.30; Mon, 7 Aug 2023 09:33:56 -0700 Message-ID: <6885a107-79da-9001-680a-bbd15286fb7d@quicinc.com> Date: Mon, 7 Aug 2023 09:33:55 -0700 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH RFC v5 02/10] drm: Introduce solid fill DRM plane property Content-Language: en-US To: Sebastian Wick , Dmitry Baryshkov CC: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Rob Clark , Sean Paul , Marijn Suijten , , , , , , , , , , References: <20230728-solid-fill-v5-0-053dbefa909c@quicinc.com> <20230728-solid-fill-v5-2-053dbefa909c@quicinc.com> From: Jessica Zhang In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nasanex01b.na.qualcomm.com (10.46.141.250) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: FoGM4ecD8G4olnbTKbQOC9KVlxtAcmFU X-Proofpoint-ORIG-GUID: FoGM4ecD8G4olnbTKbQOC9KVlxtAcmFU X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.267,Aquarius:18.0.957,Hydra:6.0.591,FMLib:17.11.176.26 definitions=2023-08-07_17,2023-08-03_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 malwarescore=0 clxscore=1015 phishscore=0 lowpriorityscore=0 suspectscore=0 spamscore=0 impostorscore=0 priorityscore=1501 adultscore=0 bulkscore=0 mlxlogscore=999 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2306200000 definitions=main-2308070153 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_NONE,SPF_PASS autolearn=ham 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 8/4/2023 6:40 AM, Sebastian Wick wrote: > On Mon, Jul 31, 2023 at 6:01 AM Dmitry Baryshkov > wrote: >> >> On 28/07/2023 20:02, Jessica Zhang wrote: >>> Document and add support for solid_fill property to drm_plane. In >>> addition, add support for setting and getting the values for solid_fill. >>> >>> To enable solid fill planes, userspace must assign a property blob to >>> the "solid_fill" plane property containing the following information: >>> >>> struct drm_mode_solid_fill { >>> u32 version; >>> u32 r, g, b; >>> }; >>> >>> Signed-off-by: Jessica Zhang >>> --- >>> drivers/gpu/drm/drm_atomic_state_helper.c | 9 +++++ >>> drivers/gpu/drm/drm_atomic_uapi.c | 55 +++++++++++++++++++++++++++++++ >>> drivers/gpu/drm/drm_blend.c | 30 +++++++++++++++++ >>> include/drm/drm_blend.h | 1 + >>> include/drm/drm_plane.h | 35 ++++++++++++++++++++ >>> include/uapi/drm/drm_mode.h | 24 ++++++++++++++ >>> 6 files changed, 154 insertions(+) >>> >>> diff --git a/drivers/gpu/drm/drm_atomic_state_helper.c b/drivers/gpu/drm/drm_atomic_state_helper.c >>> index 01638c51ce0a..86fb876efbe6 100644 >>> --- a/drivers/gpu/drm/drm_atomic_state_helper.c >>> +++ b/drivers/gpu/drm/drm_atomic_state_helper.c >>> @@ -254,6 +254,11 @@ void __drm_atomic_helper_plane_state_reset(struct drm_plane_state *plane_state, >>> 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); >>> + plane_state->solid_fill_blob = NULL; >>> + } >>> + >>> if (plane->color_encoding_property) { >>> if (!drm_object_property_get_default_value(&plane->base, >>> plane->color_encoding_property, >>> @@ -336,6 +341,9 @@ void __drm_atomic_helper_plane_duplicate_state(struct drm_plane *plane, >>> if (state->fb) >>> drm_framebuffer_get(state->fb); >>> >>> + if (state->solid_fill_blob) >>> + drm_property_blob_get(state->solid_fill_blob); >>> + >>> state->fence = NULL; >>> state->commit = NULL; >>> state->fb_damage_clips = NULL; >>> @@ -385,6 +393,7 @@ void __drm_atomic_helper_plane_destroy_state(struct drm_plane_state *state) >>> drm_crtc_commit_put(state->commit); >>> >>> drm_property_blob_put(state->fb_damage_clips); >>> + drm_property_blob_put(state->solid_fill_blob); >>> } >>> EXPORT_SYMBOL(__drm_atomic_helper_plane_destroy_state); >>> >>> diff --git a/drivers/gpu/drm/drm_atomic_uapi.c b/drivers/gpu/drm/drm_atomic_uapi.c >>> index 454f980e16c9..039686c78c2a 100644 >>> --- a/drivers/gpu/drm/drm_atomic_uapi.c >>> +++ b/drivers/gpu/drm/drm_atomic_uapi.c >>> @@ -316,6 +316,51 @@ drm_atomic_set_crtc_for_connector(struct drm_connector_state *conn_state, >>> } >>> EXPORT_SYMBOL(drm_atomic_set_crtc_for_connector); >>> >>> +static int drm_atomic_set_solid_fill_prop(struct drm_plane_state *state, >>> + struct drm_property_blob *blob) >>> +{ >>> + int blob_version; >>> + >>> + if (blob == state->solid_fill_blob) >>> + return 0; >>> + >>> + if (blob) { >>> + struct drm_mode_solid_fill *user_info = (struct drm_mode_solid_fill *)blob->data; >>> + >>> + if (blob->length != sizeof(struct drm_mode_solid_fill)) { >>> + drm_dbg_atomic(state->plane->dev, >>> + "[PLANE:%d:%s] bad solid fill blob length: %zu\n", >>> + state->plane->base.id, state->plane->name, >>> + blob->length); >>> + return -EINVAL; >>> + } >>> + >>> + blob_version = user_info->version; >> >> I remember that we had versioning for quite some time. However it stroke >> me while reviewing that we do not a way to negotiate supported >> SOLID_FILL versions. However as we now have support for different >> pixel_source properties, maybe we can drop version completely. If at >> some point a driver needs to support different kind of SOLID_FILL >> property (consider v2), we can add new pixel source to the enum. > > Agreed. Let's drop the versioning. Acked. Thanks, Jessica Zhang > >> >>> + >>> + /* Add more versions if necessary */ >>> + if (blob_version == 1) { >>> + state->solid_fill.r = user_info->r; >>> + state->solid_fill.g = user_info->g; >>> + state->solid_fill.b = user_info->b; >>> + } else { >>> + drm_dbg_atomic(state->plane->dev, >>> + "[PLANE:%d:%s] unsupported solid fill version (version=%d)\n", >>> + state->plane->base.id, state->plane->name, >>> + blob_version); >>> + return -EINVAL; >>> + } >>> + } >>> + >>> + drm_property_blob_put(state->solid_fill_blob); >>> + >>> + if (blob) >>> + state->solid_fill_blob = drm_property_blob_get(blob); >>> + else >>> + state->solid_fill_blob = NULL; >>> + >>> + return 0; >>> +} >>> + >>> static void set_out_fence_for_crtc(struct drm_atomic_state *state, >>> struct drm_crtc *crtc, s32 __user *fence_ptr) >>> { >>> @@ -546,6 +591,13 @@ static int drm_atomic_plane_set_property(struct drm_plane *plane, >>> state->src_h = val; >>> } else if (property == plane->pixel_source_property) { >>> state->pixel_source = val; >>> + } else if (property == plane->solid_fill_property) { >>> + struct drm_property_blob *solid_fill = drm_property_lookup_blob(dev, val); >>> + >>> + ret = drm_atomic_set_solid_fill_prop(state, solid_fill); >>> + drm_property_blob_put(solid_fill); >>> + >>> + return ret; >> >> Bonus point: dropping version from SOLID_FILL would allow us to use >> drm_atomic_replace_property_blob_from_id() here. >> >>> } else if (property == plane->alpha_property) { >>> state->alpha = val; >>> } else if (property == plane->blend_mode_property) { >>> @@ -620,6 +672,9 @@ drm_atomic_plane_get_property(struct drm_plane *plane, >>> *val = state->src_h; >>> } else if (property == plane->pixel_source_property) { >>> *val = state->pixel_source; >>> + } else if (property == plane->solid_fill_property) { >>> + *val = state->solid_fill_blob ? >>> + state->solid_fill_blob->base.id : 0; >>> } 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 c500310a3d09..c632dfcd8a9b 100644 >>> --- a/drivers/gpu/drm/drm_blend.c >>> +++ b/drivers/gpu/drm/drm_blend.c >>> @@ -200,6 +200,10 @@ >>> * "FB": >>> * Framebuffer source set by the "FB_ID" property. >>> * >>> + * solid_fill: >>> + * solid_fill is set up with drm_plane_create_solid_fill_property(). It >>> + * contains pixel data that drivers can use to fill a plane. >>> + * >>> * 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). >>> @@ -700,3 +704,29 @@ int drm_plane_create_pixel_source_property(struct drm_plane *plane, >>> return 0; >>> } >>> EXPORT_SYMBOL(drm_plane_create_pixel_source_property); >>> + >>> +/** >>> + * drm_plane_create_solid_fill_property - create a new solid_fill property >>> + * @plane: drm plane >>> + * >>> + * This creates a new property blob that holds pixel data for solid fill planes. >>> + * The property is exposed to userspace as a property blob called "solid_fill". >>> + * >>> + * For information on what the blob contains, see `drm_mode_solid_fill`. >>> + */ >>> +int drm_plane_create_solid_fill_property(struct drm_plane *plane) >>> +{ >>> + struct drm_property *prop; >>> + >>> + prop = drm_property_create(plane->dev, >>> + DRM_MODE_PROP_ATOMIC | DRM_MODE_PROP_BLOB, >>> + "solid_fill", 0); >>> + if (!prop) >>> + return -ENOMEM; >>> + >>> + drm_object_attach_property(&plane->base, prop, 0); >>> + plane->solid_fill_property = prop; >>> + >>> + return 0; >>> +} >>> +EXPORT_SYMBOL(drm_plane_create_solid_fill_property); >>> diff --git a/include/drm/drm_blend.h b/include/drm/drm_blend.h >>> index 122bbfbaae33..e7158fbee389 100644 >>> --- a/include/drm/drm_blend.h >>> +++ b/include/drm/drm_blend.h >>> @@ -60,4 +60,5 @@ int drm_plane_create_blend_mode_property(struct drm_plane *plane, >>> unsigned int supported_modes); >>> int drm_plane_create_pixel_source_property(struct drm_plane *plane, >>> unsigned long extra_sources); >>> +int drm_plane_create_solid_fill_property(struct drm_plane *plane); >>> #endif >>> diff --git a/include/drm/drm_plane.h b/include/drm/drm_plane.h >>> index 89508b4dea4a..abf1458fa099 100644 >>> --- a/include/drm/drm_plane.h >>> +++ b/include/drm/drm_plane.h >>> @@ -46,6 +46,17 @@ enum drm_plane_pixel_source { >>> DRM_PLANE_PIXEL_SOURCE_MAX >>> }; >>> >>> +/** >>> + * struct solid_fill_property - RGB values for solid fill plane >>> + * >>> + * Note: This is the V1 for this feature >>> + */ >>> +struct drm_solid_fill { >>> + uint32_t r; >>> + uint32_t g; >>> + uint32_t b; >>> +}; >>> + >>> /** >>> * struct drm_plane_state - mutable plane state >>> * >>> @@ -130,6 +141,23 @@ struct drm_plane_state { >>> */ >>> enum drm_plane_pixel_source pixel_source; >>> >>> + /** >>> + * @solid_fill_blob: >>> + * >>> + * Blob containing relevant information for a solid fill plane >>> + * including pixel format and data. See >>> + * drm_plane_create_solid_fill_property() for more details. >>> + */ >>> + struct drm_property_blob *solid_fill_blob; >>> + >>> + /** >>> + * @solid_fill: >>> + * >>> + * Pixel data for solid fill planes. See >>> + * drm_plane_create_solid_fill_property() for more details. >>> + */ >>> + struct drm_solid_fill solid_fill; >>> + >>> /** >>> * @alpha: >>> * Opacity of the plane with 0 as completely transparent and 0xffff as >>> @@ -720,6 +748,13 @@ struct drm_plane { >>> */ >>> struct drm_property *pixel_source_property; >>> >>> + /** >>> + * @solid_fill_property: >>> + * Optional solid_fill property for this plane. See >>> + * drm_plane_create_solid_fill_property(). >>> + */ >>> + struct drm_property *solid_fill_property; >>> + >>> /** >>> * @alpha_property: >>> * Optional alpha property for this plane. See >>> diff --git a/include/uapi/drm/drm_mode.h b/include/uapi/drm/drm_mode.h >>> index 43691058d28f..53c8efa5ad7f 100644 >>> --- a/include/uapi/drm/drm_mode.h >>> +++ b/include/uapi/drm/drm_mode.h >>> @@ -259,6 +259,30 @@ struct drm_mode_modeinfo { >>> char name[DRM_DISPLAY_MODE_LEN]; >>> }; >>> >>> +/** >>> + * struct drm_mode_solid_fill - User info for solid fill planes >>> + * >>> + * This is the userspace API solid fill information structure. >>> + * >>> + * Userspace can enable solid fill planes by assigning the plane "solid_fill" >>> + * property to a blob containing a single drm_mode_solid_fill struct populated with an RGB323232 >>> + * color and setting the pixel source to "SOLID_FILL". >>> + * >>> + * For information on the plane property, see drm_plane_create_solid_fill_property() >>> + * >>> + * @version: Version of the blob. Currently, there is only support for version == 1 >>> + * @r: Red color value of single pixel >>> + * @g: Green color value of single pixel >>> + * @b: Blue color value of single pixel >>> + */ >>> +struct drm_mode_solid_fill { >>> + __u32 version; >>> + __u32 r; >>> + __u32 g; >>> + __u32 b; >>> +}; >>> + >>> + >>> struct drm_mode_card_res { >>> __u64 fb_id_ptr; >>> __u64 crtc_id_ptr; >>> >> >> -- >> With best wishes >> Dmitry >> >