Commit 6180a1818ad1f6147983e48314ab6cbf49d4f084

Authored by bellard
1 parent d3eead2e

new directory structure


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@391 c046a42c-6fe2-441c-8c8c-71466251a162
... ... @@ -27,13 +27,8 @@
27 27 #include <sys/mman.h>
28 28  
29 29 #include "config.h"
30   -#ifdef TARGET_I386
31   -#include "cpu-i386.h"
32   -#endif
33   -#ifdef TARGET_ARM
34   -#include "cpu-arm.h"
35   -#endif
36   -#include "exec.h"
  30 +#include "cpu.h"
  31 +#include "exec-all.h"
37 32  
38 33 //#define DEBUG_TB_INVALIDATE
39 34 //#define DEBUG_FLUSH
... ...
gdbstub.c
... ... @@ -28,14 +28,9 @@
28 28 #include <signal.h>
29 29  
30 30 #include "config.h"
31   -#ifdef TARGET_I386
32   -#include "cpu-i386.h"
33   -#endif
34   -#ifdef TARGET_ARM
35   -#include "cpu-arm.h"
36   -#endif
  31 +#include "cpu.h"
37 32 #include "thunk.h"
38   -#include "exec.h"
  33 +#include "exec-all.h"
39 34  
40 35 //#define DEBUG_GDB
41 36  
... ...
hw/vga.c
... ... @@ -40,8 +40,8 @@
40 40 #include <sys/wait.h>
41 41 #include <netinet/in.h>
42 42  
43   -#include "cpu-i386.h"
44   -#include "exec.h"
  43 +#include "cpu.h"
  44 +#include "exec-all.h"
45 45  
46 46 #include "vl.h"
47 47  
... ...
linux-user/qemu.h
... ... @@ -6,15 +6,8 @@
6 6 #include <signal.h>
7 7 #include "syscall_defs.h"
8 8  
9   -#if defined(TARGET_I386)
10   -#include "cpu-i386.h"
11   -#include "syscall-i386.h"
12   -#elif defined(TARGET_ARM)
13   -#include "cpu-arm.h"
14   -#include "syscall-arm.h"
15   -#else
16   -#error unsupported target CPU
17   -#endif
  9 +#include "cpu.h"
  10 +#include "syscall.h"
18 11  
19 12 /* This struct is used to hold certain information about the image.
20 13 * Basically, it replicates in user space what would be certain
... ...
linux-user/syscall_defs.h
... ... @@ -4,284 +4,7 @@
4 4 most of them stay the same, so we handle it by puting ifdefs if
5 5 necessary */
6 6  
7   -#define TARGET_NR_exit 1
8   -#define TARGET_NR_fork 2
9   -#define TARGET_NR_read 3
10   -#define TARGET_NR_write 4
11   -#define TARGET_NR_open 5
12   -#define TARGET_NR_close 6
13   -#define TARGET_NR_waitpid 7
14   -#define TARGET_NR_creat 8
15   -#define TARGET_NR_link 9
16   -#define TARGET_NR_unlink 10
17   -#define TARGET_NR_execve 11
18   -#define TARGET_NR_chdir 12
19   -#define TARGET_NR_time 13
20   -#define TARGET_NR_mknod 14
21   -#define TARGET_NR_chmod 15
22   -#define TARGET_NR_lchown 16
23   -#define TARGET_NR_break 17
24   -#define TARGET_NR_oldstat 18
25   -#define TARGET_NR_lseek 19
26   -#define TARGET_NR_getpid 20
27   -#define TARGET_NR_mount 21
28   -#define TARGET_NR_umount 22
29   -#define TARGET_NR_setuid 23
30   -#define TARGET_NR_getuid 24
31   -#define TARGET_NR_stime 25
32   -#define TARGET_NR_ptrace 26
33   -#define TARGET_NR_alarm 27
34   -#define TARGET_NR_oldfstat 28
35   -#define TARGET_NR_pause 29
36   -#define TARGET_NR_utime 30
37   -#define TARGET_NR_stty 31
38   -#define TARGET_NR_gtty 32
39   -#define TARGET_NR_access 33
40   -#define TARGET_NR_nice 34
41   -#define TARGET_NR_ftime 35
42   -#define TARGET_NR_sync 36
43   -#define TARGET_NR_kill 37
44   -#define TARGET_NR_rename 38
45   -#define TARGET_NR_mkdir 39
46   -#define TARGET_NR_rmdir 40
47   -#define TARGET_NR_dup 41
48   -#define TARGET_NR_pipe 42
49   -#define TARGET_NR_times 43
50   -#define TARGET_NR_prof 44
51   -#define TARGET_NR_brk 45
52   -#define TARGET_NR_setgid 46
53   -#define TARGET_NR_getgid 47
54   -#define TARGET_NR_signal 48
55   -#define TARGET_NR_geteuid 49
56   -#define TARGET_NR_getegid 50
57   -#define TARGET_NR_acct 51
58   -#define TARGET_NR_umount2 52
59   -#define TARGET_NR_lock 53
60   -#define TARGET_NR_ioctl 54
61   -#define TARGET_NR_fcntl 55
62   -#define TARGET_NR_mpx 56
63   -#define TARGET_NR_setpgid 57
64   -#define TARGET_NR_ulimit 58
65   -#define TARGET_NR_oldolduname 59
66   -#define TARGET_NR_umask 60
67   -#define TARGET_NR_chroot 61
68   -#define TARGET_NR_ustat 62
69   -#define TARGET_NR_dup2 63
70   -#define TARGET_NR_getppid 64
71   -#define TARGET_NR_getpgrp 65
72   -#define TARGET_NR_setsid 66
73   -#define TARGET_NR_sigaction 67
74   -#define TARGET_NR_sgetmask 68
75   -#define TARGET_NR_ssetmask 69
76   -#define TARGET_NR_setreuid 70
77   -#define TARGET_NR_setregid 71
78   -#define TARGET_NR_sigsuspend 72
79   -#define TARGET_NR_sigpending 73
80   -#define TARGET_NR_sethostname 74
81   -#define TARGET_NR_setrlimit 75
82   -#define TARGET_NR_getrlimit 76 /* Back compatible 2Gig limited rlimit */
83   -#define TARGET_NR_getrusage 77
84   -#define TARGET_NR_gettimeofday 78
85   -#define TARGET_NR_settimeofday 79
86   -#define TARGET_NR_getgroups 80
87   -#define TARGET_NR_setgroups 81
88   -#define TARGET_NR_select 82
89   -#define TARGET_NR_symlink 83
90   -#define TARGET_NR_oldlstat 84
91   -#define TARGET_NR_readlink 85
92   -#define TARGET_NR_uselib 86
93   -#define TARGET_NR_swapon 87
94   -#define TARGET_NR_reboot 88
95   -#define TARGET_NR_readdir 89
96   -#define TARGET_NR_mmap 90
97   -#define TARGET_NR_munmap 91
98   -#define TARGET_NR_truncate 92
99   -#define TARGET_NR_ftruncate 93
100   -#define TARGET_NR_fchmod 94
101   -#define TARGET_NR_fchown 95
102   -#define TARGET_NR_getpriority 96
103   -#define TARGET_NR_setpriority 97
104   -#define TARGET_NR_profil 98
105   -#define TARGET_NR_statfs 99
106   -#define TARGET_NR_fstatfs 100
107   -#define TARGET_NR_ioperm 101
108   -#define TARGET_NR_socketcall 102
109   -#define TARGET_NR_syslog 103
110   -#define TARGET_NR_setitimer 104
111   -#define TARGET_NR_getitimer 105
112   -#define TARGET_NR_stat 106
113   -#define TARGET_NR_lstat 107
114   -#define TARGET_NR_fstat 108
115   -#define TARGET_NR_olduname 109
116   -#define TARGET_NR_iopl 110
117   -#define TARGET_NR_vhangup 111
118   -#define TARGET_NR_idle 112
119   -#define TARGET_NR_vm86old 113
120   -#define TARGET_NR_wait4 114
121   -#define TARGET_NR_swapoff 115
122   -#define TARGET_NR_sysinfo 116
123   -#define TARGET_NR_ipc 117
124   -#define TARGET_NR_fsync 118
125   -#define TARGET_NR_sigreturn 119
126   -#define TARGET_NR_clone 120
127   -#define TARGET_NR_setdomainname 121
128   -#define TARGET_NR_uname 122
129   -#define TARGET_NR_modify_ldt 123
130   -#define TARGET_NR_adjtimex 124
131   -#define TARGET_NR_mprotect 125
132   -#define TARGET_NR_sigprocmask 126
133   -#define TARGET_NR_create_module 127
134   -#define TARGET_NR_init_module 128
135   -#define TARGET_NR_delete_module 129
136   -#define TARGET_NR_get_kernel_syms 130
137   -#define TARGET_NR_quotactl 131
138   -#define TARGET_NR_getpgid 132
139   -#define TARGET_NR_fchdir 133
140   -#define TARGET_NR_bdflush 134
141   -#define TARGET_NR_sysfs 135
142   -#define TARGET_NR_personality 136
143   -#define TARGET_NR_afs_syscall 137 /* Syscall for Andrew File System */
144   -#define TARGET_NR_setfsuid 138
145   -#define TARGET_NR_setfsgid 139
146   -#define TARGET_NR__llseek 140
147   -#define TARGET_NR_getdents 141
148   -#define TARGET_NR__newselect 142
149   -#define TARGET_NR_flock 143
150   -#define TARGET_NR_msync 144
151   -#define TARGET_NR_readv 145
152   -#define TARGET_NR_writev 146
153   -#define TARGET_NR_getsid 147
154   -#define TARGET_NR_fdatasync 148
155   -#define TARGET_NR__sysctl 149
156   -#define TARGET_NR_mlock 150
157   -#define TARGET_NR_munlock 151
158   -#define TARGET_NR_mlockall 152
159   -#define TARGET_NR_munlockall 153
160   -#define TARGET_NR_sched_setparam 154
161   -#define TARGET_NR_sched_getparam 155
162   -#define TARGET_NR_sched_setscheduler 156
163   -#define TARGET_NR_sched_getscheduler 157
164   -#define TARGET_NR_sched_yield 158
165   -#define TARGET_NR_sched_get_priority_max 159
166   -#define TARGET_NR_sched_get_priority_min 160
167   -#define TARGET_NR_sched_rr_get_interval 161
168   -#define TARGET_NR_nanosleep 162
169   -#define TARGET_NR_mremap 163
170   -#define TARGET_NR_setresuid 164
171   -#define TARGET_NR_getresuid 165
172   -#define TARGET_NR_vm86 166
173   -#define TARGET_NR_query_module 167
174   -#define TARGET_NR_poll 168
175   -#define TARGET_NR_nfsservctl 169
176   -#define TARGET_NR_setresgid 170
177   -#define TARGET_NR_getresgid 171
178   -#define TARGET_NR_prctl 172
179   -#define TARGET_NR_rt_sigreturn 173
180   -#define TARGET_NR_rt_sigaction 174
181   -#define TARGET_NR_rt_sigprocmask 175
182   -#define TARGET_NR_rt_sigpending 176
183   -#define TARGET_NR_rt_sigtimedwait 177
184   -#define TARGET_NR_rt_sigqueueinfo 178
185   -#define TARGET_NR_rt_sigsuspend 179
186   -#define TARGET_NR_pread 180
187   -#define TARGET_NR_pwrite 181
188   -#define TARGET_NR_chown 182
189   -#define TARGET_NR_getcwd 183
190   -#define TARGET_NR_capget 184
191   -#define TARGET_NR_capset 185
192   -#define TARGET_NR_sigaltstack 186
193   -#define TARGET_NR_sendfile 187
194   -#define TARGET_NR_getpmsg 188 /* some people actually want streams */
195   -#define TARGET_NR_putpmsg 189 /* some people actually want streams */
196   -#define TARGET_NR_vfork 190
197   -#define TARGET_NR_ugetrlimit 191 /* SuS compliant getrlimit */
198   -#define TARGET_NR_mmap2 192
199   -#define TARGET_NR_truncate64 193
200   -#define TARGET_NR_ftruncate64 194
201   -#define TARGET_NR_stat64 195
202   -#define TARGET_NR_lstat64 196
203   -#define TARGET_NR_fstat64 197
204   -#define TARGET_NR_lchown32 198
205   -#define TARGET_NR_getuid32 199
206   -#define TARGET_NR_getgid32 200
207   -#define TARGET_NR_geteuid32 201
208   -#define TARGET_NR_getegid32 202
209   -#define TARGET_NR_setreuid32 203
210   -#define TARGET_NR_setregid32 204
211   -#define TARGET_NR_getgroups32 205
212   -#define TARGET_NR_setgroups32 206
213   -#define TARGET_NR_fchown32 207
214   -#define TARGET_NR_setresuid32 208
215   -#define TARGET_NR_getresuid32 209
216   -#define TARGET_NR_setresgid32 210
217   -#define TARGET_NR_getresgid32 211
218   -#define TARGET_NR_chown32 212
219   -#define TARGET_NR_setuid32 213
220   -#define TARGET_NR_setgid32 214
221   -#define TARGET_NR_setfsuid32 215
222   -#define TARGET_NR_setfsgid32 216
223   -
224   -#if defined(TARGET_I386)
225   -#define TARGET_NR_pivot_root 217
226   -#define TARGET_NR_mincore 218
227   -#define TARGET_NR_madvise 219
228   -#define TARGET_NR_madvise1 219 /* delete when C lib stub is removed */
229   -#define TARGET_NR_getdents64 220
230   -#endif
231   -
232   -#if defined(TARGET_ARM)
233   -#define TARGET_NR_getdents64 217
234   -#define TARGET_NR_pivot_root 218
235   -#define TARGET_NR_mincore 219
236   -#define TARGET_NR_madvise 220
237   -#endif
238   -
239   -#define TARGET_NR_fcntl64 221
240   -#define TARGET_NR_security 223 /* syscall for security modules */
241   -#define TARGET_NR_gettid 224
242   -#define TARGET_NR_readahead 225
243   -#define TARGET_NR_setxattr 226
244   -#define TARGET_NR_lsetxattr 227
245   -#define TARGET_NR_fsetxattr 228
246   -#define TARGET_NR_getxattr 229
247   -#define TARGET_NR_lgetxattr 230
248   -#define TARGET_NR_fgetxattr 231
249   -#define TARGET_NR_listxattr 232
250   -#define TARGET_NR_llistxattr 233
251   -#define TARGET_NR_flistxattr 234
252   -#define TARGET_NR_removexattr 235
253   -#define TARGET_NR_lremovexattr 236
254   -#define TARGET_NR_fremovexattr 237
255   -#define TARGET_NR_tkill 238
256   -#define TARGET_NR_sendfile64 239
257   -#define TARGET_NR_futex 240
258   -#define TARGET_NR_sched_setaffinity 241
259   -#define TARGET_NR_sched_getaffinity 242
260   -#define TARGET_NR_set_thread_area 243
261   -#define TARGET_NR_get_thread_area 244
262   -#define TARGET_NR_io_setup 245
263   -#define TARGET_NR_io_destroy 246
264   -#define TARGET_NR_io_getevents 247
265   -#define TARGET_NR_io_submit 248
266   -#define TARGET_NR_io_cancel 249
267   -#define TARGET_NR_fadvise64 250
268   -
269   -#define TARGET_NR_exit_group 252
270   -#define TARGET_NR_lookup_dcookie 253
271   -#define TARGET_NR_epoll_create 254
272   -#define TARGET_NR_epoll_ctl 255
273   -#define TARGET_NR_epoll_wait 256
274   -#define TARGET_NR_remap_file_pages 257
275   -#define TARGET_NR_set_tid_address 258
276   -#define TARGET_NR_timer_create 259
277   -#define TARGET_NR_timer_settime (TARGET_NR_timer_create+1)
278   -#define TARGET_NR_timer_gettime (TARGET_NR_timer_create+2)
279   -#define TARGET_NR_timer_getoverrun (TARGET_NR_timer_create+3)
280   -#define TARGET_NR_timer_delete (TARGET_NR_timer_create+4)
281   -#define TARGET_NR_clock_settime (TARGET_NR_timer_create+5)
282   -#define TARGET_NR_clock_gettime (TARGET_NR_timer_create+6)
283   -#define TARGET_NR_clock_getres (TARGET_NR_timer_create+7)
284   -#define TARGET_NR_clock_nanosleep (TARGET_NR_timer_create+8)
  7 +#include "syscall_nr.h"
285 8  
286 9 #define SOCKOP_socket 1
287 10 #define SOCKOP_bind 2
... ... @@ -321,7 +44,7 @@
321 44 #define TARGET_IOC_WRITE 1U
322 45 #define TARGET_IOC_READ 2U
323 46  
324   -#elif defined(TARGET_PPC) || defined(TARGET_ALPHA)
  47 +#elif defined(TARGET_PPC) || defined(TARGET_ALPHA) || defined(TARGET_SPARC)
325 48  
326 49 #define TARGET_IOC_SIZEBITS 13
327 50 #define TARGET_IOC_DIRBITS 3
... ... @@ -392,6 +115,11 @@ struct target_tms {
392 115 target_clock_t tms_cstime;
393 116 };
394 117  
  118 +struct target_utimbuf {
  119 + target_long actime;
  120 + target_long modtime;
  121 +};
  122 +
395 123 struct target_sel_arg_struct {
396 124 target_long n;
397 125 target_long inp, outp, exp;
... ... @@ -551,7 +279,7 @@ struct target_sigaction;
551 279 int do_sigaction(int sig, const struct target_sigaction *act,
552 280 struct target_sigaction *oact);
553 281  
554   -#if defined(TARGET_I386) || defined(TARGET_ARM)
  282 +#if defined(TARGET_I386) || defined(TARGET_ARM) || defined(TARGET_SPARC)
555 283  
556 284 #define TARGET_SA_NOCLDSTOP 0x00000001
557 285 #define TARGET_SA_NOCLDWAIT 0x00000002 /* not supported yet */
... ... @@ -936,7 +664,7 @@ struct target_pollfd {
936 664 #define TARGET_HDIO_SET_PIO_MODE 0x0327 /* reconfig interface to new speed */
937 665  
938 666  
939   -#if defined(TARGET_I386) || defined(TARGET_ARM)
  667 +#if defined(TARGET_I386) || defined(TARGET_ARM) || defined(TARGET_SPARC)
940 668  
941 669 /* 0x54 is just a magic number to make these relatively unique ('T') */
942 670  
... ...