[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <Zn0qTnESrqlTy5wL@alpha.franken.de>
Date: Thu, 27 Jun 2024 11:01:02 +0200
From: Thomas Bogendoerfer <tsbogend@...ha.franken.de>
To: Christian Marangi <ansuelsmth@...il.com>
Cc: Hauke Mehrtens <hauke@...ke-m.de>,
Rafał Miłecki <zajec5@...il.com>,
Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>,
Florian Fainelli <florian.fainelli@...adcom.com>,
Broadcom internal kernel review list <bcm-kernel-feedback-list@...adcom.com>,
linux-mips@...r.kernel.org, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH v8 0/4] mips: bmips: improve handling of RAC and CBR addr
On Thu, Jun 20, 2024 at 05:26:41PM +0200, Christian Marangi wrote:
> Hi,
>
> this simple series improve handling of RAC and CBR address and try to
> upstream these simple patch we have in OpenWrt for a while.
>
> The first patch fix a straight kernel panic where some Bootloader might
> enable RAC but misconfigure the CBR address. The current logic only
> check if RAC is enabled but doesn't verify if the CBR address is usable.
>
> The DMA sync function cause a kernel panic for invalid write. (as CBR is
> 0 or something like 0xa)
>
> The second is preparation for making the CBR address configurable in DT.
> Since this address doesn't change, we can cache it and reference it with
> a local variable instead of calling the register to access the value.
>
> The 4th patch make it configurable with 2 DT property, one to actually
> set the reg and the other to force set it.
>
> The first property is used when CBR is set to 0. The second property is
> to force it if the Bootloader sets it to something wrong.
>
> If the CBR value is not 0 and is not forced with the second property a
> WARN is printed and the DT value is ignored.
>
> The 4th patch enable RAC on BMIPS4350.
>
> These has been tested on BCM6358 (HG556a) and BCM6368 (VH4032N) and
> reported correct functionality.
>
> Changes v8:
> - Drop fix patch (applied to mips-fixes)
> - Rework CBR cache patch to handle bcm47xx not compiling smp-bmips.c
> Changes v7:
> - Add ACK and Reviewed-by tag for dt patch from v5
> Changes v6:
> - Add missing patch that got lost in v5
> - Fix missing header for legacy bcm47xx
> - Fix compilation error with gcc 10.2.1
> Changes v5:
> - Add Ack tags
> - Improve DT descriptions as suggested by Conor
> Changes v4:
> - Fix compilation error with legacy brcm target
> - Improve property description in DT commit (give
> CBR meaning and drop reference to linux functions)
> - Use only __read_mostly as we can't add variable to
> multiple data sections
> - In patch 4 use local cbr variable instead of global
> one.
> Changes v3:
> - Drop broken-cbr-reg property
> - Fix anyOf+const with enum
> Changes v2:
> - Prefix brcm vendor in the added property
> - Drop last patch (cpu switch from DMA sync)
> - Validate CBR addr from DT to be outside DRAM
> - Reduce indentation in DT CBR check
> - Reduce delta and use local variable for CBR where possible
> - Fix and improve typo and spelling mistake
> - Use 0xf instead of 0xa for BCM6358 RAC enable
>
> Christian Marangi (3):
> mips: bmips: rework and cache CBR addr handling
> dt-bindings: mips: brcm: Document brcm,bmips-cbr-reg property
> mips: bmips: setup: make CBR address configurable
>
> Daniel González Cabanelas (1):
> mips: bmips: enable RAC on BMIPS4350
>
> .../devicetree/bindings/mips/brcm/soc.yaml | 24 +++++++++++++
> arch/mips/bcm47xx/prom.c | 3 ++
> arch/mips/bcm47xx/setup.c | 8 +++++
> arch/mips/bcm63xx/prom.c | 3 ++
> arch/mips/bcm63xx/setup.c | 8 +++++
> arch/mips/bmips/dma.c | 2 +-
> arch/mips/bmips/setup.c | 35 +++++++++++++++++--
> arch/mips/include/asm/bmips.h | 1 +
> arch/mips/kernel/smp-bmips.c | 22 ++++++++++--
> 9 files changed, 101 insertions(+), 5 deletions(-)
series applied to mips-next.
Thomas.
--
Crap can work. Given enough thrust pigs will fly, but it's not necessarily a
good idea. [ RFC1925, 2.3 ]
Powered by blists - more mailing lists