From 57a48cba3d39b7d11e30a580fc266dda8a2137e9 Mon Sep 17 00:00:00 2001
From: Robert Nelson <robertcnelson@gmail.com>
Date: Fri, 30 Jul 2021 18:06:43 -0500
Subject: [PATCH] kernel v5.14-rc3 rebase with: device-tree/etc BBDTBS:
 https://github.com/beagleboard/BeagleBoard-DeviceTrees/commit/1c8a3d3fdb994c8ab224a9343b622d8acf3908c7
 TI_AMX3_CM3:
 http://git.ti.com/gitweb/?p=processor-firmware/ti-amx3-cm3-pm-firmware.git;a=commit;h=fb484c5e54f2e31cf0a338d2927a06a2870bcc2c
 WPANUSB:
 https://github.com/statropy/wpanusb/commit/251f0167545bf2dcaa3cad991a59dbf5ab05490a
 WIRELESS_REGDB:
 https://git.kernel.org/pub/scm/linux/kernel/git/sforshee/wireless-regdb.git/commit/?id=a4468e8f1ff2710982d2a8042e974d801e3a7ba0

Signed-off-by: Robert Nelson <robertcnelson@gmail.com>
---
 patch.sh                                      |  20 +-
 patches/defconfig                             |   2 -
 ...-am335x-boneblue-add-gpio-line-names.patch | 176 +++++++++++++
 ...m335x-boneblack-Extract-HDMI-config.patch} |   9 +-
 ...5x-sancloud-bbe-Extract-common-code.patch} |   7 +-
 ...5x-sancloud-bbe-lite-New-devicetree.patch} |  20 +-
 ...001-ARM-dts-am33xx-l4-Add-PRUSS-node.patch | 134 ++++++++++
 ...xx-l4-Add-PRUSS-MDIO-controller-node.patch |  47 ++++
 ...35x-bone-common-Enable-PRU-ICSS-node.patch |  36 +++
 ...ts-am335x-evm-Enable-PRU-ICSS-module.patch |  36 +++
 ...-am335x-evmsk-Enable-PRU-ICSS-module.patch |  36 +++
 ...-am335x-icev2-Enable-PRU-ICSS-module.patch |  36 +++
 ...dts-am4372-Add-the-PRU-ICSS1-DT-node.patch | 147 +++++++++++
 ...dts-am4372-Add-the-PRU-ICSS0-DT-node.patch | 139 ++++++++++
 ...m4372-Add-PRUSS-MDIO-controller-node.patch | 116 +++++++++
 ...10-ARM-dts-am57xx-Add-PRU-ICSS-nodes.patch | 241 ++++++++++++++++++
 ...57xx-Add-PRUSS-MDIO-controller-nodes.patch | 151 +++++++++++
 ...dopt-SanCloud-dts-files-as-supported.patch |  34 ---
 patches/git/BBDTBS                            |   2 +-
 patches/ref_omap2plus_defconfig               |   2 -
 ...-BeagleBoard.org-Device-Tree-Changes.patch | 152 +++--------
 version.sh                                    |   2 +-
 22 files changed, 1362 insertions(+), 183 deletions(-)
 create mode 100644 patches/dts/omap/0001-ARM-dts-am335x-boneblue-add-gpio-line-names.patch
 rename patches/dts/{sancloud/0001-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch => omap/0002-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch} (97%)
 rename patches/dts/{sancloud/0002-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch => omap/0003-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch} (97%)
 rename patches/dts/{sancloud/0003-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch => omap/0004-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch} (81%)
 create mode 100644 patches/dts/omap_pruss/0001-ARM-dts-am33xx-l4-Add-PRUSS-node.patch
 create mode 100644 patches/dts/omap_pruss/0002-ARM-dts-am33xx-l4-Add-PRUSS-MDIO-controller-node.patch
 create mode 100644 patches/dts/omap_pruss/0003-ARM-dts-am335x-bone-common-Enable-PRU-ICSS-node.patch
 create mode 100644 patches/dts/omap_pruss/0004-ARM-dts-am335x-evm-Enable-PRU-ICSS-module.patch
 create mode 100644 patches/dts/omap_pruss/0005-ARM-dts-am335x-evmsk-Enable-PRU-ICSS-module.patch
 create mode 100644 patches/dts/omap_pruss/0006-ARM-dts-am335x-icev2-Enable-PRU-ICSS-module.patch
 create mode 100644 patches/dts/omap_pruss/0007-ARM-dts-am4372-Add-the-PRU-ICSS1-DT-node.patch
 create mode 100644 patches/dts/omap_pruss/0008-ARM-dts-am4372-Add-the-PRU-ICSS0-DT-node.patch
 create mode 100644 patches/dts/omap_pruss/0009-ARM-dts-am4372-Add-PRUSS-MDIO-controller-node.patch
 create mode 100644 patches/dts/omap_pruss/0010-ARM-dts-am57xx-Add-PRU-ICSS-nodes.patch
 create mode 100644 patches/dts/omap_pruss/0011-ARM-dts-am57xx-Add-PRUSS-MDIO-controller-nodes.patch
 delete mode 100644 patches/dts/sancloud/0004-MAINTAINERS-Adopt-SanCloud-dts-files-as-supported.patch

diff --git a/patch.sh b/patch.sh
index fd5a0d18d..50ed816a1 100644
--- a/patch.sh
+++ b/patch.sh
@@ -348,8 +348,9 @@ ti_pm_firmware () {
 	dir 'drivers/ti/firmware'
 }
 
-sancloud_next () {
-	dir 'dts/sancloud'
+next_dtbs () {
+	dir 'dts/omap'
+	dir 'dts/omap_pruss'
 }
 
 cleanup_dts_builds () {
@@ -391,15 +392,8 @@ beagleboard_dtbs () {
 		cp -vr ../${work_dir}/include/dt-bindings/* ./include/dt-bindings/
 
 		device="am335x-bonegreen-gateway.dtb" ; dtb_makefile_append
-		device="am335x-sancloud-bbe-lite.dtb" ; dtb_makefile_append
 
 		device="am335x-boneblack-uboot.dtb" ; dtb_makefile_append
-		#device="am335x-sancloud-bbe-uboot.dtb" ; dtb_makefile_append
-
-		#device="am335x-bone-uboot-univ.dtb" ; dtb_makefile_append
-		#device="am335x-boneblack-uboot-univ.dtb" ; dtb_makefile_append
-		#device="am335x-bonegreen-wireless-uboot-univ.dtb" ; dtb_makefile_append
-		#device="am335x-sancloud-bbe-uboot-univ.dtb" ; dtb_makefile_append
 
 		${git_bin} add -f arch/arm/boot/dts/
 		${git_bin} add -f include/dt-bindings/
@@ -434,8 +428,8 @@ wpanusb
 #rt
 wireless_regdb
 ti_pm_firmware
-sancloud_next
-beagleboard_dtbs
+next_dtbs
+#beagleboard_dtbs
 #local_patch
 
 pre_backports () {
@@ -511,7 +505,7 @@ reverts () {
 drivers () {
 	#https://github.com/raspberrypi/linux/branches
 	#exit 2
-	dir 'RPi'
+	#dir 'RPi'
 	dir 'drivers/ar1021_i2c'
 	dir 'drivers/spi'
 	dir 'drivers/tps65217'
@@ -519,7 +513,7 @@ drivers () {
 	dir 'drivers/ti/cpsw'
 	dir 'drivers/ti/serial'
 	dir 'drivers/ti/tsc'
-	dir 'drivers/ti/gpio'
+	#dir 'drivers/ti/gpio'
 	dir 'drivers/greybus'
 	dir 'drivers/serdev'
 	dir 'drivers/fb_ssd1306'
diff --git a/patches/defconfig b/patches/defconfig
index 9fdee2906..a7309ba5b 100644
--- a/patches/defconfig
+++ b/patches/defconfig
@@ -2119,7 +2119,6 @@ CONFIG_TI_ST=m
 # CONFIG_SENSORS_LIS3_SPI is not set
 # CONFIG_SENSORS_LIS3_I2C is not set
 # CONFIG_ALTERA_STAPL is not set
-CONFIG_BEAGLEBONE_PINMUX_HELPER=y
 # CONFIG_ECHO is not set
 # CONFIG_MISC_RTSX_USB is not set
 # CONFIG_UACCE is not set
@@ -3200,7 +3199,6 @@ CONFIG_GPIOLIB_IRQCHIP=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_CDEV=y
 CONFIG_GPIO_CDEV_V1=y
-CONFIG_GPIO_OF_HELPER=y
 CONFIG_GPIO_GENERIC=y
 CONFIG_GPIO_MAX730X=m
 
diff --git a/patches/dts/omap/0001-ARM-dts-am335x-boneblue-add-gpio-line-names.patch b/patches/dts/omap/0001-ARM-dts-am335x-boneblue-add-gpio-line-names.patch
new file mode 100644
index 000000000..a791bbc38
--- /dev/null
+++ b/patches/dts/omap/0001-ARM-dts-am335x-boneblue-add-gpio-line-names.patch
@@ -0,0 +1,176 @@
+From 885971db68665badce8d9a0b0454376918391960 Mon Sep 17 00:00:00 2001
+From: David Lechner <david@lechnology.com>
+Date: Fri, 9 Jul 2021 16:47:06 -0500
+Subject: [PATCH 1/4] ARM: dts: am335x-boneblue: add gpio-line-names
+
+This adds gpio-line-names to the BeagleBone Blue DTS. The line names
+are based on the BeagleBone Blue rev A2 schematic.
+
+Signed-off-by: David Lechner <david@lechnology.com>
+Signed-off-by: Tony Lindgren <tony@atomide.com>
+---
+ arch/arm/boot/dts/am335x-boneblue.dts | 143 +++++++++++++++++++++++++-
+ 1 file changed, 142 insertions(+), 1 deletion(-)
+
+diff --git a/arch/arm/boot/dts/am335x-boneblue.dts b/arch/arm/boot/dts/am335x-boneblue.dts
+index 0afcc2ee0b63..c6bb325ead33 100644
+--- a/arch/arm/boot/dts/am335x-boneblue.dts
++++ b/arch/arm/boot/dts/am335x-boneblue.dts
+@@ -435,12 +435,153 @@ &dcan1 {
+ 	status = "okay";
+ };
+ 
++&gpio0 {
++	gpio-line-names =
++		"UART3_CTS", /* M17 */
++		"UART3_RTS", /* M18 */
++		"UART2_RX", /* A17 */
++		"UART2_TX", /* B17 */
++		"I2C1_SDA", /* B16 */
++		"I2C1_SCL", /* A16 */
++		"MMC0_CD", /* C15 */
++		"SPI1_SS2", /* C18 */
++		"EQEP_1A", /* V2 */
++		"EQEP_1B", /* V3 */
++		"MDIR_2B", /* V4 */
++		"BATT_LED_2", /* T5 */
++		"I2C2_SDA", /* D18 */
++		"I2C2_SCL", /* D17 */
++		"UART1_RX", /* D16 */
++		"UART1_TX", /* D15 */
++		"MMC2_DAT1", /* J18 */
++		"MMC2_DAT2", /* K15 */
++		"NC", /* F16 */
++		"WIFI_LED", /* A15 */
++		"MOT_STBY", /* D14 */
++		"WLAN_IRQ", /* K16 */
++		"PWM_2A", /* U10 */
++		"PWM_2B", /* T10 */
++		"",
++		"",
++		"BATT_LED_4", /* T11 */
++		"BATT_LED_1", /* U12 */
++		"BT_EN", /* K17 */
++		"SPI1_SS1", /* H18 */
++		"UART4_RX", /* T17 */
++		"MDIR_1B"; /* U17 */
++};
++
++&gpio1 {
++	gpio-line-names =
++		"MMC1_DAT0", /* U7 */
++		"MMC1_DAT1", /* V7 */
++		"MMC1_DAT2", /* R8 */
++		"MMC1_DAT3", /* T8 */
++		"MMC1_DAT4", /* U8 */
++		"MMC1_DAT5", /* V8 */
++		"MMC1_DAT6", /* R9 */
++		"MMC1_DAT7", /* T9 */
++		"DCAN1_TX", /* E18 */
++		"DCAN1_RX", /* E17 */
++		"UART0_RX", /* E15 */
++		"UART0_TX", /* E16 */
++		"EQEP_2A", /* T12 */
++		"EQEP_2B", /* R12 */
++		"PRU_E_A", /* V13 */
++		"PRU_E_B", /* U13 */
++		"MDIR_2A", /* R13 */
++		"GPIO1_17", /* V14 */
++		"PWM_1A", /* U14 */
++		"PWM_1B", /* T14 */
++		"EMMC_RST", /* R14 */
++		"USR_LED_0", /* V15 */
++		"USR_LED_1", /* U15 */
++		"USR_LED_2", /* T15 */
++		"USR_LED_3", /* V16 */
++		"GPIO1_25", /* U16 */
++		"MCASP0_AXR0", /* T16 */
++		"MCASP0_AXR1", /* V17 */
++		"MCASP0_ACLKR", /* U18 */
++		"BATT_LED_3", /* V6 */
++		"MMC1_CLK", /* U9 */
++		"MMC1_CMD"; /* V9 */
++};
++
++&gpio2 {
++	gpio-line-names =
++		"MDIR_1A", /* T13 */
++		"MCASP0_FSR", /* V12 */
++		"LED_RED", /* R7 */
++		"LED_GREEN", /* T7 */
++		"MODE_BTN", /* U6 */
++		"PAUSE_BTN", /* T6 */
++		"MDIR_4A", /* R1 */
++		"MDIR_4B", /* R2 */
++		"MDIR_3B", /* R3 */
++		"MDIR_3A", /* R4 */
++		"SVO7", /* T1 */
++		"SVO8", /* T2 */
++		"SVO5", /* T3 */
++		"SVO6", /* T4 */
++		"UART5_TX", /* U1 */
++		"UART5_RX", /* U2 */
++		"SERVO_EN", /* U3 */
++		"NC", /* U4 */
++		"UART3_RX", /* L17 */
++		"UART3_TX", /* L16 */
++		"MMC2_CLK", /* L15 */
++		"DCAN1_SILENT", /* M16 */
++		"SVO1", /* U5 */
++		"SVO3", /* R5 */
++		"SVO2", /* V5 */
++		"SVO4", /* R6 */
++		"MMC0_DAT3", /* F17 */
++		"MMC0_DAT2", /* F18 */
++		"MMC0_DAT1", /* G15 */
++		"MMC0_DAT0", /* G16 */
++		"MMC0_CLK", /* G17 */
++		"MMC0_CMD"; /* G18 */
++};
++
+ &gpio3 {
++	gpio-line-names =
++		"MMC2_DAT3", /* H16 */
++		"GPIO3_1", /* H17 */
++		"GPIO3_2", /* J15 */
++		"MMC2_CMD", /* J16 */
++		"MMC2_DAT0", /* J17 */
++		"I2C0_SDA", /* C17 */
++		"I2C0_SCL", /* C16 */
++		"EMU1", /* C14 */
++		"EMU0", /* B14 */
++		"WL_EN", /* K18 */
++		"WL_BT_OE", /* L18 */
++		"",
++		"",
++		"NC", /* F15 */
++		"SPI1_SCK", /* A13 */
++		"SPI1_MISO", /* B13 */
++		"SPI1_MOSI", /* D12 */
++		"GPIO3_17", /* C12 */
++		"EQEP_0A", /* B12 */
++		"EQEP_0B", /* C13 */
++		"GPIO3_20", /* D13 */
++		"IMU_INT", /* A14 */
++		"",
++		"",
++		"",
++		"",
++		"",
++		"",
++		"",
++		"",
++		"",
++		"";
++
+ 	ls-buf-en-hog {
+ 		gpio-hog;
+ 		gpios = <10 GPIO_ACTIVE_HIGH>;
+ 		output-high;
+-		line-name = "LS_BUF_EN";
+ 	};
+ };
+ 
+-- 
+2.30.2
+
diff --git a/patches/dts/sancloud/0001-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch b/patches/dts/omap/0002-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch
similarity index 97%
rename from patches/dts/sancloud/0001-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch
rename to patches/dts/omap/0002-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch
index d418c6e40..3228feb4b 100644
--- a/patches/dts/sancloud/0001-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch
+++ b/patches/dts/omap/0002-ARM-dts-am335x-boneblack-Extract-HDMI-config.patch
@@ -1,7 +1,7 @@
-From fda4a8ecc74808ecb4c86edecea32a6375ec6259 Mon Sep 17 00:00:00 2001
+From 8b113de254951b51dc2026af863ab6b9fef56c34 Mon Sep 17 00:00:00 2001
 From: Paul Barker <paul.barker@sancloud.com>
-Date: Thu, 17 Jun 2021 10:33:27 +0100
-Subject: [PATCH 1/4] ARM: dts: am335x-boneblack: Extract HDMI config
+Date: Tue, 20 Jul 2021 09:39:25 +0100
+Subject: [PATCH 2/4] ARM: dts: am335x-boneblack: Extract HDMI config
 
 Move the HDMI hardware configuration for the BeagleBone Black out of the
 boneblack common dtsi file and into its own separate dtsi file. This
@@ -11,6 +11,7 @@ to duplicate configuration or override the status of all hdmi-related
 nodes.
 
 Signed-off-by: Paul Barker <paul.barker@sancloud.com>
+Signed-off-by: Tony Lindgren <tony@atomide.com>
 ---
  .../arm/boot/dts/am335x-boneblack-common.dtsi | 135 -----------------
  arch/arm/boot/dts/am335x-boneblack-hdmi.dtsi  | 141 ++++++++++++++++++
@@ -328,7 +329,7 @@ index 000000000000..7cfddada9348
 +	};
 +};
 diff --git a/arch/arm/boot/dts/am335x-boneblack-wireless.dts b/arch/arm/boot/dts/am335x-boneblack-wireless.dts
-index 86cad9912906..2bec2287fefe 100644
+index 80116646a3fe..8b2b24c80670 100644
 --- a/arch/arm/boot/dts/am335x-boneblack-wireless.dts
 +++ b/arch/arm/boot/dts/am335x-boneblack-wireless.dts
 @@ -7,6 +7,7 @@
diff --git a/patches/dts/sancloud/0002-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch b/patches/dts/omap/0003-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch
similarity index 97%
rename from patches/dts/sancloud/0002-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch
rename to patches/dts/omap/0003-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch
index d5c80d172..8d053c0f5 100644
--- a/patches/dts/sancloud/0002-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch
+++ b/patches/dts/omap/0003-ARM-dts-am335x-sancloud-bbe-Extract-common-code.patch
@@ -1,12 +1,13 @@
-From 527e5f3d86353385f26573fb531d553713a79db5 Mon Sep 17 00:00:00 2001
+From a70b987a4be9781c67d792f827a851112be1d0f6 Mon Sep 17 00:00:00 2001
 From: Paul Barker <paul.barker@sancloud.com>
-Date: Thu, 17 Jun 2021 10:33:28 +0100
-Subject: [PATCH 2/4] ARM: dts: am335x-sancloud-bbe: Extract common code
+Date: Tue, 20 Jul 2021 09:39:26 +0100
+Subject: [PATCH 3/4] ARM: dts: am335x-sancloud-bbe: Extract common code
 
 The Sancloud BBE, BBE Lite and BBE Extended+WiFi share a common hardware
 base so we can avoid duplication via a dtsi file.
 
 Signed-off-by: Paul Barker <paul.barker@sancloud.com>
+Signed-off-by: Tony Lindgren <tony@atomide.com>
 ---
  .../boot/dts/am335x-sancloud-bbe-common.dtsi  | 96 +++++++++++++++++++
  arch/arm/boot/dts/am335x-sancloud-bbe.dts     | 91 +-----------------
diff --git a/patches/dts/sancloud/0003-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch b/patches/dts/omap/0004-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch
similarity index 81%
rename from patches/dts/sancloud/0003-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch
rename to patches/dts/omap/0004-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch
index f1c116258..aff311cbb 100644
--- a/patches/dts/sancloud/0003-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch
+++ b/patches/dts/omap/0004-ARM-dts-am335x-sancloud-bbe-lite-New-devicetree.patch
@@ -1,23 +1,24 @@
-From c11ab8f829d78b964bc0489bc1ff6bae6a0af093 Mon Sep 17 00:00:00 2001
+From ac262b7f9a3e58acbc9c40d55826fc09cd089fbf Mon Sep 17 00:00:00 2001
 From: Paul Barker <paul.barker@sancloud.com>
-Date: Thu, 17 Jun 2021 10:33:29 +0100
-Subject: [PATCH 3/4] ARM: dts: am335x-sancloud-bbe-lite: New devicetree
+Date: Tue, 20 Jul 2021 09:39:27 +0100
+Subject: [PATCH 4/4] ARM: dts: am335x-sancloud-bbe-lite: New devicetree
 
 This adds support for the Sancloud BBE Lite which shares a common
 hardware base with the non-Lite version of the BBE.
 
 Signed-off-by: Paul Barker <paul.barker@sancloud.com>
+Signed-off-by: Tony Lindgren <tony@atomide.com>
 ---
  arch/arm/boot/dts/Makefile                    |  1 +
- .../arm/boot/dts/am335x-sancloud-bbe-lite.dts | 51 +++++++++++++++++++
- 2 files changed, 52 insertions(+)
+ .../arm/boot/dts/am335x-sancloud-bbe-lite.dts | 50 +++++++++++++++++++
+ 2 files changed, 51 insertions(+)
  create mode 100644 arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts
 
 diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
-index f8f09c5066e7..8629c941f573 100644
+index 863347b6b65e..8da525e7f0ab 100644
 --- a/arch/arm/boot/dts/Makefile
 +++ b/arch/arm/boot/dts/Makefile
-@@ -834,6 +834,7 @@ dtb-$(CONFIG_SOC_AM33XX) += \
+@@ -843,6 +843,7 @@ dtb-$(CONFIG_SOC_AM33XX) += \
  	am335x-pocketbeagle.dtb \
  	am335x-regor-rdk.dtb \
  	am335x-sancloud-bbe.dtb \
@@ -27,10 +28,10 @@ index f8f09c5066e7..8629c941f573 100644
  	am335x-sl50.dtb \
 diff --git a/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts b/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts
 new file mode 100644
-index 000000000000..9c311bd106f6
+index 000000000000..d6ef19311a91
 --- /dev/null
 +++ b/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts
-@@ -0,0 +1,51 @@
+@@ -0,0 +1,50 @@
 +// SPDX-License-Identifier: GPL-2.0-only
 +/*
 + * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
@@ -75,7 +76,6 @@ index 000000000000..9c311bd106f6
 +		#size-cells = <0>;
 +
 +		compatible = "micron,spi-authenta";
-+		symlink = "spi/0.0";
 +
 +		reg = <0>;
 +		spi-max-frequency = <16000000>;
diff --git a/patches/dts/omap_pruss/0001-ARM-dts-am33xx-l4-Add-PRUSS-node.patch b/patches/dts/omap_pruss/0001-ARM-dts-am33xx-l4-Add-PRUSS-node.patch
new file mode 100644
index 000000000..6283c6b93
--- /dev/null
+++ b/patches/dts/omap_pruss/0001-ARM-dts-am33xx-l4-Add-PRUSS-node.patch
@@ -0,0 +1,134 @@
+From 389093c2f12e8e2fb822d726a2927f0f8a04a7e8 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:11 -0500
+Subject: [PATCH 01/11] ARM: dts: am33xx-l4: Add PRUSS node
+
+Add the DT nodes for the PRU-ICSS on AM33xx family of SoCs. The AM33xx
+SoCs contain a single PRU-ICSS instance and is represented by a pruss
+node and other child nodes. PRU-ICSS is supported only on AM3356+ SoCs
+though in the AM33xx family, so the nodes are added under the
+corresponding disabled interconnect target module node in the common
+am33xx-l4 dtsi file. The target module node should be enabled in only
+those derivative board files that use a SoC containing PRU-ICSS.
+
+The PRUSS subsystem node contains the entire address space. The various
+sub-modules of the PRU-ICSS are represented as individual child nodes
+(so platform devices themselves) of the PRUSS subsystem node. These
+include the two PRU cores and the interrupt controller. All the Data
+RAMs are represented within a child node of its own named 'memories'
+without any compatible. The Real Time Media Independent Interface
+controller (MII_RT), and the CFG sub-module are represented as syscon
+nodes. The PRUSS CFG module has a clock mux for IEP clock, this clk
+node is added under the CFG child node 'clocks'. The default source
+for this mux clock is the PRU_ICSS_IEP_GCLK clock.
+
+The DT nodes use all standard properties. The regs property in the PRU
+nodes define the addresses for the Instruction RAM, the Debug and Control
+sub-modules for that PRU core. The firmware for each PRU core is defined
+through a 'firmware-name' property.
+
+The default names for the firmware images for each PRU core are defined
+as follows (these can be adjusted either in derivative board dts files
+or through sysfs at runtime if required):
+     PRU-ICSS PRU0 Core: am335x-pru1_0-fw
+     PRU-ICSS PRU1 Core: am335x-pru1_1-fw
+
+Note:
+1. There are few more sub-modules like the Industrial Ethernet Peripheral
+   (IEP), MDIO, UART, eCAP that do not have bindings and so will be added
+   in the future.
+2. The PRUSS INTC on AM335x SoCs also connect the host interrupts 0 to
+   TSC_ADC; 6 and 7 as possible DMA events, so use the 'ti,irqs-reserved'
+   property in derivative board dts files _if_ any of them should not be
+   handled by the host OS.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am33xx-l4.dtsi | 71 ++++++++++++++++++++++++++++++++
+ 1 file changed, 71 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am33xx-l4.dtsi b/arch/arm/boot/dts/am33xx-l4.dtsi
+index 859e760df4c8..148176361b4e 100644
+--- a/arch/arm/boot/dts/am33xx-l4.dtsi
++++ b/arch/arm/boot/dts/am33xx-l4.dtsi
+@@ -853,6 +853,77 @@ pruss_tm: target-module@300000 {	/* 0x4a300000, ap 9 04.0 */
+ 			#size-cells = <1>;
+ 			ranges = <0x0 0x300000 0x80000>;
+ 			status = "disabled";
++
++			pruss: pruss@0 {
++				compatible = "ti,am3356-pruss";
++				reg = <0x0 0x80000>;
++				#address-cells = <1>;
++				#size-cells = <1>;
++				ranges;
++
++				pruss_mem: memories@0 {
++					reg = <0x0 0x2000>,
++					      <0x2000 0x2000>,
++					      <0x10000 0x3000>;
++					reg-names = "dram0", "dram1",
++						    "shrdram2";
++				};
++
++				pruss_cfg: cfg@26000 {
++					compatible = "ti,pruss-cfg", "syscon";
++					reg = <0x26000 0x2000>;
++					#address-cells = <1>;
++					#size-cells = <1>;
++					ranges = <0x0 0x26000 0x2000>;
++
++					clocks {
++						#address-cells = <1>;
++						#size-cells = <0>;
++
++						pruss_iepclk_mux: iepclk-mux@30 {
++							reg = <0x30>;
++							#clock-cells = <0>;
++							clocks = <&l3_gclk>,        /* icss_iep_gclk */
++								 <&pruss_ocp_gclk>; /* icss_ocp_gclk */
++						};
++					};
++				};
++
++				pruss_mii_rt: mii-rt@32000 {
++					compatible = "ti,pruss-mii", "syscon";
++					reg = <0x32000 0x58>;
++				};
++
++				pruss_intc: interrupt-controller@20000 {
++					compatible = "ti,pruss-intc";
++					reg = <0x20000 0x2000>;
++					interrupts = <20 21 22 23 24 25 26 27>;
++					interrupt-names = "host_intr0", "host_intr1",
++							  "host_intr2", "host_intr3",
++							  "host_intr4", "host_intr5",
++							  "host_intr6", "host_intr7";
++					interrupt-controller;
++					#interrupt-cells = <3>;
++				};
++
++				pru0: pru@34000 {
++					compatible = "ti,am3356-pru";
++					reg = <0x34000 0x2000>,
++					      <0x22000 0x400>,
++					      <0x22400 0x100>;
++					reg-names = "iram", "control", "debug";
++					firmware-name = "am335x-pru0-fw";
++				};
++
++				pru1: pru@38000 {
++					compatible = "ti,am3356-pru";
++					reg = <0x38000 0x2000>,
++					      <0x24000 0x400>,
++					      <0x24400 0x100>;
++					reg-names = "iram", "control", "debug";
++					firmware-name = "am335x-pru1-fw";
++				};
++			};
+ 		};
+ 	};
+ };
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0002-ARM-dts-am33xx-l4-Add-PRUSS-MDIO-controller-node.patch b/patches/dts/omap_pruss/0002-ARM-dts-am33xx-l4-Add-PRUSS-MDIO-controller-node.patch
new file mode 100644
index 000000000..19fb572a8
--- /dev/null
+++ b/patches/dts/omap_pruss/0002-ARM-dts-am33xx-l4-Add-PRUSS-MDIO-controller-node.patch
@@ -0,0 +1,47 @@
+From e58a8c83926d9840c5db57967920f53b85bf1700 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:12 -0500
+Subject: [PATCH 02/11] ARM: dts: am33xx-l4: Add PRUSS MDIO controller node
+
+The PRUSS on AM335x SoCs has a MDIO sub-module that can be used
+to control external PHYs associated with the Industrial Ethernet
+peripherals within the PRUSS. The MDIO module used within the
+PRU-ICSS is an instance of the MDIO Controller used in TI Davinci
+SoCs. The same bus frequency of 1 MHz is chosen as the regular
+MDIO node.
+
+The node is added to the common am33xx-l4.dtsi file and is disabled.
+This needs to be enabled in the respective board files using the
+relevant AM335x SoCs supporting PRUSS and where the ethernet is
+pinned out and connected properly.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am33xx-l4.dtsi | 11 +++++++++++
+ 1 file changed, 11 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am33xx-l4.dtsi b/arch/arm/boot/dts/am33xx-l4.dtsi
+index 148176361b4e..c9629cb5ccd1 100644
+--- a/arch/arm/boot/dts/am33xx-l4.dtsi
++++ b/arch/arm/boot/dts/am33xx-l4.dtsi
+@@ -923,6 +923,17 @@ pru1: pru@38000 {
+ 					reg-names = "iram", "control", "debug";
+ 					firmware-name = "am335x-pru1-fw";
+ 				};
++
++				pruss_mdio: mdio@32400 {
++					compatible = "ti,davinci_mdio";
++					reg = <0x32400 0x90>;
++					clocks = <&dpll_core_m4_ck>;
++					clock-names = "fck";
++					bus_freq = <1000000>;
++					#address-cells = <1>;
++					#size-cells = <0>;
++					status = "disabled";
++				};
+ 			};
+ 		};
+ 	};
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0003-ARM-dts-am335x-bone-common-Enable-PRU-ICSS-node.patch b/patches/dts/omap_pruss/0003-ARM-dts-am335x-bone-common-Enable-PRU-ICSS-node.patch
new file mode 100644
index 000000000..269a446e2
--- /dev/null
+++ b/patches/dts/omap_pruss/0003-ARM-dts-am335x-bone-common-Enable-PRU-ICSS-node.patch
@@ -0,0 +1,36 @@
+From 697ee639f401b3b7f05ff38605016fcbbf3ecd66 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:13 -0500
+Subject: [PATCH 03/11] ARM: dts: am335x-bone-common: Enable PRU-ICSS node
+
+The PRU-ICSS target module node was left in disabled state in the base
+am33xx-l4.dtsi file. Enable this node on all the AM335x beaglebone
+boards as they mostly use a AM3358 or a AM3359 SoC which do contain
+the PRU-ICSS IP. The PRUSS node and most of its child nodes are already
+enabled in the base dts file, and so become effective automatically
+with the enabling of this PRU-ICSS target-module node.
+
+The corresponding PRU nodes can be disabled later on if there are
+no use-cases defined to use a particular PRU core or the whole
+PRU-ICSS subsystem itself if both its PRU cores are unused.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am335x-bone-common.dtsi | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi
+index 2d51d4bba6d4..34a0045b5f65 100644
+--- a/arch/arm/boot/dts/am335x-bone-common.dtsi
++++ b/arch/arm/boot/dts/am335x-bone-common.dtsi
+@@ -397,3 +397,7 @@ &rtc {
+ 	clocks = <&clk_32768_ck>, <&clk_24mhz_clkctrl AM3_CLK_24MHZ_CLKDIV32K_CLKCTRL 0>;
+ 	clock-names = "ext-clk", "int-clk";
+ };
++
++&pruss_tm {
++	status = "okay";
++};
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0004-ARM-dts-am335x-evm-Enable-PRU-ICSS-module.patch b/patches/dts/omap_pruss/0004-ARM-dts-am335x-evm-Enable-PRU-ICSS-module.patch
new file mode 100644
index 000000000..5e2bdbe6f
--- /dev/null
+++ b/patches/dts/omap_pruss/0004-ARM-dts-am335x-evm-Enable-PRU-ICSS-module.patch
@@ -0,0 +1,36 @@
+From cb65e449de7cf179fe37acc55d28e808de2d1db0 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:14 -0500
+Subject: [PATCH 04/11] ARM: dts: am335x-evm: Enable PRU-ICSS module
+
+The PRU-ICSS target module node was left in disabled state in the
+base am33xx-l4.dtsi file. PRU-ICSS is supported on the AM335x EVM,
+so enable this node on the AM335x EVM. The PRUSS node and most of
+its child nodes are already enabled in the base dts file, and so
+become effective automatically with the enabling of this PRU-ICSS
+target module node.
+
+The corresponding PRU nodes can be disabled later on if there are
+no use-cases defined to use a particular PRU core or the whole
+PRU-ICSS subsystem itself if both its PRU cores are unused.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am335x-evm.dts | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am335x-evm.dts b/arch/arm/boot/dts/am335x-evm.dts
+index 9cf39c93defb..659e99eabe66 100644
+--- a/arch/arm/boot/dts/am335x-evm.dts
++++ b/arch/arm/boot/dts/am335x-evm.dts
+@@ -778,3 +778,7 @@ &rtc {
+ 	clocks = <&clk_32768_ck>, <&clk_24mhz_clkctrl AM3_CLK_24MHZ_CLKDIV32K_CLKCTRL 0>;
+ 	clock-names = "ext-clk", "int-clk";
+ };
++
++&pruss_tm {
++	status = "okay";
++};
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0005-ARM-dts-am335x-evmsk-Enable-PRU-ICSS-module.patch b/patches/dts/omap_pruss/0005-ARM-dts-am335x-evmsk-Enable-PRU-ICSS-module.patch
new file mode 100644
index 000000000..c52a9734c
--- /dev/null
+++ b/patches/dts/omap_pruss/0005-ARM-dts-am335x-evmsk-Enable-PRU-ICSS-module.patch
@@ -0,0 +1,36 @@
+From 41363f63d0e21e55202f947e8a70a5eede212394 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:15 -0500
+Subject: [PATCH 05/11] ARM: dts: am335x-evmsk: Enable PRU-ICSS module
+
+The PRU-ICSS target module node was left in disabled state in the
+base am33xx-l4.dtsi file. PRU-ICSS is supported on the AM335x SK
+EVM board, so enable this node to support PRUSS on this board. The
+PRUSS node and most of its child nodes are already enabled in the
+base dts file, and so become effective automatically with the
+enabling of this PRU-ICSS target module node.
+
+The corresponding PRU nodes can be disabled later on if there are
+no use-cases defined to use a particular PRU core or the whole
+PRU-ICSS subsystem itself if both its PRU cores are unused.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am335x-evmsk.dts | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am335x-evmsk.dts b/arch/arm/boot/dts/am335x-evmsk.dts
+index 001657be0381..a2db65538e51 100644
+--- a/arch/arm/boot/dts/am335x-evmsk.dts
++++ b/arch/arm/boot/dts/am335x-evmsk.dts
+@@ -715,3 +715,7 @@ &rtc {
+ 	clocks = <&clk_32768_ck>, <&clk_24mhz_clkctrl AM3_CLK_24MHZ_CLKDIV32K_CLKCTRL 0>;
+ 	clock-names = "ext-clk", "int-clk";
+ };
++
++&pruss_tm {
++	status = "okay";
++};
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0006-ARM-dts-am335x-icev2-Enable-PRU-ICSS-module.patch b/patches/dts/omap_pruss/0006-ARM-dts-am335x-icev2-Enable-PRU-ICSS-module.patch
new file mode 100644
index 000000000..7bb49f38f
--- /dev/null
+++ b/patches/dts/omap_pruss/0006-ARM-dts-am335x-icev2-Enable-PRU-ICSS-module.patch
@@ -0,0 +1,36 @@
+From 6867f9ddaab94e73edf004ff849e4bf18c85c537 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:16 -0500
+Subject: [PATCH 06/11] ARM: dts: am335x-icev2: Enable PRU-ICSS module
+
+The PRU-ICSS target module node was left in disabled state in the
+base am33xx-l4.dtsi file. PRU-ICSS is supported on the AM335x ICEv2
+board, so enable this node to support PRUSS on this board. The PRUSS
+node and most of its child nodes are already enabled in the base dts
+file, and so become effective automatically with the enabling of
+this PRU-ICSS target module node.
+
+The corresponding PRU nodes can be disabled later on if there are
+no use-cases defined to use a particular PRU core or the whole
+PRU-ICSS subsystem itself if both its PRU cores are unused.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am335x-icev2.dts | 4 ++++
+ 1 file changed, 4 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am335x-icev2.dts b/arch/arm/boot/dts/am335x-icev2.dts
+index 5e598ac96dcc..e5ce89c8f54d 100644
+--- a/arch/arm/boot/dts/am335x-icev2.dts
++++ b/arch/arm/boot/dts/am335x-icev2.dts
+@@ -508,3 +508,7 @@ ethphy1: ethernet-phy@3 {
+ 		reg = <3>;
+ 	};
+ };
++
++&pruss_tm {
++	status = "okay";
++};
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0007-ARM-dts-am4372-Add-the-PRU-ICSS1-DT-node.patch b/patches/dts/omap_pruss/0007-ARM-dts-am4372-Add-the-PRU-ICSS1-DT-node.patch
new file mode 100644
index 000000000..8b26e2d59
--- /dev/null
+++ b/patches/dts/omap_pruss/0007-ARM-dts-am4372-Add-the-PRU-ICSS1-DT-node.patch
@@ -0,0 +1,147 @@
+From 66caab85fcbdc2d924714e6a9d72ad46397a1442 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:17 -0500
+Subject: [PATCH 07/11] ARM: dts: am4372: Add the PRU-ICSS1 DT node
+
+Add the DT node for the PRU-ICSS1 instance on the AM437x family of SoCs.
+Each PRU-ICSS instance is represented by a pruss node and other child
+nodes. The nodes are added under the interconnect target module node in
+the common am4372 dtsi file. The PRU-ICSS instances are supported only
+on AM4376+ SoCs though in the AM437x family, so the interconnect target
+module node should be disabled in any derivative board dts file that
+uses AM4372 SoCs.
+
+The PRU-ICSS1 on AM437x is very similar to the PRUSS in AM33xx, except
+for variations in the RAM sizes, bus addresses and the number of
+interrupts coming into the MPU INTC (host interrupt 5 is routed to
+the other PRUSS instead of MPU).
+
+The PRUSS subsystem node contains the entire address space. The various
+sub-modules of the PRU-ICSS are represented as individual child nodes
+(so platform devices themselves) of the PRUSS subsystem node. These
+include the two PRU cores and the interrupt controller. All the Data
+RAMs are represented within a child node of its own named 'memories'
+without any compatible. The Real Time Media Independent Interface
+controller (MII_RT), and the CFG sub-module are represented as syscon
+nodes. The PRUSS CFG module has a clock mux for IEP clock, this clk
+node is added under the CFG child node 'clocks'. The default source
+for this mux clock is the PRU_ICSS_IEP_GCLK clock.
+
+The DT nodes use all standard properties. The regs property in the PRU
+nodes define the addresses for the Instruction RAM, the Debug and Control
+sub-modules for that PRU core. The firmware for each PRU core is defined
+through a 'firmware-name' property.
+
+The default names for the firmware images for each PRU core are defined
+as follows (these can be adjusted either in derivative board dts files
+or through sysfs at runtime if required):
+     PRU-ICSS1 PRU0 Core: am437x-pru1_0-fw
+     PRU-ICSS1 PRU1 Core: am437x-pru1_1-fw
+
+Note:
+1. There are few more sub-modules like the Industrial Ethernet Peripheral
+   (IEP), MDIO, UART, eCAP that do not have bindings and so will be added
+   in the future.
+2. The PRUSS INTC on AM437x SoCs also connect the host interrupt 0 to ADC0
+   and ADC1; 6 and 7 as possible DMA events, so use the 'ti,irqs-reserved'
+   property in derivative board dts files _if_ any of them should not be
+   handled by the host OS. Host interrupt 5 is already marked reserved as
+   it is connected to the other PRUSS instance.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am4372.dtsi | 78 +++++++++++++++++++++++++++++++++++
+ 1 file changed, 78 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am4372.dtsi b/arch/arm/boot/dts/am4372.dtsi
+index 57a85a6c34a2..ddfe58b1ae79 100644
+--- a/arch/arm/boot/dts/am4372.dtsi
++++ b/arch/arm/boot/dts/am4372.dtsi
+@@ -434,6 +434,84 @@ pruss_tm: target-module@54400000 {
+ 			#address-cells = <1>;
+ 			#size-cells = <1>;
+ 			ranges = <0x0 0x54400000 0x80000>;
++
++			pruss1: pruss@0 {
++				compatible = "ti,am4376-pruss1";
++				reg = <0x0 0x40000>;
++				#address-cells = <1>;
++				#size-cells = <1>;
++				ranges;
++
++				pruss1_mem: memories@0 {
++					reg = <0x0 0x2000>,
++					      <0x2000 0x2000>,
++					      <0x10000 0x8000>;
++					reg-names = "dram0", "dram1",
++						    "shrdram2";
++				};
++
++				pruss1_cfg: cfg@26000 {
++					compatible = "ti,pruss-cfg", "syscon";
++					reg = <0x26000 0x2000>;
++					#address-cells = <1>;
++					#size-cells = <1>;
++					ranges = <0x0 0x26000 0x2000>;
++
++					clocks {
++						#address-cells = <1>;
++						#size-cells = <0>;
++
++						pruss1_iepclk_mux: iepclk-mux@30 {
++							reg = <0x30>;
++							#clock-cells = <0>;
++							clocks = <&sysclk_div>,     /* icss_iep_gclk */
++								 <&pruss_ocp_gclk>; /* icss_ocp_gclk */
++						};
++					};
++				};
++
++				pruss1_mii_rt: mii-rt@32000 {
++					compatible = "ti,pruss-mii", "syscon";
++					reg = <0x32000 0x58>;
++				};
++
++				pruss1_intc: interrupt-controller@20000 {
++					compatible = "ti,pruss-intc";
++					reg = <0x20000 0x2000>;
++					interrupt-controller;
++					#interrupt-cells = <3>;
++					interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
++					interrupt-names = "host_intr0", "host_intr1",
++							  "host_intr2", "host_intr3",
++							  "host_intr4",
++							  "host_intr6", "host_intr7";
++					ti,irqs-reserved = /bits/ 8 <0x20>; /* BIT(5) */
++				};
++
++				pru1_0: pru@34000 {
++					compatible = "ti,am4376-pru";
++					reg = <0x34000 0x3000>,
++					      <0x22000 0x400>,
++					      <0x22400 0x100>;
++					reg-names = "iram", "control", "debug";
++					firmware-name = "am437x-pru1_0-fw";
++				};
++
++				pru1_1: pru@38000 {
++					compatible = "ti,am4376-pru";
++					reg = <0x38000 0x3000>,
++					      <0x24000 0x400>,
++					      <0x24400 0x100>;
++					reg-names = "iram", "control", "debug";
++					firmware-name = "am437x-pru1_1-fw";
++				};
++			};
+ 		};
+ 
+ 		target-module@50000000 {
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0008-ARM-dts-am4372-Add-the-PRU-ICSS0-DT-node.patch b/patches/dts/omap_pruss/0008-ARM-dts-am4372-Add-the-PRU-ICSS0-DT-node.patch
new file mode 100644
index 000000000..89cc51622
--- /dev/null
+++ b/patches/dts/omap_pruss/0008-ARM-dts-am4372-Add-the-PRU-ICSS0-DT-node.patch
@@ -0,0 +1,139 @@
+From b622dbbd42f69e26c4df2485bebbf69fafcdefcd Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:18 -0500
+Subject: [PATCH 08/11] ARM: dts: am4372: Add the PRU-ICSS0 DT node
+
+The AM4376+ SoCs have a second smaller PRU-ICSS subsystem (PRUSS0) in
+addition to the primary PRUSS1 instance. The PRUSS0 has less DRAM
+per PRU, and no Shared DRAM among other minor differences. The IEP
+and MII_RT modules even though present within the IP are not pinned
+out.
+
+This PRUSS0 instance has a weird SoC integration. It shares the same
+L3 OCP interconnect interface with PRUSS1, and also shares its reset
+line and clocks. Any external accesses from PRUSS0 requires the PRUSS1's
+PRUSS_SYSCFG register to be programmed properly. That said, it is its
+own IP instance (a cut-down version), and so it has been added as an
+independent node (sibling node to PRUSS1 node) and a child node of the
+corresponding PRUSS target module interconnect node. This allows the
+PRUSS0 instance to be enabled/disabled independently of the PRUSS1
+instance.
+
+The nodes are added under the corresponding interconnect target module
+node in the common am4372 dtsi file. The PRU-ICSS instances are not
+supported on AM4372 SoC though in the AM437x family, so the interconnect
+target module node should be disabled in any derivative board dts file that
+uses AM4372 SoCs. The individual PRUSS node can be disabled in the
+corresponding board dts file if desired.
+
+The default names for the firmware images for each PRU core are defined
+as follows (these can be adjusted either in derivative board dts files or
+through sysfs at runtime if required):
+     PRU-ICSS0 PRU0 Core: am437x-pru0_0-fw
+     PRU-ICSS0 PRU1 Core: am437x-pru0_1-fw
+
+Note:
+1. There are few more sub-modules like the Industrial Ethernet Peripheral
+   (IEP), eCAP, UART, that do not have bindings and so will be added in the
+   future. Only UART is pinned out, so others should be added in disabled
+   state if added.
+2. The PRUSS0 INTC on AM437x SoCs routes the host interrupt 5 to the other
+   PRUSS1, so it is already marked reserved through the 'ti,irqs-reserved'
+   property.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am4372.dtsi | 77 +++++++++++++++++++++++++++++++++++
+ 1 file changed, 77 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am4372.dtsi b/arch/arm/boot/dts/am4372.dtsi
+index ddfe58b1ae79..2200a09c2065 100644
+--- a/arch/arm/boot/dts/am4372.dtsi
++++ b/arch/arm/boot/dts/am4372.dtsi
+@@ -512,6 +512,83 @@ pru1_1: pru@38000 {
+ 					firmware-name = "am437x-pru1_1-fw";
+ 				};
+ 			};
++
++			pruss0: pruss@40000 {
++				compatible = "ti,am4376-pruss0";
++				reg = <0x40000 0x40000>;
++				#address-cells = <1>;
++				#size-cells = <1>;
++				ranges;
++
++				pruss0_mem: memories@40000 {
++					reg = <0x40000 0x1000>,
++					      <0x42000 0x1000>;
++					reg-names = "dram0", "dram1";
++				};
++
++				pruss0_cfg: cfg@66000 {
++					compatible = "ti,pruss-cfg", "syscon";
++					reg = <0x66000 0x2000>;
++					#address-cells = <1>;
++					#size-cells = <1>;
++					ranges = <0x0 0x66000 0x2000>;
++
++					clocks {
++						#address-cells = <1>;
++						#size-cells = <0>;
++
++						pruss0_iepclk_mux: iepclk-mux@30 {
++							reg = <0x30>;
++							#clock-cells = <0>;
++							clocks = <&sysclk_div>,     /* icss_iep_gclk */
++								 <&pruss_ocp_gclk>; /* icss_ocp_gclk */
++						};
++					};
++				};
++
++				pruss0_mii_rt: mii-rt@72000 {
++					compatible = "ti,pruss-mii", "syscon";
++					reg = <0x72000 0x58>;
++					status = "disabled";
++				};
++
++				pruss0_intc: interrupt-controller@60000 {
++					compatible = "ti,pruss-intc";
++					reg = <0x60000 0x2000>;
++					interrupt-controller;
++					#interrupt-cells = <3>;
++					interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 160 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 161 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 162 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 163 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>,
++						     <GIC_SPI 165 IRQ_TYPE_LEVEL_HIGH>;
++					interrupt-names = "host_intr0", "host_intr1",
++							  "host_intr2", "host_intr3",
++							  "host_intr4",
++							  "host_intr6", "host_intr7";
++					ti,irqs-reserved = /bits/ 8 <0x20>; /* BIT(5) */
++				};
++
++				pru0_0: pru@74000 {
++					compatible = "ti,am4376-pru";
++					reg = <0x74000 0x1000>,
++					      <0x62000 0x400>,
++					      <0x62400 0x100>;
++					reg-names = "iram", "control", "debug";
++					firmware-name = "am437x-pru0_0-fw";
++				};
++
++				pru0_1: pru@78000 {
++					compatible = "ti,am4376-pru";
++					reg = <0x78000 0x1000>,
++					      <0x64000 0x400>,
++					      <0x64400 0x100>;
++					reg-names = "iram", "control", "debug";
++					firmware-name = "am437x-pru0_1-fw";
++				};
++			};
+ 		};
+ 
+ 		target-module@50000000 {
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0009-ARM-dts-am4372-Add-PRUSS-MDIO-controller-node.patch b/patches/dts/omap_pruss/0009-ARM-dts-am4372-Add-PRUSS-MDIO-controller-node.patch
new file mode 100644
index 000000000..2d941d3dc
--- /dev/null
+++ b/patches/dts/omap_pruss/0009-ARM-dts-am4372-Add-PRUSS-MDIO-controller-node.patch
@@ -0,0 +1,116 @@
+From b859f04a513fb55bc96aed8d8d4d19a709647740 Mon Sep 17 00:00:00 2001
+From: "Andrew F. Davis" <afd@ti.com>
+Date: Thu, 29 Jul 2021 17:46:19 -0500
+Subject: [PATCH 09/11] ARM: dts: am4372: Add PRUSS MDIO controller node
+
+The PRU-ICSS1 instance on AM437x SoCs has a MDIO sub-module that
+can be used to control external PHYs associated with the Industrial
+Ethernet peripherals within the PRUSS. The MDIO module used within
+this PRU-ICSS is an instance of the MDIO Controller used in TI
+Davinci SoCs. The same bus frequency of 1 MHz is chosen as the
+regular MDIO node. Note that there is no MDIO node added to the
+smaller PRU-ICSS0 instance as the MDIO pins are not pinned out.
+
+The node is added and enabled in the common am4372.dtsi file by
+default, and disabled in all the existing AM437x board dts files.
+This node needs pinctrl lines, and so should be enabled only on
+boards where they are actually wired and pinned out for PRUSS
+Ethernet. Any new board dts file should disable these if they
+are not sure.
+
+Signed-off-by: Andrew F. Davis <afd@ti.com>
+[s-anna@ti.com: fix reg address, add commit description]
+Signed-off-by: Suman Anna <s-anna@ti.com>
+---
+ arch/arm/boot/dts/am4372.dtsi        | 10 ++++++++++
+ arch/arm/boot/dts/am437x-cm-t43.dts  |  4 ++++
+ arch/arm/boot/dts/am437x-gp-evm.dts  |  4 ++++
+ arch/arm/boot/dts/am437x-idk-evm.dts |  4 ++++
+ arch/arm/boot/dts/am437x-sk-evm.dts  |  4 ++++
+ arch/arm/boot/dts/am43x-epos-evm.dts |  4 ++++
+ 6 files changed, 30 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am4372.dtsi b/arch/arm/boot/dts/am4372.dtsi
+index 2200a09c2065..61a1d88f9df6 100644
+--- a/arch/arm/boot/dts/am4372.dtsi
++++ b/arch/arm/boot/dts/am4372.dtsi
+@@ -511,6 +511,16 @@ pru1_1: pru@38000 {
+ 					reg-names = "iram", "control", "debug";
+ 					firmware-name = "am437x-pru1_1-fw";
+ 				};
++
++				pruss1_mdio: mdio@32400 {
++					compatible = "ti,davinci_mdio";
++					reg = <0x32400 0x90>;
++					clocks = <&dpll_core_m4_ck>;
++					clock-names = "fck";
++					bus_freq = <1000000>;
++					#address-cells = <1>;
++					#size-cells = <0>;
++				};
+ 			};
+ 
+ 			pruss0: pruss@40000 {
+diff --git a/arch/arm/boot/dts/am437x-cm-t43.dts b/arch/arm/boot/dts/am437x-cm-t43.dts
+index a83f46ed0c9a..5ce8e684e7d3 100644
+--- a/arch/arm/boot/dts/am437x-cm-t43.dts
++++ b/arch/arm/boot/dts/am437x-cm-t43.dts
+@@ -416,3 +416,7 @@ &cpu {
+ 			   <600000 1100000>,
+ 			   <300000 950000>;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am437x-gp-evm.dts b/arch/arm/boot/dts/am437x-gp-evm.dts
+index e2677682b540..c2e4896076e7 100644
+--- a/arch/arm/boot/dts/am437x-gp-evm.dts
++++ b/arch/arm/boot/dts/am437x-gp-evm.dts
+@@ -1118,3 +1118,7 @@ &rtc {
+ &cpu {
+ 	cpu0-supply = <&dcdc2>;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am437x-idk-evm.dts b/arch/arm/boot/dts/am437x-idk-evm.dts
+index 2dc525512266..53f64e3ce735 100644
+--- a/arch/arm/boot/dts/am437x-idk-evm.dts
++++ b/arch/arm/boot/dts/am437x-idk-evm.dts
+@@ -537,3 +537,7 @@ opp100-600000000 {
+ 		opp-suspend;
+ 	};
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am437x-sk-evm.dts b/arch/arm/boot/dts/am437x-sk-evm.dts
+index 496ed34f7755..20a34d2d85df 100644
+--- a/arch/arm/boot/dts/am437x-sk-evm.dts
++++ b/arch/arm/boot/dts/am437x-sk-evm.dts
+@@ -892,3 +892,7 @@ vpfe0_ep: endpoint {
+ 		};
+ 	};
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am43x-epos-evm.dts b/arch/arm/boot/dts/am43x-epos-evm.dts
+index aae0af10a5b1..d16aa2221c91 100644
+--- a/arch/arm/boot/dts/am43x-epos-evm.dts
++++ b/arch/arm/boot/dts/am43x-epos-evm.dts
+@@ -1018,3 +1018,7 @@ &mux_synctimer32k_ck {
+ &cpu {
+ 	cpu0-supply = <&dcdc2>;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0010-ARM-dts-am57xx-Add-PRU-ICSS-nodes.patch b/patches/dts/omap_pruss/0010-ARM-dts-am57xx-Add-PRU-ICSS-nodes.patch
new file mode 100644
index 000000000..b6e3fe412
--- /dev/null
+++ b/patches/dts/omap_pruss/0010-ARM-dts-am57xx-Add-PRU-ICSS-nodes.patch
@@ -0,0 +1,241 @@
+From 5c6e11a998d259741154eada156be440d9b98037 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:20 -0500
+Subject: [PATCH 10/11] ARM: dts: am57xx: Add PRU-ICSS nodes
+
+Add the DT nodes for the PRU-ICSS1 and PRU-ICSS2 processor subsystems
+that are present on AM57xx family of SoCs. Each PRU-ICSS instance is
+represented by a pruss node and other child nodes. The two PRU-ICSSs
+are identical to each other. They are not supported on DRA7xx SoCs in
+general, so the nodes are added under the respective interconnect target
+module nodes in a common am57-pruss.dtsi file. The file is already
+included only in the AM57xx related board files.
+
+The PRU-ICSSs on AM57xx are very similar to the PRUSS in AM33xx and AM437x
+except for variations in the RAM sizes and the number of interrupts coming
+into the MPU INTC. The interrupt events into the PRU-ICSS also requires
+programming of the corresponding crossbars properly.
+
+The PRUSS subsystem node contains the entire address space. The various
+sub-modules of the PRU-ICSS are represented as individual child nodes
+(so platform devices themselves) of the PRUSS subsystem node. These
+include the two PRU cores and the interrupt controller. All the Data
+RAMs are represented within a child node of its own named 'memories'
+without any compatible. The Real Time Media Independent Interface
+controller (MII_RT), and the CFG sub-module are represented as syscon
+nodes. The PRUSS CFG module has a clock mux for IEP clock, this clk
+node is added under the CFG child node 'clocks'. The default source
+for this mux clock is the ICSS_IEP_CLK clock.
+
+The DT nodes use all standard properties. The regs property in the PRU
+nodes define the addresses for the Instruction RAM, the Debug and Control
+sub-modules for that PRU core. The firmware for each PRU core is defined
+through a 'firmware-name' property.
+
+The default names for the firmware images for each PRU core are defined
+as follows (these can be adjusted either in derivative board dts files or
+through sysfs at runtime if required):
+    PRU-ICSS1 PRU0 Core: am57xx-pru1_0-fw
+    PRU-ICSS1 PRU1 Core: am57xx-pru1_1-fw
+    PRU-ICSS2 PRU0 Core: am57xx-pru2_0-fw
+    PRU-ICSS2 PRU1 Core: am57xx-pru2_1-fw
+
+Note:
+1. There are few more sub-modules like the Industrial Ethernet Peripheral
+   (IEPs), MDIO, UART, eCAP that do not have bindings and so will be added
+   in the future.
+2. The PRUSS INTC on AM57xx SoCs also connect the host interrupts 6 and 7
+   as possible DMA events, so use the 'ti,irqs-reserved' property in
+   derivative board dts files _if_ any of them should not be handled by
+   the host OS.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+Signed-off-by: Roger Quadros <rogerq@ti.com>
+---
+ arch/arm/boot/dts/am57-pruss.dtsi | 158 +++++++++++++++++++++++++++++-
+ 1 file changed, 157 insertions(+), 1 deletion(-)
+
+diff --git a/arch/arm/boot/dts/am57-pruss.dtsi b/arch/arm/boot/dts/am57-pruss.dtsi
+index 032c1acfcda3..494d56830b34 100644
+--- a/arch/arm/boot/dts/am57-pruss.dtsi
++++ b/arch/arm/boot/dts/am57-pruss.dtsi
+@@ -1,6 +1,6 @@
+ // SPDX-License-Identifier: GPL-2.0-only
+ /*
+- * Copyright (C) 2020 Texas Instruments Incorporated - https://www.ti.com/
++ * Copyright (C) 2020-2021 Texas Instruments Incorporated - https://www.ti.com/
+  *
+  * Common PRUSS data for TI AM57xx platforms
+  */
+@@ -25,6 +25,84 @@ pruss1_tm: target-module@4b226000 {
+ 		#address-cells = <1>;
+ 		#size-cells = <1>;
+ 		ranges = <0x00000000 0x4b200000 0x80000>;
++
++		pruss1: pruss@0 {
++			compatible = "ti,am5728-pruss";
++			reg = <0x0 0x80000>;
++			#address-cells = <1>;
++			#size-cells = <1>;
++			ranges;
++
++			pruss1_mem: memories@0 {
++				reg = <0x0 0x2000>,
++				      <0x2000 0x2000>,
++				      <0x10000 0x8000>;
++				reg-names = "dram0", "dram1",
++					    "shrdram2";
++			};
++
++			pruss1_cfg: cfg@26000 {
++				compatible = "ti,pruss-cfg", "syscon";
++				reg = <0x26000 0x2000>;
++				#address-cells = <1>;
++				#size-cells = <1>;
++				ranges = <0x0 0x26000 0x2000>;
++
++				clocks {
++					#address-cells = <1>;
++					#size-cells = <0>;
++
++					pruss1_iepclk_mux: iepclk-mux@30 {
++						reg = <0x30>;
++						#clock-cells = <0>;
++						clocks = <&dpll_gmac_m3x2_ck>,  /* icss_iep_clk */
++							 <&dpll_gmac_h13x2_ck>; /* icss_clk */
++					};
++				};
++			};
++
++			pruss1_mii_rt: mii-rt@32000 {
++				compatible = "ti,pruss-mii", "syscon";
++				reg = <0x32000 0x58>;
++			};
++
++			pruss1_intc: interrupt-controller@20000 {
++				compatible = "ti,pruss-intc";
++				reg = <0x20000 0x2000>;
++				interrupt-controller;
++				#interrupt-cells = <3>;
++				interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 187 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 193 IRQ_TYPE_LEVEL_HIGH>;
++				interrupt-names = "host_intr0", "host_intr1",
++						  "host_intr2", "host_intr3",
++						  "host_intr4", "host_intr5",
++						  "host_intr6", "host_intr7";
++			};
++
++			pru1_0: pru@34000 {
++				compatible = "ti,am5728-pru";
++				reg = <0x34000 0x3000>,
++				      <0x22000 0x400>,
++				      <0x22400 0x100>;
++				reg-names = "iram", "control", "debug";
++				firmware-name = "am57xx-pru1_0-fw";
++			};
++
++			pru1_1: pru@38000 {
++				compatible = "ti,am5728-pru";
++				reg = <0x38000 0x3000>,
++				      <0x24000 0x400>,
++				      <0x24400 0x100>;
++				reg-names = "iram", "control", "debug";
++				firmware-name = "am57xx-pru1_1-fw";
++			};
++		};
+ 	};
+ 
+ 	pruss2_tm: target-module@4b2a6000 {
+@@ -46,5 +124,83 @@ pruss2_tm: target-module@4b2a6000 {
+ 		#address-cells = <1>;
+ 		#size-cells = <1>;
+ 		ranges = <0x00000000 0x4b280000 0x80000>;
++
++		pruss2: pruss@0 {
++			compatible = "ti,am5728-pruss";
++			reg = <0x0 0x80000>;
++			#address-cells = <1>;
++			#size-cells = <1>;
++			ranges;
++
++			pruss2_mem: memories@0 {
++				reg = <0x0 0x2000>,
++				      <0x2000 0x2000>,
++				      <0x10000 0x8000>;
++				reg-names = "dram0", "dram1",
++					    "shrdram2";
++			};
++
++			pruss2_cfg: cfg@26000 {
++				compatible = "ti,pruss-cfg", "syscon";
++				reg = <0x26000 0x2000>;
++				#address-cells = <1>;
++				#size-cells = <1>;
++				ranges = <0x0 0x26000 0x2000>;
++
++				clocks {
++					#address-cells = <1>;
++					#size-cells = <0>;
++
++					pruss2_iepclk_mux: iepclk-mux@30 {
++						reg = <0x30>;
++						#clock-cells = <0>;
++						clocks = <&dpll_gmac_m3x2_ck>,  /* icss_iep_clk */
++							 <&dpll_gmac_h13x2_ck>; /* icss_clk */
++					};
++				};
++			};
++
++			pruss2_mii_rt: mii-rt@32000 {
++				compatible = "ti,pruss-mii", "syscon";
++				reg = <0x32000 0x58>;
++			};
++
++			pruss2_intc: interrupt-controller@20000 {
++				compatible = "ti,pruss-intc";
++				reg = <0x20000 0x2000>;
++				interrupt-controller;
++				#interrupt-cells = <3>;
++				interrupts = <GIC_SPI 196 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 197 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 198 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 199 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 200 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 201 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 202 IRQ_TYPE_LEVEL_HIGH>,
++					     <GIC_SPI 203 IRQ_TYPE_LEVEL_HIGH>;
++				interrupt-names = "host_intr0", "host_intr1",
++						  "host_intr2", "host_intr3",
++						  "host_intr4", "host_intr5",
++						  "host_intr6", "host_intr7";
++			};
++
++			pru2_0: pru@34000 {
++				compatible = "ti,am5728-pru";
++				reg = <0x34000 0x3000>,
++				      <0x22000 0x400>,
++				      <0x22400 0x100>;
++				reg-names = "iram", "control", "debug";
++				firmware-name = "am57xx-pru2_0-fw";
++			};
++
++			pru2_1: pru@38000 {
++				compatible = "ti,am5728-pru";
++				reg = <0x38000 0x3000>,
++				      <0x24000 0x400>,
++				      <0x24400 0x100>;
++				reg-names = "iram", "control", "debug";
++				firmware-name = "am57xx-pru2_1-fw";
++			};
++		};
+ 	};
+ };
+-- 
+2.30.2
+
diff --git a/patches/dts/omap_pruss/0011-ARM-dts-am57xx-Add-PRUSS-MDIO-controller-nodes.patch b/patches/dts/omap_pruss/0011-ARM-dts-am57xx-Add-PRUSS-MDIO-controller-nodes.patch
new file mode 100644
index 000000000..98e5ace45
--- /dev/null
+++ b/patches/dts/omap_pruss/0011-ARM-dts-am57xx-Add-PRUSS-MDIO-controller-nodes.patch
@@ -0,0 +1,151 @@
+From 175d80f8aab45e46470b2a9ce483f828c4453a79 Mon Sep 17 00:00:00 2001
+From: Suman Anna <s-anna@ti.com>
+Date: Thu, 29 Jul 2021 17:46:21 -0500
+Subject: [PATCH 11/11] ARM: dts: am57xx: Add PRUSS MDIO controller nodes
+
+The PRUSSs on AM57xx SoCs contain an MDIO controller that can
+be used to control external PHYs associated with the Industrial
+Ethernet peripherals within each PRUSS. The MDIO module used
+within the PRU-ICSS is an instance of the MDIO Controller used
+in TI Davinci SoCs. The same bus frequency of 1 MHz is chosen as
+the regular MDIO node.
+
+The nodes are added in the common am57-pruss.dtsi file and enabled
+by default, but are disabled in all the existing AM57xx board dts
+files. These nodes need pinctrl lines, and so should be enabled
+only on boards where they are actually wired and pinned out for
+PRUSS Ethernet. Any new board dts file should disable these if
+they are not sure.
+
+Signed-off-by: Suman Anna <s-anna@ti.com>
+Signed-off-by: Andrew F. Davis <afd@ti.com>
+---
+ arch/arm/boot/dts/am57-pruss.dtsi             | 20 +++++++++++++++++++
+ arch/arm/boot/dts/am571x-idk.dts              |  8 ++++++++
+ arch/arm/boot/dts/am572x-idk.dts              |  8 ++++++++
+ arch/arm/boot/dts/am574x-idk.dts              |  8 ++++++++
+ .../boot/dts/am57xx-beagle-x15-common.dtsi    |  8 ++++++++
+ arch/arm/boot/dts/am57xx-cl-som-am57x.dts     |  8 ++++++++
+ 6 files changed, 60 insertions(+)
+
+diff --git a/arch/arm/boot/dts/am57-pruss.dtsi b/arch/arm/boot/dts/am57-pruss.dtsi
+index 494d56830b34..46c5383f0eee 100644
+--- a/arch/arm/boot/dts/am57-pruss.dtsi
++++ b/arch/arm/boot/dts/am57-pruss.dtsi
+@@ -102,6 +102,16 @@ pru1_1: pru@38000 {
+ 				reg-names = "iram", "control", "debug";
+ 				firmware-name = "am57xx-pru1_1-fw";
+ 			};
++
++			pruss1_mdio: mdio@32400 {
++				compatible = "ti,davinci_mdio";
++				#address-cells = <1>;
++				#size-cells = <0>;
++				clocks = <&dpll_gmac_h13x2_ck>;
++				clock-names = "fck";
++				bus_freq = <1000000>;
++				reg = <0x32400 0x90>;
++			};
+ 		};
+ 	};
+ 
+@@ -201,6 +211,16 @@ pru2_1: pru@38000 {
+ 				reg-names = "iram", "control", "debug";
+ 				firmware-name = "am57xx-pru2_1-fw";
+ 			};
++
++			pruss2_mdio: mdio@32400 {
++				compatible = "ti,davinci_mdio";
++				#address-cells = <1>;
++				#size-cells = <0>;
++				clocks = <&dpll_gmac_h13x2_ck>;
++				clock-names = "fck";
++				bus_freq = <1000000>;
++				reg = <0x32400 0x90>;
++			};
+ 		};
+ 	};
+ };
+diff --git a/arch/arm/boot/dts/am571x-idk.dts b/arch/arm/boot/dts/am571x-idk.dts
+index e81078c2d00d..48425020281a 100644
+--- a/arch/arm/boot/dts/am571x-idk.dts
++++ b/arch/arm/boot/dts/am571x-idk.dts
+@@ -208,3 +208,11 @@ &mmc2 {
+ 	pinctrl-1 = <&mmc2_pins_hs>;
+ 	pinctrl-2 = <&mmc2_pins_ddr_rev20 &mmc2_iodelay_ddr_conf>;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
++
++&pruss2_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am572x-idk.dts b/arch/arm/boot/dts/am572x-idk.dts
+index 6504265f3f7e..94a738cb0a4d 100644
+--- a/arch/arm/boot/dts/am572x-idk.dts
++++ b/arch/arm/boot/dts/am572x-idk.dts
+@@ -27,3 +27,11 @@ &mmc2 {
+ 	pinctrl-1 = <&mmc2_pins_hs>;
+ 	pinctrl-2 = <&mmc2_pins_ddr_rev20>;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
++
++&pruss2_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am574x-idk.dts b/arch/arm/boot/dts/am574x-idk.dts
+index 1b8f3a28af05..c4bf9cb2c9dc 100644
+--- a/arch/arm/boot/dts/am574x-idk.dts
++++ b/arch/arm/boot/dts/am574x-idk.dts
+@@ -43,3 +43,11 @@ &m_can0 {
+ &emif1 {
+ 	status = "okay";
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
++
++&pruss2_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am57xx-beagle-x15-common.dtsi b/arch/arm/boot/dts/am57xx-beagle-x15-common.dtsi
+index 6b82ecf803c5..994e69ab38d7 100644
+--- a/arch/arm/boot/dts/am57xx-beagle-x15-common.dtsi
++++ b/arch/arm/boot/dts/am57xx-beagle-x15-common.dtsi
+@@ -637,3 +637,11 @@ &dsp2 {
+ 	status = "okay";
+ 	memory-region = <&dsp2_memory_region>;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
++
++&pruss2_mdio {
++	status = "disabled";
++};
+diff --git a/arch/arm/boot/dts/am57xx-cl-som-am57x.dts b/arch/arm/boot/dts/am57xx-cl-som-am57x.dts
+index aed81568a297..2e94f32d9dfc 100644
+--- a/arch/arm/boot/dts/am57xx-cl-som-am57x.dts
++++ b/arch/arm/boot/dts/am57xx-cl-som-am57x.dts
+@@ -618,3 +618,11 @@ &gpio2_target {
+ 	status = "okay";
+ 	ti,no-reset-on-init;
+ };
++
++&pruss1_mdio {
++	status = "disabled";
++};
++
++&pruss2_mdio {
++	status = "disabled";
++};
+-- 
+2.30.2
+
diff --git a/patches/dts/sancloud/0004-MAINTAINERS-Adopt-SanCloud-dts-files-as-supported.patch b/patches/dts/sancloud/0004-MAINTAINERS-Adopt-SanCloud-dts-files-as-supported.patch
deleted file mode 100644
index 63532c440..000000000
--- a/patches/dts/sancloud/0004-MAINTAINERS-Adopt-SanCloud-dts-files-as-supported.patch
+++ /dev/null
@@ -1,34 +0,0 @@
-From d1ec2a081b1b326672e2635d1ec45dd9aa9c84c8 Mon Sep 17 00:00:00 2001
-From: Paul Barker <paul.barker@sancloud.com>
-Date: Thu, 17 Jun 2021 10:33:30 +0100
-Subject: [PATCH 4/4] MAINTAINERS: Adopt SanCloud dts files as supported
-
-Myself and Marc are happy to maintain these device tree files going
-forward.
-
-Signed-off-by: Paul Barker <paul.barker@sancloud.com>
-Acked-by: Marc Murphy <marc.murphy@sancloud.com>
----
- MAINTAINERS | 6 ++++++
- 1 file changed, 6 insertions(+)
-
-diff --git a/MAINTAINERS b/MAINTAINERS
-index 8c5ee008301a..28826d26e9cc 100644
---- a/MAINTAINERS
-+++ b/MAINTAINERS
-@@ -16234,6 +16234,12 @@ F:	drivers/phy/samsung/phy-s5pv210-usb2.c
- F:	drivers/phy/samsung/phy-samsung-usb2.c
- F:	drivers/phy/samsung/phy-samsung-usb2.h
- 
-+SANCLOUD BEAGLEBONE ENHANCED DEVICE TREE
-+M:	Paul Barker <paul.barker@sancloud.com>
-+R:	Marc Murphy <marc.murphy@sancloud.com>
-+S:	Supported
-+F:	arch/arm/boot/dts/am335x-sancloud*
-+
- SC1200 WDT DRIVER
- M:	Zwane Mwaikambo <zwanem@gmail.com>
- S:	Maintained
--- 
-2.30.2
-
diff --git a/patches/git/BBDTBS b/patches/git/BBDTBS
index eefd400eb..99ea2c63d 100644
--- a/patches/git/BBDTBS
+++ b/patches/git/BBDTBS
@@ -1 +1 @@
-BBDTBS: https://github.com/beagleboard/BeagleBoard-DeviceTrees/commit/9a27767206d62d59995647b919bc8a9db889b85a
+BBDTBS: https://github.com/beagleboard/BeagleBoard-DeviceTrees/commit/1c8a3d3fdb994c8ab224a9343b622d8acf3908c7
diff --git a/patches/ref_omap2plus_defconfig b/patches/ref_omap2plus_defconfig
index b37d2bbb6..d56c7a813 100644
--- a/patches/ref_omap2plus_defconfig
+++ b/patches/ref_omap2plus_defconfig
@@ -1927,7 +1927,6 @@ CONFIG_EEPROM_93CX6=y
 # CONFIG_SENSORS_LIS3_SPI is not set
 # CONFIG_SENSORS_LIS3_I2C is not set
 # CONFIG_ALTERA_STAPL is not set
-# CONFIG_BEAGLEBONE_PINMUX_HELPER is not set
 # CONFIG_ECHO is not set
 # CONFIG_BCM_VK is not set
 # CONFIG_MISC_ALCOR_PCI is not set
@@ -3030,7 +3029,6 @@ CONFIG_DEBUG_GPIO=y
 CONFIG_GPIO_SYSFS=y
 CONFIG_GPIO_CDEV=y
 CONFIG_GPIO_CDEV_V1=y
-# CONFIG_GPIO_OF_HELPER is not set
 
 #
 # Memory mapped GPIO drivers
diff --git a/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch b/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch
index 4425e5947..ae593e19e 100644
--- a/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch
+++ b/patches/soc/ti/beagleboard_dtbs/0001-Add-BeagleBoard.org-Device-Tree-Changes.patch
@@ -1,14 +1,14 @@
-From 62d4824713e9475817f7a3538459adbc9dee947f Mon Sep 17 00:00:00 2001
+From e59cf58b1cdd9dc2b938f6bc4f427eeab630309b Mon Sep 17 00:00:00 2001
 From: Robert Nelson <robertcnelson@gmail.com>
-Date: Mon, 26 Jul 2021 10:37:42 -0500
+Date: Fri, 30 Jul 2021 18:06:02 -0500
 Subject: [PATCH] Add BeagleBoard.org Device Tree Changes
 
 https://github.com/beagleboard/BeagleBoard-DeviceTrees/tree/v5.14.x
 
-https://github.com/beagleboard/BeagleBoard-DeviceTrees/commit/9a27767206d62d59995647b919bc8a9db889b85a
+https://github.com/beagleboard/BeagleBoard-DeviceTrees/commit/1c8a3d3fdb994c8ab224a9343b622d8acf3908c7
 Signed-off-by: Robert Nelson <robertcnelson@gmail.com>
 ---
- arch/arm/boot/dts/Makefile                    |   3 +
+ arch/arm/boot/dts/Makefile                    |   2 +
  arch/arm/boot/dts/am335x-bbb-bone-buses.dtsi  |  85 +++++++
  arch/arm/boot/dts/am335x-bone-common.dtsi     |  16 +-
  arch/arm/boot/dts/am335x-bone.dts             |   5 +
@@ -23,9 +23,9 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com>
  arch/arm/boot/dts/am335x-osd3358-sm-red.dts   | 138 +-----------
  arch/arm/boot/dts/am335x-osd335x-common.dtsi  |   1 +
  arch/arm/boot/dts/am335x-pocketbeagle.dts     |   2 +
- .../arm/boot/dts/am335x-sancloud-bbe-lite.dts |  10 +-
+ .../arm/boot/dts/am335x-sancloud-bbe-lite.dts |   7 +
  arch/arm/boot/dts/am335x-sancloud-bbe.dts     |   5 +
- arch/arm/boot/dts/am33xx-l4.dtsi              |  67 +++++-
+ arch/arm/boot/dts/am33xx-l4.dtsi              |   2 +-
  arch/arm/boot/dts/am33xx.dtsi                 |   7 +
  arch/arm/boot/dts/am5729-beagleboneai.dts     |   5 +
  arch/arm/boot/dts/am57xx-beagle-x15-revb1.dts |   5 +
@@ -34,13 +34,13 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com>
  arch/arm/boot/dts/dra7.dtsi                   |  12 +
  arch/arm/boot/dts/overlays/BB-ADC-00A0.dts    |  20 ++
  .../dts/overlays/BB-BONE-eMMC1-01-00A0.dts    |  28 +++
- .../dts/overlays/BB-HDMI-TDA998x-00A0.dts     | 113 ++++++++++
+ .../dts/overlays/BB-HDMI-TDA998x-00A0.dts     | 114 ++++++++++
  arch/arm/boot/dts/overlays/BBORG_FAN-A000.dts |  27 +++
  arch/arm/boot/dts/overlays/BONE-ADC.dts       |  28 +++
  arch/arm/boot/dts/overlays/Makefile           |  14 ++
  arch/arm/boot/dts/twl6030.dtsi                |   5 +
  include/dt-bindings/pinctrl/omap.h            |   4 +-
- 32 files changed, 897 insertions(+), 138 deletions(-)
+ 32 files changed, 831 insertions(+), 136 deletions(-)
  create mode 100644 arch/arm/boot/dts/am335x-bbb-bone-buses.dtsi
  create mode 100644 arch/arm/boot/dts/am335x-boneblack-uboot.dts
  create mode 100644 arch/arm/boot/dts/am335x-bonegreen-gateway.dts
@@ -52,22 +52,21 @@ Signed-off-by: Robert Nelson <robertcnelson@gmail.com>
  create mode 100644 arch/arm/boot/dts/overlays/Makefile
 
 diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile
-index 8da525e7f0ab..cc0d658cabaa 100644
+index 8da525e7f0ab..4a124cf6412d 100644
 --- a/arch/arm/boot/dts/Makefile
 +++ b/arch/arm/boot/dts/Makefile
-@@ -819,6 +819,9 @@ dtb-$(CONFIG_SOC_AM33XX) += \
+@@ -819,6 +819,8 @@ dtb-$(CONFIG_SOC_AM33XX) += \
  	am335x-base0033.dtb \
  	am335x-bone.dtb \
  	am335x-boneblack.dtb \
 +	am335x-boneblack-uboot.dtb \
-+	am335x-sancloud-bbe-lite.dtb \
 +	am335x-bonegreen-gateway.dtb \
  	am335x-boneblack-wireless.dtb \
  	am335x-boneblue.dtb \
  	am335x-bonegreen.dtb \
 diff --git a/arch/arm/boot/dts/am335x-bbb-bone-buses.dtsi b/arch/arm/boot/dts/am335x-bbb-bone-buses.dtsi
 new file mode 100644
-index 000000000000..dd8dd6b63d57
+index 000000000000..02cd206a37a6
 --- /dev/null
 +++ b/arch/arm/boot/dts/am335x-bbb-bone-buses.dtsi
 @@ -0,0 +1,85 @@
@@ -109,16 +108,6 @@ index 000000000000..dd8dd6b63d57
 +		>;
 +	};
 +
-+	mcasp0_pins: mcasp0_pins {
-+		pinctrl-single,pins = <
-+			AM33XX_PADCONF(AM335X_PIN_MCASP0_AHCLKX, PIN_INPUT_PULLUP, MUX_MODE0) /* mcasp0_ahcklx.mcasp0_ahclkx */
-+			AM33XX_PADCONF(AM335X_PIN_MCASP0_AHCLKR, PIN_OUTPUT_PULLDOWN, MUX_MODE2) /* mcasp0_ahclkr.mcasp0_axr2*/
-+			AM33XX_PADCONF(AM335X_PIN_MCASP0_FSX, PIN_OUTPUT_PULLUP, MUX_MODE0)
-+			AM33XX_PADCONF(AM335X_PIN_MCASP0_ACLKX, PIN_OUTPUT_PULLDOWN, MUX_MODE0)
-+			AM33XX_PADCONF(AM335X_PIN_GPMC_A11, PIN_OUTPUT_PULLDOWN, MUX_MODE7) /* gpmc_a11.GPIO1_27 */
-+		>;
-+	};
-+
 +	nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins {
 +		pinctrl-single,pins = <
 +			AM33XX_PADCONF(AM335X_PIN_XDMA_EVENT_INTR0, PIN_OUTPUT_PULLDOWN, MUX_MODE3)
@@ -150,6 +139,16 @@ index 000000000000..dd8dd6b63d57
 +			AM33XX_PADCONF(AM335X_PIN_XDMA_EVENT_INTR0, PIN_OUTPUT_PULLDOWN, MUX_MODE3)
 +		>;
 +	};
++
++	mcasp0_pins: mcasp0_pins {
++		pinctrl-single,pins = <
++			AM33XX_PADCONF(AM335X_PIN_MCASP0_AHCLKX, PIN_INPUT_PULLUP, MUX_MODE0) /* mcasp0_ahcklx.mcasp0_ahclkx */
++			AM33XX_PADCONF(AM335X_PIN_MCASP0_AHCLKR, PIN_OUTPUT_PULLDOWN, MUX_MODE2) /* mcasp0_ahclkr.mcasp0_axr2*/
++			AM33XX_PADCONF(AM335X_PIN_MCASP0_FSX, PIN_OUTPUT_PULLUP, MUX_MODE0)
++			AM33XX_PADCONF(AM335X_PIN_MCASP0_ACLKX, PIN_OUTPUT_PULLDOWN, MUX_MODE0)
++			AM33XX_PADCONF(AM335X_PIN_GPMC_A11, PIN_OUTPUT_PULLDOWN, MUX_MODE7) /* gpmc_a11.GPIO1_27 */
++		>;
++	};
 +};
 +
 +// ADC
@@ -157,7 +156,7 @@ index 000000000000..dd8dd6b63d57
 +
 +};
 diff --git a/arch/arm/boot/dts/am335x-bone-common.dtsi b/arch/arm/boot/dts/am335x-bone-common.dtsi
-index 2d51d4bba6d4..dfd1c54b41f1 100644
+index 34a0045b5f65..ffdee855432b 100644
 --- a/arch/arm/boot/dts/am335x-bone-common.dtsi
 +++ b/arch/arm/boot/dts/am335x-bone-common.dtsi
 @@ -26,14 +26,14 @@ leds {
@@ -201,9 +200,9 @@ index 2d51d4bba6d4..dfd1c54b41f1 100644
  
  	cape_eeprom0: cape_eeprom0@54 {
  		compatible = "atmel,24c256";
-@@ -397,3 +400,12 @@ &rtc {
- 	clocks = <&clk_32768_ck>, <&clk_24mhz_clkctrl AM3_CLK_24MHZ_CLKDIV32K_CLKCTRL 0>;
- 	clock-names = "ext-clk", "int-clk";
+@@ -401,3 +404,12 @@ &rtc {
+ &pruss_tm {
+ 	status = "okay";
  };
 +
 +&tscadc {
@@ -462,7 +461,7 @@ index 9312197316f0..2788ab042727 100644
  
  &cpu0_opp_table {
 diff --git a/arch/arm/boot/dts/am335x-boneblue.dts b/arch/arm/boot/dts/am335x-boneblue.dts
-index 0afcc2ee0b63..6ad076b9e269 100644
+index c6bb325ead33..97e53a3ff62f 100644
 --- a/arch/arm/boot/dts/am335x-boneblue.dts
 +++ b/arch/arm/boot/dts/am335x-boneblue.dts
 @@ -14,6 +14,8 @@ / {
@@ -496,7 +495,7 @@ index 9f7fb63744d0..4c87de57d1a1 100644
  &rtc {
 diff --git a/arch/arm/boot/dts/am335x-bonegreen-gateway.dts b/arch/arm/boot/dts/am335x-bonegreen-gateway.dts
 new file mode 100644
-index 000000000000..f9d5e02a73b3
+index 000000000000..9bd4c5d98fc9
 --- /dev/null
 +++ b/arch/arm/boot/dts/am335x-bonegreen-gateway.dts
 @@ -0,0 +1,208 @@
@@ -675,7 +674,7 @@ index 000000000000..f9d5e02a73b3
 +
 +// (K16) gmii1_txd1.gpio0[21]
 +&gpio0 {
-+	usb_reset {
++	usb-reset-hog {
 +		gpio-hog;
 +		gpios = <21 GPIO_ACTIVE_HIGH>;
 +		output-high;
@@ -684,7 +683,7 @@ index 000000000000..f9d5e02a73b3
 +};
 +
 +&gpio3 {
-+	ls_buf_en {
++	ls-buf-en-hog {
 +		gpio-hog;
 +		gpios = <10 GPIO_ACTIVE_HIGH>;
 +		output-high;
@@ -954,17 +953,9 @@ index 209cdd17dc1e..affd26891a30 100644
  
  	leds {
 diff --git a/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts b/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts
-index 9c311bd106f6..c5ed32407dae 100644
+index d6ef19311a91..4ad64675b84d 100644
 --- a/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts
 +++ b/arch/arm/boot/dts/am335x-sancloud-bbe-lite.dts
-@@ -1,6 +1,6 @@
- // SPDX-License-Identifier: GPL-2.0-only
- /*
-- * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
-+ * Copyright (C) 2012 Texas Instruments Incorporated - https://www.ti.com/
-  * Copyright (C) 2021 SanCloud Ltd
-  */
- /dts-v1/;
 @@ -16,6 +16,12 @@ / {
  		     "ti,am335x-bone-black",
  		     "ti,am335x-bone",
@@ -978,11 +969,10 @@ index 9c311bd106f6..c5ed32407dae 100644
  };
  
  &am33xx_pinmux {
-@@ -42,7 +48,7 @@ channel@0 {
+@@ -42,6 +48,7 @@ channel@0 {
  		#size-cells = <0>;
  
  		compatible = "micron,spi-authenta";
--		symlink = "spi/0.0";
 +		symlink = "bone/spi/0.0";
  
  		reg = <0>;
@@ -1004,83 +994,18 @@ index 2a0ac9f5dda7..a0f3ccfb8579 100644
  
  &am33xx_pinmux {
 diff --git a/arch/arm/boot/dts/am33xx-l4.dtsi b/arch/arm/boot/dts/am33xx-l4.dtsi
-index 859e760df4c8..20b97aa44ab3 100644
+index c9629cb5ccd1..bb490b5ffd9c 100644
 --- a/arch/arm/boot/dts/am33xx-l4.dtsi
 +++ b/arch/arm/boot/dts/am33xx-l4.dtsi
-@@ -852,7 +852,72 @@ pruss_tm: target-module@300000 {	/* 0x4a300000, ap 9 04.0 */
+@@ -852,7 +852,7 @@ pruss_tm: target-module@300000 {	/* 0x4a300000, ap 9 04.0 */
  			#address-cells = <1>;
  			#size-cells = <1>;
  			ranges = <0x0 0x300000 0x80000>;
 -			status = "disabled";
 +			status = "okay";
-+
-+			pruss: pruss@0 {
-+				compatible = "ti,am3356-pruss";
-+				reg = <0x0 0x80000>;
-+				#address-cells = <1>;
-+				#size-cells = <1>;
-+				ranges;
-+
-+				pruss_mem: memories@0 {
-+					reg = <0x0 0x2000>,
-+					      <0x2000 0x2000>,
-+					      <0x10000 0x3000>;
-+					reg-names = "dram0", "dram1", "shrdram2";
-+				};
-+
-+				pruss_cfg: cfg@26000 {
-+					compatible = "ti,pruss-cfg", "syscon";
-+					#address-cells = <1>;
-+					#size-cells = <1>;
-+					reg = <0x26000 0x2000>;
-+					ranges = <0x00 0x26000 0x2000>;
-+
-+					clocks {
-+						#address-cells = <1>;
-+						#size-cells = <0>;
-+
-+						pruss_iepclk_mux: iepclk-mux@30 {
-+							reg = <0x30>;
-+							#clock-cells = <0>;
-+							clocks = <&l3_gclk>,        /* icss_iep */
-+								 <&pruss_ocp_gclk>; /* icss_ocp */
-+						};
-+					};
-+				};
-+
-+				pruss_intc: interrupt-controller@20000 {
-+					compatible = "ti,pruss-intc";
-+					reg = <0x20000 0x2000>;
-+					interrupts = <20 21 22 23 24 25 26 27>;
-+					interrupt-names = "host_intr0", "host_intr1",
-+							  "host_intr2", "host_intr3",
-+							  "host_intr4", "host_intr5",
-+							  "host_intr6", "host_intr7";
-+					interrupt-controller;
-+					#interrupt-cells = <3>;
-+				};
-+
-+				pru0: pru@34000 {
-+					compatible = "ti,am3356-pru";
-+					reg = <0x34000 0x2000>,
-+					      <0x22000 0x400>,
-+					      <0x22400 0x100>;
-+					reg-names = "iram", "control", "debug";
-+					firmware-name = "am335x-pru0-fw";
-+				};
-+
-+				pru1: pru@38000 {
-+					compatible = "ti,am3356-pru";
-+					reg = <0x38000 0x2000>,
-+					      <0x24000 0x400>,
-+					      <0x24400 0x100>;
-+					reg-names = "iram", "control", "debug";
-+					firmware-name = "am335x-pru1-fw";
-+				};
-+			};
- 		};
- 	};
- };
+ 
+ 			pruss: pruss@0 {
+ 				compatible = "ti,am3356-pruss";
 diff --git a/arch/arm/boot/dts/am33xx.dtsi b/arch/arm/boot/dts/am33xx.dtsi
 index 5e33d0e88f5b..7f9f4868c6b0 100644
 --- a/arch/arm/boot/dts/am33xx.dtsi
@@ -1269,10 +1194,10 @@ index 000000000000..ab72eaa61d2f
 +};
 diff --git a/arch/arm/boot/dts/overlays/BB-HDMI-TDA998x-00A0.dts b/arch/arm/boot/dts/overlays/BB-HDMI-TDA998x-00A0.dts
 new file mode 100644
-index 000000000000..af75833cfe19
+index 000000000000..c751ab66adb3
 --- /dev/null
 +++ b/arch/arm/boot/dts/overlays/BB-HDMI-TDA998x-00A0.dts
-@@ -0,0 +1,113 @@
+@@ -0,0 +1,114 @@
 +// SPDX-License-Identifier: GPL-2.0-only
 +/*
 + * Copyright (C) 2012 Texas Instruments Incorporated - https://www.ti.com/
@@ -1315,6 +1240,7 @@ index 000000000000..af75833cfe19
 +&i2c0 {
 +	#address-cells = <1>;
 +	#size-cells = <0>;
++
 +	tda19988: tda19988@70 {
 +		compatible = "nxp,tda998x";
 +		reg = <0x70>;
diff --git a/version.sh b/version.sh
index cd8af89ee..eb6731f98 100644
--- a/version.sh
+++ b/version.sh
@@ -41,7 +41,7 @@ KERNEL_REL=5.14
 KERNEL_TAG=${KERNEL_REL}-rc3
 kernel_rt=".X-rtY"
 #Kernel Build
-BUILD=${build_prefix}3
+BUILD=${build_prefix}3.1
 
 #v5.X-rcX + upto SHA
 #prev_KERNEL_SHA=""
-- 
GitLab