xref: /plan9/sys/src/9/omap/arm.h (revision 9b7bf7df4595c26f1e9b67beb0c6e44c9876fb05)
18e32b400SDavid du Colombier /*
28e32b400SDavid du Colombier  * arm-specific definitions for cortex-a8
38e32b400SDavid du Colombier  * these are used in C and assembler
48e32b400SDavid du Colombier  *
58e32b400SDavid du Colombier  * `cortex' refers specifically to the cortex-a8.
68e32b400SDavid du Colombier  */
78e32b400SDavid du Colombier 
88e32b400SDavid du Colombier /*
98e32b400SDavid du Colombier  * Program Status Registers
108e32b400SDavid du Colombier  */
118e32b400SDavid du Colombier #define PsrMusr		0x00000010		/* mode */
128e32b400SDavid du Colombier #define PsrMfiq		0x00000011
138e32b400SDavid du Colombier #define PsrMirq		0x00000012
148e32b400SDavid du Colombier #define PsrMsvc		0x00000013	/* `protected mode for OS' */
158e32b400SDavid du Colombier #define PsrMmon		0x00000016	/* `secure monitor' (trustzone hyper) */
168e32b400SDavid du Colombier #define PsrMabt		0x00000017
178e32b400SDavid du Colombier #define PsrMund		0x0000001B
188e32b400SDavid du Colombier #define PsrMsys		0x0000001F	/* `privileged user mode for OS' (trustzone) */
198e32b400SDavid du Colombier #define PsrMask		0x0000001F
208e32b400SDavid du Colombier 
218e32b400SDavid du Colombier #define PsrDfiq		0x00000040		/* disable FIQ interrupts */
228e32b400SDavid du Colombier #define PsrDirq		0x00000080		/* disable IRQ interrupts */
238e32b400SDavid du Colombier 
248e32b400SDavid du Colombier #define PsrV		0x10000000		/* overflow */
258e32b400SDavid du Colombier #define PsrC		0x20000000		/* carry/borrow/extend */
268e32b400SDavid du Colombier #define PsrZ		0x40000000		/* zero */
278e32b400SDavid du Colombier #define PsrN		0x80000000		/* negative/less than */
288e32b400SDavid du Colombier 
298e32b400SDavid du Colombier /*
308e32b400SDavid du Colombier  * Coprocessors
318e32b400SDavid du Colombier  */
328e32b400SDavid du Colombier #define CpFP		10			/* float FP, VFP cfg. */
338e32b400SDavid du Colombier #define CpDFP		11			/* double FP */
348e32b400SDavid du Colombier #define CpSC		15			/* System Control */
358e32b400SDavid du Colombier 
368e32b400SDavid du Colombier /*
378e32b400SDavid du Colombier  * Primary (CRn) CpSC registers.
388e32b400SDavid du Colombier  */
398e32b400SDavid du Colombier #define	CpID		0			/* ID and cache type */
408e32b400SDavid du Colombier #define	CpCONTROL	1			/* miscellaneous control */
418e32b400SDavid du Colombier #define	CpTTB		2			/* Translation Table Base(s) */
428e32b400SDavid du Colombier #define	CpDAC		3			/* Domain Access Control */
438e32b400SDavid du Colombier #define	CpFSR		5			/* Fault Status */
448e32b400SDavid du Colombier #define	CpFAR		6			/* Fault Address */
458e32b400SDavid du Colombier #define	CpCACHE		7			/* cache/write buffer control */
468e32b400SDavid du Colombier #define	CpTLB		8			/* TLB control */
478e32b400SDavid du Colombier #define	CpCLD		9			/* L2 Cache Lockdown, op1==1 */
488e32b400SDavid du Colombier #define CpTLD		10			/* TLB Lockdown, with op2 */
498e32b400SDavid du Colombier #define CpVECS		12			/* vector bases, op1==0, Crm==0, op2s (cortex) */
508e32b400SDavid du Colombier #define	CpPID		13			/* Process ID */
518e32b400SDavid du Colombier #define CpDTLB		15			/* TLB, L1 cache stuff (cortex) */
528e32b400SDavid du Colombier 
538e32b400SDavid du Colombier /*
548e32b400SDavid du Colombier  * CpTTB op1==0, Crm==0 opcode2 values.
558e32b400SDavid du Colombier  */
568e32b400SDavid du Colombier #define CpTTB0		0
578e32b400SDavid du Colombier #define CpTTB1		1			/* cortex */
588e32b400SDavid du Colombier #define CpTTBctl	2			/* cortex */
598e32b400SDavid du Colombier 
608e32b400SDavid du Colombier /*
61*9b7bf7dfSDavid du Colombier  * CpFSR op1==0, Crm==0 opcode 2 values.
62*9b7bf7dfSDavid du Colombier  */
63*9b7bf7dfSDavid du Colombier #define CpDFSR		0			/* data fault status */
64*9b7bf7dfSDavid du Colombier #define CpIFSR		1			/* instruction fault status */
65*9b7bf7dfSDavid du Colombier 
66*9b7bf7dfSDavid du Colombier /*
678e32b400SDavid du Colombier  * CpID Secondary (CRm) registers.
688e32b400SDavid du Colombier  */
698e32b400SDavid du Colombier #define CpIDidct	0
708e32b400SDavid du Colombier 
718e32b400SDavid du Colombier /*
728e32b400SDavid du Colombier  * CpID op1==0 opcode2 fields.
738e32b400SDavid du Colombier  * the cortex has more op1 codes for cache size, etc.
748e32b400SDavid du Colombier  */
758e32b400SDavid du Colombier #define CpIDid		0			/* main ID */
768e32b400SDavid du Colombier #define CpIDct		1			/* cache type */
778e32b400SDavid du Colombier #define CpIDtlb		3			/* tlb type (cortex) */
788e32b400SDavid du Colombier #define CpIDmpid	5			/* multiprocessor id (cortex) */
798e32b400SDavid du Colombier 
808e32b400SDavid du Colombier /* CpIDid op1 values */
818e32b400SDavid du Colombier #define CpIDcsize	1			/* cache size (cortex) */
828e32b400SDavid du Colombier #define CpIDcssel	2			/* cache size select (cortex) */
838e32b400SDavid du Colombier 
848e32b400SDavid du Colombier /*
858e32b400SDavid du Colombier  * CpCONTROL op2 codes, op1==0, Crm==0.
868e32b400SDavid du Colombier  */
878e32b400SDavid du Colombier #define CpMainctl	0
888e32b400SDavid du Colombier #define CpAuxctl	1
898e32b400SDavid du Colombier #define CpCPaccess	2
908e32b400SDavid du Colombier 
918e32b400SDavid du Colombier /*
928e32b400SDavid du Colombier  * CpCONTROL: op1==0, CRm==0, op2==CpMainctl.
938e32b400SDavid du Colombier  * main control register.
948e32b400SDavid du Colombier  * cortex/armv7 has more ops and CRm values.
958e32b400SDavid du Colombier  */
968e32b400SDavid du Colombier #define CpCmmu		0x00000001	/* M: MMU enable */
978e32b400SDavid du Colombier #define CpCalign	0x00000002	/* A: alignment fault enable */
988e32b400SDavid du Colombier #define CpCdcache	0x00000004	/* C: data cache on */
998e32b400SDavid du Colombier #define CpCsbo (3<<22|1<<18|1<<16|017<<3)	/* must be 1 (armv7) */
1008e32b400SDavid du Colombier #define CpCsbz (CpCtre|1<<26|CpCve|1<<15|7<<7)	/* must be 0 (armv7) */
1018e32b400SDavid du Colombier #define CpCsw		(1<<10)		/* SW: SWP(B) enable (deprecated in v7) */
1028e32b400SDavid du Colombier #define CpCpredict	0x00000800	/* Z: branch prediction (armv7) */
1038e32b400SDavid du Colombier #define CpCicache	0x00001000	/* I: instruction cache on */
1048e32b400SDavid du Colombier #define CpChv		0x00002000	/* V: high vectors */
1058e32b400SDavid du Colombier #define CpCrr		(1<<14)	/* RR: round robin vs random cache replacement */
1068e32b400SDavid du Colombier #define CpCha		(1<<17)		/* HA: hw access flag enable */
1078e32b400SDavid du Colombier #define CpCdz		(1<<19)		/* DZ: divide by zero fault enable */
1088e32b400SDavid du Colombier #define CpCfi		(1<<21)		/* FI: fast intrs */
1098e32b400SDavid du Colombier #define CpCve		(1<<24)		/* VE: intr vectors enable */
1108e32b400SDavid du Colombier #define CpCee		(1<<25)		/* EE: exception endianness */
1118e32b400SDavid du Colombier #define CpCnmfi		(1<<27)		/* NMFI: non-maskable fast intrs. */
1128e32b400SDavid du Colombier #define CpCtre		(1<<28)		/* TRE: TEX remap enable */
1138e32b400SDavid du Colombier #define CpCafe		(1<<29)		/* AFE: access flag (ttb) enable */
1148e32b400SDavid du Colombier 
1158e32b400SDavid du Colombier /*
1168e32b400SDavid du Colombier  * CpCONTROL: op1==0, CRm==0, op2==CpAuxctl.
1178e32b400SDavid du Colombier  * Auxiliary control register on cortex at least.
1188e32b400SDavid du Colombier  */
1198e32b400SDavid du Colombier #define CpACcachenopipe		(1<<20)	/* don't pipeline cache maint. */
1208e32b400SDavid du Colombier #define CpACcp15serial		(1<<18)	/* serialise CP1[45] ops. */
1218e32b400SDavid du Colombier #define CpACcp15waitidle	(1<<17)	/* CP1[45] wait-on-idle */
1228e32b400SDavid du Colombier #define CpACcp15pipeflush	(1<<16)	/* CP1[45] flush pipeline */
1238e32b400SDavid du Colombier #define CpACneonissue1		(1<<12)	/* neon single issue */
1248e32b400SDavid du Colombier #define CpACldstissue1		(1<<11)	/* force single issue ld, st */
1258e32b400SDavid du Colombier #define CpACissue1		(1<<10)	/* force single issue */
1268e32b400SDavid du Colombier #define CpACnobsm		(1<<7)	/* no branch size mispredicts */
1278e32b400SDavid du Colombier #define CpACibe			(1<<6)	/* cp15 invalidate & btb enable */
1288e32b400SDavid du Colombier #define CpACl1neon		(1<<5)	/* cache neon (FP) data in L1 cache */
1298e32b400SDavid du Colombier #define CpACasa			(1<<4)	/* enable speculative accesses */
1308e32b400SDavid du Colombier #define CpACl1pe		(1<<3)	/* l1 cache parity enable */
1318e32b400SDavid du Colombier #define CpACl2en		(1<<1)	/* l2 cache enable; default 1 */
1328e32b400SDavid du Colombier /*
1338e32b400SDavid du Colombier  * CpCONTROL Secondary (CRm) registers and opcode2 fields.
1348e32b400SDavid du Colombier  */
1358e32b400SDavid du Colombier #define CpCONTROLscr	1
1368e32b400SDavid du Colombier 
1378e32b400SDavid du Colombier #define CpSCRscr	0
1388e32b400SDavid du Colombier 
1398e32b400SDavid du Colombier /*
1408e32b400SDavid du Colombier  * CpCACHE Secondary (CRm) registers and opcode2 fields.  op1==0.
1418e32b400SDavid du Colombier  * In ARM-speak, 'flush' means invalidate and 'clean' means writeback.
1428e32b400SDavid du Colombier  */
1438e32b400SDavid du Colombier #define CpCACHEintr	0			/* interrupt (op2==4) */
1448e32b400SDavid du Colombier #define CpCACHEisi	1			/* inner-sharable I cache (v7) */
1458e32b400SDavid du Colombier #define CpCACHEpaddr	4			/* 0: phys. addr (cortex) */
1468e32b400SDavid du Colombier #define CpCACHEinvi	5			/* instruction, branch table */
1478e32b400SDavid du Colombier #define CpCACHEinvd	6			/* data or unified */
1488e32b400SDavid du Colombier // #define CpCACHEinvu	7			/* unified (not on cortex) */
1498e32b400SDavid du Colombier #define CpCACHEva2pa	8			/* va -> pa translation (cortex) */
1508e32b400SDavid du Colombier #define CpCACHEwb	10			/* writeback */
1518e32b400SDavid du Colombier #define CpCACHEinvdse	11			/* data or unified by mva */
1528e32b400SDavid du Colombier #define CpCACHEwbi	14			/* writeback+invalidate */
1538e32b400SDavid du Colombier 
1548e32b400SDavid du Colombier #define CpCACHEall	0			/* entire (not for invd nor wb(i) on cortex) */
1558e32b400SDavid du Colombier #define CpCACHEse	1			/* single entry */
1568e32b400SDavid du Colombier #define CpCACHEsi	2			/* set/index (set/way) */
1578e32b400SDavid du Colombier #define CpCACHEtest	3			/* test loop */
1588e32b400SDavid du Colombier #define CpCACHEwait	4			/* wait (prefetch flush on cortex) */
1598e32b400SDavid du Colombier #define CpCACHEdmbarr	5			/* wb only (cortex) */
1608e32b400SDavid du Colombier #define CpCACHEflushbtc	6			/* flush branch-target cache (cortex) */
1618e32b400SDavid du Colombier #define CpCACHEflushbtse 7			/* ⋯ or just one entry in it (cortex) */
1628e32b400SDavid du Colombier 
1638e32b400SDavid du Colombier /*
1648e32b400SDavid du Colombier  * CpTLB Secondary (CRm) registers and opcode2 fields.
1658e32b400SDavid du Colombier  */
1668e32b400SDavid du Colombier #define CpTLBinvi	5			/* instruction */
1678e32b400SDavid du Colombier #define CpTLBinvd	6			/* data */
1688e32b400SDavid du Colombier #define CpTLBinvu	7			/* unified */
1698e32b400SDavid du Colombier 
1708e32b400SDavid du Colombier #define CpTLBinv	0			/* invalidate all */
1718e32b400SDavid du Colombier #define CpTLBinvse	1			/* invalidate single entry */
1728e32b400SDavid du Colombier #define CpTBLasid	2			/* by ASID (cortex) */
1738e32b400SDavid du Colombier 
1748e32b400SDavid du Colombier /*
1758e32b400SDavid du Colombier  * CpCLD Secondary (CRm) registers and opcode2 fields for op1==0. (cortex)
1768e32b400SDavid du Colombier  */
1778e32b400SDavid du Colombier #define CpCLDena	12			/* enables */
1788e32b400SDavid du Colombier #define CpCLDcyc	13			/* cycle counter */
1798e32b400SDavid du Colombier #define CpCLDuser	14			/* user enable */
1808e32b400SDavid du Colombier 
1818e32b400SDavid du Colombier #define CpCLDenapmnc	0
1828e32b400SDavid du Colombier #define CpCLDenacyc	1
1838e32b400SDavid du Colombier 
1848e32b400SDavid du Colombier /*
1858e32b400SDavid du Colombier  * CpCLD Secondary (CRm) registers and opcode2 fields for op1==1.
1868e32b400SDavid du Colombier  */
1878e32b400SDavid du Colombier #define CpCLDl2		0			/* l2 cache */
1888e32b400SDavid du Colombier 
1898e32b400SDavid du Colombier #define CpCLDl2aux	2			/* auxiliary control */
1908e32b400SDavid du Colombier 
1918e32b400SDavid du Colombier /*
1928e32b400SDavid du Colombier  * l2 cache aux. control
1938e32b400SDavid du Colombier  */
1948e32b400SDavid du Colombier #define CpCl2ecc	(1<<28)			/* use ecc, not parity */
1958e32b400SDavid du Colombier #define CpCl2noldforw	(1<<27)			/* no ld forwarding */
1968e32b400SDavid du Colombier #define CpCl2nowrcomb	(1<<25)			/* no write combining */
1978e32b400SDavid du Colombier #define CpCl2nowralldel	(1<<24)			/* no write allocate delay */
1988e32b400SDavid du Colombier #define CpCl2nowrallcomb (1<<23)		/* no write allocate combine */
1998e32b400SDavid du Colombier #define CpCl2nowralloc	(1<<22)			/* no write allocate */
2008e32b400SDavid du Colombier #define CpCl2eccparity	(1<<21)			/* enable ecc or parity */
2018e32b400SDavid du Colombier #define CpCl2inner	(1<<16)			/* inner cacheability */
2028e32b400SDavid du Colombier /* other bits are tag ram & data ram latencies */
2038e32b400SDavid du Colombier 
2048e32b400SDavid du Colombier /*
2058e32b400SDavid du Colombier  * CpTLD Secondary (CRm) registers and opcode2 fields.
2068e32b400SDavid du Colombier  */
2078e32b400SDavid du Colombier #define CpTLDlock	0			/* TLB lockdown registers */
2088e32b400SDavid du Colombier #define CpTLDpreload	1			/* TLB preload */
2098e32b400SDavid du Colombier 
2108e32b400SDavid du Colombier #define CpTLDi		0			/* TLB instr. lockdown reg. */
2118e32b400SDavid du Colombier #define CpTLDd		1			/* " data " " */
2128e32b400SDavid du Colombier 
2138e32b400SDavid du Colombier /*
2148e32b400SDavid du Colombier  * CpVECS Secondary (CRm) registers and opcode2 fields.
2158e32b400SDavid du Colombier  */
2168e32b400SDavid du Colombier #define CpVECSbase	0
2178e32b400SDavid du Colombier 
2188e32b400SDavid du Colombier #define CpVECSnorm	0			/* (non-)secure base addr */
2198e32b400SDavid du Colombier #define CpVECSmon	1			/* secure monitor base addr */
2208e32b400SDavid du Colombier 
2218e32b400SDavid du Colombier /*
2228e32b400SDavid du Colombier  * MMU page table entries.
2238e32b400SDavid du Colombier  * Mbz (0x10) bit is implementation-defined and must be 0 on the cortex.
2248e32b400SDavid du Colombier  */
2258e32b400SDavid du Colombier #define Mbz		(0<<4)
2268e32b400SDavid du Colombier #define Fault		0x00000000		/* L[12] pte: unmapped */
2278e32b400SDavid du Colombier 
2288e32b400SDavid du Colombier #define Coarse		(Mbz|1)			/* L1 */
2298e32b400SDavid du Colombier #define Section		(Mbz|2)			/* L1 1MB */
2308e32b400SDavid du Colombier #define Fine		(Mbz|3)			/* L1 */
2318e32b400SDavid du Colombier 
2328e32b400SDavid du Colombier #define Large		0x00000001		/* L2 64KB */
2338e32b400SDavid du Colombier #define Small		0x00000002		/* L2 4KB */
2348e32b400SDavid du Colombier #define Tiny		0x00000003		/* L2 1KB: not in v7 */
2358e32b400SDavid du Colombier #define Buffered	0x00000004		/* L[12]: write-back not -thru */
2368e32b400SDavid du Colombier #define Cached		0x00000008		/* L[12] */
2378e32b400SDavid du Colombier #define Dom0		0
2388e32b400SDavid du Colombier 
2398e32b400SDavid du Colombier #define Noaccess	0			/* AP, DAC */
2408e32b400SDavid du Colombier #define Krw		1			/* AP */
2418e32b400SDavid du Colombier /* armv7 deprecates AP[2] == 1 & AP[1:0] == 2 (Uro), prefers 3 (new in v7) */
2428e32b400SDavid du Colombier #define Uro		2			/* AP */
2438e32b400SDavid du Colombier #define Urw		3			/* AP */
2448e32b400SDavid du Colombier #define Client		1			/* DAC */
2458e32b400SDavid du Colombier #define Manager		3			/* DAC */
2468e32b400SDavid du Colombier 
2478e32b400SDavid du Colombier #define AP(n, v)	F((v), ((n)*2)+4, 2)
2488e32b400SDavid du Colombier #define L1AP(ap)	(AP(3, (ap)))
2498e32b400SDavid du Colombier #define L2AP(ap)	(AP(0, (ap)))		/* armv7 */
2508e32b400SDavid du Colombier #define DAC(n, v)	F((v), (n)*2, 2)
2518e32b400SDavid du Colombier 
2528e32b400SDavid du Colombier #define HVECTORS	0xffff0000
253