Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp1157053iob; Wed, 4 May 2022 16:09:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw+yXZUz9LbKuLOXmv76rTwqnyYOANv7F1/RhacfRNzPFl2u/3pi+JxbbnZShtvC4psx9PM X-Received: by 2002:a17:906:5641:b0:6da:8691:3fcc with SMTP id v1-20020a170906564100b006da86913fccmr22073014ejr.50.1651705795451; Wed, 04 May 2022 16:09:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651705795; cv=none; d=google.com; s=arc-20160816; b=vB5h28GAPdjU5Fy0Nvsk5+z29hELLRT3eYNBBvaIrRJE4L1zHB2G2wTLSarF20k2in /LI0YXJ/KOMdAlCSqdn8QpMU3rX3UzCRzvjI1TTHTAS3B9rRmiTRpVJEehDdg3r1nsvA b+jOA5CJp1257QamtPfphoqRP3zxs6ynA0bTwKIzZxPlqoYMukeTViS8OQ2fb866TqRj PKhAH24ff+tHqEMPNFRSMW9b0L6aVvKVS+nLiw2USqSmnR6R3QiQY9XsFNlEtet8VsUP krpf962U6ZMSFMpJdOcJtL/JO6FUCCaRvRLA+fJM23OzkkKxPpzo8dYTi6z0RTngf3hb 4gCg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=i160vd3SYJnXlFBbcmO1jrB6imf8Y/vVEsSy9dgKnng=; b=bgBh7XFoitPq9Z0nbXOsf+fhDj6DX1XlsyO1t0czzCBvdHkwyZz4ZSNO0Jdg6zQPe6 xc8gW2RcTrTI3qprC2b1qd5hN3bDCwHg9aX9AfyrNAwcUzoaqgRBNuPa+RypomasHU1t ZLsRm4Ej0vquyVY1Ulm1gDSzTbwpDsXxZl1Vx16nOQm7pbGX4TJjzHMEQZ+ZoVjIWwR8 /9SrUDgAXyTO8YAzjDGWLZBUmlHIZWfJmfAyDHiuxVVggK9aeJi+NTGImTeOTVeoN94L WH+nSFZaRd8mJ1ftctJ6TGeYI6dPmwjfUq5MPfwUyE9P6tnqk3gU0nZHQYk+VWhf2yms U98A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@foss.st.com header.s=selector1 header.b=sK2kW1PK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=foss.st.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id o17-20020a50fd91000000b004281baf2184si30725edt.180.2022.05.04.16.09.32; Wed, 04 May 2022 16:09:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@foss.st.com header.s=selector1 header.b=sK2kW1PK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=foss.st.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1350237AbiEDNLZ (ORCPT + 99 others); Wed, 4 May 2022 09:11:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52912 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350334AbiEDNKt (ORCPT ); Wed, 4 May 2022 09:10:49 -0400 Received: from mx07-00178001.pphosted.com (mx08-00178001.pphosted.com [91.207.212.93]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 107DB41301; Wed, 4 May 2022 06:07:00 -0700 (PDT) Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 244AIcL7026474; Wed, 4 May 2022 15:06:39 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=foss.st.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-transfer-encoding : content-type; s=selector1; bh=i160vd3SYJnXlFBbcmO1jrB6imf8Y/vVEsSy9dgKnng=; b=sK2kW1PK5X6qbZyiQZY66lDrImimdWnBeL31H1Nn0imk804FiE4BVZWizxQQydYBpE4l Ex+mTef2K/OcaNzVaDbObwPoSaALY8uusYsRRT2go74WZ5LVfi7V26QSZHEmLY6S2tiT tsedHAMkYFeiMhAlqnbEkYVpVMk5PaUk21Rl5+fNwOx1J4n8XzBn0tV4dNgC6XFl8LV4 47F1GHqb8p3g8qe02E505mMxnKxmFGSSHjqCXJRAD1smeC3lGcLsU9tkixS4h1auEpcY 9YemV5SLIVjCL18Ev9al416ccmyje1aucpm5DueReRds6cD8z7qTJ4l/fmlYMqN3RBcA Tw== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com (PPS) with ESMTPS id 3frt88wq4x-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Wed, 04 May 2022 15:06:39 +0200 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 98CA810002A; Wed, 4 May 2022 15:06:38 +0200 (CEST) Received: from Webmail-eu.st.com (sfhdag2node2.st.com [10.75.127.5]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id 91BCB21FEAA; Wed, 4 May 2022 15:06:38 +0200 (CEST) Received: from localhost (10.75.127.45) by SFHDAG2NODE2.st.com (10.75.127.5) with Microsoft SMTP Server (TLS) id 15.0.1497.26; Wed, 4 May 2022 15:06:37 +0200 From: Valentin Caron To: Alessandro Zummo , Alexandre Belloni , Rob Herring , Krzysztof Kozlowski , Alexandre Torgue CC: Gabriel Fernandez , Amelie Delaunay , Valentin Caron , , , , , Subject: [PATCH 4/6] rtc: stm32: add alarm A out feature Date: Wed, 4 May 2022 15:06:15 +0200 Message-ID: <20220504130617.331290-3-valentin.caron@foss.st.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220504130233.330983-1-valentin.caron@foss.st.com> References: <20220504130233.330983-1-valentin.caron@foss.st.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.75.127.45] X-ClientProxiedBy: SFHDAG2NODE2.st.com (10.75.127.5) To SFHDAG2NODE2.st.com (10.75.127.5) X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.858,Hydra:6.0.486,FMLib:17.11.64.514 definitions=2022-05-04_04,2022-05-04_01,2022-02-23_01 X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,RCVD_IN_DNSWL_LOW,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE 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 STM32 RTC can pulse some SOC pins when an RTC alarm expires. This patch adds this functionality for alarm A. The pulse can out on three pins RTC_OUT1, RTC_OUT2, RTC_OUT2_RMP (PC13, PB2, PI8 on stm32mp15) (PC13, PB2, PI1 on stm32mp13). This patch only adds the functionality for devices which are using st,stm32mp1-rtc compatible. Signed-off-by: Valentin Caron --- drivers/rtc/rtc-stm32.c | 77 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) diff --git a/drivers/rtc/rtc-stm32.c b/drivers/rtc/rtc-stm32.c index ace041eb44b8..f27927be20b2 100644 --- a/drivers/rtc/rtc-stm32.c +++ b/drivers/rtc/rtc-stm32.c @@ -5,6 +5,7 @@ */ #include +#include #include #include #include @@ -44,8 +45,10 @@ #define STM32_RTC_CR_ALRAIE BIT(12) #define STM32_RTC_CR_COSEL BIT(19) #define STM32_RTC_CR_OSEL GENMASK(22, 21) +#define STM32_RTC_CR_OSEL_ALARM_A FIELD_PREP(STM32_RTC_CR_OSEL, 0x01) #define STM32_RTC_CR_COE BIT(23) #define STM32_RTC_CR_TAMPOE BIT(26) +#define STM32_RTC_CR_TAMPALRM_TYPE BIT(30) #define STM32_RTC_CR_OUT2EN BIT(31) /* STM32_RTC_ISR/STM32_RTC_ICSR bit fields */ @@ -134,6 +137,7 @@ struct stm32_rtc_data { bool need_dbp; bool has_wakeirq; bool has_lsco; + bool has_alarm_out; }; struct stm32_rtc { @@ -149,6 +153,7 @@ struct stm32_rtc { int wakeirq_alarm; int lsco; struct clk *clk_lsco; + int out_alarm; }; /* @@ -253,6 +258,64 @@ static void stm32_rtc_clk_lsco_disable(struct platform_device *pdev) writel_relaxed(cfgr &= ~STM32_RTC_CFGR_LSCOEN, rtc->base + regs.cfgr); } +static int stm32_rtc_out_alarm_config(struct platform_device *pdev) +{ + struct stm32_rtc *rtc = platform_get_drvdata(pdev); + struct stm32_rtc_registers regs = rtc->data->regs; + unsigned int cr = readl_relaxed(rtc->base + regs.cr); + unsigned int cfgr = readl_relaxed(rtc->base + regs.cfgr); + + cr &= ~STM32_RTC_CR_OSEL; + cr |= STM32_RTC_CR_OSEL_ALARM_A; + cr &= ~STM32_RTC_CR_TAMPOE; + cr &= ~STM32_RTC_CR_COE; + cr &= ~STM32_RTC_CR_TAMPALRM_TYPE; + + switch (rtc->out_alarm) { + case RTC_OUT1: + cr &= ~STM32_RTC_CR_OUT2EN; + cfgr &= ~STM32_RTC_CFGR_OUT2_RMP; + break; + case RTC_OUT2: + cr |= STM32_RTC_CR_OUT2EN; + cfgr &= ~STM32_RTC_CFGR_OUT2_RMP; + break; + case RTC_OUT2_RMP: + cr |= STM32_RTC_CR_OUT2EN; + cfgr |= STM32_RTC_CFGR_OUT2_RMP; + break; + default: + return -EINVAL; + } + + stm32_rtc_wpr_unlock(rtc); + writel_relaxed(cr, rtc->base + regs.cr); + writel_relaxed(cfgr, rtc->base + regs.cfgr); + stm32_rtc_wpr_lock(rtc); + + return 0; +} + +static void stm32_rtc_out_alarm_disable(struct platform_device *pdev) +{ + struct stm32_rtc *rtc = platform_get_drvdata(pdev); + struct stm32_rtc_registers regs = rtc->data->regs; + unsigned int cr = readl_relaxed(rtc->base + regs.cr); + unsigned int cfgr = readl_relaxed(rtc->base + regs.cfgr); + + cr &= ~STM32_RTC_CR_OSEL; + cr &= ~STM32_RTC_CR_TAMPOE; + cr &= ~STM32_RTC_CR_COE; + cr &= ~STM32_RTC_CR_TAMPALRM_TYPE; + cr &= ~STM32_RTC_CR_OUT2EN; + cfgr &= ~STM32_RTC_CFGR_OUT2_RMP; + + stm32_rtc_wpr_unlock(rtc); + writel_relaxed(cr, rtc->base + regs.cr); + writel_relaxed(cfgr, rtc->base + regs.cfgr); + stm32_rtc_wpr_lock(rtc); +} + static int stm32_rtc_enter_init_mode(struct stm32_rtc *rtc) { const struct stm32_rtc_registers *regs = &rtc->data->regs; @@ -657,6 +720,7 @@ static const struct stm32_rtc_data stm32_rtc_data = { .need_dbp = true, .has_wakeirq = false, .has_lsco = false, + .has_alarm_out = false, .regs = { .tr = 0x00, .dr = 0x04, @@ -681,6 +745,7 @@ static const struct stm32_rtc_data stm32h7_rtc_data = { .need_dbp = true, .has_wakeirq = false, .has_lsco = false, + .has_alarm_out = false, .regs = { .tr = 0x00, .dr = 0x04, @@ -714,6 +779,7 @@ static const struct stm32_rtc_data stm32mp1_data = { .need_dbp = false, .has_wakeirq = true, .has_lsco = true, + .has_alarm_out = true, .regs = { .tr = 0x00, .dr = 0x04, @@ -928,6 +994,17 @@ static int stm32_rtc_probe(struct platform_device *pdev) goto err; } + if (rtc->data->has_alarm_out) { + ret = of_property_read_s32(pdev->dev.of_node, "st,alarm", &rtc->out_alarm); + if (!ret) { + ret = stm32_rtc_out_alarm_config(pdev); + } else { + stm32_rtc_out_alarm_disable(pdev); + rtc->out_alarm = ret; + dev_dbg(&pdev->dev, "No alarm out: %d\n", ret); + } + } + if (rtc->data->has_lsco) { ret = of_property_read_s32(pdev->dev.of_node, "st,lsco", &rtc->lsco); -- 2.25.1