diff options
Diffstat (limited to 'arch')
| -rw-r--r-- | arch/arm/dts/k3-j7200-r5-common-proc-board.dts | 11 | ||||
| -rw-r--r-- | arch/arm/mach-k3/j721e/j721e_init.c | 92 | ||||
| -rw-r--r-- | arch/arm/mach-k3/r5/Kconfig | 7 | 
3 files changed, 104 insertions, 6 deletions
| diff --git a/arch/arm/dts/k3-j7200-r5-common-proc-board.dts b/arch/arm/dts/k3-j7200-r5-common-proc-board.dts index f096b102793..06fffe2a11b 100644 --- a/arch/arm/dts/k3-j7200-r5-common-proc-board.dts +++ b/arch/arm/dts/k3-j7200-r5-common-proc-board.dts @@ -23,11 +23,12 @@  				<&k3_pds 202 TI_SCI_PD_EXCLUSIVE>,  				<&k3_pds 4 TI_SCI_PD_EXCLUSIVE>;  		resets = <&k3_reset 202 0>; -		clocks = <&k3_clks 61 1>, <&k3_clks 202 2>; -		clock-names = "gtc", "core"; -		assigned-clocks = <&k3_clks 202 2>, <&k3_clks 61 1>, <&k3_clks 323 0>; -		assigned-clock-parents= <0>, <0>, <&k3_clks 323 2>; -		assigned-clock-rates = <2000000000>, <200000000>; +		clocks = <&k3_clks 61 1>, <&k3_clks 202 2>, <&k3_clks 4 1> ; +		clock-names = "gtc", "core", "msmc"; +		assigned-clocks = <&k3_clks 202 2>, <&k3_clks 61 1>, <&k3_clks 4 1>, +						  <&k3_clks 323 0>; +		assigned-clock-parents= <0>, <0>, <0>, <&k3_clks 323 2>; +		assigned-clock-rates = <2000000000>, <200000000>, <1000000000>;  		ti,sci = <&dmsc>;  		ti,sci-proc-id = <32>;  		ti,sci-host-id = <10>; diff --git a/arch/arm/mach-k3/j721e/j721e_init.c b/arch/arm/mach-k3/j721e/j721e_init.c index e9ed8cb267c..805b28af8e4 100644 --- a/arch/arm/mach-k3/j721e/j721e_init.c +++ b/arch/arm/mach-k3/j721e/j721e_init.c @@ -19,6 +19,7 @@  #include <fdtdec.h>  #include <mmc.h>  #include <remoteproc.h> +#include <k3-avs.h>  #include "../sysfw-loader.h"  #include "../common.h" @@ -39,6 +40,12 @@  #define NB_THREADMAP_BIT0				BIT(0)  #define NB_THREADMAP_BIT1				BIT(1) +/* TISCI DEV ID for A72, MSMC Clock */ +#define DEV_A72SS0_CORE0_0_ID 202 +#define DEV_A72SS0_CORE0_0_ARM_CLK_CLK_ID 2 +#define DEV_A72SS0_CORE0_ID 4 +#define DEV_A72SS0_CORE0_MSMC_CLK_ID 1 +  #ifdef CONFIG_K3_LOAD_SYSFW  struct fwl_data cbass_hc_cfg0_fwls[] = {  #if defined(CONFIG_TARGET_J721E_R5_EVM) @@ -147,6 +154,78 @@ static void setup_navss_nb(void)  	writel(NB_THREADMAP_BIT1, (uintptr_t)NAVSS0_NBSS_NB1_CFG_NB_THREADMAP);  } +#if defined(CONFIG_CPU_V7R) && defined(CONFIG_K3_AVS0) +static int get_clock_index_by_dev_id(ofnode node, u32 dev_id, u32 clk_id) +{ +	ofnode clknode; +	int count, i; +	struct ofnode_phandle_args phandle_args; + +	clknode = ofnode_by_compatible(ofnode_null(), "ti,k2g-sci-clk"); +	if (!ofnode_valid(clknode)) { +		printf("%s: clock-controller not found\n", __func__); +		return -ENODEV; +	} + +	count = ofnode_count_phandle_with_args(node,  "assigned-clocks", "#clock-cells", 0); +	for (i = 0; i < count; i++) { +		if (ofnode_parse_phandle_with_args(node, "assigned-clocks", +						   "#clock-cells", 0, i, &phandle_args)) { +			printf("%s: Could not parse assigned-clocks at index %d\n", __func__, i); +			continue; +		} +		if (ofnode_equal(clknode, phandle_args.node) && +		    phandle_args.args[0] == dev_id && phandle_args.args[1] == clk_id) +			return i; +	} +	return -1; +} + +static int fdt_fixup_a72ss_clock_frequency(void) +{ +	int index, size; +	u32 *rates; +	ofnode node; + +	node = ofnode_by_compatible(ofnode_null(), "ti,am654-rproc"); +	if (!ofnode_valid(node)) { +		printf("%s: A72 not found\n", __func__); +		return -ENODEV; +	} + +	rates = fdt_getprop_w(ofnode_to_fdt(node), ofnode_to_offset(node), +			      "assigned-clock-rates", &size); +	if (!rates) { +		printf("%s: Wrong A72 assigned-clocks-rates configuration\n", __func__); +		return -1; +	} + +	/* Update A72 Clock Frequency to OPP_LOW spec */ +	index = get_clock_index_by_dev_id(node, +					  DEV_A72SS0_CORE0_0_ID, +					  DEV_A72SS0_CORE0_0_ARM_CLK_CLK_ID); +	if (index < 0 || index >= (size / sizeof(u32))) { +		printf("%s: Wrong A72 assigned-clocks configuration\n", __func__); +		return -1; +	} +	rates[index] = cpu_to_fdt32(1000000000); +	printf("Changed A72 CPU frequency to %dHz in DT\n", 1000000000); + +	/* Update MSMC Clock Frequency to OPP_LOW spec */ +	index = get_clock_index_by_dev_id(node, +					  DEV_A72SS0_CORE0_ID, +					  DEV_A72SS0_CORE0_MSMC_CLK_ID); +	if (index < 0 || index >= (size / sizeof(u32))) { +		printf("%s: Wrong A72 assigned-clocks configuration\n", __func__); +		return -1; +	} +	rates[index] = cpu_to_fdt32(500000000); +	printf("Changed MSMC frequency to %dHz in DT\n", 500000000); + +	return 0; +} +#endif +  /*   * This uninitialized global variable would normal end up in the .bss section,   * but the .bss is cleared between writing and reading this variable, so move @@ -301,8 +380,19 @@ void board_init_f(ulong dummy)  #if defined(CONFIG_CPU_V7R) && defined(CONFIG_K3_AVS0)  	ret = uclass_get_device_by_driver(UCLASS_MISC, DM_DRIVER_GET(k3_avs),  					  &dev); -	if (ret) +	if (ret) {  		printf("AVS init failed: %d\n", ret); +	} else if (IS_ENABLED(CONFIG_K3_OPP_LOW)) { +		ret = k3_avs_check_opp(dev, J721E_VDD_MPU, AM6_OPP_LOW); +		if (ret) { +			printf("OPP_LOW: k3_avs_check_opp failed: %d\n", ret); +		} else { +			ret = fdt_fixup_a72ss_clock_frequency(); +			if (ret) +				printf("OPP_LOW: fdt_fixup_a72ss_clock_frequency failed: %d\n", +				       ret); +		} +	}  #endif  #if defined(CONFIG_K3_J721E_DDRSS) diff --git a/arch/arm/mach-k3/r5/Kconfig b/arch/arm/mach-k3/r5/Kconfig index 878087fbf56..12335880e10 100644 --- a/arch/arm/mach-k3/r5/Kconfig +++ b/arch/arm/mach-k3/r5/Kconfig @@ -1,6 +1,13 @@  config K3_LOAD_SYSFW  	bool +config K3_OPP_LOW +	depends on ARCH_K3 && K3_AVS0 +	bool "Enable OPP_LOW on supported TI K3 SoCs" +	help +	  Enabling this will allow Socs with the proper efuse to run at a lower +	  MPU core voltage and adjust frequency according to SoC TRM +  config K3_QOS  	bool "Enable Quality of Service (QoS) Settings for TI K3 SoCs"  	default y if SOC_K3_AM62A7 | 
