cpu.h 15.3 KB
Newer Older
L
Linus Torvalds 已提交
1 2
/*
 * cpu.h: Values of the PRId register used to match up
R
Ralf Baechle 已提交
3
 *	  various MIPS cpu types.
L
Linus Torvalds 已提交
4
 *
5
 * Copyright (C) 1996 David S. Miller (davem@davemloft.net)
6
 * Copyright (C) 2004, 2013  Maciej W. Rozycki
L
Linus Torvalds 已提交
7 8 9 10
 */
#ifndef _ASM_CPU_H
#define _ASM_CPU_H

11 12 13
/*
   As of the MIPS32 and MIPS64 specs from MTI, the PRId register (CP0
   register 15, select 0) is defined in this (backwards compatible) way:
L
Linus Torvalds 已提交
14 15

  +----------------+----------------+----------------+----------------+
R
Ralf Baechle 已提交
16
  | Company Options| Company ID	    | Processor ID   | Revision	      |
L
Linus Torvalds 已提交
17
  +----------------+----------------+----------------+----------------+
R
Ralf Baechle 已提交
18
   31		 24 23		  16 15		    8 7
L
Linus Torvalds 已提交
19 20 21 22 23 24

   I don't have docs for all the previous processors, but my impression is
   that bits 16-23 have been 0 for all MIPS processors before the MIPS32/64
   spec.
*/

25 26 27 28 29 30 31 32
#define PRID_OPT_MASK		0xff000000

/*
 * Assigned Company values for bits 23:16 of the PRId register.
 */

#define PRID_COMP_MASK		0xff0000

R
Ralf Baechle 已提交
33 34 35 36 37 38
#define PRID_COMP_LEGACY	0x000000
#define PRID_COMP_MIPS		0x010000
#define PRID_COMP_BROADCOM	0x020000
#define PRID_COMP_ALCHEMY	0x030000
#define PRID_COMP_SIBYTE	0x040000
#define PRID_COMP_SANDCRAFT	0x050000
R
Ralf Baechle 已提交
39
#define PRID_COMP_NXP		0x060000
R
Ralf Baechle 已提交
40 41 42
#define PRID_COMP_TOSHIBA	0x070000
#define PRID_COMP_LSI		0x080000
#define PRID_COMP_LEXRA		0x0b0000
43
#define PRID_COMP_NETLOGIC	0x0c0000
44
#define PRID_COMP_CAVIUM	0x0d0000
45
#define PRID_COMP_LOONGSON	0x140000
46 47 48
#define PRID_COMP_INGENIC_D0	0xd00000	/* JZ4740, JZ4750 */
#define PRID_COMP_INGENIC_D1	0xd10000	/* JZ4770, JZ4775 */
#define PRID_COMP_INGENIC_E1	0xe10000	/* JZ4780 */
L
Linus Torvalds 已提交
49 50

/*
51 52 53
 * Assigned Processor ID (implementation) values for bits 15:8 of the PRId
 * register.  In order to detect a certain CPU type exactly eventually
 * additional registers may need to be examined.
L
Linus Torvalds 已提交
54
 */
55 56 57 58 59 60 61

#define PRID_IMP_MASK		0xff00

/*
 * These are valid when 23:16 == PRID_COMP_LEGACY
 */

L
Linus Torvalds 已提交
62 63 64 65 66 67 68 69 70 71 72
#define PRID_IMP_R2000		0x0100
#define PRID_IMP_AU1_REV1	0x0100
#define PRID_IMP_AU1_REV2	0x0200
#define PRID_IMP_R3000		0x0200		/* Same as R2000A  */
#define PRID_IMP_R6000		0x0300		/* Same as R3000A  */
#define PRID_IMP_R4000		0x0400
#define PRID_IMP_R6000A		0x0600
#define PRID_IMP_R10000		0x0900
#define PRID_IMP_R4300		0x0b00
#define PRID_IMP_VR41XX		0x0c00
#define PRID_IMP_R12000		0x0e00
J
Joshua Kinard 已提交
73
#define PRID_IMP_R14000		0x0f00		/* R14K && R16K */
L
Linus Torvalds 已提交
74
#define PRID_IMP_R8000		0x1000
75
#define PRID_IMP_PR4450		0x1200
L
Linus Torvalds 已提交
76 77 78 79 80 81 82 83 84 85 86 87
#define PRID_IMP_R4600		0x2000
#define PRID_IMP_R4700		0x2100
#define PRID_IMP_TX39		0x2200
#define PRID_IMP_R4640		0x2200
#define PRID_IMP_R4650		0x2200		/* Same as R4640 */
#define PRID_IMP_R5000		0x2300
#define PRID_IMP_TX49		0x2d00
#define PRID_IMP_SONIC		0x2400
#define PRID_IMP_MAGIC		0x2500
#define PRID_IMP_RM7000		0x2700
#define PRID_IMP_NEVADA		0x2800		/* RM5260 ??? */
#define PRID_IMP_RM9000		0x3400
88
#define PRID_IMP_LOONGSON_32	0x4200  /* Loongson-1 */
L
Linus Torvalds 已提交
89 90
#define PRID_IMP_R5432		0x5400
#define PRID_IMP_R5500		0x5500
91
#define PRID_IMP_LOONGSON_64	0x6300  /* Loongson-2/3 */
92 93 94 95 96 97 98

#define PRID_IMP_UNKNOWN	0xff00

/*
 * These are the PRID's for when 23:16 == PRID_COMP_MIPS
 */

99
#define PRID_IMP_QEMU_GENERIC	0x0000
L
Linus Torvalds 已提交
100 101 102 103 104 105 106 107 108 109 110
#define PRID_IMP_4KC		0x8000
#define PRID_IMP_5KC		0x8100
#define PRID_IMP_20KC		0x8200
#define PRID_IMP_4KEC		0x8400
#define PRID_IMP_4KSC		0x8600
#define PRID_IMP_25KF		0x8800
#define PRID_IMP_5KE		0x8900
#define PRID_IMP_4KECR2		0x9000
#define PRID_IMP_4KEMPR2	0x9100
#define PRID_IMP_4KSD		0x9200
#define PRID_IMP_24K		0x9300
R
Ralf Baechle 已提交
111
#define PRID_IMP_34K		0x9500
112
#define PRID_IMP_24KE		0x9600
113
#define PRID_IMP_74K		0x9700
114
#define PRID_IMP_1004K		0x9900
115
#define PRID_IMP_1074K		0x9a00
116
#define PRID_IMP_M14KC		0x9c00
117
#define PRID_IMP_M14KEC		0x9e00
118 119
#define PRID_IMP_INTERAPTIV_UP	0xa000
#define PRID_IMP_INTERAPTIV_MP	0xa100
120 121
#define PRID_IMP_PROAPTIV_UP	0xa200
#define PRID_IMP_PROAPTIV_MP	0xa300
122
#define PRID_IMP_P6600		0xa400
123
#define PRID_IMP_M5150		0xa700
124
#define PRID_IMP_P5600		0xa800
125
#define PRID_IMP_I6400		0xa900
126
#define PRID_IMP_M6250		0xab00
P
Paul Burton 已提交
127
#define PRID_IMP_I6500		0xb000
L
Linus Torvalds 已提交
128 129 130 131 132

/*
 * These are the PRID's for when 23:16 == PRID_COMP_SIBYTE
 */

R
Ralf Baechle 已提交
133 134
#define PRID_IMP_SB1		0x0100
#define PRID_IMP_SB1A		0x1100
L
Linus Torvalds 已提交
135 136 137 138 139

/*
 * These are the PRID's for when 23:16 == PRID_COMP_SANDCRAFT
 */

R
Ralf Baechle 已提交
140
#define PRID_IMP_SR71000	0x0400
L
Linus Torvalds 已提交
141

142 143 144 145
/*
 * These are the PRID's for when 23:16 == PRID_COMP_BROADCOM
 */

146 147
#define PRID_IMP_BMIPS32_REV4	0x4000
#define PRID_IMP_BMIPS32_REV8	0x8000
148 149 150 151 152
#define PRID_IMP_BMIPS3300	0x9000
#define PRID_IMP_BMIPS3300_ALT	0x9100
#define PRID_IMP_BMIPS3300_BUG	0x0000
#define PRID_IMP_BMIPS43XX	0xa000
#define PRID_IMP_BMIPS5000	0x5a00
153
#define PRID_IMP_BMIPS5200	0x5b00
154 155 156

#define PRID_REV_BMIPS4380_LO	0x0040
#define PRID_REV_BMIPS4380_HI	0x006f
157

158 159 160 161 162 163 164 165 166 167 168
/*
 * These are the PRID's for when 23:16 == PRID_COMP_CAVIUM
 */

#define PRID_IMP_CAVIUM_CN38XX 0x0000
#define PRID_IMP_CAVIUM_CN31XX 0x0100
#define PRID_IMP_CAVIUM_CN30XX 0x0200
#define PRID_IMP_CAVIUM_CN58XX 0x0300
#define PRID_IMP_CAVIUM_CN56XX 0x0400
#define PRID_IMP_CAVIUM_CN50XX 0x0600
#define PRID_IMP_CAVIUM_CN52XX 0x0700
169
#define PRID_IMP_CAVIUM_CN63XX 0x9000
170 171 172
#define PRID_IMP_CAVIUM_CN68XX 0x9100
#define PRID_IMP_CAVIUM_CN66XX 0x9200
#define PRID_IMP_CAVIUM_CN61XX 0x9300
173 174 175
#define PRID_IMP_CAVIUM_CNF71XX 0x9400
#define PRID_IMP_CAVIUM_CN78XX 0x9500
#define PRID_IMP_CAVIUM_CN70XX 0x9600
176 177
#define PRID_IMP_CAVIUM_CN73XX 0x9700
#define PRID_IMP_CAVIUM_CNF75XX 0x9800
178

179
/*
180
 * These are the PRID's for when 23:16 == PRID_COMP_INGENIC_*
181 182
 */

R
Ralf Baechle 已提交
183
#define PRID_IMP_JZRISC	       0x0200
184

185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208
/*
 * These are the PRID's for when 23:16 == PRID_COMP_NETLOGIC
 */
#define PRID_IMP_NETLOGIC_XLR732	0x0000
#define PRID_IMP_NETLOGIC_XLR716	0x0200
#define PRID_IMP_NETLOGIC_XLR532	0x0900
#define PRID_IMP_NETLOGIC_XLR308	0x0600
#define PRID_IMP_NETLOGIC_XLR532C	0x0800
#define PRID_IMP_NETLOGIC_XLR516C	0x0a00
#define PRID_IMP_NETLOGIC_XLR508C	0x0b00
#define PRID_IMP_NETLOGIC_XLR308C	0x0f00
#define PRID_IMP_NETLOGIC_XLS608	0x8000
#define PRID_IMP_NETLOGIC_XLS408	0x8800
#define PRID_IMP_NETLOGIC_XLS404	0x8c00
#define PRID_IMP_NETLOGIC_XLS208	0x8e00
#define PRID_IMP_NETLOGIC_XLS204	0x8f00
#define PRID_IMP_NETLOGIC_XLS108	0xce00
#define PRID_IMP_NETLOGIC_XLS104	0xcf00
#define PRID_IMP_NETLOGIC_XLS616B	0x4000
#define PRID_IMP_NETLOGIC_XLS608B	0x4a00
#define PRID_IMP_NETLOGIC_XLS416B	0x4400
#define PRID_IMP_NETLOGIC_XLS412B	0x4c00
#define PRID_IMP_NETLOGIC_XLS408B	0x4e00
#define PRID_IMP_NETLOGIC_XLS404B	0x4f00
M
Manuel Lauss 已提交
209
#define PRID_IMP_NETLOGIC_AU13XX	0x8000
210

211 212
#define PRID_IMP_NETLOGIC_XLP8XX	0x1000
#define PRID_IMP_NETLOGIC_XLP3XX	0x1100
213
#define PRID_IMP_NETLOGIC_XLP2XX	0x1200
214
#define PRID_IMP_NETLOGIC_XLP9XX	0x1500
215
#define PRID_IMP_NETLOGIC_XLP5XX	0x1300
216

L
Linus Torvalds 已提交
217
/*
218
 * Particular Revision values for bits 7:0 of the PRId register.
L
Linus Torvalds 已提交
219 220
 */

M
Marc St-Jean 已提交
221
#define PRID_REV_MASK		0x00ff
L
Linus Torvalds 已提交
222

223 224 225 226
/*
 * Definitions for 7:0 on legacy processors
 */

L
Linus Torvalds 已提交
227 228 229 230 231 232
#define PRID_REV_TX4927		0x0022
#define PRID_REV_TX4937		0x0030
#define PRID_REV_R4400		0x0040
#define PRID_REV_R3000A		0x0030
#define PRID_REV_R3000		0x0020
#define PRID_REV_R2000A		0x0010
R
Ralf Baechle 已提交
233 234 235
#define PRID_REV_TX3912		0x0010
#define PRID_REV_TX3922		0x0030
#define PRID_REV_TX3927		0x0040
L
Linus Torvalds 已提交
236 237 238 239 240 241
#define PRID_REV_VR4111		0x0050
#define PRID_REV_VR4181		0x0050	/* Same as VR4111 */
#define PRID_REV_VR4121		0x0060
#define PRID_REV_VR4122		0x0070
#define PRID_REV_VR4181A	0x0070	/* Same as VR4122 */
#define PRID_REV_VR4130		0x0080
M
Marc St-Jean 已提交
242
#define PRID_REV_34K_V1_0_2	0x0022
243
#define PRID_REV_LOONGSON1B	0x0020
Y
Yang Ling 已提交
244
#define PRID_REV_LOONGSON1C	0x0020	/* Same as Loongson-1B */
245 246
#define PRID_REV_LOONGSON2E	0x0002
#define PRID_REV_LOONGSON2F	0x0003
247
#define PRID_REV_LOONGSON3A_R1	0x0005
H
Huacai Chen 已提交
248 249
#define PRID_REV_LOONGSON3B_R1	0x0006
#define PRID_REV_LOONGSON3B_R2	0x0007
250
#define PRID_REV_LOONGSON3A_R2	0x0008
251
#define PRID_REV_LOONGSON3A_R3	0x0009
L
Linus Torvalds 已提交
252

253 254 255 256 257 258 259 260 261 262 263
/*
 * Older processors used to encode processor version and revision in two
 * 4-bit bitfields, the 4K seems to simply count up and even newer MTI cores
 * have switched to use the 8-bits as 3:3:2 bitfield with the last field as
 * the patch number.  *ARGH*
 */
#define PRID_REV_ENCODE_44(ver, rev)					\
	((ver) << 4 | (rev))
#define PRID_REV_ENCODE_332(ver, rev, patch)				\
	((ver) << 5 | (rev) << 2 | (patch))

L
Linus Torvalds 已提交
264 265 266 267
/*
 * FPU implementation/revision register (CP1 control register 0).
 *
 * +---------------------------------+----------------+----------------+
R
Ralf Baechle 已提交
268
 * | 0				     | Implementation | Revision       |
L
Linus Torvalds 已提交
269
 * +---------------------------------+----------------+----------------+
R
Ralf Baechle 已提交
270
 *  31				   16 15	     8 7	      0
L
Linus Torvalds 已提交
271 272
 */

273 274
#define FPIR_IMP_MASK		0xff00

L
Linus Torvalds 已提交
275 276
#define FPIR_IMP_NONE		0x0000

277 278
#if !defined(__ASSEMBLY__)

279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297
enum cpu_type_enum {
	CPU_UNKNOWN,

	/*
	 * R2000 class processors
	 */
	CPU_R2000, CPU_R3000, CPU_R3000A, CPU_R3041, CPU_R3051, CPU_R3052,
	CPU_R3081, CPU_R3081E,

	/*
	 * R6000 class processors
	 */
	CPU_R6000, CPU_R6000A,

	/*
	 * R4000 class processors
	 */
	CPU_R4000PC, CPU_R4000SC, CPU_R4000MC, CPU_R4200, CPU_R4300, CPU_R4310,
	CPU_R4400PC, CPU_R4400SC, CPU_R4400MC, CPU_R4600, CPU_R4640, CPU_R4650,
R
Ralf Baechle 已提交
298
	CPU_R4700, CPU_R5000, CPU_R5500, CPU_NEVADA, CPU_R5432, CPU_R10000,
J
Joshua Kinard 已提交
299 300
	CPU_R12000, CPU_R14000, CPU_R16000, CPU_VR41XX, CPU_VR4111, CPU_VR4121,
	CPU_VR4122, CPU_VR4131, CPU_VR4133, CPU_VR4181, CPU_VR4181A, CPU_RM7000,
301
	CPU_SR71000, CPU_TX49XX,
302 303 304 305 306 307 308 309 310 311 312 313 314 315

	/*
	 * R8000 class processors
	 */
	CPU_R8000,

	/*
	 * TX3900 class processors
	 */
	CPU_TX3912, CPU_TX3922, CPU_TX3927,

	/*
	 * MIPS32 class processors
	 */
316
	CPU_4KC, CPU_4KEC, CPU_4KSC, CPU_24K, CPU_34K, CPU_1004K, CPU_74K,
317
	CPU_ALCHEMY, CPU_PR4450, CPU_BMIPS32, CPU_BMIPS3300, CPU_BMIPS4350,
318
	CPU_BMIPS4380, CPU_BMIPS5000, CPU_JZRISC, CPU_LOONGSON1, CPU_M14KC,
319
	CPU_M14KEC, CPU_INTERAPTIV, CPU_P5600, CPU_PROAPTIV, CPU_1074K,
320
	CPU_M5150, CPU_I6400, CPU_P6600, CPU_M6250,
321 322 323 324

	/*
	 * MIPS64 class processors
	 */
L
Leonid Yegoshin 已提交
325
	CPU_5KC, CPU_5KE, CPU_20KC, CPU_25KF, CPU_SB1, CPU_SB1A, CPU_LOONGSON2,
326
	CPU_LOONGSON3, CPU_CAVIUM_OCTEON, CPU_CAVIUM_OCTEON_PLUS,
P
Paul Burton 已提交
327
	CPU_CAVIUM_OCTEON2, CPU_CAVIUM_OCTEON3, CPU_XLR, CPU_XLP, CPU_I6500,
328

329 330
	CPU_QEMU_GENERIC,

331 332 333
	CPU_LAST
};

334
#endif /* !__ASSEMBLY */
L
Linus Torvalds 已提交
335 336 337 338 339

/*
 * ISA Level encodings
 *
 */
340 341 342 343 344 345 346 347
#define MIPS_CPU_ISA_II		0x00000001
#define MIPS_CPU_ISA_III	0x00000002
#define MIPS_CPU_ISA_IV		0x00000004
#define MIPS_CPU_ISA_V		0x00000008
#define MIPS_CPU_ISA_M32R1	0x00000010
#define MIPS_CPU_ISA_M32R2	0x00000020
#define MIPS_CPU_ISA_M64R1	0x00000040
#define MIPS_CPU_ISA_M64R2	0x00000080
348 349
#define MIPS_CPU_ISA_M32R6	0x00000100
#define MIPS_CPU_ISA_M64R6	0x00000200
350 351

#define MIPS_CPU_ISA_32BIT (MIPS_CPU_ISA_II | MIPS_CPU_ISA_M32R1 | \
352
	MIPS_CPU_ISA_M32R2 | MIPS_CPU_ISA_M32R6)
353
#define MIPS_CPU_ISA_64BIT (MIPS_CPU_ISA_III | MIPS_CPU_ISA_IV | \
354 355
	MIPS_CPU_ISA_V | MIPS_CPU_ISA_M64R1 | MIPS_CPU_ISA_M64R2 | \
	MIPS_CPU_ISA_M64R6)
L
Linus Torvalds 已提交
356

357 358 359 360 361 362 363
/*
 * Private version of BIT_ULL() to escape include file recursion hell.
 * We soon will have to switch to another mechanism that will work with
 * more than 64 bits anyway.
 */
#define MBIT_ULL(bit)		(1ULL << (bit))

L
Linus Torvalds 已提交
364 365 366
/*
 * CPU Option encodings
 */
367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399
#define MIPS_CPU_TLB		MBIT_ULL( 0)	/* CPU has TLB */
#define MIPS_CPU_4KEX		MBIT_ULL( 1)	/* "R4K" exception model */
#define MIPS_CPU_3K_CACHE	MBIT_ULL( 2)	/* R3000-style caches */
#define MIPS_CPU_4K_CACHE	MBIT_ULL( 3)	/* R4000-style caches */
#define MIPS_CPU_TX39_CACHE	MBIT_ULL( 4)	/* TX3900-style caches */
#define MIPS_CPU_FPU		MBIT_ULL( 5)	/* CPU has FPU */
#define MIPS_CPU_32FPR		MBIT_ULL( 6)	/* 32 dbl. prec. FP registers */
#define MIPS_CPU_COUNTER	MBIT_ULL( 7)	/* Cycle count/compare */
#define MIPS_CPU_WATCH		MBIT_ULL( 8)	/* watchpoint registers */
#define MIPS_CPU_DIVEC		MBIT_ULL( 9)	/* dedicated interrupt vector */
#define MIPS_CPU_VCE		MBIT_ULL(10)	/* virt. coherence conflict possible */
#define MIPS_CPU_CACHE_CDEX_P	MBIT_ULL(11)	/* Create_Dirty_Exclusive CACHE op */
#define MIPS_CPU_CACHE_CDEX_S	MBIT_ULL(12)	/* ... same for seconary cache ... */
#define MIPS_CPU_MCHECK		MBIT_ULL(13)	/* Machine check exception */
#define MIPS_CPU_EJTAG		MBIT_ULL(14)	/* EJTAG exception */
#define MIPS_CPU_NOFPUEX	MBIT_ULL(15)	/* no FPU exception */
#define MIPS_CPU_LLSC		MBIT_ULL(16)	/* CPU has ll/sc instructions */
#define MIPS_CPU_INCLUSIVE_CACHES	MBIT_ULL(17)	/* P-cache subset enforced */
#define MIPS_CPU_PREFETCH	MBIT_ULL(18)	/* CPU has usable prefetch */
#define MIPS_CPU_VINT		MBIT_ULL(19)	/* CPU supports MIPSR2 vectored interrupts */
#define MIPS_CPU_VEIC		MBIT_ULL(20)	/* CPU supports MIPSR2 external interrupt controller mode */
#define MIPS_CPU_ULRI		MBIT_ULL(21)	/* CPU has ULRI feature */
#define MIPS_CPU_PCI		MBIT_ULL(22)	/* CPU has Perf Ctr Int indicator */
#define MIPS_CPU_RIXI		MBIT_ULL(23)	/* CPU has TLB Read/eXec Inhibit */
#define MIPS_CPU_MICROMIPS	MBIT_ULL(24)	/* CPU has microMIPS capability */
#define MIPS_CPU_TLBINV		MBIT_ULL(25)	/* CPU supports TLBINV/F */
#define MIPS_CPU_SEGMENTS	MBIT_ULL(26)	/* CPU supports Segmentation Control registers */
#define MIPS_CPU_EVA		MBIT_ULL(27)	/* CPU supports Enhanced Virtual Addressing */
#define MIPS_CPU_HTW		MBIT_ULL(28)	/* CPU support Hardware Page Table Walker */
#define MIPS_CPU_RIXIEX		MBIT_ULL(29)	/* CPU has unique exception codes for {Read, Execute}-Inhibit exceptions */
#define MIPS_CPU_MAAR		MBIT_ULL(30)	/* MAAR(I) registers are present */
#define MIPS_CPU_FRE		MBIT_ULL(31)	/* FRE & UFE bits implemented */
#define MIPS_CPU_RW_LLB		MBIT_ULL(32)	/* LLADDR/LLB writes are allowed */
400
#define MIPS_CPU_LPA		MBIT_ULL(33)	/* CPU supports Large Physical Addressing */
401 402 403 404 405 406 407
#define MIPS_CPU_CDMM		MBIT_ULL(34)	/* CPU has Common Device Memory Map */
#define MIPS_CPU_BP_GHIST	MBIT_ULL(35)	/* R12K+ Branch Prediction Global History */
#define MIPS_CPU_SP		MBIT_ULL(36)	/* Small (1KB) page support */
#define MIPS_CPU_FTLB		MBIT_ULL(37)	/* CPU has Fixed-page-size TLB */
#define MIPS_CPU_NAN_LEGACY	MBIT_ULL(38)	/* Legacy NaN implemented */
#define MIPS_CPU_NAN_2008	MBIT_ULL(39)	/* 2008 NaN implemented */
#define MIPS_CPU_VP		MBIT_ULL(40)	/* MIPSr6 Virtual Processors (multi-threading) */
408
#define MIPS_CPU_LDPTE		MBIT_ULL(41)	/* CPU has ldpte/lddir instructions */
409
#define MIPS_CPU_MVH		MBIT_ULL(42)	/* CPU supports MFHC0/MTHC0 */
410
#define MIPS_CPU_EBASE_WG	MBIT_ULL(43)	/* CPU has EBase.WG */
411 412
#define MIPS_CPU_BADINSTR	MBIT_ULL(44)	/* CPU has BadInstr register */
#define MIPS_CPU_BADINSTRP	MBIT_ULL(45)	/* CPU has BadInstrP register */
413
#define MIPS_CPU_CTXTC		MBIT_ULL(46)	/* CPU has [X]ConfigContext registers */
J
James Hogan 已提交
414
#define MIPS_CPU_PERF		MBIT_ULL(47)	/* CPU has MIPS performance counters */
415 416 417 418 419
#define MIPS_CPU_GUESTCTL0EXT	MBIT_ULL(48)	/* CPU has VZ GuestCtl0Ext register */
#define MIPS_CPU_GUESTCTL1	MBIT_ULL(49)	/* CPU has VZ GuestCtl1 register */
#define MIPS_CPU_GUESTCTL2	MBIT_ULL(50)	/* CPU has VZ GuestCtl2 register */
#define MIPS_CPU_GUESTID	MBIT_ULL(51)	/* CPU uses VZ ASE GuestID feature */
#define MIPS_CPU_DRG		MBIT_ULL(52)	/* CPU has VZ Direct Root to Guest (DRG) */
J
James Hogan 已提交
420
#define MIPS_CPU_UFR		MBIT_ULL(53)	/* CPU supports User mode FR switching */
421 422 423 424
#define MIPS_CPU_SHARED_FTLB_RAM \
				MBIT_ULL(54)	/* CPU shares FTLB RAM with another */
#define MIPS_CPU_SHARED_FTLB_ENTRIES \
				MBIT_ULL(55)	/* CPU shares FTLB entries with another */
L
Linus Torvalds 已提交
425

426 427 428 429 430 431 432
/*
 * CPU ASE encodings
 */
#define MIPS_ASE_MIPS16		0x00000001 /* code compression */
#define MIPS_ASE_MDMX		0x00000002 /* MIPS digital media extension */
#define MIPS_ASE_MIPS3D		0x00000004 /* MIPS-3D */
#define MIPS_ASE_SMARTMIPS	0x00000008 /* SmartMIPS */
433
#define MIPS_ASE_DSP		0x00000010 /* Signal Processing ASE */
434
#define MIPS_ASE_MIPSMT		0x00000020 /* CPU supports MIPS MT */
435
#define MIPS_ASE_DSP2P		0x00000040 /* Signal Processing ASE Rev 2 */
436
#define MIPS_ASE_VZ		0x00000080 /* Virtualization ASE */
P
Paul Burton 已提交
437
#define MIPS_ASE_MSA		0x00000100 /* MIPS SIMD Architecture */
438
#define MIPS_ASE_DSP3		0x00000200 /* Signal Processing ASE Rev 3*/
439
#define MIPS_ASE_MIPS16E2	0x00000400 /* MIPS16e2 */
440

L
Linus Torvalds 已提交
441
#endif /* _ASM_CPU_H */