diff options
Diffstat (limited to 'arch/arm/include/asm')
| -rw-r--r-- | arch/arm/include/asm/arch-fsl-layerscape/config.h | 4 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-fsl-layerscape/cpu.h | 12 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-fsl-layerscape/immap_lsch3.h | 69 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-fsl-layerscape/mmu.h | 2 | ||||
| -rw-r--r-- | arch/arm/include/asm/armv8/mmu.h | 5 | ||||
| -rw-r--r-- | arch/arm/include/asm/fsl_secure_boot.h | 4 | ||||
| -rw-r--r-- | arch/arm/include/asm/global_data.h | 7 | ||||
| -rw-r--r-- | arch/arm/include/asm/system.h | 1 | 
8 files changed, 76 insertions, 28 deletions
| diff --git a/arch/arm/include/asm/arch-fsl-layerscape/config.h b/arch/arm/include/asm/arch-fsl-layerscape/config.h index 586ce172152..b5b08aae232 100644 --- a/arch/arm/include/asm/arch-fsl-layerscape/config.h +++ b/arch/arm/include/asm/arch-fsl-layerscape/config.h @@ -33,8 +33,8 @@  #define CONFIG_SYS_FSL_OCRAM_SIZE	0x00020000 /* Real size 128K */  /* DDR */ -#define CONFIG_SYS_LS2_DDR_BLOCK1_SIZE	((phys_size_t)2 << 30) -#define CONFIG_MAX_MEM_MAPPED		CONFIG_SYS_LS2_DDR_BLOCK1_SIZE +#define CONFIG_SYS_DDR_BLOCK1_SIZE	((phys_size_t)2 << 30) +#define CONFIG_MAX_MEM_MAPPED		CONFIG_SYS_DDR_BLOCK1_SIZE  #define CONFIG_SYS_FSL_CCSR_GUR_LE  #define CONFIG_SYS_FSL_CCSR_SCFG_LE diff --git a/arch/arm/include/asm/arch-fsl-layerscape/cpu.h b/arch/arm/include/asm/arch-fsl-layerscape/cpu.h index 4ea4aeaf4c2..bcf3e3863e6 100644 --- a/arch/arm/include/asm/arch-fsl-layerscape/cpu.h +++ b/arch/arm/include/asm/arch-fsl-layerscape/cpu.h @@ -115,7 +115,11 @@ static struct mm_region early_map[] = {  	},  	{ CONFIG_SYS_FSL_DRAM_BASE1, CONFIG_SYS_FSL_DRAM_BASE1,  	  CONFIG_SYS_FSL_DRAM_SIZE1, +#if defined(CONFIG_SPL) && !defined(CONFIG_SPL_BUILD)  	  PTE_BLOCK_MEMTYPE(MT_NORMAL) | +#else	/* Start with nGnRnE and PXN and UXN to prevent speculative access */ +	  PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN | +#endif  	  PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS  	},  	/* Map IFC region #2 up to CONFIG_SYS_FLASH_BASE for NAND boot */ @@ -130,7 +134,7 @@ static struct mm_region early_map[] = {  	},  	{ CONFIG_SYS_FSL_DRAM_BASE2, CONFIG_SYS_FSL_DRAM_BASE2,  	  CONFIG_SYS_FSL_DRAM_SIZE2, -	  PTE_BLOCK_MEMTYPE(MT_NORMAL) | +	  PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN |  	  PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS  	},  #elif defined(CONFIG_FSL_LSCH2) @@ -158,12 +162,16 @@ static struct mm_region early_map[] = {  	},  	{ CONFIG_SYS_FSL_DRAM_BASE1, CONFIG_SYS_FSL_DRAM_BASE1,  	  CONFIG_SYS_FSL_DRAM_SIZE1, +#if defined(CONFIG_SPL) && !defined(CONFIG_SPL_BUILD)  	  PTE_BLOCK_MEMTYPE(MT_NORMAL) | +#else	/* Start with nGnRnE and PXN and UXN to prevent speculative access */ +	  PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN | +#endif  	  PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS  	},  	{ CONFIG_SYS_FSL_DRAM_BASE2, CONFIG_SYS_FSL_DRAM_BASE2,  	  CONFIG_SYS_FSL_DRAM_SIZE2, -	  PTE_BLOCK_MEMTYPE(MT_NORMAL) | +	  PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN |  	  PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS  	},  #endif diff --git a/arch/arm/include/asm/arch-fsl-layerscape/immap_lsch3.h b/arch/arm/include/asm/arch-fsl-layerscape/immap_lsch3.h index 43ae686a295..08ea8fb8eff 100644 --- a/arch/arm/include/asm/arch-fsl-layerscape/immap_lsch3.h +++ b/arch/arm/include/asm/arch-fsl-layerscape/immap_lsch3.h @@ -177,21 +177,23 @@ struct ccsr_gur {  	u8	res_008[0x20-0x8];  	u32	gpporcr1;	/* General-purpose POR configuration */  	u32	gpporcr2;	/* General-purpose POR configuration 2 */ -#define FSL_CHASSIS3_DCFG_FUSESR_VID_SHIFT	25 +	u32	gpporcr3; +	u32	gpporcr4; +	u8	res_030[0x60-0x30]; +#define FSL_CHASSIS3_DCFG_FUSESR_VID_SHIFT	2  #define FSL_CHASSIS3_DCFG_FUSESR_VID_MASK	0x1F -#define FSL_CHASSIS3_DCFG_FUSESR_ALTVID_SHIFT	20 +#define FSL_CHASSIS3_DCFG_FUSESR_ALTVID_SHIFT	7  #define FSL_CHASSIS3_DCFG_FUSESR_ALTVID_MASK	0x1F  	u32	dcfg_fusesr;	/* Fuse status register */ -	u32	gpporcr3; -	u32	gpporcr4; -	u8	res_034[0x70-0x34]; -	u32	devdisr;	/* Device disable control */ +	u8	res_064[0x70-0x64]; +	u32	devdisr;	/* Device disable control 1 */  	u32	devdisr2;	/* Device disable control 2 */  	u32	devdisr3;	/* Device disable control 3 */  	u32	devdisr4;	/* Device disable control 4 */  	u32	devdisr5;	/* Device disable control 5 */  	u32	devdisr6;	/* Device disable control 6 */ -	u32	devdisr7;	/* Device disable control 7 */ +	u8	res_088[0x94-0x88]; +	u32	coredisr;	/* Device disable control 7 */  #define FSL_CHASSIS3_DEVDISR2_DPMAC1	0x00000001  #define FSL_CHASSIS3_DEVDISR2_DPMAC2	0x00000002  #define FSL_CHASSIS3_DEVDISR2_DPMAC3	0x00000004 @@ -216,15 +218,11 @@ struct ccsr_gur {  #define FSL_CHASSIS3_DEVDISR2_DPMAC22	0x00200000  #define FSL_CHASSIS3_DEVDISR2_DPMAC23	0x00400000  #define FSL_CHASSIS3_DEVDISR2_DPMAC24	0x00800000 -	u8	res_08c[0x90-0x8c]; -	u32	coredisru;	/* uppper portion for support of 64 cores */ -	u32	coredisrl;	/* lower portion for support of 64 cores */  	u8	res_098[0xa0-0x98];  	u32	pvr;		/* Processor version */  	u32	svr;		/* System version */ -	u32	mvr;		/* Manufacturing version */ -	u8	res_0ac[0x100-0xac]; -	u32	rcwsr[32];	/* Reset control word status */ +	u8	res_0a8[0x100-0xa8]; +	u32	rcwsr[30];	/* Reset control word status */  #define FSL_CHASSIS3_RCWSR0_SYS_PLL_RAT_SHIFT	2  #define FSL_CHASSIS3_RCWSR0_SYS_PLL_RAT_MASK	0x1f @@ -239,24 +237,53 @@ struct ccsr_gur {  #define RCW_SB_EN_REG_INDEX	9  #define RCW_SB_EN_MASK		0x00000400 -	u8	res_180[0x200-0x180]; -	u32	scratchrw[32];	/* Scratch Read/Write */ -	u8	res_280[0x300-0x280]; +	u8	res_178[0x200-0x178]; +	u32	scratchrw[16];	/* Scratch Read/Write */ +	u8	res_240[0x300-0x240];  	u32	scratchw1r[4];	/* Scratch Read (Write once) */  	u8	res_310[0x400-0x310];  	u32	bootlocptrl;	/* Boot location pointer low-order addr */  	u32	bootlocptrh;	/* Boot location pointer high-order addr */ -	u8	res_408[0x500-0x408]; -	u8	res_500[0x740-0x500];	/* add more registers when needed */ +	u8	res_408[0x520-0x408]; +	u32	usb1_amqr; +	u32	usb2_amqr; +	u8	res_528[0x530-0x528];	/* add more registers when needed */ +	u32	sdmm1_amqr; +	u8	res_534[0x550-0x534];	/* add more registers when needed */ +	u32	sata1_amqr; +	u32	sata2_amqr; +	u8	res_558[0x570-0x558];	/* add more registers when needed */ +	u32	misc1_amqr; +	u8	res_574[0x590-0x574];	/* add more registers when needed */ +	u32	spare1_amqr; +	u32	spare2_amqr; +	u8	res_598[0x620-0x598];	/* add more registers when needed */ +	u32	gencr[7];	/* General Control Registers */ +	u8	res_63c[0x640-0x63c];	/* add more registers when needed */ +	u32	cgensr1;	/* Core General Status Register */ +	u8	res_644[0x660-0x644];	/* add more registers when needed */ +	u32	cgencr1;	/* Core General Control Register */ +	u8	res_664[0x740-0x664];	/* add more registers when needed */  	u32	tp_ityp[64];	/* Topology Initiator Type Register */  	struct {  		u32	upper;  		u32	lower; -	} tp_cluster[3];	/* Core Cluster n Topology Register */ -	u8	res_858[0x1000-0x858]; +	} tp_cluster[4];	/* Core cluster n Topology Register */ +	u8	res_864[0x920-0x864];	/* add more registers when needed */ +	u32 ioqoscr[8];	/*I/O Quality of Services Register */ +	u32 uccr; +	u8	res_944[0x960-0x944];	/* add more registers when needed */ +	u32 ftmcr; +	u8	res_964[0x990-0x964];	/* add more registers when needed */ +	u32 coredisablesr; +	u8	res_994[0xa00-0x994];	/* add more registers when needed */ +	u32 sdbgcr; /*Secure Debug Confifuration Register */ +	u8	res_a04[0xbf8-0xa04];	/* add more registers when needed */ +	u32 ipbrr1; +	u32 ipbrr2; +	u8	res_858[0x1000-0xc00];  }; -  struct ccsr_clk_cluster_group {  	struct {  		u8	res_00[0x10]; diff --git a/arch/arm/include/asm/arch-fsl-layerscape/mmu.h b/arch/arm/include/asm/arch-fsl-layerscape/mmu.h index d54eacd4a03..d232bec1e4d 100644 --- a/arch/arm/include/asm/arch-fsl-layerscape/mmu.h +++ b/arch/arm/include/asm/arch-fsl-layerscape/mmu.h @@ -6,5 +6,5 @@  #ifndef _ASM_ARMV8_FSL_LAYERSCAPE_MMU_H_  #define _ASM_ARMV8_FSL_LAYERSCAPE_MMU_H_ -#include <asm/arch-armv8/mmu.h> +void update_early_mmu_table(void);  #endif /* _ASM_ARMV8_FSL_LAYERSCAPE_MMU_H_ */ diff --git a/arch/arm/include/asm/armv8/mmu.h b/arch/arm/include/asm/armv8/mmu.h index e9b4cdbbcd5..a34990368e4 100644 --- a/arch/arm/include/asm/armv8/mmu.h +++ b/arch/arm/include/asm/armv8/mmu.h @@ -53,6 +53,7 @@  #define PTE_TYPE_FAULT		(0 << 0)  #define PTE_TYPE_TABLE		(3 << 0)  #define PTE_TYPE_BLOCK		(1 << 0) +#define PTE_TYPE_VALID		(1 << 0)  #define PTE_TABLE_PXN		(1UL << 59)  #define PTE_TABLE_XN		(1UL << 60) @@ -77,6 +78,10 @@   */  #define PMD_ATTRINDX(t)		((t) << 2)  #define PMD_ATTRINDX_MASK	(7 << 2) +#define PMD_ATTRMASK		(PTE_BLOCK_PXN		| \ +				 PTE_BLOCK_UXN		| \ +				 PMD_ATTRINDX_MASK	| \ +				 PTE_TYPE_VALID)  /*   * TCR flags. diff --git a/arch/arm/include/asm/fsl_secure_boot.h b/arch/arm/include/asm/fsl_secure_boot.h index ccb513fba24..fd627c0874e 100644 --- a/arch/arm/include/asm/fsl_secure_boot.h +++ b/arch/arm/include/asm/fsl_secure_boot.h @@ -86,8 +86,8 @@  /* For SD boot address and size are assigned in terms of sector   * offset and no. of sectors respectively.   */ -#define CONFIG_BS_HDR_ADDR_DEVICE	0x00000800 -#define CONFIG_BS_ADDR_DEVICE		0x00000840 +#define CONFIG_BS_HDR_ADDR_DEVICE	0x00000900 +#define CONFIG_BS_ADDR_DEVICE		0x00000940  #define CONFIG_BS_HDR_SIZE		0x00000010  #define CONFIG_BS_SIZE			0x00000008  #else diff --git a/arch/arm/include/asm/global_data.h b/arch/arm/include/asm/global_data.h index aee87cdcbf9..dfcbcceba3b 100644 --- a/arch/arm/include/asm/global_data.h +++ b/arch/arm/include/asm/global_data.h @@ -59,6 +59,13 @@ struct arch_global_data {  	phys_addr_t secure_ram;  	unsigned long tlb_allocated;  #endif +#ifdef CONFIG_RESV_RAM +	/* +	 * Reserved RAM for memory resident, eg. Management Complex (MC) +	 * driver which continues to run after U-Boot exits. +	 */ +	phys_addr_t resv_ram; +#endif  #ifdef CONFIG_ARCH_OMAP2  	u32 omap_boot_device; diff --git a/arch/arm/include/asm/system.h b/arch/arm/include/asm/system.h index 766e929d462..9c3261c8847 100644 --- a/arch/arm/include/asm/system.h +++ b/arch/arm/include/asm/system.h @@ -226,6 +226,7 @@ void protect_secure_region(void);  void smp_kick_all_cpus(void);  void flush_l3_cache(void); +void mmu_change_region_attr(phys_addr_t start, size_t size, u64 attrs);  /*   *Issue a secure monitor call in accordance with ARM "SMC Calling convention", | 
