| 
									
										
										
										
											2003-09-30 20:34:21 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *  ARM execution defines | 
					
						
							| 
									
										
										
										
											2007-09-16 21:08:06 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2003-09-30 20:34:21 +00:00
										 |  |  |  *  Copyright (c) 2003 Fabrice Bellard | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							|  |  |  |  * version 2 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
					
						
							|  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Lesser General Public | 
					
						
							| 
									
										
										
										
											2009-07-16 20:47:01 +00:00
										 |  |  |  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:34:21 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-03-19 14:47:40 +00:00
										 |  |  | #include "config.h"
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:34:21 +00:00
										 |  |  | #include "dyngen-exec.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | register struct CPUARMState *env asm(AREG0); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-04-30 02:02:17 +00:00
										 |  |  | #define M0   env->iwmmxt.val
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-30 20:34:21 +00:00
										 |  |  | #include "cpu.h"
 | 
					
						
							|  |  |  | #include "exec-all.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-24 18:03:20 +00:00
										 |  |  | static inline int cpu_has_work(CPUState *env) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return (env->interrupt_request & | 
					
						
							|  |  |  |             (CPU_INTERRUPT_FIQ | CPU_INTERRUPT_HARD | CPU_INTERRUPT_EXITTB)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-03 17:44:37 +00:00
										 |  |  | static inline int cpu_halted(CPUState *env) { | 
					
						
							|  |  |  |     if (!env->halted) | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     /* An interrupt wakes the CPU even if the I and F CPSR bits are
 | 
					
						
							|  |  |  |        set.  We use EXITTB to silently wake CPU without causing an | 
					
						
							|  |  |  |        actual interrupt.  */ | 
					
						
							| 
									
										
										
										
											2009-04-24 18:03:20 +00:00
										 |  |  |     if (cpu_has_work(env)) { | 
					
						
							| 
									
										
										
										
											2007-06-03 17:44:37 +00:00
										 |  |  |         env->halted = 0; | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return EXCP_HALTED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-11-26 10:38:39 +00:00
										 |  |  | #if !defined(CONFIG_USER_ONLY)
 | 
					
						
							|  |  |  | #include "softmmu_exec.h"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-02-22 19:27:29 +00:00
										 |  |  | void raise_exception(int); |