fixes for host gcc 4.6.1
[zpugcc/jano.git] / toolchain / gdb / sim / m32r / traps-linux.c
blob55a97a514d0a51b2cbceadd68e6171f889f8b78e
1 /* m32r exception, interrupt, and trap (EIT) support
2 Copyright (C) 1998, 2003 Free Software Foundation, Inc.
3 Contributed by Renesas.
5 This file is part of GDB, the GNU debugger.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License along
18 with this program; if not, write to the Free Software Foundation, Inc.,
19 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21 #include "sim-main.h"
22 #include "syscall.h"
23 #include "targ-vals.h"
24 #include <dirent.h>
25 #include <errno.h>
26 #include <fcntl.h>
27 #include <time.h>
28 #include <unistd.h>
29 #include <utime.h>
30 #include <sys/mman.h>
31 #include <sys/poll.h>
32 #include <sys/resource.h>
33 #include <sys/sysinfo.h>
34 #include <sys/stat.h>
35 #include <sys/time.h>
36 #include <sys/timeb.h>
37 #include <sys/timex.h>
38 #include <sys/types.h>
39 #include <sys/uio.h>
40 #include <sys/utsname.h>
41 #include <sys/vfs.h>
42 #include <linux/module.h>
43 #include <linux/sysctl.h>
44 #include <linux/types.h>
45 #include <linux/unistd.h>
47 #define TRAP_ELF_SYSCALL 0
48 #define TRAP_LINUX_SYSCALL 2
49 #define TRAP_FLUSH_CACHE 12
51 /* The semantic code invokes this for invalid (unrecognized) instructions. */
53 SEM_PC
54 sim_engine_invalid_insn (SIM_CPU *current_cpu, IADDR cia, SEM_PC vpc)
56 SIM_DESC sd = CPU_STATE (current_cpu);
58 #if 0
59 if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
61 h_bsm_set (current_cpu, h_sm_get (current_cpu));
62 h_bie_set (current_cpu, h_ie_get (current_cpu));
63 h_bcond_set (current_cpu, h_cond_get (current_cpu));
64 /* sm not changed */
65 h_ie_set (current_cpu, 0);
66 h_cond_set (current_cpu, 0);
68 h_bpc_set (current_cpu, cia);
70 sim_engine_restart (CPU_STATE (current_cpu), current_cpu, NULL,
71 EIT_RSVD_INSN_ADDR);
73 else
74 #endif
75 sim_engine_halt (sd, current_cpu, NULL, cia, sim_stopped, SIM_SIGILL);
76 return vpc;
79 /* Process an address exception. */
81 void
82 m32r_core_signal (SIM_DESC sd, SIM_CPU *current_cpu, sim_cia cia,
83 unsigned int map, int nr_bytes, address_word addr,
84 transfer_type transfer, sim_core_signals sig)
86 if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
88 m32rbf_h_cr_set (current_cpu, H_CR_BBPC,
89 m32rbf_h_cr_get (current_cpu, H_CR_BPC));
90 if (MACH_NUM (CPU_MACH (current_cpu)) == MACH_M32R)
92 m32rbf_h_bpsw_set (current_cpu, m32rbf_h_psw_get (current_cpu));
93 /* sm not changed */
94 m32rbf_h_psw_set (current_cpu, m32rbf_h_psw_get (current_cpu) & 0x80);
96 else if (MACH_NUM (CPU_MACH (current_cpu)) == MACH_M32RX)
98 m32rxf_h_bpsw_set (current_cpu, m32rxf_h_psw_get (current_cpu));
99 /* sm not changed */
100 m32rxf_h_psw_set (current_cpu, m32rxf_h_psw_get (current_cpu) & 0x80);
102 else
104 m32r2f_h_bpsw_set (current_cpu, m32r2f_h_psw_get (current_cpu));
105 /* sm not changed */
106 m32r2f_h_psw_set (current_cpu, m32r2f_h_psw_get (current_cpu) & 0x80);
108 m32rbf_h_cr_set (current_cpu, H_CR_BPC, cia);
110 sim_engine_restart (CPU_STATE (current_cpu), current_cpu, NULL,
111 EIT_ADDR_EXCP_ADDR);
113 else
114 sim_core_signal (sd, current_cpu, cia, map, nr_bytes, addr,
115 transfer, sig);
118 /* Read/write functions for system call interface. */
120 static int
121 syscall_read_mem (host_callback *cb, struct cb_syscall *sc,
122 unsigned long taddr, char *buf, int bytes)
124 SIM_DESC sd = (SIM_DESC) sc->p1;
125 SIM_CPU *cpu = (SIM_CPU *) sc->p2;
127 return sim_core_read_buffer (sd, cpu, read_map, buf, taddr, bytes);
130 static int
131 syscall_write_mem (host_callback *cb, struct cb_syscall *sc,
132 unsigned long taddr, const char *buf, int bytes)
134 SIM_DESC sd = (SIM_DESC) sc->p1;
135 SIM_CPU *cpu = (SIM_CPU *) sc->p2;
137 return sim_core_write_buffer (sd, cpu, write_map, buf, taddr, bytes);
140 /* Translate target's address to host's address. */
142 static void *
143 t2h_addr (host_callback *cb, struct cb_syscall *sc,
144 unsigned long taddr)
146 extern sim_core_trans_addr (SIM_DESC, sim_cpu *, unsigned, address_word);
147 void *addr;
148 SIM_DESC sd = (SIM_DESC) sc->p1;
149 SIM_CPU *cpu = (SIM_CPU *) sc->p2;
151 if (taddr == 0)
152 return NULL;
154 return sim_core_trans_addr (sd, cpu, read_map, taddr);
157 static unsigned int
158 conv_endian (unsigned int tvalue)
160 unsigned int hvalue;
161 unsigned int t1, t2, t3, t4;
163 if (CURRENT_HOST_BYTE_ORDER == LITTLE_ENDIAN)
165 t1 = tvalue & 0xff000000;
166 t2 = tvalue & 0x00ff0000;
167 t3 = tvalue & 0x0000ff00;
168 t4 = tvalue & 0x000000ff;
170 hvalue = t1 >> 24;
171 hvalue += t2 >> 8;
172 hvalue += t3 << 8;
173 hvalue += t4 << 24;
175 else
176 hvalue = tvalue;
178 return hvalue;
181 static unsigned short
182 conv_endian16 (unsigned short tvalue)
184 unsigned short hvalue;
185 unsigned short t1, t2;
187 if (CURRENT_HOST_BYTE_ORDER == LITTLE_ENDIAN)
189 t1 = tvalue & 0xff00;
190 t2 = tvalue & 0x00ff;
192 hvalue = t1 >> 8;
193 hvalue += t2 << 8;
195 else
196 hvalue = tvalue;
198 return hvalue;
201 static void
202 translate_endian(void *addr, size_t size)
204 unsigned int *p = (unsigned int *) addr;
205 int i;
207 for (i = 0; i <= size - 4; i += 4,p++)
208 *p = conv_endian(*p);
210 if (i <= size - 2)
211 *((unsigned short *) p) = conv_endian16(*((unsigned short *) p));
214 /* Trap support.
215 The result is the pc address to continue at.
216 Preprocessing like saving the various registers has already been done. */
219 m32r_trap (SIM_CPU *current_cpu, PCADDR pc, int num)
221 SIM_DESC sd = CPU_STATE (current_cpu);
222 host_callback *cb = STATE_CALLBACK (sd);
224 #ifdef SIM_HAVE_BREAKPOINTS
225 /* Check for breakpoints "owned" by the simulator first, regardless
226 of --environment. */
227 if (num == TRAP_BREAKPOINT)
229 /* First try sim-break.c. If it's a breakpoint the simulator "owns"
230 it doesn't return. Otherwise it returns and let's us try. */
231 sim_handle_breakpoint (sd, current_cpu, pc);
232 /* Fall through. */
234 #endif
236 switch (num)
238 case TRAP_ELF_SYSCALL :
240 CB_SYSCALL s;
242 CB_SYSCALL_INIT (&s);
243 s.func = m32rbf_h_gr_get (current_cpu, 0);
244 s.arg1 = m32rbf_h_gr_get (current_cpu, 1);
245 s.arg2 = m32rbf_h_gr_get (current_cpu, 2);
246 s.arg3 = m32rbf_h_gr_get (current_cpu, 3);
248 if (s.func == TARGET_SYS_exit)
250 sim_engine_halt (sd, current_cpu, NULL, pc, sim_exited, s.arg1);
253 s.p1 = (PTR) sd;
254 s.p2 = (PTR) current_cpu;
255 s.read_mem = syscall_read_mem;
256 s.write_mem = syscall_write_mem;
257 cb_syscall (cb, &s);
258 m32rbf_h_gr_set (current_cpu, 2, s.errcode);
259 m32rbf_h_gr_set (current_cpu, 0, s.result);
260 m32rbf_h_gr_set (current_cpu, 1, s.result2);
261 break;
264 case TRAP_LINUX_SYSCALL :
266 CB_SYSCALL s;
267 unsigned int func, arg1, arg2, arg3, arg4, arg5, arg6, arg7;
268 int result, result2, errcode;
270 if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
272 /* The new pc is the trap vector entry.
273 We assume there's a branch there to some handler.
274 Use cr5 as EVB (EIT Vector Base) register. */
275 USI new_pc = m32rbf_h_cr_get (current_cpu, 5) + 0x40 + num * 4;
276 return new_pc;
279 func = m32rbf_h_gr_get (current_cpu, 7);
280 arg1 = m32rbf_h_gr_get (current_cpu, 0);
281 arg2 = m32rbf_h_gr_get (current_cpu, 1);
282 arg3 = m32rbf_h_gr_get (current_cpu, 2);
283 arg4 = m32rbf_h_gr_get (current_cpu, 3);
284 arg5 = m32rbf_h_gr_get (current_cpu, 4);
285 arg6 = m32rbf_h_gr_get (current_cpu, 5);
286 arg7 = m32rbf_h_gr_get (current_cpu, 6);
288 CB_SYSCALL_INIT (&s);
289 s.func = func;
290 s.arg1 = arg1;
291 s.arg2 = arg2;
292 s.arg3 = arg3;
294 s.p1 = (PTR) sd;
295 s.p2 = (PTR) current_cpu;
296 s.read_mem = syscall_read_mem;
297 s.write_mem = syscall_write_mem;
299 result = 0;
300 result2 = 0;
301 errcode = 0;
303 switch (func)
305 case __NR_exit:
306 sim_engine_halt (sd, current_cpu, NULL, pc, sim_exited, arg1);
307 break;
309 case __NR_read:
310 result = read(arg1, t2h_addr(cb, &s, arg2), arg3);
311 errcode = errno;
312 break;
314 case __NR_write:
315 result = write(arg1, t2h_addr(cb, &s, arg2), arg3);
316 errcode = errno;
317 break;
319 case __NR_open:
320 result = open((char *) t2h_addr(cb, &s, arg1), arg2, arg3);
321 errcode = errno;
322 break;
324 case __NR_close:
325 result = close(arg1);
326 errcode = errno;
327 break;
329 case __NR_creat:
330 result = creat((char *) t2h_addr(cb, &s, arg1), arg2);
331 errcode = errno;
332 break;
334 case __NR_link:
335 result = link((char *) t2h_addr(cb, &s, arg1),
336 (char *) t2h_addr(cb, &s, arg2));
337 errcode = errno;
338 break;
340 case __NR_unlink:
341 result = unlink((char *) t2h_addr(cb, &s, arg1));
342 errcode = errno;
343 break;
345 case __NR_chdir:
346 result = chdir((char *) t2h_addr(cb, &s, arg1));
347 errcode = errno;
348 break;
350 case __NR_time:
352 time_t t;
354 if (arg1 == 0)
356 result = (int) time(NULL);
357 errcode = errno;
359 else
361 result = (int) time(&t);
362 errcode = errno;
364 if (result != 0)
365 break;
367 translate_endian((void *) &t, sizeof(t));
368 if ((s.write_mem) (cb, &s, arg1, (char *) &t, sizeof(t)) != sizeof(t))
370 result = -1;
371 errcode = EINVAL;
375 break;
377 case __NR_mknod:
378 result = mknod((char *) t2h_addr(cb, &s, arg1),
379 (mode_t) arg2, (dev_t) arg3);
380 errcode = errno;
381 break;
383 case __NR_chmod:
384 result = chmod((char *) t2h_addr(cb, &s, arg1), (mode_t) arg2);
385 errcode = errno;
386 break;
388 case __NR_lchown:
389 result = lchown((char *) t2h_addr(cb, &s, arg1),
390 (uid_t) arg2, (gid_t) arg3);
391 errcode = errno;
392 break;
394 case __NR_lseek:
395 result = (int) lseek(arg1, (off_t) arg2, arg3);
396 errcode = errno;
397 break;
399 case __NR_getpid:
400 result = getpid();
401 errcode = errno;
402 break;
404 case __NR_getuid:
405 result = getuid();
406 errcode = errno;
407 break;
409 case __NR_utime:
411 struct utimbuf buf;
413 if (arg2 == 0)
415 result = utime((char *) t2h_addr(cb, &s, arg1), NULL);
416 errcode = errno;
418 else
420 buf = *((struct utimbuf *) t2h_addr(cb, &s, arg2));
421 translate_endian((void *) &buf, sizeof(buf));
422 result = utime((char *) t2h_addr(cb, &s, arg1), &buf);
423 errcode = errno;
426 break;
428 case __NR_access:
429 result = access((char *) t2h_addr(cb, &s, arg1), arg2);
430 errcode = errno;
431 break;
433 case __NR_ftime:
435 struct timeb t;
437 result = ftime(&t);
438 errcode = errno;
440 if (result != 0)
441 break;
443 t.time = conv_endian(t.time);
444 t.millitm = conv_endian16(t.millitm);
445 t.timezone = conv_endian16(t.timezone);
446 t.dstflag = conv_endian16(t.dstflag);
447 if ((s.write_mem) (cb, &s, arg1, (char *) &t, sizeof(t))
448 != sizeof(t))
450 result = -1;
451 errcode = EINVAL;
455 case __NR_sync:
456 sync();
457 result = 0;
458 break;
460 case __NR_rename:
461 result = rename((char *) t2h_addr(cb, &s, arg1),
462 (char *) t2h_addr(cb, &s, arg2));
463 errcode = errno;
464 break;
466 case __NR_mkdir:
467 result = mkdir((char *) t2h_addr(cb, &s, arg1), arg2);
468 errcode = errno;
469 break;
471 case __NR_rmdir:
472 result = rmdir((char *) t2h_addr(cb, &s, arg1));
473 errcode = errno;
474 break;
476 case __NR_dup:
477 result = dup(arg1);
478 errcode = errno;
479 break;
481 case __NR_brk:
482 result = brk((void *) arg1);
483 errcode = errno;
484 //result = arg1;
485 break;
487 case __NR_getgid:
488 result = getgid();
489 errcode = errno;
490 break;
492 case __NR_geteuid:
493 result = geteuid();
494 errcode = errno;
495 break;
497 case __NR_getegid:
498 result = getegid();
499 errcode = errno;
500 break;
502 case __NR_ioctl:
503 result = ioctl(arg1, arg2, arg3);
504 errcode = errno;
505 break;
507 case __NR_fcntl:
508 result = fcntl(arg1, arg2, arg3);
509 errcode = errno;
510 break;
512 case __NR_ustat:
514 struct ustat ubuf;
516 result = ustat(arg1, &ubuf);
517 errcode = errno;
519 if (result != 0)
520 break;
522 ubuf.f_tfree = conv_endian(ubuf.f_tfree);
523 ubuf.f_tinode = conv_endian(ubuf.f_tinode);
524 if ((s.write_mem) (cb, &s, arg2, (char *) &ubuf, sizeof(ubuf))
525 != sizeof(ubuf))
527 result = -1;
528 errcode = EINVAL;
531 break;
533 case __NR_dup2:
534 result = dup2(arg1, arg2);
535 errcode = errno;
536 break;
538 case __NR_getppid:
539 result = getppid();
540 errcode = errno;
541 break;
543 case __NR_getpgrp:
544 result = getpgrp();
545 errcode = errno;
546 break;
548 case __NR_getrlimit:
550 struct rlimit rlim;
552 result = getrlimit(arg1, &rlim);
553 errcode = errno;
555 if (result != 0)
556 break;
558 translate_endian((void *) &rlim, sizeof(rlim));
559 if ((s.write_mem) (cb, &s, arg2, (char *) &rlim, sizeof(rlim))
560 != sizeof(rlim))
562 result = -1;
563 errcode = EINVAL;
566 break;
568 case __NR_getrusage:
570 struct rusage usage;
572 result = getrusage(arg1, &usage);
573 errcode = errno;
575 if (result != 0)
576 break;
578 translate_endian((void *) &usage, sizeof(usage));
579 if ((s.write_mem) (cb, &s, arg2, (char *) &usage, sizeof(usage))
580 != sizeof(usage))
582 result = -1;
583 errcode = EINVAL;
586 break;
588 case __NR_gettimeofday:
590 struct timeval tv;
591 struct timezone tz;
593 result = gettimeofday(&tv, &tz);
594 errcode = errno;
596 if (result != 0)
597 break;
599 translate_endian((void *) &tv, sizeof(tv));
600 if ((s.write_mem) (cb, &s, arg1, (char *) &tv, sizeof(tv))
601 != sizeof(tv))
603 result = -1;
604 errcode = EINVAL;
607 translate_endian((void *) &tz, sizeof(tz));
608 if ((s.write_mem) (cb, &s, arg2, (char *) &tz, sizeof(tz))
609 != sizeof(tz))
611 result = -1;
612 errcode = EINVAL;
615 break;
617 case __NR_getgroups:
619 gid_t *list;
621 if (arg1 > 0)
622 list = (gid_t *) malloc(arg1 * sizeof(gid_t));
624 result = getgroups(arg1, list);
625 errcode = errno;
627 if (result != 0)
628 break;
630 translate_endian((void *) list, arg1 * sizeof(gid_t));
631 if (arg1 > 0)
632 if ((s.write_mem) (cb, &s, arg2, (char *) list, arg1 * sizeof(gid_t))
633 != arg1 * sizeof(gid_t))
635 result = -1;
636 errcode = EINVAL;
639 break;
641 case __NR_select:
643 int n;
644 fd_set readfds;
645 fd_set *treadfdsp;
646 fd_set *hreadfdsp;
647 fd_set writefds;
648 fd_set *twritefdsp;
649 fd_set *hwritefdsp;
650 fd_set exceptfds;
651 fd_set *texceptfdsp;
652 fd_set *hexceptfdsp;
653 struct timeval *ttimeoutp;
654 struct timeval timeout;
656 n = arg1;
658 treadfdsp = (fd_set *) arg2;
659 if (treadfdsp != NULL)
661 readfds = *((fd_set *) t2h_addr(cb, &s, (unsigned int) treadfdsp));
662 translate_endian((void *) &readfds, sizeof(readfds));
663 hreadfdsp = &readfds;
665 else
666 hreadfdsp = NULL;
668 twritefdsp = (fd_set *) arg3;
669 if (twritefdsp != NULL)
671 writefds = *((fd_set *) t2h_addr(cb, &s, (unsigned int) twritefdsp));
672 translate_endian((void *) &writefds, sizeof(writefds));
673 hwritefdsp = &writefds;
675 else
676 hwritefdsp = NULL;
678 texceptfdsp = (fd_set *) arg4;
679 if (texceptfdsp != NULL)
681 exceptfds = *((fd_set *) t2h_addr(cb, &s, (unsigned int) texceptfdsp));
682 translate_endian((void *) &exceptfds, sizeof(exceptfds));
683 hexceptfdsp = &exceptfds;
685 else
686 hexceptfdsp = NULL;
688 ttimeoutp = (struct timeval *) arg5;
689 timeout = *((struct timeval *) t2h_addr(cb, &s, (unsigned int) ttimeoutp));
690 translate_endian((void *) &timeout, sizeof(timeout));
692 result = select(n, hreadfdsp, hwritefdsp, hexceptfdsp, &timeout);
693 errcode = errno;
695 if (result != 0)
696 break;
698 if (treadfdsp != NULL)
700 translate_endian((void *) &readfds, sizeof(readfds));
701 if ((s.write_mem) (cb, &s, (unsigned long) treadfdsp,
702 (char *) &readfds, sizeof(readfds)) != sizeof(readfds))
704 result = -1;
705 errcode = EINVAL;
709 if (twritefdsp != NULL)
711 translate_endian((void *) &writefds, sizeof(writefds));
712 if ((s.write_mem) (cb, &s, (unsigned long) twritefdsp,
713 (char *) &writefds, sizeof(writefds)) != sizeof(writefds))
715 result = -1;
716 errcode = EINVAL;
720 if (texceptfdsp != NULL)
722 translate_endian((void *) &exceptfds, sizeof(exceptfds));
723 if ((s.write_mem) (cb, &s, (unsigned long) texceptfdsp,
724 (char *) &exceptfds, sizeof(exceptfds)) != sizeof(exceptfds))
726 result = -1;
727 errcode = EINVAL;
731 translate_endian((void *) &timeout, sizeof(timeout));
732 if ((s.write_mem) (cb, &s, (unsigned long) ttimeoutp,
733 (char *) &timeout, sizeof(timeout)) != sizeof(timeout))
735 result = -1;
736 errcode = EINVAL;
739 break;
741 case __NR_symlink:
742 result = symlink((char *) t2h_addr(cb, &s, arg1),
743 (char *) t2h_addr(cb, &s, arg2));
744 errcode = errno;
745 break;
747 case __NR_readlink:
748 result = readlink((char *) t2h_addr(cb, &s, arg1),
749 (char *) t2h_addr(cb, &s, arg2),
750 arg3);
751 errcode = errno;
752 break;
754 case __NR_readdir:
755 result = (int) readdir((DIR *) t2h_addr(cb, &s, arg1));
756 errcode = errno;
757 break;
759 #if 0
760 case __NR_mmap:
762 result = (int) mmap((void *) t2h_addr(cb, &s, arg1),
763 arg2, arg3, arg4, arg5, arg6);
764 errcode = errno;
766 if (errno == 0)
768 sim_core_attach (sd, NULL,
769 0, access_read_write_exec, 0,
770 result, arg2, 0, NULL, NULL);
773 break;
774 #endif
775 case __NR_mmap:
777 void *addr;
778 size_t len;
779 int prot, flags, fildes;
780 off_t off;
782 addr = *((void **) t2h_addr(cb, &s, arg1));
783 len = *((size_t *) t2h_addr(cb, &s, arg1 + 4));
784 prot = *((int *) t2h_addr(cb, &s, arg1 + 8));
785 flags = *((int *) t2h_addr(cb, &s, arg1 + 12));
786 fildes = *((int *) t2h_addr(cb, &s, arg1 + 16));
787 off = *((off_t *) t2h_addr(cb, &s, arg1 + 20));
789 addr = (void *) conv_endian((unsigned int) addr);
790 len = conv_endian(len);
791 prot = conv_endian(prot);
792 flags = conv_endian(flags);
793 fildes = conv_endian(fildes);
794 off = conv_endian(off);
796 //addr = (void *) t2h_addr(cb, &s, (unsigned int) addr);
797 result = (int) mmap(addr, len, prot, flags, fildes, off);
798 errcode = errno;
800 //if (errno == 0)
801 if (result != -1)
803 char c;
804 if (sim_core_read_buffer (sd, NULL, read_map, &c, result, 1) == 0)
805 sim_core_attach (sd, NULL,
806 0, access_read_write_exec, 0,
807 result, len, 0, NULL, NULL);
810 break;
812 case __NR_munmap:
814 result = munmap((void *)arg1, arg2);
815 errcode = errno;
816 if (result != -1)
818 sim_core_detach (sd, NULL, 0, arg2, result);
821 break;
823 case __NR_truncate:
824 result = truncate((char *) t2h_addr(cb, &s, arg1), arg2);
825 errcode = errno;
826 break;
828 case __NR_ftruncate:
829 result = ftruncate(arg1, arg2);
830 errcode = errno;
831 break;
833 case __NR_fchmod:
834 result = fchmod(arg1, arg2);
835 errcode = errno;
836 break;
838 case __NR_fchown:
839 result = fchown(arg1, arg2, arg3);
840 errcode = errno;
841 break;
843 case __NR_statfs:
845 struct statfs statbuf;
847 result = statfs((char *) t2h_addr(cb, &s, arg1), &statbuf);
848 errcode = errno;
850 if (result != 0)
851 break;
853 translate_endian((void *) &statbuf, sizeof(statbuf));
854 if ((s.write_mem) (cb, &s, arg2, (char *) &statbuf, sizeof(statbuf))
855 != sizeof(statbuf))
857 result = -1;
858 errcode = EINVAL;
861 break;
863 case __NR_fstatfs:
865 struct statfs statbuf;
867 result = fstatfs(arg1, &statbuf);
868 errcode = errno;
870 if (result != 0)
871 break;
873 translate_endian((void *) &statbuf, sizeof(statbuf));
874 if ((s.write_mem) (cb, &s, arg2, (char *) &statbuf, sizeof(statbuf))
875 != sizeof(statbuf))
877 result = -1;
878 errcode = EINVAL;
881 break;
883 case __NR_syslog:
884 result = syslog(arg1, (char *) t2h_addr(cb, &s, arg2));
885 errcode = errno;
886 break;
888 case __NR_setitimer:
890 struct itimerval value, ovalue;
892 value = *((struct itimerval *) t2h_addr(cb, &s, arg2));
893 translate_endian((void *) &value, sizeof(value));
895 if (arg2 == 0)
897 result = setitimer(arg1, &value, NULL);
898 errcode = errno;
900 else
902 result = setitimer(arg1, &value, &ovalue);
903 errcode = errno;
905 if (result != 0)
906 break;
908 translate_endian((void *) &ovalue, sizeof(ovalue));
909 if ((s.write_mem) (cb, &s, arg3, (char *) &ovalue, sizeof(ovalue))
910 != sizeof(ovalue))
912 result = -1;
913 errcode = EINVAL;
917 break;
919 case __NR_getitimer:
921 struct itimerval value;
923 result = getitimer(arg1, &value);
924 errcode = errno;
926 if (result != 0)
927 break;
929 translate_endian((void *) &value, sizeof(value));
930 if ((s.write_mem) (cb, &s, arg2, (char *) &value, sizeof(value))
931 != sizeof(value))
933 result = -1;
934 errcode = EINVAL;
937 break;
939 case __NR_stat:
941 char *buf;
942 int buflen;
943 struct stat statbuf;
945 result = stat((char *) t2h_addr(cb, &s, arg1), &statbuf);
946 errcode = errno;
947 if (result < 0)
948 break;
950 buflen = cb_host_to_target_stat (cb, NULL, NULL);
951 buf = xmalloc (buflen);
952 if (cb_host_to_target_stat (cb, &statbuf, buf) != buflen)
954 /* The translation failed. This is due to an internal
955 host program error, not the target's fault. */
956 free (buf);
957 result = -1;
958 errcode = ENOSYS;
959 break;
961 if ((s.write_mem) (cb, &s, arg2, buf, buflen) != buflen)
963 free (buf);
964 result = -1;
965 errcode = EINVAL;
966 break;
968 free (buf);
970 break;
972 case __NR_lstat:
974 char *buf;
975 int buflen;
976 struct stat statbuf;
978 result = lstat((char *) t2h_addr(cb, &s, arg1), &statbuf);
979 errcode = errno;
980 if (result < 0)
981 break;
983 buflen = cb_host_to_target_stat (cb, NULL, NULL);
984 buf = xmalloc (buflen);
985 if (cb_host_to_target_stat (cb, &statbuf, buf) != buflen)
987 /* The translation failed. This is due to an internal
988 host program error, not the target's fault. */
989 free (buf);
990 result = -1;
991 errcode = ENOSYS;
992 break;
994 if ((s.write_mem) (cb, &s, arg2, buf, buflen) != buflen)
996 free (buf);
997 result = -1;
998 errcode = EINVAL;
999 break;
1001 free (buf);
1003 break;
1005 case __NR_fstat:
1007 char *buf;
1008 int buflen;
1009 struct stat statbuf;
1011 result = fstat(arg1, &statbuf);
1012 errcode = errno;
1013 if (result < 0)
1014 break;
1016 buflen = cb_host_to_target_stat (cb, NULL, NULL);
1017 buf = xmalloc (buflen);
1018 if (cb_host_to_target_stat (cb, &statbuf, buf) != buflen)
1020 /* The translation failed. This is due to an internal
1021 host program error, not the target's fault. */
1022 free (buf);
1023 result = -1;
1024 errcode = ENOSYS;
1025 break;
1027 if ((s.write_mem) (cb, &s, arg2, buf, buflen) != buflen)
1029 free (buf);
1030 result = -1;
1031 errcode = EINVAL;
1032 break;
1034 free (buf);
1036 break;
1038 case __NR_sysinfo:
1040 struct sysinfo info;
1042 result = sysinfo(&info);
1043 errcode = errno;
1045 if (result != 0)
1046 break;
1048 info.uptime = conv_endian(info.uptime);
1049 info.loads[0] = conv_endian(info.loads[0]);
1050 info.loads[1] = conv_endian(info.loads[1]);
1051 info.loads[2] = conv_endian(info.loads[2]);
1052 info.totalram = conv_endian(info.totalram);
1053 info.freeram = conv_endian(info.freeram);
1054 info.sharedram = conv_endian(info.sharedram);
1055 info.bufferram = conv_endian(info.bufferram);
1056 info.totalswap = conv_endian(info.totalswap);
1057 info.freeswap = conv_endian(info.freeswap);
1058 info.procs = conv_endian16(info.procs);
1059 #if LINUX_VERSION_CODE >= 0x20400
1060 info.totalhigh = conv_endian(info.totalhigh);
1061 info.freehigh = conv_endian(info.freehigh);
1062 info.mem_unit = conv_endian(info.mem_unit);
1063 #endif
1064 if ((s.write_mem) (cb, &s, arg1, (char *) &info, sizeof(info))
1065 != sizeof(info))
1067 result = -1;
1068 errcode = EINVAL;
1071 break;
1073 #if 0
1074 case __NR_ipc:
1076 result = ipc(arg1, arg2, arg3, arg4,
1077 (void *) t2h_addr(cb, &s, arg5), arg6);
1078 errcode = errno;
1080 break;
1081 #endif
1083 case __NR_fsync:
1084 result = fsync(arg1);
1085 errcode = errno;
1086 break;
1088 case __NR_uname:
1089 /* utsname contains only arrays of char, so it is not necessary
1090 to translate endian. */
1091 result = uname((struct utsname *) t2h_addr(cb, &s, arg1));
1092 errcode = errno;
1093 break;
1095 case __NR_adjtimex:
1097 struct timex buf;
1099 result = adjtimex(&buf);
1100 errcode = errno;
1102 if (result != 0)
1103 break;
1105 translate_endian((void *) &buf, sizeof(buf));
1106 if ((s.write_mem) (cb, &s, arg1, (char *) &buf, sizeof(buf))
1107 != sizeof(buf))
1109 result = -1;
1110 errcode = EINVAL;
1113 break;
1115 case __NR_mprotect:
1116 result = mprotect((void *) arg1, arg2, arg3);
1117 errcode = errno;
1118 break;
1120 case __NR_get_kernel_syms:
1122 struct kernel_sym table;
1124 result = get_kernel_syms(&table);
1125 errcode = errno;
1127 if (result != 0)
1128 break;
1130 table.value = conv_endian(table.value);
1131 if ((s.write_mem) (cb, &s, arg1, (char *) &table, sizeof(table))
1132 != sizeof(table))
1134 result = -1;
1135 errcode = EINVAL;
1138 break;
1140 case __NR_fchdir:
1141 result = fchdir(arg1);
1142 errcode = errno;
1143 break;
1145 case __NR_setfsuid:
1146 result = setfsuid(arg1);
1147 errcode = errno;
1148 break;
1150 case __NR_setfsgid:
1151 result = setfsgid(arg1);
1152 errcode = errno;
1153 break;
1155 #if 0
1156 case __NR__llseek:
1158 loff_t buf;
1160 result = _llseek(arg1, arg2, arg3, &buf, arg5);
1161 errcode = errno;
1163 if (result != 0)
1164 break;
1166 translate_endian((void *) &buf, sizeof(buf));
1167 if ((s.write_mem) (cb, &s, t2h_addr(cb, &s, arg4),
1168 (char *) &buf, sizeof(buf)) != sizeof(buf))
1170 result = -1;
1171 errcode = EINVAL;
1174 break;
1176 case __NR_getdents:
1178 struct dirent dir;
1180 result = getdents(arg1, &dir, arg3);
1181 errcode = errno;
1183 if (result != 0)
1184 break;
1186 dir.d_ino = conv_endian(dir.d_ino);
1187 dir.d_off = conv_endian(dir.d_off);
1188 dir.d_reclen = conv_endian16(dir.d_reclen);
1189 if ((s.write_mem) (cb, &s, arg2, (char *) &dir, sizeof(dir))
1190 != sizeof(dir))
1192 result = -1;
1193 errcode = EINVAL;
1196 break;
1197 #endif
1199 case __NR_flock:
1200 result = flock(arg1, arg2);
1201 errcode = errno;
1202 break;
1204 case __NR_msync:
1205 result = msync((void *) arg1, arg2, arg3);
1206 errcode = errno;
1207 break;
1209 case __NR_readv:
1211 struct iovec vector;
1213 vector = *((struct iovec *) t2h_addr(cb, &s, arg2));
1214 translate_endian((void *) &vector, sizeof(vector));
1216 result = readv(arg1, &vector, arg3);
1217 errcode = errno;
1219 break;
1221 case __NR_writev:
1223 struct iovec vector;
1225 vector = *((struct iovec *) t2h_addr(cb, &s, arg2));
1226 translate_endian((void *) &vector, sizeof(vector));
1228 result = writev(arg1, &vector, arg3);
1229 errcode = errno;
1231 break;
1233 case __NR_fdatasync:
1234 result = fdatasync(arg1);
1235 errcode = errno;
1236 break;
1238 case __NR_mlock:
1239 result = mlock((void *) t2h_addr(cb, &s, arg1), arg2);
1240 errcode = errno;
1241 break;
1243 case __NR_munlock:
1244 result = munlock((void *) t2h_addr(cb, &s, arg1), arg2);
1245 errcode = errno;
1246 break;
1248 case __NR_nanosleep:
1250 struct timespec req, rem;
1252 req = *((struct timespec *) t2h_addr(cb, &s, arg2));
1253 translate_endian((void *) &req, sizeof(req));
1255 result = nanosleep(&req, &rem);
1256 errcode = errno;
1258 if (result != 0)
1259 break;
1261 translate_endian((void *) &rem, sizeof(rem));
1262 if ((s.write_mem) (cb, &s, arg2, (char *) &rem, sizeof(rem))
1263 != sizeof(rem))
1265 result = -1;
1266 errcode = EINVAL;
1269 break;
1271 case __NR_mremap: /* FIXME */
1272 result = (int) mremap((void *) t2h_addr(cb, &s, arg1), arg2, arg3, arg4);
1273 errcode = errno;
1274 break;
1276 case __NR_getresuid:
1278 uid_t ruid, euid, suid;
1280 result = getresuid(&ruid, &euid, &suid);
1281 errcode = errno;
1283 if (result != 0)
1284 break;
1286 *((uid_t *) t2h_addr(cb, &s, arg1)) = conv_endian(ruid);
1287 *((uid_t *) t2h_addr(cb, &s, arg2)) = conv_endian(euid);
1288 *((uid_t *) t2h_addr(cb, &s, arg3)) = conv_endian(suid);
1290 break;
1292 case __NR_poll:
1294 struct pollfd ufds;
1296 ufds = *((struct pollfd *) t2h_addr(cb, &s, arg1));
1297 ufds.fd = conv_endian(ufds.fd);
1298 ufds.events = conv_endian16(ufds.events);
1299 ufds.revents = conv_endian16(ufds.revents);
1301 result = poll(&ufds, arg2, arg3);
1302 errcode = errno;
1304 break;
1306 case __NR_getresgid:
1308 uid_t rgid, egid, sgid;
1310 result = getresgid(&rgid, &egid, &sgid);
1311 errcode = errno;
1313 if (result != 0)
1314 break;
1316 *((uid_t *) t2h_addr(cb, &s, arg1)) = conv_endian(rgid);
1317 *((uid_t *) t2h_addr(cb, &s, arg2)) = conv_endian(egid);
1318 *((uid_t *) t2h_addr(cb, &s, arg3)) = conv_endian(sgid);
1320 break;
1322 case __NR_pread:
1323 result = pread(arg1, (void *) t2h_addr(cb, &s, arg2), arg3, arg4);
1324 errcode = errno;
1325 break;
1327 case __NR_pwrite:
1328 result = pwrite(arg1, (void *) t2h_addr(cb, &s, arg2), arg3, arg4);
1329 errcode = errno;
1330 break;
1332 case __NR_chown:
1333 result = chown((char *) t2h_addr(cb, &s, arg1), arg2, arg3);
1334 errcode = errno;
1335 break;
1337 case __NR_getcwd:
1338 result = (int) getcwd((char *) t2h_addr(cb, &s, arg1), arg2);
1339 errcode = errno;
1340 break;
1342 case __NR_sendfile:
1344 off_t offset;
1346 offset = *((off_t *) t2h_addr(cb, &s, arg3));
1347 offset = conv_endian(offset);
1349 result = sendfile(arg1, arg2, &offset, arg3);
1350 errcode = errno;
1352 if (result != 0)
1353 break;
1355 *((off_t *) t2h_addr(cb, &s, arg3)) = conv_endian(offset);
1357 break;
1359 default:
1360 result = -1;
1361 errcode = ENOSYS;
1362 break;
1365 if (result == -1)
1366 m32rbf_h_gr_set (current_cpu, 0, -errcode);
1367 else
1368 m32rbf_h_gr_set (current_cpu, 0, result);
1369 break;
1372 case TRAP_BREAKPOINT:
1373 sim_engine_halt (sd, current_cpu, NULL, pc,
1374 sim_stopped, SIM_SIGTRAP);
1375 break;
1377 case TRAP_FLUSH_CACHE:
1378 /* Do nothing. */
1379 break;
1381 default :
1383 /* Use cr5 as EVB (EIT Vector Base) register. */
1384 USI new_pc = m32rbf_h_cr_get (current_cpu, 5) + 0x40 + num * 4;
1385 return new_pc;
1389 /* Fake an "rte" insn. */
1390 /* FIXME: Should duplicate all of rte processing. */
1391 return (pc & -4) + 4;