| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | #ifndef EXEC_SPARC_H
 | 
					
						
							|  |  |  | #define EXEC_SPARC_H 1
 | 
					
						
							|  |  |  | #include "dyngen-exec.h"
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #include "config.h"
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | register struct CPUSPARCState *env asm(AREG0); | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							|  |  |  | #define T0 (env->t0)
 | 
					
						
							|  |  |  | #define T1 (env->t1)
 | 
					
						
							|  |  |  | #define T2 (env->t2)
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define REGWPTR env->regwptr
 | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | register uint32_t T0 asm(AREG1); | 
					
						
							|  |  |  | register uint32_t T1 asm(AREG2); | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #undef REG_REGWPTR // Broken
 | 
					
						
							|  |  |  | #ifdef REG_REGWPTR
 | 
					
						
							|  |  |  | register uint32_t *REGWPTR asm(AREG3); | 
					
						
							|  |  |  | #define reg_REGWPTR
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef AREG4
 | 
					
						
							|  |  |  | register uint32_t T2 asm(AREG4); | 
					
						
							|  |  |  | #define reg_T2
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define T2 (env->t2)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define REGWPTR env->regwptr
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | register uint32_t T2 asm(AREG3); | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #define reg_T2
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #define FT0 (env->ft0)
 | 
					
						
							|  |  |  | #define FT1 (env->ft1)
 | 
					
						
							|  |  |  | #define DT0 (env->dt0)
 | 
					
						
							|  |  |  | #define DT1 (env->dt1)
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "cpu.h"
 | 
					
						
							|  |  |  | #include "exec-all.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void cpu_lock(void); | 
					
						
							|  |  |  | void cpu_unlock(void); | 
					
						
							|  |  |  | void cpu_loop_exit(void); | 
					
						
							| 
									
										
										
										
											2004-04-25 17:56:08 +00:00
										 |  |  | void helper_flush(target_ulong addr); | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | void helper_ld_asi(int asi, int size, int sign); | 
					
						
							|  |  |  | void helper_st_asi(int asi, int size, int sign); | 
					
						
							|  |  |  | void helper_rett(void); | 
					
						
							| 
									
										
										
										
											2004-10-04 21:23:09 +00:00
										 |  |  | void helper_ldfsr(void); | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | void set_cwp(int new_cwp); | 
					
						
							| 
									
										
										
										
											2004-10-10 17:46:24 +00:00
										 |  |  | void do_fitos(void); | 
					
						
							|  |  |  | void do_fitod(void); | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | void do_fabss(void); | 
					
						
							|  |  |  | void do_fsqrts(void); | 
					
						
							|  |  |  | void do_fsqrtd(void); | 
					
						
							|  |  |  | void do_fcmps(void); | 
					
						
							|  |  |  | void do_fcmpd(void); | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #ifdef TARGET_SPARC64
 | 
					
						
							|  |  |  | void do_fabsd(void); | 
					
						
							|  |  |  | void do_fcmps_fcc1(void); | 
					
						
							|  |  |  | void do_fcmpd_fcc1(void); | 
					
						
							|  |  |  | void do_fcmps_fcc2(void); | 
					
						
							|  |  |  | void do_fcmpd_fcc2(void); | 
					
						
							|  |  |  | void do_fcmps_fcc3(void); | 
					
						
							|  |  |  | void do_fcmpd_fcc3(void); | 
					
						
							|  |  |  | void do_popc(); | 
					
						
							| 
									
										
										
										
											2005-07-23 14:27:54 +00:00
										 |  |  | void do_wrpstate(); | 
					
						
							|  |  |  | void do_done(); | 
					
						
							|  |  |  | void do_retry(); | 
					
						
							| 
									
										
										
										
											2005-07-02 14:31:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | void do_ldd_kernel(target_ulong addr); | 
					
						
							|  |  |  | void do_ldd_user(target_ulong addr); | 
					
						
							|  |  |  | void do_ldd_raw(target_ulong addr); | 
					
						
							| 
									
										
										
										
											2005-02-13 19:02:42 +00:00
										 |  |  | void do_interrupt(int intno); | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | void raise_exception(int tt); | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | void memcpy32(target_ulong *dst, const target_ulong *src); | 
					
						
							| 
									
										
										
										
											2005-07-04 22:18:23 +00:00
										 |  |  | target_ulong mmu_probe(CPUState *env, target_ulong address, int mmulev); | 
					
						
							|  |  |  | void dump_mmu(CPUState *env); | 
					
						
							| 
									
										
										
										
											2004-12-19 23:18:01 +00:00
										 |  |  | void helper_debug(); | 
					
						
							| 
									
										
										
										
											2005-01-30 22:39:04 +00:00
										 |  |  | void do_wrpsr(); | 
					
						
							|  |  |  | void do_rdpsr(); | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* XXX: move that to a generic header */ | 
					
						
							|  |  |  | #if !defined(CONFIG_USER_ONLY)
 | 
					
						
							| 
									
										
										
										
											2005-10-30 18:16:26 +00:00
										 |  |  | #include "softmmu_exec.h"
 | 
					
						
							| 
									
										
										
										
											2004-09-30 21:55:55 +00:00
										 |  |  | #endif /* !defined(CONFIG_USER_ONLY) */
 | 
					
						
							| 
									
										
										
										
											2004-10-12 22:01:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static inline void env_to_regs(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-10-30 17:06:11 +00:00
										 |  |  | #if defined(reg_REGWPTR)
 | 
					
						
							|  |  |  |     REGWPTR = env->regbase + (env->cwp * 16); | 
					
						
							|  |  |  |     env->regwptr = REGWPTR; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2004-10-12 22:01:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void regs_to_env(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-02-07 23:10:53 +00:00
										 |  |  | int cpu_sparc_handle_mmu_fault(CPUState *env, target_ulong address, int rw, | 
					
						
							|  |  |  |                                int is_user, int is_softmmu); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:36:07 +00:00
										 |  |  | #endif
 |