diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /arch/arc/include/asm/arcregs.h | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'arch/arc/include/asm/arcregs.h')
| -rw-r--r-- | arch/arc/include/asm/arcregs.h | 127 | 
1 files changed, 10 insertions, 117 deletions
| diff --git a/arch/arc/include/asm/arcregs.h b/arch/arc/include/asm/arcregs.h index 1b907c46566..355cb470c2a 100644 --- a/arch/arc/include/asm/arcregs.h +++ b/arch/arc/include/asm/arcregs.h @@ -20,7 +20,6 @@  #define ARC_REG_PERIBASE_BCR	0x69  #define ARC_REG_FP_BCR		0x6B	/* Single-Precision FPU */  #define ARC_REG_DPFP_BCR	0x6C	/* Dbl Precision FPU */ -#define ARC_REG_MMU_BCR		0x6f  #define ARC_REG_DCCM_BCR	0x74	/* DCCM Present + SZ */  #define ARC_REG_TIMERS_BCR	0x75  #define ARC_REG_ICCM_BCR	0x78 @@ -34,22 +33,12 @@  #define ARC_REG_D_UNCACH_BCR	0x6A  /* status32 Bits Positions */ -#define STATUS_H_BIT		0	/* CPU Halted */ -#define STATUS_E1_BIT		1	/* Int 1 enable */ -#define STATUS_E2_BIT		2	/* Int 2 enable */ -#define STATUS_A1_BIT		3	/* Int 1 active */ -#define STATUS_A2_BIT		4	/* Int 2 active */  #define STATUS_AE_BIT		5	/* Exception active */  #define STATUS_DE_BIT		6	/* PC is in delay slot */  #define STATUS_U_BIT		7	/* User/Kernel mode */  #define STATUS_L_BIT		12	/* Loop inhibit */  /* These masks correspond to the status word(STATUS_32) bits */ -#define STATUS_H_MASK		(1<<STATUS_H_BIT) -#define STATUS_E1_MASK		(1<<STATUS_E1_BIT) -#define STATUS_E2_MASK		(1<<STATUS_E2_BIT) -#define STATUS_A1_MASK		(1<<STATUS_A1_BIT) -#define STATUS_A2_MASK		(1<<STATUS_A2_BIT)  #define STATUS_AE_MASK		(1<<STATUS_AE_BIT)  #define STATUS_DE_MASK		(1<<STATUS_DE_BIT)  #define STATUS_U_MASK		(1<<STATUS_U_BIT) @@ -71,6 +60,7 @@  #define ECR_V_ITLB_MISS			0x21  #define ECR_V_DTLB_MISS			0x22  #define ECR_V_PROTV			0x23 +#define ECR_V_TRAP			0x25  /* Protection Violation Exception Cause Code Values */  #define ECR_C_PROTV_INST_FETCH		0x00 @@ -79,94 +69,23 @@  #define ECR_C_PROTV_XCHG		0x03  #define ECR_C_PROTV_MISALIG_DATA	0x04 +#define ECR_C_BIT_PROTV_MISALIG_DATA	10 + +/* Machine Check Cause Code Values */ +#define ECR_C_MCHK_DUP_TLB		0x01 +  /* DTLB Miss Exception Cause Code Values */  #define ECR_C_BIT_DTLB_LD_MISS		8  #define ECR_C_BIT_DTLB_ST_MISS		9 +/* Dummy ECR values for Interrupts */ +#define event_IRQ1		0x0031abcd +#define event_IRQ2		0x0032abcd  /* Auxiliary registers */  #define AUX_IDENTITY		4  #define AUX_INTR_VEC_BASE	0x25 -#define AUX_IRQ_LEV		0x200	/* IRQ Priority: L1 or L2 */ -#define AUX_IRQ_HINT		0x201	/* For generating Soft Interrupts */ -#define AUX_IRQ_LV12		0x43	/* interrupt level register */ - -#define AUX_IENABLE		0x40c -#define AUX_ITRIGGER		0x40d -#define AUX_IPULSE		0x415 - -/* Timer related Aux registers */ -#define ARC_REG_TIMER0_LIMIT	0x23	/* timer 0 limit */ -#define ARC_REG_TIMER0_CTRL	0x22	/* timer 0 control */ -#define ARC_REG_TIMER0_CNT	0x21	/* timer 0 count */ -#define ARC_REG_TIMER1_LIMIT	0x102	/* timer 1 limit */ -#define ARC_REG_TIMER1_CTRL	0x101	/* timer 1 control */ -#define ARC_REG_TIMER1_CNT	0x100	/* timer 1 count */ - -#define TIMER_CTRL_IE		(1 << 0) /* Interupt when Count reachs limit */ -#define TIMER_CTRL_NH		(1 << 1) /* Count only when CPU NOT halted */ - -/* MMU Management regs */ -#define ARC_REG_TLBPD0		0x405 -#define ARC_REG_TLBPD1		0x406 -#define ARC_REG_TLBINDEX	0x407 -#define ARC_REG_TLBCOMMAND	0x408 -#define ARC_REG_PID		0x409 -#define ARC_REG_SCRATCH_DATA0	0x418 - -/* Bits in MMU PID register */ -#define MMU_ENABLE		(1 << 31)	/* Enable MMU for process */ - -/* Error code if probe fails */ -#define TLB_LKUP_ERR		0x80000000 - -/* TLB Commands */ -#define TLBWrite    0x1 -#define TLBRead     0x2 -#define TLBGetIndex 0x3 -#define TLBProbe    0x4 - -#if (CONFIG_ARC_MMU_VER >= 2) -#define TLBWriteNI  0x5		/* write JTLB without inv uTLBs */ -#define TLBIVUTLB   0x6		/* explicitly inv uTLBs */ -#else -#undef TLBWriteNI		/* These cmds don't exist on older MMU */ -#undef TLBIVUTLB -#endif -/* Instruction cache related Auxiliary registers */ -#define ARC_REG_IC_BCR		0x77	/* Build Config reg */ -#define ARC_REG_IC_IVIC		0x10 -#define ARC_REG_IC_CTRL		0x11 -#define ARC_REG_IC_IVIL		0x19 -#if (CONFIG_ARC_MMU_VER > 2) -#define ARC_REG_IC_PTAG		0x1E -#endif - -/* Bit val in IC_CTRL */ -#define IC_CTRL_CACHE_DISABLE   0x1 - -/* Data cache related Auxiliary registers */ -#define ARC_REG_DC_BCR		0x72 -#define ARC_REG_DC_IVDC		0x47 -#define ARC_REG_DC_CTRL		0x48 -#define ARC_REG_DC_IVDL		0x4A -#define ARC_REG_DC_FLSH		0x4B -#define ARC_REG_DC_FLDL		0x4C -#if (CONFIG_ARC_MMU_VER > 2) -#define ARC_REG_DC_PTAG		0x5C -#endif - -/* Bit val in DC_CTRL */ -#define DC_CTRL_INV_MODE_FLUSH  0x40 -#define DC_CTRL_FLUSH_STATUS    0x100 - -/* MMU Management regs */ -#define ARC_REG_PID		0x409 -#define ARC_REG_SCRATCH_DATA0	0x418 - -/* Bits in MMU PID register */ -#define MMU_ENABLE		(1 << 31)	/* Enable MMU for process */  /*   * Floating Pt Registers @@ -293,24 +212,6 @@ struct bcr_identity {  #endif  }; -struct bcr_mmu_1_2 { -#ifdef CONFIG_CPU_BIG_ENDIAN -	unsigned int ver:8, ways:4, sets:4, u_itlb:8, u_dtlb:8; -#else -	unsigned int u_dtlb:8, u_itlb:8, sets:4, ways:4, ver:8; -#endif -}; - -struct bcr_mmu_3 { -#ifdef CONFIG_CPU_BIG_ENDIAN -	unsigned int ver:8, ways:4, sets:4, osm:1, reserv:3, pg_sz:4, -		     u_itlb:4, u_dtlb:4; -#else -	unsigned int u_dtlb:4, u_itlb:4, pg_sz:4, reserv:3, osm:1, sets:4, -		     ways:4, ver:8; -#endif -}; -  #define EXTN_SWAP_VALID     0x1  #define EXTN_NORM_VALID     0x2  #define EXTN_MINMAX_VALID   0x2 @@ -343,14 +244,6 @@ struct bcr_extn_xymem {  #endif  }; -struct bcr_cache { -#ifdef CONFIG_CPU_BIG_ENDIAN -	unsigned int pad:12, line_len:4, sz:4, config:4, ver:8; -#else -	unsigned int ver:8, config:4, sz:4, line_len:4, pad:12; -#endif -}; -  struct bcr_perip {  #ifdef CONFIG_CPU_BIG_ENDIAN  	unsigned int start:8, pad2:8, sz:8, pad:8; @@ -403,7 +296,7 @@ struct cpuinfo_arc_mmu {  };  struct cpuinfo_arc_cache { -	unsigned int has_aliasing, sz, line_len, assoc, ver; +	unsigned int sz, line_len, assoc, ver;  };  struct cpuinfo_arc_ccm { | 
