From patchwork Thu May 27 23:53:59 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dmitry Osipenko X-Patchwork-Id: 449198 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-10.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, SPF_HELO_NONE, SPF_PASS, USER_AGENT_GIT autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 12C28C4708C for ; Thu, 27 May 2021 23:54:22 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id E6D8B613E2 for ; Thu, 27 May 2021 23:54:21 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236252AbhE0Xzy (ORCPT ); Thu, 27 May 2021 19:55:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34670 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233938AbhE0Xzx (ORCPT ); Thu, 27 May 2021 19:55:53 -0400 Received: from mail-lf1-x135.google.com (mail-lf1-x135.google.com [IPv6:2a00:1450:4864:20::135]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 88023C061574; Thu, 27 May 2021 16:54:19 -0700 (PDT) Received: by mail-lf1-x135.google.com with SMTP id v8so2626562lft.8; Thu, 27 May 2021 16:54:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=l1cOQ7Sld9+WDtqhKXFGTGRhUcmsdeCO/MC/bWS5WC4=; b=W5qjZ/7W8JNXpNKFCI5yWQx/b7GgJCkDM4LnuZWo8IzbBijOxfXC4CoJhJC01UChGt zOaxFRJDmcx4knRrl4HLVQfwhQbFpiUjd1kLQNzCAZs6t2QK2Iy5yRrQZng5ck+yYDB5 XaX23XdwdmfWcEqWmYj9WBra6/MC0tohxX/ACrfQp3obYF8nWFnNHTunbrF/FkLdaK+E et+yA61GK22mTScZ/vjhr6cgZ59fASixNztw8tbAcn9YvVbpIQhYWPsjwFcmS89XIy7h RbgVY1i9CI4sLklqK4iJZF3GTHOSDbHxob6IFE1lx5xgu9RoBZfoL6Xin9Vb5j6wxuxQ cwoA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=l1cOQ7Sld9+WDtqhKXFGTGRhUcmsdeCO/MC/bWS5WC4=; b=AUUOfnfJgZhV9XribjCej3OIPyw/GdAtCFwDu53Dv++6pPtWGE4AkWNr4ao3cNGus6 beWKa9mkCFdCTsGovBcTbPyUdWALHEISIRZGSXzFQ+O0ZUQZuHPbA4GKsGhPFd/GJCw5 uf3USIgkhNhcbv612w8YxNxzddLw5r03ayXuG1FedIcra4KnWvRMlSgrw+GK82IR+6uz xDTwS7ILz7IH7xzzplG96FIcxUqBvrqFcf+vEwsbn+sk8FFYa/WPXii3RksfptcJpdcl Zz66M4y889x2kEOil+WReFqYujSEi0p3OQURhyMEw5OwvghP1OuDWu+80oQt5+03uYKq 7PmA== X-Gm-Message-State: AOAM531lX4acggWC/wxmKwfpvxxNGDzgWw1P/LsjNZEFI1u2EJdm2sg7 E4Gfk1jR8+8uI8StDJ+ft3U= X-Google-Smtp-Source: ABdhPJydJOJO0aUYm1Zj45i1k94UFqa6yCf5dCvql1qatajls9Gxh+TzwttiDHGnv9ICQDMaBhAKiw== X-Received: by 2002:ac2:5399:: with SMTP id g25mr4015313lfh.197.1622159657914; Thu, 27 May 2021 16:54:17 -0700 (PDT) Received: from localhost.localdomain (46-138-12-55.dynamic.spd-mgts.ru. [46.138.12.55]) by smtp.gmail.com with ESMTPSA id t129sm319000lff.109.2021.05.27.16.54.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 27 May 2021 16:54:17 -0700 (PDT) From: Dmitry Osipenko To: Thierry Reding , Jonathan Hunter , =?utf-8?b?TWljaGHFgiBNaXJvc8WCYXc=?= , =?utf-8?q?Nikola_Milosavljevi=C4=87?= , Ulf Hansson , Peter Geis , Nicolas Chauvet , Viresh Kumar , Stephen Boyd , Matt Merhar , Paul Fertser , Mark Brown , Liam Girdwood , Krzysztof Kozlowski , Mikko Perttunen Cc: linux-kernel@vger.kernel.org, linux-tegra@vger.kernel.org, devicetree@vger.kernel.org, linux-pm@vger.kernel.org, Nathan Chancellor , linux-clk@vger.kernel.org Subject: [PATCH v5 00/14] NVIDIA Tegra memory and power management changes for 5.14 Date: Fri, 28 May 2021 02:53:59 +0300 Message-Id: <20210527235413.23120-1-digetx@gmail.com> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org This series: 1. Adds CPU/core voltage bump before system is rebooted. 2. Adds new devm_tegra_core_dev_init_opp_table() helper and switches Tegra memory drivers to use it. 3. Adds compile-testing support to the Tegra memory drivers. 4. Adds Tegra SoC core power domain support. Changelog: v5: - Fixed compile-test warning reported for v3 which happened due to copy-paste typo around new tegra210_clk_emc_attach() stub. v4: - Fixed misplaced prototypes of tegra_pmc_core_domain_state_synced(), which I noticed only after sending out v3. This fixes building with !CONFIG_PM_SLEEP. v3: - Dropped "Detach coupled regulator before coupling count is dropped" patch that was added in v2 since it missed regulator locking and it should be more reasonable to add a new generic hook for syncing before detaching. For now it's optional to sync Tegra SoC regulators before detaching since it's not something that happens in practice, hence it's more optimal to simply drop that feature. - Added more stubs for T210 clk driver which should fix compile-testing problem reported for v2 by kernel robot. - Added COMMON_CLK for COMPILE_TEST of memory drivers since for today the problem of compile-testing of legacy platforms that use HAVE_LEGACY_CLK isn't solved, we will be able to remove it after fixing the legacy platforms. - Factored out new PMC driver state syncing feature into a separate patch "pmc: Add driver state syncing", which was requested by Ulf Hansson in a review comment to v2. - Added r-b from Ulf Hansson to the PMC binding-update patch that he gave to v2. v2: - Added more clk stubs that should fix build error reported by the kernel bot to v1 for the T210 memory driver. - Added r-b from Krzysztof Kozlowski to the memory patches. - Added back voltage restore on detaching of coupled regulators to the T20 regulator coupler which previously got missed by accident. - Added new patch: regulator: core: Detach coupled regulator before coupling count is dropped It fixes skipped voltage balancing on detaching of regulators which I happened to notice due to the recent regression of the MAX77620 driver that made driver to re-probe and detach coupled regulators. v1: - Merged previous patches into this single series. - Added ack from Rob Herring to the core domain DT binding patch. - Implemented suggestions that were given by Krzysztof Kozlowski: - Factored out soc_is_tegra() stub into standalone patch. - Updated tags of the "Fix compilation warnings on 64bit platforms" patch, added reported-by from lkp robot and removed suggested-by from Nathan Chancellor. - Switched to use use BIT() macro. - Added r-b from Krzysztof Kozlowski to "Enable compile testing for all drivers" patch. - Added r-b from Nathan Chancellor. - Dropped voltage floor/ceiling from devm_tegra_core_dev_init_opp_table() since only memory drivers now need to initialize voltage vote and they don't need floor/ceil. This was suggested by Viresh Kumar. Dmitry Osipenko (14): regulator: core: Add regulator_sync_voltage_rdev() soc/tegra: regulators: Bump voltages on system reboot soc/tegra: Add stub for soc_is_tegra() soc/tegra: Add devm_tegra_core_dev_init_opp_table() soc/tegra: fuse: Add stubs needed for compile-testing clk: tegra: Add stubs needed for compile-testing memory: tegra: Fix compilation warnings on 64bit platforms memory: tegra: Enable compile testing for all drivers memory: tegra20-emc: Use devm_tegra_core_dev_init_opp_table() memory: tegra30-emc: Use devm_tegra_core_dev_init_opp_table() dt-bindings: soc: tegra-pmc: Document core power domain soc/tegra: pmc: Add core power domain soc/tegra: pmc: Add driver state syncing soc/tegra: regulators: Support core domain state syncing .../arm/tegra/nvidia,tegra20-pmc.yaml | 35 +++++ drivers/memory/tegra/Kconfig | 16 +- drivers/memory/tegra/tegra124-emc.c | 4 +- drivers/memory/tegra/tegra20-emc.c | 48 +----- drivers/memory/tegra/tegra30-emc.c | 52 +------ drivers/regulator/core.c | 23 +++ drivers/soc/tegra/Kconfig | 14 ++ drivers/soc/tegra/common.c | 97 ++++++++++++ drivers/soc/tegra/pmc.c | 143 ++++++++++++++++++ drivers/soc/tegra/regulators-tegra20.c | 94 +++++++++++- drivers/soc/tegra/regulators-tegra30.c | 93 +++++++++++- include/linux/clk/tegra.h | 96 +++++++++--- include/linux/regulator/driver.h | 1 + include/soc/tegra/common.h | 31 ++++ include/soc/tegra/fuse.h | 20 ++- include/soc/tegra/pmc.h | 7 + 16 files changed, 648 insertions(+), 126 deletions(-)