Received: by 10.192.165.156 with SMTP id m28csp1539627imm; Tue, 17 Apr 2018 00:40:06 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/62BKkh9bS1THnOU1sPgFZ3+2Y4gZQ+JmtU8LA9ugvuDgox7CZSlA6UGnFjBOJnDNnwcxC X-Received: by 10.98.98.65 with SMTP id w62mr1038625pfb.256.1523950806623; Tue, 17 Apr 2018 00:40:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523950806; cv=none; d=google.com; s=arc-20160816; b=Ow/Hn2r/gEvu5klcqDPG9LRLbyoezqj72B3PrxJsCEm+2bIoOfoKjSjoXAoQ8bAiYO d22EGTOxEeQ6FmdbxM3MAOX6UID0+EieRfUK+dYQFnN5fu3g4fyRIkTtDR4U0QqBDu6A ZTY/oJz9U0Z4qJ7QhTfjhf0gJLhlzwTJtXPcBtcU8x5z71rE/Yc9QBf0luYlukl1FBfl xwIKyBBMv0/u1Hx5Zpm2s31YAoasg/NX2ZdweLBneWVDZWqygQYx53XlyIxNXfUHeAnP 6aBue2RkF/lb2HJWM9KErb/kMr1PkgBRULMDKTYXpMMjU3e5NTp/Hbz3rguwAX+rnF4I j1Mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=FnhgHUrFdlF2ZYN4J73d8gzjuNIYdie4ulQgzRMIPfg=; b=oSuJQquIue4Y/IDouQqrjVL0+0oWHf3vtZsda7/EI9koIWZPNT5MolP8dmSf1jB255 667wgMjZcDgJfXzfs7eMtzi3tCt+N2EGaRmxbHrZ9iyoTnEus9TSu2B8DcFMnCFs54J5 m66YVYguo4xtyfmDgzR9QutJOnYjIz9aa3yFvjd9V/IbMu3RITs3DdOsel9+scZFNrGr ph9YHlNRVwBJaooZTdu9afQUGD8HSHxR7QA4bXMV6VVpR8K/K/MFlmLTLPBLUJCpEk6a vMvPWPvMo4SSJ0lBY1czMw30KiJLL8+tVhLz92uOSoC1f0i2RlR8eHz4VCJlVUah8Kqt 74jw== ARC-Authentication-Results: i=1; mx.google.com; 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 x10si12055433pfm.18.2018.04.17.00.39.52; Tue, 17 Apr 2018 00:40:06 -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; 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 S1751793AbeDQHia (ORCPT + 99 others); Tue, 17 Apr 2018 03:38:30 -0400 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:24423 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751238AbeDQHi2 (ORCPT ); Tue, 17 Apr 2018 03:38:28 -0400 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id w3H7YV5O024253; Tue, 17 Apr 2018 09:38:03 +0200 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2hbd6cwafe-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Tue, 17 Apr 2018 09:38:03 +0200 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 3E2683A; Tue, 17 Apr 2018 07:38:01 +0000 (GMT) Received: from Webmail-eu.st.com (gpxdag5node6.st.com [10.75.127.79]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 076521570; Tue, 17 Apr 2018 07:38:01 +0000 (GMT) Received: from [10.48.0.167] (10.75.127.123) by GPXDAG5NODE6.st.com (10.75.127.79) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Tue, 17 Apr 2018 09:38:00 +0200 Subject: Re: [PATCH v4 2/6] mfd: stm32-timers: add support for dmas To: Lee Jones CC: , , , , , , , , , , , References: <1523895561-4073-1-git-send-email-fabrice.gasnier@st.com> <1523895561-4073-3-git-send-email-fabrice.gasnier@st.com> <20180417071250.yhgl7c7apn7w53xf@dell> From: Fabrice Gasnier Message-ID: <34e30463-6236-a8e4-fd1f-6217612375eb@st.com> Date: Tue, 17 Apr 2018 09:37:59 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180417071250.yhgl7c7apn7w53xf@dell> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.75.127.123] X-ClientProxiedBy: GPXDAG6NODE6.st.com (10.75.127.82) To GPXDAG5NODE6.st.com (10.75.127.79) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-04-17_03:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/17/2018 09:12 AM, Lee Jones wrote: > On Mon, 16 Apr 2018, Fabrice Gasnier wrote: > >> STM32 Timers can support up to 7 DMA requests: >> - 4 channels, update, compare and trigger. >> Optionally request part, or all DMAs from stm32-timers MFD core. >> >> Also add routine to implement burst reads using DMA from timer registers. >> This is exported. So, it can be used by child drivers, PWM capture >> for instance (but not limited to). >> >> Signed-off-by: Fabrice Gasnier >> Reviewed-by: Benjamin Gaignard >> --- >> Changes in v4: >> - Lee's comments: Add kerneldoc header, better format comments. >> Changes in v3: >> - Basically Lee's comments: >> - rather create a struct stm32_timers_dma, and place a reference to it >> in existing ddata (instead of adding priv struct). >> - rather use a struct device in exported routine prototype, and use >> standard helpers instead of ddata. Get rid of to_stm32_timers_priv(). >> - simplify error handling in probe (remove a goto) >> - comment on devm_of_platform_*populate() usage. >> >> Changes in v2: >> - Abstract DMA handling from child driver: move it to MFD core >> - Add comments on optional dma support >> --- >> drivers/mfd/stm32-timers.c | 227 ++++++++++++++++++++++++++++++++++++++- >> include/linux/mfd/stm32-timers.h | 32 ++++++ >> 2 files changed, 257 insertions(+), 2 deletions(-) > > [...] > >> diff --git a/include/linux/mfd/stm32-timers.h b/include/linux/mfd/stm32-timers.h >> index 2aadab6..a04d7a1 100644 >> --- a/include/linux/mfd/stm32-timers.h >> +++ b/include/linux/mfd/stm32-timers.h >> @@ -8,6 +8,8 @@ >> #define _LINUX_STM32_GPTIMER_H_ >> >> #include >> +#include >> +#include >> #include > > [...] > >> +struct stm32_timers_dma; >> + >> struct stm32_timers { >> struct clk *clk; >> struct regmap *regmap; >> u32 max_arr; >> + struct stm32_timers_dma *dma; /* Only to be used by the parent */ > > I'm confused. I thought the point of putting this comment in was so > that you could place the definition of 'stm32_timers_dma' and remove > the forward declaration? Hi Lee, Sorry, if I miss-understood the point then. So, do you wish I both: - move the full struct definition in above header ? - and keep this comment ? +/** + * struct stm32_timers_dma - STM32 timer DMA handling. + * @completion: end of DMA transfer completion + * @phys_base: control registers physical base address + * @lock: protect DMA access + * @chan: DMA channel in use + * @chans: DMA channels available for this timer instance + */ +struct stm32_timers_dma { + struct completion completion; + phys_addr_t phys_base; + struct mutex lock; + struct dma_chan *chan; + struct dma_chan *chans[STM32_TIMERS_MAX_DMAS]; +}; This will basically expose the struct to child drivers. But I'm ok if you think this is acceptable. I can send a V5 if you wish... Please advise, Best regards, Fabrice > >> }; >> + >> +int stm32_timers_dma_burst_read(struct device *dev, u32 *buf, >> + enum stm32_timers_dmas id, u32 reg, >> + unsigned int num_reg, unsigned int bursts, >> + unsigned long tmo_ms); >> #endif >