Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp5136059ybl; Mon, 26 Aug 2019 23:24:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqzNFaHku4m7d3yQHpsBgHOCLyMFg7rjem0ATQCx5zEBZgLSN3/l86YNjyUHEkxXgkHL1nae X-Received: by 2002:a17:902:f095:: with SMTP id go21mr23228558plb.216.1566887067043; Mon, 26 Aug 2019 23:24:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566887067; cv=none; d=google.com; s=arc-20160816; b=oGo9z+CeMo+Brjb4A39esqKsm+wpsBlwsIksHsZ2XjKbTlZXDV8P8lyFV9tLNZjlRP Z2mzTOwPj5YnmXOv+Sv6wr82N6lblzf8Zwpv0O0PEeVduKzD1JZ29J/B6oNYdzV+6meH XDdNQAGF0cCThPVNlMTpj0LVdcgPepGJhOBfGuMIod0StLyotQXQVFO7IEcrPVmltMqp LdEw/DrKn9MYsEqKp3+bb0GLzJ8UxFsgamKk9UM0oxucFKKz8eYwsXGqUmDNloX+AHAg 2QpqodYk8j7PFT7UYTc69bcxWWCPcg9ixSB5WdgIg+NUrTe0wQOHIlspgooHi6DZYJL7 PNGQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dmarc-filter:dkim-signature:dkim-signature; bh=B6lA9cwJ7A15b160SNgl0dEpG8ZxXTjU5LVVwepFvYk=; b=Eyzc004Jw22w1kY6w9N/vYgHgMLm3wWK0qqjkm+tqc8ipw7nFYmkoBNsWvL1MFLNQ7 DXPgPfQ2YsQXZLCFI+ZlHgDXwBiNCZCy0PWWqJwo78cROnIki8T4XvGMpXaF1h3mGKtA qUmYR9a4fVFyQhdpsSgfjxZgtaoQQX3bhEvqETGoLEfA0JqMIzHHVdPf641oQGMovVX5 UI8h1DL1htzZCj2JJzUgPRgZ7XH06hVSzkHSyZtH3WD9eKYwkIBI7KrwPDewhfNIPgOk BeqUyVJfg4LNzBW/+PWTjpRkbqbZr+owJoQJY++CR5dAEHAnKUh7wTWmKg9vlPMxzahb kRWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=mEw+pjhC; dkim=pass header.i=@codeaurora.org header.s=default header.b=mEw+pjhC; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j191si10904091pgd.88.2019.08.26.23.24.11; Mon, 26 Aug 2019 23:24:27 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=mEw+pjhC; dkim=pass header.i=@codeaurora.org header.s=default header.b=mEw+pjhC; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727255AbfH0GXS (ORCPT + 99 others); Tue, 27 Aug 2019 02:23:18 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:59420 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725825AbfH0GXS (ORCPT ); Tue, 27 Aug 2019 02:23:18 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id C15BD60DAB; Tue, 27 Aug 2019 06:23:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1566886996; bh=8JDB7XEGpzAup5vhaZHeRs9FwAfWZJ2300GU6dey8g0=; h=From:To:Cc:Subject:Date:From; b=mEw+pjhC20Hs5D3av8Yqr+CtjJesRRC3MOHxE1RrtsIMK4O/U3rfs5HocUZW1DS7/ bl8LfX07Ccwf2K+02pLwxuFJPPhvFBJxqhg9meEi9F6N1y5gkZGqOZbVjHm7MvaGQ0 StEQJeGOVYtvcvd4Szgy8/jAs0vIc5raF/CpH0TM= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED,SPF_NONE autolearn=no autolearn_force=no version=3.4.0 Received: from amasule-linux.qualcomm.com (blr-c-bdr-fw-01_globalnat_allzones-outside.qualcomm.com [103.229.19.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: amasule@codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id E504860CEC; Tue, 27 Aug 2019 06:23:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1566886996; bh=8JDB7XEGpzAup5vhaZHeRs9FwAfWZJ2300GU6dey8g0=; h=From:To:Cc:Subject:Date:From; b=mEw+pjhC20Hs5D3av8Yqr+CtjJesRRC3MOHxE1RrtsIMK4O/U3rfs5HocUZW1DS7/ bl8LfX07Ccwf2K+02pLwxuFJPPhvFBJxqhg9meEi9F6N1y5gkZGqOZbVjHm7MvaGQ0 StEQJeGOVYtvcvd4Szgy8/jAs0vIc5raF/CpH0TM= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org E504860CEC Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=amasule@codeaurora.org From: Aniket Masule To: linux-media@vger.kernel.org, stanimir.varbanov@linaro.org Cc: linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, vgarodia@codeaurora.org, Aniket Masule Subject: [PATCH v7 0/3] media: venus: Update clock scaling Date: Tue, 27 Aug 2019 11:53:03 +0530 Message-Id: <1566886986-10329-1-git-send-email-amasule@codeaurora.org> X-Mailer: git-send-email 1.9.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In this patch series, clock scaling and core selection methods are updated. Current clock scaling is same for vpu4 and previous versions. Introducing load calculations using vpp cycles, which indicates the cycles required by video hardware to process each macroblock. Also adding vsp cycles, cycles require by stream processor. Clock scaling is now done more precisely using vpp and vsp cycles. Removing core selection from this series, there will be separate patch once issue related to power domain is fixed. This patch depends on the following patches: https://lore.kernel.org/patchwork/patch/1114762/ - Venus interconnect support for sdm845 https://lore.kernel.org/patchwork/patch/1114761/ - Venus interconnect support for sdm845 Changes since v6: - Removed core selection. - Corrected frequency calculations. - Removed instance lock used while iterating over buffers. Changes since v5: - Corrected load_per_core calculations. Changes since v4: - Added call to load_scale_clocks from venus_helper_vb2_buf_queue. - Modified check to match core_id in core_selection. Changes since v3: - vsp_cycles and vpp_cyles are now unsigned long. - Core number counting aligned with VIDC_CORE_ID_. - Aligned hardware overload handling of scale_clocks_v4 with scale_clocks. - Added bitrate based clock scaling patch in this patch series. - Instance state check is now moved from scale_clocks to load_scale_clocks Aniket Masule (3): media: venus: Add codec data table media: venus: Update clock scaling media: venus: Update to bitrate based clock scaling drivers/media/platform/qcom/venus/core.c | 13 ++ drivers/media/platform/qcom/venus/core.h | 16 +++ drivers/media/platform/qcom/venus/helpers.c | 188 +++++++++++++++++++++++++--- drivers/media/platform/qcom/venus/helpers.h | 3 +- drivers/media/platform/qcom/venus/vdec.c | 8 +- drivers/media/platform/qcom/venus/venc.c | 4 + 6 files changed, 209 insertions(+), 23 deletions(-) -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project