Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp2464084rdb; Fri, 8 Dec 2023 08:51:13 -0800 (PST) X-Google-Smtp-Source: AGHT+IFretkP/4rfNNc4exhiOS8JiBSykfmb+458+Bn5jJ+tXGVWaFDA1spspD2AcyslsNsg/LtI X-Received: by 2002:a05:6358:cb1f:b0:170:261a:7097 with SMTP id gr31-20020a056358cb1f00b00170261a7097mr183503rwb.41.1702054273276; Fri, 08 Dec 2023 08:51:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702054273; cv=none; d=google.com; s=arc-20160816; b=tvl6UGfj4gNRf38UFaLgAnkN5fln1MAvINAgAX36suizenNxsCYIJ+poNBZmxO6xAD TfF+POyzRReIvT+N+w4pg7417HVXzr54TKKl9WMurWgB066Q5mVV4KwWMLElw94LcX4X sRSoa7eO26iQ14anlq4VoYx8nKifMUE8PsKFfgcxQv8sd17cP1YNh1chwvlKXK5S1LwC Yxu8lCHSP9d0igc7XS990ogAxG0+f1hM69RA6X5PIm/ftBxpyanWpFRUq2IrAfhgpx10 /YAayt7g8atBfo4yxDD7PNcRt6WXM3/S1yoAgg3QKrm9hI0mu6ZpXxXsbMAvAac5gxh4 7I8A== 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=d7iaiuLnTs1nTerRivXfsPIu2c4lLoqHhnJU4Qwcqx0=; fh=1F4O3yHu21T8QLdQ5GUr4CAXJeBqSHcVm6pPyoYFBOY=; b=MUCj/UefKZfgFcxYwDvRVwbGKvGq/iOvu9HKtJKM9AcdkphRQnCZWz3EqiJjFF3eqI WiSRt07kqrDyUzQVfKdotfimSv2bn6pvQLFPzzgYT1H7vp5ZLBpUyzT6P2FmsQPm+KL1 jqISikXP0fZpD/DRZz9us1Nlb0lwukIHMc44tsrvgMnMXGTR1u/LQH3nAAvFXWQju8KS gRRV0YZB+c1DZ02xf88p2SDDa/M6Sd0KbJCsq7J9mJPOMQOb8gWyBCj/OarHfohdNiHc iZOG5zIxf3qHcXzsxmIupg76WGyLfENJJKb6gLusSSpn+pzJG+6USI8UkHqk9UT5jZ54 Jf+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b="JMRR/+Ev"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 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 lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id t18-20020a63eb12000000b005c663b4fcc5si1731669pgh.458.2023.12.08.08.51.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 08 Dec 2023 08:51:13 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b="JMRR/+Ev"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 8A48680697FE; Fri, 8 Dec 2023 08:50:41 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233678AbjLHQu0 (ORCPT + 99 others); Fri, 8 Dec 2023 11:50:26 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53798 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233671AbjLHQuW (ORCPT ); Fri, 8 Dec 2023 11:50:22 -0500 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3FEBA122; Fri, 8 Dec 2023 08:50:28 -0800 (PST) Received: from pps.filterd (m0279863.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 3B8Ghibg013101; Fri, 8 Dec 2023 16:50:21 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=d7iaiuLnTs1nTerRivXfsPIu2c4lLoqHhnJU4Qwcqx0=; b=JMRR/+EvFWStI5Rl+13oe9fZUwwrTxIFcOx6Z0VeOwc9Y1yIOO0MPa54eq5MEMPYFHDs HgU+a+edGcrmWLbVhVBfecqsoCFPXI1mQFm3rguJaO7H/to1n9DbarkgCB1Fd1Zb8zGl co9+PZN7LIWxb6wtNbhdqn0AiER9z/eY4dMPo1xXKfIMX7gpI5QlpUsLnv6zF5WPQj+6 WFMGKBC+LnZiMAIs32cgvbMddYS3/MuyddYcdeWzL9K9u9sECX8Cse3LKSZ7nxyORvnx KRCyJdkU5ISxLYbrv7RFp1DNpLYM56YGlTDciIgurTq9HRwyHoAFD2IKmxr34YTietco qQ== Received: from nalasppmta03.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3uux1998d5-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 08 Dec 2023 16:50:20 +0000 Received: from nalasex01a.na.qualcomm.com (nalasex01a.na.qualcomm.com [10.47.209.196]) by NALASPPMTA03.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 3B8GoKsH027427 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 8 Dec 2023 16:50:20 GMT Received: from [10.110.30.94] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.40; Fri, 8 Dec 2023 08:50:17 -0800 Message-ID: <0484fef8-872d-a5cd-cafa-307b93487d2c@quicinc.com> Date: Fri, 8 Dec 2023 08:50:15 -0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.11.0 Subject: Re: [PATCH v2 14/16] drm/msm/dpu: reserve cdm blocks for writeback in case of YUV output Content-Language: en-US To: Dmitry Baryshkov CC: , Rob Clark , "Sean Paul" , Marijn Suijten , "David Airlie" , Daniel Vetter , , , , , References: <20231208050641.32582-1-quic_abhinavk@quicinc.com> <20231208050641.32582-15-quic_abhinavk@quicinc.com> <188e0168-a45b-6e38-ac49-8b0fd41e9110@quicinc.com> From: Abhinav Kumar In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: _7QgQ0c9S1qlfJbGyQvnj8KrZNxY3_dJ X-Proofpoint-ORIG-GUID: _7QgQ0c9S1qlfJbGyQvnj8KrZNxY3_dJ X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.997,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2023-12-08_11,2023-12-07_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 malwarescore=0 clxscore=1015 lowpriorityscore=0 suspectscore=0 bulkscore=0 phishscore=0 impostorscore=0 spamscore=0 priorityscore=1501 adultscore=0 mlxlogscore=999 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2311290000 definitions=main-2312080139 X-Spam-Status: No, score=-3.0 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Fri, 08 Dec 2023 08:50:41 -0800 (PST) On 12/8/2023 8:38 AM, Dmitry Baryshkov wrote: > On Fri, 8 Dec 2023 at 18:34, Abhinav Kumar wrote: >> >> >> >> On 12/8/2023 3:54 AM, Dmitry Baryshkov wrote: >>> On Fri, 8 Dec 2023 at 07:07, Abhinav Kumar wrote: >>>> >>>> Reserve CDM blocks for writeback if the format of the output fb >>>> is YUV. At the moment, the reservation is done only for writeback >>>> but can easily be extended by relaxing the checks once other >>>> interfaces are ready to output YUV. >>>> >>>> changes in v2: >>>> - use needs_cdm from topology struct >>>> - drop fb related checks from atomic_mode_set() >>> >>> It looks like this should be squashed with the patch 11. The 'unbind >>> CDM' doesn't really make sense without this patch. We need to allocate >>> it first, before touching it. >>> >> >> The way I was thinking was that patch just completes the >> dpu_encoder_phys_cleanup() and yes it was intentionally kept ahead >> because that will not kick in till hw_cdm is assigned. >> >> Then, this patch only handles reserving/assignment of hw_cdm when needed. >> >> That was the motivation behind this split. > > It leaves a leaf code that is not used at all. There is no need to > cleanup anything if it was not allocated. Please remove the split and > squash it with allocation. > Ack. No concerns with squashing them. >> >>>> >>>> Signed-off-by: Abhinav Kumar >>>> --- >>>> drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.c | 27 +++++++++++++++++++++ >>>> 1 file changed, 27 insertions(+) >>>> >>>> diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.c b/drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.c >>>> index 862912727925..a576e3e62429 100644 >>>> --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.c >>>> +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_encoder.c >>>> @@ -16,6 +16,7 @@ >>>> #include >>>> #include >>>> #include >>>> +#include >>>> >>>> #include "msm_drv.h" >>>> #include "dpu_kms.h" >>>> @@ -583,6 +584,7 @@ static int dpu_encoder_virt_atomic_check( >>>> struct drm_display_mode *adj_mode; >>>> struct msm_display_topology topology; >>>> struct dpu_global_state *global_state; >>>> + struct drm_framebuffer *fb; >>>> struct drm_dsc_config *dsc; >>>> int i = 0; >>>> int ret = 0; >>>> @@ -623,6 +625,22 @@ static int dpu_encoder_virt_atomic_check( >>>> >>>> topology = dpu_encoder_get_topology(dpu_enc, dpu_kms, adj_mode, crtc_state, dsc); >>>> >>>> + /* >>>> + * Use CDM only for writeback at the moment as other interfaces cannot handle it. >>>> + * if writeback itself cannot handle cdm for some reason it will fail in its atomic_check() >>>> + * earlier. >>>> + */ >>>> + if (dpu_enc->disp_info.intf_type == INTF_WB && conn_state->writeback_job) { >>>> + fb = conn_state->writeback_job->fb; >>>> + >>>> + if (fb && DPU_FORMAT_IS_YUV(to_dpu_format(msm_framebuffer_format(fb)))) >>>> + topology.needs_cdm = true; >>>> + if (topology.needs_cdm && !dpu_enc->cur_master->hw_cdm) >>>> + crtc_state->mode_changed = true; >>>> + else if (!topology.needs_cdm && dpu_enc->cur_master->hw_cdm) >>>> + crtc_state->mode_changed = true; >>>> + } >>>> + >>>> /* >>>> * Release and Allocate resources on every modeset >>>> * Dont allocate when active is false. >>>> @@ -1063,6 +1081,15 @@ static void dpu_encoder_virt_atomic_mode_set(struct drm_encoder *drm_enc, >>>> >>>> dpu_enc->dsc_mask = dsc_mask; >>>> >>>> + if (dpu_enc->disp_info.intf_type == INTF_WB && conn_state->writeback_job) { >>>> + struct dpu_hw_blk *hw_cdm = NULL; >>>> + >>>> + dpu_rm_get_assigned_resources(&dpu_kms->rm, global_state, >>>> + drm_enc->base.id, DPU_HW_BLK_CDM, >>>> + &hw_cdm, 1); >>>> + dpu_enc->cur_master->hw_cdm = hw_cdm ? to_dpu_hw_cdm(hw_cdm) : NULL; >>>> + } >>>> + >>>> cstate = to_dpu_crtc_state(crtc_state); >>>> >>>> for (i = 0; i < num_lm; i++) { >>>> -- >>>> 2.40.1 >>>> >>> >>> >>> -- >>> With best wishes >>> >>> Dmitry > > >