From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 10E38C433EF for ; Mon, 11 Oct 2021 11:30:48 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id CEC9760EDF for ; Mon, 11 Oct 2021 11:30:47 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org CEC9760EDF Authentication-Results: mail.kernel.org; dmarc=fail (p=quarantine dis=none) header.from=microchip.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-ID:Date:Subject:CC :To:From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=4klV+LpfMaDOUIKmSmYQFEndvZMeQW/jrxnMypeAx2g=; b=S0URVLrF4NL0/4 zeaBPVgrTLfTgaRxijtZeX6qnO5mhWQaJciOj4WRVkfxtEjwpuAjCyk37q+hHqz5Gg0YeVu7Dnpof nAAr+jItOWXaMyX1nBn1DVPIM+VftvJf5KVMXiJmIM+hHwBOnc6KXZtYqVx3bHrEwPXTfYDGINrPM KnNTCS6Mg6XalIL0zJs5U4zS67kwrZAZhluVl7QPe5zli0I8rqHj8VTLaQEf0u/mcamH6bpWZxAYi L00c964N7/llVVSZ2XdKrTHddzIQkLPgEXAKKwDaFVRHJu2o0OzYHKmOAv4nAYBIhnZ0Q/LSCEK97 plO2D5rdth3eet8pulUQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1mZtT2-0093le-6B; Mon, 11 Oct 2021 11:27:41 +0000 Received: from esa.microchip.iphmx.com ([68.232.153.233]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mZtSt-0093jY-Vh for linux-arm-kernel@lists.infradead.org; Mon, 11 Oct 2021 11:27:33 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=microchip.com; i=@microchip.com; q=dns/txt; s=mchp; t=1633951653; x=1665487653; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=DlAv5sayhPu+EI8WewXPhpt7h0/Q9kN/IpzGmaVkuQU=; b=o3/zGHeVhzj0SYPfiuvVE4oVUb8d5Mm8A7qca1osMXs2PHFYniGZTF9/ Ru88Sp5c9nBJxCz9Isoahj/14bMssZtAjzGm+9M9hPCWgzRZHhc9Hwo05 7mtEbDWQ3tW/jkXg8a+NmdWJ6KevwlbwVElNPTvlH6NuZZkuHBb1lAXbE rBexKlajmNDMfE9OszTDoGk6BUv03pPvvGy0WrjcSlo/Lp5U7q3I9cgP2 8X9XkWNmo59dXKcz7fJ4SDF+CN1mfcrFvtry/cO8D/A8XqscY8JS2et5K +YJkC1JA63twoz5DI8VqN8fr4j+i5jHW+6roVaD+LGLHzmxx3/3Jo3p+m A==; IronPort-SDR: TFpPcnuuQGFR5uvefkP0o/OCPN9NYnbJdhxDPe/oZrz3W97hHTCrnsJwXxmpf54sD3AFhPbg4q qzOvPuLIOzVNIBvLjhtZDXvNZ8aiiVPwMgiB9xihfVaQztzxyUJNQJKwKtFfokmzQQMX00rJO8 yjk7g0AtU3Cj0okJDPfFdRUUyJCP/4asxhI27c3ROiKusmhaVULIjQ0WBOBg61NZGiaKpqVaVV vKVsLEJqovHCC7KhZNmPhp8XELVG9jwjsk8cgzzQBzS6Z6t72Rxljyo8p9NjhaLcCHDDXzhwAk W0U1Kyh8IgWwI0aVDEGZ5nKU X-IronPort-AV: E=Sophos;i="5.85,364,1624345200"; d="scan'208";a="139244660" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa5.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 11 Oct 2021 04:27:31 -0700 Received: from chn-vm-ex02.mchp-main.com (10.10.85.144) by chn-vm-ex01.mchp-main.com (10.10.85.143) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.14; Mon, 11 Oct 2021 04:27:30 -0700 Received: from rob-dk-mpu01.microchip.com (10.10.115.15) by chn-vm-ex02.mchp-main.com (10.10.85.144) with Microsoft SMTP Server id 15.1.2176.14 via Frontend Transport; Mon, 11 Oct 2021 04:27:28 -0700 From: Claudiu Beznea To: , , , , CC: , , , Claudiu Beznea Subject: [PATCH v5 00/15] clk: at91: updates for power management and dvfs Date: Mon, 11 Oct 2021 14:27:04 +0300 Message-ID: <20211011112719.3951784-1-claudiu.beznea@microchip.com> X-Mailer: git-send-email 2.33.0 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20211011_042732_088599_CB87FA1D X-CRM114-Status: GOOD ( 18.53 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi, This series addresses the clock power management for SAMA7G5 and also updates the master clock driver and sam9x60-pll driver to accommodate the requests at [1] and avoid overclocking of CPU and MCK0 domains while changing the frequency via DVFS. The power management part is implemented by adding save_context()/restore_context() on each clock driver (patch 1/15). Since the PM part is necessary only for backup mode (supported on SAMA5D2 and SAMA7G5) the pmc.c has been adapted to call the save_context()/restore_context() only on switches to/from backup mode (patch 2/15). Patch 3/15 adds the securam clock on SAMA7G5. This is necessary for backup mode of SAMA7G5. Patch 4/15 adapt SAMA7G5 MCK1..4 driver to use the defines at include/linux/clk/at91_pmc.h introduced in commit ec03f18cc222 ("clk: at91: add register definition for sama7g5's master clock"). Patch 5/15 improves a bit readabiblity in some places of master clock driver. Patch 6/15 enable the suspend/resume for clocks also for SAMA7G5. Patches 7-10/15 adds fixes in master clock driver and sam9x60-pll driver. Patches 11-12/15 address DVFS by adding notifiers for master clock driver and sam9x60-pll driver to avoid overclocking for CPU domain and MCK0 domain. Patch 13/15 removes the master clock prescaler from Linux clock tree as it has been discovered a hardware bug on it and it may not lock on some scenario although its output clock is stable. Patch 14/15 decreases the low limit of MCK0 as it can go even to 32KHz. Patch 15/15 uses clk_core_get_rate_recalc() in clk_rate_get(). Thank you, Claudiu Beznea [1] https://lore.kernel.org/lkml/20210105104426.4tmgc2l3vyicwedd@vireshk-i7/ [2] https://lore.kernel.org/lkml/163047507296.42057.10597374695758699868@swboyd.mtv.corp.google.com/ Changes in v5: - dropped patches 16/17, 17/17 from previous version - in patch 02/15: - use read_relaxed() to get the value at address pointed by at91_pmc_backup_suspend - removed of_find_device_by_node() from pmc_register_ops() since its returned value was not used in the function (of_device_is_available() is enough to know before mapping securam). of_find_device_by_node() was the one which needed the changes of postcore_initcall() with subsys_initcall() (as described in commit description from v4) thus kept the postcore_initcall(); also updated the commit description to reflect this. Changes in v4: - removed opp dependencies along with get_cpu_device() in patch 11/17 as those functionalities are not available at the initialization time for clocks instantiated with CLK_OF_DECLARE Changes in v3: - minor fixes in patch 1/7 (e.g. use regmap_read() + checks + update + regmap_write() sequence instead of regmap_read() + checks + regmap_update_bits() - patch 4/17 has been updated after commit ec03f18cc222 ("clk: at91: add register definition for sama7g5's master clock") - patch 6-10/17, 14-17/17 are newly introduced - notifier for sam9x60 div pll was introduced (patch 11/17) and notifier logic for master clock div has been changed (patch 12/17) to use safe divider on PRE_RATE_CHANGE events and update clock to highest possible rate on POST_RATE_CHANGE events - master clock prescaler has been removed from Linux clock tree for SAMA7G5 Changes in v2: - addressed code review comments - collected tags Claudiu Beznea (15): clk: at91: re-factor clocks suspend/resume clk: at91: pmc: execute suspend/resume only for backup mode clk: at91: sama7g5: add securam's peripheral clock clk: at91: clk-master: add register definition for sama7g5's master clock clk: at91: clk-master: improve readability by using local variables clk: at91: pmc: add sama7g5 to the list of available pmcs clk: at91: sam9x60-pll: use DIV_ROUND_CLOSEST_ULL clk: at91: clk-master: check if div or pres is zero clk: at91: clk-master: mask mckr against layout->mask clk: at91: clk-master: fix prescaler logic clk: at91: clk-sam9x60-pll: add notifier for div part of PLL clk: at91: clk-master: add notifier for divider clk: at91: sama7g5: remove prescaler part of master clock clk: at91: sama7g5: set low limit for mck0 at 32KHz clk: use clk_core_get_rate_recalc() in clk_rate_get() drivers/clk/at91/at91rm9200.c | 2 +- drivers/clk/at91/at91sam9260.c | 2 +- drivers/clk/at91/at91sam9g45.c | 2 +- drivers/clk/at91/at91sam9n12.c | 2 +- drivers/clk/at91/at91sam9rl.c | 2 +- drivers/clk/at91/at91sam9x5.c | 2 +- drivers/clk/at91/clk-generated.c | 46 ++- drivers/clk/at91/clk-main.c | 66 ++++ drivers/clk/at91/clk-master.c | 463 ++++++++++++++++++++++------ drivers/clk/at91/clk-peripheral.c | 40 ++- drivers/clk/at91/clk-pll.c | 39 +++ drivers/clk/at91/clk-programmable.c | 29 +- drivers/clk/at91/clk-sam9x60-pll.c | 174 +++++++++-- drivers/clk/at91/clk-system.c | 20 ++ drivers/clk/at91/clk-usb.c | 27 ++ drivers/clk/at91/clk-utmi.c | 39 +++ drivers/clk/at91/dt-compat.c | 2 +- drivers/clk/at91/pmc.c | 173 +++-------- drivers/clk/at91/pmc.h | 29 +- drivers/clk/at91/sam9x60.c | 6 +- drivers/clk/at91/sama5d2.c | 2 +- drivers/clk/at91/sama5d3.c | 2 +- drivers/clk/at91/sama5d4.c | 2 +- drivers/clk/at91/sama7g5.c | 29 +- drivers/clk/clk.c | 2 +- 25 files changed, 890 insertions(+), 312 deletions(-) -- 2.25.1 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel