| 
									
										
										
										
											2016-06-29 11:05:55 +02:00
										 |  |  | #ifndef SPARC_CPU_H
 | 
					
						
							|  |  |  | #define SPARC_CPU_H
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-17 18:20:00 +01:00
										 |  |  | #include "qemu/bswap.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-15 13:49:25 +01:00
										 |  |  | #include "cpu-qom.h"
 | 
					
						
							| 
									
										
										
										
											2019-03-22 11:51:19 -07:00
										 |  |  | #include "exec/cpu-defs.h"
 | 
					
						
							| 
									
										
										
										
											2022-03-23 19:57:39 +04:00
										 |  |  | #include "qemu/cpu-float.h"
 | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-20 18:36:33 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * From Oracle SPARC Architecture 2015: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Compatibility notes: The PSO memory model described in SPARC V8 and | 
					
						
							|  |  |  |  *   SPARC V9 compatibility architecture specifications was never implemented | 
					
						
							|  |  |  |  *   in a SPARC V9 implementation and is not included in the Oracle SPARC | 
					
						
							|  |  |  |  *   Architecture specification. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   The RMO memory model described in the SPARC V9 specification was | 
					
						
							|  |  |  |  *   implemented in some non-Sun SPARC V9 implementations, but is not | 
					
						
							|  |  |  |  *   directly supported in Oracle SPARC Architecture 2015 implementations. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Therefore always use TSO in QEMU. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * D.5 Specification of Partial Store Order (PSO) | 
					
						
							|  |  |  |  *   ... [loads] are followed by an implied MEMBAR #LoadLoad | #LoadStore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * D.6 Specification of Total Store Order (TSO) | 
					
						
							|  |  |  |  *   ... PSO with the additional requirement that all [stores] are followed | 
					
						
							|  |  |  |  *   by an implied MEMBAR #StoreStore. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define TCG_GUEST_DEFAULT_MO  (TCG_MO_LD_LD | TCG_MO_LD_ST | TCG_MO_ST_ST)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | #if !defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2011-10-17 10:42:49 -07:00
										 |  |  | #define TARGET_DPREGS 16
 | 
					
						
							| 
									
										
										
										
											2010-04-17 16:25:06 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-10-17 10:42:49 -07:00
										 |  |  | #define TARGET_DPREGS 32
 | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-01-24 15:19:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | /*#define EXCP_INTERRUPT 0x100*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 12:33:09 +01:00
										 |  |  | /* Windowed register indexes.  */ | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  |     WREG_O0, | 
					
						
							|  |  |  |     WREG_O1, | 
					
						
							|  |  |  |     WREG_O2, | 
					
						
							|  |  |  |     WREG_O3, | 
					
						
							|  |  |  |     WREG_O4, | 
					
						
							|  |  |  |     WREG_O5, | 
					
						
							|  |  |  |     WREG_O6, | 
					
						
							|  |  |  |     WREG_O7, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     WREG_L0, | 
					
						
							|  |  |  |     WREG_L1, | 
					
						
							|  |  |  |     WREG_L2, | 
					
						
							|  |  |  |     WREG_L3, | 
					
						
							|  |  |  |     WREG_L4, | 
					
						
							|  |  |  |     WREG_L5, | 
					
						
							|  |  |  |     WREG_L6, | 
					
						
							|  |  |  |     WREG_L7, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     WREG_I0, | 
					
						
							|  |  |  |     WREG_I1, | 
					
						
							|  |  |  |     WREG_I2, | 
					
						
							|  |  |  |     WREG_I3, | 
					
						
							|  |  |  |     WREG_I4, | 
					
						
							|  |  |  |     WREG_I5, | 
					
						
							|  |  |  |     WREG_I6, | 
					
						
							|  |  |  |     WREG_I7, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     WREG_SP = WREG_O6, | 
					
						
							|  |  |  |     WREG_FP = WREG_I6, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  | /* trap definitions */ | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #ifndef TARGET_SPARC64
 | 
					
						
							| 
									
										
										
										
											2005-02-13 19:02:42 +00:00
										 |  |  | #define TT_TFAULT   0x01
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  | #define TT_ILL_INSN 0x02
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define TT_PRIV_INSN 0x03
 | 
					
						
							| 
									
										
										
										
											2004-12-19 23:18:01 +00:00
										 |  |  | #define TT_NFPU_INSN 0x04
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  | #define TT_WIN_OVF  0x05
 | 
					
						
							| 
									
										
										
										
											2007-09-16 21:08:06 +00:00
										 |  |  | #define TT_WIN_UNF  0x06
 | 
					
						
							| 
									
										
										
										
											2007-04-13 15:46:16 +00:00
										 |  |  | #define TT_UNALIGNED 0x07
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define TT_FP_EXCP  0x08
 | 
					
						
							| 
									
										
										
										
											2005-02-13 19:02:42 +00:00
										 |  |  | #define TT_DFAULT   0x09
 | 
					
						
							| 
									
										
										
										
											2007-03-23 20:01:20 +00:00
										 |  |  | #define TT_TOVF     0x0a
 | 
					
						
							| 
									
										
										
										
											2005-02-13 19:02:42 +00:00
										 |  |  | #define TT_EXTINT   0x10
 | 
					
						
							| 
									
										
										
										
											2007-05-27 19:36:00 +00:00
										 |  |  | #define TT_CODE_ACCESS 0x21
 | 
					
						
							| 
									
										
										
										
											2008-05-09 20:13:43 +00:00
										 |  |  | #define TT_UNIMP_FLUSH 0x25
 | 
					
						
							| 
									
										
										
										
											2007-05-06 17:59:24 +00:00
										 |  |  | #define TT_DATA_ACCESS 0x29
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  | #define TT_DIV_ZERO 0x2a
 | 
					
						
							| 
									
										
										
										
											2007-04-01 15:08:21 +00:00
										 |  |  | #define TT_NCP_INSN 0x24
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  | #define TT_TRAP     0x80
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2009-08-03 23:15:02 +04:00
										 |  |  | #define TT_POWER_ON_RESET 0x01
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_TFAULT   0x08
 | 
					
						
							| 
									
										
										
										
											2007-05-27 19:36:00 +00:00
										 |  |  | #define TT_CODE_ACCESS 0x0a
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_ILL_INSN 0x10
 | 
					
						
							| 
									
										
										
										
											2008-05-09 20:13:43 +00:00
										 |  |  | #define TT_UNIMP_FLUSH TT_ILL_INSN
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_PRIV_INSN 0x11
 | 
					
						
							|  |  |  | #define TT_NFPU_INSN 0x20
 | 
					
						
							|  |  |  | #define TT_FP_EXCP  0x21
 | 
					
						
							| 
									
										
										
										
											2007-03-23 20:01:20 +00:00
										 |  |  | #define TT_TOVF     0x23
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_CLRWIN   0x24
 | 
					
						
							|  |  |  | #define TT_DIV_ZERO 0x28
 | 
					
						
							|  |  |  | #define TT_DFAULT   0x30
 | 
					
						
							| 
									
										
										
										
											2007-05-06 17:59:24 +00:00
										 |  |  | #define TT_DATA_ACCESS 0x32
 | 
					
						
							| 
									
										
										
										
											2007-04-13 15:46:16 +00:00
										 |  |  | #define TT_UNALIGNED 0x34
 | 
					
						
							| 
									
										
										
										
											2005-07-23 14:27:54 +00:00
										 |  |  | #define TT_PRIV_ACT 0x37
 | 
					
						
							| 
									
										
										
										
											2012-01-23 14:31:21 +01:00
										 |  |  | #define TT_INSN_REAL_TRANSLATION_MISS 0x3e
 | 
					
						
							|  |  |  | #define TT_DATA_REAL_TRANSLATION_MISS 0x3f
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_EXTINT   0x40
 | 
					
						
							| 
									
										
										
										
											2008-07-21 18:43:32 +00:00
										 |  |  | #define TT_IVEC     0x60
 | 
					
						
							| 
									
										
										
										
											2008-07-16 16:55:52 +00:00
										 |  |  | #define TT_TMISS    0x64
 | 
					
						
							|  |  |  | #define TT_DMISS    0x68
 | 
					
						
							| 
									
										
										
										
											2008-07-21 18:43:32 +00:00
										 |  |  | #define TT_DPROT    0x6c
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_SPILL    0x80
 | 
					
						
							|  |  |  | #define TT_FILL     0xc0
 | 
					
						
							| 
									
										
										
										
											2010-05-16 04:11:29 +04:00
										 |  |  | #define TT_WOTHER   (1 << 5)
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define TT_TRAP     0x100
 | 
					
						
							| 
									
										
										
										
											2016-06-07 18:33:53 +02:00
										 |  |  | #define TT_HTRAP    0x180
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-23 17:12:35 +00:00
										 |  |  | #define PSR_NEG_SHIFT 23
 | 
					
						
							|  |  |  | #define PSR_NEG   (1 << PSR_NEG_SHIFT)
 | 
					
						
							|  |  |  | #define PSR_ZERO_SHIFT 22
 | 
					
						
							|  |  |  | #define PSR_ZERO  (1 << PSR_ZERO_SHIFT)
 | 
					
						
							|  |  |  | #define PSR_OVF_SHIFT 21
 | 
					
						
							|  |  |  | #define PSR_OVF   (1 << PSR_OVF_SHIFT)
 | 
					
						
							|  |  |  | #define PSR_CARRY_SHIFT 20
 | 
					
						
							|  |  |  | #define PSR_CARRY (1 << PSR_CARRY_SHIFT)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define PSR_ICC   (PSR_NEG|PSR_ZERO|PSR_OVF|PSR_CARRY)
 | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #if !defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2004-12-19 23:18:01 +00:00
										 |  |  | #define PSR_EF    (1<<12)
 | 
					
						
							|  |  |  | #define PSR_PIL   0xf00
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define PSR_S     (1<<7)
 | 
					
						
							|  |  |  | #define PSR_PS    (1<<6)
 | 
					
						
							|  |  |  | #define PSR_ET    (1<<5)
 | 
					
						
							|  |  |  | #define PSR_CWP   0x1f
 | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-10 07:19:11 +00:00
										 |  |  | #define CC_SRC (env->cc_src)
 | 
					
						
							|  |  |  | #define CC_SRC2 (env->cc_src2)
 | 
					
						
							|  |  |  | #define CC_DST (env->cc_dst)
 | 
					
						
							|  |  |  | #define CC_OP  (env->cc_op)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-06 15:10:57 +02:00
										 |  |  | /* Even though lazy evaluation of CPU condition codes tends to be less
 | 
					
						
							|  |  |  |  * important on RISC systems where condition codes are only updated | 
					
						
							|  |  |  |  * when explicitly requested, SPARC uses it to update 32-bit and 64-bit | 
					
						
							|  |  |  |  * condition codes. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-05-10 07:19:11 +00:00
										 |  |  | enum { | 
					
						
							|  |  |  |     CC_OP_DYNAMIC, /* must use dynamic code to get cc_op */ | 
					
						
							|  |  |  |     CC_OP_FLAGS,   /* all cc are back in status register */ | 
					
						
							|  |  |  |     CC_OP_DIV,     /* modify N, Z and V, C = 0*/ | 
					
						
							|  |  |  |     CC_OP_ADD,     /* modify all flags, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_ADDX,    /* modify all flags, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_TADD,    /* modify all flags, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_TADDTV,  /* modify all flags except V, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_SUB,     /* modify all flags, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_SUBX,    /* modify all flags, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_TSUB,    /* modify all flags, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_TSUBTV,  /* modify all flags except V, CC_DST = res, CC_SRC = src1 */ | 
					
						
							|  |  |  |     CC_OP_LOGIC,   /* modify N and Z, C = V = 0, CC_DST = res */ | 
					
						
							|  |  |  |     CC_OP_NB, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | /* Trap base register */ | 
					
						
							|  |  |  | #define TBR_BASE_MASK 0xfffff000
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #if defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2009-07-12 12:35:31 +04:00
										 |  |  | #define PS_TCT   (1<<12) /* UA2007, impl.dep. trap on control transfer */
 | 
					
						
							|  |  |  | #define PS_IG    (1<<11) /* v9, zero on UA2007 */
 | 
					
						
							|  |  |  | #define PS_MG    (1<<10) /* v9, zero on UA2007 */
 | 
					
						
							|  |  |  | #define PS_CLE   (1<<9) /* UA2007 */
 | 
					
						
							|  |  |  | #define PS_TLE   (1<<8) /* UA2007 */
 | 
					
						
							| 
									
										
										
										
											2007-07-07 20:48:42 +00:00
										 |  |  | #define PS_RMO   (1<<7)
 | 
					
						
							| 
									
										
										
										
											2009-07-12 12:35:31 +04:00
										 |  |  | #define PS_RED   (1<<5) /* v9, zero on UA2007 */
 | 
					
						
							|  |  |  | #define PS_PEF   (1<<4) /* enable fpu */
 | 
					
						
							|  |  |  | #define PS_AM    (1<<3) /* address mask */
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define PS_PRIV  (1<<2)
 | 
					
						
							|  |  |  | #define PS_IE    (1<<1)
 | 
					
						
							| 
									
										
										
										
											2009-07-12 12:35:31 +04:00
										 |  |  | #define PS_AG    (1<<0) /* v9, zero on UA2007 */
 | 
					
						
							| 
									
										
										
										
											2006-06-26 19:53:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 15:27:35 +00:00
										 |  |  | #define FPRS_DL (1 << 0)
 | 
					
						
							|  |  |  | #define FPRS_DU (1 << 1)
 | 
					
						
							|  |  |  | #define FPRS_FEF (1 << 2)
 | 
					
						
							| 
									
										
										
										
											2007-10-14 17:07:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define HS_PRIV  (1<<2)
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | /* Fcc */ | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_RD1        (1ULL << 31)
 | 
					
						
							|  |  |  | #define FSR_RD0        (1ULL << 30)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define FSR_RD_MASK    (FSR_RD1 | FSR_RD0)
 | 
					
						
							|  |  |  | #define FSR_RD_NEAREST 0
 | 
					
						
							|  |  |  | #define FSR_RD_ZERO    FSR_RD0
 | 
					
						
							|  |  |  | #define FSR_RD_POS     FSR_RD1
 | 
					
						
							|  |  |  | #define FSR_RD_NEG     (FSR_RD1 | FSR_RD0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_NVM   (1ULL << 27)
 | 
					
						
							|  |  |  | #define FSR_OFM   (1ULL << 26)
 | 
					
						
							|  |  |  | #define FSR_UFM   (1ULL << 25)
 | 
					
						
							|  |  |  | #define FSR_DZM   (1ULL << 24)
 | 
					
						
							|  |  |  | #define FSR_NXM   (1ULL << 23)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define FSR_TEM_MASK (FSR_NVM | FSR_OFM | FSR_UFM | FSR_DZM | FSR_NXM)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_NVA   (1ULL << 9)
 | 
					
						
							|  |  |  | #define FSR_OFA   (1ULL << 8)
 | 
					
						
							|  |  |  | #define FSR_UFA   (1ULL << 7)
 | 
					
						
							|  |  |  | #define FSR_DZA   (1ULL << 6)
 | 
					
						
							|  |  |  | #define FSR_NXA   (1ULL << 5)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define FSR_AEXC_MASK (FSR_NVA | FSR_OFA | FSR_UFA | FSR_DZA | FSR_NXA)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_NVC   (1ULL << 4)
 | 
					
						
							|  |  |  | #define FSR_OFC   (1ULL << 3)
 | 
					
						
							|  |  |  | #define FSR_UFC   (1ULL << 2)
 | 
					
						
							|  |  |  | #define FSR_DZC   (1ULL << 1)
 | 
					
						
							|  |  |  | #define FSR_NXC   (1ULL << 0)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define FSR_CEXC_MASK (FSR_NVC | FSR_OFC | FSR_UFC | FSR_DZC | FSR_NXC)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_FTT2   (1ULL << 16)
 | 
					
						
							|  |  |  | #define FSR_FTT1   (1ULL << 15)
 | 
					
						
							|  |  |  | #define FSR_FTT0   (1ULL << 14)
 | 
					
						
							| 
									
										
										
										
											2023-02-15 19:45:15 -10:00
										 |  |  | #define FSR_FTT_MASK (FSR_FTT2 | FSR_FTT1 | FSR_FTT0)
 | 
					
						
							| 
									
										
										
										
											2008-09-06 17:50:16 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							|  |  |  | #define FSR_FTT_NMASK      0xfffffffffffe3fffULL
 | 
					
						
							|  |  |  | #define FSR_FTT_CEXC_NMASK 0xfffffffffffe3fe0ULL
 | 
					
						
							| 
									
										
										
										
											2008-09-09 19:02:49 +00:00
										 |  |  | #define FSR_LDFSR_OLDMASK  0x0000003f000fc000ULL
 | 
					
						
							|  |  |  | #define FSR_LDXFSR_MASK    0x0000003fcfc00fffULL
 | 
					
						
							|  |  |  | #define FSR_LDXFSR_OLDMASK 0x00000000000fc000ULL
 | 
					
						
							| 
									
										
										
										
											2008-09-06 17:50:16 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define FSR_FTT_NMASK      0xfffe3fffULL
 | 
					
						
							|  |  |  | #define FSR_FTT_CEXC_NMASK 0xfffe3fe0ULL
 | 
					
						
							| 
									
										
										
										
											2008-09-09 19:02:49 +00:00
										 |  |  | #define FSR_LDFSR_OLDMASK  0x000fc000ULL
 | 
					
						
							| 
									
										
										
										
											2008-09-06 17:50:16 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-09-09 19:02:49 +00:00
										 |  |  | #define FSR_LDFSR_MASK     0xcfc00fffULL
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_FTT_IEEE_EXCP (1ULL << 14)
 | 
					
						
							|  |  |  | #define FSR_FTT_UNIMPFPOP (3ULL << 14)
 | 
					
						
							|  |  |  | #define FSR_FTT_SEQ_ERROR (4ULL << 14)
 | 
					
						
							|  |  |  | #define FSR_FTT_INVAL_FPR (6ULL << 14)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-23 17:12:35 +00:00
										 |  |  | #define FSR_FCC1_SHIFT 11
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_FCC1  (1ULL << FSR_FCC1_SHIFT)
 | 
					
						
							| 
									
										
										
										
											2008-04-23 17:12:35 +00:00
										 |  |  | #define FSR_FCC0_SHIFT 10
 | 
					
						
							| 
									
										
										
										
											2008-08-29 21:03:31 +00:00
										 |  |  | #define FSR_FCC0  (1ULL << FSR_FCC0_SHIFT)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* MMU */ | 
					
						
							| 
									
										
										
										
											2007-09-20 14:54:22 +00:00
										 |  |  | #define MMU_E     (1<<0)
 | 
					
						
							|  |  |  | #define MMU_NF    (1<<1)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PTE_ENTRYTYPE_MASK 3
 | 
					
						
							|  |  |  | #define PTE_ACCESS_MASK    0x1c
 | 
					
						
							|  |  |  | #define PTE_ACCESS_SHIFT   2
 | 
					
						
							| 
									
										
										
										
											2004-10-04 21:23:09 +00:00
										 |  |  | #define PTE_PPN_SHIFT      7
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define PTE_ADDR_MASK      0xffffff00
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 14:54:22 +00:00
										 |  |  | #define PG_ACCESSED_BIT 5
 | 
					
						
							|  |  |  | #define PG_MODIFIED_BIT 6
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define PG_CACHE_BIT    7
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PG_ACCESSED_MASK (1 << PG_ACCESSED_BIT)
 | 
					
						
							|  |  |  | #define PG_MODIFIED_MASK (1 << PG_MODIFIED_BIT)
 | 
					
						
							|  |  |  | #define PG_CACHE_MASK    (1 << PG_CACHE_BIT)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-07 08:07:37 +00:00
										 |  |  | /* 3 <= NWINDOWS <= 32. */ | 
					
						
							|  |  |  | #define MIN_NWINDOWS 3
 | 
					
						
							|  |  |  | #define MAX_NWINDOWS 32
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-22 11:51:19 -07:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							| 
									
										
										
										
											2008-03-05 17:59:48 +00:00
										 |  |  | typedef struct trap_state { | 
					
						
							|  |  |  |     uint64_t tpc; | 
					
						
							|  |  |  |     uint64_t tnpc; | 
					
						
							|  |  |  |     uint64_t tstate; | 
					
						
							|  |  |  |     uint32_t tt; | 
					
						
							|  |  |  | } trap_state; | 
					
						
							| 
									
										
										
										
											2007-10-14 17:07:21 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-08-31 13:30:52 -07:00
										 |  |  | #define TARGET_INSN_START_EXTRA_WORDS 1
 | 
					
						
							| 
									
										
										
										
											2007-10-14 07:07:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-14 13:36:09 +01:00
										 |  |  | struct sparc_def_t { | 
					
						
							| 
									
										
										
										
											2008-08-21 17:33:42 +00:00
										 |  |  |     const char *name; | 
					
						
							|  |  |  |     target_ulong iu_version; | 
					
						
							|  |  |  |     uint32_t fpu_version; | 
					
						
							|  |  |  |     uint32_t mmu_version; | 
					
						
							|  |  |  |     uint32_t mmu_bm; | 
					
						
							|  |  |  |     uint32_t mmu_ctpr_mask; | 
					
						
							|  |  |  |     uint32_t mmu_cxr_mask; | 
					
						
							|  |  |  |     uint32_t mmu_sfsr_mask; | 
					
						
							|  |  |  |     uint32_t mmu_trcr_mask; | 
					
						
							| 
									
										
										
										
											2008-12-23 15:06:35 +00:00
										 |  |  |     uint32_t mxcc_version; | 
					
						
							| 
									
										
										
										
											2008-08-21 17:33:42 +00:00
										 |  |  |     uint32_t features; | 
					
						
							|  |  |  |     uint32_t nwindows; | 
					
						
							|  |  |  |     uint32_t maxtl; | 
					
						
							| 
									
										
										
										
											2017-09-14 13:36:09 +01:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2008-08-21 17:33:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-15 17:02:33 -07:00
										 |  |  | #define FEATURE(X)  CPU_FEATURE_BIT_##X,
 | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | #include "cpu-feature.h.inc"
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef FEATURE
 | 
					
						
							|  |  |  | #define FEATURE(X)  CPU_FEATURE_##X = 1u << CPU_FEATURE_BIT_##X,
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | #include "cpu-feature.h.inc"
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef FEATURE
 | 
					
						
							| 
									
										
										
										
											2011-01-31 11:36:54 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 17:33:42 +00:00
										 |  |  | #ifndef TARGET_SPARC64
 | 
					
						
							| 
									
										
										
										
											2023-10-11 20:34:14 -07:00
										 |  |  | #define CPU_DEFAULT_FEATURES (CPU_FEATURE_MUL | CPU_FEATURE_DIV | \
 | 
					
						
							|  |  |  |                               CPU_FEATURE_FSMULD) | 
					
						
							| 
									
										
										
										
											2008-08-21 17:33:42 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2023-10-11 20:34:14 -07:00
										 |  |  | #define CPU_DEFAULT_FEATURES (CPU_FEATURE_MUL | CPU_FEATURE_DIV | \
 | 
					
						
							|  |  |  |                               CPU_FEATURE_FSMULD | CPU_FEATURE_CASA | \ | 
					
						
							|  |  |  |                               CPU_FEATURE_VIS1 | CPU_FEATURE_VIS2) | 
					
						
							| 
									
										
										
										
											2008-08-21 17:33:42 +00:00
										 |  |  | enum { | 
					
						
							|  |  |  |     mmu_us_12, // Ultrasparc < III (64 entry TLB)
 | 
					
						
							|  |  |  |     mmu_us_3,  // Ultrasparc III (512 entry TLB)
 | 
					
						
							|  |  |  |     mmu_us_4,  // Ultrasparc IV (several TLBs, 32 and 256MB pages)
 | 
					
						
							|  |  |  |     mmu_sun4v, // T1, T2
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:57:39 +04:00
										 |  |  | #define TTE_VALID_BIT       (1ULL << 63)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:33 +09:00
										 |  |  | #define TTE_NFO_BIT         (1ULL << 60)
 | 
					
						
							| 
									
										
										
										
											2019-08-24 04:36:58 +10:00
										 |  |  | #define TTE_IE_BIT          (1ULL << 59)
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:57:39 +04:00
										 |  |  | #define TTE_USED_BIT        (1ULL << 41)
 | 
					
						
							|  |  |  | #define TTE_LOCKED_BIT      (1ULL <<  6)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:33 +09:00
										 |  |  | #define TTE_SIDEEFFECT_BIT  (1ULL <<  3)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:27 +09:00
										 |  |  | #define TTE_PRIV_BIT        (1ULL <<  2)
 | 
					
						
							|  |  |  | #define TTE_W_OK_BIT        (1ULL <<  1)
 | 
					
						
							| 
									
										
										
										
											2009-12-05 11:14:55 +00:00
										 |  |  | #define TTE_GLOBAL_BIT      (1ULL <<  0)
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:57:39 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 13:22:27 +01:00
										 |  |  | #define TTE_NFO_BIT_UA2005  (1ULL << 62)
 | 
					
						
							|  |  |  | #define TTE_USED_BIT_UA2005 (1ULL << 47)
 | 
					
						
							|  |  |  | #define TTE_LOCKED_BIT_UA2005 (1ULL <<  61)
 | 
					
						
							|  |  |  | #define TTE_SIDEEFFECT_BIT_UA2005 (1ULL <<  11)
 | 
					
						
							|  |  |  | #define TTE_PRIV_BIT_UA2005 (1ULL <<  8)
 | 
					
						
							|  |  |  | #define TTE_W_OK_BIT_UA2005 (1ULL <<  6)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:57:39 +04:00
										 |  |  | #define TTE_IS_VALID(tte)   ((tte) & TTE_VALID_BIT)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:33 +09:00
										 |  |  | #define TTE_IS_NFO(tte)     ((tte) & TTE_NFO_BIT)
 | 
					
						
							| 
									
										
										
										
											2019-08-24 04:36:58 +10:00
										 |  |  | #define TTE_IS_IE(tte)      ((tte) & TTE_IE_BIT)
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:57:39 +04:00
										 |  |  | #define TTE_IS_USED(tte)    ((tte) & TTE_USED_BIT)
 | 
					
						
							|  |  |  | #define TTE_IS_LOCKED(tte)  ((tte) & TTE_LOCKED_BIT)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:33 +09:00
										 |  |  | #define TTE_IS_SIDEEFFECT(tte) ((tte) & TTE_SIDEEFFECT_BIT)
 | 
					
						
							| 
									
										
										
										
											2016-03-02 13:22:27 +01:00
										 |  |  | #define TTE_IS_SIDEEFFECT_UA2005(tte) ((tte) & TTE_SIDEEFFECT_BIT_UA2005)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:27 +09:00
										 |  |  | #define TTE_IS_PRIV(tte)    ((tte) & TTE_PRIV_BIT)
 | 
					
						
							|  |  |  | #define TTE_IS_W_OK(tte)    ((tte) & TTE_W_OK_BIT)
 | 
					
						
							| 
									
										
										
										
											2016-03-02 13:22:27 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TTE_IS_NFO_UA2005(tte)     ((tte) & TTE_NFO_BIT_UA2005)
 | 
					
						
							|  |  |  | #define TTE_IS_USED_UA2005(tte)    ((tte) & TTE_USED_BIT_UA2005)
 | 
					
						
							|  |  |  | #define TTE_IS_LOCKED_UA2005(tte)  ((tte) & TTE_LOCKED_BIT_UA2005)
 | 
					
						
							|  |  |  | #define TTE_IS_SIDEEFFECT_UA2005(tte) ((tte) & TTE_SIDEEFFECT_BIT_UA2005)
 | 
					
						
							|  |  |  | #define TTE_IS_PRIV_UA2005(tte)    ((tte) & TTE_PRIV_BIT_UA2005)
 | 
					
						
							|  |  |  | #define TTE_IS_W_OK_UA2005(tte)    ((tte) & TTE_W_OK_BIT_UA2005)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-05 11:14:55 +00:00
										 |  |  | #define TTE_IS_GLOBAL(tte)  ((tte) & TTE_GLOBAL_BIT)
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:57:39 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define TTE_SET_USED(tte)   ((tte) |= TTE_USED_BIT)
 | 
					
						
							|  |  |  | #define TTE_SET_UNUSED(tte) ((tte) &= ~TTE_USED_BIT)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:27 +09:00
										 |  |  | #define TTE_PGSIZE(tte)     (((tte) >> 61) & 3ULL)
 | 
					
						
							| 
									
										
										
										
											2016-03-02 13:22:27 +01:00
										 |  |  | #define TTE_PGSIZE_UA2005(tte)     ((tte) & 7ULL)
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:27 +09:00
										 |  |  | #define TTE_PA(tte)         ((tte) & 0x1ffffffe000ULL)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-10 10:44:15 +02:00
										 |  |  | /* UltraSPARC T1 specific */ | 
					
						
							|  |  |  | #define TLB_UST1_IS_REAL_BIT   (1ULL << 9)  /* Real translation entry */
 | 
					
						
							|  |  |  | #define TLB_UST1_IS_SUN4V_BIT  (1ULL << 10) /* sun4u/sun4v TTE format switch */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:28 +09:00
										 |  |  | #define SFSR_NF_BIT         (1ULL << 24)   /* JPS1 NoFault */
 | 
					
						
							|  |  |  | #define SFSR_TM_BIT         (1ULL << 15)   /* JPS1 TLB Miss */
 | 
					
						
							|  |  |  | #define SFSR_FT_VA_IMMU_BIT (1ULL << 13)   /* USIIi VA out of range (IMMU) */
 | 
					
						
							|  |  |  | #define SFSR_FT_VA_DMMU_BIT (1ULL << 12)   /* USIIi VA out of range (DMMU) */
 | 
					
						
							|  |  |  | #define SFSR_FT_NFO_BIT     (1ULL << 11)   /* NFO page access */
 | 
					
						
							|  |  |  | #define SFSR_FT_ILL_BIT     (1ULL << 10)   /* illegal LDA/STA ASI */
 | 
					
						
							|  |  |  | #define SFSR_FT_ATOMIC_BIT  (1ULL <<  9)   /* atomic op on noncacheable area */
 | 
					
						
							|  |  |  | #define SFSR_FT_NF_E_BIT    (1ULL <<  8)   /* NF access on side effect area */
 | 
					
						
							|  |  |  | #define SFSR_FT_PRIV_BIT    (1ULL <<  7)   /* privilege violation */
 | 
					
						
							|  |  |  | #define SFSR_PR_BIT         (1ULL <<  3)   /* privilege mode */
 | 
					
						
							|  |  |  | #define SFSR_WRITE_BIT      (1ULL <<  2)   /* write access mode */
 | 
					
						
							|  |  |  | #define SFSR_OW_BIT         (1ULL <<  1)   /* status overwritten */
 | 
					
						
							|  |  |  | #define SFSR_VALID_BIT      (1ULL <<  0)   /* status valid */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SFSR_ASI_SHIFT      16             /* 23:16 ASI value */
 | 
					
						
							|  |  |  | #define SFSR_ASI_MASK       (0xffULL << SFSR_ASI_SHIFT)
 | 
					
						
							|  |  |  | #define SFSR_CT_PRIMARY     (0ULL <<  4)   /* 5:4 context type */
 | 
					
						
							|  |  |  | #define SFSR_CT_SECONDARY   (1ULL <<  4)
 | 
					
						
							|  |  |  | #define SFSR_CT_NUCLEUS     (2ULL <<  4)
 | 
					
						
							|  |  |  | #define SFSR_CT_NOTRANS     (3ULL <<  4)
 | 
					
						
							|  |  |  | #define SFSR_CT_MASK        (3ULL <<  4)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-01 09:20:58 +00:00
										 |  |  | /* Leon3 cache control */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Cache control: emulate the behavior of cache control registers but without
 | 
					
						
							|  |  |  |    any effect on the emulated */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_STATE_MASK 0x3
 | 
					
						
							|  |  |  | #define CACHE_DISABLED   0x0
 | 
					
						
							|  |  |  | #define CACHE_FROZEN     0x1
 | 
					
						
							|  |  |  | #define CACHE_ENABLED    0x3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Cache Control register fields */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CACHE_CTRL_IF (1 <<  4)  /* Instruction Cache Freeze on Interrupt */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_DF (1 <<  5)  /* Data Cache Freeze on Interrupt */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_DP (1 << 14)  /* Data cache flush pending */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_IP (1 << 15)  /* Instruction cache flush pending */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_IB (1 << 16)  /* Instruction burst fetch */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_FI (1 << 21)  /* Flush Instruction cache (Write only) */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_FD (1 << 22)  /* Flush Data cache (Write only) */
 | 
					
						
							|  |  |  | #define CACHE_CTRL_DS (1 << 23)  /* Data cache snoop enable */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-03 21:45:05 +02:00
										 |  |  | #define CONVERT_BIT(X, SRC, DST) \
 | 
					
						
							|  |  |  |          (SRC > DST ? (X) / (SRC / DST) & (DST) : ((X) & SRC) * (DST / SRC)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-27 01:49:04 +04:00
										 |  |  | typedef struct SparcTLBEntry { | 
					
						
							|  |  |  |     uint64_t tag; | 
					
						
							|  |  |  |     uint64_t tte; | 
					
						
							|  |  |  | } SparcTLBEntry; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-28 00:00:53 +03:00
										 |  |  | struct CPUTimer | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const char *name; | 
					
						
							|  |  |  |     uint32_t    frequency; | 
					
						
							|  |  |  |     uint32_t    disabled; | 
					
						
							|  |  |  |     uint64_t    disabled_mask; | 
					
						
							| 
									
										
										
										
											2015-11-08 12:27:38 +00:00
										 |  |  |     uint32_t    npt; | 
					
						
							|  |  |  |     uint64_t    npt_mask; | 
					
						
							| 
									
										
										
										
											2010-01-28 00:00:53 +03:00
										 |  |  |     int64_t     clock_offset; | 
					
						
							| 
									
										
										
										
											2013-12-01 08:49:47 +01:00
										 |  |  |     QEMUTimer  *qtimer; | 
					
						
							| 
									
										
										
										
											2010-01-28 00:00:53 +03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct CPUTimer CPUTimer; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-07 13:35:58 +01:00
										 |  |  | typedef struct CPUArchState CPUSPARCState; | 
					
						
							| 
									
										
										
										
											2016-02-09 12:07:48 +01:00
										 |  |  | #if defined(TARGET_SPARC64)
 | 
					
						
							|  |  |  | typedef union { | 
					
						
							|  |  |  |    uint64_t mmuregs[16]; | 
					
						
							|  |  |  |    struct { | 
					
						
							|  |  |  |     uint64_t tsb_tag_target; | 
					
						
							|  |  |  |     uint64_t mmu_primary_context; | 
					
						
							|  |  |  |     uint64_t mmu_secondary_context; | 
					
						
							|  |  |  |     uint64_t sfsr; | 
					
						
							|  |  |  |     uint64_t sfar; | 
					
						
							|  |  |  |     uint64_t tsb; | 
					
						
							|  |  |  |     uint64_t tag_access; | 
					
						
							|  |  |  |     uint64_t virtual_watchpoint; | 
					
						
							|  |  |  |     uint64_t physical_watchpoint; | 
					
						
							| 
									
										
										
										
											2016-02-09 10:58:49 +01:00
										 |  |  |     uint64_t sun4v_ctx_config[2]; | 
					
						
							|  |  |  |     uint64_t sun4v_tsb_pointers[4]; | 
					
						
							| 
									
										
										
										
											2016-02-09 12:07:48 +01:00
										 |  |  |    }; | 
					
						
							|  |  |  | } SparcV9MMU; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2022-02-07 13:35:58 +01:00
										 |  |  | struct CPUArchState { | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  |     target_ulong gregs[8]; /* general registers */ | 
					
						
							|  |  |  |     target_ulong *regwptr; /* pointer to current register window */ | 
					
						
							|  |  |  |     target_ulong pc;       /* program counter */ | 
					
						
							|  |  |  |     target_ulong npc;      /* next program counter */ | 
					
						
							|  |  |  |     target_ulong y;        /* multiply/divide register */ | 
					
						
							| 
									
										
										
										
											2008-03-13 20:45:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* emulator internal flags handling */ | 
					
						
							| 
									
										
										
										
											2008-03-16 19:22:18 +00:00
										 |  |  |     target_ulong cc_src, cc_src2; | 
					
						
							| 
									
										
										
										
											2008-03-13 20:45:31 +00:00
										 |  |  |     target_ulong cc_dst; | 
					
						
							| 
									
										
										
										
											2009-05-10 07:19:11 +00:00
										 |  |  |     uint32_t cc_op; | 
					
						
							| 
									
										
										
										
											2008-03-13 20:45:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-10 10:58:20 +00:00
										 |  |  |     target_ulong cond; /* conditional branch result (XXX: save it in a
 | 
					
						
							|  |  |  |                           temporary register when possible) */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  |     uint32_t psr;      /* processor state register */ | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  |     target_ulong fsr;      /* FPU state register */ | 
					
						
							| 
									
										
										
										
											2011-10-17 10:42:49 -07:00
										 |  |  |     CPU_DoubleU fpr[TARGET_DPREGS];  /* floating point registers */ | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  |     uint32_t cwp;      /* index of current register window (extracted
 | 
					
						
							|  |  |  |                           from PSR) */ | 
					
						
							| 
									
										
										
										
											2009-07-12 12:35:31 +04:00
										 |  |  | #if !defined(TARGET_SPARC64) || defined(TARGET_ABI32)
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  |     uint32_t wim;      /* window invalid mask */ | 
					
						
							| 
									
										
										
										
											2009-07-12 12:35:31 +04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  |     target_ulong tbr;  /* trap base register */ | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #if !defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  |     int      psrs;     /* supervisor mode (extracted from PSR) */ | 
					
						
							|  |  |  |     int      psrps;    /* previous supervisor mode */ | 
					
						
							|  |  |  |     int      psret;    /* enable traps */ | 
					
						
							| 
									
										
										
										
											2009-07-12 12:35:31 +04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-08-04 10:50:30 +00:00
										 |  |  |     uint32_t psrpil;   /* interrupt blocking level */ | 
					
						
							|  |  |  |     uint32_t pil_in;   /* incoming interrupt level bitmap */ | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #if !defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2004-12-19 23:18:01 +00:00
										 |  |  |     int      psref;    /* enable fpu */ | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-01-04 15:01:44 +00:00
										 |  |  |     int interrupt_index; | 
					
						
							|  |  |  |     /* NOTE: we allow 8 more registers to handle wrapping */ | 
					
						
							| 
									
										
										
										
											2008-06-07 08:07:37 +00:00
										 |  |  |     target_ulong regbase[MAX_NWINDOWS * 16 + 8]; | 
					
						
							| 
									
										
										
										
											2004-04-25 17:57:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-14 14:19:17 +00:00
										 |  |  |     /* Fields up to this point are cleared by a CPU reset */ | 
					
						
							|  |  |  |     struct {} end_reset_fields; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-26 21:22:53 +02:00
										 |  |  |     /* Fields from here on are preserved across CPU reset. */ | 
					
						
							| 
									
										
										
										
											2012-03-10 17:55:05 +00:00
										 |  |  |     target_ulong version; | 
					
						
							|  |  |  |     uint32_t nwindows; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  |     /* MMU regs */ | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #if defined(TARGET_SPARC64)
 | 
					
						
							|  |  |  |     uint64_t lsu; | 
					
						
							|  |  |  | #define DMMU_E 0x8
 | 
					
						
							|  |  |  | #define IMMU_E 0x4
 | 
					
						
							| 
									
										
										
										
											2016-02-09 12:07:48 +01:00
										 |  |  |     SparcV9MMU immu; | 
					
						
							|  |  |  |     SparcV9MMU dmmu; | 
					
						
							| 
									
										
										
										
											2009-07-27 01:49:04 +04:00
										 |  |  |     SparcTLBEntry itlb[64]; | 
					
						
							|  |  |  |     SparcTLBEntry dtlb[64]; | 
					
						
							| 
									
										
										
										
											2008-07-20 18:22:16 +00:00
										 |  |  |     uint32_t mmu_version; | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2007-11-25 12:43:10 +00:00
										 |  |  |     uint32_t mmuregs[32]; | 
					
						
							| 
									
										
										
										
											2007-10-14 16:29:21 +00:00
										 |  |  |     uint64_t mxccdata[4]; | 
					
						
							|  |  |  |     uint64_t mxccregs[8]; | 
					
						
							| 
									
										
										
										
											2011-06-18 20:27:05 +00:00
										 |  |  |     uint32_t mmubpctrv, mmubpctrc, mmubpctrs; | 
					
						
							|  |  |  |     uint64_t mmubpaction; | 
					
						
							| 
									
										
										
										
											2008-12-23 15:30:50 +00:00
										 |  |  |     uint64_t mmubpregs[4]; | 
					
						
							| 
									
										
										
										
											2007-11-28 20:54:33 +00:00
										 |  |  |     uint64_t prom_addr; | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  |     /* temporary float registers */ | 
					
						
							| 
									
										
										
										
											2007-11-25 18:40:20 +00:00
										 |  |  |     float128 qt0, qt1; | 
					
						
							| 
									
										
										
										
											2005-03-13 17:01:47 +00:00
										 |  |  |     float_status fp_status; | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | #if defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2008-07-25 07:42:14 +00:00
										 |  |  | #define MAXTL_MAX 8
 | 
					
						
							|  |  |  | #define MAXTL_MASK (MAXTL_MAX - 1)
 | 
					
						
							|  |  |  |     trap_state ts[MAXTL_MAX]; | 
					
						
							| 
									
										
										
										
											2007-09-20 14:54:22 +00:00
										 |  |  |     uint32_t xcc;               /* Extended integer condition codes */ | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  |     uint32_t asi; | 
					
						
							|  |  |  |     uint32_t pstate; | 
					
						
							|  |  |  |     uint32_t tl; | 
					
						
							| 
									
										
										
										
											2008-07-25 07:42:14 +00:00
										 |  |  |     uint32_t maxtl; | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  |     uint32_t cansave, canrestore, otherwin, wstate, cleanwin; | 
					
						
							| 
									
										
										
										
											2005-07-23 14:27:54 +00:00
										 |  |  |     uint64_t agregs[8]; /* alternate general registers */ | 
					
						
							|  |  |  |     uint64_t bgregs[8]; /* backup for normal global registers */ | 
					
						
							|  |  |  |     uint64_t igregs[8]; /* interrupt general registers */ | 
					
						
							|  |  |  |     uint64_t mgregs[8]; /* mmu general registers */ | 
					
						
							| 
									
										
										
										
											2016-06-07 18:34:49 +02:00
										 |  |  |     uint64_t glregs[8 * MAXTL_MAX]; | 
					
						
							| 
									
										
										
										
											2023-07-17 11:35:44 +01:00
										 |  |  |     uint32_t fprs; | 
					
						
							| 
									
										
										
										
											2005-07-23 14:27:54 +00:00
										 |  |  |     uint64_t tick_cmpr, stick_cmpr; | 
					
						
							| 
									
										
										
										
											2010-01-28 00:00:53 +03:00
										 |  |  |     CPUTimer *tick, *stick; | 
					
						
							| 
									
										
										
										
											2010-01-07 23:28:21 +03:00
										 |  |  | #define TICK_NPT_MASK        0x8000000000000000ULL
 | 
					
						
							|  |  |  | #define TICK_INT_DIS         0x8000000000000000ULL
 | 
					
						
							| 
									
										
										
										
											2006-07-18 21:12:17 +00:00
										 |  |  |     uint64_t gsr; | 
					
						
							| 
									
										
										
										
											2007-04-22 19:14:52 +00:00
										 |  |  |     uint32_t gl; // UA2005
 | 
					
						
							|  |  |  |     /* UA 2005 hyperprivileged registers */ | 
					
						
							| 
									
										
										
										
											2008-07-25 07:42:14 +00:00
										 |  |  |     uint64_t hpstate, htstate[MAXTL_MAX], hintp, htba, hver, hstick_cmpr, ssr; | 
					
						
							| 
									
										
										
										
											2016-03-02 14:36:20 +01:00
										 |  |  |     uint64_t scratch[8]; | 
					
						
							| 
									
										
										
										
											2010-01-28 00:00:53 +03:00
										 |  |  |     CPUTimer *hstick; // UA 2005
 | 
					
						
							| 
									
										
										
										
											2012-03-10 20:37:00 +00:00
										 |  |  |     /* Interrupt vector registers */ | 
					
						
							|  |  |  |     uint64_t ivec_status; | 
					
						
							|  |  |  |     uint64_t ivec_data[3]; | 
					
						
							| 
									
										
										
										
											2008-09-22 19:50:28 +00:00
										 |  |  |     uint32_t softint; | 
					
						
							| 
									
										
										
										
											2008-12-23 08:47:26 +00:00
										 |  |  | #define SOFTINT_TIMER   1
 | 
					
						
							|  |  |  | #define SOFTINT_STIMER  (1 << 16)
 | 
					
						
							| 
									
										
										
										
											2010-01-07 23:28:21 +03:00
										 |  |  | #define SOFTINT_INTRMASK (0xFFFE)
 | 
					
						
							|  |  |  | #define SOFTINT_REG_MASK (SOFTINT_STIMER|SOFTINT_INTRMASK|SOFTINT_TIMER)
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-08-24 18:31:26 +02:00
										 |  |  |     sparc_def_t def; | 
					
						
							| 
									
										
										
										
											2011-01-24 12:56:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void *irq_manager; | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  |     void (*qemu_irq_ack)(CPUSPARCState *env, void *irq_manager, int intno); | 
					
						
							| 
									
										
										
										
											2011-01-24 12:56:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Leon3 cache control */ | 
					
						
							|  |  |  |     uint32_t cache_control; | 
					
						
							| 
									
										
										
										
											2012-02-24 17:15:27 +01:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2008-05-09 20:13:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-15 13:49:25 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * SPARCCPU: | 
					
						
							|  |  |  |  * @env: #CPUSPARCState | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * A SPARC CPU. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-02-14 17:15:16 +01:00
										 |  |  | struct ArchCPU { | 
					
						
							| 
									
										
										
										
											2016-03-15 13:49:25 +01:00
										 |  |  |     /*< private >*/ | 
					
						
							|  |  |  |     CPUState parent_obj; | 
					
						
							|  |  |  |     /*< public >*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CPUSPARCState env; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef CONFIG_USER_ONLY
 | 
					
						
							| 
									
										
										
										
											2019-08-12 07:23:44 +02:00
										 |  |  | extern const VMStateDescription vmstate_sparc_cpu; | 
					
						
							| 
									
										
										
										
											2022-12-06 16:20:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | hwaddr sparc_cpu_get_phys_page_debug(CPUState *cpu, vaddr addr); | 
					
						
							| 
									
										
										
										
											2016-03-15 13:49:25 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void sparc_cpu_do_interrupt(CPUState *cpu); | 
					
						
							| 
									
										
										
										
											2020-03-16 17:21:41 +00:00
										 |  |  | int sparc_cpu_gdb_read_register(CPUState *cpu, GByteArray *buf, int reg); | 
					
						
							| 
									
										
										
										
											2016-03-15 13:49:25 +01:00
										 |  |  | int sparc_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg); | 
					
						
							| 
									
										
										
										
											2022-04-20 17:26:02 +04:00
										 |  |  | G_NORETURN void sparc_cpu_do_unaligned_access(CPUState *cpu, vaddr addr, | 
					
						
							|  |  |  |                                               MMUAccessType access_type, | 
					
						
							|  |  |  |                                               int mmu_idx, | 
					
						
							|  |  |  |                                               uintptr_t retaddr); | 
					
						
							|  |  |  | G_NORETURN void cpu_raise_exception_ra(CPUSPARCState *, int, uintptr_t); | 
					
						
							| 
									
										
										
										
											2012-05-03 03:12:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-11 09:33:40 +00:00
										 |  |  | /* cpu_init.c */ | 
					
						
							| 
									
										
										
										
											2008-08-29 20:50:21 +00:00
										 |  |  | void cpu_sparc_set_id(CPUSPARCState *env, unsigned int cpu); | 
					
						
							| 
									
										
										
										
											2019-04-17 21:17:57 +02:00
										 |  |  | void sparc_cpu_list(void); | 
					
						
							| 
									
										
										
										
											2011-09-11 11:30:01 +00:00
										 |  |  | /* mmu_helper.c */ | 
					
						
							| 
									
										
										
										
											2019-04-03 07:16:41 +07:00
										 |  |  | bool sparc_cpu_tlb_fill(CPUState *cs, vaddr address, int size, | 
					
						
							|  |  |  |                         MMUAccessType access_type, int mmu_idx, | 
					
						
							|  |  |  |                         bool probe, uintptr_t retaddr); | 
					
						
							| 
									
										
										
										
											2008-10-03 19:02:42 +00:00
										 |  |  | target_ulong mmu_probe(CPUSPARCState *env, target_ulong address, int mmulev); | 
					
						
							| 
									
										
										
										
											2019-04-17 21:17:58 +02:00
										 |  |  | void dump_mmu(CPUSPARCState *env); | 
					
						
							| 
									
										
										
										
											2008-08-29 20:50:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-08 12:48:16 +02:00
										 |  |  | #if !defined(TARGET_SPARC64) && !defined(CONFIG_USER_ONLY)
 | 
					
						
							| 
									
										
										
										
											2013-06-27 19:09:09 +02:00
										 |  |  | int sparc_cpu_memory_rw_debug(CPUState *cpu, vaddr addr, | 
					
						
							|  |  |  |                               uint8_t *buf, int len, bool is_write); | 
					
						
							| 
									
										
										
										
											2011-09-08 12:48:16 +02:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 20:50:21 +00:00
										 |  |  | /* translate.c */ | 
					
						
							| 
									
										
										
										
											2017-10-15 19:02:42 -07:00
										 |  |  | void sparc_tcg_init(void); | 
					
						
							| 
									
										
										
										
											2022-10-24 21:03:29 +10:00
										 |  |  | void sparc_restore_state_to_opc(CPUState *cs, | 
					
						
							|  |  |  |                                 const TranslationBlock *tb, | 
					
						
							|  |  |  |                                 const uint64_t *data); | 
					
						
							| 
									
										
										
										
											2008-08-29 20:50:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* cpu-exec.c */ | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-01 09:03:20 +00:00
										 |  |  | /* win_helper.c */ | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | target_ulong cpu_get_psr(CPUSPARCState *env1); | 
					
						
							|  |  |  | void cpu_put_psr(CPUSPARCState *env1, target_ulong val); | 
					
						
							| 
									
										
										
										
											2016-01-11 12:40:24 +00:00
										 |  |  | void cpu_put_psr_raw(CPUSPARCState *env1, target_ulong val); | 
					
						
							| 
									
										
										
										
											2010-05-09 20:19:04 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | void cpu_change_pstate(CPUSPARCState *env1, uint32_t new_pstate); | 
					
						
							| 
									
										
										
										
											2016-06-07 18:34:49 +02:00
										 |  |  | void cpu_gl_switch_gregs(CPUSPARCState *env, uint32_t new_gl); | 
					
						
							| 
									
										
										
										
											2009-08-22 11:54:03 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | int cpu_cwp_inc(CPUSPARCState *env1, int cwp); | 
					
						
							|  |  |  | int cpu_cwp_dec(CPUSPARCState *env1, int cwp); | 
					
						
							|  |  |  | void cpu_set_cwp(CPUSPARCState *env1, int new_cwp); | 
					
						
							| 
									
										
										
										
											2011-08-01 09:03:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 11:54:03 +00:00
										 |  |  | /* sun4m.c, sun4u.c */ | 
					
						
							|  |  |  | void cpu_check_irqs(CPUSPARCState *env); | 
					
						
							| 
									
										
										
										
											2008-06-07 08:07:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-04 23:15:41 +04:00
										 |  |  | #if defined (TARGET_SPARC64)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int compare_masked(uint64_t x, uint64_t y, uint64_t mask) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return (x & mask) == (y & mask); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MMU_CONTEXT_BITS 13
 | 
					
						
							|  |  |  | #define MMU_CONTEXT_MASK ((1 << MMU_CONTEXT_BITS) - 1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int tlb_compare_context(const SparcTLBEntry *tlb, | 
					
						
							|  |  |  |                                       uint64_t context) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return compare_masked(context, tlb->tag, MMU_CONTEXT_MASK); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-29 20:50:21 +00:00
										 |  |  | /* cpu-exec.c */ | 
					
						
							| 
									
										
										
										
											2010-03-01 04:11:28 +00:00
										 |  |  | #if !defined(CONFIG_USER_ONLY)
 | 
					
						
							| 
									
										
										
										
											2019-08-01 19:30:12 +01:00
										 |  |  | void sparc_cpu_do_transaction_failed(CPUState *cs, hwaddr physaddr, | 
					
						
							|  |  |  |                                      vaddr addr, unsigned size, | 
					
						
							|  |  |  |                                      MMUAccessType access_type, | 
					
						
							|  |  |  |                                      int mmu_idx, MemTxAttrs attrs, | 
					
						
							|  |  |  |                                      MemTxResult response, uintptr_t retaddr); | 
					
						
							| 
									
										
										
										
											2011-07-22 00:16:30 +09:00
										 |  |  | #if defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2012-10-23 12:30:10 +02:00
										 |  |  | hwaddr cpu_get_phys_page_nofault(CPUSPARCState *env, target_ulong addr, | 
					
						
							| 
									
										
										
										
											2010-05-03 11:29:44 +04:00
										 |  |  |                                            int mmu_idx); | 
					
						
							| 
									
										
										
										
											2011-07-04 20:34:28 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2010-03-01 04:11:28 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:51:05 +02:00
										 |  |  | #define SPARC_CPU_TYPE_SUFFIX "-" TYPE_SPARC_CPU
 | 
					
						
							|  |  |  | #define SPARC_CPU_TYPE_NAME(model) model SPARC_CPU_TYPE_SUFFIX
 | 
					
						
							| 
									
										
										
										
											2018-02-07 11:40:25 +01:00
										 |  |  | #define CPU_RESOLVING_TYPE TYPE_SPARC_CPU
 | 
					
						
							| 
									
										
										
										
											2017-10-05 15:51:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-12 06:47:46 +00:00
										 |  |  | #define cpu_list sparc_cpu_list
 | 
					
						
							| 
									
										
										
										
											2007-06-03 21:02:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-14 07:07:08 +00:00
										 |  |  | /* MMU modes definitions */ | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #if defined (TARGET_SPARC64)
 | 
					
						
							|  |  |  | #define MMU_USER_IDX   0
 | 
					
						
							|  |  |  | #define MMU_USER_SECONDARY_IDX   1
 | 
					
						
							|  |  |  | #define MMU_KERNEL_IDX 2
 | 
					
						
							|  |  |  | #define MMU_KERNEL_SECONDARY_IDX 3
 | 
					
						
							|  |  |  | #define MMU_NUCLEUS_IDX 4
 | 
					
						
							| 
									
										
										
										
											2016-06-09 10:16:03 +02:00
										 |  |  | #define MMU_PHYS_IDX   5
 | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2008-02-14 17:46:44 +00:00
										 |  |  | #define MMU_USER_IDX   0
 | 
					
						
							|  |  |  | #define MMU_KERNEL_IDX 1
 | 
					
						
							| 
									
										
										
										
											2016-07-12 21:01:29 -07:00
										 |  |  | #define MMU_PHYS_IDX   2
 | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if defined (TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | static inline int cpu_has_hypervisor(CPUSPARCState *env1) | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-08-24 18:31:26 +02:00
										 |  |  |     return env1->def.features & CPU_FEATURE_HYPV; | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | static inline int cpu_hypervisor_mode(CPUSPARCState *env1) | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | { | 
					
						
							|  |  |  |     return cpu_has_hypervisor(env1) && (env1->hpstate & HS_PRIV); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | static inline int cpu_supervisor_mode(CPUSPARCState *env1) | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  | { | 
					
						
							|  |  |  |     return env1->pstate & PS_PRIV; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2016-11-01 21:57:01 +01:00
										 |  |  | #else
 | 
					
						
							|  |  |  | static inline int cpu_supervisor_mode(CPUSPARCState *env1) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return env1->psrs; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-05-03 11:29:44 +04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-02-14 17:46:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-12 21:01:29 -07:00
										 |  |  | static inline int cpu_mmu_index(CPUSPARCState *env, bool ifetch) | 
					
						
							| 
									
										
										
										
											2007-10-14 07:07:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-10-14 17:07:21 +00:00
										 |  |  | #if defined(CONFIG_USER_ONLY)
 | 
					
						
							| 
									
										
										
										
											2008-02-14 17:46:44 +00:00
										 |  |  |     return MMU_USER_IDX; | 
					
						
							| 
									
										
										
										
											2007-10-14 17:07:21 +00:00
										 |  |  | #elif !defined(TARGET_SPARC64)
 | 
					
						
							| 
									
										
										
										
											2016-07-12 21:01:29 -07:00
										 |  |  |     if ((env->mmuregs[0] & MMU_E) == 0) { /* MMU disabled */ | 
					
						
							|  |  |  |         return MMU_PHYS_IDX; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return env->psrs; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2007-10-14 17:07:21 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-07-12 21:01:29 -07:00
										 |  |  |     /* IMMU or DMMU disabled.  */ | 
					
						
							|  |  |  |     if (ifetch | 
					
						
							|  |  |  |         ? (env->lsu & IMMU_E) == 0 || (env->pstate & PS_RED) != 0 | 
					
						
							|  |  |  |         : (env->lsu & DMMU_E) == 0) { | 
					
						
							|  |  |  |         return MMU_PHYS_IDX; | 
					
						
							|  |  |  |     } else if (cpu_hypervisor_mode(env)) { | 
					
						
							| 
									
										
										
										
											2016-06-09 10:16:03 +02:00
										 |  |  |         return MMU_PHYS_IDX; | 
					
						
							| 
									
										
										
										
											2016-03-02 14:53:38 +01:00
										 |  |  |     } else if (env->tl > 0) { | 
					
						
							|  |  |  |         return MMU_NUCLEUS_IDX; | 
					
						
							| 
									
										
										
										
											2016-07-12 21:01:29 -07:00
										 |  |  |     } else if (cpu_supervisor_mode(env)) { | 
					
						
							| 
									
										
										
										
											2010-05-22 14:52:24 +04:00
										 |  |  |         return MMU_KERNEL_IDX; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |         return MMU_USER_IDX; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2007-10-14 17:07:21 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | static inline int cpu_interrupts_enabled(CPUSPARCState *env1) | 
					
						
							| 
									
										
										
										
											2010-01-07 23:28:26 +03:00
										 |  |  | { | 
					
						
							|  |  |  | #if !defined (TARGET_SPARC64)
 | 
					
						
							|  |  |  |     if (env1->psret != 0) | 
					
						
							|  |  |  |         return 1; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-06-12 22:19:43 +02:00
										 |  |  |     if ((env1->pstate & PS_IE) && !cpu_hypervisor_mode(env1)) { | 
					
						
							| 
									
										
										
										
											2010-01-07 23:28:26 +03:00
										 |  |  |         return 1; | 
					
						
							| 
									
										
										
										
											2016-06-12 22:19:43 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-01-07 23:28:26 +03:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | static inline int cpu_pil_allowed(CPUSPARCState *env1, int pil) | 
					
						
							| 
									
										
										
										
											2010-01-07 23:28:31 +03:00
										 |  |  | { | 
					
						
							|  |  |  | #if !defined(TARGET_SPARC64)
 | 
					
						
							|  |  |  |     /* level 15 is non-maskable on sparc v8 */ | 
					
						
							|  |  |  |     return pil == 15 || pil > env1->psrpil; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return pil > env1->psrpil; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-17 18:19:49 +01:00
										 |  |  | #include "exec/cpu-all.h"
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-03 19:04:42 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							|  |  |  | /* sun4u.c */ | 
					
						
							| 
									
										
										
										
											2010-01-28 00:00:53 +03:00
										 |  |  | void cpu_tick_set_count(CPUTimer *timer, uint64_t count); | 
					
						
							|  |  |  | uint64_t cpu_tick_get_count(CPUTimer *timer); | 
					
						
							|  |  |  | void cpu_tick_set_limit(CPUTimer *timer, uint64_t limit); | 
					
						
							| 
									
										
										
										
											2012-03-14 01:38:22 +01:00
										 |  |  | trap_state* cpu_tsptr(CPUSPARCState* env); | 
					
						
							| 
									
										
										
										
											2008-10-03 19:04:42 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  | #define TB_FLAG_MMU_MASK     7
 | 
					
						
							|  |  |  | #define TB_FLAG_FPU_ENABLED  (1 << 4)
 | 
					
						
							|  |  |  | #define TB_FLAG_AM_ENABLED   (1 << 5)
 | 
					
						
							| 
									
										
										
										
											2016-11-01 21:57:01 +01:00
										 |  |  | #define TB_FLAG_SUPER        (1 << 6)
 | 
					
						
							|  |  |  | #define TB_FLAG_HYPER        (1 << 7)
 | 
					
						
							| 
									
										
										
										
											2015-09-03 14:14:33 -07:00
										 |  |  | #define TB_FLAG_ASI_SHIFT    24
 | 
					
						
							| 
									
										
										
										
											2011-07-14 17:30:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-21 15:56:24 +02:00
										 |  |  | static inline void cpu_get_tb_cpu_state(CPUSPARCState *env, vaddr *pc, | 
					
						
							|  |  |  |                                         uint64_t *cs_base, uint32_t *pflags) | 
					
						
							| 
									
										
										
										
											2008-11-18 19:46:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  |     uint32_t flags; | 
					
						
							| 
									
										
										
										
											2008-11-18 19:46:41 +00:00
										 |  |  |     *pc = env->pc; | 
					
						
							|  |  |  |     *cs_base = env->npc; | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  |     flags = cpu_mmu_index(env, false); | 
					
						
							| 
									
										
										
										
											2016-11-01 21:57:01 +01:00
										 |  |  | #ifndef CONFIG_USER_ONLY
 | 
					
						
							|  |  |  |     if (cpu_supervisor_mode(env)) { | 
					
						
							|  |  |  |         flags |= TB_FLAG_SUPER; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-11-18 19:46:41 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							| 
									
										
										
										
											2016-11-01 21:57:01 +01:00
										 |  |  | #ifndef CONFIG_USER_ONLY
 | 
					
						
							|  |  |  |     if (cpu_hypervisor_mode(env)) { | 
					
						
							|  |  |  |         flags |= TB_FLAG_HYPER; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-07-14 17:30:43 +00:00
										 |  |  |     if (env->pstate & PS_AM) { | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  |         flags |= TB_FLAG_AM_ENABLED; | 
					
						
							| 
									
										
										
										
											2011-07-14 17:30:43 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-10-11 20:34:14 -07:00
										 |  |  |     if ((env->pstate & PS_PEF) && (env->fprs & FPRS_FEF)) { | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  |         flags |= TB_FLAG_FPU_ENABLED; | 
					
						
							| 
									
										
										
										
											2011-07-14 17:30:43 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-03 14:14:33 -07:00
										 |  |  |     flags |= env->asi << TB_FLAG_ASI_SHIFT; | 
					
						
							| 
									
										
										
										
											2008-11-18 19:46:41 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2023-10-11 20:34:14 -07:00
										 |  |  |     if (env->psref) { | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  |         flags |= TB_FLAG_FPU_ENABLED; | 
					
						
							| 
									
										
										
										
											2011-07-14 17:30:43 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-08-24 20:51:21 -07:00
										 |  |  |     *pflags = flags; | 
					
						
							| 
									
										
										
										
											2011-07-14 17:30:43 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline bool tb_fpu_enabled(int tb_flags) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if defined(CONFIG_USER_ONLY)
 | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return tb_flags & TB_FLAG_FPU_ENABLED; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline bool tb_am_enabled(int tb_flags) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifndef TARGET_SPARC64
 | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return tb_flags & TB_FLAG_AM_ENABLED; | 
					
						
							| 
									
										
										
										
											2008-11-18 19:46:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 15:27:38 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							|  |  |  | /* win_helper.c */ | 
					
						
							|  |  |  | target_ulong cpu_get_ccr(CPUSPARCState *env1); | 
					
						
							|  |  |  | void cpu_put_ccr(CPUSPARCState *env1, target_ulong val); | 
					
						
							|  |  |  | target_ulong cpu_get_cwp64(CPUSPARCState *env1); | 
					
						
							|  |  |  | void cpu_put_cwp64(CPUSPARCState *env1, int cwp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline uint64_t sparc64_tstate(CPUSPARCState *env) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     uint64_t tstate = (cpu_get_ccr(env) << 32) | | 
					
						
							|  |  |  |         ((env->asi & 0xff) << 24) | ((env->pstate & 0xf3f) << 8) | | 
					
						
							|  |  |  |         cpu_get_cwp64(env); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (env->def.features & CPU_FEATURE_GL) { | 
					
						
							|  |  |  |         tstate |= (env->gl & 7ULL) << 40; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return tstate; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | #endif
 |