mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 01:28:14 +00:00 
			
		
		
		
	When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			240 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			240 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Copyright (C) 2009 Jens Scharsig (js_at_ng@scharsoft.de)
 | |
|  */
 | |
| 
 | |
| #ifndef AT91_MATRIX_H
 | |
| #define AT91_MATRIX_H
 | |
| 
 | |
| #ifdef __ASSEMBLY__
 | |
| 
 | |
| #if defined(CONFIG_AT91SAM9260) || defined(CONFIG_AT91SAM9G20)
 | |
| #define AT91_ASM_MATRIX_CSA0	(ATMEL_BASE_MATRIX + 0x11C)
 | |
| #elif defined(CONFIG_AT91SAM9261)
 | |
| #define AT91_ASM_MATRIX_CSA0	(ATMEL_BASE_MATRIX + 0x30)
 | |
| #elif defined(CONFIG_AT91SAM9263)
 | |
| #define AT91_ASM_MATRIX_CSA0	(ATMEL_BASE_MATRIX + 0x120)
 | |
| #elif defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| #define AT91_ASM_MATRIX_CSA0	(ATMEL_BASE_MATRIX + 0x128)
 | |
| #else
 | |
| #error AT91_ASM_MATRIX_CSA0 is not definied for current CPU
 | |
| #endif
 | |
| 
 | |
| #define AT91_ASM_MATRIX_MCFG	ATMEL_BASE_MATRIX
 | |
| 
 | |
| #else
 | |
| #if defined(CONFIG_AT91SAM9260) || defined(CONFIG_AT91SAM9G20)
 | |
| #define AT91_MATRIX_MASTERS	6
 | |
| #define AT91_MATRIX_SLAVES	5
 | |
| #elif defined(CONFIG_AT91SAM9261)
 | |
| #define AT91_MATRIX_MASTERS	1
 | |
| #define AT91_MATRIX_SLAVES	5
 | |
| #elif defined(CONFIG_AT91SAM9263)
 | |
| #define AT91_MATRIX_MASTERS	9
 | |
| #define AT91_MATRIX_SLAVES	7
 | |
| #elif defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| #define AT91_MATRIX_MASTERS	11
 | |
| #define AT91_MATRIX_SLAVES	8
 | |
| #else
 | |
| #error CPU not supported. Please update at91_matrix.h
 | |
| #endif
 | |
| 
 | |
| typedef struct at91_priority {
 | |
| 	u32	a;
 | |
| 	u32	b;
 | |
| } at91_priority_t;
 | |
| 
 | |
| typedef struct at91_matrix {
 | |
| 	u32		mcfg[AT91_MATRIX_MASTERS];
 | |
| #if defined(CONFIG_AT91SAM9261)
 | |
| 	u32		scfg[AT91_MATRIX_SLAVES];
 | |
| 	u32		res61_1[3];
 | |
| 	u32		tcr;
 | |
| 	u32		res61_2[2];
 | |
| 	u32		csa;
 | |
| 	u32		pucr;
 | |
| 	u32		res61_3[114];
 | |
| #else
 | |
| 	u32		reserve1[16 - AT91_MATRIX_MASTERS];
 | |
| 	u32		scfg[AT91_MATRIX_SLAVES];
 | |
| 	u32		reserve2[16 - AT91_MATRIX_SLAVES];
 | |
| 	at91_priority_t	pr[AT91_MATRIX_SLAVES];
 | |
| 	u32		reserve3[32 - (2 * AT91_MATRIX_SLAVES)];
 | |
| 	u32		mrcr;		/* 0x100 Master Remap Control */
 | |
| 	u32		reserve4[3];
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| 	u32		ccr[52];	/* 0x110 - 0x1E0 Chip Configuration */
 | |
| 	u32		womr;		/* 0x1E4 Write Protect Mode  */
 | |
| 	u32		wpsr;		/* 0x1E8 Write Protect Status */
 | |
| 	u32		resg45_1[10];
 | |
| #elif defined(CONFIG_AT91SAM9260)  || defined(CONFIG_AT91SAM9G20)
 | |
| 	u32		res60_1[3];
 | |
| 	u32		csa;
 | |
| 	u32		res60_2[56];
 | |
| #elif defined(CONFIG_AT91SAM9263)
 | |
| 	u32		res63_1;
 | |
| 	u32		tcmr;
 | |
| 	u32		res63_2[2];
 | |
| 	u32		csa[2];
 | |
| 	u32		res63_3[54];
 | |
| #else
 | |
| 	u32		reserve5[60];
 | |
| #endif
 | |
| #endif
 | |
| } at91_matrix_t;
 | |
| 
 | |
| #endif /* __ASSEMBLY__ */
 | |
| 
 | |
| #define AT91_MATRIX_CSA_DBPUC		0x00000100
 | |
| #define AT91_MATRIX_CSA_VDDIOMSEL_1_8V	0x00000000
 | |
| #define AT91_MATRIX_CSA_VDDIOMSEL_3_3V	0x00010000
 | |
| 
 | |
| #define AT91_MATRIX_CSA_EBI_CS1A	0x00000002
 | |
| #define AT91_MATRIX_CSA_EBI_CS3A	0x00000008
 | |
| #define AT91_MATRIX_CSA_EBI_CS4A	0x00000010
 | |
| #define AT91_MATRIX_CSA_EBI_CS5A	0x00000020
 | |
| 
 | |
| #define AT91_MATRIX_CSA_EBI1_CS2A	0x00000008
 | |
| 
 | |
| #if defined CONFIG_AT91SAM9261
 | |
| /* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */
 | |
| #define	AT91_MATRIX_MCFG_RCB0	(1 << 0)
 | |
| /* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */
 | |
| #define	AT91_MATRIX_MCFG_RCB1	(1 << 1)
 | |
| #endif
 | |
| 
 | |
| /* Undefined Length Burst Type */
 | |
| #if defined(CONFIG_AT91SAM9260) || defined(CONFIG_AT91SAM9263) || \
 | |
| 	defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| #define AT91_MATRIX_MCFG_ULBT_INFINITE	0x00000000
 | |
| #define AT91_MATRIX_MCFG_ULBT_SINGLE	0x00000001
 | |
| #define AT91_MATRIX_MCFG_ULBT_FOUR	0x00000002
 | |
| #define AT91_MATRIX_MCFG_ULBT_EIGHT	0x00000003
 | |
| #define AT91_MATRIX_MCFG_ULBT_SIXTEEN	0x00000004
 | |
| #endif
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| #define AT91_MATRIX_MCFG_ULBT_THIRTYTWO	0x00000005
 | |
| #define AT91_MATRIX_MCFG_ULBT_SIXTYFOUR	0x00000006
 | |
| #define AT91_MATRIX_MCFG_ULBT_128	0x00000007
 | |
| #endif
 | |
| 
 | |
| /* Default Master Type */
 | |
| #define AT91_MATRIX_SCFG_DEFMSTR_TYPE_NONE	0x00000000
 | |
| #define AT91_MATRIX_SCFG_DEFMSTR_TYPE_LAST	0x00010000
 | |
| #define AT91_MATRIX_SCFG_DEFMSTR_TYPE_FIXED	0x00020000
 | |
| 
 | |
| /* Fixed Index of Default Master */
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9263) || \
 | |
| 	defined(CONFIG_AT91SAM9M10G45)
 | |
| #define	AT91_MATRIX_SCFG_FIXED_DEFMSTR(x)	((x & 0xf) << 18)
 | |
| #elif defined(CONFIG_AT91SAM9261) || defined(CONFIG_AT91SAM9260)
 | |
| #define	AT91_MATRIX_SCFG_FIXED_DEFMSTR(x)	((x & 7) << 18)
 | |
| #endif
 | |
| 
 | |
| /* Maximum Number of Allowed Cycles for a Burst */
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| #define	AT91_MATRIX_SCFG_SLOT_CYCLE(x)	((x & 0x1ff) << 0)
 | |
| #elif defined(CONFIG_AT91SAM9260) || defined(CONFIG_AT91SAM9261) || \
 | |
| 	defined(CONFIG_AT91SAM9263)
 | |
| #define	AT91_MATRIX_SCFG_SLOT_CYCLE(x)	((x & 0xff) << 0)
 | |
| #endif
 | |
| 
 | |
| /* Arbitration Type */
 | |
| #if defined(CONFIG_AT91SAM9260) || defined(CONFIG_AT91SAM9263)
 | |
| #define	AT91_MATRIX_SCFG_ARBT_ROUND_ROBIN	0x00000000
 | |
| #define	AT91_MATRIX_SCFG_ARBT_FIXED_PRIORITY	0x01000000
 | |
| #endif
 | |
| 
 | |
| /* Master Remap Control Register */
 | |
| #if defined(CONFIG_AT91SAM9260) || defined(CONFIG_AT91SAM9263) || \
 | |
| 	defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| /* Remap Command for AHB Master 0 (ARM926EJ-S Instruction Master) */
 | |
| #define	AT91_MATRIX_MRCR_RCB0	(1 << 0)
 | |
| /* Remap Command for AHB Master 1 (ARM926EJ-S Data Master) */
 | |
| #define	AT91_MATRIX_MRCR_RCB1	(1 << 1)
 | |
| #endif
 | |
| #if defined(CONFIG_AT91SAM9263) || defined(CONFIG_AT91SAM9G45) || \
 | |
| 	defined(CONFIG_AT91SAM9M10G45)
 | |
| #define	AT91_MATRIX_MRCR_RCB2	0x00000004
 | |
| #define	AT91_MATRIX_MRCR_RCB3	0x00000008
 | |
| #define	AT91_MATRIX_MRCR_RCB4	0x00000010
 | |
| #define	AT91_MATRIX_MRCR_RCB5	0x00000020
 | |
| #define	AT91_MATRIX_MRCR_RCB6	0x00000040
 | |
| #define	AT91_MATRIX_MRCR_RCB7	0x00000080
 | |
| #define	AT91_MATRIX_MRCR_RCB8	0x00000100
 | |
| #endif
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| #define	AT91_MATRIX_MRCR_RCB9	0x00000200
 | |
| #define	AT91_MATRIX_MRCR_RCB10	0x00000400
 | |
| #define	AT91_MATRIX_MRCR_RCB11	0x00000800
 | |
| #endif
 | |
| 
 | |
| /* TCM Configuration Register */
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| /* Size of ITCM enabled memory block */
 | |
| #define	AT91_MATRIX_TCMR_ITCM_0		0x00000000
 | |
| #define	AT91_MATRIX_TCMR_ITCM_32	0x00000040
 | |
| /* Size of DTCM enabled memory block */
 | |
| #define	AT91_MATRIX_TCMR_DTCM_0		0x00000000
 | |
| #define	AT91_MATRIX_TCMR_DTCM_32	0x00000060
 | |
| #define	AT91_MATRIX_TCMR_DTCM_64	0x00000070
 | |
| /* Wait state TCM register */
 | |
| #define	AT91_MATRIX_TCMR_TCM_NO_WS	0x00000000
 | |
| #define	AT91_MATRIX_TCMR_TCM_ONE_WS	0x00000800
 | |
| #endif
 | |
| #if defined(CONFIG_AT91SAM9263)
 | |
| /* Size of ITCM enabled memory block */
 | |
| #define	AT91_MATRIX_TCMR_ITCM_0		0x00000000
 | |
| #define	AT91_MATRIX_TCMR_ITCM_16	0x00000005
 | |
| #define	AT91_MATRIX_TCMR_ITCM_32	0x00000006
 | |
| /* Size of DTCM enabled memory block */
 | |
| #define	AT91_MATRIX_TCMR_DTCM_0		0x00000000
 | |
| #define	AT91_MATRIX_TCMR_DTCM_16	0x00000050
 | |
| #define	AT91_MATRIX_TCMR_DTCM_32	0x00000060
 | |
| #endif
 | |
| #if defined(CONFIG_AT91SAM9261)
 | |
| /* Size of ITCM enabled memory block */
 | |
| #define	AT91_MATRIX_TCMR_ITCM_0		0x00000000
 | |
| #define	AT91_MATRIX_TCMR_ITCM_16	0x00000005
 | |
| #define	AT91_MATRIX_TCMR_ITCM_32	0x00000006
 | |
| #define	AT91_MATRIX_TCMR_ITCM_64	0x00000007
 | |
| /* Size of DTCM enabled memory block */
 | |
| #define	AT91_MATRIX_TCMR_DTCM_0		0x00000000
 | |
| #define	AT91_MATRIX_TCMR_DTCM_16	0x00000050
 | |
| #define	AT91_MATRIX_TCMR_DTCM_32	0x00000060
 | |
| #define	AT91_MATRIX_TCMR_DTCM_64	0x00000070
 | |
| #endif
 | |
| 
 | |
| #if defined(CONFIG_AT91SAM9G45) || defined(CONFIG_AT91SAM9M10G45)
 | |
| /* Video Mode Configuration Register */
 | |
| #define	AT91C_MATRIX_VDEC_SEL_OFF	0x00000000
 | |
| #define	AT91C_MATRIX_VDEC_SEL_ON	0x00000001
 | |
| /* Write Protect Mode Register */
 | |
| #define	AT91_MATRIX_WPMR_WP_WPDIS	0x00000000
 | |
| #define	AT91_MATRIX_WPMR_WP_WPEN	0x00000001
 | |
| #define	AT91_MATRIX_WPMR_WPKEY		0xFFFFFF00	/* Write Protect KEY */
 | |
| /* Write Protect Status Register */
 | |
| #define	AT91_MATRIX_WPSR_NO_WPV		0x00000000
 | |
| #define	AT91_MATRIX_WPSR_WPV		0x00000001
 | |
| #define	AT91_MATRIX_WPSR_WPVSRC		0x00FFFF00	/* Write Protect Violation Source */
 | |
| #endif
 | |
| 
 | |
| /* USB Pad Pull-Up Control Register */
 | |
| #if defined(CONFIG_AT91SAM9261)
 | |
| #define	AT91_MATRIX_USBPUCR_PUON	0x40000000
 | |
| #endif
 | |
| 
 | |
| #define AT91_MATRIX_PRA_M0(x)	((x & 3) << 0)	/* Master 0 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M1(x)	((x & 3) << 4)	/* Master 1 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M2(x)	((x & 3) << 8)	/* Master 2 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M3(x)	((x & 3) << 12)	/* Master 3 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M4(x)	((x & 3) << 16)	/* Master 4 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M5(x)	((x & 3) << 20)	/* Master 5 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M6(x)	((x & 3) << 24)	/* Master 6 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRA_M7(x)	((x & 3) << 28)	/* Master 7 Priority Reg. A*/
 | |
| #define AT91_MATRIX_PRB_M8(x)	((x & 3) << 0)	/* Master 8 Priority Reg. B) */
 | |
| #define AT91_MATRIX_PRB_M9(x)	((x & 3) << 4)	/* Master 9 Priority Reg. B) */
 | |
| #define AT91_MATRIX_PRB_M10(x)	((x & 3) << 8)	/* Master 10 Priority Reg. B) */
 | |
| 
 | |
| #endif
 |