]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
arm: mach-k3: Export common fdt fixups for use in board code
authorJoão Paulo Gonçalves <joao.goncalves@toradex.com>
Mon, 23 Jun 2025 17:39:55 +0000 (14:39 -0300)
committerTom Rini <trini@konsulko.com>
Wed, 9 Jul 2025 14:40:03 +0000 (08:40 -0600)
Avoid code duplication by making the common TI K3 device tree fixup
functions to be reusable by board-specific code.

Signed-off-by: João Paulo Gonçalves <joao.goncalves@toradex.com>
arch/arm/mach-k3/am62ax/am62a7_fdt.c
arch/arm/mach-k3/am62px/am62p5_fdt.c
arch/arm/mach-k3/am62x/am625_fdt.c
arch/arm/mach-k3/am65x/am654_fdt.c
arch/arm/mach-k3/common_fdt.c
arch/arm/mach-k3/include/mach/k3-common-fdt.h [moved from arch/arm/mach-k3/common_fdt.h with 68% similarity]
arch/arm/mach-k3/j721e/j721e_fdt.c
arch/arm/mach-k3/j721s2/j721s2_fdt.c
arch/arm/mach-k3/j722s/j722s_fdt.c
arch/arm/mach-k3/j784s4/j784s4_fdt.c

index 7f764ab36b564de2fb28ecd9c41d33de441165d5..c7c5d2f0885a432ab521df7080306d0c50691cfa 100644 (file)
@@ -3,11 +3,10 @@
  * Copyright (C) 2024 Texas Instruments Incorporated - https://www.ti.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <asm/hardware.h>
 #include <fdt_support.h>
 
-#include "../common_fdt.h"
-
 int ft_system_setup(void *blob, struct bd_info *bd)
 {
        fdt_fixup_reserved(blob, "tfa", CONFIG_K3_ATF_LOAD_ADDR, 0x80000);
index 2c40fa5a59410e2c1c53f8ec1bc256ec001d09a1..4d8061354c84c0f429d2ad0447bcdc2aea4d1004 100644 (file)
@@ -3,8 +3,8 @@
  * Copyright (C) 2024 Texas Instruments Incorporated - https://www.ti.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <asm/hardware.h>
-#include "../common_fdt.h"
 #include <fdt_support.h>
 
 static void fdt_fixup_cores_wdt_nodes_am62p(void *blob, int core_nr)
@@ -38,42 +38,6 @@ static void fdt_fixup_canfd_nodes_am62p(void *blob, bool has_canfd)
        }
 }
 
-static int fdt_fixup_trips_node(void *blob, int zoneoffset, int maxc)
-{
-       int node, trip;
-
-       node = fdt_subnode_offset(blob, zoneoffset, "trips");
-       if (node < 0)
-               return -1;
-
-       fdt_for_each_subnode(trip, blob, node) {
-               const char *type = fdt_getprop(blob, trip, "type", NULL);
-
-               if (!type || (strncmp(type, "critical", 8) != 0))
-                       continue;
-
-               if (fdt_setprop_u32(blob, trip, "temperature", 1000 * maxc) < 0)
-                       return -1;
-       }
-
-       return 0;
-}
-
-static void fdt_fixup_thermal_zone_nodes_am62p(void *blob, int maxc)
-{
-       int node, zone;
-
-       node = fdt_path_offset(blob, "/thermal-zones");
-       if (node < 0)
-               return;
-
-       fdt_for_each_subnode(zone, blob, node) {
-               if (fdt_fixup_trips_node(blob, zone, maxc) < 0)
-                       printf("Failed to set temperature in %s critical trips\n",
-                              fdt_get_name(blob, zone, NULL));
-       }
-}
-
 static void fdt_fixup_cpu_freq_nodes_am62p(void *blob, int max_freq)
 {
        if (max_freq >= 1250000000)
@@ -90,7 +54,7 @@ int ft_system_setup(void *blob, struct bd_info *bd)
        fdt_fixup_cores_wdt_nodes_am62p(blob, k3_get_core_nr());
        fdt_fixup_video_codec_nodes_am62p(blob, k3_has_video_codec());
        fdt_fixup_canfd_nodes_am62p(blob, k3_has_canfd());
-       fdt_fixup_thermal_zone_nodes_am62p(blob, k3_get_max_temp());
+       fdt_fixup_thermal_critical_trips_k3(blob, k3_get_max_temp());
        fdt_fixup_cpu_freq_nodes_am62p(blob, k3_get_a53_max_frequency());
        fdt_fixup_reserved(blob, "tfa", CONFIG_K3_ATF_LOAD_ADDR, 0x80000);
        fdt_fixup_reserved(blob, "optee", CONFIG_K3_OPTEE_LOAD_ADDR, 0x1800000);
index ab9b573f3cff3d6a341d688b703f16a31ca65494..e5d95ab7dd1bb2ea8b5d6469673a0b2566fd411c 100644 (file)
@@ -3,12 +3,11 @@
  * Copyright 2023 Toradex - https://www.toradex.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <asm/hardware.h>
 #include <fdt_support.h>
 #include <fdtdec.h>
 
-#include "../common_fdt.h"
-
 static void fdt_fixup_cores_nodes_am625(void *blob, int core_nr)
 {
        char node_path[32];
@@ -40,42 +39,6 @@ static void fdt_fixup_pru_node_am625(void *blob, int has_pru)
                fdt_del_node_path(blob, "/bus@f0000/pruss@30040000");
 }
 
-static int fdt_fixup_trips_node(void *blob, int zoneoffset, int maxc)
-{
-       int node, trip;
-
-       node = fdt_subnode_offset(blob, zoneoffset, "trips");
-       if (node < 0)
-               return -1;
-
-       fdt_for_each_subnode(trip, blob, node) {
-               const char *type = fdt_getprop(blob, trip, "type", NULL);
-
-               if (!type || (strncmp(type, "critical", 8) != 0))
-                       continue;
-
-               if (fdt_setprop_u32(blob, trip, "temperature", 1000 * maxc) < 0)
-                       return -1;
-       }
-
-       return 0;
-}
-
-static void fdt_fixup_thermal_zone_nodes_am625(void *blob, int maxc)
-{
-       int node, zone;
-
-       node = fdt_path_offset(blob, "/thermal-zones");
-       if (node < 0)
-               return;
-
-       fdt_for_each_subnode(zone, blob, node) {
-               if (fdt_fixup_trips_node(blob, zone, maxc) < 0)
-                       printf("Failed to set temperature in %s critical trips\n",
-                              fdt_get_name(blob, zone, NULL));
-       }
-}
-
 static void fdt_fixup_thermal_cooling_device_cpus_am625(void *blob, int core_nr)
 {
        static const char * const thermal_path[] = {
@@ -115,7 +78,7 @@ int ft_system_setup(void *blob, struct bd_info *bd)
        fdt_fixup_cores_nodes_am625(blob, k3_get_core_nr());
        fdt_fixup_gpu_nodes_am625(blob, k3_has_gpu());
        fdt_fixup_pru_node_am625(blob, k3_has_pru());
-       fdt_fixup_thermal_zone_nodes_am625(blob, k3_get_max_temp());
+       fdt_fixup_thermal_critical_trips_k3(blob, k3_get_max_temp());
        fdt_fixup_thermal_cooling_device_cpus_am625(blob, k3_get_core_nr());
        fdt_fixup_reserved(blob, "tfa", CONFIG_K3_ATF_LOAD_ADDR, 0x80000);
        fdt_fixup_reserved(blob, "optee", CONFIG_K3_OPTEE_LOAD_ADDR, 0x1800000);
index bcb15208be921a1633d74e25dbba54fb93ea58eb..73bca424da34586cfa35b32127817919af7a3ec2 100644 (file)
@@ -3,10 +3,9 @@
  * Copyright 2023 Toradex - https://www.toradex.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <fdt_support.h>
 
-#include "../common_fdt.h"
-
 int ft_system_setup(void *blob, struct bd_info *bd)
 {
        return fdt_fixup_msmc_ram_k3(blob);
index 867ed1731428d946246d971933b71ec4bc5ef953..2777354c6abae3205d47b92d2bba266154ac623a 100644 (file)
@@ -3,11 +3,11 @@
  * Copyright 2023 Toradex - https://www.toradex.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include "common.h"
 #include <dm.h>
 #include <fdt_support.h>
 #include <linux/soc/ti/ti_sci_protocol.h>
-#include "common_fdt.h"
 
 static int fdt_fixup_msmc_ram(void *blob, char *parent_path, char *node_name)
 {
@@ -164,3 +164,39 @@ add_carveout:
 
        return 0;
 }
+
+static int fdt_fixup_critical_trips(void *blob, int zoneoffset, int maxc)
+{
+       int node, trip;
+
+       node = fdt_subnode_offset(blob, zoneoffset, "trips");
+       if (node < 0)
+               return -1;
+
+       fdt_for_each_subnode(trip, blob, node) {
+               const char *type = fdt_getprop(blob, trip, "type", NULL);
+
+               if (!type || (strncmp(type, "critical", 8) != 0))
+                       continue;
+
+               if (fdt_setprop_u32(blob, trip, "temperature", 1000 * maxc) < 0)
+                       return -1;
+       }
+
+       return 0;
+}
+
+void fdt_fixup_thermal_critical_trips_k3(void *blob, int maxc)
+{
+       int node, zone;
+
+       node = fdt_path_offset(blob, "/thermal-zones");
+       if (node < 0)
+               return;
+
+       fdt_for_each_subnode(zone, blob, node) {
+               if (fdt_fixup_critical_trips(blob, zone, maxc) < 0)
+                       printf("Failed to set temperature in %s critical trips\n",
+                              fdt_get_name(blob, zone, NULL));
+       }
+}
similarity index 68%
rename from arch/arm/mach-k3/common_fdt.h
rename to arch/arm/mach-k3/include/mach/k3-common-fdt.h
index 52c0795748389be46d6ba23aaab7065a930ba248..38a5bb82d954fa3060c41c50c08c54aec49fb3f2 100644 (file)
@@ -3,12 +3,13 @@
  * Copyright 2023 Toradex - https://www.toradex.com/
  */
 
-#ifndef _COMMON_FDT_H
-#define _COMMON_FDT_H
+#ifndef _K3_COMMON_FDT_H
+#define _K3_COMMON_FDT_H
 
 int fdt_fixup_msmc_ram_k3(void *blob);
 int fdt_del_node_path(void *blob, const char *path);
 int fdt_fixup_reserved(void *blob, const char *name,
                       unsigned int new_address, unsigned int new_size);
+void fdt_fixup_thermal_critical_trips_k3(void *blob, int maxc);
 
-#endif /* _COMMON_FDT_H */
+#endif /* _K3_COMMON_FDT_H */
index bcb15208be921a1633d74e25dbba54fb93ea58eb..73bca424da34586cfa35b32127817919af7a3ec2 100644 (file)
@@ -3,10 +3,9 @@
  * Copyright 2023 Toradex - https://www.toradex.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <fdt_support.h>
 
-#include "../common_fdt.h"
-
 int ft_system_setup(void *blob, struct bd_info *bd)
 {
        return fdt_fixup_msmc_ram_k3(blob);
index bcb15208be921a1633d74e25dbba54fb93ea58eb..73bca424da34586cfa35b32127817919af7a3ec2 100644 (file)
@@ -3,10 +3,9 @@
  * Copyright 2023 Toradex - https://www.toradex.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <fdt_support.h>
 
-#include "../common_fdt.h"
-
 int ft_system_setup(void *blob, struct bd_info *bd)
 {
        return fdt_fixup_msmc_ram_k3(blob);
index 29c832d28acf54d2ad73f76a4a3d135643bb6bb4..c7c5d2f0885a432ab521df7080306d0c50691cfa 100644 (file)
@@ -3,8 +3,8 @@
  * Copyright (C) 2024 Texas Instruments Incorporated - https://www.ti.com/
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <asm/hardware.h>
-#include "../common_fdt.h"
 #include <fdt_support.h>
 
 int ft_system_setup(void *blob, struct bd_info *bd)
index e127509705143ac93e9d26a7efc91aec55b81230..9c9a1382b419d3a4caa34613b696fcceda405097 100644 (file)
@@ -6,10 +6,9 @@
  *     Apurva Nandan <a-nandan@ti.com>
  */
 
+#include <asm/arch/k3-common-fdt.h>
 #include <fdt_support.h>
 
-#include "../common_fdt.h"
-
 int ft_system_setup(void *blob, struct bd_info *bd)
 {
        return fdt_fixup_msmc_ram_k3(blob);