From: Tom Rini <trini@konsulko.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v1 1/4] arm: socfpga: imply SPL config instead of select
Date: Mon, 14 Jan 2019 16:50:48 -0500 [thread overview]
Message-ID: <20190114215048.GS5463@bill-the-cat> (raw)
In-Reply-To: <9e679556-3e5c-07bf-1473-68a1b0263f35@denx.de>
On Mon, Jan 14, 2019 at 10:30:36PM +0100, Marek Vasut wrote:
> On 1/14/19 10:28 PM, Tom Rini wrote:
> > On Mon, Jan 14, 2019 at 07:31:26PM +0100, Marek Vasut wrote:
> >> On 1/14/19 5:05 PM, Simon Goldschmidt wrote:
> >>> Hi Dinh,
> >>
> >> Hi,
> >>
> >>> Am 14.01.2019 um 16:58 schrieb Dinh Nguyen:
> >>>> Hi Simon,
> >>>>
> >>>> On 1/14/19 9:50 AM, Simon Goldschmidt wrote:
> >>>>> Am 11.01.2019 um 23:02 schrieb Marek Vasut:
> >>>>>> On 1/11/19 9:39 PM, Simon Goldschmidt wrote:
> >>>>>>> Am 07.01.2019 um 23:53 schrieb Marek Vasut:
> >>>>>>>> On 1/7/19 10:14 PM, Simon Goldschmidt wrote:
> >>>>>>>>> In order to build a smaller SPL, let's imply SPL_DM_RESET and
> >>>>>>>>> SPL_WATCHDOG_SUPPORT instead of selecting them, so they can be
> >>>>>>>>> disabled
> >>>>>>>>> via defconfig.
> >>>>>>>>>
> >>>>>>>>> This also seems to be required to use OF_PLATDATA, as the reset
> >>>>>>>>> drivers
> >>>>>>>>> don't seem to work with it.
> >>>>>>>>
> >>>>>>>> How do you un-reset IP blocks if you disable the reset controller ?
> >>>>>>>
> >>>>>>> I found that out just now: there's the function
> >>>>>>> 'reset_deassert_peripherals_handoff()' in spl_gen5.c that should
> >>>>>>> "De-assert reset for peripherals and bridges based on handoff".
> >>>>>>> However,
> >>>>>>> at least for Gen5, it just writes a 0 to rstmgr->permodrst. By doing
> >>>>>>> that, it enables *ALL* peripherals on the SoC (except for some DMA
> >>>>>>> channels that aren't really used) :-)
> >>>>>>>
> >>>>>>> I guess that needs some cleaning up as well ;-)
> >>>>>>
> >>>>>> Yes
> >>>>>>
> >>>>>>> I think the proper thing to do here would be to remove this
> >>>>>>> function and
> >>>>>>> convert all drivers to provide appropriate 'resets' properties in the
> >>>>>>> dts?
> >>>>>>
> >>>>>> Indeed
> >>>>>
> >>>>> So I just did that and it works nice for SPL and U-Boot: By adding some
> >>>>> "resets" properties the the main dtsi and adding reset bulk code to the
> >>>>> cadence_qspi, denali_dt nand and drivers, I can nearly remove the reset
> >>>>> code from arch/mach_socfpga.
> >>>>>
> >>>>> The problem would be that now Linux cannot use peripherals that aren't
> >>>>> enabled by U-Boot because it relies on them being enabled. How are such
> >>>>> dependencies solved? Because even if I would add reset support in the
> >>>>> corresponding Linux drivers, we probably could not bootolder Kernels
> >>>>> (e.g. the Debian 9 kernel - v4.9.x) with a new U-Boot...
> >>>>>
> >>>>
> >>>> I added an early reset driver for SoCFPGA that should take care of this.
> >>>> The patch is in v5.0-rc2[1].
> >>>
> >>> OK, it's good to know that this work is already done, I haven't
> >>> monitored this close enough.
> >>
> >> We had the same problem with A10, indeed.
> >>
> >>> But am I correct that my above problem remains even in v5.0 as not all
> >>> peripherals in socfpga.dtsi have a "resets" property set (e.g. mmc and
> >>> qspi) and would thuse not be taken out of reset by Linux?
> >>>
> >>> Plus: should U-Boot work with older Linux kernels? Because if so, we
> >>> need fallback code in U-Boot to unreset peripherals when running with an
> >>> older kernel...
> >>
> >> Yes, it'd break old broken kernels . The real question is, do we care ?
> >
> > Yes, we care. Especially since it sounds like we're talking about
> > something that's an LTS and not super-ancient vendor kernel. Off the
> > top of my head I can't recall if we ever fully removed support in sunxi
> > for the vendor kernel in some cases, or just made it, eventually, opt-in
> > as it was a fairly annoying incompatible behavior case.
> >
> > But yes, in general, we do care about old kernels and need to be loud
> > and clear about when we're removing support for them on a given SoC due
> > to it being a PITA to support both ways of doing X and people have had Y
> > years to migrate or correct their kernel.
>
> Then we have to add some fallback mechanism, possibly the env variable
> to tell reset controller to unreset everything.
Alright, so the prior art in question is:
commit accc9e446be6c3bd129315a0c5830bddccfa16da
Author: Hans de Goede <hdegoede@redhat.com>
Date: Wed Oct 22 14:56:36 2014 +0200
sunxi: Add CONFIG_OLD_SUNXI_KERNEL_COMPAT Kconfig option
And is about supporting the sunxi 3.4 vendor kernel tree, and something
we have still (and a single enabler of). So, what's the range of broken
/ not broken kernels here?
--
Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: not available
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20190114/7a318a2f/attachment.sig>
next prev parent reply other threads:[~2019-01-14 21:50 UTC|newest]
Thread overview: 77+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-01-07 21:14 [U-Boot] [PATCH v1 0/4] arm: socfgpa: support of-platdata Simon Goldschmidt
2019-01-07 21:14 ` [U-Boot] [PATCH v1 1/4] arm: socfpga: imply SPL config instead of select Simon Goldschmidt
2019-01-07 22:53 ` Marek Vasut
2019-01-08 6:24 ` Simon Goldschmidt
2019-01-08 11:22 ` Marek Vasut
2019-01-08 12:09 ` Simon Goldschmidt
2019-01-08 12:22 ` Marek Vasut
2019-01-08 12:46 ` Simon Goldschmidt
2019-01-08 12:49 ` Marek Vasut
2019-01-08 14:48 ` Tom Rini
2019-01-08 14:50 ` Marek Vasut
2019-01-08 14:58 ` Tom Rini
2019-01-08 15:04 ` Simon Goldschmidt
2019-01-08 15:11 ` Tom Rini
2019-01-08 15:05 ` Marek Vasut
2019-01-08 15:01 ` Simon Goldschmidt
2019-01-08 20:52 ` Simon Goldschmidt
2019-01-08 20:54 ` Marek Vasut
2019-01-11 20:39 ` Simon Goldschmidt
2019-01-11 22:02 ` Marek Vasut
2019-01-14 15:50 ` Simon Goldschmidt
2019-01-14 15:58 ` Dinh Nguyen
2019-01-14 16:05 ` Simon Goldschmidt
2019-01-14 18:31 ` Marek Vasut
2019-01-14 18:58 ` Simon Goldschmidt
2019-01-14 19:33 ` Marek Vasut
2019-01-14 19:43 ` Simon Goldschmidt
2019-01-14 20:01 ` Marek Vasut
2019-01-14 20:12 ` Simon Goldschmidt
2019-01-14 20:23 ` Marek Vasut
2019-01-14 20:30 ` Simon Goldschmidt
2019-01-14 20:49 ` Marek Vasut
2019-01-14 20:59 ` Simon Goldschmidt
2019-01-14 21:28 ` Tom Rini
2019-01-14 21:30 ` Marek Vasut
2019-01-14 21:35 ` Simon Goldschmidt
2019-01-14 21:50 ` Tom Rini [this message]
2019-01-14 21:53 ` Simon Goldschmidt
2019-01-14 21:57 ` Marek Vasut
2019-01-14 22:26 ` Dinh Nguyen
2019-01-15 6:59 ` Simon Goldschmidt
2019-01-07 21:14 ` [U-Boot] [PATCH v1 2/4] arm: socfpga: fix compiling with OF_PLATDATA Simon Goldschmidt
2019-01-07 22:53 ` Marek Vasut
2019-01-08 6:32 ` Simon Goldschmidt
2019-01-08 11:46 ` Marek Vasut
2019-01-08 12:14 ` Simon Goldschmidt
2019-01-08 12:23 ` Marek Vasut
2019-01-07 21:14 ` [U-Boot] [PATCH v1 3/4] serial: add an of-platdata driver for "snps, dw-apb-uart" Simon Goldschmidt
2019-01-07 22:12 ` Lukasz Majewski
2019-01-08 6:06 ` Simon Goldschmidt
2019-01-08 7:30 ` Lukasz Majewski
2019-01-08 7:41 ` Simon Goldschmidt
2019-01-08 8:49 ` Lukasz Majewski
2019-01-09 8:35 ` Alexey Brodkin
2019-01-09 11:33 ` Simon Goldschmidt
2019-01-09 18:43 ` Simon Goldschmidt
2019-01-11 8:33 ` Alexey Brodkin
2019-01-11 8:41 ` Simon Goldschmidt
2019-01-11 9:03 ` Alexey Brodkin
2019-01-11 10:00 ` Simon Goldschmidt
2019-01-11 9:22 ` Andy Shevchenko
2019-01-11 10:01 ` Simon Goldschmidt
2019-01-16 21:35 ` Simon Glass
2019-01-10 12:56 ` Simon Glass
2019-01-07 21:14 ` [U-Boot] [PATCH v1 4/4] mmc: socfpga: support of-platdata Simon Goldschmidt
2019-01-07 21:59 ` [U-Boot] [PATCH v1 0/4] arm: socfgpa: " Lukasz Majewski
2019-01-08 6:53 ` Simon Goldschmidt
2019-01-07 22:57 ` Marek Vasut
2019-01-08 6:56 ` Simon Goldschmidt
2019-01-08 11:49 ` Marek Vasut
2019-01-08 12:38 ` Simon Goldschmidt
2019-01-08 12:57 ` Marek Vasut
2019-01-08 13:07 ` Simon Goldschmidt
2019-01-08 13:38 ` Marek Vasut
2019-01-08 13:51 ` Simon Goldschmidt
2019-01-08 14:43 ` Marek Vasut
2019-02-01 18:58 ` Simon Goldschmidt
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=20190114215048.GS5463@bill-the-cat \
--to=trini@konsulko.com \
--cc=u-boot@lists.denx.de \
/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