arcregs.h 9.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11
/*
 * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

#ifndef _ASM_ARC_ARCREGS_H
#define _ASM_ARC_ARCREGS_H

V
Vineet Gupta 已提交
12
/* Build Configuration Registers */
13 14
#define ARC_REG_AUX_DCCM	0x18	/* DCCM Base Addr ARCv2 */
#define ARC_REG_DCCM_BASE_BUILD	0x61	/* DCCM Base Addr ARCompact */
15
#define ARC_REG_CRC_BCR		0x62
V
Vineet Gupta 已提交
16
#define ARC_REG_VECBASE_BCR	0x68
17
#define ARC_REG_PERIBASE_BCR	0x69
18 19
#define ARC_REG_FP_BCR		0x6B	/* ARCompact: Single-Precision FPU */
#define ARC_REG_DPFP_BCR	0x6C	/* ARCompact: Dbl Precision FPU */
20
#define ARC_REG_FP_V2_BCR	0xc8	/* ARCv2 FPU */
21
#define ARC_REG_SLC_BCR		0xce
22
#define ARC_REG_DCCM_BUILD	0x74	/* DCCM size (common) */
23
#define ARC_REG_TIMERS_BCR	0x75
24
#define ARC_REG_AP_BCR		0x76
25
#define ARC_REG_ICCM_BUILD	0x78	/* ICCM size (common) */
26 27 28 29 30 31 32 33
#define ARC_REG_XY_MEM_BCR	0x79
#define ARC_REG_MAC_BCR		0x7a
#define ARC_REG_MUL_BCR		0x7b
#define ARC_REG_SWAP_BCR	0x7c
#define ARC_REG_NORM_BCR	0x7d
#define ARC_REG_MIXMAX_BCR	0x7e
#define ARC_REG_BARREL_BCR	0x7f
#define ARC_REG_D_UNCACH_BCR	0x6A
34 35
#define ARC_REG_BPU_BCR		0xc0
#define ARC_REG_ISA_CFG_BCR	0xc1
V
Vineet Gupta 已提交
36
#define ARC_REG_RTT_BCR		0xF2
37
#define ARC_REG_IRQ_BCR		0xF3
38
#define ARC_REG_SMART_BCR	0xFF
39
#define ARC_REG_CLUSTER_BCR	0xcf
40
#define ARC_REG_AUX_ICCM	0x208	/* ICCM Base Addr (ARCv2) */
V
Vineet Gupta 已提交
41

42 43 44 45 46 47 48 49 50 51 52 53
/* status32 Bits Positions */
#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_AE_MASK		(1<<STATUS_AE_BIT)
#define STATUS_DE_MASK		(1<<STATUS_DE_BIT)
#define STATUS_U_MASK		(1<<STATUS_U_BIT)
#define STATUS_L_MASK		(1<<STATUS_L_BIT)

V
Vineet Gupta 已提交
54 55 56 57 58 59
/*
 * ECR: Exception Cause Reg bits-n-pieces
 * [23:16] = Exception Vector
 * [15: 8] = Exception Cause Code
 * [ 7: 0] = Exception Parameters (for certain types only)
 */
60
#ifdef CONFIG_ISA_ARCOMPACT
61
#define ECR_V_MEM_ERR			0x01
V
Vineet Gupta 已提交
62 63 64 65 66
#define ECR_V_INSN_ERR			0x02
#define ECR_V_MACH_CHK			0x20
#define ECR_V_ITLB_MISS			0x21
#define ECR_V_DTLB_MISS			0x22
#define ECR_V_PROTV			0x23
67
#define ECR_V_TRAP			0x25
68 69 70 71 72 73 74 75 76
#else
#define ECR_V_MEM_ERR			0x01
#define ECR_V_INSN_ERR			0x02
#define ECR_V_MACH_CHK			0x03
#define ECR_V_ITLB_MISS			0x04
#define ECR_V_DTLB_MISS			0x05
#define ECR_V_PROTV			0x06
#define ECR_V_TRAP			0x09
#endif
V
Vineet Gupta 已提交
77

78 79
/* DTLB Miss and Protection Violation Cause Codes */

V
Vineet Gupta 已提交
80 81 82 83 84 85
#define ECR_C_PROTV_INST_FETCH		0x00
#define ECR_C_PROTV_LOAD		0x01
#define ECR_C_PROTV_STORE		0x02
#define ECR_C_PROTV_XCHG		0x03
#define ECR_C_PROTV_MISALIG_DATA	0x04

86 87 88 89 90
#define ECR_C_BIT_PROTV_MISALIG_DATA	10

/* Machine Check Cause Code Values */
#define ECR_C_MCHK_DUP_TLB		0x01

V
Vineet Gupta 已提交
91 92 93 94
/* DTLB Miss Exception Cause Code Values */
#define ECR_C_BIT_DTLB_LD_MISS		8
#define ECR_C_BIT_DTLB_ST_MISS		9

95 96 97
/* Auxiliary registers */
#define AUX_IDENTITY		4
#define AUX_INTR_VEC_BASE	0x25
98
#define AUX_VOL			0x5e
V
Vineet Gupta 已提交
99

100 101 102 103 104 105 106 107 108 109 110
/*
 * Floating Pt Registers
 * Status regs are read-only (build-time) so need not be saved/restored
 */
#define ARC_AUX_FP_STAT         0x300
#define ARC_AUX_DPFP_1L         0x301
#define ARC_AUX_DPFP_1H         0x302
#define ARC_AUX_DPFP_2L         0x303
#define ARC_AUX_DPFP_2H         0x304
#define ARC_AUX_DPFP_STAT       0x305

111 112 113 114 115 116 117 118 119 120 121 122 123 124
#ifndef __ASSEMBLY__

/*
 ******************************************************************
 *      Inline ASM macros to read/write AUX Regs
 *      Essentially invocation of lr/sr insns from "C"
 */

#if 1

#define read_aux_reg(reg)	__builtin_arc_lr(reg)

/* gcc builtin sr needs reg param to be long immediate */
#define write_aux_reg(reg_immed, val)		\
125
		__builtin_arc_sr((unsigned int)(val), reg_immed)
126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173

#else

#define read_aux_reg(reg)		\
({					\
	unsigned int __ret;		\
	__asm__ __volatile__(		\
	"	lr    %0, [%1]"		\
	: "=r"(__ret)			\
	: "i"(reg));			\
	__ret;				\
})

/*
 * Aux Reg address is specified as long immediate by caller
 * e.g.
 *    write_aux_reg(0x69, some_val);
 * This generates tightest code.
 */
#define write_aux_reg(reg_imm, val)	\
({					\
	__asm__ __volatile__(		\
	"	sr   %0, [%1]	\n"	\
	:				\
	: "ir"(val), "i"(reg_imm));	\
})

/*
 * Aux Reg address is specified in a variable
 *  * e.g.
 *      reg_num = 0x69
 *      write_aux_reg2(reg_num, some_val);
 * This has to generate glue code to load the reg num from
 *  memory to a reg hence not recommended.
 */
#define write_aux_reg2(reg_in_var, val)		\
({						\
	unsigned int tmp;			\
						\
	__asm__ __volatile__(			\
	"	ld   %0, [%2]	\n\t"		\
	"	sr   %1, [%0]	\n\t"		\
	: "=&r"(tmp)				\
	: "r"(val), "memory"(&reg_in_var));	\
})

#endif

V
Vineet Gupta 已提交
174 175 176 177 178 179 180 181 182 183 184 185
#define READ_BCR(reg, into)				\
{							\
	unsigned int tmp;				\
	tmp = read_aux_reg(reg);			\
	if (sizeof(tmp) == sizeof(into)) {		\
		into = *((typeof(into) *)&tmp);		\
	} else {					\
		extern void bogus_undefined(void);	\
		bogus_undefined();			\
	}						\
}

V
Vineet Gupta 已提交
186
#define WRITE_AUX(reg, into)				\
V
Vineet Gupta 已提交
187 188 189
{							\
	unsigned int tmp;				\
	if (sizeof(tmp) == sizeof(into)) {		\
V
Vineet Gupta 已提交
190
		tmp = (*(unsigned int *)&(into));	\
V
Vineet Gupta 已提交
191 192 193 194 195 196 197
		write_aux_reg(reg, tmp);		\
	} else  {					\
		extern void bogus_undefined(void);	\
		bogus_undefined();			\
	}						\
}

198 199 200 201 202
/* Helpers */
#define TO_KB(bytes)		((bytes) >> 10)
#define TO_MB(bytes)		(TO_KB(bytes) >> 10)
#define PAGES_TO_KB(n_pages)	((n_pages) << (PAGE_SHIFT - 10))
#define PAGES_TO_MB(n_pages)	(PAGES_TO_KB(n_pages) >> 10)
V
Vineet Gupta 已提交
203

204

V
Vineet Gupta 已提交
205 206 207 208
/*
 ***************************************************************
 * Build Configuration Registers, with encoded hardware config
 */
209 210 211 212 213 214 215
struct bcr_identity {
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int chip_id:16, cpu_id:8, family:8;
#else
	unsigned int family:8, cpu_id:8, chip_id:16;
#endif
};
V
Vineet Gupta 已提交
216

217
struct bcr_isa {
218
#ifdef CONFIG_CPU_BIG_ENDIAN
219 220
	unsigned int div_rem:4, pad2:4, ldd:1, unalign:1, atomic:1, be:1,
		     pad1:11, atomic1:1, ver:8;
221
#else
222 223
	unsigned int ver:8, atomic1:1, pad1:11, be:1, atomic:1, unalign:1,
		     ldd:1, pad2:4, div_rem:4;
224 225 226
#endif
};

227
struct bcr_mpy {
228
#ifdef CONFIG_CPU_BIG_ENDIAN
229
	unsigned int pad:8, x1616:8, dsp:4, cycles:2, type:2, ver:8;
230
#else
231
	unsigned int ver:8, type:2, cycles:2, dsp:4, x1616:8, pad:8;
232 233 234 235 236 237 238 239 240 241
#endif
};

struct bcr_extn_xymem {
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int ram_org:2, num_banks:4, bank_sz:4, ver:8;
#else
	unsigned int ver:8, bank_sz:4, num_banks:4, ram_org:2;
#endif
};
242

243
struct bcr_iccm_arcompact {
244 245 246 247 248 249 250
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int base:16, pad:5, sz:3, ver:8;
#else
	unsigned int ver:8, sz:3, pad:5, base:16;
#endif
};

251
struct bcr_iccm_arcv2 {
252
#ifdef CONFIG_CPU_BIG_ENDIAN
253
	unsigned int pad:8, sz11:4, sz01:4, sz10:4, sz00:4, ver:8;
254
#else
255
	unsigned int ver:8, sz00:4, sz10:4, sz01:4, sz11:4, pad:8;
256 257 258
#endif
};

259
struct bcr_dccm_arcompact {
260 261 262 263 264 265 266
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int res:21, sz:3, ver:8;
#else
	unsigned int ver:8, sz:3, res:21;
#endif
};

267 268 269 270 271 272 273 274
struct bcr_dccm_arcv2 {
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int pad2:12, cyc:3, pad1:1, sz1:4, sz0:4, ver:8;
#else
	unsigned int ver:8, sz0:4, sz1:4, pad1:1, cyc:3, pad2:12;
#endif
};

275 276
/* ARCompact: Both SP and DP FPU BCRs have same format */
struct bcr_fp_arcompact {
277 278 279 280 281 282 283
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int fast:1, ver:8;
#else
	unsigned int ver:8, fast:1;
#endif
};

284 285 286 287 288 289 290 291
struct bcr_fp_arcv2 {
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int pad2:15, dp:1, pad1:7, sp:1, ver:8;
#else
	unsigned int ver:8, sp:1, pad1:7, dp:1, pad2:15;
#endif
};

292 293
struct bcr_timer {
#ifdef CONFIG_CPU_BIG_ENDIAN
294
	unsigned int pad2:15, rtsc:1, pad1:5, rtc:1, t1:1, t0:1, ver:8;
295
#else
296
	unsigned int ver:8, t0:1, t1:1, rtc:1, pad1:5, rtsc:1, pad2:15;
297 298 299 300 301 302 303 304 305 306 307
#endif
};

struct bcr_bpu_arcompact {
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int pad2:19, fam:1, pad:2, ent:2, ver:8;
#else
	unsigned int ver:8, ent:2, pad:2, fam:1, pad2:19;
#endif
};

308 309 310 311 312 313 314 315
struct bcr_bpu_arcv2 {
#ifdef CONFIG_CPU_BIG_ENDIAN
	unsigned int pad:6, fbe:2, tqe:2, ts:4, ft:1, rse:2, pte:3, bce:3, ver:8;
#else
	unsigned int ver:8, bce:3, pte:3, rse:2, ft:1, ts:4, tqe:2, fbe:2, pad:6;
#endif
};

316 317
struct bcr_generic {
#ifdef CONFIG_CPU_BIG_ENDIAN
318
	unsigned int info:24, ver:8;
319
#else
320
	unsigned int ver:8, info:24;
321 322 323
#endif
};

V
Vineet Gupta 已提交
324 325 326 327 328
/*
 *******************************************************************
 * Generic structures to hold build configuration used at runtime
 */

V
Vineet Gupta 已提交
329
struct cpuinfo_arc_mmu {
330
	unsigned int ver:4, pg_sz_k:8, s_pg_sz_m:8, pad:10, sasid:1, pae:1;
331
	unsigned int sets:12, ways:4, u_dtlb:8, u_itlb:8;
V
Vineet Gupta 已提交
332 333
};

V
Vineet Gupta 已提交
334
struct cpuinfo_arc_cache {
335
	unsigned int sz_k:14, line_len:8, assoc:4, ver:4, alias:1, vipt:1;
V
Vineet Gupta 已提交
336 337
};

338 339 340 341
struct cpuinfo_arc_bpu {
	unsigned int ver, full, num_cache, num_pred;
};

342 343 344 345
struct cpuinfo_arc_ccm {
	unsigned int base_addr, sz;
};

V
Vineet Gupta 已提交
346
struct cpuinfo_arc {
347
	struct cpuinfo_arc_cache icache, dcache, slc;
V
Vineet Gupta 已提交
348
	struct cpuinfo_arc_mmu mmu;
349
	struct cpuinfo_arc_bpu bpu;
350
	struct bcr_identity core;
351
	struct bcr_isa isa;
352
	const char *details;
353 354
	unsigned int vec_base;
	struct cpuinfo_arc_ccm iccm, dccm;
355 356 357 358
	struct {
		unsigned int swap:1, norm:1, minmax:1, barrel:1, crc:1, pad1:3,
			     fpu_sp:1, fpu_dp:1, pad2:6,
			     debug:1, ap:1, smart:1, rtt:1, pad3:4,
359
			     timer0:1, timer1:1, rtc:1, gfrc:1, pad4:4;
360 361
	} extn;
	struct bcr_mpy extn_mpy;
362
	struct bcr_extn_xymem extn_xymem;
V
Vineet Gupta 已提交
363 364 365 366
};

extern struct cpuinfo_arc cpuinfo_arc700[];

367 368 369 370 371 372 373 374 375 376
static inline int is_isa_arcv2(void)
{
	return IS_ENABLED(CONFIG_ISA_ARCV2);
}

static inline int is_isa_arcompact(void)
{
	return IS_ENABLED(CONFIG_ISA_ARCOMPACT);
}

377 378 379
#endif /* __ASEMBLY__ */

#endif /* _ASM_ARC_ARCREGS_H */