]> git.dujemihanovic.xyz Git - u-boot.git/log
u-boot.git
8 months agonet: eth-uclass: guard against reentrant eth_init()/eth_halt() calls
Matthias Schiffer [Fri, 26 Apr 2024 08:02:24 +0000 (10:02 +0200)]
net: eth-uclass: guard against reentrant eth_init()/eth_halt() calls

With netconsole, any log message can result in an eth_init(), possibly
causing an reentrant call into eth_init() if a driver's ops print
anything:

    eth_init() -> driver.start() -> printf() -> netconsole -> eth_init()
    eth_halt() -> driver.stop() -> printf() -> netconsole -> eth_init()

Rather than expecting every single Ethernet driver to handle this case,
prevent the reentrant calls in eth_init() and eth_halt().

The issue was noticed on an AM62x board, where a bootm after
simultaneous netconsole and TFTP would result in a crash.

Signed-off-by: Matthias Schiffer <matthias.schiffer@ew.tq-group.com>
Link: https://e2e.ti.com/support/processors-group/processors/f/processors-forum/1350550/sk-am62a-lp-am65_cpsw_nuss_port-error-in-u-boot-while-using-netconsole-functionality/
8 months agoMerge patch series "Add remoteproc driver for AM62a SoC"
Tom Rini [Wed, 15 May 2024 16:45:33 +0000 (10:45 -0600)]
Merge patch series "Add remoteproc driver for AM62a SoC"

Hari Nagalla <hnagalla@ti.com> says:

This series adds relevant ip data in remoteproc driver for AM62a devices.

Logs: https://paste.sr.ht/~hnagalla/5e20838705c1d688bca81886dad56451b56d3913

8 months agoboard: ti: am62ax: Add support for remote proc load
Hari Nagalla [Thu, 9 May 2024 14:20:37 +0000 (09:20 -0500)]
board: ti: am62ax: Add support for remote proc load

Add AM62a remote proc firmware names to environment variables for
loading of C7x DSP and R5F processors.

Signed-off-by: Hari Nagalla <hnagalla@ti.com>
Reviewed-by: Devarsh Thakkar <devarsht@ti.com>
8 months agoconfigs: am62ax: enable remote proc drivers
Hari Nagalla [Thu, 9 May 2024 14:20:36 +0000 (09:20 -0500)]
configs: am62ax: enable remote proc drivers

Enable K3-DSP and K3-R5FSS remote proc drivers for am62ax.

Signed-off-by: Hari Nagalla <hnagalla@ti.com>
Reviewed-by: Devarsh Thakkar <devarsht@ti.com>
8 months agoremoteproc: k3-r5: Add support for R5F core on AM62A SoCs
Hari Nagalla [Thu, 9 May 2024 14:20:35 +0000 (09:20 -0500)]
remoteproc: k3-r5: Add support for R5F core on AM62A SoCs

AM62A has a R5F core in MCU voltage domain.
Extend support for R5F remote proc driver on AM62A with compatible
strings.

Signed-off-by: Hari Nagalla <hnagalla@ti.com>
Reviewed-by: Devarsh Thakkar <devarsht@ti.com>
8 months agoremoteproc: k3-dsp: Enable C71x support for AM62A
Hari Nagalla [Thu, 9 May 2024 14:20:34 +0000 (09:20 -0500)]
remoteproc: k3-dsp: Enable C71x support for AM62A

AM62A SoC has a single C71x DSP subsystem with analytics engine in
main voltage domain. Extend support to AM62A with compatible strings.

Signed-off-by: Hari Nagalla <hnagalla@ti.com>
Reviewed-by: Devarsh Thakkar <devarsht@ti.com>
8 months agoMerge patch series "Add DFU and usb boot for TI am62x SK and beagleplay"
Tom Rini [Wed, 15 May 2024 16:45:10 +0000 (10:45 -0600)]
Merge patch series "Add DFU and usb boot for TI am62x SK and beagleplay"

Martyn Welch <martyn.welch@collabora.com> says:

This series adds DFU support for TI AM62 SK and beagleplay boards.

I have picked this series up from Sjoerd due to time constraints.

Since the last revision:
* Removed dwc3 mode setting in favour of reinstating forced peripheral
  mode for usb0
* Use of config fragments for both r5 and a53 DFU configuration to
  reduce duplication
* Typographical improvements to documentation

We plan to also submit the dts changes to linux so that those can be
dropped again in the near future (hopefully)

8 months agodoc: board: Add document for DFU boot on am62x SoCs
Sjoerd Simons [Mon, 6 May 2024 14:38:46 +0000 (15:38 +0100)]
doc: board: Add document for DFU boot on am62x SoCs

Both AM62 SK and beagleplay support DFU boot in a similar way now;
Document how to actually run DFU boot for both boards

Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Tested-by: Mattijs Korpershoek <mkorpershoek@baylibre.com> # on beagle play
Signed-off-by: Martyn Welch <martyn.welch@collabora.com>
8 months agobeagleplay: Add DFU support
Sjoerd Simons [Mon, 6 May 2024 14:38:45 +0000 (15:38 +0100)]
beagleplay: Add DFU support

DFU mode on a beagleplay can be used via the Type-C connector by holding
the USR switch while powering on.

Configuration is already provided as fragments for both the A53 and R5
u-boot parts. Include the am62x_a53_usbdfu.config config. The
am62x_r5_usbdfu.config fragment needs to be added should DFU boot be
required as this will disable booting from persistent storage due to
binary size constraints.

Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Signed-off-by: Martyn Welch <martyn.welch@collabora.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Tested-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
8 months agoconfigs: am62x_evm_*: Enable USB and DFU support
Sjoerd Simons [Mon, 6 May 2024 14:38:44 +0000 (15:38 +0100)]
configs: am62x_evm_*: Enable USB and DFU support

Provide config fragments to enable USB host as well as USB gadget and DFU
support for a53 and r5. This relevant fragment is included into the
am62x EVM a53 defconfig. For the r5, due to the smaller available size,
the config fragment also disables support for persistent storage to free
up space for USB support. This fragment needs to be included is DFU
booting is desired.

The CONFIG_DFU_SF option is placed in the defconfig rather than the
fragment as this is known not to be supported on all boards that can
support DFU.

Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Signed-off-by: Martyn Welch <martyn.welch@collabora.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
8 months agoarm: dts: k3-am625-sk: Enable usb port in u-boot
Sjoerd Simons [Mon, 6 May 2024 14:38:43 +0000 (15:38 +0100)]
arm: dts: k3-am625-sk: Enable usb port in u-boot

Enable usb0 in all boot phases for use with DFU

Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Reviewed-by: Alexander Sverdlin <alexander.sverdlin@siemens.com>
Signed-off-by: Martyn Welch <martyn.welch@collabora.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
8 months agoboard: ti: am62x: am62x: include env for DFU
Sjoerd Simons [Mon, 6 May 2024 14:38:42 +0000 (15:38 +0100)]
board: ti: am62x: am62x: include env for DFU

Include standard TI K3 dfu environment

Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Reviewed-by: Alexander Sverdlin <alexander.sverdlin@siemens.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Tested-by: Mattijs Korpershoek <mkorpershoek@baylibre.com> # on beagle play
8 months agousb: dwc3: Add dwc3 glue driver for am62
Sjoerd Simons [Mon, 6 May 2024 14:38:41 +0000 (15:38 +0100)]
usb: dwc3: Add dwc3 glue driver for am62

Add glue code for TI AM62 to the dwc3 driver; Most code adopted from
TI vendor u-boot code.

Signed-off-by: Sjoerd Simons <sjoerd@collabora.com>
Tested-by: Alexander Sverdlin <alexander.sverdlin@siemens.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Tested-by: Mattijs Korpershoek <mkorpershoek@baylibre.com> # on beagle play
8 months agoMerge branch '2024-05-13-assorted-updates' into next
Tom Rini [Tue, 14 May 2024 13:46:33 +0000 (07:46 -0600)]
Merge branch '2024-05-13-assorted-updates' into next

- A few zfs fixes, ARMv8 timer cleanups, support more algorithms with
  the nuvoton crypto driver, virtio + env in filesystem fix, K3 code
  cleanup and warning fix in gen_compile_commands.

8 months agoarm: mach-k3: Move code specific to a SoC into that SoC's directory
Andrew Davis [Fri, 10 May 2024 20:21:24 +0000 (15:21 -0500)]
arm: mach-k3: Move code specific to a SoC into that SoC's directory

Each SoC now has a directory in mach-k3, let's move the SoC specific
files into their respective directories.

Signed-off-by: Andrew Davis <afd@ti.com>
8 months agoscripts: gen_compile_commands: fix invalid escape sequence warning
Caleb Connolly [Fri, 3 May 2024 15:18:36 +0000 (17:18 +0200)]
scripts: gen_compile_commands: fix invalid escape sequence warning

Since Python 3.12 unrecognised escape sequences trigger a SyntaxWarning.
Convert the '\#' string to a raw string so the backslash is correctly
used as a literal.

Ported from Linux commit dae4a0171e25 ("gen_compile_commands: fix invalid
escape sequence warning").

This updates the script to be in-line with Linux 6.9-rc6.

Signed-off-by: Caleb Connolly <caleb.connolly@linaro.org>
Reviewed-by: João Marcos Costa <jmcosta944@gmail.com>
8 months agoInit virtio before loading ENV from EXT4 or FAT
Fiona Klute [Wed, 1 May 2024 08:54:09 +0000 (10:54 +0200)]
Init virtio before loading ENV from EXT4 or FAT

Specifying a file in an EXT4 or FAT partition on a virtio device as
environment location failed because virtio hadn't been initialized by
the time the environment was loaded. This patch mirrors commit
54ee5ae84191 ("Add SCSI scan for ENV in EXT4 or FAT") in issue and
fix, just for a different kind of block device.

The additional include in include/virtio.h is needed so all functions
called there are defined, the alternative would have been to include
dm/device.h separately in the env/ sources.

Checkpatch suggests using "if (IS_ENABLED(CONFIG...))" instead of
"#if defined(CONFIG_...)", I'm sticking to the style of the existing
code here.

Signed-off-by: Fiona Klute <fiona.klute@gmx.de>
CC: Joe Hershberger <joe.hershberger@ni.com>
CC: Bin Meng <bmeng.cn@gmail.com>
CC: Rogier Stam <rogier@unrailed.org>
8 months agoarmv8: generic_timer: Use event stream for udelay
Peter Hoyes [Wed, 1 May 2024 08:16:33 +0000 (09:16 +0100)]
armv8: generic_timer: Use event stream for udelay

Polling cntpct_el0 in a tight loop for delays is inefficient.
This is particularly apparent on Arm FVPs, which do not simulate
real time, meaning that a 1s sleep can take a couple of orders
of magnitude longer to execute in wall time.

If running at EL2 or above (where CNTHCTL_EL2 is available), enable
the cntpct_el0 event stream temporarily and use wfe to implement
the delay more efficiently. The event period is chosen as a
trade-off between efficiency and the fact that Arm FVPs do not
typically simulate real time.

This is only implemented for Armv8 boards, where an architectural
timer exists, and only enabled by default for the ARCH_VEXPRESS64
board family.

Signed-off-by: Peter Hoyes <Peter.Hoyes@arm.com>
Reviewed-by: Andre Przywara <andre.przywara@arm.com>
8 months agoarm: Move sev() and wfe() definitions to common Arm header file
Peter Hoyes [Wed, 1 May 2024 08:16:32 +0000 (09:16 +0100)]
arm: Move sev() and wfe() definitions to common Arm header file

The sev() and wfe() asm macros are currently defined only for
mach-exynos. As these are common Arm instructions, move them to the
common asm/system.h header file, for both Armv7 and Armv8, so they
can be used by other machines.

wfe may theoretically trigger a context switch if an interrupt occurs
so add a memory barrier to this call.

Signed-off-by: Peter Hoyes <Peter.Hoyes@arm.com>
Reviewed-by: Andre Przywara<andre.przywara@arm.com>
8 months agosandbox: make function 'do_undefined' properly compiles for PowerPC
WHR [Tue, 30 Apr 2024 16:55:10 +0000 (00:55 +0800)]
sandbox: make function 'do_undefined' properly compiles for PowerPC

The 2 bytes 0xffff is too short for being a PowerPC instruction, resulting
in an error similar to:
    /tmp/ccW8yjie.s: Assembler messages:
    /tmp/ccW8yjie.s: Error: unaligned opcodes detected in executable segment
    /tmp/ccW8yjie.s:223: Error: instruction address is not a multiple of 4
    make[2]: *** [/tmp/ccyF4HIC.mk:17: /tmp/ccCKUFuF.ltrans5.ltrans.o] Error 1

Signed-off-by: WHR <msl0000023508@gmail.com>
8 months agozfs: fix function 'zlib_decompress' pointlessly calling itself
WHR [Tue, 30 Apr 2024 16:40:38 +0000 (00:40 +0800)]
zfs: fix function 'zlib_decompress' pointlessly calling itself

In order to prevent crashing due to infinite recursion and actually
decompress the requested data, call the zlib function 'uncompress'
instead.

Signed-off-by: WHR <msl0000023508@gmail.com>
8 months agozfs: recognize zpools formatted with features support
WHR [Tue, 30 Apr 2024 16:28:32 +0000 (00:28 +0800)]
zfs: recognize zpools formatted with features support

Currently no features are implemented, only the zpool version 5000 that
indicating the features support, is recognized. Since it is possible for
OpenZFS to create a pool with features support enabled, but without
enabling any actual feature, this change enables U-Boot to read such
pools.

Signed-off-by: WHR <msl0000023508@gmail.com>
8 months agocrypto: nuvoton: npcm_sha: Support SHA 384/512
Jim Liu [Mon, 29 Apr 2024 06:38:03 +0000 (14:38 +0800)]
crypto: nuvoton: npcm_sha: Support SHA 384/512

1. Use vendor naming rule to rename each function
2. add SHA 384/512 support

Signed-off-by: Jim Liu <JJLIU0@nuvoton.com>
8 months agoMerge patch series "Add AM64x Support to PRUSS and PRU_RPROC driver"
Tom Rini [Fri, 10 May 2024 16:44:58 +0000 (10:44 -0600)]
Merge patch series "Add AM64x Support to PRUSS and PRU_RPROC driver"

MD Danish Anwar <danishanwar@ti.com> says:

This series adds AM64x related compatibles to PRUSS and PRU_RPROC drivers.
This series is a prerequisite for ICSSG Ethernet driver.

Once Support for AM64x is added to PRUSS and PRU_RPROC driver, I'll send
another series to enable ICSSG Ethernet driver for AM64x as well.

8 months agoMerge patch series "Generate all SR boot binaries"
Tom Rini [Fri, 10 May 2024 16:43:09 +0000 (10:43 -0600)]
Merge patch series "Generate all SR boot binaries"

Neha Malcom Francis <n-francis@ti.com> says:

Add support for missing HS SRs in the build for J721E and J7200.

Boot logs (updated for v2):
https://gist.github.com/nehamalcom/e652752623537aced8cf31308015d7c9

8 months agoMerge patch series "*** Commonize board code for K3 based SoMs ***"
Tom Rini [Fri, 10 May 2024 16:42:25 +0000 (10:42 -0600)]
Merge patch series "*** Commonize board code for K3 based SoMs ***"

Wadim Egorov <w.egorov@phytec.de> says:

Factor out code that we can reuse across all our K3 based SoMs.
2nd patch of this series require patch [1] to be applied first.

[1] https://lists.denx.de/pipermail/u-boot/2024-April/552021.html

8 months agoarm: mach-k3: am642: Provide a way to obtain boot device for non SPLs
Wadim Egorov [Wed, 24 Apr 2024 12:43:20 +0000 (14:43 +0200)]
arm: mach-k3: am642: Provide a way to obtain boot device for non SPLs

Let's provide get_boot_device() for AM64, similar to what we did
in commit 2f9095e2bf59 ("arm: mach-k3: am625: Provide a way to obtain boot
device for non SPLs") for AM62.

Signed-off-by: Wadim Egorov <w.egorov@phytec.de>
8 months agosoc: ti: pruss: Add support for AM64x
MD Danish Anwar [Tue, 30 Apr 2024 10:46:33 +0000 (16:16 +0530)]
soc: ti: pruss: Add support for AM64x

Add support for AM64x by adding it's compatible in pruss driver.

Signed-off-by: MD Danish Anwar <danishanwar@ti.com>
Reviewed-by: Roger Quadros <rogerq@kernel.org>
8 months agoremoteproc: pru: Add support for AM64x PRU / RTU cores
MD Danish Anwar [Tue, 30 Apr 2024 10:46:32 +0000 (16:16 +0530)]
remoteproc: pru: Add support for AM64x PRU / RTU cores

Add support for AM64x PRU cores by adding compatibles for AM64x.

Signed-off-by: MD Danish Anwar <danishanwar@ti.com>
Reviewed-by: Roger Quadros <rogerq@kernel.org>
8 months agoarm: dts: k3-j7200-binman: Add support for HSSE1.0 and HSFS1.0
Neha Malcom Francis [Thu, 25 Apr 2024 22:06:59 +0000 (03:36 +0530)]
arm: dts: k3-j7200-binman: Add support for HSSE1.0 and HSFS1.0

J7200  has SR1.0 and SR2.0 having three variants of each GP, HS-FS and
HS-SE. Current build does not generate HS-SE SR1.0 and HS-FS SR1.0 so
add support for them.

Reported-by: Suman Anna <s-anna@ti.com>
Reported-by: Aniket Limaye <a-limaye@ti.com>
Signed-off-by: Neha Malcom Francis <n-francis@ti.com>
Reviewed-by: Andrew Davis <afd@ti.com>
8 months agoarm: dts: k3-j721e-binman: Add support for HSFS1.1
Neha Malcom Francis [Thu, 25 Apr 2024 22:06:58 +0000 (03:36 +0530)]
arm: dts: k3-j721e-binman: Add support for HSFS1.1

J721E has SR1.1 and SR2.0 having three variants of each GP, HS-FS and
HS-SE. Current build does not generate HS-FS SR1.1 so add support for
them.

Reported-by: Suman Anna <s-anna@ti.com>
Signed-off-by: Neha Malcom Francis <n-francis@ti.com>
Reviewed-by: Andrew Davis <afd@ti.com>
8 months agophycore_am64x_a53_defconfig: Enable CONFIG_BOARD_LATE_INIT
Wadim Egorov [Wed, 24 Apr 2024 12:53:35 +0000 (14:53 +0200)]
phycore_am64x_a53_defconfig: Enable CONFIG_BOARD_LATE_INIT

Enable CONFIG_BOARD_LATE_INIT to use PHYTECs common board_late_init()
to set handy environment variables for u-boot.
Also, resync after savedefconfig.

Signed-off-by: Wadim Egorov <w.egorov@phytec.de>
8 months agoboard: phytec: Commonize board code for K3 based SoMs
Wadim Egorov [Wed, 24 Apr 2024 12:53:34 +0000 (14:53 +0200)]
board: phytec: Commonize board code for K3 based SoMs

Environment handling code can be reused across all our K3 based SoMs.
Instead of adding the same code for every new SoM, move it to a common
board.c file.

Signed-off-by: Wadim Egorov <w.egorov@phytec.de>
8 months agotest/py: Make the number of SPL banners seen a variable
Tom Rini [Wed, 24 Apr 2024 22:45:37 +0000 (16:45 -0600)]
test/py: Make the number of SPL banners seen a variable

Currently we have the option to tell the console code that we should
ignore the SPL banner. We also have an option to say that we can see it
a second time, and ignore it. However, some platforms such as TI AM64x
will have us see the SPL banner three times. Rather than add an
"spl3_skipped" option, rework the code. By default we expect to see the
banner once, but boards can specify seeing it as many times as they
expect to.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agonet: Add drivers for Sysnopsys Ethernet 10G device
Boon Khai Ng [Wed, 17 Apr 2024 07:46:56 +0000 (15:46 +0800)]
net: Add drivers for Sysnopsys Ethernet 10G device

This driver support the Synopsys Designware Ethernet 10G
IP block refer from the driver dwc_eth_qos.

The driver MAC register mapping is different between
Synopsys QoS IP and Synopsys 10G IP, and thus new file
is created meant for Sysnopsys 10G IP.

The dwc_eth_xgmac_socfpga.c is specific to a device family,
the driver support the specific configuration used in
Intel SoC FPGA Agilex5.

This driver is extensible for other device family to use.

Signed-off-by: Boon Khai Ng <boon.khai.ng@intel.com>
8 months agoMerge patch series "arm: Add Analog Devices SC5xx Machine Type"
Tom Rini [Wed, 8 May 2024 01:24:07 +0000 (19:24 -0600)]
Merge patch series "arm: Add Analog Devices SC5xx Machine Type"

Greg Malysa <greg.malysa@timesys.com> says:

This series adds support for the ADI SC5xx machine type and includes two
core drivers that are required for being able to boot any board--a UART
driver, the gptimer driver which is used as a clock reference (CNTVCNT
is not supported on the armv7 sc5xx SoCs) and the clock tree driver. Our
corresponding Linux support relies on u-boot configuring the clocks
correctly before booting, so it is not possible to boot any board
without the CGU/CDU configuration happening here. There are also no
board files, device trees, or defconfigs included here, but some common
definitions that will be used to build board files currently are. The
sc5xx SoCs themselves include many armv7 families (sc57x, sc58x, and
sc594) all using an ARM Cortex-A5, and one armv8 family (sc598) indended
to be a drop-in replacement for the SC594 in terms of peripherals, with
a Cortex-A55 instead.

Some of the configuration code in dmcinit and clkinit is quite scary and
causes a lot of checkpatch violations. It is modified from code
initially provided by ADI, but it has not been fully rewritten. There's
a question of how important it is to clean up this code--it has some
quality violations, but it has been in use (including in production) for
over two years and is known to work for performing the low level SoC
initialization, while a rewrite might introduce timing or sequence bugs
that could take a significant amount of time to detect in the future.

8 months agodrivers: timer: Add in driver support for ADI SC5XX-family GP timer peripheral
Greg Malysa [Thu, 25 Apr 2024 00:04:03 +0000 (20:04 -0400)]
drivers: timer: Add in driver support for ADI SC5XX-family GP timer peripheral

Co-developed-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com>
Signed-off-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com>
Co-developed-by: Angelo Dureghello <angelo.dureghello@timesys.com>
Signed-off-by: Angelo Dureghello <angelo.dureghello@timesys.com>
Co-developed-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Greg Malysa <greg.malysa@timesys.com>
8 months agodrivers: serial: Add in UART for ADI SC5XX-family processors
Nathan Barrett-Morrison [Thu, 25 Apr 2024 00:04:02 +0000 (20:04 -0400)]
drivers: serial: Add in UART for ADI SC5XX-family processors

Co-developed-by: Greg Malysa <greg.malysa@timesys.com>
Signed-off-by: Greg Malysa <greg.malysa@timesys.com>
Co-developed-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Vasileios Bimpikas <vasileios.bimpikas@analog.com>
Signed-off-by: Utsav Agarwal <utsav.agarwal@analog.com>
Signed-off-by: Arturs Artamonovs <arturs.artamonovs@analog.com>
Signed-off-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com>
8 months agodrivers: clk: adi: Add in SC5XX-family clock driver
Nathan Barrett-Morrison [Thu, 25 Apr 2024 00:04:01 +0000 (20:04 -0400)]
drivers: clk: adi: Add in SC5XX-family clock driver

This adds support for the SC5XX clock trees which are required for reading
clock speeds on the SoCs. This is largely a port of the same support for
Linux, which has not yet been submitted upstream.

Co-developed-by: Greg Malysa <greg.malysa@timesys.com>
Signed-off-by: Greg Malysa <greg.malysa@timesys.com>
Co-developed-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Vasileios Bimpikas <vasileios.bimpikas@analog.com>
Signed-off-by: Utsav Agarwal <utsav.agarwal@analog.com>
Signed-off-by: Arturs Artamonovs <arturs.artamonovs@analog.com>
Signed-off-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com>
8 months agoarch: arm: Add Analog Devices SC5xx machine type
Nathan Barrett-Morrison [Thu, 25 Apr 2024 00:04:00 +0000 (20:04 -0400)]
arch: arm: Add Analog Devices SC5xx machine type

Add support for the SC5xx machine type from Analog Devices. This
includes support for the SC57x, SC58x, SC59x, and SC59x-64 SoCs, which
have many common features such as common ADI IP blocks, and SHARC DSP
cores. This commit introduces core functionality required for all boards
using an SC5xx SoC, such as:

- SPL configuration
- Required CPU hooks such as reset
- Boot ROM interaction to load the stage 2 bootloader in the reference
  configuration. Other options are possible but not officially supported
  at this time
- SoC-common configuration expected to be reused by all boards
- Early initialization for system clocks and DDR controller

Co-developed-by: Greg Malysa <greg.malysa@timesys.com>
Signed-off-by: Greg Malysa <greg.malysa@timesys.com>
Co-developed-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Ian Roberts <ian.roberts@timesys.com>
Signed-off-by: Vasileios Bimpikas <vasileios.bimpikas@analog.com>
Signed-off-by: Utsav Agarwal <utsav.agarwal@analog.com>
Signed-off-by: Arturs Artamonovs <arturs.artamonovs@analog.com>
Signed-off-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com>
8 months agoMerge branch '2024-05-06-remove-include-common_h' into next
Tom Rini [Tue, 7 May 2024 14:01:06 +0000 (08:01 -0600)]
Merge branch '2024-05-06-remove-include-common_h' into next

- Merge the four series that I made to finally remove include/common.h.
  For the most part, this is just removing <common.h> entirely. In a few
  cases we needed to add <linux/types.h> or <time.h>. In the case of
  PowerPC related code, we instead need to bring in <asm/ppc.h>.

8 months agocommon.h: Remove this file and all references
Tom Rini [Thu, 2 May 2024 01:31:38 +0000 (19:31 -0600)]
common.h: Remove this file and all references

With all files that had included this file directly having been updated,
we can now remove this file.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoapi: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:37 +0000 (19:31 -0600)]
api: Remove <common.h> and add needed includes

Remove <common.h> from here and when needed add missing include files
directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoxen: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:36 +0000 (19:31 -0600)]
xen: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agowatchdog: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:35 +0000 (19:31 -0600)]
watchdog: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Acked-by: Angelo Dureghello <angelo@kernel-space.org>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agow1-eeprom: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:34 +0000 (19:31 -0600)]
w1-eeprom: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agow1: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:33 +0000 (19:31 -0600)]
w1: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agovirtio: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:32 +0000 (19:31 -0600)]
virtio: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agovideo: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:31 +0000 (19:31 -0600)]
video: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Peter Robinson <pbrobinson@gmail.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoreboot-mode: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:12 +0000 (19:31 -0600)]
reboot-mode: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agousb: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:30 +0000 (19:31 -0600)]
usb: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoram: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:11 +0000 (19:31 -0600)]
ram: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoufs: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:29 +0000 (19:31 -0600)]
ufs: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agopwm: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:10 +0000 (19:31 -0600)]
pwm: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agotpm: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:28 +0000 (19:31 -0600)]
tpm: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agopower: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:09 +0000 (19:31 -0600)]
power: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agotimer: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:27 +0000 (19:31 -0600)]
timer: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agopinctrl: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:08 +0000 (19:31 -0600)]
pinctrl: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Peter Robinson <pbrobinson@gmail.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agothermal: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:26 +0000 (19:31 -0600)]
thermal: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agophy: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:07 +0000 (19:31 -0600)]
phy: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agosysreset: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:25 +0000 (19:31 -0600)]
sysreset: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agopci_endpoint: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:06 +0000 (19:31 -0600)]
pci_endpoint: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agosysinfo: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:24 +0000 (19:31 -0600)]
sysinfo: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agospmi: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:23 +0000 (19:31 -0600)]
spmi: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agospi: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:22 +0000 (19:31 -0600)]
spi: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Cédric Le Goater <clg@kaod.org>
Reviewed-by: William Zhang <william.zhang@broadcom.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agosound: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:21 +0000 (19:31 -0600)]
sound: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agosoc: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:20 +0000 (19:31 -0600)]
soc: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Bryan Brattlof <bb@ti.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agosmem: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:19 +0000 (19:31 -0600)]
smem: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agosm: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:18 +0000 (19:31 -0600)]
sm: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoserial: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:17 +0000 (19:31 -0600)]
serial: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Peter Robinson <pbrobinson@gmail.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoscsi: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:16 +0000 (19:31 -0600)]
scsi: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agortc: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:15 +0000 (19:31 -0600)]
rtc: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoreset: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:14 +0000 (19:31 -0600)]
reset: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoremoteproc: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:13 +0000 (19:31 -0600)]
remoteproc: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agopci: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:05 +0000 (19:31 -0600)]
pci: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Heiko Schocher <hs@denx.de>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agopch: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:04 +0000 (19:31 -0600)]
pch: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agonvme: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:03 +0000 (19:31 -0600)]
nvme: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agonet: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:02 +0000 (19:31 -0600)]
net: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agomux: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:01 +0000 (19:31 -0600)]
mux: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agomtd: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:31:00 +0000 (19:31 -0600)]
mtd: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: William Zhang <william.zhang@broadcom.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agommc: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:59 +0000 (19:30 -0600)]
mmc: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Jaehoon Chung <jh80.chung@samsung.com>
Reviewed-by: Peter Robinson <pbrobinson@gmail.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agomisc: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:58 +0000 (19:30 -0600)]
misc: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agomemory: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:57 +0000 (19:30 -0600)]
memory: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agomailbox: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:56 +0000 (19:30 -0600)]
mailbox: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoled: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:55 +0000 (19:30 -0600)]
led: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoiommu: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:54 +0000 (19:30 -0600)]
iommu: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoinput: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:53 +0000 (19:30 -0600)]
input: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoi2c: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:52 +0000 (19:30 -0600)]
i2c: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Heiko Schocher <hs@denx.de>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agohwspinlock: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:51 +0000 (19:30 -0600)]
hwspinlock: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agogpio: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:50 +0000 (19:30 -0600)]
gpio: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Heiko Schocher <hs@denx.de>
Reviewed-by: Peter Robinson <pbrobinson@gmail.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agofwu-mdata: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:49 +0000 (19:30 -0600)]
fwu-mdata: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Acked-by: Jassi Brar <jassisinghbrar@gmail.com>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agofuzz: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:48 +0000 (19:30 -0600)]
fuzz: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agofpga: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:47 +0000 (19:30 -0600)]
fpga: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agofirmware: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:46 +0000 (19:30 -0600)]
firmware: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agofastboot: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:45 +0000 (19:30 -0600)]
fastboot: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoextcon: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:44 +0000 (19:30 -0600)]
extcon: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agodma: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:43 +0000 (19:30 -0600)]
dma: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agodfu: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:42 +0000 (19:30 -0600)]
dfu: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agodemo: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:41 +0000 (19:30 -0600)]
demo: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>
8 months agoddr: Remove <common.h> and add needed includes
Tom Rini [Thu, 2 May 2024 01:30:40 +0000 (19:30 -0600)]
ddr: Remove <common.h> and add needed includes

Remove <common.h> from this driver directory and when needed
add missing include files directly.

Signed-off-by: Tom Rini <trini@konsulko.com>