2 * Copyright 2016 NXP Semiconductor, Inc.
4 * SPDX-License-Identifier: GPL-2.0+
9 #include <fdt_support.h>
10 #include <linux/sizes.h>
11 #include <linux/kernel.h>
13 #ifdef CONFIG_ARMV8_SEC_FIRMWARE_SUPPORT
14 #include <asm/armv8/sec_firmware.h>
17 int fdt_psci(void *fdt)
19 #if defined(CONFIG_ARMV8_PSCI) || defined(CONFIG_ARMV7_PSCI)
21 unsigned int psci_ver = 0;
25 nodeoff = fdt_path_offset(fdt, "/cpus");
27 printf("couldn't find /cpus\n");
31 /* add 'enable-method = "psci"' to each cpu node */
32 for (tmp = fdt_first_subnode(fdt, nodeoff);
34 tmp = fdt_next_subnode(fdt, tmp)) {
35 const struct fdt_property *prop;
38 prop = fdt_get_property(fdt, tmp, "device_type", &len);
43 if (strcmp(prop->data, "cpu"))
47 * Not checking rv here, our approach is to skip over errors in
48 * individual cpu nodes, hopefully some of the nodes are
49 * processed correctly and those will boot
51 fdt_setprop_string(fdt, tmp, "enable-method", "psci");
54 nodeoff = fdt_path_offset(fdt, "/psci");
58 nodeoff = fdt_path_offset(fdt, "/");
62 nodeoff = fdt_add_subnode(fdt, nodeoff, "psci");
67 #ifdef CONFIG_ARMV8_SEC_FIRMWARE_SUPPORT
68 psci_ver = sec_firmware_support_psci_version();
72 psci_compt = "arm,psci-1.0";
75 psci_compt = "arm,psci-0.2";
78 psci_compt = "arm,psci";
82 tmp = fdt_setprop_string(fdt, nodeoff, "compatible", psci_compt);
85 tmp = fdt_setprop_string(fdt, nodeoff, "method", "smc");
89 #ifdef CONFIG_ARMV7_PSCI
90 tmp = fdt_setprop_u32(fdt, nodeoff, "cpu_suspend",
91 ARM_PSCI_FN_CPU_SUSPEND);
94 tmp = fdt_setprop_u32(fdt, nodeoff, "cpu_off", ARM_PSCI_FN_CPU_OFF);
97 tmp = fdt_setprop_u32(fdt, nodeoff, "cpu_on", ARM_PSCI_FN_CPU_ON);
100 tmp = fdt_setprop_u32(fdt, nodeoff, "migrate", ARM_PSCI_FN_MIGRATE);