1=============================================================================
2Purpose of this file
3=============================================================================
4In late 2004 Nick and Julian spent a little time working on the beginnings of
5an ARM port.  IIRC it was compiling, but we never got it running at all, or if
6we did, it didn't get very far.  Most of the required
7arch/platform-specific functions were still empty stubs.
8
9Since then, the code structure has changed a lot.  In particular, the $ARCH and
10$PLATFORM directories have gone, and everything has been broken into much
11more well-defined modules.  The ARM code wasn't being kept up with these
12changes, so it has bit-rotted badly.  So now I'm pulling it all out.  But
13there is some useful knowledge in the ARM code, and the vki*.h files are
14fully done.  So I'm putting all the useful stuff in this file in case anyone
15tries porting to ARM again in the future.
16
17-- njn, Jul 2, 2005
18
19=============================================================================
20General
21=============================================================================
22You'll need to :
23- Update Makefile.am files when you add back in the vki*.h files in include/
24  and coregrind/.
25- Also the valgrind.spec.in file
26- Add lots of missing cases in lots of places requiring
27  arch-/platform-specific code.  Compile errors should tell you where.
28
29=============================================================================
30configure.in
31=============================================================================
32You'll need to:
33- Add appropriate arm/ test subdirs to memcheck/tests/, none/tests/,
34  cachegrind/tests/.
35- Add arm to VG_ARCH_ALL and arm-linux to VG_PLATFORM_ALL
36- Add it to the $VG_ARCH/$VG_PLATFORM case statements in configure.in
37- Here's the case for the ${host_cpu} case statement:
38
39     arm*)
40	AC_MSG_RESULT([ok (${host_cpu})])
41        VG_ARCH="arm"
42        KICKSTART_BASE="0xb0000000"
43        ARCH_CORE_AM_CFLAGS="-fomit-frame-pointer"
44        ARCH_TOOL_AM_CFLAGS="-fomit-frame-pointer"
45        ARCH_CORE_AM_CCASFLAGS=""
46        ;;
47
48=============================================================================
49From cachegrind/cg-arm.c
50=============================================================================
51void VG_(configure_caches)(cache_t* I1c, cache_t* D1c, cache_t* L2c,
52                           Bool all_caches_clo_defined)
53{
54   // XXX: I1 and D1 are vaguely plausible, although they could really be
55   // anything.  However, most (all?) ARMs don't have an L2 cache.  But
56   // Cachegrind assumes the presence of an L2 cache... so we just copy the
57   // x86 defaults.  Urk.
58   *I1c = (cache_t) {   4096, 2, 32 };
59   *D1c = (cache_t) {   4096, 2, 32 };
60   *L2c = (cache_t) { 262144, 8, 64 };
61}
62
63=============================================================================
64From m_syswrap/syswrap-arm-linux.c
65=============================================================================
66
67/* ---------------------------------------------------------------------
68   The ARM/Linux syscall table
69   ------------------------------------------------------------------ */
70
71// Macros for adding ARM/Linux-specific wrappers to the syscall table.  Note
72// that ARM syscall numbers start at __NR_SYSCALL_BASE.
73#define PLAX_(const, name) \
74   SYS_WRAPPER_ENTRY_X_(arm_linux, const - __NR_SYSCALL_BASE, name)
75#define PLAXY(const, name) \
76   SYS_WRAPPER_ENTRY_XY(arm_linux, const - __NR_SYSCALL_BASE, name)
77
78// This table maps from __NR_xxx syscall numbers (from
79// linux/include/asm-arm/unistd.h) to the appropriate PRE/POST sys_foo()
80// wrappers on ARM (as per sys_call_table in linux/arch/arm/kernel/entry.S).
81//
82// XXX: look at the x86-linux one to see how to do it.
83
84const struct SyscallTableEntry ML_(syscall_table)[] = {
85   //   (restart_syscall)                             // 0
86   GENX_(__NR_exit,              sys_exit),           // 1
87   LINX_(__NR_mount,             sys_mount),          // 21
88   PLAX_(__NR_syscall,           sys_syscall),        // 113
89   PLAXY(__NR_ipc,               sys_ipc),            // 117
90   PLAX_(__NR_clone,             sys_clone),          // 120
91};
92
93const UInt ML_(syscall_table_size) =
94            sizeof(ML_(syscall_table)) / sizeof(ML_(syscall_table)[0]);
95
96=============================================================================
97From m_scheduler/scheduler.c
98=============================================================================
99#elif defined(VGA_arm)
100#  define VG_CLREQ_ARGS       guest_R0
101#  define VG_CLREQ_RET        guest_R0
102
103=============================================================================
104From include/pub_tool_machine.h
105=============================================================================
106#elif defined(VGA_arm)
107#  define VG_MIN_INSTR_SZB          4
108#  define VG_MAX_INSTR_SZB          4
109#  define VG_STACK_REDZONE_SZB      0
110
111=============================================================================
112From include/pub_tool_basics.h
113=============================================================================
114#elif defined(VGA_arm)
115#  define VG_REGPARM(n)            /* */
116
117=============================================================================
118From coregrind/pub_core_machine.h
119=============================================================================
120#elif defined(VGA_arm)
121#  define VG_ELF_ENDIANNESS   ELFDATA2LSB
122#  define VG_ELF_MACHINE      EM_ARM
123#  define VG_ELF_CLASS        ELFCLASS32
124
125#elif defined(VGA_arm)
126   // XXX: Not sure, but I think:
127   //   r11 = frame pointer
128   //   r12 = "implicit parameter" (neither caller-save, nor callee-save)
129   //   r13 = stack pointer
130   //   r14 = link register
131   //   r15 = program counter
132#  define VG_INSTR_PTR        guest_R15
133#  define VG_STACK_PTR        guest_R13
134#  define VG_FRAME_PTR        guest_R11
135
136=============================================================================
137From coregrind/pub_core_threadstate.h
138=============================================================================
139#elif defined(VGA_arm)
140   typedef VexGuestARMState   VexGuestArchState;
141
142=============================================================================
143From coregrind/vki_unistd.h
144=============================================================================
145#elif defined(VGP_arm_linux)
146#  include "vki_unistd-arm-linux.h"
147
148=============================================================================
149From coregrind/m_signals.c
150=============================================================================
151#elif defined(VGP_arm_linux)
152#  define VG_UCONTEXT_INSTR_PTR(uc)       ((uc)->uc_mcontext.arm_pc)
153#  define VG_UCONTEXT_STACK_PTR(uc)       ((uc)->uc_mcontext.arm_sp)
154#  define VG_UCONTEXT_FRAME_PTR(uc)       ((uc)->uc_mcontext.arm_fp)
155#  define VG_UCONTEXT_SYSCALL_NUM(uc)     ((uc)->uc_mcontext.arm_r0)
156#  error VG_UCONTEXT_SYSCALL_RET undefined for ARM/Linux
157
158=============================================================================
159From tests/arch_test.c
160=============================================================================
161- You'll need to add "arm" to all_archs[].
162
163#ifdef __arm__
164static Bool go(char* cpu)
165{
166   if ( strcmp( cpu, "arm" ) == 0 )
167      return True;
168   else
169      return False;
170}
171#endif // __arm__
172
173=============================================================================
174All of include/vki_posixtypes-arm-linux.h
175=============================================================================
176
177/*--------------------------------------------------------------------*/
178/*--- ARM/Linux-specific kernel interface: posix types.            ---*/
179/*---                                   vki_posixtypes-arm-linux.h ---*/
180/*--------------------------------------------------------------------*/
181
182/*
183   This file is part of Valgrind, a dynamic binary instrumentation
184   framework.
185
186   Copyright (C) 2000-2005 Julian Seward
187      jseward@acm.org
188
189   This program is free software; you can redistribute it and/or
190   modify it under the terms of the GNU General Public License as
191   published by the Free Software Foundation; either version 2 of the
192   License, or (at your option) any later version.
193
194   This program is distributed in the hope that it will be useful, but
195   WITHOUT ANY WARRANTY; without even the implied warranty of
196   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
197   General Public License for more details.
198
199   You should have received a copy of the GNU General Public License
200   along with this program; if not, write to the Free Software
201   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
202   02111-1307, USA.
203
204   The GNU General Public License is contained in the file COPYING.
205*/
206
207#ifndef __VKI_POSIXTYPES_ARM_LINUX_H
208#define __VKI_POSIXTYPES_ARM_LINUX_H
209
210//----------------------------------------------------------------------
211// From linux-2.6.8.1/include/asm-i386/posix_types.h
212//----------------------------------------------------------------------
213
214typedef unsigned short		__vki_kernel_mode_t;
215typedef long			__vki_kernel_off_t;
216typedef int			__vki_kernel_pid_t;
217typedef unsigned short		__vki_kernel_ipc_pid_t;
218typedef unsigned short		__vki_kernel_uid_t;
219typedef unsigned short		__vki_kernel_gid_t;
220typedef unsigned int		__vki_kernel_size_t;
221typedef long			__vki_kernel_time_t;
222typedef long			__vki_kernel_suseconds_t;
223typedef long			__vki_kernel_clock_t;
224typedef int			__vki_kernel_timer_t;
225typedef int			__vki_kernel_clockid_t;
226typedef char *			__vki_kernel_caddr_t;
227typedef unsigned int		__vki_kernel_uid32_t;
228typedef unsigned int		__vki_kernel_gid32_t;
229
230typedef unsigned short		__vki_kernel_old_uid_t;
231typedef unsigned short		__vki_kernel_old_gid_t;
232
233typedef long long	        __vki_kernel_loff_t;
234
235typedef struct {
236	int	val[2];
237} __vki_kernel_fsid_t;
238
239#endif // __VKI_POSIXTYPES_ARM_LINUX_H
240
241/*--------------------------------------------------------------------*/
242/*--- end                                                          ---*/
243/*--------------------------------------------------------------------*/
244
245=============================================================================
246All of include/vki-arm-linux.h
247=============================================================================
248
249/*--------------------------------------------------------------------*/
250/*--- ARM/Linux-specific kernel interface.         vki-arm-linux.h ---*/
251/*--------------------------------------------------------------------*/
252
253/*
254   This file is part of Valgrind, a dynamic binary instrumentation
255   framework.
256
257   Copyright (C) 2000-2005 Julian Seward
258      jseward@acm.org
259
260   This program is free software; you can redistribute it and/or
261   modify it under the terms of the GNU General Public License as
262   published by the Free Software Foundation; either version 2 of the
263   License, or (at your option) any later version.
264
265   This program is distributed in the hope that it will be useful, but
266   WITHOUT ANY WARRANTY; without even the implied warranty of
267   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
268   General Public License for more details.
269
270   You should have received a copy of the GNU General Public License
271   along with this program; if not, write to the Free Software
272   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
273   02111-1307, USA.
274
275   The GNU General Public License is contained in the file COPYING.
276*/
277
278#ifndef __VKI_ARM_LINUX_H
279#define __VKI_ARM_LINUX_H
280
281// ARM can be big or little endian;  we're only supporting little endian.
282#define VKI_LITTLE_ENDIAN  1
283
284//----------------------------------------------------------------------
285// From linux-2.6.9/include/asm-arm/types.h
286//----------------------------------------------------------------------
287
288typedef unsigned char __vki_u8;
289
290typedef __signed__ short __vki_s16;
291typedef unsigned short __vki_u16;
292
293typedef unsigned int __vki_u32;
294
295typedef __signed__ long long __vki_s64;
296typedef unsigned long long __vki_u64;
297
298typedef unsigned short vki_u16;
299
300typedef unsigned int vki_u32;
301
302//----------------------------------------------------------------------
303// From linux-2.6.9/include/asm-arm/page.h
304//----------------------------------------------------------------------
305
306#define VKI_PAGE_SHIFT		12
307#define VKI_PAGE_SIZE		(1UL << VKI_PAGE_SHIFT)
308
309//----------------------------------------------------------------------
310// From linux-2.6.9/include/asm-arm/signal.h
311//----------------------------------------------------------------------
312
313#define _VKI_NSIG	64
314#define _VKI_NSIG_BPW	32
315#define _VKI_NSIG_WORDS	(_VKI_NSIG / _VKI_NSIG_BPW)
316
317typedef unsigned long vki_old_sigset_t;		/* at least 32 bits */
318
319typedef struct {
320	unsigned long sig[_VKI_NSIG_WORDS];
321} vki_sigset_t;
322
323#define VKI_SIGHUP		 1
324#define VKI_SIGINT		 2
325#define VKI_SIGQUIT		 3
326#define VKI_SIGILL		 4
327#define VKI_SIGTRAP		 5
328#define VKI_SIGABRT		 6
329//#define VKI_SIGIOT		 6
330#define VKI_SIGBUS		 7
331#define VKI_SIGFPE		 8
332#define VKI_SIGKILL		 9
333#define VKI_SIGUSR1		10
334#define VKI_SIGSEGV		11
335#define VKI_SIGUSR2		12
336#define VKI_SIGPIPE		13
337#define VKI_SIGALRM		14
338#define VKI_SIGTERM		15
339#define VKI_SIGSTKFLT	16
340#define VKI_SIGCHLD		17
341#define VKI_SIGCONT		18
342#define VKI_SIGSTOP		19
343#define VKI_SIGTSTP		20
344#define VKI_SIGTTIN		21
345#define VKI_SIGTTOU		22
346#define VKI_SIGURG		23
347#define VKI_SIGXCPU		24
348#define VKI_SIGXFSZ		25
349#define VKI_SIGVTALRM	26
350#define VKI_SIGPROF		27
351#define VKI_SIGWINCH	28
352#define VKI_SIGIO		29
353#define VKI_SIGPWR		30
354#define VKI_SIGSYS		31
355#define	VKI_SIGUNUSED	31
356
357/* These should not be considered constants from userland.  */
358#define VKI_SIGRTMIN	32
359#define VKI_SIGRTMAX	_VKI_NSIG
360
361#define VKI_SIGSWI		32
362
363#define VKI_SA_NOCLDSTOP	0x00000001
364#define VKI_SA_NOCLDWAIT	0x00000002
365#define VKI_SA_SIGINFO	0x00000004
366//#define VKI_SA_THIRTYTWO	0x02000000
367#define VKI_SA_RESTORER	0x04000000
368#define VKI_SA_ONSTACK	0x08000000
369#define VKI_SA_RESTART	0x10000000
370#define VKI_SA_NODEFER	0x40000000
371#define VKI_SA_RESETHAND	0x80000000
372
373#define VKI_SA_NOMASK	VKI_SA_NODEFER
374#define VKI_SA_ONESHOT	VKI_SA_RESETHAND
375//#define VKI_SA_INTERRUPT	0x20000000 /* dummy -- ignored */
376
377
378#define VKI_SS_ONSTACK	1
379#define VKI_SS_DISABLE	2
380
381#define VKI_MINSIGSTKSZ	2048
382
383#define VKI_SIG_BLOCK          0	/* for blocking signals */
384#define VKI_SIG_UNBLOCK        1	/* for unblocking signals */
385#define VKI_SIG_SETMASK        2	/* for setting the signal mask */
386
387/* Type of a signal handler.  */
388typedef void __vki_signalfn_t(int);
389typedef __vki_signalfn_t __user *__vki_sighandler_t;
390
391typedef void __vki_restorefn_t(void);
392typedef __vki_restorefn_t __user *__vki_sigrestore_t;
393
394#define VKI_SIG_DFL	((__vki_sighandler_t)0)	/* default signal handling */
395#define VKI_SIG_IGN	((__vki_sighandler_t)1)	/* ignore signal */
396
397struct vki_old_sigaction {
398        // [[Nb: a 'k' prefix is added to "sa_handler" because
399        // bits/sigaction.h (which gets dragged in somehow via signal.h)
400        // #defines it as something else.  Since that is done for glibc's
401        // purposes, which we don't care about here, we use our own name.]]
402	__vki_sighandler_t ksa_handler;
403	vki_old_sigset_t sa_mask;
404	unsigned long sa_flags;
405	__vki_sigrestore_t sa_restorer;
406};
407
408struct vki_sigaction {
409        // [[See comment about extra 'k' above]]
410	__vki_sighandler_t ksa_handler;
411	unsigned long sa_flags;
412	__vki_sigrestore_t sa_restorer;
413	vki_sigset_t sa_mask;		/* mask last for extensibility */
414};
415
416typedef struct vki_sigaltstack {
417	void __user *ss_sp;
418	int ss_flags;
419	vki_size_t ss_size;
420} vki_stack_t;
421
422//----------------------------------------------------------------------
423// From linux-2.6.9/include/asm-arm/sigcontext.h
424//----------------------------------------------------------------------
425
426struct vki_sigcontext {
427	unsigned long trap_no;
428	unsigned long error_code;
429	unsigned long oldmask;
430	unsigned long arm_r0;
431	unsigned long arm_r1;
432	unsigned long arm_r2;
433	unsigned long arm_r3;
434	unsigned long arm_r4;
435	unsigned long arm_r5;
436	unsigned long arm_r6;
437	unsigned long arm_r7;
438	unsigned long arm_r8;
439	unsigned long arm_r9;
440	unsigned long arm_r10;
441	unsigned long arm_fp;
442	unsigned long arm_ip;
443	unsigned long arm_sp;
444	unsigned long arm_lr;
445	unsigned long arm_pc;
446	unsigned long arm_cpsr;
447	unsigned long fault_address;
448};
449
450//----------------------------------------------------------------------
451// From linux-2.6.9/include/asm-arm/mman.h
452//----------------------------------------------------------------------
453
454#define VKI_PROT_READ	0x1		/* page can be read */
455#define VKI_PROT_WRITE	0x2		/* page can be written */
456#define VKI_PROT_EXEC	0x4		/* page can be executed */
457//#define VKI_PROT_SEM	0x8		/* page may be used for atomic ops */
458//#define VKI_PROT_NONE	0x0		/* page can not be accessed */
459
460#define VKI_MAP_SHARED	0x01		/* Share changes */
461#define VKI_MAP_PRIVATE	0x02		/* Changes are private */
462#define VKI_MAP_TYPE	0x0f		/* Mask for type of mapping */
463#define VKI_MAP_FIXED	0x10		/* Interpret addr exactly */
464#define VKI_MAP_ANONYMOUS	0x20	/* don't use a file */
465
466//----------------------------------------------------------------------
467// From linux-2.6.9/include/asm-arm/fcntl.h
468//----------------------------------------------------------------------
469
470#define VKI_O_RDONLY	     00
471#define VKI_O_WRONLY	     01
472#define VKI_O_CREAT	   0100	/* not fcntl */
473#define VKI_O_EXCL	   0200	/* not fcntl */
474#define VKI_O_TRUNC	  01000	/* not fcntl */
475#define VKI_O_NONBLOCK	  04000
476
477#define VKI_F_DUPFD	0	/* dup */
478#define VKI_F_GETFD	1	/* get close_on_exec */
479#define VKI_F_SETFD	2	/* set/clear close_on_exec */
480#define VKI_F_GETFL	3	/* get file->f_flags */
481#define VKI_F_SETFL	4	/* set file->f_flags */
482#define VKI_F_GETLK	5
483#define VKI_F_SETLK	6
484#define VKI_F_SETLKW	7
485
486#define VKI_F_SETOWN	8	/*  for sockets. */
487#define VKI_F_GETOWN	9	/*  for sockets. */
488#define VKI_F_SETSIG	10	/*  for sockets. */
489#define VKI_F_GETSIG	11	/*  for sockets. */
490
491#define VKI_F_GETLK64	12	/*  using 'struct flock64' */
492#define VKI_F_SETLK64	13
493#define VKI_F_SETLKW64	14
494
495/* for F_[GET|SET]FL */
496#define VKI_FD_CLOEXEC	1	/* actually anything with low bit set goes */
497
498#define VKI_F_LINUX_SPECIFIC_BASE	1024
499
500//----------------------------------------------------------------------
501// From linux-2.6.9/include/asm-arm/resource.h
502//----------------------------------------------------------------------
503
504#define VKI_RLIMIT_DATA		2	/* max data size */
505#define VKI_RLIMIT_STACK	3	/* max stack size */
506#define VKI_RLIMIT_CORE		4	/* max core file size */
507#define VKI_RLIMIT_NOFILE	7	/* max number of open files */
508
509//----------------------------------------------------------------------
510// From linux-2.6.9/include/asm-arm/socket.h
511//----------------------------------------------------------------------
512
513#define VKI_SOL_SOCKET	1
514
515#define VKI_SO_TYPE	3
516
517//----------------------------------------------------------------------
518// From linux-2.6.9/include/asm-arm/sockios.h
519//----------------------------------------------------------------------
520
521#define VKI_SIOCSPGRP	0x8902
522#define VKI_SIOCGPGRP	0x8904
523#define VKI_SIOCGSTAMP	0x8906		/* Get stamp */
524
525//----------------------------------------------------------------------
526// From linux-2.6.9/include/asm-arm/stat.h
527//----------------------------------------------------------------------
528
529// [[Nb: resolved some #ifdefs by assuming __ARMEB__ is false, ie. that
530// we're not big-endian.]]
531struct vki_stat {
532	unsigned long  st_dev;
533	unsigned long  st_ino;
534	unsigned short st_mode;
535	unsigned short st_nlink;
536	unsigned short st_uid;
537	unsigned short st_gid;
538	unsigned long  st_rdev;
539	unsigned long  st_size;
540	unsigned long  st_blksize;
541	unsigned long  st_blocks;
542	unsigned long  st_atime;
543	unsigned long  st_atime_nsec;
544	unsigned long  st_mtime;
545	unsigned long  st_mtime_nsec;
546	unsigned long  st_ctime;
547	unsigned long  st_ctime_nsec;
548	unsigned long  __unused4;
549	unsigned long  __unused5;
550};
551
552struct vki_stat64 {
553	unsigned long long	st_dev;
554	unsigned char   __pad0[4];
555
556#define STAT64_HAS_BROKEN_ST_INO	1
557	unsigned long	__st_ino;
558	unsigned int	st_mode;
559	unsigned int	st_nlink;
560
561	unsigned long	st_uid;
562	unsigned long	st_gid;
563
564	unsigned long long	st_rdev;
565	unsigned char   __pad3[4];
566
567	long long	st_size;
568	unsigned long	st_blksize;
569
570	unsigned long   st_blocks;	/* Number 512-byte blocks allocated. */
571	unsigned long   __pad4;		/* Future possible st_blocks hi bits */
572
573	unsigned long	st_atime;
574	unsigned long	st_atime_nsec;
575
576	unsigned long	st_mtime;
577	unsigned long	st_mtime_nsec;
578
579	unsigned long	st_ctime;
580	unsigned long	st_ctime_nsec;
581
582	unsigned long long	st_ino;
583};
584
585//----------------------------------------------------------------------
586// From linux-2.6.9/include/asm-arm/statfs.h
587//----------------------------------------------------------------------
588
589// [[Nb: asm-arm/statfs.h just #include asm-generic/statfs.h directly]]
590struct vki_statfs {
591	__vki_u32 f_type;
592	__vki_u32 f_bsize;
593	__vki_u32 f_blocks;
594	__vki_u32 f_bfree;
595	__vki_u32 f_bavail;
596	__vki_u32 f_files;
597	__vki_u32 f_ffree;
598	__vki_kernel_fsid_t f_fsid;
599	__vki_u32 f_namelen;
600	__vki_u32 f_frsize;
601	__vki_u32 f_spare[5];
602};
603
604//----------------------------------------------------------------------
605// From linux-2.6.9/include/asm-arm/termios.h
606//----------------------------------------------------------------------
607
608struct vki_winsize {
609	unsigned short ws_row;
610	unsigned short ws_col;
611	unsigned short ws_xpixel;
612	unsigned short ws_ypixel;
613};
614
615#define VKI_NCC 8
616struct vki_termio {
617	unsigned short c_iflag;		/* input mode flags */
618	unsigned short c_oflag;		/* output mode flags */
619	unsigned short c_cflag;		/* control mode flags */
620	unsigned short c_lflag;		/* local mode flags */
621	unsigned char c_line;		/* line discipline */
622	unsigned char c_cc[VKI_NCC];	/* control characters */
623};
624
625//----------------------------------------------------------------------
626// From linux-2.6.9/include/asm-arm/termbits.h
627//----------------------------------------------------------------------
628
629typedef unsigned char   vki_cc_t;
630typedef unsigned int    vki_tcflag_t;
631
632#define VKI_NCCS 19
633struct vki_termios {
634	vki_tcflag_t c_iflag;		/* input mode flags */
635	vki_tcflag_t c_oflag;		/* output mode flags */
636	vki_tcflag_t c_cflag;		/* control mode flags */
637	vki_tcflag_t c_lflag;		/* local mode flags */
638	vki_cc_t c_line;		/* line discipline */
639	vki_cc_t c_cc[VKI_NCCS];	/* control characters */
640};
641
642//----------------------------------------------------------------------
643// From linux-2.6.9/include/asm-arm/ioctl.h
644//----------------------------------------------------------------------
645
646#define _VKI_IOC_NRBITS		8
647#define _VKI_IOC_TYPEBITS	8
648#define _VKI_IOC_SIZEBITS	14
649#define _VKI_IOC_DIRBITS	2
650
651#define _VKI_IOC_SIZEMASK	((1 << _VKI_IOC_SIZEBITS)-1)
652#define _VKI_IOC_DIRMASK	((1 << _VKI_IOC_DIRBITS)-1)
653
654#define _VKI_IOC_NRSHIFT	0
655#define _VKI_IOC_TYPESHIFT	(_VKI_IOC_NRSHIFT+_VKI_IOC_NRBITS)
656#define _VKI_IOC_SIZESHIFT	(_VKI_IOC_TYPESHIFT+_VKI_IOC_TYPEBITS)
657#define _VKI_IOC_DIRSHIFT	(_VKI_IOC_SIZESHIFT+_VKI_IOC_SIZEBITS)
658
659#define _VKI_IOC_NONE	0U
660#define _VKI_IOC_WRITE	1U
661#define _VKI_IOC_READ	2U
662
663#define _VKI_IOC(dir,type,nr,size) \
664	(((dir)  << _VKI_IOC_DIRSHIFT) | \
665	 ((type) << _VKI_IOC_TYPESHIFT) | \
666	 ((nr)   << _VKI_IOC_NRSHIFT) | \
667	 ((size) << _VKI_IOC_SIZESHIFT))
668
669/* used to create numbers */
670#define _VKI_IO(type,nr)	_VKI_IOC(_VKI_IOC_NONE,(type),(nr),0)
671#define _VKI_IOR(type,nr,size)	_VKI_IOC(_VKI_IOC_READ,(type),(nr),sizeof(size))
672#define _VKI_IOW(type,nr,size)	_VKI_IOC(_VKI_IOC_WRITE,(type),(nr),sizeof(size))
673#define _VKI_IOWR(type,nr,size)	_VKI_IOC(_VKI_IOC_READ|_VKI_IOC_WRITE,(type),(nr),sizeof(size))
674
675/* used to decode ioctl numbers.. */
676#define _VKI_IOC_DIR(nr)	(((nr) >> _VKI_IOC_DIRSHIFT) & _VKI_IOC_DIRMASK)
677#define _VKI_IOC_SIZE(nr)	(((nr) >> _VKI_IOC_SIZESHIFT) & _VKI_IOC_SIZEMASK)
678
679//----------------------------------------------------------------------
680// From linux-2.6.9/include/asm-arm/ioctls.h
681//----------------------------------------------------------------------
682
683#define VKI_TCGETS	0x5401
684#define VKI_TCSETS	0x5402
685#define VKI_TCSETSW	0x5403
686#define VKI_TCSETSF	0x5404
687#define VKI_TCGETA	0x5405
688#define VKI_TCSETA	0x5406
689#define VKI_TCSETAW	0x5407
690#define VKI_TCSETAF	0x5408
691#define VKI_TCSBRK	0x5409
692#define VKI_TCXONC	0x540A
693#define VKI_TCFLSH	0x540B
694#define VKI_TIOCSCTTY	0x540E
695#define VKI_TIOCGPGRP	0x540F
696#define VKI_TIOCSPGRP	0x5410
697#define VKI_TIOCOUTQ	0x5411
698#define VKI_TIOCGWINSZ	0x5413
699#define VKI_TIOCSWINSZ	0x5414
700#define VKI_TIOCMBIS	0x5416
701#define VKI_TIOCMBIC	0x5417
702#define VKI_TIOCMSET	0x5418
703#define VKI_FIONREAD	0x541B
704#define VKI_TIOCLINUX	0x541C
705#define VKI_FIONBIO	0x5421
706#define VKI_TCSBRKP	0x5425	/* Needed for POSIX tcsendbreak() */
707#define VKI_TIOCGPTN	_VKI_IOR('T',0x30, unsigned int) /* Get Pty Number (of pty-mux device) */
708#define VKI_TIOCSPTLCK	_VKI_IOW('T',0x31, int)  /* Lock/unlock Pty */
709
710#define VKI_FIOASYNC	0x5452
711
712//----------------------------------------------------------------------
713// From linux-2.6.9/include/asm-arm/poll.h
714//----------------------------------------------------------------------
715
716#define VKI_POLLIN	0x0001
717
718struct vki_pollfd {
719	int fd;
720	short events;
721	short revents;
722};
723
724//----------------------------------------------------------------------
725// From linux-2.6.9/include/asm-arm/user.h
726//----------------------------------------------------------------------
727
728// XXX: For x86, had here:
729//   struct vki_user_i387_struct
730//   struct vki_user_fxsr_struct
731//   struct vki_user_regs_struct
732
733//----------------------------------------------------------------------
734// From linux-2.6.9/include/asm-arm/ptrace.h
735//----------------------------------------------------------------------
736
737struct vki_pt_regs {
738	long uregs[18];
739};
740
741//----------------------------------------------------------------------
742// From linux-2.6.9/include/asm-arm/elf.h
743//----------------------------------------------------------------------
744
745typedef unsigned long vki_elf_greg_t;
746
747#define VKI_ELF_NGREG (sizeof (struct vki_pt_regs) / sizeof(vki_elf_greg_t))
748typedef vki_elf_greg_t vki_elf_gregset_t[VKI_ELF_NGREG];
749
750//----------------------------------------------------------------------
751// From linux-2.6.9/include/asm-arm/ucontext.h
752//----------------------------------------------------------------------
753
754struct vki_ucontext {
755	unsigned long		uc_flags;
756	struct vki_ucontext    *uc_link;
757	vki_stack_t		uc_stack;
758	struct vki_sigcontext	uc_mcontext;
759	vki_sigset_t		uc_sigmask;	/* mask last for extensibility */
760};
761
762//----------------------------------------------------------------------
763// From linux-2.6.9/include/asm-arm/ipcbuf.h
764//----------------------------------------------------------------------
765
766struct vki_ipc64_perm
767{
768	__vki_kernel_key_t	key;
769	__vki_kernel_uid32_t	uid;
770	__vki_kernel_gid32_t	gid;
771	__vki_kernel_uid32_t	cuid;
772	__vki_kernel_gid32_t	cgid;
773	__vki_kernel_mode_t	mode;
774	unsigned short		__pad1;
775	unsigned short		seq;
776	unsigned short		__pad2;
777	unsigned long		__unused1;
778	unsigned long		__unused2;
779};
780
781//----------------------------------------------------------------------
782// From linux-2.6.9/include/asm-arm/sembuf.h
783//----------------------------------------------------------------------
784
785struct vki_semid64_ds {
786	struct vki_ipc64_perm sem_perm;		/* permissions .. see ipc.h */
787	__vki_kernel_time_t	sem_otime;		/* last semop time */
788	unsigned long	__unused1;
789	__vki_kernel_time_t	sem_ctime;		/* last change time */
790	unsigned long	__unused2;
791	unsigned long	sem_nsems;		/* no. of semaphores in array */
792	unsigned long	__unused3;
793	unsigned long	__unused4;
794};
795
796
797//----------------------------------------------------------------------
798// From linux-2.6.9/include/asm-arm/msgbuf.h
799//----------------------------------------------------------------------
800
801struct vki_msqid64_ds {
802	struct vki_ipc64_perm msg_perm;
803	__vki_kernel_time_t msg_stime;	/* last msgsnd time */
804	unsigned long	__unused1;
805	__vki_kernel_time_t msg_rtime;	/* last msgrcv time */
806	unsigned long	__unused2;
807	__vki_kernel_time_t msg_ctime;	/* last change time */
808	unsigned long	__unused3;
809	unsigned long  msg_cbytes;	/* current number of bytes on queue */
810	unsigned long  msg_qnum;	/* number of messages in queue */
811	unsigned long  msg_qbytes;	/* max number of bytes on queue */
812	__vki_kernel_pid_t msg_lspid;	/* pid of last msgsnd */
813	__vki_kernel_pid_t msg_lrpid;	/* last receive pid */
814	unsigned long  __unused4;
815	unsigned long  __unused5;
816};
817
818//----------------------------------------------------------------------
819// From linux-2.6.9/include/asm-arm/ipc.h
820//----------------------------------------------------------------------
821
822struct vki_ipc_kludge {
823	struct vki_msgbuf __user *msgp;
824	long msgtyp;
825};
826
827//----------------------------------------------------------------------
828// From linux-2.6.9/include/asm-arm/shmbuf.h
829//----------------------------------------------------------------------
830
831struct vki_shmid64_ds {
832	struct vki_ipc64_perm	shm_perm;	/* operation perms */
833	vki_size_t		shm_segsz;	/* size of segment (bytes) */
834	__vki_kernel_time_t	shm_atime;	/* last attach time */
835	unsigned long		__unused1;
836	__vki_kernel_time_t	shm_dtime;	/* last detach time */
837	unsigned long		__unused2;
838	__vki_kernel_time_t	shm_ctime;	/* last change time */
839	unsigned long		__unused3;
840	__vki_kernel_pid_t	shm_cpid;	/* pid of creator */
841	__vki_kernel_pid_t	shm_lpid;	/* pid of last operator */
842	unsigned long		shm_nattch;	/* no. of current attaches */
843	unsigned long		__unused4;
844	unsigned long		__unused5;
845};
846
847struct vki_shminfo64 {
848	unsigned long	shmmax;
849	unsigned long	shmmin;
850	unsigned long	shmmni;
851	unsigned long	shmseg;
852	unsigned long	shmall;
853	unsigned long	__unused1;
854	unsigned long	__unused2;
855	unsigned long	__unused3;
856	unsigned long	__unused4;
857};
858
859//----------------------------------------------------------------------
860// And that's it!
861//----------------------------------------------------------------------
862
863#endif // __VKI_ARM_LINUX_H
864
865/*--------------------------------------------------------------------*/
866/*--- end                                                          ---*/
867/*--------------------------------------------------------------------*/
868
869=============================================================================
870All of coregrind/vki_unistd-arm-linux.h
871=============================================================================
872
873/*
874   This file is part of Valgrind, a dynamic binary instrumentation
875   framework.
876
877   Copyright (C) 2000-2005 Julian Seward
878      jseward@acm.org
879
880   This program is free software; you can redistribute it and/or
881   modify it under the terms of the GNU General Public License as
882   published by the Free Software Foundation; either version 2 of the
883   License, or (at your option) any later version.
884
885   This program is distributed in the hope that it will be useful, but
886   WITHOUT ANY WARRANTY; without even the implied warranty of
887   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
888   General Public License for more details.
889
890   You should have received a copy of the GNU General Public License
891   along with this program; if not, write to the Free Software
892   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
893   02111-1307, USA.
894
895   The GNU General Public License is contained in the file COPYING.
896*/
897
898#ifndef __VKI_UNISTD_ARM_LINUX_H
899#define __VKI_UNISTD_ARM_LINUX_H
900
901// From linux-2.6.8.1/include/asm-arm/unistd.h
902
903// Nb: ARM Thumb has a different __NR_SYSCALL_BASE, but we don't care about
904//     that architecture.
905#define __NR_SYSCALL_BASE	0x900000
906
907#define __NR_restart_syscall		(__NR_SYSCALL_BASE+  0)
908#define __NR_exit			(__NR_SYSCALL_BASE+  1)
909#define __NR_fork			(__NR_SYSCALL_BASE+  2)
910#define __NR_read			(__NR_SYSCALL_BASE+  3)
911#define __NR_write			(__NR_SYSCALL_BASE+  4)
912#define __NR_open			(__NR_SYSCALL_BASE+  5)
913#define __NR_close			(__NR_SYSCALL_BASE+  6)
914					/* 7 was sys_waitpid */
915#define __NR_creat			(__NR_SYSCALL_BASE+  8)
916#define __NR_link			(__NR_SYSCALL_BASE+  9)
917#define __NR_unlink			(__NR_SYSCALL_BASE+ 10)
918#define __NR_execve			(__NR_SYSCALL_BASE+ 11)
919#define __NR_chdir			(__NR_SYSCALL_BASE+ 12)
920#define __NR_time			(__NR_SYSCALL_BASE+ 13)
921#define __NR_mknod			(__NR_SYSCALL_BASE+ 14)
922#define __NR_chmod			(__NR_SYSCALL_BASE+ 15)
923#define __NR_lchown			(__NR_SYSCALL_BASE+ 16)
924					/* 17 was sys_break */
925					/* 18 was sys_stat */
926#define __NR_lseek			(__NR_SYSCALL_BASE+ 19)
927#define __NR_getpid			(__NR_SYSCALL_BASE+ 20)
928#define __NR_mount			(__NR_SYSCALL_BASE+ 21)
929#define __NR_umount			(__NR_SYSCALL_BASE+ 22)
930#define __NR_setuid			(__NR_SYSCALL_BASE+ 23)
931#define __NR_getuid			(__NR_SYSCALL_BASE+ 24)
932#define __NR_stime			(__NR_SYSCALL_BASE+ 25)
933#define __NR_ptrace			(__NR_SYSCALL_BASE+ 26)
934#define __NR_alarm			(__NR_SYSCALL_BASE+ 27)
935					/* 28 was sys_fstat */
936#define __NR_pause			(__NR_SYSCALL_BASE+ 29)
937#define __NR_utime			(__NR_SYSCALL_BASE+ 30)
938					/* 31 was sys_stty */
939					/* 32 was sys_gtty */
940#define __NR_access			(__NR_SYSCALL_BASE+ 33)
941#define __NR_nice			(__NR_SYSCALL_BASE+ 34)
942					/* 35 was sys_ftime */
943#define __NR_sync			(__NR_SYSCALL_BASE+ 36)
944#define __NR_kill			(__NR_SYSCALL_BASE+ 37)
945#define __NR_rename			(__NR_SYSCALL_BASE+ 38)
946#define __NR_mkdir			(__NR_SYSCALL_BASE+ 39)
947#define __NR_rmdir			(__NR_SYSCALL_BASE+ 40)
948#define __NR_dup			(__NR_SYSCALL_BASE+ 41)
949#define __NR_pipe			(__NR_SYSCALL_BASE+ 42)
950#define __NR_times			(__NR_SYSCALL_BASE+ 43)
951					/* 44 was sys_prof */
952#define __NR_brk			(__NR_SYSCALL_BASE+ 45)
953#define __NR_setgid			(__NR_SYSCALL_BASE+ 46)
954#define __NR_getgid			(__NR_SYSCALL_BASE+ 47)
955					/* 48 was sys_signal */
956#define __NR_geteuid			(__NR_SYSCALL_BASE+ 49)
957#define __NR_getegid			(__NR_SYSCALL_BASE+ 50)
958#define __NR_acct			(__NR_SYSCALL_BASE+ 51)
959#define __NR_umount2			(__NR_SYSCALL_BASE+ 52)
960					/* 53 was sys_lock */
961#define __NR_ioctl			(__NR_SYSCALL_BASE+ 54)
962#define __NR_fcntl			(__NR_SYSCALL_BASE+ 55)
963					/* 56 was sys_mpx */
964#define __NR_setpgid			(__NR_SYSCALL_BASE+ 57)
965					/* 58 was sys_ulimit */
966					/* 59 was sys_olduname */
967#define __NR_umask			(__NR_SYSCALL_BASE+ 60)
968#define __NR_chroot			(__NR_SYSCALL_BASE+ 61)
969#define __NR_ustat			(__NR_SYSCALL_BASE+ 62)
970#define __NR_dup2			(__NR_SYSCALL_BASE+ 63)
971#define __NR_getppid			(__NR_SYSCALL_BASE+ 64)
972#define __NR_getpgrp			(__NR_SYSCALL_BASE+ 65)
973#define __NR_setsid			(__NR_SYSCALL_BASE+ 66)
974#define __NR_sigaction			(__NR_SYSCALL_BASE+ 67)
975					/* 68 was sys_sgetmask */
976					/* 69 was sys_ssetmask */
977#define __NR_setreuid			(__NR_SYSCALL_BASE+ 70)
978#define __NR_setregid			(__NR_SYSCALL_BASE+ 71)
979#define __NR_sigsuspend			(__NR_SYSCALL_BASE+ 72)
980#define __NR_sigpending			(__NR_SYSCALL_BASE+ 73)
981#define __NR_sethostname		(__NR_SYSCALL_BASE+ 74)
982#define __NR_setrlimit			(__NR_SYSCALL_BASE+ 75)
983#define __NR_getrlimit			(__NR_SYSCALL_BASE+ 76)	/* Back compat 2GB limited rlimit */
984#define __NR_getrusage			(__NR_SYSCALL_BASE+ 77)
985#define __NR_gettimeofday		(__NR_SYSCALL_BASE+ 78)
986#define __NR_settimeofday		(__NR_SYSCALL_BASE+ 79)
987#define __NR_getgroups			(__NR_SYSCALL_BASE+ 80)
988#define __NR_setgroups			(__NR_SYSCALL_BASE+ 81)
989#define __NR_select			(__NR_SYSCALL_BASE+ 82)
990#define __NR_symlink			(__NR_SYSCALL_BASE+ 83)
991					/* 84 was sys_lstat */
992#define __NR_readlink			(__NR_SYSCALL_BASE+ 85)
993#define __NR_uselib			(__NR_SYSCALL_BASE+ 86)
994#define __NR_swapon			(__NR_SYSCALL_BASE+ 87)
995#define __NR_reboot			(__NR_SYSCALL_BASE+ 88)
996#define __NR_readdir			(__NR_SYSCALL_BASE+ 89)
997#define __NR_mmap			(__NR_SYSCALL_BASE+ 90)
998#define __NR_munmap			(__NR_SYSCALL_BASE+ 91)
999#define __NR_truncate			(__NR_SYSCALL_BASE+ 92)
1000#define __NR_ftruncate			(__NR_SYSCALL_BASE+ 93)
1001#define __NR_fchmod			(__NR_SYSCALL_BASE+ 94)
1002#define __NR_fchown			(__NR_SYSCALL_BASE+ 95)
1003#define __NR_getpriority		(__NR_SYSCALL_BASE+ 96)
1004#define __NR_setpriority		(__NR_SYSCALL_BASE+ 97)
1005					/* 98 was sys_profil */
1006#define __NR_statfs			(__NR_SYSCALL_BASE+ 99)
1007#define __NR_fstatfs			(__NR_SYSCALL_BASE+100)
1008					/* 101 was sys_ioperm */
1009#define __NR_socketcall			(__NR_SYSCALL_BASE+102)
1010#define __NR_syslog			(__NR_SYSCALL_BASE+103)
1011#define __NR_setitimer			(__NR_SYSCALL_BASE+104)
1012#define __NR_getitimer			(__NR_SYSCALL_BASE+105)
1013#define __NR_stat			(__NR_SYSCALL_BASE+106)
1014#define __NR_lstat			(__NR_SYSCALL_BASE+107)
1015#define __NR_fstat			(__NR_SYSCALL_BASE+108)
1016					/* 109 was sys_uname */
1017					/* 110 was sys_iopl */
1018#define __NR_vhangup			(__NR_SYSCALL_BASE+111)
1019					/* 112 was sys_idle */
1020#define __NR_syscall			(__NR_SYSCALL_BASE+113) /* syscall to call a syscall! */
1021#define __NR_wait4			(__NR_SYSCALL_BASE+114)
1022#define __NR_swapoff			(__NR_SYSCALL_BASE+115)
1023#define __NR_sysinfo			(__NR_SYSCALL_BASE+116)
1024#define __NR_ipc			(__NR_SYSCALL_BASE+117)
1025#define __NR_fsync			(__NR_SYSCALL_BASE+118)
1026#define __NR_sigreturn			(__NR_SYSCALL_BASE+119)
1027#define __NR_clone			(__NR_SYSCALL_BASE+120)
1028#define __NR_setdomainname		(__NR_SYSCALL_BASE+121)
1029#define __NR_uname			(__NR_SYSCALL_BASE+122)
1030					/* 123 was sys_modify_ldt */
1031#define __NR_adjtimex			(__NR_SYSCALL_BASE+124)
1032#define __NR_mprotect			(__NR_SYSCALL_BASE+125)
1033#define __NR_sigprocmask		(__NR_SYSCALL_BASE+126)
1034					/* 127 was sys_create_module */
1035#define __NR_init_module		(__NR_SYSCALL_BASE+128)
1036#define __NR_delete_module		(__NR_SYSCALL_BASE+129)
1037					/* 130 was sys_get_kernel_syms */
1038#define __NR_quotactl			(__NR_SYSCALL_BASE+131)
1039#define __NR_getpgid			(__NR_SYSCALL_BASE+132)
1040#define __NR_fchdir			(__NR_SYSCALL_BASE+133)
1041#define __NR_bdflush			(__NR_SYSCALL_BASE+134)
1042#define __NR_sysfs			(__NR_SYSCALL_BASE+135)
1043#define __NR_personality		(__NR_SYSCALL_BASE+136)
1044					/* 137 was sys_afs_syscall */
1045#define __NR_setfsuid			(__NR_SYSCALL_BASE+138)
1046#define __NR_setfsgid			(__NR_SYSCALL_BASE+139)
1047#define __NR__llseek			(__NR_SYSCALL_BASE+140)
1048#define __NR_getdents			(__NR_SYSCALL_BASE+141)
1049#define __NR__newselect			(__NR_SYSCALL_BASE+142)
1050#define __NR_flock			(__NR_SYSCALL_BASE+143)
1051#define __NR_msync			(__NR_SYSCALL_BASE+144)
1052#define __NR_readv			(__NR_SYSCALL_BASE+145)
1053#define __NR_writev			(__NR_SYSCALL_BASE+146)
1054#define __NR_getsid			(__NR_SYSCALL_BASE+147)
1055#define __NR_fdatasync			(__NR_SYSCALL_BASE+148)
1056#define __NR__sysctl			(__NR_SYSCALL_BASE+149)
1057#define __NR_mlock			(__NR_SYSCALL_BASE+150)
1058#define __NR_munlock			(__NR_SYSCALL_BASE+151)
1059#define __NR_mlockall			(__NR_SYSCALL_BASE+152)
1060#define __NR_munlockall			(__NR_SYSCALL_BASE+153)
1061#define __NR_sched_setparam		(__NR_SYSCALL_BASE+154)
1062#define __NR_sched_getparam		(__NR_SYSCALL_BASE+155)
1063#define __NR_sched_setscheduler		(__NR_SYSCALL_BASE+156)
1064#define __NR_sched_getscheduler		(__NR_SYSCALL_BASE+157)
1065#define __NR_sched_yield		(__NR_SYSCALL_BASE+158)
1066#define __NR_sched_get_priority_max	(__NR_SYSCALL_BASE+159)
1067#define __NR_sched_get_priority_min	(__NR_SYSCALL_BASE+160)
1068#define __NR_sched_rr_get_interval	(__NR_SYSCALL_BASE+161)
1069#define __NR_nanosleep			(__NR_SYSCALL_BASE+162)
1070#define __NR_mremap			(__NR_SYSCALL_BASE+163)
1071#define __NR_setresuid			(__NR_SYSCALL_BASE+164)
1072#define __NR_getresuid			(__NR_SYSCALL_BASE+165)
1073					/* 166 was sys_vm86 */
1074					/* 167 was sys_query_module */
1075#define __NR_poll			(__NR_SYSCALL_BASE+168)
1076#define __NR_nfsservctl			(__NR_SYSCALL_BASE+169)
1077#define __NR_setresgid			(__NR_SYSCALL_BASE+170)
1078#define __NR_getresgid			(__NR_SYSCALL_BASE+171)
1079#define __NR_prctl			(__NR_SYSCALL_BASE+172)
1080#define __NR_rt_sigreturn		(__NR_SYSCALL_BASE+173)
1081#define __NR_rt_sigaction		(__NR_SYSCALL_BASE+174)
1082#define __NR_rt_sigprocmask		(__NR_SYSCALL_BASE+175)
1083#define __NR_rt_sigpending		(__NR_SYSCALL_BASE+176)
1084#define __NR_rt_sigtimedwait		(__NR_SYSCALL_BASE+177)
1085#define __NR_rt_sigqueueinfo		(__NR_SYSCALL_BASE+178)
1086#define __NR_rt_sigsuspend		(__NR_SYSCALL_BASE+179)
1087#define __NR_pread64			(__NR_SYSCALL_BASE+180)
1088#define __NR_pwrite64			(__NR_SYSCALL_BASE+181)
1089#define __NR_chown			(__NR_SYSCALL_BASE+182)
1090#define __NR_getcwd			(__NR_SYSCALL_BASE+183)
1091#define __NR_capget			(__NR_SYSCALL_BASE+184)
1092#define __NR_capset			(__NR_SYSCALL_BASE+185)
1093#define __NR_sigaltstack		(__NR_SYSCALL_BASE+186)
1094#define __NR_sendfile			(__NR_SYSCALL_BASE+187)
1095					/* 188 reserved */
1096					/* 189 reserved */
1097#define __NR_vfork			(__NR_SYSCALL_BASE+190)
1098#define __NR_ugetrlimit			(__NR_SYSCALL_BASE+191)	/* SuS compliant getrlimit */
1099#define __NR_mmap2			(__NR_SYSCALL_BASE+192)
1100#define __NR_truncate64			(__NR_SYSCALL_BASE+193)
1101#define __NR_ftruncate64		(__NR_SYSCALL_BASE+194)
1102#define __NR_stat64			(__NR_SYSCALL_BASE+195)
1103#define __NR_lstat64			(__NR_SYSCALL_BASE+196)
1104#define __NR_fstat64			(__NR_SYSCALL_BASE+197)
1105#define __NR_lchown32			(__NR_SYSCALL_BASE+198)
1106#define __NR_getuid32			(__NR_SYSCALL_BASE+199)
1107#define __NR_getgid32			(__NR_SYSCALL_BASE+200)
1108#define __NR_geteuid32			(__NR_SYSCALL_BASE+201)
1109#define __NR_getegid32			(__NR_SYSCALL_BASE+202)
1110#define __NR_setreuid32			(__NR_SYSCALL_BASE+203)
1111#define __NR_setregid32			(__NR_SYSCALL_BASE+204)
1112#define __NR_getgroups32		(__NR_SYSCALL_BASE+205)
1113#define __NR_setgroups32		(__NR_SYSCALL_BASE+206)
1114#define __NR_fchown32			(__NR_SYSCALL_BASE+207)
1115#define __NR_setresuid32		(__NR_SYSCALL_BASE+208)
1116#define __NR_getresuid32		(__NR_SYSCALL_BASE+209)
1117#define __NR_setresgid32		(__NR_SYSCALL_BASE+210)
1118#define __NR_getresgid32		(__NR_SYSCALL_BASE+211)
1119#define __NR_chown32			(__NR_SYSCALL_BASE+212)
1120#define __NR_setuid32			(__NR_SYSCALL_BASE+213)
1121#define __NR_setgid32			(__NR_SYSCALL_BASE+214)
1122#define __NR_setfsuid32			(__NR_SYSCALL_BASE+215)
1123#define __NR_setfsgid32			(__NR_SYSCALL_BASE+216)
1124#define __NR_getdents64			(__NR_SYSCALL_BASE+217)
1125#define __NR_pivot_root			(__NR_SYSCALL_BASE+218)
1126#define __NR_mincore			(__NR_SYSCALL_BASE+219)
1127#define __NR_madvise			(__NR_SYSCALL_BASE+220)
1128#define __NR_fcntl64			(__NR_SYSCALL_BASE+221)
1129					/* 222 for tux */
1130					/* 223 is unused */
1131#define __NR_gettid			(__NR_SYSCALL_BASE+224)
1132#define __NR_readahead			(__NR_SYSCALL_BASE+225)
1133#define __NR_setxattr			(__NR_SYSCALL_BASE+226)
1134#define __NR_lsetxattr			(__NR_SYSCALL_BASE+227)
1135#define __NR_fsetxattr			(__NR_SYSCALL_BASE+228)
1136#define __NR_getxattr			(__NR_SYSCALL_BASE+229)
1137#define __NR_lgetxattr			(__NR_SYSCALL_BASE+230)
1138#define __NR_fgetxattr			(__NR_SYSCALL_BASE+231)
1139#define __NR_listxattr			(__NR_SYSCALL_BASE+232)
1140#define __NR_llistxattr			(__NR_SYSCALL_BASE+233)
1141#define __NR_flistxattr			(__NR_SYSCALL_BASE+234)
1142#define __NR_removexattr		(__NR_SYSCALL_BASE+235)
1143#define __NR_lremovexattr		(__NR_SYSCALL_BASE+236)
1144#define __NR_fremovexattr		(__NR_SYSCALL_BASE+237)
1145#define __NR_tkill			(__NR_SYSCALL_BASE+238)
1146#define __NR_sendfile64			(__NR_SYSCALL_BASE+239)
1147#define __NR_futex			(__NR_SYSCALL_BASE+240)
1148#define __NR_sched_setaffinity		(__NR_SYSCALL_BASE+241)
1149#define __NR_sched_getaffinity		(__NR_SYSCALL_BASE+242)
1150#define __NR_io_setup			(__NR_SYSCALL_BASE+243)
1151#define __NR_io_destroy			(__NR_SYSCALL_BASE+244)
1152#define __NR_io_getevents		(__NR_SYSCALL_BASE+245)
1153#define __NR_io_submit			(__NR_SYSCALL_BASE+246)
1154#define __NR_io_cancel			(__NR_SYSCALL_BASE+247)
1155#define __NR_exit_group			(__NR_SYSCALL_BASE+248)
1156#define __NR_lookup_dcookie		(__NR_SYSCALL_BASE+249)
1157#define __NR_epoll_create		(__NR_SYSCALL_BASE+250)
1158#define __NR_epoll_ctl			(__NR_SYSCALL_BASE+251)
1159#define __NR_epoll_wait			(__NR_SYSCALL_BASE+252)
1160#define __NR_remap_file_pages		(__NR_SYSCALL_BASE+253)
1161					/* 254 for set_thread_area */
1162					/* 255 for get_thread_area */
1163					/* 256 for set_tid_address */
1164#define __NR_timer_create		(__NR_SYSCALL_BASE+257)
1165#define __NR_timer_settime		(__NR_SYSCALL_BASE+258)
1166#define __NR_timer_gettime		(__NR_SYSCALL_BASE+259)
1167#define __NR_timer_getoverrun		(__NR_SYSCALL_BASE+260)
1168#define __NR_timer_delete		(__NR_SYSCALL_BASE+261)
1169#define __NR_clock_settime		(__NR_SYSCALL_BASE+262)
1170#define __NR_clock_gettime		(__NR_SYSCALL_BASE+263)
1171#define __NR_clock_getres		(__NR_SYSCALL_BASE+264)
1172#define __NR_clock_nanosleep		(__NR_SYSCALL_BASE+265)
1173#define __NR_statfs64			(__NR_SYSCALL_BASE+266)
1174#define __NR_fstatfs64			(__NR_SYSCALL_BASE+267)
1175#define __NR_tgkill			(__NR_SYSCALL_BASE+268)
1176#define __NR_utimes			(__NR_SYSCALL_BASE+269)
1177#define __NR_fadvise64_64		(__NR_SYSCALL_BASE+270)
1178#define __NR_pciconfig_iobase		(__NR_SYSCALL_BASE+271)
1179#define __NR_pciconfig_read		(__NR_SYSCALL_BASE+272)
1180#define __NR_pciconfig_write		(__NR_SYSCALL_BASE+273)
1181
1182#endif /* __VKI_UNISTD_ARM_LINUX_H */
1183
1184