93 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Copyright (C) 2020 Cortina Access Inc.
 | |
|  *
 | |
|  * Configuration for Cortina-Access Presidio board
 | |
|  */
 | |
| 
 | |
| #ifndef __PRESIDIO_ASIC_H
 | |
| #define __PRESIDIO_ASIC_H
 | |
| 
 | |
| #define CONFIG_REMAKE_ELF
 | |
| 
 | |
| #define CONFIG_SUPPORT_RAW_INITRD
 | |
| 
 | |
| #define CONFIG_SYS_INIT_SP_ADDR		0x00100000
 | |
| #define CONFIG_SYS_BOOTM_LEN		0x00c00000
 | |
| 
 | |
| /* Generic Timer Definitions */
 | |
| #define COUNTER_FREQUENCY		25000000
 | |
| #define CONFIG_SYS_TIMER_RATE		COUNTER_FREQUENCY
 | |
| #define CONFIG_SYS_TIMER_COUNTER	0xf4321008
 | |
| 
 | |
| /* note: arch/arm/cpu/armv8/start.S which references GICD_BASE/GICC_BASE
 | |
|  * does not yet support DT. Thus define it here.
 | |
|  */
 | |
| #define CONFIG_GICV2
 | |
| #define GICD_BASE			0xf7011000
 | |
| #define GICC_BASE			0xf7012000
 | |
| 
 | |
| /* Size of malloc() pool */
 | |
| #define CONFIG_SYS_MALLOC_LEN		(CONFIG_ENV_SIZE + (8 << 20))
 | |
| 
 | |
| #define CONFIG_SYS_TIMER_BASE		0xf4321000
 | |
| 
 | |
| /* Use external clock source */
 | |
| #define PRESIDIO_APB_CLK		125000000
 | |
| #define CORTINA_PER_IO_FREQ		PRESIDIO_APB_CLK
 | |
| 
 | |
| /* Cortina Serial Configuration */
 | |
| #define CORTINA_UART_CLOCK		(PRESIDIO_APB_CLK)
 | |
| #define CORTINA_SERIAL_PORTS		{(void *)CONFIG_SYS_SERIAL0, \
 | |
| 					 (void *)CONFIG_SYS_SERIAL1}
 | |
| 
 | |
| #define CONFIG_SYS_SERIAL0		PER_UART0_CFG
 | |
| #define CONFIG_SYS_SERIAL1		PER_UART1_CFG
 | |
| 
 | |
| /* BOOTP options */
 | |
| #define CONFIG_BOOTP_BOOTFILESIZE
 | |
| 
 | |
| /* Miscellaneous configurable options */
 | |
| #define CONFIG_SYS_LOAD_ADDR		(DDR_BASE + 0x10000000)
 | |
| #define CONFIG_LAST_STAGE_INIT
 | |
| 
 | |
| /* SDRAM Bank #1 */
 | |
| #define DDR_BASE			0x00000000
 | |
| #define PHYS_SDRAM_1			DDR_BASE
 | |
| #define PHYS_SDRAM_1_SIZE		0x80000000 /* 2GB */
 | |
| #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM_1
 | |
| 
 | |
| /* Console I/O Buffer Size */
 | |
| #define CONFIG_SYS_CBSIZE		256
 | |
| #define CONFIG_SYS_PBSIZE		(CONFIG_SYS_CBSIZE + \
 | |
| 					sizeof(CONFIG_SYS_PROMPT) + 16)
 | |
| #define CONFIG_SYS_BARGSIZE		CONFIG_SYS_CBSIZE
 | |
| 
 | |
| #define KSEG1_ATU_XLAT(x) (x)
 | |
| 
 | |
| /* HW REG ADDR */
 | |
| #define NI_READ_POLL_COUNT                      1000
 | |
| #define CA_NI_MDIO_REG_BASE                     0xF4338
 | |
| #define NI_HV_GLB_MAC_ADDR_CFG0_OFFSET          0x010
 | |
| #define NI_HV_GLB_MAC_ADDR_CFG1_OFFSET          0x014
 | |
| #define NI_HV_PT_BASE                           0x400
 | |
| #define NI_HV_XRAM_BASE                         0x820
 | |
| #define GLOBAL_BLOCK_RESET_OFFSET               0x04
 | |
| #define GLOBAL_GLOBAL_CONFIG_OFFSET             0x20
 | |
| #define GLOBAL_IO_DRIVE_CONTROL_OFFSET          0x4c
 | |
| 
 | |
| /* max command args */
 | |
| #define CONFIG_SYS_MAXARGS		64
 | |
| #define CONFIG_EXTRA_ENV_SETTINGS	"silent=y\0"
 | |
| 
 | |
| /* nand driver parameters */
 | |
| #ifdef CONFIG_TARGET_PRESIDIO_ASIC
 | |
| 	#define CONFIG_SYS_NAND_ONFI_DETECTION
 | |
| 	#define CONFIG_SYS_MAX_NAND_DEVICE      1
 | |
| 	#define CONFIG_SYS_NAND_MAX_CHIPS       1
 | |
| 	#define CONFIG_SYS_NAND_BASE            CONFIG_SYS_FLASH_BASE
 | |
| 	#define CONFIG_SYS_NAND_BASE_LIST       { CONFIG_SYS_NAND_BASE }
 | |
| #endif
 | |
| 
 | |
| #endif /* __PRESIDIO_ASIC_H */
 |