linux-api.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Philipp Zabel <p.zabel@pengutronix.de>
To: Maxime Ripard <maxime.ripard@free-electrons.com>
Cc: Mark Rutland <mark.rutland@arm.com>,
	"linux-doc@vger.kernel.org" <linux-doc@vger.kernel.org>,
	Linus Walleij <linus.walleij@linaro.org>,
	Will Deacon <will.deacon@arm.com>, Stefan Agner <stefan@agner.ch>,
	Nikolay Borisov <Nikolay.Borisov@arm.com>,
	Peter Meerwald <pmeerw@pmeerw.net>,
	"linux-api@vger.kernel.org" <linux-api@vger.kernel.org>,
	Lee Jones <lee.jones@linaro.org>,
	Mauro Carvalho Chehab <mchehab@osg.samsung.com>,
	Linux-Arch <linux-arch@vger.kernel.org>,
	Daniel Thompson <daniel.thompson@linaro.org>,
	Russell King <linux@arm.linux.org.uk>,
	Pawel Moll <pawel.moll@arm.com>, Jonathan Corbet <corbet@lwn.net>,
	Jiri Slaby <jslaby@suse.cz>,
	Daniel Lezcano <daniel.lezcano@linaro.org>,
	Chanwoo Choi <cw00.choi@samsung.com>,
	Andy Shevchenko <andy.shevchenko@gmail.com>,
	Antti Palosaari <crope@iki.fi>,
	Geert Uytterhoeven
	<geert@linux-m68k.org>"linux-serial@vger.kernel.org" <li>
Subject: Re: [PATCH v8 14/16] ARM: dts: Introduce STM32F429 MCU
Date: Fri, 22 May 2015 12:07:11 +0200	[thread overview]
Message-ID: <1432289231.3929.60.camel@pengutronix.de> (raw)
In-Reply-To: <20150522091822.GF8557@lukather>

Am Freitag, den 22.05.2015, 11:18 +0200 schrieb Maxime Ripard:
> On Fri, May 22, 2015 at 11:06:28AM +0200, Philipp Zabel wrote:
> > > In the probe function, it would check the number of reg resources.
> > > If a single resource is passed, it would take it, else it would look
> > > the one named "reset".
> > > The driver and bindings would be the same for the two families, and
> > > the bindings would be backward compatible with sunxi ones.
> > > 
> > > Philip, Arnd, what do you think?
> > 
> > I'm not a fan of describing the register layout in the device tree as
> > detailed as the sunxi bindings do. I'd prefer the reg property to
> > describe the device's register address space with one entry per
> > contiguous block of registers.
> 
> That's exactly what we do.

Sorry, what I mean is 'as detailed as reusing the sunxi bindings for
stm32xx here would do'. I don't know enough about the Allwinner register
layouts to form an opinion.

The STM32F427xx/STM32F429xx manual, Table 13. "STM32F427xx and
STM32F429xx register boundary addresses" contains this entry:
    Bus    Boundary address       Peripheral
    AHB1   0x40023800-0x400238bf  RCC

And that's how I'd expect it to be described by the device tree:

    rcc: rcc@40023800 {
        compatible = "st,stm32-rcc";
        reg = <0x40023800 0xc0>;
    };

Instead of "reg = <0x40023810 0x20>" for the resets. Where in the
address range the reset, clock gate and clock configuration registers
reside could be derived from the compatible value.

> > Unifying the mostly identical drivers is a good idea though, and reusing
> > preexisting bindings is better than inventing new ones. I favor the
> > socfpga binding, but I still like the sunxi bindings and this proposal
> > better than encoding the register offset in the reset index.
> 
> I don't really get the difference between the socfpga and our bindings
> actually. Would you mind to explain a bit further what you don't like
> about it ?

The socfpga driver currently hardcodes the reset register offset (0x10)
and number of banks (4), the sunxi driver has no register offset (0x0)
and derives the number of banks from the resource size.
I'd store the internal register offsets and number of banks in the
driver, together with the compatible string.

regards
Philipp

  reply	other threads:[~2015-05-22 10:07 UTC|newest]

Thread overview: 85+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-05-09  7:53 [PATCH v8 00/16] Add support to STMicroelectronics STM32 family Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 01/16] scripts: link-vmlinux: Don't pass page offset to kallsyms if XIP Kernel Maxime Coquelin
2015-05-18 11:47   ` Maxime Coquelin
2015-05-20 23:04     ` Andreas Färber
     [not found]       ` <555D12F8.4000403-l3A5Bk7waGM@public.gmane.org>
2015-05-21  5:40         ` Michal Marek
2015-05-21  7:42           ` Maxime Coquelin
2015-05-22 20:20         ` Andreas Färber
2015-05-09  7:53 ` [PATCH v8 02/16] ARM: ARMv7-M: Enlarge vector table up to 256 entries Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 03/16] dt-bindings: Document the ARM System timer bindings Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 04/16] clocksource/drivers: Add ARM System timer driver Maxime Coquelin
2015-05-18 11:55   ` Maxime Coquelin
     [not found]     ` <CALszF6BiKwDKejfpVgs6ojTxC4LSRfLSEaszXTGVy7xfbHLHZg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-18 12:49       ` Daniel Lezcano
2015-05-18 12:57         ` Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 05/16] dt-bindings: mfd: Add STM32F4 RCC numeric constants into DT include file Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 07/16] drivers: reset: Add STM32 reset driver Maxime Coquelin
     [not found]   ` <1431158038-3813-8-git-send-email-mcoquelin.stm32-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-05-20 23:45     ` Andreas Färber
2015-05-21  7:46       ` Maxime Coquelin
2015-05-21 17:58         ` Andreas Färber
2015-05-21 19:57           ` Maxime Coquelin
2015-05-21 22:01             ` Andreas Färber
2015-05-22 14:04               ` Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 08/16] dt-bindings: Document the STM32 timer bindings Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 09/16] clockevents/drivers: Add STM32 Timer driver Maxime Coquelin
2015-05-18 12:59   ` Maxime Coquelin
2015-05-18 13:10   ` Daniel Lezcano
2015-05-18 14:03     ` Maxime Coquelin
2015-05-19  8:16       ` Daniel Lezcano
2015-05-19  8:55         ` Maxime Coquelin
     [not found]           ` <CALszF6CwGuKqgbX6gVrya1-_YOgvtrgC7pVqKTNjCRif_o532A-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-19  9:06             ` Daniel Lezcano
2015-05-19  9:44               ` Maxime Coquelin
2015-05-19  9:59                 ` Daniel Lezcano
     [not found]                   ` <555B098A.8030202-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2015-05-19 10:02                     ` Maxime Coquelin
     [not found]                       ` <CALszF6AJ3Zf598wYeUx=iNWHHKT24xUyfagB=+4GocwZ-Fd-0g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-19 10:55                         ` Arnd Bergmann
2015-05-19 13:42                           ` Maxime Coquelin
2015-05-19 13:49                             ` Daniel Lezcano
2015-05-19 14:05                               ` Arnd Bergmann
2015-05-19 14:41                               ` Maxime Coquelin
2015-05-19 14:50                                 ` Russell King - ARM Linux
2015-05-19 15:34                                   ` Maxime Coquelin
     [not found]                                 ` <CALszF6A-De6dvcRNoa9ruL+y6Wt_rc7bi-O-VxHWkFF9NSt5_g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-19 15:03                                   ` Daniel Lezcano
2015-05-19 12:56                       ` Thomas Gleixner
2015-05-19 13:00                         ` Russell King - ARM Linux
     [not found]                           ` <20150519130028.GF2067-l+eeeJia6m9vn6HldHNs0ANdhmdF6hFW@public.gmane.org>
2015-05-19 13:17                             ` Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 10/16] dt-bindings: Document the STM32 USART bindings Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 11/16] serial: stm32-usart: Add STM32 USART Driver Maxime Coquelin
2015-05-09 10:07   ` Andy Shevchenko
2015-05-18 13:05   ` Maxime Coquelin
2015-05-09  7:53 ` [PATCH v8 12/16] ARM: Add STM32 family machine Maxime Coquelin
     [not found]   ` <1431158038-3813-13-git-send-email-mcoquelin.stm32-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-05-15 19:57     ` Arnd Bergmann
2015-05-09  7:53 ` [PATCH v8 13/16] ARM: dts: Add ARM System timer as clocksource in armv7m Maxime Coquelin
2015-05-15 19:59   ` Arnd Bergmann
2015-05-09  7:53 ` [PATCH v8 14/16] ARM: dts: Introduce STM32F429 MCU Maxime Coquelin
2015-05-12 21:21   ` Arnd Bergmann
2015-05-13 11:45     ` Maxime Coquelin
     [not found]       ` <CALszF6CS8Q9DWX+ERtu=k=Bzr1-25N3oZQyWyxDZBF3an4nFKQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-13 12:58         ` Daniel Thompson
2015-05-13 13:27           ` Arnd Bergmann
2015-05-13 15:20             ` Daniel Thompson
2015-05-13 15:28               ` Arnd Bergmann
2015-05-13 16:29                 ` Maxime Coquelin
     [not found]                   ` <CALszF6DHazhN6+hGShyrmqtMrPod0hdb8mHAwK-GWfRxXzy7wQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-13 16:37                     ` Arnd Bergmann
2015-05-13 16:54                       ` Maxime Coquelin
     [not found]                         ` <CALszF6CaO_yuNiSDuDV+4d2NRe_+32j=zcSE1HPhB1UH59cW9w-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-05-13 19:11                           ` Arnd Bergmann
2015-05-20 16:17                             ` Maxime Coquelin
2015-05-21 18:51                               ` Maxime Ripard
2015-05-22  9:06                               ` Philipp Zabel
2015-05-22  9:18                                 ` Maxime Ripard
2015-05-22 10:07                                   ` Philipp Zabel [this message]
2015-05-22 12:32                                     ` Maxime Coquelin
2015-05-22 12:43                                       ` Daniel Thompson
2015-05-22 13:09                                       ` Andreas Färber
2015-05-22 13:57                                         ` Maxime Coquelin
2015-05-22 14:06                                           ` Andreas Färber
2015-05-22 14:14                                           ` Daniel Thompson
2015-05-23  8:18                                     ` Maxime Ripard
2015-05-22  9:41                                 ` Maxime Coquelin
2015-05-13 19:29                         ` Daniel Thompson
     [not found]                           ` <5553A608.9080402-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2015-05-13 19:37                             ` Arnd Bergmann
2015-05-14 16:34                               ` Maxime Coquelin
2015-05-14 19:38                                 ` Daniel Thompson
2015-05-18 12:21                         ` Maxime Coquelin
     [not found] ` <1431158038-3813-1-git-send-email-mcoquelin.stm32-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-05-09  7:53   ` [PATCH v8 06/16] dt-bindings: Document the STM32 reset bindings Maxime Coquelin
2015-05-09  7:53   ` [PATCH v8 15/16] ARM: configs: Add STM32 defconfig Maxime Coquelin
     [not found]     ` <1431158038-3813-16-git-send-email-mcoquelin.stm32-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-05-15 20:03       ` Arnd Bergmann
2015-05-09  7:53 ` [PATCH v8 16/16] MAINTAINERS: Add entry for STM32 MCUs Maxime Coquelin
2015-05-15 19:58   ` Arnd Bergmann

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1432289231.3929.60.camel@pengutronix.de \
    --to=p.zabel@pengutronix.de \
    --cc=Nikolay.Borisov@arm.com \
    --cc=andy.shevchenko@gmail.com \
    --cc=corbet@lwn.net \
    --cc=crope@iki.fi \
    --cc=cw00.choi@samsung.com \
    --cc=daniel.lezcano@linaro.org \
    --cc=daniel.thompson@linaro.org \
    --cc=geert@linux-m68k.org \
    --cc=jslaby@suse.cz \
    --cc=lee.jones@linaro.org \
    --cc=linus.walleij@linaro.org \
    --cc=linux-api@vger.kernel.org \
    --cc=linux-arch@vger.kernel.org \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux@arm.linux.org.uk \
    --cc=mark.rutland@arm.com \
    --cc=maxime.ripard@free-electrons.com \
    --cc=mchehab@osg.samsung.com \
    --cc=pawel.moll@arm.com \
    --cc=pmeerw@pmeerw.net \
    --cc=stefan@agner.ch \
    --cc=will.deacon@arm.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).