Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp1499713rdh; Mon, 25 Sep 2023 15:02:14 -0700 (PDT) X-Google-Smtp-Source: AGHT+IG1lu5Sgm083NTALyca8GZVOK33rqzCNQ5fWa0gSLZPnqC/VEoL8Bg45lJnLC9TUHWggLyl X-Received: by 2002:a05:6a20:a110:b0:148:f952:552b with SMTP id q16-20020a056a20a11000b00148f952552bmr10073794pzk.51.1695679334311; Mon, 25 Sep 2023 15:02:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695679334; cv=none; d=google.com; s=arc-20160816; b=vcajjvD1CqAm0LmlCsQhPTlIb/sdCTNDooxxq0Mu2nUCvfQR0nuGNUuVIZ71UnNXln J/YcXbAe5tHknF+uAnrZTbZufrflVgnwrZNcF47Q0eGEyAO9FdzOY52306EQNolMTaTU xvA9vIjVRv3DH0A/IXkErWZ08I4dg3iCmWjwIMHCtLlQ3Y8yrGt6SXErX2TZ7D+uD/j9 WNP+U9fOUA8oRS6J4ObcYznPBYaw1YNLGWM0/5d9P5M5xpSpuRV2gIrdutWEemYcSygR CkzvWvn9Dv2jNrIvolPrkcCRX4iZ1KO4P1b6r8bmM9nlwY3Okq2YSKiqMAgLg3RYQB5/ Ykjg== 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=NKcdicweB9SW4tRwHH9GymH3cRH2ykJJRNqn7NSBMrs=; fh=OtHlbOOWAgxChXwKiKRoWFnAJwsOV4sGZVP0moMAaJw=; b=CtrY973iC2QPuH1VvAZ8wY+d0VtTwW9DXPSeh+mb6zaZYwDkeZL6eyo2blnvWXs72m Q/lYIHGQCgB2THPaX1m2YHyTjo8xcdrga/Byf4oN0q0MmgkHaFnGeJxL8lB+HmjGftzI kkcc4LzDgjDF3q3SqbGfuIVwzj6eOwvFeEUS0D9+4P1/mqhxywGjAgZ27eg/LPNwO47r lL39R10qnMHK4+R2gFvI2+oC+4e+E1aJle0ewGGAIkerCaC65IKasPVxUIlI9rL/8zFo GiZU21MinkJpC/1fsFNFOJoCG6xmFA6m1Lg09douf6QhAQro05PNIBdIr53xlRg6F34a YBlQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=TH6G67XY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id j3-20020a170903028300b001c0f0103e96si2701281plr.71.2023.09.25.15.02.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Sep 2023 15:02:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=TH6G67XY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 81C1C8247746; Mon, 25 Sep 2023 02:13:53 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232754AbjIYJNz (ORCPT + 99 others); Mon, 25 Sep 2023 05:13:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40030 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232574AbjIYJNy (ORCPT ); Mon, 25 Sep 2023 05:13:54 -0400 Received: from madras.collabora.co.uk (madras.collabora.co.uk [46.235.227.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 87B4F9B; Mon, 25 Sep 2023 02:13:47 -0700 (PDT) Received: from [192.168.1.100] (2-237-20-237.ip236.fastwebnet.it [2.237.20.237]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: kholk11) by madras.collabora.co.uk (Postfix) with ESMTPSA id 7861366072FF; Mon, 25 Sep 2023 10:13:45 +0100 (BST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1695633226; bh=G+i7ey/TdIsiQ6r9kJEi+gBjHgvwqjQdIaKtDxCh6uI=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=TH6G67XYd7ZH2TraAeKivPSL/LNq8WEJumbUczTJjdsPKV09F0whFgko0ItKOseW8 DMVWjJwds4yXF3QsDBpPFfXkbSXf6vzdAWH7cpXxp4NTKXp+tdRL60WPZ4c4A2llaZ 3FCp+8s8rmkN9AjD28u2BxlGSNDc7tcMxxWgi6tjaa4x6hz8kIetv+Fh2lq/zwHNzd P+Hcr0u8tt/0b1fy/BM7yM6iaVSU8W7OuqmEyA2GbnR/DSdFrSHJbGC/3sARlcqOs1 LYCdOykCqZbhv8Wkmve+aCYCLW189tDHEm0fkpXpEV1iZlk+l5uYX2sRnK9tJc0nt7 ubZ3VmW6RaZ6Q== Message-ID: <6df2b962-fa21-d58f-7f39-fe46d049f97e@collabora.com> Date: Mon, 25 Sep 2023 11:13:43 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.15.0 Subject: Re: [PATCH] media: mediatek: vcodec: add encoder power management helper functions Content-Language: en-US To: Irui Wang , Hans Verkuil , Mauro Carvalho Chehab , Matthias Brugger , Yunfei Dong Cc: Project_Global_Chrome_Upstream_Group@mediatek.com, linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, Maoguang Meng References: <20230925040200.18220-1-irui.wang@mediatek.com> From: AngeloGioacchino Del Regno In-Reply-To: <20230925040200.18220-1-irui.wang@mediatek.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.6 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Mon, 25 Sep 2023 02:13:53 -0700 (PDT) Il 25/09/23 06:02, Irui Wang ha scritto: > Remove PM functions at start/stop streaming, add PM helper functions > to get PM before encoding frame start and put PM after encoding frame > done. Meanwhile, remove unnecessary clock operations. > > Signed-off-by: Irui Wang > --- > .../mediatek/vcodec/encoder/mtk_vcodec_enc.c | 21 +++---------------- > .../vcodec/encoder/mtk_vcodec_enc_pm.c | 18 ++++++++++++++++ > .../vcodec/encoder/mtk_vcodec_enc_pm.h | 3 ++- > .../mediatek/vcodec/encoder/venc_drv_if.c | 8 ++----- > 4 files changed, 25 insertions(+), 25 deletions(-) > > diff --git a/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc.c b/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc.c > index 04948d3eb011..eb381fa6e7d1 100644 > --- a/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc.c > +++ b/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc.c > @@ -866,7 +866,7 @@ static int vb2ops_venc_start_streaming(struct vb2_queue *q, unsigned int count) > { > struct mtk_vcodec_enc_ctx *ctx = vb2_get_drv_priv(q); > struct venc_enc_param param; > - int ret, pm_ret; > + int ret; > int i; > > /* Once state turn into MTK_STATE_ABORT, we need stop_streaming > @@ -886,18 +886,12 @@ static int vb2ops_venc_start_streaming(struct vb2_queue *q, unsigned int count) > return 0; > } > > - ret = pm_runtime_resume_and_get(&ctx->dev->plat_dev->dev); > - if (ret < 0) { > - mtk_v4l2_venc_err(ctx, "pm_runtime_resume_and_get fail %d", ret); > - goto err_start_stream; > - } > - > mtk_venc_set_param(ctx, ¶m); > ret = venc_if_set_param(ctx, VENC_SET_PARAM_ENC, ¶m); > if (ret) { > mtk_v4l2_venc_err(ctx, "venc_if_set_param failed=%d", ret); > ctx->state = MTK_STATE_ABORT; > - goto err_set_param; > + goto err_start_stream; > } > ctx->param_change = MTK_ENCODE_PARAM_NONE; > > @@ -910,18 +904,13 @@ static int vb2ops_venc_start_streaming(struct vb2_queue *q, unsigned int count) > if (ret) { > mtk_v4l2_venc_err(ctx, "venc_if_set_param failed=%d", ret); > ctx->state = MTK_STATE_ABORT; > - goto err_set_param; > + goto err_start_stream; > } > ctx->state = MTK_STATE_HEADER; > } > > return 0; > > -err_set_param: > - pm_ret = pm_runtime_put(&ctx->dev->plat_dev->dev); > - if (pm_ret < 0) > - mtk_v4l2_venc_err(ctx, "pm_runtime_put fail %d", pm_ret); > - > err_start_stream: > for (i = 0; i < q->num_buffers; ++i) { > struct vb2_buffer *buf = vb2_get_buffer(q, i); > @@ -1004,10 +993,6 @@ static void vb2ops_venc_stop_streaming(struct vb2_queue *q) > if (ret) > mtk_v4l2_venc_err(ctx, "venc_if_deinit failed=%d", ret); > > - ret = pm_runtime_put(&ctx->dev->plat_dev->dev); > - if (ret < 0) > - mtk_v4l2_venc_err(ctx, "pm_runtime_put fail %d", ret); > - > ctx->state = MTK_STATE_FREE; > } > > diff --git a/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.c b/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.c > index 3fce936e61b9..a22b7dfc656e 100644 > --- a/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.c > +++ b/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.c > @@ -58,6 +58,24 @@ int mtk_vcodec_init_enc_clk(struct mtk_vcodec_enc_dev *mtkdev) > return 0; > } > > +void mtk_vcodec_enc_pw_on(struct mtk_vcodec_pm *pm) > +{ > + int ret; > + > + ret = pm_runtime_resume_and_get(pm->dev); > + if (ret) > + dev_err(pm->dev, "pm_runtime_resume_and_get fail: %d", ret); > +} Those are exactly the same functions as the DECODER counterpart... instead of duplicating them, can you please simply commonize the functions in mtk_vcodec_dec_pm.c ? Regards, Angelo > + > +void mtk_vcodec_enc_pw_off(struct mtk_vcodec_pm *pm) > +{ > + int ret; > + > + ret = pm_runtime_put(pm->dev); > + if (ret && ret != -EAGAIN) > + dev_err(pm->dev, "pm_runtime_put fail %d", ret); > +} > + > void mtk_vcodec_enc_clock_on(struct mtk_vcodec_pm *pm) > { > struct mtk_vcodec_clk *enc_clk = &pm->venc_clk; > diff --git a/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.h b/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.h > index e50be0575190..157ea08ba9e3 100644 > --- a/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.h > +++ b/drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_pm.h > @@ -10,7 +10,8 @@ > #include "mtk_vcodec_enc_drv.h" > > int mtk_vcodec_init_enc_clk(struct mtk_vcodec_enc_dev *dev); > - > +void mtk_vcodec_enc_pw_on(struct mtk_vcodec_pm *pm); > +void mtk_vcodec_enc_pw_off(struct mtk_vcodec_pm *pm); > void mtk_vcodec_enc_clock_on(struct mtk_vcodec_pm *pm); > void mtk_vcodec_enc_clock_off(struct mtk_vcodec_pm *pm); > > diff --git a/drivers/media/platform/mediatek/vcodec/encoder/venc_drv_if.c b/drivers/media/platform/mediatek/vcodec/encoder/venc_drv_if.c > index 1bdaecdd64a7..c402a686f3cb 100644 > --- a/drivers/media/platform/mediatek/vcodec/encoder/venc_drv_if.c > +++ b/drivers/media/platform/mediatek/vcodec/encoder/venc_drv_if.c > @@ -32,9 +32,7 @@ int venc_if_init(struct mtk_vcodec_enc_ctx *ctx, unsigned int fourcc) > } > > mtk_venc_lock(ctx); > - mtk_vcodec_enc_clock_on(&ctx->dev->pm); > ret = ctx->enc_if->init(ctx); > - mtk_vcodec_enc_clock_off(&ctx->dev->pm); > mtk_venc_unlock(ctx); > > return ret; > @@ -46,9 +44,7 @@ int venc_if_set_param(struct mtk_vcodec_enc_ctx *ctx, > int ret = 0; > > mtk_venc_lock(ctx); > - mtk_vcodec_enc_clock_on(&ctx->dev->pm); > ret = ctx->enc_if->set_param(ctx->drv_handle, type, in); > - mtk_vcodec_enc_clock_off(&ctx->dev->pm); > mtk_venc_unlock(ctx); > > return ret; > @@ -68,10 +64,12 @@ int venc_if_encode(struct mtk_vcodec_enc_ctx *ctx, > ctx->dev->curr_ctx = ctx; > spin_unlock_irqrestore(&ctx->dev->irqlock, flags); > > + mtk_vcodec_enc_pw_on(&ctx->dev->pm); > mtk_vcodec_enc_clock_on(&ctx->dev->pm); > ret = ctx->enc_if->encode(ctx->drv_handle, opt, frm_buf, > bs_buf, result); > mtk_vcodec_enc_clock_off(&ctx->dev->pm); > + mtk_vcodec_enc_pw_off(&ctx->dev->pm); > > spin_lock_irqsave(&ctx->dev->irqlock, flags); > ctx->dev->curr_ctx = NULL; > @@ -89,9 +87,7 @@ int venc_if_deinit(struct mtk_vcodec_enc_ctx *ctx) > return 0; > > mtk_venc_lock(ctx); > - mtk_vcodec_enc_clock_on(&ctx->dev->pm); > ret = ctx->enc_if->deinit(ctx->drv_handle); > - mtk_vcodec_enc_clock_off(&ctx->dev->pm); > mtk_venc_unlock(ctx); > > ctx->drv_handle = NULL;