mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 14:31:21 +02:00 
			
		
		
		
	U-boot is responsible for enabling the GPU DT node after all necessary configuration (VPR setup for T124) is performed. In order to be able to check whether this configuration has been performed right before booting the kernel, make it happen during board_init(). Also move VPR configuration into the more generic gpu.c file, which will also host other GPU-related functions, and let boards specify individually whether they need VPR setup or not. Signed-off-by: Alexandre Courbot <acourbot@nvidia.com> Cc: Stephen Warren <swarren@nvidia.com> Cc: Tom Warren <twarren@nvidia.com> Signed-off-by: Tom Warren <twarren@nvidia.com>
		
			
				
	
	
		
			70 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2010-2015
 | |
|  * NVIDIA Corporation <www.nvidia.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier:	GPL-2.0+
 | |
|  */
 | |
| #include <asm/types.h>
 | |
| 
 | |
| /* Stabilization delays, in usec */
 | |
| #define PLL_STABILIZATION_DELAY	(300)
 | |
| #define IO_STABILIZATION_DELAY	(1000)
 | |
| 
 | |
| #define PLLX_ENABLED		(1 << 30)
 | |
| #define CCLK_BURST_POLICY	0x20008888
 | |
| #define SUPER_CCLK_DIVIDER	0x80000000
 | |
| 
 | |
| /* Calculate clock fractional divider value from ref and target frequencies */
 | |
| #define CLK_DIVIDER(REF, FREQ)	((((REF) * 2) / FREQ) - 2)
 | |
| 
 | |
| /* Calculate clock frequency value from reference and clock divider value */
 | |
| #define CLK_FREQUENCY(REF, REG)	(((REF) * 2) / (REG + 2))
 | |
| 
 | |
| /* AVP/CPU ID */
 | |
| #define PG_UP_TAG_0_PID_CPU	0x55555555	/* CPU aka "a9" aka "mpcore" */
 | |
| #define PG_UP_TAG_0		0x0
 | |
| 
 | |
| /* AP base physical address of internal SRAM */
 | |
| #define NV_PA_BASE_SRAM		0x40000000
 | |
| 
 | |
| #define EXCEP_VECTOR_CPU_RESET_VECTOR	(NV_PA_EVP_BASE + 0x100)
 | |
| #define CSITE_CPU_DBG0_LAR		(NV_PA_CSITE_BASE + 0x10FB0)
 | |
| #define CSITE_CPU_DBG1_LAR		(NV_PA_CSITE_BASE + 0x12FB0)
 | |
| 
 | |
| #define FLOW_CTLR_HALT_COP_EVENTS	(NV_PA_FLOW_BASE + 4)
 | |
| #define FLOW_MODE_STOP			2
 | |
| #define HALT_COP_EVENT_JTAG		(1 << 28)
 | |
| #define HALT_COP_EVENT_IRQ_1		(1 << 11)
 | |
| #define HALT_COP_EVENT_FIQ_1		(1 << 9)
 | |
| 
 | |
| /* This is the main entry into U-Boot, used by the Cortex-A9 */
 | |
| extern void _start(void);
 | |
| 
 | |
| /**
 | |
|  * Works out the SOC/SKU type used for clocks settings
 | |
|  *
 | |
|  * @return	SOC type - see TEGRA_SOC...
 | |
|  */
 | |
| int tegra_get_chip_sku(void);
 | |
| 
 | |
| /**
 | |
|  * Returns the pure SOC (chip ID) from the HIDREV register
 | |
|  *
 | |
|  * @return	SOC ID - see CHIPID_TEGRAxx...
 | |
|  */
 | |
| int tegra_get_chip(void);
 | |
| 
 | |
| /**
 | |
|  * Returns the SKU ID from the sku_info register
 | |
|  *
 | |
|  * @return	SKU ID - see SKU_ID_Txx...
 | |
|  */
 | |
| int tegra_get_sku_info(void);
 | |
| 
 | |
| /* Do any chip-specific cache config */
 | |
| void config_cache(void);
 | |
| 
 | |
| #if defined(CONFIG_TEGRA_SUPPORT_NON_SECURE)
 | |
| bool tegra_cpu_is_non_secure(void);
 | |
| #endif
 |