xref: /openbmc/qemu/linux-user/main.c (revision 6350b2a09b8a330cbfaea462a34bbb1b8c63d7b1)
1 /*
2  *  qemu user main
3  *
4  *  Copyright (c) 2003-2008 Fabrice Bellard
5  *
6  *  This program is free software; you can redistribute it and/or modify
7  *  it under the terms of the GNU General Public License as published by
8  *  the Free Software Foundation; either version 2 of the License, or
9  *  (at your option) any later version.
10  *
11  *  This program is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  *  GNU General Public License for more details.
15  *
16  *  You should have received a copy of the GNU General Public License
17  *  along with this program; if not, see <http://www.gnu.org/licenses/>.
18  */
19 #include "qemu/osdep.h"
20 #include "qemu-version.h"
21 #include <sys/syscall.h>
22 #include <sys/resource.h>
23 
24 #include "qapi/error.h"
25 #include "qemu.h"
26 #include "qemu/path.h"
27 #include "qemu/config-file.h"
28 #include "qemu/cutils.h"
29 #include "qemu/help_option.h"
30 #include "cpu.h"
31 #include "exec/exec-all.h"
32 #include "tcg.h"
33 #include "qemu/timer.h"
34 #include "qemu/envlist.h"
35 #include "elf.h"
36 #include "exec/log.h"
37 #include "trace/control.h"
38 #include "glib-compat.h"
39 
40 char *exec_path;
41 
42 int singlestep;
43 static const char *filename;
44 static const char *argv0;
45 static int gdbstub_port;
46 static envlist_t *envlist;
47 static const char *cpu_model;
48 unsigned long mmap_min_addr;
49 unsigned long guest_base;
50 int have_guest_base;
51 
52 #define EXCP_DUMP(env, fmt, ...)                                        \
53 do {                                                                    \
54     CPUState *cs = ENV_GET_CPU(env);                                    \
55     fprintf(stderr, fmt , ## __VA_ARGS__);                              \
56     cpu_dump_state(cs, stderr, fprintf, 0);                             \
57     if (qemu_log_separate()) {                                          \
58         qemu_log(fmt, ## __VA_ARGS__);                                  \
59         log_cpu_state(cs, 0);                                           \
60     }                                                                   \
61 } while (0)
62 
63 /*
64  * When running 32-on-64 we should make sure we can fit all of the possible
65  * guest address space into a contiguous chunk of virtual host memory.
66  *
67  * This way we will never overlap with our own libraries or binaries or stack
68  * or anything else that QEMU maps.
69  *
70  * Many cpus reserve the high bit (or more than one for some 64-bit cpus)
71  * of the address for the kernel.  Some cpus rely on this and user space
72  * uses the high bit(s) for pointer tagging and the like.  For them, we
73  * must preserve the expected address space.
74  */
75 #ifndef MAX_RESERVED_VA
76 # if HOST_LONG_BITS > TARGET_VIRT_ADDR_SPACE_BITS
77 #  if TARGET_VIRT_ADDR_SPACE_BITS == 32 && \
78       (TARGET_LONG_BITS == 32 || defined(TARGET_ABI32))
79 /* There are a number of places where we assign reserved_va to a variable
80    of type abi_ulong and expect it to fit.  Avoid the last page.  */
81 #   define MAX_RESERVED_VA  (0xfffffffful & TARGET_PAGE_MASK)
82 #  else
83 #   define MAX_RESERVED_VA  (1ul << TARGET_VIRT_ADDR_SPACE_BITS)
84 #  endif
85 # else
86 #  define MAX_RESERVED_VA  0
87 # endif
88 #endif
89 
90 /* That said, reserving *too* much vm space via mmap can run into problems
91    with rlimits, oom due to page table creation, etc.  We will still try it,
92    if directed by the command-line option, but not by default.  */
93 #if HOST_LONG_BITS == 64 && TARGET_VIRT_ADDR_SPACE_BITS <= 32
94 unsigned long reserved_va = MAX_RESERVED_VA;
95 #else
96 unsigned long reserved_va;
97 #endif
98 
99 static void usage(int exitcode);
100 
101 static const char *interp_prefix = CONFIG_QEMU_INTERP_PREFIX;
102 const char *qemu_uname_release;
103 
104 /* XXX: on x86 MAP_GROWSDOWN only works if ESP <= address + 32, so
105    we allocate a bigger stack. Need a better solution, for example
106    by remapping the process stack directly at the right place */
107 unsigned long guest_stack_size = 8 * 1024 * 1024UL;
108 
109 void gemu_log(const char *fmt, ...)
110 {
111     va_list ap;
112 
113     va_start(ap, fmt);
114     vfprintf(stderr, fmt, ap);
115     va_end(ap);
116 }
117 
118 #if defined(TARGET_I386)
119 int cpu_get_pic_interrupt(CPUX86State *env)
120 {
121     return -1;
122 }
123 #endif
124 
125 /***********************************************************/
126 /* Helper routines for implementing atomic operations.  */
127 
128 /* Make sure everything is in a consistent state for calling fork().  */
129 void fork_start(void)
130 {
131     cpu_list_lock();
132     qemu_mutex_lock(&tb_ctx.tb_lock);
133     mmap_fork_start();
134 }
135 
136 void fork_end(int child)
137 {
138     mmap_fork_end(child);
139     if (child) {
140         CPUState *cpu, *next_cpu;
141         /* Child processes created by fork() only have a single thread.
142            Discard information about the parent threads.  */
143         CPU_FOREACH_SAFE(cpu, next_cpu) {
144             if (cpu != thread_cpu) {
145                 QTAILQ_REMOVE(&cpus, cpu, node);
146             }
147         }
148         qemu_mutex_init(&tb_ctx.tb_lock);
149         qemu_init_cpu_list();
150         gdbserver_fork(thread_cpu);
151     } else {
152         qemu_mutex_unlock(&tb_ctx.tb_lock);
153         cpu_list_unlock();
154     }
155 }
156 
157 #ifdef TARGET_I386
158 /***********************************************************/
159 /* CPUX86 core interface */
160 
161 uint64_t cpu_get_tsc(CPUX86State *env)
162 {
163     return cpu_get_host_ticks();
164 }
165 
166 static void write_dt(void *ptr, unsigned long addr, unsigned long limit,
167                      int flags)
168 {
169     unsigned int e1, e2;
170     uint32_t *p;
171     e1 = (addr << 16) | (limit & 0xffff);
172     e2 = ((addr >> 16) & 0xff) | (addr & 0xff000000) | (limit & 0x000f0000);
173     e2 |= flags;
174     p = ptr;
175     p[0] = tswap32(e1);
176     p[1] = tswap32(e2);
177 }
178 
179 static uint64_t *idt_table;
180 #ifdef TARGET_X86_64
181 static void set_gate64(void *ptr, unsigned int type, unsigned int dpl,
182                        uint64_t addr, unsigned int sel)
183 {
184     uint32_t *p, e1, e2;
185     e1 = (addr & 0xffff) | (sel << 16);
186     e2 = (addr & 0xffff0000) | 0x8000 | (dpl << 13) | (type << 8);
187     p = ptr;
188     p[0] = tswap32(e1);
189     p[1] = tswap32(e2);
190     p[2] = tswap32(addr >> 32);
191     p[3] = 0;
192 }
193 /* only dpl matters as we do only user space emulation */
194 static void set_idt(int n, unsigned int dpl)
195 {
196     set_gate64(idt_table + n * 2, 0, dpl, 0, 0);
197 }
198 #else
199 static void set_gate(void *ptr, unsigned int type, unsigned int dpl,
200                      uint32_t addr, unsigned int sel)
201 {
202     uint32_t *p, e1, e2;
203     e1 = (addr & 0xffff) | (sel << 16);
204     e2 = (addr & 0xffff0000) | 0x8000 | (dpl << 13) | (type << 8);
205     p = ptr;
206     p[0] = tswap32(e1);
207     p[1] = tswap32(e2);
208 }
209 
210 /* only dpl matters as we do only user space emulation */
211 static void set_idt(int n, unsigned int dpl)
212 {
213     set_gate(idt_table + n, 0, dpl, 0, 0);
214 }
215 #endif
216 
217 void cpu_loop(CPUX86State *env)
218 {
219     CPUState *cs = CPU(x86_env_get_cpu(env));
220     int trapnr;
221     abi_ulong pc;
222     abi_ulong ret;
223     target_siginfo_t info;
224 
225     for(;;) {
226         cpu_exec_start(cs);
227         trapnr = cpu_exec(cs);
228         cpu_exec_end(cs);
229         process_queued_cpu_work(cs);
230 
231         switch(trapnr) {
232         case 0x80:
233             /* linux syscall from int $0x80 */
234             ret = do_syscall(env,
235                              env->regs[R_EAX],
236                              env->regs[R_EBX],
237                              env->regs[R_ECX],
238                              env->regs[R_EDX],
239                              env->regs[R_ESI],
240                              env->regs[R_EDI],
241                              env->regs[R_EBP],
242                              0, 0);
243             if (ret == -TARGET_ERESTARTSYS) {
244                 env->eip -= 2;
245             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
246                 env->regs[R_EAX] = ret;
247             }
248             break;
249 #ifndef TARGET_ABI32
250         case EXCP_SYSCALL:
251             /* linux syscall from syscall instruction */
252             ret = do_syscall(env,
253                              env->regs[R_EAX],
254                              env->regs[R_EDI],
255                              env->regs[R_ESI],
256                              env->regs[R_EDX],
257                              env->regs[10],
258                              env->regs[8],
259                              env->regs[9],
260                              0, 0);
261             if (ret == -TARGET_ERESTARTSYS) {
262                 env->eip -= 2;
263             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
264                 env->regs[R_EAX] = ret;
265             }
266             break;
267 #endif
268         case EXCP0B_NOSEG:
269         case EXCP0C_STACK:
270             info.si_signo = TARGET_SIGBUS;
271             info.si_errno = 0;
272             info.si_code = TARGET_SI_KERNEL;
273             info._sifields._sigfault._addr = 0;
274             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
275             break;
276         case EXCP0D_GPF:
277             /* XXX: potential problem if ABI32 */
278 #ifndef TARGET_X86_64
279             if (env->eflags & VM_MASK) {
280                 handle_vm86_fault(env);
281             } else
282 #endif
283             {
284                 info.si_signo = TARGET_SIGSEGV;
285                 info.si_errno = 0;
286                 info.si_code = TARGET_SI_KERNEL;
287                 info._sifields._sigfault._addr = 0;
288                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
289             }
290             break;
291         case EXCP0E_PAGE:
292             info.si_signo = TARGET_SIGSEGV;
293             info.si_errno = 0;
294             if (!(env->error_code & 1))
295                 info.si_code = TARGET_SEGV_MAPERR;
296             else
297                 info.si_code = TARGET_SEGV_ACCERR;
298             info._sifields._sigfault._addr = env->cr[2];
299             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
300             break;
301         case EXCP00_DIVZ:
302 #ifndef TARGET_X86_64
303             if (env->eflags & VM_MASK) {
304                 handle_vm86_trap(env, trapnr);
305             } else
306 #endif
307             {
308                 /* division by zero */
309                 info.si_signo = TARGET_SIGFPE;
310                 info.si_errno = 0;
311                 info.si_code = TARGET_FPE_INTDIV;
312                 info._sifields._sigfault._addr = env->eip;
313                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
314             }
315             break;
316         case EXCP01_DB:
317         case EXCP03_INT3:
318 #ifndef TARGET_X86_64
319             if (env->eflags & VM_MASK) {
320                 handle_vm86_trap(env, trapnr);
321             } else
322 #endif
323             {
324                 info.si_signo = TARGET_SIGTRAP;
325                 info.si_errno = 0;
326                 if (trapnr == EXCP01_DB) {
327                     info.si_code = TARGET_TRAP_BRKPT;
328                     info._sifields._sigfault._addr = env->eip;
329                 } else {
330                     info.si_code = TARGET_SI_KERNEL;
331                     info._sifields._sigfault._addr = 0;
332                 }
333                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
334             }
335             break;
336         case EXCP04_INTO:
337         case EXCP05_BOUND:
338 #ifndef TARGET_X86_64
339             if (env->eflags & VM_MASK) {
340                 handle_vm86_trap(env, trapnr);
341             } else
342 #endif
343             {
344                 info.si_signo = TARGET_SIGSEGV;
345                 info.si_errno = 0;
346                 info.si_code = TARGET_SI_KERNEL;
347                 info._sifields._sigfault._addr = 0;
348                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
349             }
350             break;
351         case EXCP06_ILLOP:
352             info.si_signo = TARGET_SIGILL;
353             info.si_errno = 0;
354             info.si_code = TARGET_ILL_ILLOPN;
355             info._sifields._sigfault._addr = env->eip;
356             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
357             break;
358         case EXCP_INTERRUPT:
359             /* just indicate that signals should be handled asap */
360             break;
361         case EXCP_DEBUG:
362             {
363                 int sig;
364 
365                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
366                 if (sig)
367                   {
368                     info.si_signo = sig;
369                     info.si_errno = 0;
370                     info.si_code = TARGET_TRAP_BRKPT;
371                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
372                   }
373             }
374             break;
375         case EXCP_ATOMIC:
376             cpu_exec_step_atomic(cs);
377             break;
378         default:
379             pc = env->segs[R_CS].base + env->eip;
380             EXCP_DUMP(env, "qemu: 0x%08lx: unhandled CPU exception 0x%x - aborting\n",
381                       (long)pc, trapnr);
382             abort();
383         }
384         process_pending_signals(env);
385     }
386 }
387 #endif
388 
389 #ifdef TARGET_ARM
390 
391 #define get_user_code_u32(x, gaddr, env)                \
392     ({ abi_long __r = get_user_u32((x), (gaddr));       \
393         if (!__r && bswap_code(arm_sctlr_b(env))) {     \
394             (x) = bswap32(x);                           \
395         }                                               \
396         __r;                                            \
397     })
398 
399 #define get_user_code_u16(x, gaddr, env)                \
400     ({ abi_long __r = get_user_u16((x), (gaddr));       \
401         if (!__r && bswap_code(arm_sctlr_b(env))) {     \
402             (x) = bswap16(x);                           \
403         }                                               \
404         __r;                                            \
405     })
406 
407 #define get_user_data_u32(x, gaddr, env)                \
408     ({ abi_long __r = get_user_u32((x), (gaddr));       \
409         if (!__r && arm_cpu_bswap_data(env)) {          \
410             (x) = bswap32(x);                           \
411         }                                               \
412         __r;                                            \
413     })
414 
415 #define get_user_data_u16(x, gaddr, env)                \
416     ({ abi_long __r = get_user_u16((x), (gaddr));       \
417         if (!__r && arm_cpu_bswap_data(env)) {          \
418             (x) = bswap16(x);                           \
419         }                                               \
420         __r;                                            \
421     })
422 
423 #define put_user_data_u32(x, gaddr, env)                \
424     ({ typeof(x) __x = (x);                             \
425         if (arm_cpu_bswap_data(env)) {                  \
426             __x = bswap32(__x);                         \
427         }                                               \
428         put_user_u32(__x, (gaddr));                     \
429     })
430 
431 #define put_user_data_u16(x, gaddr, env)                \
432     ({ typeof(x) __x = (x);                             \
433         if (arm_cpu_bswap_data(env)) {                  \
434             __x = bswap16(__x);                         \
435         }                                               \
436         put_user_u16(__x, (gaddr));                     \
437     })
438 
439 #ifdef TARGET_ABI32
440 /* Commpage handling -- there is no commpage for AArch64 */
441 
442 /*
443  * See the Linux kernel's Documentation/arm/kernel_user_helpers.txt
444  * Input:
445  * r0 = pointer to oldval
446  * r1 = pointer to newval
447  * r2 = pointer to target value
448  *
449  * Output:
450  * r0 = 0 if *ptr was changed, non-0 if no exchange happened
451  * C set if *ptr was changed, clear if no exchange happened
452  *
453  * Note segv's in kernel helpers are a bit tricky, we can set the
454  * data address sensibly but the PC address is just the entry point.
455  */
456 static void arm_kernel_cmpxchg64_helper(CPUARMState *env)
457 {
458     uint64_t oldval, newval, val;
459     uint32_t addr, cpsr;
460     target_siginfo_t info;
461 
462     /* Based on the 32 bit code in do_kernel_trap */
463 
464     /* XXX: This only works between threads, not between processes.
465        It's probably possible to implement this with native host
466        operations. However things like ldrex/strex are much harder so
467        there's not much point trying.  */
468     start_exclusive();
469     cpsr = cpsr_read(env);
470     addr = env->regs[2];
471 
472     if (get_user_u64(oldval, env->regs[0])) {
473         env->exception.vaddress = env->regs[0];
474         goto segv;
475     };
476 
477     if (get_user_u64(newval, env->regs[1])) {
478         env->exception.vaddress = env->regs[1];
479         goto segv;
480     };
481 
482     if (get_user_u64(val, addr)) {
483         env->exception.vaddress = addr;
484         goto segv;
485     }
486 
487     if (val == oldval) {
488         val = newval;
489 
490         if (put_user_u64(val, addr)) {
491             env->exception.vaddress = addr;
492             goto segv;
493         };
494 
495         env->regs[0] = 0;
496         cpsr |= CPSR_C;
497     } else {
498         env->regs[0] = -1;
499         cpsr &= ~CPSR_C;
500     }
501     cpsr_write(env, cpsr, CPSR_C, CPSRWriteByInstr);
502     end_exclusive();
503     return;
504 
505 segv:
506     end_exclusive();
507     /* We get the PC of the entry address - which is as good as anything,
508        on a real kernel what you get depends on which mode it uses. */
509     info.si_signo = TARGET_SIGSEGV;
510     info.si_errno = 0;
511     /* XXX: check env->error_code */
512     info.si_code = TARGET_SEGV_MAPERR;
513     info._sifields._sigfault._addr = env->exception.vaddress;
514     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
515 }
516 
517 /* Handle a jump to the kernel code page.  */
518 static int
519 do_kernel_trap(CPUARMState *env)
520 {
521     uint32_t addr;
522     uint32_t cpsr;
523     uint32_t val;
524 
525     switch (env->regs[15]) {
526     case 0xffff0fa0: /* __kernel_memory_barrier */
527         /* ??? No-op. Will need to do better for SMP.  */
528         break;
529     case 0xffff0fc0: /* __kernel_cmpxchg */
530          /* XXX: This only works between threads, not between processes.
531             It's probably possible to implement this with native host
532             operations. However things like ldrex/strex are much harder so
533             there's not much point trying.  */
534         start_exclusive();
535         cpsr = cpsr_read(env);
536         addr = env->regs[2];
537         /* FIXME: This should SEGV if the access fails.  */
538         if (get_user_u32(val, addr))
539             val = ~env->regs[0];
540         if (val == env->regs[0]) {
541             val = env->regs[1];
542             /* FIXME: Check for segfaults.  */
543             put_user_u32(val, addr);
544             env->regs[0] = 0;
545             cpsr |= CPSR_C;
546         } else {
547             env->regs[0] = -1;
548             cpsr &= ~CPSR_C;
549         }
550         cpsr_write(env, cpsr, CPSR_C, CPSRWriteByInstr);
551         end_exclusive();
552         break;
553     case 0xffff0fe0: /* __kernel_get_tls */
554         env->regs[0] = cpu_get_tls(env);
555         break;
556     case 0xffff0f60: /* __kernel_cmpxchg64 */
557         arm_kernel_cmpxchg64_helper(env);
558         break;
559 
560     default:
561         return 1;
562     }
563     /* Jump back to the caller.  */
564     addr = env->regs[14];
565     if (addr & 1) {
566         env->thumb = 1;
567         addr &= ~1;
568     }
569     env->regs[15] = addr;
570 
571     return 0;
572 }
573 
574 void cpu_loop(CPUARMState *env)
575 {
576     CPUState *cs = CPU(arm_env_get_cpu(env));
577     int trapnr;
578     unsigned int n, insn;
579     target_siginfo_t info;
580     uint32_t addr;
581     abi_ulong ret;
582 
583     for(;;) {
584         cpu_exec_start(cs);
585         trapnr = cpu_exec(cs);
586         cpu_exec_end(cs);
587         process_queued_cpu_work(cs);
588 
589         switch(trapnr) {
590         case EXCP_UDEF:
591         case EXCP_NOCP:
592         case EXCP_INVSTATE:
593             {
594                 TaskState *ts = cs->opaque;
595                 uint32_t opcode;
596                 int rc;
597 
598                 /* we handle the FPU emulation here, as Linux */
599                 /* we get the opcode */
600                 /* FIXME - what to do if get_user() fails? */
601                 get_user_code_u32(opcode, env->regs[15], env);
602 
603                 rc = EmulateAll(opcode, &ts->fpa, env);
604                 if (rc == 0) { /* illegal instruction */
605                     info.si_signo = TARGET_SIGILL;
606                     info.si_errno = 0;
607                     info.si_code = TARGET_ILL_ILLOPN;
608                     info._sifields._sigfault._addr = env->regs[15];
609                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
610                 } else if (rc < 0) { /* FP exception */
611                     int arm_fpe=0;
612 
613                     /* translate softfloat flags to FPSR flags */
614                     if (-rc & float_flag_invalid)
615                       arm_fpe |= BIT_IOC;
616                     if (-rc & float_flag_divbyzero)
617                       arm_fpe |= BIT_DZC;
618                     if (-rc & float_flag_overflow)
619                       arm_fpe |= BIT_OFC;
620                     if (-rc & float_flag_underflow)
621                       arm_fpe |= BIT_UFC;
622                     if (-rc & float_flag_inexact)
623                       arm_fpe |= BIT_IXC;
624 
625                     FPSR fpsr = ts->fpa.fpsr;
626                     //printf("fpsr 0x%x, arm_fpe 0x%x\n",fpsr,arm_fpe);
627 
628                     if (fpsr & (arm_fpe << 16)) { /* exception enabled? */
629                       info.si_signo = TARGET_SIGFPE;
630                       info.si_errno = 0;
631 
632                       /* ordered by priority, least first */
633                       if (arm_fpe & BIT_IXC) info.si_code = TARGET_FPE_FLTRES;
634                       if (arm_fpe & BIT_UFC) info.si_code = TARGET_FPE_FLTUND;
635                       if (arm_fpe & BIT_OFC) info.si_code = TARGET_FPE_FLTOVF;
636                       if (arm_fpe & BIT_DZC) info.si_code = TARGET_FPE_FLTDIV;
637                       if (arm_fpe & BIT_IOC) info.si_code = TARGET_FPE_FLTINV;
638 
639                       info._sifields._sigfault._addr = env->regs[15];
640                       queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
641                     } else {
642                       env->regs[15] += 4;
643                     }
644 
645                     /* accumulate unenabled exceptions */
646                     if ((!(fpsr & BIT_IXE)) && (arm_fpe & BIT_IXC))
647                       fpsr |= BIT_IXC;
648                     if ((!(fpsr & BIT_UFE)) && (arm_fpe & BIT_UFC))
649                       fpsr |= BIT_UFC;
650                     if ((!(fpsr & BIT_OFE)) && (arm_fpe & BIT_OFC))
651                       fpsr |= BIT_OFC;
652                     if ((!(fpsr & BIT_DZE)) && (arm_fpe & BIT_DZC))
653                       fpsr |= BIT_DZC;
654                     if ((!(fpsr & BIT_IOE)) && (arm_fpe & BIT_IOC))
655                       fpsr |= BIT_IOC;
656                     ts->fpa.fpsr=fpsr;
657                 } else { /* everything OK */
658                     /* increment PC */
659                     env->regs[15] += 4;
660                 }
661             }
662             break;
663         case EXCP_SWI:
664         case EXCP_BKPT:
665             {
666                 env->eabi = 1;
667                 /* system call */
668                 if (trapnr == EXCP_BKPT) {
669                     if (env->thumb) {
670                         /* FIXME - what to do if get_user() fails? */
671                         get_user_code_u16(insn, env->regs[15], env);
672                         n = insn & 0xff;
673                         env->regs[15] += 2;
674                     } else {
675                         /* FIXME - what to do if get_user() fails? */
676                         get_user_code_u32(insn, env->regs[15], env);
677                         n = (insn & 0xf) | ((insn >> 4) & 0xff0);
678                         env->regs[15] += 4;
679                     }
680                 } else {
681                     if (env->thumb) {
682                         /* FIXME - what to do if get_user() fails? */
683                         get_user_code_u16(insn, env->regs[15] - 2, env);
684                         n = insn & 0xff;
685                     } else {
686                         /* FIXME - what to do if get_user() fails? */
687                         get_user_code_u32(insn, env->regs[15] - 4, env);
688                         n = insn & 0xffffff;
689                     }
690                 }
691 
692                 if (n == ARM_NR_cacheflush) {
693                     /* nop */
694                 } else if (n == ARM_NR_semihosting
695                            || n == ARM_NR_thumb_semihosting) {
696                     env->regs[0] = do_arm_semihosting (env);
697                 } else if (n == 0 || n >= ARM_SYSCALL_BASE || env->thumb) {
698                     /* linux syscall */
699                     if (env->thumb || n == 0) {
700                         n = env->regs[7];
701                     } else {
702                         n -= ARM_SYSCALL_BASE;
703                         env->eabi = 0;
704                     }
705                     if ( n > ARM_NR_BASE) {
706                         switch (n) {
707                         case ARM_NR_cacheflush:
708                             /* nop */
709                             break;
710                         case ARM_NR_set_tls:
711                             cpu_set_tls(env, env->regs[0]);
712                             env->regs[0] = 0;
713                             break;
714                         case ARM_NR_breakpoint:
715                             env->regs[15] -= env->thumb ? 2 : 4;
716                             goto excp_debug;
717                         default:
718                             gemu_log("qemu: Unsupported ARM syscall: 0x%x\n",
719                                      n);
720                             env->regs[0] = -TARGET_ENOSYS;
721                             break;
722                         }
723                     } else {
724                         ret = do_syscall(env,
725                                          n,
726                                          env->regs[0],
727                                          env->regs[1],
728                                          env->regs[2],
729                                          env->regs[3],
730                                          env->regs[4],
731                                          env->regs[5],
732                                          0, 0);
733                         if (ret == -TARGET_ERESTARTSYS) {
734                             env->regs[15] -= env->thumb ? 2 : 4;
735                         } else if (ret != -TARGET_QEMU_ESIGRETURN) {
736                             env->regs[0] = ret;
737                         }
738                     }
739                 } else {
740                     goto error;
741                 }
742             }
743             break;
744         case EXCP_SEMIHOST:
745             env->regs[0] = do_arm_semihosting(env);
746             break;
747         case EXCP_INTERRUPT:
748             /* just indicate that signals should be handled asap */
749             break;
750         case EXCP_PREFETCH_ABORT:
751         case EXCP_DATA_ABORT:
752             addr = env->exception.vaddress;
753             {
754                 info.si_signo = TARGET_SIGSEGV;
755                 info.si_errno = 0;
756                 /* XXX: check env->error_code */
757                 info.si_code = TARGET_SEGV_MAPERR;
758                 info._sifields._sigfault._addr = addr;
759                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
760             }
761             break;
762         case EXCP_DEBUG:
763         excp_debug:
764             {
765                 int sig;
766 
767                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
768                 if (sig)
769                   {
770                     info.si_signo = sig;
771                     info.si_errno = 0;
772                     info.si_code = TARGET_TRAP_BRKPT;
773                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
774                   }
775             }
776             break;
777         case EXCP_KERNEL_TRAP:
778             if (do_kernel_trap(env))
779               goto error;
780             break;
781         case EXCP_YIELD:
782             /* nothing to do here for user-mode, just resume guest code */
783             break;
784         case EXCP_ATOMIC:
785             cpu_exec_step_atomic(cs);
786             break;
787         default:
788         error:
789             EXCP_DUMP(env, "qemu: unhandled CPU exception 0x%x - aborting\n", trapnr);
790             abort();
791         }
792         process_pending_signals(env);
793     }
794 }
795 
796 #else
797 
798 /* AArch64 main loop */
799 void cpu_loop(CPUARMState *env)
800 {
801     CPUState *cs = CPU(arm_env_get_cpu(env));
802     int trapnr, sig;
803     abi_long ret;
804     target_siginfo_t info;
805 
806     for (;;) {
807         cpu_exec_start(cs);
808         trapnr = cpu_exec(cs);
809         cpu_exec_end(cs);
810         process_queued_cpu_work(cs);
811 
812         switch (trapnr) {
813         case EXCP_SWI:
814             ret = do_syscall(env,
815                              env->xregs[8],
816                              env->xregs[0],
817                              env->xregs[1],
818                              env->xregs[2],
819                              env->xregs[3],
820                              env->xregs[4],
821                              env->xregs[5],
822                              0, 0);
823             if (ret == -TARGET_ERESTARTSYS) {
824                 env->pc -= 4;
825             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
826                 env->xregs[0] = ret;
827             }
828             break;
829         case EXCP_INTERRUPT:
830             /* just indicate that signals should be handled asap */
831             break;
832         case EXCP_UDEF:
833             info.si_signo = TARGET_SIGILL;
834             info.si_errno = 0;
835             info.si_code = TARGET_ILL_ILLOPN;
836             info._sifields._sigfault._addr = env->pc;
837             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
838             break;
839         case EXCP_PREFETCH_ABORT:
840         case EXCP_DATA_ABORT:
841             info.si_signo = TARGET_SIGSEGV;
842             info.si_errno = 0;
843             /* XXX: check env->error_code */
844             info.si_code = TARGET_SEGV_MAPERR;
845             info._sifields._sigfault._addr = env->exception.vaddress;
846             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
847             break;
848         case EXCP_DEBUG:
849         case EXCP_BKPT:
850             sig = gdb_handlesig(cs, TARGET_SIGTRAP);
851             if (sig) {
852                 info.si_signo = sig;
853                 info.si_errno = 0;
854                 info.si_code = TARGET_TRAP_BRKPT;
855                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
856             }
857             break;
858         case EXCP_SEMIHOST:
859             env->xregs[0] = do_arm_semihosting(env);
860             break;
861         case EXCP_YIELD:
862             /* nothing to do here for user-mode, just resume guest code */
863             break;
864         case EXCP_ATOMIC:
865             cpu_exec_step_atomic(cs);
866             break;
867         default:
868             EXCP_DUMP(env, "qemu: unhandled CPU exception 0x%x - aborting\n", trapnr);
869             abort();
870         }
871         process_pending_signals(env);
872         /* Exception return on AArch64 always clears the exclusive monitor,
873          * so any return to running guest code implies this.
874          */
875         env->exclusive_addr = -1;
876     }
877 }
878 #endif /* ndef TARGET_ABI32 */
879 
880 #endif
881 
882 #ifdef TARGET_UNICORE32
883 
884 void cpu_loop(CPUUniCore32State *env)
885 {
886     CPUState *cs = CPU(uc32_env_get_cpu(env));
887     int trapnr;
888     unsigned int n, insn;
889     target_siginfo_t info;
890 
891     for (;;) {
892         cpu_exec_start(cs);
893         trapnr = cpu_exec(cs);
894         cpu_exec_end(cs);
895         process_queued_cpu_work(cs);
896 
897         switch (trapnr) {
898         case UC32_EXCP_PRIV:
899             {
900                 /* system call */
901                 get_user_u32(insn, env->regs[31] - 4);
902                 n = insn & 0xffffff;
903 
904                 if (n >= UC32_SYSCALL_BASE) {
905                     /* linux syscall */
906                     n -= UC32_SYSCALL_BASE;
907                     if (n == UC32_SYSCALL_NR_set_tls) {
908                             cpu_set_tls(env, env->regs[0]);
909                             env->regs[0] = 0;
910                     } else {
911                         abi_long ret = do_syscall(env,
912                                                   n,
913                                                   env->regs[0],
914                                                   env->regs[1],
915                                                   env->regs[2],
916                                                   env->regs[3],
917                                                   env->regs[4],
918                                                   env->regs[5],
919                                                   0, 0);
920                         if (ret == -TARGET_ERESTARTSYS) {
921                             env->regs[31] -= 4;
922                         } else if (ret != -TARGET_QEMU_ESIGRETURN) {
923                             env->regs[0] = ret;
924                         }
925                     }
926                 } else {
927                     goto error;
928                 }
929             }
930             break;
931         case UC32_EXCP_DTRAP:
932         case UC32_EXCP_ITRAP:
933             info.si_signo = TARGET_SIGSEGV;
934             info.si_errno = 0;
935             /* XXX: check env->error_code */
936             info.si_code = TARGET_SEGV_MAPERR;
937             info._sifields._sigfault._addr = env->cp0.c4_faultaddr;
938             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
939             break;
940         case EXCP_INTERRUPT:
941             /* just indicate that signals should be handled asap */
942             break;
943         case EXCP_DEBUG:
944             {
945                 int sig;
946 
947                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
948                 if (sig) {
949                     info.si_signo = sig;
950                     info.si_errno = 0;
951                     info.si_code = TARGET_TRAP_BRKPT;
952                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
953                 }
954             }
955             break;
956         case EXCP_ATOMIC:
957             cpu_exec_step_atomic(cs);
958             break;
959         default:
960             goto error;
961         }
962         process_pending_signals(env);
963     }
964 
965 error:
966     EXCP_DUMP(env, "qemu: unhandled CPU exception 0x%x - aborting\n", trapnr);
967     abort();
968 }
969 #endif
970 
971 #ifdef TARGET_SPARC
972 #define SPARC64_STACK_BIAS 2047
973 
974 //#define DEBUG_WIN
975 
976 /* WARNING: dealing with register windows _is_ complicated. More info
977    can be found at http://www.sics.se/~psm/sparcstack.html */
978 static inline int get_reg_index(CPUSPARCState *env, int cwp, int index)
979 {
980     index = (index + cwp * 16) % (16 * env->nwindows);
981     /* wrap handling : if cwp is on the last window, then we use the
982        registers 'after' the end */
983     if (index < 8 && env->cwp == env->nwindows - 1)
984         index += 16 * env->nwindows;
985     return index;
986 }
987 
988 /* save the register window 'cwp1' */
989 static inline void save_window_offset(CPUSPARCState *env, int cwp1)
990 {
991     unsigned int i;
992     abi_ulong sp_ptr;
993 
994     sp_ptr = env->regbase[get_reg_index(env, cwp1, 6)];
995 #ifdef TARGET_SPARC64
996     if (sp_ptr & 3)
997         sp_ptr += SPARC64_STACK_BIAS;
998 #endif
999 #if defined(DEBUG_WIN)
1000     printf("win_overflow: sp_ptr=0x" TARGET_ABI_FMT_lx " save_cwp=%d\n",
1001            sp_ptr, cwp1);
1002 #endif
1003     for(i = 0; i < 16; i++) {
1004         /* FIXME - what to do if put_user() fails? */
1005         put_user_ual(env->regbase[get_reg_index(env, cwp1, 8 + i)], sp_ptr);
1006         sp_ptr += sizeof(abi_ulong);
1007     }
1008 }
1009 
1010 static void save_window(CPUSPARCState *env)
1011 {
1012 #ifndef TARGET_SPARC64
1013     unsigned int new_wim;
1014     new_wim = ((env->wim >> 1) | (env->wim << (env->nwindows - 1))) &
1015         ((1LL << env->nwindows) - 1);
1016     save_window_offset(env, cpu_cwp_dec(env, env->cwp - 2));
1017     env->wim = new_wim;
1018 #else
1019     save_window_offset(env, cpu_cwp_dec(env, env->cwp - 2));
1020     env->cansave++;
1021     env->canrestore--;
1022 #endif
1023 }
1024 
1025 static void restore_window(CPUSPARCState *env)
1026 {
1027 #ifndef TARGET_SPARC64
1028     unsigned int new_wim;
1029 #endif
1030     unsigned int i, cwp1;
1031     abi_ulong sp_ptr;
1032 
1033 #ifndef TARGET_SPARC64
1034     new_wim = ((env->wim << 1) | (env->wim >> (env->nwindows - 1))) &
1035         ((1LL << env->nwindows) - 1);
1036 #endif
1037 
1038     /* restore the invalid window */
1039     cwp1 = cpu_cwp_inc(env, env->cwp + 1);
1040     sp_ptr = env->regbase[get_reg_index(env, cwp1, 6)];
1041 #ifdef TARGET_SPARC64
1042     if (sp_ptr & 3)
1043         sp_ptr += SPARC64_STACK_BIAS;
1044 #endif
1045 #if defined(DEBUG_WIN)
1046     printf("win_underflow: sp_ptr=0x" TARGET_ABI_FMT_lx " load_cwp=%d\n",
1047            sp_ptr, cwp1);
1048 #endif
1049     for(i = 0; i < 16; i++) {
1050         /* FIXME - what to do if get_user() fails? */
1051         get_user_ual(env->regbase[get_reg_index(env, cwp1, 8 + i)], sp_ptr);
1052         sp_ptr += sizeof(abi_ulong);
1053     }
1054 #ifdef TARGET_SPARC64
1055     env->canrestore++;
1056     if (env->cleanwin < env->nwindows - 1)
1057         env->cleanwin++;
1058     env->cansave--;
1059 #else
1060     env->wim = new_wim;
1061 #endif
1062 }
1063 
1064 static void flush_windows(CPUSPARCState *env)
1065 {
1066     int offset, cwp1;
1067 
1068     offset = 1;
1069     for(;;) {
1070         /* if restore would invoke restore_window(), then we can stop */
1071         cwp1 = cpu_cwp_inc(env, env->cwp + offset);
1072 #ifndef TARGET_SPARC64
1073         if (env->wim & (1 << cwp1))
1074             break;
1075 #else
1076         if (env->canrestore == 0)
1077             break;
1078         env->cansave++;
1079         env->canrestore--;
1080 #endif
1081         save_window_offset(env, cwp1);
1082         offset++;
1083     }
1084     cwp1 = cpu_cwp_inc(env, env->cwp + 1);
1085 #ifndef TARGET_SPARC64
1086     /* set wim so that restore will reload the registers */
1087     env->wim = 1 << cwp1;
1088 #endif
1089 #if defined(DEBUG_WIN)
1090     printf("flush_windows: nb=%d\n", offset - 1);
1091 #endif
1092 }
1093 
1094 void cpu_loop (CPUSPARCState *env)
1095 {
1096     CPUState *cs = CPU(sparc_env_get_cpu(env));
1097     int trapnr;
1098     abi_long ret;
1099     target_siginfo_t info;
1100 
1101     while (1) {
1102         cpu_exec_start(cs);
1103         trapnr = cpu_exec(cs);
1104         cpu_exec_end(cs);
1105         process_queued_cpu_work(cs);
1106 
1107         /* Compute PSR before exposing state.  */
1108         if (env->cc_op != CC_OP_FLAGS) {
1109             cpu_get_psr(env);
1110         }
1111 
1112         switch (trapnr) {
1113 #ifndef TARGET_SPARC64
1114         case 0x88:
1115         case 0x90:
1116 #else
1117         case 0x110:
1118         case 0x16d:
1119 #endif
1120             ret = do_syscall (env, env->gregs[1],
1121                               env->regwptr[0], env->regwptr[1],
1122                               env->regwptr[2], env->regwptr[3],
1123                               env->regwptr[4], env->regwptr[5],
1124                               0, 0);
1125             if (ret == -TARGET_ERESTARTSYS || ret == -TARGET_QEMU_ESIGRETURN) {
1126                 break;
1127             }
1128             if ((abi_ulong)ret >= (abi_ulong)(-515)) {
1129 #if defined(TARGET_SPARC64) && !defined(TARGET_ABI32)
1130                 env->xcc |= PSR_CARRY;
1131 #else
1132                 env->psr |= PSR_CARRY;
1133 #endif
1134                 ret = -ret;
1135             } else {
1136 #if defined(TARGET_SPARC64) && !defined(TARGET_ABI32)
1137                 env->xcc &= ~PSR_CARRY;
1138 #else
1139                 env->psr &= ~PSR_CARRY;
1140 #endif
1141             }
1142             env->regwptr[0] = ret;
1143             /* next instruction */
1144             env->pc = env->npc;
1145             env->npc = env->npc + 4;
1146             break;
1147         case 0x83: /* flush windows */
1148 #ifdef TARGET_ABI32
1149         case 0x103:
1150 #endif
1151             flush_windows(env);
1152             /* next instruction */
1153             env->pc = env->npc;
1154             env->npc = env->npc + 4;
1155             break;
1156 #ifndef TARGET_SPARC64
1157         case TT_WIN_OVF: /* window overflow */
1158             save_window(env);
1159             break;
1160         case TT_WIN_UNF: /* window underflow */
1161             restore_window(env);
1162             break;
1163         case TT_TFAULT:
1164         case TT_DFAULT:
1165             {
1166                 info.si_signo = TARGET_SIGSEGV;
1167                 info.si_errno = 0;
1168                 /* XXX: check env->error_code */
1169                 info.si_code = TARGET_SEGV_MAPERR;
1170                 info._sifields._sigfault._addr = env->mmuregs[4];
1171                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1172             }
1173             break;
1174 #else
1175         case TT_SPILL: /* window overflow */
1176             save_window(env);
1177             break;
1178         case TT_FILL: /* window underflow */
1179             restore_window(env);
1180             break;
1181         case TT_TFAULT:
1182         case TT_DFAULT:
1183             {
1184                 info.si_signo = TARGET_SIGSEGV;
1185                 info.si_errno = 0;
1186                 /* XXX: check env->error_code */
1187                 info.si_code = TARGET_SEGV_MAPERR;
1188                 if (trapnr == TT_DFAULT)
1189                     info._sifields._sigfault._addr = env->dmmu.mmuregs[4];
1190                 else
1191                     info._sifields._sigfault._addr = cpu_tsptr(env)->tpc;
1192                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1193             }
1194             break;
1195 #ifndef TARGET_ABI32
1196         case 0x16e:
1197             flush_windows(env);
1198             sparc64_get_context(env);
1199             break;
1200         case 0x16f:
1201             flush_windows(env);
1202             sparc64_set_context(env);
1203             break;
1204 #endif
1205 #endif
1206         case EXCP_INTERRUPT:
1207             /* just indicate that signals should be handled asap */
1208             break;
1209         case TT_ILL_INSN:
1210             {
1211                 info.si_signo = TARGET_SIGILL;
1212                 info.si_errno = 0;
1213                 info.si_code = TARGET_ILL_ILLOPC;
1214                 info._sifields._sigfault._addr = env->pc;
1215                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1216             }
1217             break;
1218         case EXCP_DEBUG:
1219             {
1220                 int sig;
1221 
1222                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
1223                 if (sig)
1224                   {
1225                     info.si_signo = sig;
1226                     info.si_errno = 0;
1227                     info.si_code = TARGET_TRAP_BRKPT;
1228                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1229                   }
1230             }
1231             break;
1232         case EXCP_ATOMIC:
1233             cpu_exec_step_atomic(cs);
1234             break;
1235         default:
1236             printf ("Unhandled trap: 0x%x\n", trapnr);
1237             cpu_dump_state(cs, stderr, fprintf, 0);
1238             exit(EXIT_FAILURE);
1239         }
1240         process_pending_signals (env);
1241     }
1242 }
1243 
1244 #endif
1245 
1246 #ifdef TARGET_PPC
1247 static inline uint64_t cpu_ppc_get_tb(CPUPPCState *env)
1248 {
1249     return cpu_get_host_ticks();
1250 }
1251 
1252 uint64_t cpu_ppc_load_tbl(CPUPPCState *env)
1253 {
1254     return cpu_ppc_get_tb(env);
1255 }
1256 
1257 uint32_t cpu_ppc_load_tbu(CPUPPCState *env)
1258 {
1259     return cpu_ppc_get_tb(env) >> 32;
1260 }
1261 
1262 uint64_t cpu_ppc_load_atbl(CPUPPCState *env)
1263 {
1264     return cpu_ppc_get_tb(env);
1265 }
1266 
1267 uint32_t cpu_ppc_load_atbu(CPUPPCState *env)
1268 {
1269     return cpu_ppc_get_tb(env) >> 32;
1270 }
1271 
1272 uint32_t cpu_ppc601_load_rtcu(CPUPPCState *env)
1273 __attribute__ (( alias ("cpu_ppc_load_tbu") ));
1274 
1275 uint32_t cpu_ppc601_load_rtcl(CPUPPCState *env)
1276 {
1277     return cpu_ppc_load_tbl(env) & 0x3FFFFF80;
1278 }
1279 
1280 /* XXX: to be fixed */
1281 int ppc_dcr_read (ppc_dcr_t *dcr_env, int dcrn, uint32_t *valp)
1282 {
1283     return -1;
1284 }
1285 
1286 int ppc_dcr_write (ppc_dcr_t *dcr_env, int dcrn, uint32_t val)
1287 {
1288     return -1;
1289 }
1290 
1291 static int do_store_exclusive(CPUPPCState *env)
1292 {
1293     target_ulong addr;
1294     target_ulong page_addr;
1295     target_ulong val, val2 __attribute__((unused)) = 0;
1296     int flags;
1297     int segv = 0;
1298 
1299     addr = env->reserve_ea;
1300     page_addr = addr & TARGET_PAGE_MASK;
1301     start_exclusive();
1302     mmap_lock();
1303     flags = page_get_flags(page_addr);
1304     if ((flags & PAGE_READ) == 0) {
1305         segv = 1;
1306     } else {
1307         int reg = env->reserve_info & 0x1f;
1308         int size = env->reserve_info >> 5;
1309         int stored = 0;
1310 
1311         if (addr == env->reserve_addr) {
1312             switch (size) {
1313             case 1: segv = get_user_u8(val, addr); break;
1314             case 2: segv = get_user_u16(val, addr); break;
1315             case 4: segv = get_user_u32(val, addr); break;
1316 #if defined(TARGET_PPC64)
1317             case 8: segv = get_user_u64(val, addr); break;
1318             case 16: {
1319                 segv = get_user_u64(val, addr);
1320                 if (!segv) {
1321                     segv = get_user_u64(val2, addr + 8);
1322                 }
1323                 break;
1324             }
1325 #endif
1326             default: abort();
1327             }
1328             if (!segv && val == env->reserve_val) {
1329                 val = env->gpr[reg];
1330                 switch (size) {
1331                 case 1: segv = put_user_u8(val, addr); break;
1332                 case 2: segv = put_user_u16(val, addr); break;
1333                 case 4: segv = put_user_u32(val, addr); break;
1334 #if defined(TARGET_PPC64)
1335                 case 8: segv = put_user_u64(val, addr); break;
1336                 case 16: {
1337                     if (val2 == env->reserve_val2) {
1338                         if (msr_le) {
1339                             val2 = val;
1340                             val = env->gpr[reg+1];
1341                         } else {
1342                             val2 = env->gpr[reg+1];
1343                         }
1344                         segv = put_user_u64(val, addr);
1345                         if (!segv) {
1346                             segv = put_user_u64(val2, addr + 8);
1347                         }
1348                     }
1349                     break;
1350                 }
1351 #endif
1352                 default: abort();
1353                 }
1354                 if (!segv) {
1355                     stored = 1;
1356                 }
1357             }
1358         }
1359         env->crf[0] = (stored << 1) | xer_so;
1360         env->reserve_addr = (target_ulong)-1;
1361     }
1362     if (!segv) {
1363         env->nip += 4;
1364     }
1365     mmap_unlock();
1366     end_exclusive();
1367     return segv;
1368 }
1369 
1370 void cpu_loop(CPUPPCState *env)
1371 {
1372     CPUState *cs = CPU(ppc_env_get_cpu(env));
1373     target_siginfo_t info;
1374     int trapnr;
1375     target_ulong ret;
1376 
1377     for(;;) {
1378         cpu_exec_start(cs);
1379         trapnr = cpu_exec(cs);
1380         cpu_exec_end(cs);
1381         process_queued_cpu_work(cs);
1382 
1383         switch(trapnr) {
1384         case POWERPC_EXCP_NONE:
1385             /* Just go on */
1386             break;
1387         case POWERPC_EXCP_CRITICAL: /* Critical input                        */
1388             cpu_abort(cs, "Critical interrupt while in user mode. "
1389                       "Aborting\n");
1390             break;
1391         case POWERPC_EXCP_MCHECK:   /* Machine check exception               */
1392             cpu_abort(cs, "Machine check exception while in user mode. "
1393                       "Aborting\n");
1394             break;
1395         case POWERPC_EXCP_DSI:      /* Data storage exception                */
1396             /* XXX: check this. Seems bugged */
1397             switch (env->error_code & 0xFF000000) {
1398             case 0x40000000:
1399             case 0x42000000:
1400                 info.si_signo = TARGET_SIGSEGV;
1401                 info.si_errno = 0;
1402                 info.si_code = TARGET_SEGV_MAPERR;
1403                 break;
1404             case 0x04000000:
1405                 info.si_signo = TARGET_SIGILL;
1406                 info.si_errno = 0;
1407                 info.si_code = TARGET_ILL_ILLADR;
1408                 break;
1409             case 0x08000000:
1410                 info.si_signo = TARGET_SIGSEGV;
1411                 info.si_errno = 0;
1412                 info.si_code = TARGET_SEGV_ACCERR;
1413                 break;
1414             default:
1415                 /* Let's send a regular segfault... */
1416                 EXCP_DUMP(env, "Invalid segfault errno (%02x)\n",
1417                           env->error_code);
1418                 info.si_signo = TARGET_SIGSEGV;
1419                 info.si_errno = 0;
1420                 info.si_code = TARGET_SEGV_MAPERR;
1421                 break;
1422             }
1423             info._sifields._sigfault._addr = env->nip;
1424             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1425             break;
1426         case POWERPC_EXCP_ISI:      /* Instruction storage exception         */
1427             /* XXX: check this */
1428             switch (env->error_code & 0xFF000000) {
1429             case 0x40000000:
1430                 info.si_signo = TARGET_SIGSEGV;
1431             info.si_errno = 0;
1432                 info.si_code = TARGET_SEGV_MAPERR;
1433                 break;
1434             case 0x10000000:
1435             case 0x08000000:
1436                 info.si_signo = TARGET_SIGSEGV;
1437                 info.si_errno = 0;
1438                 info.si_code = TARGET_SEGV_ACCERR;
1439                 break;
1440             default:
1441                 /* Let's send a regular segfault... */
1442                 EXCP_DUMP(env, "Invalid segfault errno (%02x)\n",
1443                           env->error_code);
1444                 info.si_signo = TARGET_SIGSEGV;
1445                 info.si_errno = 0;
1446                 info.si_code = TARGET_SEGV_MAPERR;
1447                 break;
1448             }
1449             info._sifields._sigfault._addr = env->nip - 4;
1450             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1451             break;
1452         case POWERPC_EXCP_EXTERNAL: /* External input                        */
1453             cpu_abort(cs, "External interrupt while in user mode. "
1454                       "Aborting\n");
1455             break;
1456         case POWERPC_EXCP_ALIGN:    /* Alignment exception                   */
1457             /* XXX: check this */
1458             info.si_signo = TARGET_SIGBUS;
1459             info.si_errno = 0;
1460             info.si_code = TARGET_BUS_ADRALN;
1461             info._sifields._sigfault._addr = env->nip;
1462             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1463             break;
1464         case POWERPC_EXCP_PROGRAM:  /* Program exception                     */
1465         case POWERPC_EXCP_HV_EMU:   /* HV emulation                          */
1466             /* XXX: check this */
1467             switch (env->error_code & ~0xF) {
1468             case POWERPC_EXCP_FP:
1469                 info.si_signo = TARGET_SIGFPE;
1470                 info.si_errno = 0;
1471                 switch (env->error_code & 0xF) {
1472                 case POWERPC_EXCP_FP_OX:
1473                     info.si_code = TARGET_FPE_FLTOVF;
1474                     break;
1475                 case POWERPC_EXCP_FP_UX:
1476                     info.si_code = TARGET_FPE_FLTUND;
1477                     break;
1478                 case POWERPC_EXCP_FP_ZX:
1479                 case POWERPC_EXCP_FP_VXZDZ:
1480                     info.si_code = TARGET_FPE_FLTDIV;
1481                     break;
1482                 case POWERPC_EXCP_FP_XX:
1483                     info.si_code = TARGET_FPE_FLTRES;
1484                     break;
1485                 case POWERPC_EXCP_FP_VXSOFT:
1486                     info.si_code = TARGET_FPE_FLTINV;
1487                     break;
1488                 case POWERPC_EXCP_FP_VXSNAN:
1489                 case POWERPC_EXCP_FP_VXISI:
1490                 case POWERPC_EXCP_FP_VXIDI:
1491                 case POWERPC_EXCP_FP_VXIMZ:
1492                 case POWERPC_EXCP_FP_VXVC:
1493                 case POWERPC_EXCP_FP_VXSQRT:
1494                 case POWERPC_EXCP_FP_VXCVI:
1495                     info.si_code = TARGET_FPE_FLTSUB;
1496                     break;
1497                 default:
1498                     EXCP_DUMP(env, "Unknown floating point exception (%02x)\n",
1499                               env->error_code);
1500                     break;
1501                 }
1502                 break;
1503             case POWERPC_EXCP_INVAL:
1504                 info.si_signo = TARGET_SIGILL;
1505                 info.si_errno = 0;
1506                 switch (env->error_code & 0xF) {
1507                 case POWERPC_EXCP_INVAL_INVAL:
1508                     info.si_code = TARGET_ILL_ILLOPC;
1509                     break;
1510                 case POWERPC_EXCP_INVAL_LSWX:
1511                     info.si_code = TARGET_ILL_ILLOPN;
1512                     break;
1513                 case POWERPC_EXCP_INVAL_SPR:
1514                     info.si_code = TARGET_ILL_PRVREG;
1515                     break;
1516                 case POWERPC_EXCP_INVAL_FP:
1517                     info.si_code = TARGET_ILL_COPROC;
1518                     break;
1519                 default:
1520                     EXCP_DUMP(env, "Unknown invalid operation (%02x)\n",
1521                               env->error_code & 0xF);
1522                     info.si_code = TARGET_ILL_ILLADR;
1523                     break;
1524                 }
1525                 break;
1526             case POWERPC_EXCP_PRIV:
1527                 info.si_signo = TARGET_SIGILL;
1528                 info.si_errno = 0;
1529                 switch (env->error_code & 0xF) {
1530                 case POWERPC_EXCP_PRIV_OPC:
1531                     info.si_code = TARGET_ILL_PRVOPC;
1532                     break;
1533                 case POWERPC_EXCP_PRIV_REG:
1534                     info.si_code = TARGET_ILL_PRVREG;
1535                     break;
1536                 default:
1537                     EXCP_DUMP(env, "Unknown privilege violation (%02x)\n",
1538                               env->error_code & 0xF);
1539                     info.si_code = TARGET_ILL_PRVOPC;
1540                     break;
1541                 }
1542                 break;
1543             case POWERPC_EXCP_TRAP:
1544                 cpu_abort(cs, "Tried to call a TRAP\n");
1545                 break;
1546             default:
1547                 /* Should not happen ! */
1548                 cpu_abort(cs, "Unknown program exception (%02x)\n",
1549                           env->error_code);
1550                 break;
1551             }
1552             info._sifields._sigfault._addr = env->nip;
1553             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1554             break;
1555         case POWERPC_EXCP_FPU:      /* Floating-point unavailable exception  */
1556             info.si_signo = TARGET_SIGILL;
1557             info.si_errno = 0;
1558             info.si_code = TARGET_ILL_COPROC;
1559             info._sifields._sigfault._addr = env->nip;
1560             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1561             break;
1562         case POWERPC_EXCP_SYSCALL:  /* System call exception                 */
1563             cpu_abort(cs, "Syscall exception while in user mode. "
1564                       "Aborting\n");
1565             break;
1566         case POWERPC_EXCP_APU:      /* Auxiliary processor unavailable       */
1567             info.si_signo = TARGET_SIGILL;
1568             info.si_errno = 0;
1569             info.si_code = TARGET_ILL_COPROC;
1570             info._sifields._sigfault._addr = env->nip;
1571             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1572             break;
1573         case POWERPC_EXCP_DECR:     /* Decrementer exception                 */
1574             cpu_abort(cs, "Decrementer interrupt while in user mode. "
1575                       "Aborting\n");
1576             break;
1577         case POWERPC_EXCP_FIT:      /* Fixed-interval timer interrupt        */
1578             cpu_abort(cs, "Fix interval timer interrupt while in user mode. "
1579                       "Aborting\n");
1580             break;
1581         case POWERPC_EXCP_WDT:      /* Watchdog timer interrupt              */
1582             cpu_abort(cs, "Watchdog timer interrupt while in user mode. "
1583                       "Aborting\n");
1584             break;
1585         case POWERPC_EXCP_DTLB:     /* Data TLB error                        */
1586             cpu_abort(cs, "Data TLB exception while in user mode. "
1587                       "Aborting\n");
1588             break;
1589         case POWERPC_EXCP_ITLB:     /* Instruction TLB error                 */
1590             cpu_abort(cs, "Instruction TLB exception while in user mode. "
1591                       "Aborting\n");
1592             break;
1593         case POWERPC_EXCP_SPEU:     /* SPE/embedded floating-point unavail.  */
1594             info.si_signo = TARGET_SIGILL;
1595             info.si_errno = 0;
1596             info.si_code = TARGET_ILL_COPROC;
1597             info._sifields._sigfault._addr = env->nip;
1598             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1599             break;
1600         case POWERPC_EXCP_EFPDI:    /* Embedded floating-point data IRQ      */
1601             cpu_abort(cs, "Embedded floating-point data IRQ not handled\n");
1602             break;
1603         case POWERPC_EXCP_EFPRI:    /* Embedded floating-point round IRQ     */
1604             cpu_abort(cs, "Embedded floating-point round IRQ not handled\n");
1605             break;
1606         case POWERPC_EXCP_EPERFM:   /* Embedded performance monitor IRQ      */
1607             cpu_abort(cs, "Performance monitor exception not handled\n");
1608             break;
1609         case POWERPC_EXCP_DOORI:    /* Embedded doorbell interrupt           */
1610             cpu_abort(cs, "Doorbell interrupt while in user mode. "
1611                        "Aborting\n");
1612             break;
1613         case POWERPC_EXCP_DOORCI:   /* Embedded doorbell critical interrupt  */
1614             cpu_abort(cs, "Doorbell critical interrupt while in user mode. "
1615                       "Aborting\n");
1616             break;
1617         case POWERPC_EXCP_RESET:    /* System reset exception                */
1618             cpu_abort(cs, "Reset interrupt while in user mode. "
1619                       "Aborting\n");
1620             break;
1621         case POWERPC_EXCP_DSEG:     /* Data segment exception                */
1622             cpu_abort(cs, "Data segment exception while in user mode. "
1623                       "Aborting\n");
1624             break;
1625         case POWERPC_EXCP_ISEG:     /* Instruction segment exception         */
1626             cpu_abort(cs, "Instruction segment exception "
1627                       "while in user mode. Aborting\n");
1628             break;
1629         /* PowerPC 64 with hypervisor mode support */
1630         case POWERPC_EXCP_HDECR:    /* Hypervisor decrementer exception      */
1631             cpu_abort(cs, "Hypervisor decrementer interrupt "
1632                       "while in user mode. Aborting\n");
1633             break;
1634         case POWERPC_EXCP_TRACE:    /* Trace exception                       */
1635             /* Nothing to do:
1636              * we use this exception to emulate step-by-step execution mode.
1637              */
1638             break;
1639         /* PowerPC 64 with hypervisor mode support */
1640         case POWERPC_EXCP_HDSI:     /* Hypervisor data storage exception     */
1641             cpu_abort(cs, "Hypervisor data storage exception "
1642                       "while in user mode. Aborting\n");
1643             break;
1644         case POWERPC_EXCP_HISI:     /* Hypervisor instruction storage excp   */
1645             cpu_abort(cs, "Hypervisor instruction storage exception "
1646                       "while in user mode. Aborting\n");
1647             break;
1648         case POWERPC_EXCP_HDSEG:    /* Hypervisor data segment exception     */
1649             cpu_abort(cs, "Hypervisor data segment exception "
1650                       "while in user mode. Aborting\n");
1651             break;
1652         case POWERPC_EXCP_HISEG:    /* Hypervisor instruction segment excp   */
1653             cpu_abort(cs, "Hypervisor instruction segment exception "
1654                       "while in user mode. Aborting\n");
1655             break;
1656         case POWERPC_EXCP_VPU:      /* Vector unavailable exception          */
1657             info.si_signo = TARGET_SIGILL;
1658             info.si_errno = 0;
1659             info.si_code = TARGET_ILL_COPROC;
1660             info._sifields._sigfault._addr = env->nip;
1661             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1662             break;
1663         case POWERPC_EXCP_PIT:      /* Programmable interval timer IRQ       */
1664             cpu_abort(cs, "Programmable interval timer interrupt "
1665                       "while in user mode. Aborting\n");
1666             break;
1667         case POWERPC_EXCP_IO:       /* IO error exception                    */
1668             cpu_abort(cs, "IO error exception while in user mode. "
1669                       "Aborting\n");
1670             break;
1671         case POWERPC_EXCP_RUNM:     /* Run mode exception                    */
1672             cpu_abort(cs, "Run mode exception while in user mode. "
1673                       "Aborting\n");
1674             break;
1675         case POWERPC_EXCP_EMUL:     /* Emulation trap exception              */
1676             cpu_abort(cs, "Emulation trap exception not handled\n");
1677             break;
1678         case POWERPC_EXCP_IFTLB:    /* Instruction fetch TLB error           */
1679             cpu_abort(cs, "Instruction fetch TLB exception "
1680                       "while in user-mode. Aborting");
1681             break;
1682         case POWERPC_EXCP_DLTLB:    /* Data load TLB miss                    */
1683             cpu_abort(cs, "Data load TLB exception while in user-mode. "
1684                       "Aborting");
1685             break;
1686         case POWERPC_EXCP_DSTLB:    /* Data store TLB miss                   */
1687             cpu_abort(cs, "Data store TLB exception while in user-mode. "
1688                       "Aborting");
1689             break;
1690         case POWERPC_EXCP_FPA:      /* Floating-point assist exception       */
1691             cpu_abort(cs, "Floating-point assist exception not handled\n");
1692             break;
1693         case POWERPC_EXCP_IABR:     /* Instruction address breakpoint        */
1694             cpu_abort(cs, "Instruction address breakpoint exception "
1695                       "not handled\n");
1696             break;
1697         case POWERPC_EXCP_SMI:      /* System management interrupt           */
1698             cpu_abort(cs, "System management interrupt while in user mode. "
1699                       "Aborting\n");
1700             break;
1701         case POWERPC_EXCP_THERM:    /* Thermal interrupt                     */
1702             cpu_abort(cs, "Thermal interrupt interrupt while in user mode. "
1703                       "Aborting\n");
1704             break;
1705         case POWERPC_EXCP_PERFM:   /* Embedded performance monitor IRQ      */
1706             cpu_abort(cs, "Performance monitor exception not handled\n");
1707             break;
1708         case POWERPC_EXCP_VPUA:     /* Vector assist exception               */
1709             cpu_abort(cs, "Vector assist exception not handled\n");
1710             break;
1711         case POWERPC_EXCP_SOFTP:    /* Soft patch exception                  */
1712             cpu_abort(cs, "Soft patch exception not handled\n");
1713             break;
1714         case POWERPC_EXCP_MAINT:    /* Maintenance exception                 */
1715             cpu_abort(cs, "Maintenance exception while in user mode. "
1716                       "Aborting\n");
1717             break;
1718         case POWERPC_EXCP_STOP:     /* stop translation                      */
1719             /* We did invalidate the instruction cache. Go on */
1720             break;
1721         case POWERPC_EXCP_BRANCH:   /* branch instruction:                   */
1722             /* We just stopped because of a branch. Go on */
1723             break;
1724         case POWERPC_EXCP_SYSCALL_USER:
1725             /* system call in user-mode emulation */
1726             /* WARNING:
1727              * PPC ABI uses overflow flag in cr0 to signal an error
1728              * in syscalls.
1729              */
1730             env->crf[0] &= ~0x1;
1731             env->nip += 4;
1732             ret = do_syscall(env, env->gpr[0], env->gpr[3], env->gpr[4],
1733                              env->gpr[5], env->gpr[6], env->gpr[7],
1734                              env->gpr[8], 0, 0);
1735             if (ret == -TARGET_ERESTARTSYS) {
1736                 env->nip -= 4;
1737                 break;
1738             }
1739             if (ret == (target_ulong)(-TARGET_QEMU_ESIGRETURN)) {
1740                 /* Returning from a successful sigreturn syscall.
1741                    Avoid corrupting register state.  */
1742                 break;
1743             }
1744             if (ret > (target_ulong)(-515)) {
1745                 env->crf[0] |= 0x1;
1746                 ret = -ret;
1747             }
1748             env->gpr[3] = ret;
1749             break;
1750         case POWERPC_EXCP_STCX:
1751             if (do_store_exclusive(env)) {
1752                 info.si_signo = TARGET_SIGSEGV;
1753                 info.si_errno = 0;
1754                 info.si_code = TARGET_SEGV_MAPERR;
1755                 info._sifields._sigfault._addr = env->nip;
1756                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1757             }
1758             break;
1759         case EXCP_DEBUG:
1760             {
1761                 int sig;
1762 
1763                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
1764                 if (sig) {
1765                     info.si_signo = sig;
1766                     info.si_errno = 0;
1767                     info.si_code = TARGET_TRAP_BRKPT;
1768                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
1769                   }
1770             }
1771             break;
1772         case EXCP_INTERRUPT:
1773             /* just indicate that signals should be handled asap */
1774             break;
1775         case EXCP_ATOMIC:
1776             cpu_exec_step_atomic(cs);
1777             break;
1778         default:
1779             cpu_abort(cs, "Unknown exception 0x%x. Aborting\n", trapnr);
1780             break;
1781         }
1782         process_pending_signals(env);
1783     }
1784 }
1785 #endif
1786 
1787 #ifdef TARGET_MIPS
1788 
1789 # ifdef TARGET_ABI_MIPSO32
1790 #  define MIPS_SYS(name, args) args,
1791 static const uint8_t mips_syscall_args[] = {
1792 	MIPS_SYS(sys_syscall	, 8)	/* 4000 */
1793 	MIPS_SYS(sys_exit	, 1)
1794 	MIPS_SYS(sys_fork	, 0)
1795 	MIPS_SYS(sys_read	, 3)
1796 	MIPS_SYS(sys_write	, 3)
1797 	MIPS_SYS(sys_open	, 3)	/* 4005 */
1798 	MIPS_SYS(sys_close	, 1)
1799 	MIPS_SYS(sys_waitpid	, 3)
1800 	MIPS_SYS(sys_creat	, 2)
1801 	MIPS_SYS(sys_link	, 2)
1802 	MIPS_SYS(sys_unlink	, 1)	/* 4010 */
1803 	MIPS_SYS(sys_execve	, 0)
1804 	MIPS_SYS(sys_chdir	, 1)
1805 	MIPS_SYS(sys_time	, 1)
1806 	MIPS_SYS(sys_mknod	, 3)
1807 	MIPS_SYS(sys_chmod	, 2)	/* 4015 */
1808 	MIPS_SYS(sys_lchown	, 3)
1809 	MIPS_SYS(sys_ni_syscall	, 0)
1810 	MIPS_SYS(sys_ni_syscall	, 0)	/* was sys_stat */
1811 	MIPS_SYS(sys_lseek	, 3)
1812 	MIPS_SYS(sys_getpid	, 0)	/* 4020 */
1813 	MIPS_SYS(sys_mount	, 5)
1814 	MIPS_SYS(sys_umount	, 1)
1815 	MIPS_SYS(sys_setuid	, 1)
1816 	MIPS_SYS(sys_getuid	, 0)
1817 	MIPS_SYS(sys_stime	, 1)	/* 4025 */
1818 	MIPS_SYS(sys_ptrace	, 4)
1819 	MIPS_SYS(sys_alarm	, 1)
1820 	MIPS_SYS(sys_ni_syscall	, 0)	/* was sys_fstat */
1821 	MIPS_SYS(sys_pause	, 0)
1822 	MIPS_SYS(sys_utime	, 2)	/* 4030 */
1823 	MIPS_SYS(sys_ni_syscall	, 0)
1824 	MIPS_SYS(sys_ni_syscall	, 0)
1825 	MIPS_SYS(sys_access	, 2)
1826 	MIPS_SYS(sys_nice	, 1)
1827 	MIPS_SYS(sys_ni_syscall	, 0)	/* 4035 */
1828 	MIPS_SYS(sys_sync	, 0)
1829 	MIPS_SYS(sys_kill	, 2)
1830 	MIPS_SYS(sys_rename	, 2)
1831 	MIPS_SYS(sys_mkdir	, 2)
1832 	MIPS_SYS(sys_rmdir	, 1)	/* 4040 */
1833 	MIPS_SYS(sys_dup		, 1)
1834 	MIPS_SYS(sys_pipe	, 0)
1835 	MIPS_SYS(sys_times	, 1)
1836 	MIPS_SYS(sys_ni_syscall	, 0)
1837 	MIPS_SYS(sys_brk		, 1)	/* 4045 */
1838 	MIPS_SYS(sys_setgid	, 1)
1839 	MIPS_SYS(sys_getgid	, 0)
1840 	MIPS_SYS(sys_ni_syscall	, 0)	/* was signal(2) */
1841 	MIPS_SYS(sys_geteuid	, 0)
1842 	MIPS_SYS(sys_getegid	, 0)	/* 4050 */
1843 	MIPS_SYS(sys_acct	, 0)
1844 	MIPS_SYS(sys_umount2	, 2)
1845 	MIPS_SYS(sys_ni_syscall	, 0)
1846 	MIPS_SYS(sys_ioctl	, 3)
1847 	MIPS_SYS(sys_fcntl	, 3)	/* 4055 */
1848 	MIPS_SYS(sys_ni_syscall	, 2)
1849 	MIPS_SYS(sys_setpgid	, 2)
1850 	MIPS_SYS(sys_ni_syscall	, 0)
1851 	MIPS_SYS(sys_olduname	, 1)
1852 	MIPS_SYS(sys_umask	, 1)	/* 4060 */
1853 	MIPS_SYS(sys_chroot	, 1)
1854 	MIPS_SYS(sys_ustat	, 2)
1855 	MIPS_SYS(sys_dup2	, 2)
1856 	MIPS_SYS(sys_getppid	, 0)
1857 	MIPS_SYS(sys_getpgrp	, 0)	/* 4065 */
1858 	MIPS_SYS(sys_setsid	, 0)
1859 	MIPS_SYS(sys_sigaction	, 3)
1860 	MIPS_SYS(sys_sgetmask	, 0)
1861 	MIPS_SYS(sys_ssetmask	, 1)
1862 	MIPS_SYS(sys_setreuid	, 2)	/* 4070 */
1863 	MIPS_SYS(sys_setregid	, 2)
1864 	MIPS_SYS(sys_sigsuspend	, 0)
1865 	MIPS_SYS(sys_sigpending	, 1)
1866 	MIPS_SYS(sys_sethostname	, 2)
1867 	MIPS_SYS(sys_setrlimit	, 2)	/* 4075 */
1868 	MIPS_SYS(sys_getrlimit	, 2)
1869 	MIPS_SYS(sys_getrusage	, 2)
1870 	MIPS_SYS(sys_gettimeofday, 2)
1871 	MIPS_SYS(sys_settimeofday, 2)
1872 	MIPS_SYS(sys_getgroups	, 2)	/* 4080 */
1873 	MIPS_SYS(sys_setgroups	, 2)
1874 	MIPS_SYS(sys_ni_syscall	, 0)	/* old_select */
1875 	MIPS_SYS(sys_symlink	, 2)
1876 	MIPS_SYS(sys_ni_syscall	, 0)	/* was sys_lstat */
1877 	MIPS_SYS(sys_readlink	, 3)	/* 4085 */
1878 	MIPS_SYS(sys_uselib	, 1)
1879 	MIPS_SYS(sys_swapon	, 2)
1880 	MIPS_SYS(sys_reboot	, 3)
1881 	MIPS_SYS(old_readdir	, 3)
1882 	MIPS_SYS(old_mmap	, 6)	/* 4090 */
1883 	MIPS_SYS(sys_munmap	, 2)
1884 	MIPS_SYS(sys_truncate	, 2)
1885 	MIPS_SYS(sys_ftruncate	, 2)
1886 	MIPS_SYS(sys_fchmod	, 2)
1887 	MIPS_SYS(sys_fchown	, 3)	/* 4095 */
1888 	MIPS_SYS(sys_getpriority	, 2)
1889 	MIPS_SYS(sys_setpriority	, 3)
1890 	MIPS_SYS(sys_ni_syscall	, 0)
1891 	MIPS_SYS(sys_statfs	, 2)
1892 	MIPS_SYS(sys_fstatfs	, 2)	/* 4100 */
1893 	MIPS_SYS(sys_ni_syscall	, 0)	/* was ioperm(2) */
1894 	MIPS_SYS(sys_socketcall	, 2)
1895 	MIPS_SYS(sys_syslog	, 3)
1896 	MIPS_SYS(sys_setitimer	, 3)
1897 	MIPS_SYS(sys_getitimer	, 2)	/* 4105 */
1898 	MIPS_SYS(sys_newstat	, 2)
1899 	MIPS_SYS(sys_newlstat	, 2)
1900 	MIPS_SYS(sys_newfstat	, 2)
1901 	MIPS_SYS(sys_uname	, 1)
1902 	MIPS_SYS(sys_ni_syscall	, 0)	/* 4110 was iopl(2) */
1903 	MIPS_SYS(sys_vhangup	, 0)
1904 	MIPS_SYS(sys_ni_syscall	, 0)	/* was sys_idle() */
1905 	MIPS_SYS(sys_ni_syscall	, 0)	/* was sys_vm86 */
1906 	MIPS_SYS(sys_wait4	, 4)
1907 	MIPS_SYS(sys_swapoff	, 1)	/* 4115 */
1908 	MIPS_SYS(sys_sysinfo	, 1)
1909 	MIPS_SYS(sys_ipc		, 6)
1910 	MIPS_SYS(sys_fsync	, 1)
1911 	MIPS_SYS(sys_sigreturn	, 0)
1912 	MIPS_SYS(sys_clone	, 6)	/* 4120 */
1913 	MIPS_SYS(sys_setdomainname, 2)
1914 	MIPS_SYS(sys_newuname	, 1)
1915 	MIPS_SYS(sys_ni_syscall	, 0)	/* sys_modify_ldt */
1916 	MIPS_SYS(sys_adjtimex	, 1)
1917 	MIPS_SYS(sys_mprotect	, 3)	/* 4125 */
1918 	MIPS_SYS(sys_sigprocmask	, 3)
1919 	MIPS_SYS(sys_ni_syscall	, 0)	/* was create_module */
1920 	MIPS_SYS(sys_init_module	, 5)
1921 	MIPS_SYS(sys_delete_module, 1)
1922 	MIPS_SYS(sys_ni_syscall	, 0)	/* 4130	was get_kernel_syms */
1923 	MIPS_SYS(sys_quotactl	, 0)
1924 	MIPS_SYS(sys_getpgid	, 1)
1925 	MIPS_SYS(sys_fchdir	, 1)
1926 	MIPS_SYS(sys_bdflush	, 2)
1927 	MIPS_SYS(sys_sysfs	, 3)	/* 4135 */
1928 	MIPS_SYS(sys_personality	, 1)
1929 	MIPS_SYS(sys_ni_syscall	, 0)	/* for afs_syscall */
1930 	MIPS_SYS(sys_setfsuid	, 1)
1931 	MIPS_SYS(sys_setfsgid	, 1)
1932 	MIPS_SYS(sys_llseek	, 5)	/* 4140 */
1933 	MIPS_SYS(sys_getdents	, 3)
1934 	MIPS_SYS(sys_select	, 5)
1935 	MIPS_SYS(sys_flock	, 2)
1936 	MIPS_SYS(sys_msync	, 3)
1937 	MIPS_SYS(sys_readv	, 3)	/* 4145 */
1938 	MIPS_SYS(sys_writev	, 3)
1939 	MIPS_SYS(sys_cacheflush	, 3)
1940 	MIPS_SYS(sys_cachectl	, 3)
1941 	MIPS_SYS(sys_sysmips	, 4)
1942 	MIPS_SYS(sys_ni_syscall	, 0)	/* 4150 */
1943 	MIPS_SYS(sys_getsid	, 1)
1944 	MIPS_SYS(sys_fdatasync	, 0)
1945 	MIPS_SYS(sys_sysctl	, 1)
1946 	MIPS_SYS(sys_mlock	, 2)
1947 	MIPS_SYS(sys_munlock	, 2)	/* 4155 */
1948 	MIPS_SYS(sys_mlockall	, 1)
1949 	MIPS_SYS(sys_munlockall	, 0)
1950 	MIPS_SYS(sys_sched_setparam, 2)
1951 	MIPS_SYS(sys_sched_getparam, 2)
1952 	MIPS_SYS(sys_sched_setscheduler, 3)	/* 4160 */
1953 	MIPS_SYS(sys_sched_getscheduler, 1)
1954 	MIPS_SYS(sys_sched_yield	, 0)
1955 	MIPS_SYS(sys_sched_get_priority_max, 1)
1956 	MIPS_SYS(sys_sched_get_priority_min, 1)
1957 	MIPS_SYS(sys_sched_rr_get_interval, 2)	/* 4165 */
1958 	MIPS_SYS(sys_nanosleep,	2)
1959 	MIPS_SYS(sys_mremap	, 5)
1960 	MIPS_SYS(sys_accept	, 3)
1961 	MIPS_SYS(sys_bind	, 3)
1962 	MIPS_SYS(sys_connect	, 3)	/* 4170 */
1963 	MIPS_SYS(sys_getpeername	, 3)
1964 	MIPS_SYS(sys_getsockname	, 3)
1965 	MIPS_SYS(sys_getsockopt	, 5)
1966 	MIPS_SYS(sys_listen	, 2)
1967 	MIPS_SYS(sys_recv	, 4)	/* 4175 */
1968 	MIPS_SYS(sys_recvfrom	, 6)
1969 	MIPS_SYS(sys_recvmsg	, 3)
1970 	MIPS_SYS(sys_send	, 4)
1971 	MIPS_SYS(sys_sendmsg	, 3)
1972 	MIPS_SYS(sys_sendto	, 6)	/* 4180 */
1973 	MIPS_SYS(sys_setsockopt	, 5)
1974 	MIPS_SYS(sys_shutdown	, 2)
1975 	MIPS_SYS(sys_socket	, 3)
1976 	MIPS_SYS(sys_socketpair	, 4)
1977 	MIPS_SYS(sys_setresuid	, 3)	/* 4185 */
1978 	MIPS_SYS(sys_getresuid	, 3)
1979 	MIPS_SYS(sys_ni_syscall	, 0)	/* was sys_query_module */
1980 	MIPS_SYS(sys_poll	, 3)
1981 	MIPS_SYS(sys_nfsservctl	, 3)
1982 	MIPS_SYS(sys_setresgid	, 3)	/* 4190 */
1983 	MIPS_SYS(sys_getresgid	, 3)
1984 	MIPS_SYS(sys_prctl	, 5)
1985 	MIPS_SYS(sys_rt_sigreturn, 0)
1986 	MIPS_SYS(sys_rt_sigaction, 4)
1987 	MIPS_SYS(sys_rt_sigprocmask, 4)	/* 4195 */
1988 	MIPS_SYS(sys_rt_sigpending, 2)
1989 	MIPS_SYS(sys_rt_sigtimedwait, 4)
1990 	MIPS_SYS(sys_rt_sigqueueinfo, 3)
1991 	MIPS_SYS(sys_rt_sigsuspend, 0)
1992 	MIPS_SYS(sys_pread64	, 6)	/* 4200 */
1993 	MIPS_SYS(sys_pwrite64	, 6)
1994 	MIPS_SYS(sys_chown	, 3)
1995 	MIPS_SYS(sys_getcwd	, 2)
1996 	MIPS_SYS(sys_capget	, 2)
1997 	MIPS_SYS(sys_capset	, 2)	/* 4205 */
1998 	MIPS_SYS(sys_sigaltstack	, 2)
1999 	MIPS_SYS(sys_sendfile	, 4)
2000 	MIPS_SYS(sys_ni_syscall	, 0)
2001 	MIPS_SYS(sys_ni_syscall	, 0)
2002 	MIPS_SYS(sys_mmap2	, 6)	/* 4210 */
2003 	MIPS_SYS(sys_truncate64	, 4)
2004 	MIPS_SYS(sys_ftruncate64	, 4)
2005 	MIPS_SYS(sys_stat64	, 2)
2006 	MIPS_SYS(sys_lstat64	, 2)
2007 	MIPS_SYS(sys_fstat64	, 2)	/* 4215 */
2008 	MIPS_SYS(sys_pivot_root	, 2)
2009 	MIPS_SYS(sys_mincore	, 3)
2010 	MIPS_SYS(sys_madvise	, 3)
2011 	MIPS_SYS(sys_getdents64	, 3)
2012 	MIPS_SYS(sys_fcntl64	, 3)	/* 4220 */
2013 	MIPS_SYS(sys_ni_syscall	, 0)
2014 	MIPS_SYS(sys_gettid	, 0)
2015 	MIPS_SYS(sys_readahead	, 5)
2016 	MIPS_SYS(sys_setxattr	, 5)
2017 	MIPS_SYS(sys_lsetxattr	, 5)	/* 4225 */
2018 	MIPS_SYS(sys_fsetxattr	, 5)
2019 	MIPS_SYS(sys_getxattr	, 4)
2020 	MIPS_SYS(sys_lgetxattr	, 4)
2021 	MIPS_SYS(sys_fgetxattr	, 4)
2022 	MIPS_SYS(sys_listxattr	, 3)	/* 4230 */
2023 	MIPS_SYS(sys_llistxattr	, 3)
2024 	MIPS_SYS(sys_flistxattr	, 3)
2025 	MIPS_SYS(sys_removexattr	, 2)
2026 	MIPS_SYS(sys_lremovexattr, 2)
2027 	MIPS_SYS(sys_fremovexattr, 2)	/* 4235 */
2028 	MIPS_SYS(sys_tkill	, 2)
2029 	MIPS_SYS(sys_sendfile64	, 5)
2030 	MIPS_SYS(sys_futex	, 6)
2031 	MIPS_SYS(sys_sched_setaffinity, 3)
2032 	MIPS_SYS(sys_sched_getaffinity, 3)	/* 4240 */
2033 	MIPS_SYS(sys_io_setup	, 2)
2034 	MIPS_SYS(sys_io_destroy	, 1)
2035 	MIPS_SYS(sys_io_getevents, 5)
2036 	MIPS_SYS(sys_io_submit	, 3)
2037 	MIPS_SYS(sys_io_cancel	, 3)	/* 4245 */
2038 	MIPS_SYS(sys_exit_group	, 1)
2039 	MIPS_SYS(sys_lookup_dcookie, 3)
2040 	MIPS_SYS(sys_epoll_create, 1)
2041 	MIPS_SYS(sys_epoll_ctl	, 4)
2042 	MIPS_SYS(sys_epoll_wait	, 3)	/* 4250 */
2043 	MIPS_SYS(sys_remap_file_pages, 5)
2044 	MIPS_SYS(sys_set_tid_address, 1)
2045 	MIPS_SYS(sys_restart_syscall, 0)
2046 	MIPS_SYS(sys_fadvise64_64, 7)
2047 	MIPS_SYS(sys_statfs64	, 3)	/* 4255 */
2048 	MIPS_SYS(sys_fstatfs64	, 2)
2049 	MIPS_SYS(sys_timer_create, 3)
2050 	MIPS_SYS(sys_timer_settime, 4)
2051 	MIPS_SYS(sys_timer_gettime, 2)
2052 	MIPS_SYS(sys_timer_getoverrun, 1)	/* 4260 */
2053 	MIPS_SYS(sys_timer_delete, 1)
2054 	MIPS_SYS(sys_clock_settime, 2)
2055 	MIPS_SYS(sys_clock_gettime, 2)
2056 	MIPS_SYS(sys_clock_getres, 2)
2057 	MIPS_SYS(sys_clock_nanosleep, 4)	/* 4265 */
2058 	MIPS_SYS(sys_tgkill	, 3)
2059 	MIPS_SYS(sys_utimes	, 2)
2060 	MIPS_SYS(sys_mbind	, 4)
2061 	MIPS_SYS(sys_ni_syscall	, 0)	/* sys_get_mempolicy */
2062 	MIPS_SYS(sys_ni_syscall	, 0)	/* 4270 sys_set_mempolicy */
2063 	MIPS_SYS(sys_mq_open	, 4)
2064 	MIPS_SYS(sys_mq_unlink	, 1)
2065 	MIPS_SYS(sys_mq_timedsend, 5)
2066 	MIPS_SYS(sys_mq_timedreceive, 5)
2067 	MIPS_SYS(sys_mq_notify	, 2)	/* 4275 */
2068 	MIPS_SYS(sys_mq_getsetattr, 3)
2069 	MIPS_SYS(sys_ni_syscall	, 0)	/* sys_vserver */
2070 	MIPS_SYS(sys_waitid	, 4)
2071 	MIPS_SYS(sys_ni_syscall	, 0)	/* available, was setaltroot */
2072 	MIPS_SYS(sys_add_key	, 5)
2073 	MIPS_SYS(sys_request_key, 4)
2074 	MIPS_SYS(sys_keyctl	, 5)
2075 	MIPS_SYS(sys_set_thread_area, 1)
2076 	MIPS_SYS(sys_inotify_init, 0)
2077 	MIPS_SYS(sys_inotify_add_watch, 3) /* 4285 */
2078 	MIPS_SYS(sys_inotify_rm_watch, 2)
2079 	MIPS_SYS(sys_migrate_pages, 4)
2080 	MIPS_SYS(sys_openat, 4)
2081 	MIPS_SYS(sys_mkdirat, 3)
2082 	MIPS_SYS(sys_mknodat, 4)	/* 4290 */
2083 	MIPS_SYS(sys_fchownat, 5)
2084 	MIPS_SYS(sys_futimesat, 3)
2085 	MIPS_SYS(sys_fstatat64, 4)
2086 	MIPS_SYS(sys_unlinkat, 3)
2087 	MIPS_SYS(sys_renameat, 4)	/* 4295 */
2088 	MIPS_SYS(sys_linkat, 5)
2089 	MIPS_SYS(sys_symlinkat, 3)
2090 	MIPS_SYS(sys_readlinkat, 4)
2091 	MIPS_SYS(sys_fchmodat, 3)
2092 	MIPS_SYS(sys_faccessat, 3)	/* 4300 */
2093 	MIPS_SYS(sys_pselect6, 6)
2094 	MIPS_SYS(sys_ppoll, 5)
2095 	MIPS_SYS(sys_unshare, 1)
2096 	MIPS_SYS(sys_splice, 6)
2097 	MIPS_SYS(sys_sync_file_range, 7) /* 4305 */
2098 	MIPS_SYS(sys_tee, 4)
2099 	MIPS_SYS(sys_vmsplice, 4)
2100 	MIPS_SYS(sys_move_pages, 6)
2101 	MIPS_SYS(sys_set_robust_list, 2)
2102 	MIPS_SYS(sys_get_robust_list, 3) /* 4310 */
2103 	MIPS_SYS(sys_kexec_load, 4)
2104 	MIPS_SYS(sys_getcpu, 3)
2105 	MIPS_SYS(sys_epoll_pwait, 6)
2106 	MIPS_SYS(sys_ioprio_set, 3)
2107 	MIPS_SYS(sys_ioprio_get, 2)
2108         MIPS_SYS(sys_utimensat, 4)
2109         MIPS_SYS(sys_signalfd, 3)
2110         MIPS_SYS(sys_ni_syscall, 0)     /* was timerfd */
2111         MIPS_SYS(sys_eventfd, 1)
2112         MIPS_SYS(sys_fallocate, 6)      /* 4320 */
2113         MIPS_SYS(sys_timerfd_create, 2)
2114         MIPS_SYS(sys_timerfd_gettime, 2)
2115         MIPS_SYS(sys_timerfd_settime, 4)
2116         MIPS_SYS(sys_signalfd4, 4)
2117         MIPS_SYS(sys_eventfd2, 2)       /* 4325 */
2118         MIPS_SYS(sys_epoll_create1, 1)
2119         MIPS_SYS(sys_dup3, 3)
2120         MIPS_SYS(sys_pipe2, 2)
2121         MIPS_SYS(sys_inotify_init1, 1)
2122         MIPS_SYS(sys_preadv, 5)         /* 4330 */
2123         MIPS_SYS(sys_pwritev, 5)
2124         MIPS_SYS(sys_rt_tgsigqueueinfo, 4)
2125         MIPS_SYS(sys_perf_event_open, 5)
2126         MIPS_SYS(sys_accept4, 4)
2127         MIPS_SYS(sys_recvmmsg, 5)       /* 4335 */
2128         MIPS_SYS(sys_fanotify_init, 2)
2129         MIPS_SYS(sys_fanotify_mark, 6)
2130         MIPS_SYS(sys_prlimit64, 4)
2131         MIPS_SYS(sys_name_to_handle_at, 5)
2132         MIPS_SYS(sys_open_by_handle_at, 3) /* 4340 */
2133         MIPS_SYS(sys_clock_adjtime, 2)
2134         MIPS_SYS(sys_syncfs, 1)
2135         MIPS_SYS(sys_sendmmsg, 4)
2136         MIPS_SYS(sys_setns, 2)
2137         MIPS_SYS(sys_process_vm_readv, 6) /* 345 */
2138         MIPS_SYS(sys_process_vm_writev, 6)
2139         MIPS_SYS(sys_kcmp, 5)
2140         MIPS_SYS(sys_finit_module, 3)
2141         MIPS_SYS(sys_sched_setattr, 2)
2142         MIPS_SYS(sys_sched_getattr, 3)  /* 350 */
2143         MIPS_SYS(sys_renameat2, 5)
2144         MIPS_SYS(sys_seccomp, 3)
2145         MIPS_SYS(sys_getrandom, 3)
2146         MIPS_SYS(sys_memfd_create, 2)
2147         MIPS_SYS(sys_bpf, 3)            /* 355 */
2148         MIPS_SYS(sys_execveat, 5)
2149         MIPS_SYS(sys_userfaultfd, 1)
2150         MIPS_SYS(sys_membarrier, 2)
2151         MIPS_SYS(sys_mlock2, 3)
2152         MIPS_SYS(sys_copy_file_range, 6) /* 360 */
2153         MIPS_SYS(sys_preadv2, 6)
2154         MIPS_SYS(sys_pwritev2, 6)
2155 };
2156 #  undef MIPS_SYS
2157 # endif /* O32 */
2158 
2159 static int do_store_exclusive(CPUMIPSState *env)
2160 {
2161     target_ulong addr;
2162     target_ulong page_addr;
2163     target_ulong val;
2164     int flags;
2165     int segv = 0;
2166     int reg;
2167     int d;
2168 
2169     addr = env->lladdr;
2170     page_addr = addr & TARGET_PAGE_MASK;
2171     start_exclusive();
2172     mmap_lock();
2173     flags = page_get_flags(page_addr);
2174     if ((flags & PAGE_READ) == 0) {
2175         segv = 1;
2176     } else {
2177         reg = env->llreg & 0x1f;
2178         d = (env->llreg & 0x20) != 0;
2179         if (d) {
2180             segv = get_user_s64(val, addr);
2181         } else {
2182             segv = get_user_s32(val, addr);
2183         }
2184         if (!segv) {
2185             if (val != env->llval) {
2186                 env->active_tc.gpr[reg] = 0;
2187             } else {
2188                 if (d) {
2189                     segv = put_user_u64(env->llnewval, addr);
2190                 } else {
2191                     segv = put_user_u32(env->llnewval, addr);
2192                 }
2193                 if (!segv) {
2194                     env->active_tc.gpr[reg] = 1;
2195                 }
2196             }
2197         }
2198     }
2199     env->lladdr = -1;
2200     if (!segv) {
2201         env->active_tc.PC += 4;
2202     }
2203     mmap_unlock();
2204     end_exclusive();
2205     return segv;
2206 }
2207 
2208 /* Break codes */
2209 enum {
2210     BRK_OVERFLOW = 6,
2211     BRK_DIVZERO = 7
2212 };
2213 
2214 static int do_break(CPUMIPSState *env, target_siginfo_t *info,
2215                     unsigned int code)
2216 {
2217     int ret = -1;
2218 
2219     switch (code) {
2220     case BRK_OVERFLOW:
2221     case BRK_DIVZERO:
2222         info->si_signo = TARGET_SIGFPE;
2223         info->si_errno = 0;
2224         info->si_code = (code == BRK_OVERFLOW) ? FPE_INTOVF : FPE_INTDIV;
2225         queue_signal(env, info->si_signo, QEMU_SI_FAULT, &*info);
2226         ret = 0;
2227         break;
2228     default:
2229         info->si_signo = TARGET_SIGTRAP;
2230         info->si_errno = 0;
2231         queue_signal(env, info->si_signo, QEMU_SI_FAULT, &*info);
2232         ret = 0;
2233         break;
2234     }
2235 
2236     return ret;
2237 }
2238 
2239 void cpu_loop(CPUMIPSState *env)
2240 {
2241     CPUState *cs = CPU(mips_env_get_cpu(env));
2242     target_siginfo_t info;
2243     int trapnr;
2244     abi_long ret;
2245 # ifdef TARGET_ABI_MIPSO32
2246     unsigned int syscall_num;
2247 # endif
2248 
2249     for(;;) {
2250         cpu_exec_start(cs);
2251         trapnr = cpu_exec(cs);
2252         cpu_exec_end(cs);
2253         process_queued_cpu_work(cs);
2254 
2255         switch(trapnr) {
2256         case EXCP_SYSCALL:
2257             env->active_tc.PC += 4;
2258 # ifdef TARGET_ABI_MIPSO32
2259             syscall_num = env->active_tc.gpr[2] - 4000;
2260             if (syscall_num >= sizeof(mips_syscall_args)) {
2261                 ret = -TARGET_ENOSYS;
2262             } else {
2263                 int nb_args;
2264                 abi_ulong sp_reg;
2265                 abi_ulong arg5 = 0, arg6 = 0, arg7 = 0, arg8 = 0;
2266 
2267                 nb_args = mips_syscall_args[syscall_num];
2268                 sp_reg = env->active_tc.gpr[29];
2269                 switch (nb_args) {
2270                 /* these arguments are taken from the stack */
2271                 case 8:
2272                     if ((ret = get_user_ual(arg8, sp_reg + 28)) != 0) {
2273                         goto done_syscall;
2274                     }
2275                 case 7:
2276                     if ((ret = get_user_ual(arg7, sp_reg + 24)) != 0) {
2277                         goto done_syscall;
2278                     }
2279                 case 6:
2280                     if ((ret = get_user_ual(arg6, sp_reg + 20)) != 0) {
2281                         goto done_syscall;
2282                     }
2283                 case 5:
2284                     if ((ret = get_user_ual(arg5, sp_reg + 16)) != 0) {
2285                         goto done_syscall;
2286                     }
2287                 default:
2288                     break;
2289                 }
2290                 ret = do_syscall(env, env->active_tc.gpr[2],
2291                                  env->active_tc.gpr[4],
2292                                  env->active_tc.gpr[5],
2293                                  env->active_tc.gpr[6],
2294                                  env->active_tc.gpr[7],
2295                                  arg5, arg6, arg7, arg8);
2296             }
2297 done_syscall:
2298 # else
2299             ret = do_syscall(env, env->active_tc.gpr[2],
2300                              env->active_tc.gpr[4], env->active_tc.gpr[5],
2301                              env->active_tc.gpr[6], env->active_tc.gpr[7],
2302                              env->active_tc.gpr[8], env->active_tc.gpr[9],
2303                              env->active_tc.gpr[10], env->active_tc.gpr[11]);
2304 # endif /* O32 */
2305             if (ret == -TARGET_ERESTARTSYS) {
2306                 env->active_tc.PC -= 4;
2307                 break;
2308             }
2309             if (ret == -TARGET_QEMU_ESIGRETURN) {
2310                 /* Returning from a successful sigreturn syscall.
2311                    Avoid clobbering register state.  */
2312                 break;
2313             }
2314             if ((abi_ulong)ret >= (abi_ulong)-1133) {
2315                 env->active_tc.gpr[7] = 1; /* error flag */
2316                 ret = -ret;
2317             } else {
2318                 env->active_tc.gpr[7] = 0; /* error flag */
2319             }
2320             env->active_tc.gpr[2] = ret;
2321             break;
2322         case EXCP_TLBL:
2323         case EXCP_TLBS:
2324         case EXCP_AdEL:
2325         case EXCP_AdES:
2326             info.si_signo = TARGET_SIGSEGV;
2327             info.si_errno = 0;
2328             /* XXX: check env->error_code */
2329             info.si_code = TARGET_SEGV_MAPERR;
2330             info._sifields._sigfault._addr = env->CP0_BadVAddr;
2331             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2332             break;
2333         case EXCP_CpU:
2334         case EXCP_RI:
2335             info.si_signo = TARGET_SIGILL;
2336             info.si_errno = 0;
2337             info.si_code = 0;
2338             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2339             break;
2340         case EXCP_INTERRUPT:
2341             /* just indicate that signals should be handled asap */
2342             break;
2343         case EXCP_DEBUG:
2344             {
2345                 int sig;
2346 
2347                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
2348                 if (sig)
2349                   {
2350                     info.si_signo = sig;
2351                     info.si_errno = 0;
2352                     info.si_code = TARGET_TRAP_BRKPT;
2353                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2354                   }
2355             }
2356             break;
2357         case EXCP_SC:
2358             if (do_store_exclusive(env)) {
2359                 info.si_signo = TARGET_SIGSEGV;
2360                 info.si_errno = 0;
2361                 info.si_code = TARGET_SEGV_MAPERR;
2362                 info._sifields._sigfault._addr = env->active_tc.PC;
2363                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2364             }
2365             break;
2366         case EXCP_DSPDIS:
2367             info.si_signo = TARGET_SIGILL;
2368             info.si_errno = 0;
2369             info.si_code = TARGET_ILL_ILLOPC;
2370             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2371             break;
2372         /* The code below was inspired by the MIPS Linux kernel trap
2373          * handling code in arch/mips/kernel/traps.c.
2374          */
2375         case EXCP_BREAK:
2376             {
2377                 abi_ulong trap_instr;
2378                 unsigned int code;
2379 
2380                 if (env->hflags & MIPS_HFLAG_M16) {
2381                     if (env->insn_flags & ASE_MICROMIPS) {
2382                         /* microMIPS mode */
2383                         ret = get_user_u16(trap_instr, env->active_tc.PC);
2384                         if (ret != 0) {
2385                             goto error;
2386                         }
2387 
2388                         if ((trap_instr >> 10) == 0x11) {
2389                             /* 16-bit instruction */
2390                             code = trap_instr & 0xf;
2391                         } else {
2392                             /* 32-bit instruction */
2393                             abi_ulong instr_lo;
2394 
2395                             ret = get_user_u16(instr_lo,
2396                                                env->active_tc.PC + 2);
2397                             if (ret != 0) {
2398                                 goto error;
2399                             }
2400                             trap_instr = (trap_instr << 16) | instr_lo;
2401                             code = ((trap_instr >> 6) & ((1 << 20) - 1));
2402                             /* Unfortunately, microMIPS also suffers from
2403                                the old assembler bug...  */
2404                             if (code >= (1 << 10)) {
2405                                 code >>= 10;
2406                             }
2407                         }
2408                     } else {
2409                         /* MIPS16e mode */
2410                         ret = get_user_u16(trap_instr, env->active_tc.PC);
2411                         if (ret != 0) {
2412                             goto error;
2413                         }
2414                         code = (trap_instr >> 6) & 0x3f;
2415                     }
2416                 } else {
2417                     ret = get_user_u32(trap_instr, env->active_tc.PC);
2418                     if (ret != 0) {
2419                         goto error;
2420                     }
2421 
2422                     /* As described in the original Linux kernel code, the
2423                      * below checks on 'code' are to work around an old
2424                      * assembly bug.
2425                      */
2426                     code = ((trap_instr >> 6) & ((1 << 20) - 1));
2427                     if (code >= (1 << 10)) {
2428                         code >>= 10;
2429                     }
2430                 }
2431 
2432                 if (do_break(env, &info, code) != 0) {
2433                     goto error;
2434                 }
2435             }
2436             break;
2437         case EXCP_TRAP:
2438             {
2439                 abi_ulong trap_instr;
2440                 unsigned int code = 0;
2441 
2442                 if (env->hflags & MIPS_HFLAG_M16) {
2443                     /* microMIPS mode */
2444                     abi_ulong instr[2];
2445 
2446                     ret = get_user_u16(instr[0], env->active_tc.PC) ||
2447                           get_user_u16(instr[1], env->active_tc.PC + 2);
2448 
2449                     trap_instr = (instr[0] << 16) | instr[1];
2450                 } else {
2451                     ret = get_user_u32(trap_instr, env->active_tc.PC);
2452                 }
2453 
2454                 if (ret != 0) {
2455                     goto error;
2456                 }
2457 
2458                 /* The immediate versions don't provide a code.  */
2459                 if (!(trap_instr & 0xFC000000)) {
2460                     if (env->hflags & MIPS_HFLAG_M16) {
2461                         /* microMIPS mode */
2462                         code = ((trap_instr >> 12) & ((1 << 4) - 1));
2463                     } else {
2464                         code = ((trap_instr >> 6) & ((1 << 10) - 1));
2465                     }
2466                 }
2467 
2468                 if (do_break(env, &info, code) != 0) {
2469                     goto error;
2470                 }
2471             }
2472             break;
2473         case EXCP_ATOMIC:
2474             cpu_exec_step_atomic(cs);
2475             break;
2476         default:
2477 error:
2478             EXCP_DUMP(env, "qemu: unhandled CPU exception 0x%x - aborting\n", trapnr);
2479             abort();
2480         }
2481         process_pending_signals(env);
2482     }
2483 }
2484 #endif
2485 
2486 #ifdef TARGET_NIOS2
2487 
2488 void cpu_loop(CPUNios2State *env)
2489 {
2490     CPUState *cs = ENV_GET_CPU(env);
2491     Nios2CPU *cpu = NIOS2_CPU(cs);
2492     target_siginfo_t info;
2493     int trapnr, gdbsig, ret;
2494 
2495     for (;;) {
2496         cpu_exec_start(cs);
2497         trapnr = cpu_exec(cs);
2498         cpu_exec_end(cs);
2499         gdbsig = 0;
2500 
2501         switch (trapnr) {
2502         case EXCP_INTERRUPT:
2503             /* just indicate that signals should be handled asap */
2504             break;
2505         case EXCP_TRAP:
2506             if (env->regs[R_AT] == 0) {
2507                 abi_long ret;
2508                 qemu_log_mask(CPU_LOG_INT, "\nSyscall\n");
2509 
2510                 ret = do_syscall(env, env->regs[2],
2511                                  env->regs[4], env->regs[5], env->regs[6],
2512                                  env->regs[7], env->regs[8], env->regs[9],
2513                                  0, 0);
2514 
2515                 if (env->regs[2] == 0) {    /* FIXME: syscall 0 workaround */
2516                     ret = 0;
2517                 }
2518 
2519                 env->regs[2] = abs(ret);
2520                 /* Return value is 0..4096 */
2521                 env->regs[7] = (ret > 0xfffffffffffff000ULL);
2522                 env->regs[CR_ESTATUS] = env->regs[CR_STATUS];
2523                 env->regs[CR_STATUS] &= ~0x3;
2524                 env->regs[R_EA] = env->regs[R_PC] + 4;
2525                 env->regs[R_PC] += 4;
2526                 break;
2527             } else {
2528                 qemu_log_mask(CPU_LOG_INT, "\nTrap\n");
2529 
2530                 env->regs[CR_ESTATUS] = env->regs[CR_STATUS];
2531                 env->regs[CR_STATUS] &= ~0x3;
2532                 env->regs[R_EA] = env->regs[R_PC] + 4;
2533                 env->regs[R_PC] = cpu->exception_addr;
2534 
2535                 gdbsig = TARGET_SIGTRAP;
2536                 break;
2537             }
2538         case 0xaa:
2539             switch (env->regs[R_PC]) {
2540             /*case 0x1000:*/  /* TODO:__kuser_helper_version */
2541             case 0x1004:      /* __kuser_cmpxchg */
2542                 start_exclusive();
2543                 if (env->regs[4] & 0x3) {
2544                     goto kuser_fail;
2545                 }
2546                 ret = get_user_u32(env->regs[2], env->regs[4]);
2547                 if (ret) {
2548                     end_exclusive();
2549                     goto kuser_fail;
2550                 }
2551                 env->regs[2] -= env->regs[5];
2552                 if (env->regs[2] == 0) {
2553                     put_user_u32(env->regs[6], env->regs[4]);
2554                 }
2555                 end_exclusive();
2556                 env->regs[R_PC] = env->regs[R_RA];
2557                 break;
2558             /*case 0x1040:*/  /* TODO:__kuser_sigtramp */
2559             default:
2560                 ;
2561 kuser_fail:
2562                 info.si_signo = TARGET_SIGSEGV;
2563                 info.si_errno = 0;
2564                 /* TODO: check env->error_code */
2565                 info.si_code = TARGET_SEGV_MAPERR;
2566                 info._sifields._sigfault._addr = env->regs[R_PC];
2567                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2568             }
2569             break;
2570         default:
2571             EXCP_DUMP(env, "\nqemu: unhandled CPU exception %#x - aborting\n",
2572                      trapnr);
2573             gdbsig = TARGET_SIGILL;
2574             break;
2575         }
2576         if (gdbsig) {
2577             gdb_handlesig(cs, gdbsig);
2578             if (gdbsig != TARGET_SIGTRAP) {
2579                 exit(EXIT_FAILURE);
2580             }
2581         }
2582 
2583         process_pending_signals(env);
2584     }
2585 }
2586 
2587 #endif /* TARGET_NIOS2 */
2588 
2589 #ifdef TARGET_OPENRISC
2590 
2591 void cpu_loop(CPUOpenRISCState *env)
2592 {
2593     CPUState *cs = CPU(openrisc_env_get_cpu(env));
2594     int trapnr;
2595     abi_long ret;
2596     target_siginfo_t info;
2597 
2598     for (;;) {
2599         cpu_exec_start(cs);
2600         trapnr = cpu_exec(cs);
2601         cpu_exec_end(cs);
2602         process_queued_cpu_work(cs);
2603 
2604         switch (trapnr) {
2605         case EXCP_SYSCALL:
2606             env->pc += 4;   /* 0xc00; */
2607             ret = do_syscall(env,
2608                              cpu_get_gpr(env, 11), /* return value       */
2609                              cpu_get_gpr(env, 3),  /* r3 - r7 are params */
2610                              cpu_get_gpr(env, 4),
2611                              cpu_get_gpr(env, 5),
2612                              cpu_get_gpr(env, 6),
2613                              cpu_get_gpr(env, 7),
2614                              cpu_get_gpr(env, 8), 0, 0);
2615             if (ret == -TARGET_ERESTARTSYS) {
2616                 env->pc -= 4;
2617             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
2618                 cpu_set_gpr(env, 11, ret);
2619             }
2620             break;
2621         case EXCP_DPF:
2622         case EXCP_IPF:
2623         case EXCP_RANGE:
2624             info.si_signo = TARGET_SIGSEGV;
2625             info.si_errno = 0;
2626             info.si_code = TARGET_SEGV_MAPERR;
2627             info._sifields._sigfault._addr = env->pc;
2628             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2629             break;
2630         case EXCP_ALIGN:
2631             info.si_signo = TARGET_SIGBUS;
2632             info.si_errno = 0;
2633             info.si_code = TARGET_BUS_ADRALN;
2634             info._sifields._sigfault._addr = env->pc;
2635             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2636             break;
2637         case EXCP_ILLEGAL:
2638             info.si_signo = TARGET_SIGILL;
2639             info.si_errno = 0;
2640             info.si_code = TARGET_ILL_ILLOPC;
2641             info._sifields._sigfault._addr = env->pc;
2642             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2643             break;
2644         case EXCP_FPE:
2645             info.si_signo = TARGET_SIGFPE;
2646             info.si_errno = 0;
2647             info.si_code = 0;
2648             info._sifields._sigfault._addr = env->pc;
2649             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2650             break;
2651         case EXCP_INTERRUPT:
2652             /* We processed the pending cpu work above.  */
2653             break;
2654         case EXCP_DEBUG:
2655             trapnr = gdb_handlesig(cs, TARGET_SIGTRAP);
2656             if (trapnr) {
2657                 info.si_signo = trapnr;
2658                 info.si_errno = 0;
2659                 info.si_code = TARGET_TRAP_BRKPT;
2660                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2661             }
2662             break;
2663         case EXCP_ATOMIC:
2664             cpu_exec_step_atomic(cs);
2665             break;
2666         default:
2667             g_assert_not_reached();
2668         }
2669         process_pending_signals(env);
2670     }
2671 }
2672 
2673 #endif /* TARGET_OPENRISC */
2674 
2675 #ifdef TARGET_SH4
2676 void cpu_loop(CPUSH4State *env)
2677 {
2678     CPUState *cs = CPU(sh_env_get_cpu(env));
2679     int trapnr, ret;
2680     target_siginfo_t info;
2681 
2682     while (1) {
2683         cpu_exec_start(cs);
2684         trapnr = cpu_exec(cs);
2685         cpu_exec_end(cs);
2686         process_queued_cpu_work(cs);
2687 
2688         switch (trapnr) {
2689         case 0x160:
2690             env->pc += 2;
2691             ret = do_syscall(env,
2692                              env->gregs[3],
2693                              env->gregs[4],
2694                              env->gregs[5],
2695                              env->gregs[6],
2696                              env->gregs[7],
2697                              env->gregs[0],
2698                              env->gregs[1],
2699                              0, 0);
2700             if (ret == -TARGET_ERESTARTSYS) {
2701                 env->pc -= 2;
2702             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
2703                 env->gregs[0] = ret;
2704             }
2705             break;
2706         case EXCP_INTERRUPT:
2707             /* just indicate that signals should be handled asap */
2708             break;
2709         case EXCP_DEBUG:
2710             {
2711                 int sig;
2712 
2713                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
2714                 if (sig)
2715                   {
2716                     info.si_signo = sig;
2717                     info.si_errno = 0;
2718                     info.si_code = TARGET_TRAP_BRKPT;
2719                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2720                   }
2721             }
2722             break;
2723 	case 0xa0:
2724 	case 0xc0:
2725             info.si_signo = TARGET_SIGSEGV;
2726             info.si_errno = 0;
2727             info.si_code = TARGET_SEGV_MAPERR;
2728             info._sifields._sigfault._addr = env->tea;
2729             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2730 	    break;
2731 
2732         case EXCP_ATOMIC:
2733             cpu_exec_step_atomic(cs);
2734             break;
2735         default:
2736             printf ("Unhandled trap: 0x%x\n", trapnr);
2737             cpu_dump_state(cs, stderr, fprintf, 0);
2738             exit(EXIT_FAILURE);
2739         }
2740         process_pending_signals (env);
2741     }
2742 }
2743 #endif
2744 
2745 #ifdef TARGET_CRIS
2746 void cpu_loop(CPUCRISState *env)
2747 {
2748     CPUState *cs = CPU(cris_env_get_cpu(env));
2749     int trapnr, ret;
2750     target_siginfo_t info;
2751 
2752     while (1) {
2753         cpu_exec_start(cs);
2754         trapnr = cpu_exec(cs);
2755         cpu_exec_end(cs);
2756         process_queued_cpu_work(cs);
2757 
2758         switch (trapnr) {
2759         case 0xaa:
2760             {
2761                 info.si_signo = TARGET_SIGSEGV;
2762                 info.si_errno = 0;
2763                 /* XXX: check env->error_code */
2764                 info.si_code = TARGET_SEGV_MAPERR;
2765                 info._sifields._sigfault._addr = env->pregs[PR_EDA];
2766                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2767             }
2768             break;
2769 	case EXCP_INTERRUPT:
2770 	  /* just indicate that signals should be handled asap */
2771 	  break;
2772         case EXCP_BREAK:
2773             ret = do_syscall(env,
2774                              env->regs[9],
2775                              env->regs[10],
2776                              env->regs[11],
2777                              env->regs[12],
2778                              env->regs[13],
2779                              env->pregs[7],
2780                              env->pregs[11],
2781                              0, 0);
2782             if (ret == -TARGET_ERESTARTSYS) {
2783                 env->pc -= 2;
2784             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
2785                 env->regs[10] = ret;
2786             }
2787             break;
2788         case EXCP_DEBUG:
2789             {
2790                 int sig;
2791 
2792                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
2793                 if (sig)
2794                   {
2795                     info.si_signo = sig;
2796                     info.si_errno = 0;
2797                     info.si_code = TARGET_TRAP_BRKPT;
2798                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2799                   }
2800             }
2801             break;
2802         case EXCP_ATOMIC:
2803             cpu_exec_step_atomic(cs);
2804             break;
2805         default:
2806             printf ("Unhandled trap: 0x%x\n", trapnr);
2807             cpu_dump_state(cs, stderr, fprintf, 0);
2808             exit(EXIT_FAILURE);
2809         }
2810         process_pending_signals (env);
2811     }
2812 }
2813 #endif
2814 
2815 #ifdef TARGET_MICROBLAZE
2816 void cpu_loop(CPUMBState *env)
2817 {
2818     CPUState *cs = CPU(mb_env_get_cpu(env));
2819     int trapnr, ret;
2820     target_siginfo_t info;
2821 
2822     while (1) {
2823         cpu_exec_start(cs);
2824         trapnr = cpu_exec(cs);
2825         cpu_exec_end(cs);
2826         process_queued_cpu_work(cs);
2827 
2828         switch (trapnr) {
2829         case 0xaa:
2830             {
2831                 info.si_signo = TARGET_SIGSEGV;
2832                 info.si_errno = 0;
2833                 /* XXX: check env->error_code */
2834                 info.si_code = TARGET_SEGV_MAPERR;
2835                 info._sifields._sigfault._addr = 0;
2836                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2837             }
2838             break;
2839 	case EXCP_INTERRUPT:
2840 	  /* just indicate that signals should be handled asap */
2841 	  break;
2842         case EXCP_BREAK:
2843             /* Return address is 4 bytes after the call.  */
2844             env->regs[14] += 4;
2845             env->sregs[SR_PC] = env->regs[14];
2846             ret = do_syscall(env,
2847                              env->regs[12],
2848                              env->regs[5],
2849                              env->regs[6],
2850                              env->regs[7],
2851                              env->regs[8],
2852                              env->regs[9],
2853                              env->regs[10],
2854                              0, 0);
2855             if (ret == -TARGET_ERESTARTSYS) {
2856                 /* Wind back to before the syscall. */
2857                 env->sregs[SR_PC] -= 4;
2858             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
2859                 env->regs[3] = ret;
2860             }
2861             /* All syscall exits result in guest r14 being equal to the
2862              * PC we return to, because the kernel syscall exit "rtbd" does
2863              * this. (This is true even for sigreturn(); note that r14 is
2864              * not a userspace-usable register, as the kernel may clobber it
2865              * at any point.)
2866              */
2867             env->regs[14] = env->sregs[SR_PC];
2868             break;
2869         case EXCP_HW_EXCP:
2870             env->regs[17] = env->sregs[SR_PC] + 4;
2871             if (env->iflags & D_FLAG) {
2872                 env->sregs[SR_ESR] |= 1 << 12;
2873                 env->sregs[SR_PC] -= 4;
2874                 /* FIXME: if branch was immed, replay the imm as well.  */
2875             }
2876 
2877             env->iflags &= ~(IMM_FLAG | D_FLAG);
2878 
2879             switch (env->sregs[SR_ESR] & 31) {
2880                 case ESR_EC_DIVZERO:
2881                     info.si_signo = TARGET_SIGFPE;
2882                     info.si_errno = 0;
2883                     info.si_code = TARGET_FPE_FLTDIV;
2884                     info._sifields._sigfault._addr = 0;
2885                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2886                     break;
2887                 case ESR_EC_FPU:
2888                     info.si_signo = TARGET_SIGFPE;
2889                     info.si_errno = 0;
2890                     if (env->sregs[SR_FSR] & FSR_IO) {
2891                         info.si_code = TARGET_FPE_FLTINV;
2892                     }
2893                     if (env->sregs[SR_FSR] & FSR_DZ) {
2894                         info.si_code = TARGET_FPE_FLTDIV;
2895                     }
2896                     info._sifields._sigfault._addr = 0;
2897                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2898                     break;
2899                 default:
2900                     printf ("Unhandled hw-exception: 0x%x\n",
2901                             env->sregs[SR_ESR] & ESR_EC_MASK);
2902                     cpu_dump_state(cs, stderr, fprintf, 0);
2903                     exit(EXIT_FAILURE);
2904                     break;
2905             }
2906             break;
2907         case EXCP_DEBUG:
2908             {
2909                 int sig;
2910 
2911                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
2912                 if (sig)
2913                   {
2914                     info.si_signo = sig;
2915                     info.si_errno = 0;
2916                     info.si_code = TARGET_TRAP_BRKPT;
2917                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2918                   }
2919             }
2920             break;
2921         case EXCP_ATOMIC:
2922             cpu_exec_step_atomic(cs);
2923             break;
2924         default:
2925             printf ("Unhandled trap: 0x%x\n", trapnr);
2926             cpu_dump_state(cs, stderr, fprintf, 0);
2927             exit(EXIT_FAILURE);
2928         }
2929         process_pending_signals (env);
2930     }
2931 }
2932 #endif
2933 
2934 #ifdef TARGET_M68K
2935 
2936 void cpu_loop(CPUM68KState *env)
2937 {
2938     CPUState *cs = CPU(m68k_env_get_cpu(env));
2939     int trapnr;
2940     unsigned int n;
2941     target_siginfo_t info;
2942     TaskState *ts = cs->opaque;
2943 
2944     for(;;) {
2945         cpu_exec_start(cs);
2946         trapnr = cpu_exec(cs);
2947         cpu_exec_end(cs);
2948         process_queued_cpu_work(cs);
2949 
2950         switch(trapnr) {
2951         case EXCP_ILLEGAL:
2952             {
2953                 if (ts->sim_syscalls) {
2954                     uint16_t nr;
2955                     get_user_u16(nr, env->pc + 2);
2956                     env->pc += 4;
2957                     do_m68k_simcall(env, nr);
2958                 } else {
2959                     goto do_sigill;
2960                 }
2961             }
2962             break;
2963         case EXCP_HALT_INSN:
2964             /* Semihosing syscall.  */
2965             env->pc += 4;
2966             do_m68k_semihosting(env, env->dregs[0]);
2967             break;
2968         case EXCP_LINEA:
2969         case EXCP_LINEF:
2970         case EXCP_UNSUPPORTED:
2971         do_sigill:
2972             info.si_signo = TARGET_SIGILL;
2973             info.si_errno = 0;
2974             info.si_code = TARGET_ILL_ILLOPN;
2975             info._sifields._sigfault._addr = env->pc;
2976             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2977             break;
2978         case EXCP_DIV0:
2979             info.si_signo = TARGET_SIGFPE;
2980             info.si_errno = 0;
2981             info.si_code = TARGET_FPE_INTDIV;
2982             info._sifields._sigfault._addr = env->pc;
2983             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
2984             break;
2985         case EXCP_TRAP0:
2986             {
2987                 abi_long ret;
2988                 ts->sim_syscalls = 0;
2989                 n = env->dregs[0];
2990                 env->pc += 2;
2991                 ret = do_syscall(env,
2992                                  n,
2993                                  env->dregs[1],
2994                                  env->dregs[2],
2995                                  env->dregs[3],
2996                                  env->dregs[4],
2997                                  env->dregs[5],
2998                                  env->aregs[0],
2999                                  0, 0);
3000                 if (ret == -TARGET_ERESTARTSYS) {
3001                     env->pc -= 2;
3002                 } else if (ret != -TARGET_QEMU_ESIGRETURN) {
3003                     env->dregs[0] = ret;
3004                 }
3005             }
3006             break;
3007         case EXCP_INTERRUPT:
3008             /* just indicate that signals should be handled asap */
3009             break;
3010         case EXCP_ACCESS:
3011             {
3012                 info.si_signo = TARGET_SIGSEGV;
3013                 info.si_errno = 0;
3014                 /* XXX: check env->error_code */
3015                 info.si_code = TARGET_SEGV_MAPERR;
3016                 info._sifields._sigfault._addr = env->mmu.ar;
3017                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3018             }
3019             break;
3020         case EXCP_DEBUG:
3021             {
3022                 int sig;
3023 
3024                 sig = gdb_handlesig(cs, TARGET_SIGTRAP);
3025                 if (sig)
3026                   {
3027                     info.si_signo = sig;
3028                     info.si_errno = 0;
3029                     info.si_code = TARGET_TRAP_BRKPT;
3030                     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3031                   }
3032             }
3033             break;
3034         case EXCP_ATOMIC:
3035             cpu_exec_step_atomic(cs);
3036             break;
3037         default:
3038             EXCP_DUMP(env, "qemu: unhandled CPU exception 0x%x - aborting\n", trapnr);
3039             abort();
3040         }
3041         process_pending_signals(env);
3042     }
3043 }
3044 #endif /* TARGET_M68K */
3045 
3046 #ifdef TARGET_ALPHA
3047 void cpu_loop(CPUAlphaState *env)
3048 {
3049     CPUState *cs = CPU(alpha_env_get_cpu(env));
3050     int trapnr;
3051     target_siginfo_t info;
3052     abi_long sysret;
3053 
3054     while (1) {
3055         bool arch_interrupt = true;
3056 
3057         cpu_exec_start(cs);
3058         trapnr = cpu_exec(cs);
3059         cpu_exec_end(cs);
3060         process_queued_cpu_work(cs);
3061 
3062         switch (trapnr) {
3063         case EXCP_RESET:
3064             fprintf(stderr, "Reset requested. Exit\n");
3065             exit(EXIT_FAILURE);
3066             break;
3067         case EXCP_MCHK:
3068             fprintf(stderr, "Machine check exception. Exit\n");
3069             exit(EXIT_FAILURE);
3070             break;
3071         case EXCP_SMP_INTERRUPT:
3072         case EXCP_CLK_INTERRUPT:
3073         case EXCP_DEV_INTERRUPT:
3074             fprintf(stderr, "External interrupt. Exit\n");
3075             exit(EXIT_FAILURE);
3076             break;
3077         case EXCP_MMFAULT:
3078             info.si_signo = TARGET_SIGSEGV;
3079             info.si_errno = 0;
3080             info.si_code = (page_get_flags(env->trap_arg0) & PAGE_VALID
3081                             ? TARGET_SEGV_ACCERR : TARGET_SEGV_MAPERR);
3082             info._sifields._sigfault._addr = env->trap_arg0;
3083             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3084             break;
3085         case EXCP_UNALIGN:
3086             info.si_signo = TARGET_SIGBUS;
3087             info.si_errno = 0;
3088             info.si_code = TARGET_BUS_ADRALN;
3089             info._sifields._sigfault._addr = env->trap_arg0;
3090             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3091             break;
3092         case EXCP_OPCDEC:
3093         do_sigill:
3094             info.si_signo = TARGET_SIGILL;
3095             info.si_errno = 0;
3096             info.si_code = TARGET_ILL_ILLOPC;
3097             info._sifields._sigfault._addr = env->pc;
3098             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3099             break;
3100         case EXCP_ARITH:
3101             info.si_signo = TARGET_SIGFPE;
3102             info.si_errno = 0;
3103             info.si_code = TARGET_FPE_FLTINV;
3104             info._sifields._sigfault._addr = env->pc;
3105             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3106             break;
3107         case EXCP_FEN:
3108             /* No-op.  Linux simply re-enables the FPU.  */
3109             break;
3110         case EXCP_CALL_PAL:
3111             switch (env->error_code) {
3112             case 0x80:
3113                 /* BPT */
3114                 info.si_signo = TARGET_SIGTRAP;
3115                 info.si_errno = 0;
3116                 info.si_code = TARGET_TRAP_BRKPT;
3117                 info._sifields._sigfault._addr = env->pc;
3118                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3119                 break;
3120             case 0x81:
3121                 /* BUGCHK */
3122                 info.si_signo = TARGET_SIGTRAP;
3123                 info.si_errno = 0;
3124                 info.si_code = 0;
3125                 info._sifields._sigfault._addr = env->pc;
3126                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3127                 break;
3128             case 0x83:
3129                 /* CALLSYS */
3130                 trapnr = env->ir[IR_V0];
3131                 sysret = do_syscall(env, trapnr,
3132                                     env->ir[IR_A0], env->ir[IR_A1],
3133                                     env->ir[IR_A2], env->ir[IR_A3],
3134                                     env->ir[IR_A4], env->ir[IR_A5],
3135                                     0, 0);
3136                 if (sysret == -TARGET_ERESTARTSYS) {
3137                     env->pc -= 4;
3138                     break;
3139                 }
3140                 if (sysret == -TARGET_QEMU_ESIGRETURN) {
3141                     break;
3142                 }
3143                 /* Syscall writes 0 to V0 to bypass error check, similar
3144                    to how this is handled internal to Linux kernel.
3145                    (Ab)use trapnr temporarily as boolean indicating error.  */
3146                 trapnr = (env->ir[IR_V0] != 0 && sysret < 0);
3147                 env->ir[IR_V0] = (trapnr ? -sysret : sysret);
3148                 env->ir[IR_A3] = trapnr;
3149                 break;
3150             case 0x86:
3151                 /* IMB */
3152                 /* ??? We can probably elide the code using page_unprotect
3153                    that is checking for self-modifying code.  Instead we
3154                    could simply call tb_flush here.  Until we work out the
3155                    changes required to turn off the extra write protection,
3156                    this can be a no-op.  */
3157                 break;
3158             case 0x9E:
3159                 /* RDUNIQUE */
3160                 /* Handled in the translator for usermode.  */
3161                 abort();
3162             case 0x9F:
3163                 /* WRUNIQUE */
3164                 /* Handled in the translator for usermode.  */
3165                 abort();
3166             case 0xAA:
3167                 /* GENTRAP */
3168                 info.si_signo = TARGET_SIGFPE;
3169                 switch (env->ir[IR_A0]) {
3170                 case TARGET_GEN_INTOVF:
3171                     info.si_code = TARGET_FPE_INTOVF;
3172                     break;
3173                 case TARGET_GEN_INTDIV:
3174                     info.si_code = TARGET_FPE_INTDIV;
3175                     break;
3176                 case TARGET_GEN_FLTOVF:
3177                     info.si_code = TARGET_FPE_FLTOVF;
3178                     break;
3179                 case TARGET_GEN_FLTUND:
3180                     info.si_code = TARGET_FPE_FLTUND;
3181                     break;
3182                 case TARGET_GEN_FLTINV:
3183                     info.si_code = TARGET_FPE_FLTINV;
3184                     break;
3185                 case TARGET_GEN_FLTINE:
3186                     info.si_code = TARGET_FPE_FLTRES;
3187                     break;
3188                 case TARGET_GEN_ROPRAND:
3189                     info.si_code = 0;
3190                     break;
3191                 default:
3192                     info.si_signo = TARGET_SIGTRAP;
3193                     info.si_code = 0;
3194                     break;
3195                 }
3196                 info.si_errno = 0;
3197                 info._sifields._sigfault._addr = env->pc;
3198                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3199                 break;
3200             default:
3201                 goto do_sigill;
3202             }
3203             break;
3204         case EXCP_DEBUG:
3205             info.si_signo = gdb_handlesig(cs, TARGET_SIGTRAP);
3206             if (info.si_signo) {
3207                 info.si_errno = 0;
3208                 info.si_code = TARGET_TRAP_BRKPT;
3209                 queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3210             } else {
3211                 arch_interrupt = false;
3212             }
3213             break;
3214         case EXCP_INTERRUPT:
3215             /* Just indicate that signals should be handled asap.  */
3216             break;
3217         case EXCP_ATOMIC:
3218             cpu_exec_step_atomic(cs);
3219             arch_interrupt = false;
3220             break;
3221         default:
3222             printf ("Unhandled trap: 0x%x\n", trapnr);
3223             cpu_dump_state(cs, stderr, fprintf, 0);
3224             exit(EXIT_FAILURE);
3225         }
3226         process_pending_signals (env);
3227 
3228         /* Most of the traps imply a transition through PALcode, which
3229            implies an REI instruction has been executed.  Which means
3230            that RX and LOCK_ADDR should be cleared.  But there are a
3231            few exceptions for traps internal to QEMU.  */
3232         if (arch_interrupt) {
3233             env->flags &= ~ENV_FLAG_RX_FLAG;
3234             env->lock_addr = -1;
3235         }
3236     }
3237 }
3238 #endif /* TARGET_ALPHA */
3239 
3240 #ifdef TARGET_S390X
3241 void cpu_loop(CPUS390XState *env)
3242 {
3243     CPUState *cs = CPU(s390_env_get_cpu(env));
3244     int trapnr, n, sig;
3245     target_siginfo_t info;
3246     target_ulong addr;
3247     abi_long ret;
3248 
3249     while (1) {
3250         cpu_exec_start(cs);
3251         trapnr = cpu_exec(cs);
3252         cpu_exec_end(cs);
3253         process_queued_cpu_work(cs);
3254 
3255         switch (trapnr) {
3256         case EXCP_INTERRUPT:
3257             /* Just indicate that signals should be handled asap.  */
3258             break;
3259 
3260         case EXCP_SVC:
3261             n = env->int_svc_code;
3262             if (!n) {
3263                 /* syscalls > 255 */
3264                 n = env->regs[1];
3265             }
3266             env->psw.addr += env->int_svc_ilen;
3267             ret = do_syscall(env, n, env->regs[2], env->regs[3],
3268                              env->regs[4], env->regs[5],
3269                              env->regs[6], env->regs[7], 0, 0);
3270             if (ret == -TARGET_ERESTARTSYS) {
3271                 env->psw.addr -= env->int_svc_ilen;
3272             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
3273                 env->regs[2] = ret;
3274             }
3275             break;
3276 
3277         case EXCP_DEBUG:
3278             sig = gdb_handlesig(cs, TARGET_SIGTRAP);
3279             if (sig) {
3280                 n = TARGET_TRAP_BRKPT;
3281                 goto do_signal_pc;
3282             }
3283             break;
3284         case EXCP_PGM:
3285             n = env->int_pgm_code;
3286             switch (n) {
3287             case PGM_OPERATION:
3288             case PGM_PRIVILEGED:
3289                 sig = TARGET_SIGILL;
3290                 n = TARGET_ILL_ILLOPC;
3291                 goto do_signal_pc;
3292             case PGM_PROTECTION:
3293             case PGM_ADDRESSING:
3294                 sig = TARGET_SIGSEGV;
3295                 /* XXX: check env->error_code */
3296                 n = TARGET_SEGV_MAPERR;
3297                 addr = env->__excp_addr;
3298                 goto do_signal;
3299             case PGM_EXECUTE:
3300             case PGM_SPECIFICATION:
3301             case PGM_SPECIAL_OP:
3302             case PGM_OPERAND:
3303             do_sigill_opn:
3304                 sig = TARGET_SIGILL;
3305                 n = TARGET_ILL_ILLOPN;
3306                 goto do_signal_pc;
3307 
3308             case PGM_FIXPT_OVERFLOW:
3309                 sig = TARGET_SIGFPE;
3310                 n = TARGET_FPE_INTOVF;
3311                 goto do_signal_pc;
3312             case PGM_FIXPT_DIVIDE:
3313                 sig = TARGET_SIGFPE;
3314                 n = TARGET_FPE_INTDIV;
3315                 goto do_signal_pc;
3316 
3317             case PGM_DATA:
3318                 n = (env->fpc >> 8) & 0xff;
3319                 if (n == 0xff) {
3320                     /* compare-and-trap */
3321                     goto do_sigill_opn;
3322                 } else {
3323                     /* An IEEE exception, simulated or otherwise.  */
3324                     if (n & 0x80) {
3325                         n = TARGET_FPE_FLTINV;
3326                     } else if (n & 0x40) {
3327                         n = TARGET_FPE_FLTDIV;
3328                     } else if (n & 0x20) {
3329                         n = TARGET_FPE_FLTOVF;
3330                     } else if (n & 0x10) {
3331                         n = TARGET_FPE_FLTUND;
3332                     } else if (n & 0x08) {
3333                         n = TARGET_FPE_FLTRES;
3334                     } else {
3335                         /* ??? Quantum exception; BFP, DFP error.  */
3336                         goto do_sigill_opn;
3337                     }
3338                     sig = TARGET_SIGFPE;
3339                     goto do_signal_pc;
3340                 }
3341 
3342             default:
3343                 fprintf(stderr, "Unhandled program exception: %#x\n", n);
3344                 cpu_dump_state(cs, stderr, fprintf, 0);
3345                 exit(EXIT_FAILURE);
3346             }
3347             break;
3348 
3349         do_signal_pc:
3350             addr = env->psw.addr;
3351         do_signal:
3352             info.si_signo = sig;
3353             info.si_errno = 0;
3354             info.si_code = n;
3355             info._sifields._sigfault._addr = addr;
3356             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3357             break;
3358 
3359         case EXCP_ATOMIC:
3360             cpu_exec_step_atomic(cs);
3361             break;
3362         default:
3363             fprintf(stderr, "Unhandled trap: 0x%x\n", trapnr);
3364             cpu_dump_state(cs, stderr, fprintf, 0);
3365             exit(EXIT_FAILURE);
3366         }
3367         process_pending_signals (env);
3368     }
3369 }
3370 
3371 #endif /* TARGET_S390X */
3372 
3373 #ifdef TARGET_TILEGX
3374 
3375 static void gen_sigill_reg(CPUTLGState *env)
3376 {
3377     target_siginfo_t info;
3378 
3379     info.si_signo = TARGET_SIGILL;
3380     info.si_errno = 0;
3381     info.si_code = TARGET_ILL_PRVREG;
3382     info._sifields._sigfault._addr = env->pc;
3383     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3384 }
3385 
3386 static void do_signal(CPUTLGState *env, int signo, int sigcode)
3387 {
3388     target_siginfo_t info;
3389 
3390     info.si_signo = signo;
3391     info.si_errno = 0;
3392     info._sifields._sigfault._addr = env->pc;
3393 
3394     if (signo == TARGET_SIGSEGV) {
3395         /* The passed in sigcode is a dummy; check for a page mapping
3396            and pass either MAPERR or ACCERR.  */
3397         target_ulong addr = env->excaddr;
3398         info._sifields._sigfault._addr = addr;
3399         if (page_check_range(addr, 1, PAGE_VALID) < 0) {
3400             sigcode = TARGET_SEGV_MAPERR;
3401         } else {
3402             sigcode = TARGET_SEGV_ACCERR;
3403         }
3404     }
3405     info.si_code = sigcode;
3406 
3407     queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3408 }
3409 
3410 static void gen_sigsegv_maperr(CPUTLGState *env, target_ulong addr)
3411 {
3412     env->excaddr = addr;
3413     do_signal(env, TARGET_SIGSEGV, 0);
3414 }
3415 
3416 static void set_regval(CPUTLGState *env, uint8_t reg, uint64_t val)
3417 {
3418     if (unlikely(reg >= TILEGX_R_COUNT)) {
3419         switch (reg) {
3420         case TILEGX_R_SN:
3421         case TILEGX_R_ZERO:
3422             return;
3423         case TILEGX_R_IDN0:
3424         case TILEGX_R_IDN1:
3425         case TILEGX_R_UDN0:
3426         case TILEGX_R_UDN1:
3427         case TILEGX_R_UDN2:
3428         case TILEGX_R_UDN3:
3429             gen_sigill_reg(env);
3430             return;
3431         default:
3432             g_assert_not_reached();
3433         }
3434     }
3435     env->regs[reg] = val;
3436 }
3437 
3438 /*
3439  * Compare the 8-byte contents of the CmpValue SPR with the 8-byte value in
3440  * memory at the address held in the first source register. If the values are
3441  * not equal, then no memory operation is performed. If the values are equal,
3442  * the 8-byte quantity from the second source register is written into memory
3443  * at the address held in the first source register. In either case, the result
3444  * of the instruction is the value read from memory. The compare and write to
3445  * memory are atomic and thus can be used for synchronization purposes. This
3446  * instruction only operates for addresses aligned to a 8-byte boundary.
3447  * Unaligned memory access causes an Unaligned Data Reference interrupt.
3448  *
3449  * Functional Description (64-bit)
3450  *       uint64_t memVal = memoryReadDoubleWord (rf[SrcA]);
3451  *       rf[Dest] = memVal;
3452  *       if (memVal == SPR[CmpValueSPR])
3453  *           memoryWriteDoubleWord (rf[SrcA], rf[SrcB]);
3454  *
3455  * Functional Description (32-bit)
3456  *       uint64_t memVal = signExtend32 (memoryReadWord (rf[SrcA]));
3457  *       rf[Dest] = memVal;
3458  *       if (memVal == signExtend32 (SPR[CmpValueSPR]))
3459  *           memoryWriteWord (rf[SrcA], rf[SrcB]);
3460  *
3461  *
3462  * This function also processes exch and exch4 which need not process SPR.
3463  */
3464 static void do_exch(CPUTLGState *env, bool quad, bool cmp)
3465 {
3466     target_ulong addr;
3467     target_long val, sprval;
3468 
3469     start_exclusive();
3470 
3471     addr = env->atomic_srca;
3472     if (quad ? get_user_s64(val, addr) : get_user_s32(val, addr)) {
3473         goto sigsegv_maperr;
3474     }
3475 
3476     if (cmp) {
3477         if (quad) {
3478             sprval = env->spregs[TILEGX_SPR_CMPEXCH];
3479         } else {
3480             sprval = sextract64(env->spregs[TILEGX_SPR_CMPEXCH], 0, 32);
3481         }
3482     }
3483 
3484     if (!cmp || val == sprval) {
3485         target_long valb = env->atomic_srcb;
3486         if (quad ? put_user_u64(valb, addr) : put_user_u32(valb, addr)) {
3487             goto sigsegv_maperr;
3488         }
3489     }
3490 
3491     set_regval(env, env->atomic_dstr, val);
3492     end_exclusive();
3493     return;
3494 
3495  sigsegv_maperr:
3496     end_exclusive();
3497     gen_sigsegv_maperr(env, addr);
3498 }
3499 
3500 static void do_fetch(CPUTLGState *env, int trapnr, bool quad)
3501 {
3502     int8_t write = 1;
3503     target_ulong addr;
3504     target_long val, valb;
3505 
3506     start_exclusive();
3507 
3508     addr = env->atomic_srca;
3509     valb = env->atomic_srcb;
3510     if (quad ? get_user_s64(val, addr) : get_user_s32(val, addr)) {
3511         goto sigsegv_maperr;
3512     }
3513 
3514     switch (trapnr) {
3515     case TILEGX_EXCP_OPCODE_FETCHADD:
3516     case TILEGX_EXCP_OPCODE_FETCHADD4:
3517         valb += val;
3518         break;
3519     case TILEGX_EXCP_OPCODE_FETCHADDGEZ:
3520         valb += val;
3521         if (valb < 0) {
3522             write = 0;
3523         }
3524         break;
3525     case TILEGX_EXCP_OPCODE_FETCHADDGEZ4:
3526         valb += val;
3527         if ((int32_t)valb < 0) {
3528             write = 0;
3529         }
3530         break;
3531     case TILEGX_EXCP_OPCODE_FETCHAND:
3532     case TILEGX_EXCP_OPCODE_FETCHAND4:
3533         valb &= val;
3534         break;
3535     case TILEGX_EXCP_OPCODE_FETCHOR:
3536     case TILEGX_EXCP_OPCODE_FETCHOR4:
3537         valb |= val;
3538         break;
3539     default:
3540         g_assert_not_reached();
3541     }
3542 
3543     if (write) {
3544         if (quad ? put_user_u64(valb, addr) : put_user_u32(valb, addr)) {
3545             goto sigsegv_maperr;
3546         }
3547     }
3548 
3549     set_regval(env, env->atomic_dstr, val);
3550     end_exclusive();
3551     return;
3552 
3553  sigsegv_maperr:
3554     end_exclusive();
3555     gen_sigsegv_maperr(env, addr);
3556 }
3557 
3558 void cpu_loop(CPUTLGState *env)
3559 {
3560     CPUState *cs = CPU(tilegx_env_get_cpu(env));
3561     int trapnr;
3562 
3563     while (1) {
3564         cpu_exec_start(cs);
3565         trapnr = cpu_exec(cs);
3566         cpu_exec_end(cs);
3567         process_queued_cpu_work(cs);
3568 
3569         switch (trapnr) {
3570         case TILEGX_EXCP_SYSCALL:
3571         {
3572             abi_ulong ret = do_syscall(env, env->regs[TILEGX_R_NR],
3573                                        env->regs[0], env->regs[1],
3574                                        env->regs[2], env->regs[3],
3575                                        env->regs[4], env->regs[5],
3576                                        env->regs[6], env->regs[7]);
3577             if (ret == -TARGET_ERESTARTSYS) {
3578                 env->pc -= 8;
3579             } else if (ret != -TARGET_QEMU_ESIGRETURN) {
3580                 env->regs[TILEGX_R_RE] = ret;
3581                 env->regs[TILEGX_R_ERR] = TILEGX_IS_ERRNO(ret) ? -ret : 0;
3582             }
3583             break;
3584         }
3585         case TILEGX_EXCP_OPCODE_EXCH:
3586             do_exch(env, true, false);
3587             break;
3588         case TILEGX_EXCP_OPCODE_EXCH4:
3589             do_exch(env, false, false);
3590             break;
3591         case TILEGX_EXCP_OPCODE_CMPEXCH:
3592             do_exch(env, true, true);
3593             break;
3594         case TILEGX_EXCP_OPCODE_CMPEXCH4:
3595             do_exch(env, false, true);
3596             break;
3597         case TILEGX_EXCP_OPCODE_FETCHADD:
3598         case TILEGX_EXCP_OPCODE_FETCHADDGEZ:
3599         case TILEGX_EXCP_OPCODE_FETCHAND:
3600         case TILEGX_EXCP_OPCODE_FETCHOR:
3601             do_fetch(env, trapnr, true);
3602             break;
3603         case TILEGX_EXCP_OPCODE_FETCHADD4:
3604         case TILEGX_EXCP_OPCODE_FETCHADDGEZ4:
3605         case TILEGX_EXCP_OPCODE_FETCHAND4:
3606         case TILEGX_EXCP_OPCODE_FETCHOR4:
3607             do_fetch(env, trapnr, false);
3608             break;
3609         case TILEGX_EXCP_SIGNAL:
3610             do_signal(env, env->signo, env->sigcode);
3611             break;
3612         case TILEGX_EXCP_REG_IDN_ACCESS:
3613         case TILEGX_EXCP_REG_UDN_ACCESS:
3614             gen_sigill_reg(env);
3615             break;
3616         case EXCP_ATOMIC:
3617             cpu_exec_step_atomic(cs);
3618             break;
3619         default:
3620             fprintf(stderr, "trapnr is %d[0x%x].\n", trapnr, trapnr);
3621             g_assert_not_reached();
3622         }
3623         process_pending_signals(env);
3624     }
3625 }
3626 
3627 #endif
3628 
3629 #ifdef TARGET_HPPA
3630 
3631 static abi_ulong hppa_lws(CPUHPPAState *env)
3632 {
3633     uint32_t which = env->gr[20];
3634     abi_ulong addr = env->gr[26];
3635     abi_ulong old = env->gr[25];
3636     abi_ulong new = env->gr[24];
3637     abi_ulong size, ret;
3638 
3639     switch (which) {
3640     default:
3641         return -TARGET_ENOSYS;
3642 
3643     case 0: /* elf32 atomic 32bit cmpxchg */
3644         if ((addr & 3) || !access_ok(VERIFY_WRITE, addr, 4)) {
3645             return -TARGET_EFAULT;
3646         }
3647         old = tswap32(old);
3648         new = tswap32(new);
3649         ret = atomic_cmpxchg((uint32_t *)g2h(addr), old, new);
3650         ret = tswap32(ret);
3651         break;
3652 
3653     case 2: /* elf32 atomic "new" cmpxchg */
3654         size = env->gr[23];
3655         if (size >= 4) {
3656             return -TARGET_ENOSYS;
3657         }
3658         if (((addr | old | new) & ((1 << size) - 1))
3659             || !access_ok(VERIFY_WRITE, addr, 1 << size)
3660             || !access_ok(VERIFY_READ, old, 1 << size)
3661             || !access_ok(VERIFY_READ, new, 1 << size)) {
3662             return -TARGET_EFAULT;
3663         }
3664         /* Note that below we use host-endian loads so that the cmpxchg
3665            can be host-endian as well.  */
3666         switch (size) {
3667         case 0:
3668             old = *(uint8_t *)g2h(old);
3669             new = *(uint8_t *)g2h(new);
3670             ret = atomic_cmpxchg((uint8_t *)g2h(addr), old, new);
3671             ret = ret != old;
3672             break;
3673         case 1:
3674             old = *(uint16_t *)g2h(old);
3675             new = *(uint16_t *)g2h(new);
3676             ret = atomic_cmpxchg((uint16_t *)g2h(addr), old, new);
3677             ret = ret != old;
3678             break;
3679         case 2:
3680             old = *(uint32_t *)g2h(old);
3681             new = *(uint32_t *)g2h(new);
3682             ret = atomic_cmpxchg((uint32_t *)g2h(addr), old, new);
3683             ret = ret != old;
3684             break;
3685         case 3:
3686             {
3687                 uint64_t o64, n64, r64;
3688                 o64 = *(uint64_t *)g2h(old);
3689                 n64 = *(uint64_t *)g2h(new);
3690 #ifdef CONFIG_ATOMIC64
3691                 r64 = atomic_cmpxchg__nocheck((uint64_t *)g2h(addr), o64, n64);
3692                 ret = r64 != o64;
3693 #else
3694                 start_exclusive();
3695                 r64 = *(uint64_t *)g2h(addr);
3696                 ret = 1;
3697                 if (r64 == o64) {
3698                     *(uint64_t *)g2h(addr) = n64;
3699                     ret = 0;
3700                 }
3701                 end_exclusive();
3702 #endif
3703             }
3704             break;
3705         }
3706         break;
3707     }
3708 
3709     env->gr[28] = ret;
3710     return 0;
3711 }
3712 
3713 void cpu_loop(CPUHPPAState *env)
3714 {
3715     CPUState *cs = CPU(hppa_env_get_cpu(env));
3716     target_siginfo_t info;
3717     abi_ulong ret;
3718     int trapnr;
3719 
3720     while (1) {
3721         cpu_exec_start(cs);
3722         trapnr = cpu_exec(cs);
3723         cpu_exec_end(cs);
3724         process_queued_cpu_work(cs);
3725 
3726         switch (trapnr) {
3727         case EXCP_SYSCALL:
3728             ret = do_syscall(env, env->gr[20],
3729                              env->gr[26], env->gr[25],
3730                              env->gr[24], env->gr[23],
3731                              env->gr[22], env->gr[21], 0, 0);
3732             switch (ret) {
3733             default:
3734                 env->gr[28] = ret;
3735                 /* We arrived here by faking the gateway page.  Return.  */
3736                 env->iaoq_f = env->gr[31];
3737                 env->iaoq_b = env->gr[31] + 4;
3738                 break;
3739             case -TARGET_ERESTARTSYS:
3740             case -TARGET_QEMU_ESIGRETURN:
3741                 break;
3742             }
3743             break;
3744         case EXCP_SYSCALL_LWS:
3745             env->gr[21] = hppa_lws(env);
3746             /* We arrived here by faking the gateway page.  Return.  */
3747             env->iaoq_f = env->gr[31];
3748             env->iaoq_b = env->gr[31] + 4;
3749             break;
3750         case EXCP_SIGSEGV:
3751             info.si_signo = TARGET_SIGSEGV;
3752             info.si_errno = 0;
3753             info.si_code = TARGET_SEGV_ACCERR;
3754             info._sifields._sigfault._addr = env->ior;
3755             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3756             break;
3757         case EXCP_SIGILL:
3758             info.si_signo = TARGET_SIGILL;
3759             info.si_errno = 0;
3760             info.si_code = TARGET_ILL_ILLOPN;
3761             info._sifields._sigfault._addr = env->iaoq_f;
3762             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3763             break;
3764         case EXCP_SIGFPE:
3765             info.si_signo = TARGET_SIGFPE;
3766             info.si_errno = 0;
3767             info.si_code = 0;
3768             info._sifields._sigfault._addr = env->iaoq_f;
3769             queue_signal(env, info.si_signo, QEMU_SI_FAULT, &info);
3770             break;
3771         case EXCP_DEBUG:
3772             trapnr = gdb_handlesig(cs, TARGET_SIGTRAP);
3773             if (trapnr) {
3774                 info.si_signo = trapnr;
3775                 info.si_errno = 0;
3776                 info.si_code = TARGET_TRAP_BRKPT;
3777                 queue_signal(env, trapnr, QEMU_SI_FAULT, &info);
3778             }
3779             break;
3780         case EXCP_INTERRUPT:
3781             /* just indicate that signals should be handled asap */
3782             break;
3783         default:
3784             g_assert_not_reached();
3785         }
3786         process_pending_signals(env);
3787     }
3788 }
3789 
3790 #endif /* TARGET_HPPA */
3791 
3792 THREAD CPUState *thread_cpu;
3793 
3794 bool qemu_cpu_is_self(CPUState *cpu)
3795 {
3796     return thread_cpu == cpu;
3797 }
3798 
3799 void qemu_cpu_kick(CPUState *cpu)
3800 {
3801     cpu_exit(cpu);
3802 }
3803 
3804 void task_settid(TaskState *ts)
3805 {
3806     if (ts->ts_tid == 0) {
3807         ts->ts_tid = (pid_t)syscall(SYS_gettid);
3808     }
3809 }
3810 
3811 void stop_all_tasks(void)
3812 {
3813     /*
3814      * We trust that when using NPTL, start_exclusive()
3815      * handles thread stopping correctly.
3816      */
3817     start_exclusive();
3818 }
3819 
3820 /* Assumes contents are already zeroed.  */
3821 void init_task_state(TaskState *ts)
3822 {
3823     ts->used = 1;
3824 }
3825 
3826 CPUArchState *cpu_copy(CPUArchState *env)
3827 {
3828     CPUState *cpu = ENV_GET_CPU(env);
3829     CPUState *new_cpu = cpu_init(cpu_model);
3830     CPUArchState *new_env = new_cpu->env_ptr;
3831     CPUBreakpoint *bp;
3832     CPUWatchpoint *wp;
3833 
3834     /* Reset non arch specific state */
3835     cpu_reset(new_cpu);
3836 
3837     memcpy(new_env, env, sizeof(CPUArchState));
3838 
3839     /* Clone all break/watchpoints.
3840        Note: Once we support ptrace with hw-debug register access, make sure
3841        BP_CPU break/watchpoints are handled correctly on clone. */
3842     QTAILQ_INIT(&new_cpu->breakpoints);
3843     QTAILQ_INIT(&new_cpu->watchpoints);
3844     QTAILQ_FOREACH(bp, &cpu->breakpoints, entry) {
3845         cpu_breakpoint_insert(new_cpu, bp->pc, bp->flags, NULL);
3846     }
3847     QTAILQ_FOREACH(wp, &cpu->watchpoints, entry) {
3848         cpu_watchpoint_insert(new_cpu, wp->vaddr, wp->len, wp->flags, NULL);
3849     }
3850 
3851     return new_env;
3852 }
3853 
3854 static void handle_arg_help(const char *arg)
3855 {
3856     usage(EXIT_SUCCESS);
3857 }
3858 
3859 static void handle_arg_log(const char *arg)
3860 {
3861     int mask;
3862 
3863     mask = qemu_str_to_log_mask(arg);
3864     if (!mask) {
3865         qemu_print_log_usage(stdout);
3866         exit(EXIT_FAILURE);
3867     }
3868     qemu_log_needs_buffers();
3869     qemu_set_log(mask);
3870 }
3871 
3872 static void handle_arg_dfilter(const char *arg)
3873 {
3874     qemu_set_dfilter_ranges(arg, NULL);
3875 }
3876 
3877 static void handle_arg_log_filename(const char *arg)
3878 {
3879     qemu_set_log_filename(arg, &error_fatal);
3880 }
3881 
3882 static void handle_arg_set_env(const char *arg)
3883 {
3884     char *r, *p, *token;
3885     r = p = strdup(arg);
3886     while ((token = strsep(&p, ",")) != NULL) {
3887         if (envlist_setenv(envlist, token) != 0) {
3888             usage(EXIT_FAILURE);
3889         }
3890     }
3891     free(r);
3892 }
3893 
3894 static void handle_arg_unset_env(const char *arg)
3895 {
3896     char *r, *p, *token;
3897     r = p = strdup(arg);
3898     while ((token = strsep(&p, ",")) != NULL) {
3899         if (envlist_unsetenv(envlist, token) != 0) {
3900             usage(EXIT_FAILURE);
3901         }
3902     }
3903     free(r);
3904 }
3905 
3906 static void handle_arg_argv0(const char *arg)
3907 {
3908     argv0 = strdup(arg);
3909 }
3910 
3911 static void handle_arg_stack_size(const char *arg)
3912 {
3913     char *p;
3914     guest_stack_size = strtoul(arg, &p, 0);
3915     if (guest_stack_size == 0) {
3916         usage(EXIT_FAILURE);
3917     }
3918 
3919     if (*p == 'M') {
3920         guest_stack_size *= 1024 * 1024;
3921     } else if (*p == 'k' || *p == 'K') {
3922         guest_stack_size *= 1024;
3923     }
3924 }
3925 
3926 static void handle_arg_ld_prefix(const char *arg)
3927 {
3928     interp_prefix = strdup(arg);
3929 }
3930 
3931 static void handle_arg_pagesize(const char *arg)
3932 {
3933     qemu_host_page_size = atoi(arg);
3934     if (qemu_host_page_size == 0 ||
3935         (qemu_host_page_size & (qemu_host_page_size - 1)) != 0) {
3936         fprintf(stderr, "page size must be a power of two\n");
3937         exit(EXIT_FAILURE);
3938     }
3939 }
3940 
3941 static void handle_arg_randseed(const char *arg)
3942 {
3943     unsigned long long seed;
3944 
3945     if (parse_uint_full(arg, &seed, 0) != 0 || seed > UINT_MAX) {
3946         fprintf(stderr, "Invalid seed number: %s\n", arg);
3947         exit(EXIT_FAILURE);
3948     }
3949     srand(seed);
3950 }
3951 
3952 static void handle_arg_gdb(const char *arg)
3953 {
3954     gdbstub_port = atoi(arg);
3955 }
3956 
3957 static void handle_arg_uname(const char *arg)
3958 {
3959     qemu_uname_release = strdup(arg);
3960 }
3961 
3962 static void handle_arg_cpu(const char *arg)
3963 {
3964     cpu_model = strdup(arg);
3965     if (cpu_model == NULL || is_help_option(cpu_model)) {
3966         /* XXX: implement xxx_cpu_list for targets that still miss it */
3967 #if defined(cpu_list)
3968         cpu_list(stdout, &fprintf);
3969 #endif
3970         exit(EXIT_FAILURE);
3971     }
3972 }
3973 
3974 static void handle_arg_guest_base(const char *arg)
3975 {
3976     guest_base = strtol(arg, NULL, 0);
3977     have_guest_base = 1;
3978 }
3979 
3980 static void handle_arg_reserved_va(const char *arg)
3981 {
3982     char *p;
3983     int shift = 0;
3984     reserved_va = strtoul(arg, &p, 0);
3985     switch (*p) {
3986     case 'k':
3987     case 'K':
3988         shift = 10;
3989         break;
3990     case 'M':
3991         shift = 20;
3992         break;
3993     case 'G':
3994         shift = 30;
3995         break;
3996     }
3997     if (shift) {
3998         unsigned long unshifted = reserved_va;
3999         p++;
4000         reserved_va <<= shift;
4001         if (reserved_va >> shift != unshifted
4002             || (MAX_RESERVED_VA && reserved_va > MAX_RESERVED_VA)) {
4003             fprintf(stderr, "Reserved virtual address too big\n");
4004             exit(EXIT_FAILURE);
4005         }
4006     }
4007     if (*p) {
4008         fprintf(stderr, "Unrecognised -R size suffix '%s'\n", p);
4009         exit(EXIT_FAILURE);
4010     }
4011 }
4012 
4013 static void handle_arg_singlestep(const char *arg)
4014 {
4015     singlestep = 1;
4016 }
4017 
4018 static void handle_arg_strace(const char *arg)
4019 {
4020     do_strace = 1;
4021 }
4022 
4023 static void handle_arg_version(const char *arg)
4024 {
4025     printf("qemu-" TARGET_NAME " version " QEMU_VERSION QEMU_PKGVERSION
4026            "\n" QEMU_COPYRIGHT "\n");
4027     exit(EXIT_SUCCESS);
4028 }
4029 
4030 static char *trace_file;
4031 static void handle_arg_trace(const char *arg)
4032 {
4033     g_free(trace_file);
4034     trace_file = trace_opt_parse(arg);
4035 }
4036 
4037 struct qemu_argument {
4038     const char *argv;
4039     const char *env;
4040     bool has_arg;
4041     void (*handle_opt)(const char *arg);
4042     const char *example;
4043     const char *help;
4044 };
4045 
4046 static const struct qemu_argument arg_table[] = {
4047     {"h",          "",                 false, handle_arg_help,
4048      "",           "print this help"},
4049     {"help",       "",                 false, handle_arg_help,
4050      "",           ""},
4051     {"g",          "QEMU_GDB",         true,  handle_arg_gdb,
4052      "port",       "wait gdb connection to 'port'"},
4053     {"L",          "QEMU_LD_PREFIX",   true,  handle_arg_ld_prefix,
4054      "path",       "set the elf interpreter prefix to 'path'"},
4055     {"s",          "QEMU_STACK_SIZE",  true,  handle_arg_stack_size,
4056      "size",       "set the stack size to 'size' bytes"},
4057     {"cpu",        "QEMU_CPU",         true,  handle_arg_cpu,
4058      "model",      "select CPU (-cpu help for list)"},
4059     {"E",          "QEMU_SET_ENV",     true,  handle_arg_set_env,
4060      "var=value",  "sets targets environment variable (see below)"},
4061     {"U",          "QEMU_UNSET_ENV",   true,  handle_arg_unset_env,
4062      "var",        "unsets targets environment variable (see below)"},
4063     {"0",          "QEMU_ARGV0",       true,  handle_arg_argv0,
4064      "argv0",      "forces target process argv[0] to be 'argv0'"},
4065     {"r",          "QEMU_UNAME",       true,  handle_arg_uname,
4066      "uname",      "set qemu uname release string to 'uname'"},
4067     {"B",          "QEMU_GUEST_BASE",  true,  handle_arg_guest_base,
4068      "address",    "set guest_base address to 'address'"},
4069     {"R",          "QEMU_RESERVED_VA", true,  handle_arg_reserved_va,
4070      "size",       "reserve 'size' bytes for guest virtual address space"},
4071     {"d",          "QEMU_LOG",         true,  handle_arg_log,
4072      "item[,...]", "enable logging of specified items "
4073      "(use '-d help' for a list of items)"},
4074     {"dfilter",    "QEMU_DFILTER",     true,  handle_arg_dfilter,
4075      "range[,...]","filter logging based on address range"},
4076     {"D",          "QEMU_LOG_FILENAME", true, handle_arg_log_filename,
4077      "logfile",     "write logs to 'logfile' (default stderr)"},
4078     {"p",          "QEMU_PAGESIZE",    true,  handle_arg_pagesize,
4079      "pagesize",   "set the host page size to 'pagesize'"},
4080     {"singlestep", "QEMU_SINGLESTEP",  false, handle_arg_singlestep,
4081      "",           "run in singlestep mode"},
4082     {"strace",     "QEMU_STRACE",      false, handle_arg_strace,
4083      "",           "log system calls"},
4084     {"seed",       "QEMU_RAND_SEED",   true,  handle_arg_randseed,
4085      "",           "Seed for pseudo-random number generator"},
4086     {"trace",      "QEMU_TRACE",       true,  handle_arg_trace,
4087      "",           "[[enable=]<pattern>][,events=<file>][,file=<file>]"},
4088     {"version",    "QEMU_VERSION",     false, handle_arg_version,
4089      "",           "display version information and exit"},
4090     {NULL, NULL, false, NULL, NULL, NULL}
4091 };
4092 
4093 static void usage(int exitcode)
4094 {
4095     const struct qemu_argument *arginfo;
4096     int maxarglen;
4097     int maxenvlen;
4098 
4099     printf("usage: qemu-" TARGET_NAME " [options] program [arguments...]\n"
4100            "Linux CPU emulator (compiled for " TARGET_NAME " emulation)\n"
4101            "\n"
4102            "Options and associated environment variables:\n"
4103            "\n");
4104 
4105     /* Calculate column widths. We must always have at least enough space
4106      * for the column header.
4107      */
4108     maxarglen = strlen("Argument");
4109     maxenvlen = strlen("Env-variable");
4110 
4111     for (arginfo = arg_table; arginfo->handle_opt != NULL; arginfo++) {
4112         int arglen = strlen(arginfo->argv);
4113         if (arginfo->has_arg) {
4114             arglen += strlen(arginfo->example) + 1;
4115         }
4116         if (strlen(arginfo->env) > maxenvlen) {
4117             maxenvlen = strlen(arginfo->env);
4118         }
4119         if (arglen > maxarglen) {
4120             maxarglen = arglen;
4121         }
4122     }
4123 
4124     printf("%-*s %-*s Description\n", maxarglen+1, "Argument",
4125             maxenvlen, "Env-variable");
4126 
4127     for (arginfo = arg_table; arginfo->handle_opt != NULL; arginfo++) {
4128         if (arginfo->has_arg) {
4129             printf("-%s %-*s %-*s %s\n", arginfo->argv,
4130                    (int)(maxarglen - strlen(arginfo->argv) - 1),
4131                    arginfo->example, maxenvlen, arginfo->env, arginfo->help);
4132         } else {
4133             printf("-%-*s %-*s %s\n", maxarglen, arginfo->argv,
4134                     maxenvlen, arginfo->env,
4135                     arginfo->help);
4136         }
4137     }
4138 
4139     printf("\n"
4140            "Defaults:\n"
4141            "QEMU_LD_PREFIX  = %s\n"
4142            "QEMU_STACK_SIZE = %ld byte\n",
4143            interp_prefix,
4144            guest_stack_size);
4145 
4146     printf("\n"
4147            "You can use -E and -U options or the QEMU_SET_ENV and\n"
4148            "QEMU_UNSET_ENV environment variables to set and unset\n"
4149            "environment variables for the target process.\n"
4150            "It is possible to provide several variables by separating them\n"
4151            "by commas in getsubopt(3) style. Additionally it is possible to\n"
4152            "provide the -E and -U options multiple times.\n"
4153            "The following lines are equivalent:\n"
4154            "    -E var1=val2 -E var2=val2 -U LD_PRELOAD -U LD_DEBUG\n"
4155            "    -E var1=val2,var2=val2 -U LD_PRELOAD,LD_DEBUG\n"
4156            "    QEMU_SET_ENV=var1=val2,var2=val2 QEMU_UNSET_ENV=LD_PRELOAD,LD_DEBUG\n"
4157            "Note that if you provide several changes to a single variable\n"
4158            "the last change will stay in effect.\n"
4159            "\n"
4160            QEMU_HELP_BOTTOM "\n");
4161 
4162     exit(exitcode);
4163 }
4164 
4165 static int parse_args(int argc, char **argv)
4166 {
4167     const char *r;
4168     int optind;
4169     const struct qemu_argument *arginfo;
4170 
4171     for (arginfo = arg_table; arginfo->handle_opt != NULL; arginfo++) {
4172         if (arginfo->env == NULL) {
4173             continue;
4174         }
4175 
4176         r = getenv(arginfo->env);
4177         if (r != NULL) {
4178             arginfo->handle_opt(r);
4179         }
4180     }
4181 
4182     optind = 1;
4183     for (;;) {
4184         if (optind >= argc) {
4185             break;
4186         }
4187         r = argv[optind];
4188         if (r[0] != '-') {
4189             break;
4190         }
4191         optind++;
4192         r++;
4193         if (!strcmp(r, "-")) {
4194             break;
4195         }
4196         /* Treat --foo the same as -foo.  */
4197         if (r[0] == '-') {
4198             r++;
4199         }
4200 
4201         for (arginfo = arg_table; arginfo->handle_opt != NULL; arginfo++) {
4202             if (!strcmp(r, arginfo->argv)) {
4203                 if (arginfo->has_arg) {
4204                     if (optind >= argc) {
4205                         (void) fprintf(stderr,
4206                             "qemu: missing argument for option '%s'\n", r);
4207                         exit(EXIT_FAILURE);
4208                     }
4209                     arginfo->handle_opt(argv[optind]);
4210                     optind++;
4211                 } else {
4212                     arginfo->handle_opt(NULL);
4213                 }
4214                 break;
4215             }
4216         }
4217 
4218         /* no option matched the current argv */
4219         if (arginfo->handle_opt == NULL) {
4220             (void) fprintf(stderr, "qemu: unknown option '%s'\n", r);
4221             exit(EXIT_FAILURE);
4222         }
4223     }
4224 
4225     if (optind >= argc) {
4226         (void) fprintf(stderr, "qemu: no user program specified\n");
4227         exit(EXIT_FAILURE);
4228     }
4229 
4230     filename = argv[optind];
4231     exec_path = argv[optind];
4232 
4233     return optind;
4234 }
4235 
4236 int main(int argc, char **argv, char **envp)
4237 {
4238     struct target_pt_regs regs1, *regs = &regs1;
4239     struct image_info info1, *info = &info1;
4240     struct linux_binprm bprm;
4241     TaskState *ts;
4242     CPUArchState *env;
4243     CPUState *cpu;
4244     int optind;
4245     char **target_environ, **wrk;
4246     char **target_argv;
4247     int target_argc;
4248     int i;
4249     int ret;
4250     int execfd;
4251 
4252     module_call_init(MODULE_INIT_TRACE);
4253     qemu_init_cpu_list();
4254     module_call_init(MODULE_INIT_QOM);
4255 
4256     envlist = envlist_create();
4257 
4258     /* add current environment into the list */
4259     for (wrk = environ; *wrk != NULL; wrk++) {
4260         (void) envlist_setenv(envlist, *wrk);
4261     }
4262 
4263     /* Read the stack limit from the kernel.  If it's "unlimited",
4264        then we can do little else besides use the default.  */
4265     {
4266         struct rlimit lim;
4267         if (getrlimit(RLIMIT_STACK, &lim) == 0
4268             && lim.rlim_cur != RLIM_INFINITY
4269             && lim.rlim_cur == (target_long)lim.rlim_cur) {
4270             guest_stack_size = lim.rlim_cur;
4271         }
4272     }
4273 
4274     cpu_model = NULL;
4275 
4276     srand(time(NULL));
4277 
4278     qemu_add_opts(&qemu_trace_opts);
4279 
4280     optind = parse_args(argc, argv);
4281 
4282     if (!trace_init_backends()) {
4283         exit(1);
4284     }
4285     trace_init_file(trace_file);
4286 
4287     /* Zero out regs */
4288     memset(regs, 0, sizeof(struct target_pt_regs));
4289 
4290     /* Zero out image_info */
4291     memset(info, 0, sizeof(struct image_info));
4292 
4293     memset(&bprm, 0, sizeof (bprm));
4294 
4295     /* Scan interp_prefix dir for replacement files. */
4296     init_paths(interp_prefix);
4297 
4298     init_qemu_uname_release();
4299 
4300     if (cpu_model == NULL) {
4301 #if defined(TARGET_I386)
4302 #ifdef TARGET_X86_64
4303         cpu_model = "qemu64";
4304 #else
4305         cpu_model = "qemu32";
4306 #endif
4307 #elif defined(TARGET_ARM)
4308         cpu_model = "any";
4309 #elif defined(TARGET_UNICORE32)
4310         cpu_model = "any";
4311 #elif defined(TARGET_M68K)
4312         cpu_model = "any";
4313 #elif defined(TARGET_SPARC)
4314 #ifdef TARGET_SPARC64
4315         cpu_model = "TI UltraSparc II";
4316 #else
4317         cpu_model = "Fujitsu MB86904";
4318 #endif
4319 #elif defined(TARGET_MIPS)
4320 #if defined(TARGET_ABI_MIPSN32) || defined(TARGET_ABI_MIPSN64)
4321         cpu_model = "5KEf";
4322 #else
4323         cpu_model = "24Kf";
4324 #endif
4325 #elif defined TARGET_OPENRISC
4326         cpu_model = "or1200";
4327 #elif defined(TARGET_PPC)
4328 # ifdef TARGET_PPC64
4329         cpu_model = "POWER8";
4330 # else
4331         cpu_model = "750";
4332 # endif
4333 #elif defined TARGET_SH4
4334         cpu_model = "sh7785";
4335 #elif defined TARGET_S390X
4336         cpu_model = "qemu";
4337 #else
4338         cpu_model = "any";
4339 #endif
4340     }
4341     tcg_exec_init(0);
4342     /* NOTE: we need to init the CPU at this stage to get
4343        qemu_host_page_size */
4344     cpu = cpu_init(cpu_model);
4345     env = cpu->env_ptr;
4346     cpu_reset(cpu);
4347 
4348     thread_cpu = cpu;
4349 
4350     if (getenv("QEMU_STRACE")) {
4351         do_strace = 1;
4352     }
4353 
4354     if (getenv("QEMU_RAND_SEED")) {
4355         handle_arg_randseed(getenv("QEMU_RAND_SEED"));
4356     }
4357 
4358     target_environ = envlist_to_environ(envlist, NULL);
4359     envlist_free(envlist);
4360 
4361     /*
4362      * Now that page sizes are configured in cpu_init() we can do
4363      * proper page alignment for guest_base.
4364      */
4365     guest_base = HOST_PAGE_ALIGN(guest_base);
4366 
4367     if (reserved_va || have_guest_base) {
4368         guest_base = init_guest_space(guest_base, reserved_va, 0,
4369                                       have_guest_base);
4370         if (guest_base == (unsigned long)-1) {
4371             fprintf(stderr, "Unable to reserve 0x%lx bytes of virtual address "
4372                     "space for use as guest address space (check your virtual "
4373                     "memory ulimit setting or reserve less using -R option)\n",
4374                     reserved_va);
4375             exit(EXIT_FAILURE);
4376         }
4377 
4378         if (reserved_va) {
4379             mmap_next_start = reserved_va;
4380         }
4381     }
4382 
4383     /*
4384      * Read in mmap_min_addr kernel parameter.  This value is used
4385      * When loading the ELF image to determine whether guest_base
4386      * is needed.  It is also used in mmap_find_vma.
4387      */
4388     {
4389         FILE *fp;
4390 
4391         if ((fp = fopen("/proc/sys/vm/mmap_min_addr", "r")) != NULL) {
4392             unsigned long tmp;
4393             if (fscanf(fp, "%lu", &tmp) == 1) {
4394                 mmap_min_addr = tmp;
4395                 qemu_log_mask(CPU_LOG_PAGE, "host mmap_min_addr=0x%lx\n", mmap_min_addr);
4396             }
4397             fclose(fp);
4398         }
4399     }
4400 
4401     /*
4402      * Prepare copy of argv vector for target.
4403      */
4404     target_argc = argc - optind;
4405     target_argv = calloc(target_argc + 1, sizeof (char *));
4406     if (target_argv == NULL) {
4407 	(void) fprintf(stderr, "Unable to allocate memory for target_argv\n");
4408 	exit(EXIT_FAILURE);
4409     }
4410 
4411     /*
4412      * If argv0 is specified (using '-0' switch) we replace
4413      * argv[0] pointer with the given one.
4414      */
4415     i = 0;
4416     if (argv0 != NULL) {
4417         target_argv[i++] = strdup(argv0);
4418     }
4419     for (; i < target_argc; i++) {
4420         target_argv[i] = strdup(argv[optind + i]);
4421     }
4422     target_argv[target_argc] = NULL;
4423 
4424     ts = g_new0(TaskState, 1);
4425     init_task_state(ts);
4426     /* build Task State */
4427     ts->info = info;
4428     ts->bprm = &bprm;
4429     cpu->opaque = ts;
4430     task_settid(ts);
4431 
4432     execfd = qemu_getauxval(AT_EXECFD);
4433     if (execfd == 0) {
4434         execfd = open(filename, O_RDONLY);
4435         if (execfd < 0) {
4436             printf("Error while loading %s: %s\n", filename, strerror(errno));
4437             _exit(EXIT_FAILURE);
4438         }
4439     }
4440 
4441     ret = loader_exec(execfd, filename, target_argv, target_environ, regs,
4442         info, &bprm);
4443     if (ret != 0) {
4444         printf("Error while loading %s: %s\n", filename, strerror(-ret));
4445         _exit(EXIT_FAILURE);
4446     }
4447 
4448     for (wrk = target_environ; *wrk; wrk++) {
4449         g_free(*wrk);
4450     }
4451 
4452     g_free(target_environ);
4453 
4454     if (qemu_loglevel_mask(CPU_LOG_PAGE)) {
4455         qemu_log("guest_base  0x%lx\n", guest_base);
4456         log_page_dump();
4457 
4458         qemu_log("start_brk   0x" TARGET_ABI_FMT_lx "\n", info->start_brk);
4459         qemu_log("end_code    0x" TARGET_ABI_FMT_lx "\n", info->end_code);
4460         qemu_log("start_code  0x" TARGET_ABI_FMT_lx "\n", info->start_code);
4461         qemu_log("start_data  0x" TARGET_ABI_FMT_lx "\n", info->start_data);
4462         qemu_log("end_data    0x" TARGET_ABI_FMT_lx "\n", info->end_data);
4463         qemu_log("start_stack 0x" TARGET_ABI_FMT_lx "\n", info->start_stack);
4464         qemu_log("brk         0x" TARGET_ABI_FMT_lx "\n", info->brk);
4465         qemu_log("entry       0x" TARGET_ABI_FMT_lx "\n", info->entry);
4466         qemu_log("argv_start  0x" TARGET_ABI_FMT_lx "\n", info->arg_start);
4467         qemu_log("env_start   0x" TARGET_ABI_FMT_lx "\n",
4468                  info->arg_end + (abi_ulong)sizeof(abi_ulong));
4469         qemu_log("auxv_start  0x" TARGET_ABI_FMT_lx "\n", info->saved_auxv);
4470     }
4471 
4472     target_set_brk(info->brk);
4473     syscall_init();
4474     signal_init();
4475 
4476     /* Now that we've loaded the binary, GUEST_BASE is fixed.  Delay
4477        generating the prologue until now so that the prologue can take
4478        the real value of GUEST_BASE into account.  */
4479     tcg_prologue_init(tcg_ctx);
4480     tcg_region_init();
4481 
4482 #if defined(TARGET_I386)
4483     env->cr[0] = CR0_PG_MASK | CR0_WP_MASK | CR0_PE_MASK;
4484     env->hflags |= HF_PE_MASK | HF_CPL_MASK;
4485     if (env->features[FEAT_1_EDX] & CPUID_SSE) {
4486         env->cr[4] |= CR4_OSFXSR_MASK;
4487         env->hflags |= HF_OSFXSR_MASK;
4488     }
4489 #ifndef TARGET_ABI32
4490     /* enable 64 bit mode if possible */
4491     if (!(env->features[FEAT_8000_0001_EDX] & CPUID_EXT2_LM)) {
4492         fprintf(stderr, "The selected x86 CPU does not support 64 bit mode\n");
4493         exit(EXIT_FAILURE);
4494     }
4495     env->cr[4] |= CR4_PAE_MASK;
4496     env->efer |= MSR_EFER_LMA | MSR_EFER_LME;
4497     env->hflags |= HF_LMA_MASK;
4498 #endif
4499 
4500     /* flags setup : we activate the IRQs by default as in user mode */
4501     env->eflags |= IF_MASK;
4502 
4503     /* linux register setup */
4504 #ifndef TARGET_ABI32
4505     env->regs[R_EAX] = regs->rax;
4506     env->regs[R_EBX] = regs->rbx;
4507     env->regs[R_ECX] = regs->rcx;
4508     env->regs[R_EDX] = regs->rdx;
4509     env->regs[R_ESI] = regs->rsi;
4510     env->regs[R_EDI] = regs->rdi;
4511     env->regs[R_EBP] = regs->rbp;
4512     env->regs[R_ESP] = regs->rsp;
4513     env->eip = regs->rip;
4514 #else
4515     env->regs[R_EAX] = regs->eax;
4516     env->regs[R_EBX] = regs->ebx;
4517     env->regs[R_ECX] = regs->ecx;
4518     env->regs[R_EDX] = regs->edx;
4519     env->regs[R_ESI] = regs->esi;
4520     env->regs[R_EDI] = regs->edi;
4521     env->regs[R_EBP] = regs->ebp;
4522     env->regs[R_ESP] = regs->esp;
4523     env->eip = regs->eip;
4524 #endif
4525 
4526     /* linux interrupt setup */
4527 #ifndef TARGET_ABI32
4528     env->idt.limit = 511;
4529 #else
4530     env->idt.limit = 255;
4531 #endif
4532     env->idt.base = target_mmap(0, sizeof(uint64_t) * (env->idt.limit + 1),
4533                                 PROT_READ|PROT_WRITE,
4534                                 MAP_ANONYMOUS|MAP_PRIVATE, -1, 0);
4535     idt_table = g2h(env->idt.base);
4536     set_idt(0, 0);
4537     set_idt(1, 0);
4538     set_idt(2, 0);
4539     set_idt(3, 3);
4540     set_idt(4, 3);
4541     set_idt(5, 0);
4542     set_idt(6, 0);
4543     set_idt(7, 0);
4544     set_idt(8, 0);
4545     set_idt(9, 0);
4546     set_idt(10, 0);
4547     set_idt(11, 0);
4548     set_idt(12, 0);
4549     set_idt(13, 0);
4550     set_idt(14, 0);
4551     set_idt(15, 0);
4552     set_idt(16, 0);
4553     set_idt(17, 0);
4554     set_idt(18, 0);
4555     set_idt(19, 0);
4556     set_idt(0x80, 3);
4557 
4558     /* linux segment setup */
4559     {
4560         uint64_t *gdt_table;
4561         env->gdt.base = target_mmap(0, sizeof(uint64_t) * TARGET_GDT_ENTRIES,
4562                                     PROT_READ|PROT_WRITE,
4563                                     MAP_ANONYMOUS|MAP_PRIVATE, -1, 0);
4564         env->gdt.limit = sizeof(uint64_t) * TARGET_GDT_ENTRIES - 1;
4565         gdt_table = g2h(env->gdt.base);
4566 #ifdef TARGET_ABI32
4567         write_dt(&gdt_table[__USER_CS >> 3], 0, 0xfffff,
4568                  DESC_G_MASK | DESC_B_MASK | DESC_P_MASK | DESC_S_MASK |
4569                  (3 << DESC_DPL_SHIFT) | (0xa << DESC_TYPE_SHIFT));
4570 #else
4571         /* 64 bit code segment */
4572         write_dt(&gdt_table[__USER_CS >> 3], 0, 0xfffff,
4573                  DESC_G_MASK | DESC_B_MASK | DESC_P_MASK | DESC_S_MASK |
4574                  DESC_L_MASK |
4575                  (3 << DESC_DPL_SHIFT) | (0xa << DESC_TYPE_SHIFT));
4576 #endif
4577         write_dt(&gdt_table[__USER_DS >> 3], 0, 0xfffff,
4578                  DESC_G_MASK | DESC_B_MASK | DESC_P_MASK | DESC_S_MASK |
4579                  (3 << DESC_DPL_SHIFT) | (0x2 << DESC_TYPE_SHIFT));
4580     }
4581     cpu_x86_load_seg(env, R_CS, __USER_CS);
4582     cpu_x86_load_seg(env, R_SS, __USER_DS);
4583 #ifdef TARGET_ABI32
4584     cpu_x86_load_seg(env, R_DS, __USER_DS);
4585     cpu_x86_load_seg(env, R_ES, __USER_DS);
4586     cpu_x86_load_seg(env, R_FS, __USER_DS);
4587     cpu_x86_load_seg(env, R_GS, __USER_DS);
4588     /* This hack makes Wine work... */
4589     env->segs[R_FS].selector = 0;
4590 #else
4591     cpu_x86_load_seg(env, R_DS, 0);
4592     cpu_x86_load_seg(env, R_ES, 0);
4593     cpu_x86_load_seg(env, R_FS, 0);
4594     cpu_x86_load_seg(env, R_GS, 0);
4595 #endif
4596 #elif defined(TARGET_AARCH64)
4597     {
4598         int i;
4599 
4600         if (!(arm_feature(env, ARM_FEATURE_AARCH64))) {
4601             fprintf(stderr,
4602                     "The selected ARM CPU does not support 64 bit mode\n");
4603             exit(EXIT_FAILURE);
4604         }
4605 
4606         for (i = 0; i < 31; i++) {
4607             env->xregs[i] = regs->regs[i];
4608         }
4609         env->pc = regs->pc;
4610         env->xregs[31] = regs->sp;
4611     }
4612 #elif defined(TARGET_ARM)
4613     {
4614         int i;
4615         cpsr_write(env, regs->uregs[16], CPSR_USER | CPSR_EXEC,
4616                    CPSRWriteByInstr);
4617         for(i = 0; i < 16; i++) {
4618             env->regs[i] = regs->uregs[i];
4619         }
4620 #ifdef TARGET_WORDS_BIGENDIAN
4621         /* Enable BE8.  */
4622         if (EF_ARM_EABI_VERSION(info->elf_flags) >= EF_ARM_EABI_VER4
4623             && (info->elf_flags & EF_ARM_BE8)) {
4624             env->uncached_cpsr |= CPSR_E;
4625             env->cp15.sctlr_el[1] |= SCTLR_E0E;
4626         } else {
4627             env->cp15.sctlr_el[1] |= SCTLR_B;
4628         }
4629 #endif
4630     }
4631 #elif defined(TARGET_UNICORE32)
4632     {
4633         int i;
4634         cpu_asr_write(env, regs->uregs[32], 0xffffffff);
4635         for (i = 0; i < 32; i++) {
4636             env->regs[i] = regs->uregs[i];
4637         }
4638     }
4639 #elif defined(TARGET_SPARC)
4640     {
4641         int i;
4642 	env->pc = regs->pc;
4643 	env->npc = regs->npc;
4644         env->y = regs->y;
4645         for(i = 0; i < 8; i++)
4646             env->gregs[i] = regs->u_regs[i];
4647         for(i = 0; i < 8; i++)
4648             env->regwptr[i] = regs->u_regs[i + 8];
4649     }
4650 #elif defined(TARGET_PPC)
4651     {
4652         int i;
4653 
4654 #if defined(TARGET_PPC64)
4655         int flag = (env->insns_flags2 & PPC2_BOOKE206) ? MSR_CM : MSR_SF;
4656 #if defined(TARGET_ABI32)
4657         env->msr &= ~((target_ulong)1 << flag);
4658 #else
4659         env->msr |= (target_ulong)1 << flag;
4660 #endif
4661 #endif
4662         env->nip = regs->nip;
4663         for(i = 0; i < 32; i++) {
4664             env->gpr[i] = regs->gpr[i];
4665         }
4666     }
4667 #elif defined(TARGET_M68K)
4668     {
4669         env->pc = regs->pc;
4670         env->dregs[0] = regs->d0;
4671         env->dregs[1] = regs->d1;
4672         env->dregs[2] = regs->d2;
4673         env->dregs[3] = regs->d3;
4674         env->dregs[4] = regs->d4;
4675         env->dregs[5] = regs->d5;
4676         env->dregs[6] = regs->d6;
4677         env->dregs[7] = regs->d7;
4678         env->aregs[0] = regs->a0;
4679         env->aregs[1] = regs->a1;
4680         env->aregs[2] = regs->a2;
4681         env->aregs[3] = regs->a3;
4682         env->aregs[4] = regs->a4;
4683         env->aregs[5] = regs->a5;
4684         env->aregs[6] = regs->a6;
4685         env->aregs[7] = regs->usp;
4686         env->sr = regs->sr;
4687         ts->sim_syscalls = 1;
4688     }
4689 #elif defined(TARGET_MICROBLAZE)
4690     {
4691         env->regs[0] = regs->r0;
4692         env->regs[1] = regs->r1;
4693         env->regs[2] = regs->r2;
4694         env->regs[3] = regs->r3;
4695         env->regs[4] = regs->r4;
4696         env->regs[5] = regs->r5;
4697         env->regs[6] = regs->r6;
4698         env->regs[7] = regs->r7;
4699         env->regs[8] = regs->r8;
4700         env->regs[9] = regs->r9;
4701         env->regs[10] = regs->r10;
4702         env->regs[11] = regs->r11;
4703         env->regs[12] = regs->r12;
4704         env->regs[13] = regs->r13;
4705         env->regs[14] = regs->r14;
4706         env->regs[15] = regs->r15;
4707         env->regs[16] = regs->r16;
4708         env->regs[17] = regs->r17;
4709         env->regs[18] = regs->r18;
4710         env->regs[19] = regs->r19;
4711         env->regs[20] = regs->r20;
4712         env->regs[21] = regs->r21;
4713         env->regs[22] = regs->r22;
4714         env->regs[23] = regs->r23;
4715         env->regs[24] = regs->r24;
4716         env->regs[25] = regs->r25;
4717         env->regs[26] = regs->r26;
4718         env->regs[27] = regs->r27;
4719         env->regs[28] = regs->r28;
4720         env->regs[29] = regs->r29;
4721         env->regs[30] = regs->r30;
4722         env->regs[31] = regs->r31;
4723         env->sregs[SR_PC] = regs->pc;
4724     }
4725 #elif defined(TARGET_MIPS)
4726     {
4727         int i;
4728 
4729         for(i = 0; i < 32; i++) {
4730             env->active_tc.gpr[i] = regs->regs[i];
4731         }
4732         env->active_tc.PC = regs->cp0_epc & ~(target_ulong)1;
4733         if (regs->cp0_epc & 1) {
4734             env->hflags |= MIPS_HFLAG_M16;
4735         }
4736         if (((info->elf_flags & EF_MIPS_NAN2008) != 0) !=
4737             ((env->active_fpu.fcr31 & (1 << FCR31_NAN2008)) != 0)) {
4738             if ((env->active_fpu.fcr31_rw_bitmask &
4739                   (1 << FCR31_NAN2008)) == 0) {
4740                 fprintf(stderr, "ELF binary's NaN mode not supported by CPU\n");
4741                 exit(1);
4742             }
4743             if ((info->elf_flags & EF_MIPS_NAN2008) != 0) {
4744                 env->active_fpu.fcr31 |= (1 << FCR31_NAN2008);
4745             } else {
4746                 env->active_fpu.fcr31 &= ~(1 << FCR31_NAN2008);
4747             }
4748             restore_snan_bit_mode(env);
4749         }
4750     }
4751 #elif defined(TARGET_NIOS2)
4752     {
4753         env->regs[0] = 0;
4754         env->regs[1] = regs->r1;
4755         env->regs[2] = regs->r2;
4756         env->regs[3] = regs->r3;
4757         env->regs[4] = regs->r4;
4758         env->regs[5] = regs->r5;
4759         env->regs[6] = regs->r6;
4760         env->regs[7] = regs->r7;
4761         env->regs[8] = regs->r8;
4762         env->regs[9] = regs->r9;
4763         env->regs[10] = regs->r10;
4764         env->regs[11] = regs->r11;
4765         env->regs[12] = regs->r12;
4766         env->regs[13] = regs->r13;
4767         env->regs[14] = regs->r14;
4768         env->regs[15] = regs->r15;
4769         /* TODO: unsigned long  orig_r2; */
4770         env->regs[R_RA] = regs->ra;
4771         env->regs[R_FP] = regs->fp;
4772         env->regs[R_SP] = regs->sp;
4773         env->regs[R_GP] = regs->gp;
4774         env->regs[CR_ESTATUS] = regs->estatus;
4775         env->regs[R_EA] = regs->ea;
4776         /* TODO: unsigned long  orig_r7; */
4777 
4778         /* Emulate eret when starting thread. */
4779         env->regs[R_PC] = regs->ea;
4780     }
4781 #elif defined(TARGET_OPENRISC)
4782     {
4783         int i;
4784 
4785         for (i = 0; i < 32; i++) {
4786             cpu_set_gpr(env, i, regs->gpr[i]);
4787         }
4788         env->pc = regs->pc;
4789         cpu_set_sr(env, regs->sr);
4790     }
4791 #elif defined(TARGET_SH4)
4792     {
4793         int i;
4794 
4795         for(i = 0; i < 16; i++) {
4796             env->gregs[i] = regs->regs[i];
4797         }
4798         env->pc = regs->pc;
4799     }
4800 #elif defined(TARGET_ALPHA)
4801     {
4802         int i;
4803 
4804         for(i = 0; i < 28; i++) {
4805             env->ir[i] = ((abi_ulong *)regs)[i];
4806         }
4807         env->ir[IR_SP] = regs->usp;
4808         env->pc = regs->pc;
4809     }
4810 #elif defined(TARGET_CRIS)
4811     {
4812 	    env->regs[0] = regs->r0;
4813 	    env->regs[1] = regs->r1;
4814 	    env->regs[2] = regs->r2;
4815 	    env->regs[3] = regs->r3;
4816 	    env->regs[4] = regs->r4;
4817 	    env->regs[5] = regs->r5;
4818 	    env->regs[6] = regs->r6;
4819 	    env->regs[7] = regs->r7;
4820 	    env->regs[8] = regs->r8;
4821 	    env->regs[9] = regs->r9;
4822 	    env->regs[10] = regs->r10;
4823 	    env->regs[11] = regs->r11;
4824 	    env->regs[12] = regs->r12;
4825 	    env->regs[13] = regs->r13;
4826 	    env->regs[14] = info->start_stack;
4827 	    env->regs[15] = regs->acr;
4828 	    env->pc = regs->erp;
4829     }
4830 #elif defined(TARGET_S390X)
4831     {
4832             int i;
4833             for (i = 0; i < 16; i++) {
4834                 env->regs[i] = regs->gprs[i];
4835             }
4836             env->psw.mask = regs->psw.mask;
4837             env->psw.addr = regs->psw.addr;
4838     }
4839 #elif defined(TARGET_TILEGX)
4840     {
4841         int i;
4842         for (i = 0; i < TILEGX_R_COUNT; i++) {
4843             env->regs[i] = regs->regs[i];
4844         }
4845         for (i = 0; i < TILEGX_SPR_COUNT; i++) {
4846             env->spregs[i] = 0;
4847         }
4848         env->pc = regs->pc;
4849     }
4850 #elif defined(TARGET_HPPA)
4851     {
4852         int i;
4853         for (i = 1; i < 32; i++) {
4854             env->gr[i] = regs->gr[i];
4855         }
4856         env->iaoq_f = regs->iaoq[0];
4857         env->iaoq_b = regs->iaoq[1];
4858     }
4859 #else
4860 #error unsupported target CPU
4861 #endif
4862 
4863 #if defined(TARGET_ARM) || defined(TARGET_M68K) || defined(TARGET_UNICORE32)
4864     ts->stack_base = info->start_stack;
4865     ts->heap_base = info->brk;
4866     /* This will be filled in on the first SYS_HEAPINFO call.  */
4867     ts->heap_limit = 0;
4868 #endif
4869 
4870     if (gdbstub_port) {
4871         if (gdbserver_start(gdbstub_port) < 0) {
4872             fprintf(stderr, "qemu: could not open gdbserver on port %d\n",
4873                     gdbstub_port);
4874             exit(EXIT_FAILURE);
4875         }
4876         gdb_handlesig(cpu, 0);
4877     }
4878     cpu_loop(env);
4879     /* never exits */
4880     return 0;
4881 }
4882