blob: a2d4cce0bda0d8e843af688cb14e4f961b388ccb [file] [log] [blame]
Dmitry V. Levin10de62b2006-12-13 21:45:31 +000012006-12-12 Dmitry V. Levin <ldv@altlinux.org>
2
3 Fix -ff -o behaviour. Fix piping trace output.
4 * defs.h (newoutf): Remove.
5 (alloctcb): Rename to alloc_tcb. Add alloctcb() macro wrapper
6 around alloc_tcb().
7 * process.c [!USE_PROCFS] (internal_clone, internal_fork):
8 Remove newoutf() call.
9 * strace.c (set_cloexec_flag, strace_fopen, strace_popen,
10 swap_uid): New functions.
11 (popen_pid): New variable.
12 (newoutf): Make static, use strace_fopen().
13 (main): Use strace_fopen() and strace_popen(), remove uids
14 swapping. Do not open outfname when followfork > 1.
15 Reinitialize tcp->outf properly.
16 (alloctcb): Rename to alloc_tcb. Use newoutf().
17 (trace): Check popen_pid. Remove newoutf() call.
18 [USE_PROCFS] (proc_open, proc_poll_open): Use set_cloexec_flag().
19 Fixes RH#204950, RH#218435.
20
Dmitry V. Levinb9fe0112006-12-13 16:59:44 +0000212006-12-10 Dmitry V. Levin <ldv@altlinux.org>
22
Dmitry V. Levind3cb3922006-12-13 17:45:02 +000023 Add biarch support for "struct sigevent".
24 * time.c [LINUX && SUPPORTED_PERSONALITIES > 1] (printsigevent32):
25 New function.
26 [LINUX] (printsigevent): [SUPPORTED_PERSONALITIES > 1]
27 Handle 32-bit personality.
28
Dmitry V. Levin165b15d2006-12-13 17:43:45 +000029 Add biarch support for "struct timex".
30 * time.c [LINUX && SUPPORTED_PERSONALITIES > 1] (tprint_timex32):
31 New function.
32 [LINUX] (tprint_timex): New function.
33 [LINUX] (sys_adjtimex): Use it.
34
Dmitry V. Levin1a684d62006-12-13 17:42:32 +000035 Enhance adjtimex parser.
36 * time.c [LINUX] (adjtimex_modes, adjtimex_status,
37 adjtimex_state): New xlat structures.
38 [LINUX] (sys_adjtimex): Print the whole struct timex.
39 Decode modes, status and return code.
40
Dmitry V. Levin1cad25d2006-12-13 17:14:36 +000041 Add biarch support for "struct itimerval".
42 * time.c (printitv): Rename to printitv_bitness().
43 Add printitv() macro wrapper around printitv_bitness().
44 (printitv_bitness): Handle 32-bit personality.
45 [ALPHA] (sys_osf_getitimer, sys_osf_setitimer):
46 Use printitv_bitness().
47 (tprint_timeval, tprint_timeval32): New functions.
48 (printtv_bitness, printitv_bitness, sys_adjtimex): Use them.
49 (printitv32): Remove.
50
51 Add biarch support for "struct timeval".
52 * defs.h (bitness_t): New enum type.
53 (printtv_bitness, sprinttv): New function prototypes.
54 (printtv): Convert to macro wrapper around printtv_bitness().
55 (printtv32): Remove.
56 * desc.c (decode_select): Use printtv_bitness() and sprinttv().
57 (sys_oldselect, sys_osf_select, sys_select, sys_pselect6):
58 Update decode_select() use.
59 * file.c [ALPHA] (sys_osf_utimes): Use printtv_bitness().
60 * time.c (printtv_bitness, sprinttv): New functions.
61 (printtv, printtv32): Remove.
62 [ALPHA] (sys_osf_settimeofday, sys_osf_settimeofday):
63 Use printtv_bitness().
64 Fixes RH#171626, RH#173050.
65
Dmitry V. Levin4ebb4e32006-12-13 17:08:08 +000066 Add biarch support for "struct iovec".
67 * defs.h (personality_wordsize): Add.
68 * io.c [HAVE_SYS_UIO_H] (tprint_iov): [LINUX &&
69 SUPPORTED_PERSONALITIES > 1] Handle 32-bit personality.
70 * util.c [HAVE_SYS_UIO_H] (dumpiov): [LINUX &&
71 SUPPORTED_PERSONALITIES > 1] Likewise.
72 Patch from Jakub Jelinek.
73 Fixes RH#218433.
74
Dmitry V. Levinac518d12006-12-13 17:03:02 +000075 * time.c (sys_timer_create): Check umove() return code.
76
Dmitry V. Levinb9fe0112006-12-13 16:59:44 +000077 Make several global variables static.
78 #ifdef definitions of rarely unused functions.
79 * defs.h (rflag, tflag, outfname): Remove.
80 * strace.c (iflag, interactive, pflag_seen, rflag, tflag,
81 outfname, username): Make static.
82 * desc.c (sys_getdtablesize): Define only for
83 ALPHA || FREEBSD || SUNOS4.
84 * file.c (sys_fchroot): Define only for SUNOS4 || SVR4.
85 (sys_mkfifo): Define only for FREEBSD.
86 * mem.c (sys_sbrk): Define only for FREEBSD || SUNOS4.
87 (sys_getpagesize): Define only for
88 ALPHA || FREEBSD || IA64 || SUNOS4 || SVR4.
89 * net.c (sys_so_socket): Define only for SVR4.
90 * process.c (sys_gethostid): Define only for
91 FREEBSD || SUNOS4 || SVR4.
92 (sys_gethostname): Define only for
93 ALPHA || FREEBSD || SUNOS4 || SVR4.
94 (sys_setpgrp): Define only for ALPHA || SUNOS4 || SVR4.
95 (sys_execv): Define only for SPARC || SPARC64 || SUNOS4.
96 * signal.c (sys_sigblock): Define only for FREEBSD || SUNOS4.
97 (sys_sighold, sys_sigwait): Define only for SVR4.
98 (sys_killpg): Define only for FREEBSD || SUNOS4.
99 * stream.c (sys_getmsg): Define only for
100 SPARC || SPARC64 || SUNOS4 || SVR4.
101 * syscall.c (sys_indir): Define only for SUNOS4.
102
Dmitry V. Levin35a55782006-12-04 13:48:10 +00001032006-11-27 Dmitry V. Levin <ldv@altlinux.org>
104
105 * system.c [LINUX]: Define CTL_PROC, since Linux 2.6.18+ headers
106 removed CTL_PROC enum. Patch from Jakub Jelinek.
107 [LINUX] (sysctl_root): Add CTL_BUS, CTL_ABI and CTL_CPU.
108
Dmitry V. Levina6946662006-12-04 13:46:28 +00001092006-11-20 Jakub Jelinek <jakub@redhat.com>
110
111 * linux/ia64/syscallent.h: Add #if check to make sure that
112 SYS_socket_subcall adjustment isn't forgotten again.
113
Dmitry V. Levinef5c3d62006-10-16 00:26:47 +00001142006-10-16 Dmitry V. Levin <ldv@altlinux.org>
115
116 Implement comprehensive quotactl(2) parser for Linux.
117 * Makefile.am (strace_SOURCES): Add quota.c.
118 * quota.c: New file.
119 * resource.c: Remove old quotactl(2) parser.
120 Fixes RH#118696.
121
Dmitry V. Levincbd470f2006-10-14 14:23:57 +00001222006-10-14 Dmitry V. Levin <ldv@altlinux.org>
123
Dmitry V. Levin1f336e52006-10-14 20:20:46 +0000124 * configure.ac(AC_CHECK_HEADERS): Add inttypes.h.
125 * file.c [_LFS64_LARGEFILE && (LINUX || SVR4)]:
126 Include <inttypes.h>.
127 (sys_getdents64): Use PRIu64/PRId64 to avoid gcc warnings on
128 64-bit platforms.
129
Dmitry V. Levincbd470f2006-10-14 14:23:57 +0000130 * strace.c (main): Check getcwd() return code.
131
Dmitry V. Levin95ebf5a2006-10-13 20:25:12 +00001322006-10-13 Ulrich Drepper <drepper@redhat.com>
133 Bernhard Kaindl <bk@suse.de>
134 Dmitry V. Levin <ldv@altlinux.org>
135 Michael Holzheu <holzheu@de.ibm.com>
136
137 Add hooks for new syscalls. Add decoders for *at, inotify*,
138 pselect6, ppoll and unshare syscalls.
139
140 * defs.h: Declare print_sigset.
141 * desc.c (sys_pselect6): New function.
142 * file.c (decode_open, decode_access, decode_mkdir,
143 decode_readlink, decode_chmod, decode_utimes, decode_mknod):
144 New functions.
145 (sys_open, sys_access, sys_mkdir, sys_readlink, sys_chmod,
146 sys_utimes, sys_mknod): Use them.
147 [LINUX] (fstatatflags, unlinkatflags, inotify_modes): New
148 variables.
149 [LINUX] (print_dirfd, sys_openat, sys_faccessat,
150 sys_newfstatat, sys_mkdirat, sys_linkat, sys_unlinkat,
151 sys_symlinkat, sys_readlinkat, sys_renameat, sys_fchownat,
152 sys_fchmodat, sys_futimesat, sys_mknodat, sys_inotify_add_watch,
153 sys_inotify_rm_watch): New functions.
154 * process.c [LINUX] (sys_unshare): New function.
155 * signal.c (print_sigset): New function.
156 (sys_sigprocmask): Use it.
157 * stream.c (decode_poll): New function.
158 (sys_poll): Use it.
159 [LINUX] (sys_ppoll): New function.
160 * linux/syscall.h: Delcare new syscall handlers.
161 * linux/syscallent.h: Hook up new syscalls.
162 * linux/alpha/syscallent.h: Likewise.
163 * linux/hppa/syscallent.h: Likewise.
164 * linux/ia64/syscallent.h: Likewise.
165 * linux/mips/syscallent.h: Likewise.
166 * linux/powerpc/syscallent.h: Likewise.
167 * linux/s390/syscallent.h: Likewise.
168 * linux/s390x/syscallent.h: Likewise.
169 * linux/sparc/syscallent.h: Likewise.
170 * linux/sparc64/syscallent.h: Likewise.
171 * linux/x86_64/syscallent.h: Likewise.
172 Fixes RH#178633.
173
Dmitry V. Levin96339422006-10-11 23:11:43 +00001742006-10-06 Dmitry V. Levin <ldv@altlinux.org>
175
176 * strace.c [!USE_PROCFS] (trace): Presence of PT_GETSIGINFO
177 macro does not mean that PT_CR_IPSR and PT_CR_IIP macros are
178 also defined, so check them along with PT_GETSIGINFO.
179 Fixes RH#209856.
180
Dmitry V. Levin504eb0b2006-10-11 22:58:31 +00001812006-09-01 Dmitry V. Levin <ldv@altlinux.org>
182
183 * file.c (print_xattr_val): Fix memory corruption bug reported
184 by James Antill.
185 Fixes RH#200621.
186
Dmitry V. Levinaca9a742006-10-11 22:56:49 +00001872006-04-21 Dmitry V. Levin <ldv@altlinux.org>
188
189 * defs.h [LINUX && X86_64 && !__NR_exit_group]: Define
190 __NR_exit_group.
191
Dmitry V. Levin76860f62006-10-11 22:55:25 +00001922006-03-29 Dmitry V. Levin <ldv@altlinux.org>
193
194 Fix race conditions in tcb allocation.
195 * process.c (fork_tcb): Return error code as documented. Do not
196 print "tcb table full" error message.
197 [USE_PROCFS] (internal_fork): Do not print "tcb table full"
198 error message.
199 [SYS_clone || SYS_clone2] (internal_clone, internal_fork): Call
200 fork_tcb() before alloctcb(). Do not print "tcb table full"
201 error message.
202 * strace.c (main): Do not print "tcb table full" error message.
203 (expand_tcbtab): Print error message in case of memory allocation
204 failure.
205 (alloctcb): Print error message when tcb table is full.
206 (trace): Expand tcb table if necessary prior to allocating
207 entry there. Do not print "tcb table full" error message.
208 Fixes RH#180293.
209
Roland McGrathff87ae22006-08-22 07:37:00 +00002102006-08-22 Roland McGrath <roland@redhat.com>
211
212 * ipc.c (sys_msgget, sys_semget, sys_shmget): Show key values in hex.
213 Fixes RH#198179.
214
Roland McGrath6ef291b2006-08-22 06:06:24 +00002152006-08-21 Roland McGrath <roland@redhat.com>
216
217 * linux/syscall.h (SYS_socket_subcall): Bump to 400.
218 * linux/syscallent.h: Update table.
219 * linux/arm/syscallent.h: Likewise.
220 * linux/m68k/syscallent.h: Likewise.
221 * linux/s390/syscallent.h: Likewise.
222 * linux/s390x/syscallent.h: Likewise.
Roland McGrath71030012006-08-22 06:33:45 +0000223 * linux/powerpc/syscallent.h: Likewise.
224 * linux/sh/syscallent.h: Likewise.
225 * linux/sh64/syscallent.h: Likewise.
Roland McGrathfd52f8d2006-10-10 00:57:30 +0000226 Fixes RH#201462.
Roland McGrath6ef291b2006-08-22 06:06:24 +0000227
Roland McGrath23777062006-04-25 07:22:04 +00002282006-04-25 Roland McGrath <roland@redhat.com>
229
Roland McGrathde170102006-04-25 07:48:06 +0000230 * strace.c (main): Fail when -c is given with -ff.
231 * strace.1: Note their incompatibility.
232 Fixes RH#187847.
233
Roland McGrath5b97ae32006-04-25 07:39:48 +0000234 * strace.c (main): Fail when nonoption args follow -p switches.
235 Fixes Debian#361302.
236
Roland McGrath9d19e162006-04-25 07:33:26 +0000237 * Makefile.am (EXTRA_DIST): Add xlate.el.
238
239 * linux/mips/Makefile.in: File removed, unused cruft.
240 * linux/sparc/Makefile.in: Likewise.
241
Roland McGrath23777062006-04-25 07:22:04 +0000242 * strace.spec (Source0): Use http://dl.sourceforge.net URL.
243
244 * ipc.c (sys_semtimedop): Fixed inverted indirect_ipccall test.
245 * linux/hppa/syscallent.h: Fixed semtimedop entry.
246 From Mike Stroyan <mike.stroyan@hp.com>.
247 Fixes Debian#340239.
248
Roland McGrath9216ba72006-04-25 07:34:44 +00002492006-03-30 Daniel Jacobowitz <dan@codesourcery.com>
250
Roland McGrath5b97ae32006-04-25 07:39:48 +0000251 * linux/arm/syscallent.h: Correct the name of exit. Remove
252 M68K conditionals and sys_security. Correct syscalls 243-282.
253 Fixes Debian#360154.
254
Roland McGrath9216ba72006-04-25 07:34:44 +0000255 * process.c (change_syscall): Add ARM support.
256 * syscall.c (get_scno): Handle ARM EABI.
257 Fixes Debian#360152.
258
Roland McGrath074a8e12006-01-17 06:23:01 +00002592006-01-16 Roland McGrath <roland@redhat.com>
260
261 * configure.ac, NEWS: Version 4.5.14.
262 * debian/changelog, strace.spec: 4.5.14-1.
263
Roland McGrathef6b8bf2006-01-14 00:20:26 +00002642006-01-13 Roland McGrath <roland@redhat.com>
265
266 * debian/control (Build-Depends): Add debhelper.
267
Roland McGrath97a932b2006-01-12 10:19:01 +00002682006-01-12 Roland McGrath <roland@redhat.com>
269
Roland McGrath402c9d12006-01-12 22:35:02 +0000270 * signal.c [LINUX] (sys_restart_syscall): New function.
271 * linux/syscall.h: Declare sys_restart_syscall.
272 * linux/sparc/syscall.h: Likewise.
273 * linux/syscallent.h: Call 0 is restart_syscall.
274 * linux/arm/syscallent.h: Likewise.
275 * linux/powerpc/syscallent.h: Likewise.
276 * linux/m68k/syscallent.h: Likewise.
277 * linux/hppa/syscallent.h: Likewise.
278 * linux/sh/syscallent.h: Likewise.
279 * linux/sparc/syscallent.h: Likewise.
280 * linux/sparc64/syscallent.h: Likewise.
281 * linux/alpha/syscallent.h: Use sys_restart_syscall.
282 * linux/ia64/syscallent.h: Likewise.
283 * linux/mips/syscallent.h: Likewise.
284 * linux/x86_64/syscallent.h: Likewise.
Roland McGrathef6b8bf2006-01-14 00:20:26 +0000285 Fixes RH#165469.
Roland McGrath402c9d12006-01-12 22:35:02 +0000286
2872005-08-08 Dmitry V. Levin <ldv@altlinux.org>
288
289 * system.c [LINUX] (MS_MGC_VAL): New macro.
290 [LINUX] (mount_flags): Add it.
291 [LINUX] (sys_mount): If neither MS_BIND nor MS_MOVE bits are
292 set in the flags argument, try to fetch data string.
293 Fixes RH#165377.
294
2952006-01-12 Roland McGrath <roland@redhat.com>
296
Roland McGrath9ee476f2006-01-12 11:03:48 +0000297 * system.c (sys_sysctl): Don't read off end of NAME when max_strlen
298 exceeds INFO.nlen.
299 From Timo Lindfors <timo.lindfors@iki.fi>.
300 Fixes Debian#339117.
301
302 * debian/rules (binary-arch): Don't pass -s to install. Use dh_strip.
303 Fixes Debian#325132.
304
305 * debian/control (Standards-Version): Update to 3.6.2.
306
Roland McGrath97a932b2006-01-12 10:19:01 +0000307 * defs.h [LINUXSPARC] (PERSONALITY0_WORDSIZE, PERSONALITY1_WORDSIZE):
308 New macros.
309 [SPARC64] (PERSONALITY2_WORDSIZE): New macro.
310 [X86_64] (PERSONALITY0_WORDSIZE, PERSONALITY1_WORDSIZE): New macros.
311 * syscall.c (PERSONALITY0_WORDSIZE): New macro if undefined.
312 (personality_wordsize): New variable.
313 (decode_subcall): Use it for size of argument words.
314 Fixes RH#174354.
315
Roland McGrath49355302006-01-12 09:51:03 +00003162005-11-17 Dmitry V. Levin <ldv@altlinux.org>
317
318 Implement qual_flags support for each personality.
319 * strace.c (main): Move qualify calls after set_personality call.
320 * syscall.c (qual_flags0): New variable..
321 [SUPPORTED_PERSONALITIES >= 2] (qual_flags1): New variable.
322 [SUPPORTED_PERSONALITIES >= 3] (qual_flags2): New variable.
323 (qual_flags): Change variable definition from array to pointer.
324 (set_personality): Initialize qual_flags variable.
325 (qualify_one): Add "pers" argument to specify personality.
326 [SUPPORTED_PERSONALITIES >= 2]: Set qual_flags1 if requested.
327 [SUPPORTED_PERSONALITIES >= 3]: Set qual_flags2 if requested.
328 (qual_syscall): Pass personality to qualify_one.
329 [SUPPORTED_PERSONALITIES >= 2]: Look for syscall also in sysent1
330 table.
331 [SUPPORTED_PERSONALITIES >= 3]: Look for syscall also in sysent2
332 table.
333 (qual_signal): Pass personality to qualify_one.
334 (qual_desc): Likewise.
335 (qualify): Use qualify_one instead of manual qual_flags
336 manipulations.
337 [SUPPORTED_PERSONALITIES >= 2]: Look for syscall also in sysent1
338 table.
339 [SUPPORTED_PERSONALITIES >= 3]: Look for syscall also in sysent2
340 table.
341 * defs.h: Update qual_flags declaration.
342 Fixes RH#173986.
343
Roland McGrath7c061b22006-01-12 09:45:59 +00003442005-11-14 Dmitry V. Levin <ldv@altlinux.org>
345
346 * syscall.c (qual_syscall): Handle numeric syscall specification.
347 Fixes RH#174798.
348
349 * syscall.c (qual_signal, qual_options): Remove redundant argument
350 check.
351
Roland McGrath52f70f72005-12-02 04:34:25 +00003522005-12-01 Roland McGrath <roland@redhat.com>
353
354 * ipc.c (indirect_ipccall) [MIPS || HPPA]: Return false.
355 Fixes Debian#340239.
356
357 * Makefile.am (EXTRA_DIST): Add linux/arm/syscallent.h
358 and linux/m68k/syscallent.h.
359 Fixes Debian#336197.
360
361 * debian/control (Architecture): Add armeb.
362 Fixes Debian#335681.
363
3642005-11-02 Michal Marek <mmarek@suse.cz>
365
366 * strace-graph (handle_trace): follow clone() and vfork() calls.
367
Roland McGrath362f1c32005-12-02 04:23:50 +00003682005-10-25 Heiko Carstens <heiko.carstens@de.ibm.com>
369
370 * linux/s390/syscallent.h: Added ioprio_set, ioprio_get,
371 inotify_init, inotify_add_watch, inotify_rm_watch.
372 Corrected number of arguments for request_key.
373 * linux/s390x/syscallent.h: Likewise.
374
3752005-12-01 Roland McGrath <roland@redhat.com>
376
377 * ipc.c (indirect_ipccall) [IA64]: Return false unless the syscall
378 number is in the low range of IA32 syscalls.
379
3802005-10-07 Andreas Schwab <schwab@suse.de>
381
382 * linux/ia64/syscallent.h: Syscall 1105 is gettid, not ioperm.
383
Roland McGrath89e94ff2005-12-02 03:57:20 +00003842005-12-01 Roland McGrath <roland@redhat.com>
385
Roland McGrath8e5ca842005-12-02 04:08:39 +0000386 * resource.c (resources): Add RLIMIT_NICE, RLIMIT_RTPRIO.
387 Reported by Scott Tsai <scottt958@yahoo.com.tw>.
388
Roland McGrath89e94ff2005-12-02 03:57:20 +0000389 * ipc.c (indirect_ipccall): New function.
390 (sys_msgctl, sys_msgsnd, sys_msgrcv, sys_semop): Use that predicate
391 instead of #ifdef LINUX test.
392 [LINUX] (sys_semtimedop): Likewise.
393 (sys_shmctl, sys_shmat, sys_shmdt): Likewise.
394 Fixes RH#164755.
395
Roland McGrath61b675e2005-12-02 03:44:20 +00003962005-07-31 Ulrich Drepper <drepper@redhat.com>
397
Roland McGrath89e94ff2005-12-02 03:57:20 +0000398 * linux/x86_64/syscallent.h: Fix syscall parameter count for msgrcv and
399 msgctl.
400
Roland McGrath61b675e2005-12-02 03:44:20 +0000401 * ipc.c (sys_msgrcv): Add entering handling and print first parameter
402 there.
403 Fixes RH#164757.
404
Roland McGrathbc38ae72005-12-02 03:59:47 +00004052005-08-08 Dmitry V. Levin <ldv@altlinux.org>
406
407 * strace.1: Update "SEE ALSO" links to reference to valid
408 manpages.
409 Patch from Michail Litvak <mci@owl.openwall.com>.
410 Fixes RH#165375.
411
Roland McGrath68565782005-10-21 22:06:58 +00004122005-10-21 Roland McGrath <roland@redhat.com>
413
414 * util.c (printpathn): Cap N at sizeof path - 1.
415
Roland McGrath0c26d342005-08-03 11:43:03 +00004162005-08-03 Roland McGrath <roland@redhat.com>
417
418 * configure.ac, NEWS: Version 4.5.13.
419 * debian/changelog, strace.spec: 4.5.13-1.
420
Roland McGrath03c3d752005-08-03 12:18:37 +0000421 * configure.ac: Check for struct dqblk.dqb_curblocks field.
Roland McGrath7e946762005-08-03 12:02:14 +0000422 * resource.c [LINUX] (OLD_CMD): New macro.
423 (quotacmds): Use it to hard-wire old O_* values, don't use macros.
Roland McGrath03c3d752005-08-03 12:18:37 +0000424 (sys_quotactl): If dqb_curblocks is not there, it's called
425 dqb_curspace instead. Print dqb_* fields as unsigned long long.
Roland McGrath7e946762005-08-03 12:02:14 +0000426
Roland McGrath9554a482005-08-03 11:29:26 +00004272005-07-19 Michael Schmitz <schmitz@debian.org>
428
429 Long overdue m68k cleanup.
430 * linux/syscallent.h: remove m68k declarations.
431 * linux/m68k/syscallent.h: new file, fixed up declarations
432 to match kernel version 2.6.11. Newer syscalls are sufficiently
433 different from i386 to merit a separate file.
434
4352005-08-03 Roland McGrath <roland@redhat.com>
436
437 * linux/x86_64/syscallent.h: Update init_module argument count.
438 * linux/sparc/syscallent.h: Likewise.
439 * linux/sparc64/syscallent2.h: Likewise.
440 * linux/sparc64/syscallent.h: Likewise.
441 * linux/sh/syscallent.h: Likewise.
442 * linux/sh64/syscallent.h: Likewise.
443 * linux/s390/syscallent.h: Likewise.
444 * linux/s390x/syscallent.h: Likewise.
445 * linux/powerpc/syscallent.h: Likewise.
446 * linux/arm/syscallent.h: Likewise.
447
4482005-07-22 James Lentini <jlentini@gmail.com>
449
450 * bjm.c (sys_init_module): Display all three arguments.
451 * linux/syscallent.h: Update argument count.
452
Roland McGrathe0f6bb02005-08-03 11:23:50 +00004532005-08-03 Roland McGrath <roland@redhat.com>
454
455 * process.c (internal_wait): Don't suspend when known child is known
456 to be exiting already.
457
458 * strace.c (detach): If detaching the last live thread in a group with
459 a zombie leader, then detach the leader too.
460 (handle_group_exit): Use detach, not droptcb, for predeceased thread.
461 Mark process about to take a signal with TCB_GROUP_EXITING flag.
462 Fixes RH#161919.
463
Roland McGrath30afb792005-07-19 07:42:24 +00004642005-07-19 Roland McGrath <roland@redhat.com>
465
466 * defs.h [LINUX] [M68K] (__NR_exit_group): Define it if missing.
467 Fixes Debian#315500.
468
Roland McGrath387d0e52005-07-19 07:13:34 +00004692005-07-14 Heiko Carstens <heiko.carstens@de.ibm.com>
470
471 * linux/s390/syscallent.h (sys_tgkill, vserver, fadvise64_64)
472 (statfs64, fstatfs64, remap_file_pages, mbind, get_mempolicy)
473 (set_mempolicy, mq_open, mq_unlink, mq_timedsend, mq_timedreceive)
474 (mq_notify, mq_getsetattr, sys_kexec_load, add_key, request_key)
475 (keyctl, waitid): Added.
476 * linux/s390x/syscallent.h: Likewise and added missing _llseek.
477 * linux/s390/errnoent.h (ECANCELED, ENOKEY, EKEYEXPIRED)
478 (EKEYREVOKED, EKEYREJECTED, EOWNERDEAD, ENOTRECOVERABLE): Added.
479 * linux/s390x/errnoent.h: Likewise.
480
Roland McGrath415a7d62005-07-05 09:50:40 +00004812005-07-05 Roland McGrath <roland@redhat.com>
482
483 * mem.c [LINUX] (sys_old_mmap) [X86_64]: Extract 32-bit values if
484 child is 32-bit.
485 Fixes RH#162467.
486
Roland McGrathfd583f62005-07-05 03:22:50 +00004872005-06-08 Dmitry V. Levin <ldv@altlinux.org>
488
Roland McGrathe10dc512005-07-05 03:26:03 +0000489 Introduce "-e trace=desc".
490 * defs.h (TRACE_DESC): New flag.
491 * syscall.c: Define TD macro before include of syscallent files
492 and undefine it afterwards.
493 (lookup_class): Recognize "desc" keyword.
494 * strace.1: Document "-e trace=desc".
495 * freebsd/i386/syscallent.h: Mark those syscalls which take a
496 file descriptor as an argument or return a file descriptor with
497 TD flag.
498 * linux/alpha/syscallent.h: Likewise.
499 * linux/hppa/syscallent.h: Likewise.
500 * linux/ia64/syscallent.h: Likewise.
501 * linux/mips/syscallent.h: Likewise.
502 * linux/powerpc/syscallent.h: Likewise.
503 * linux/s390/syscallent.h: Likewise.
504 * linux/s390x/syscallent.h: Likewise.
505 * linux/sh/syscallent.h: Likewise.
506 * linux/sh64/syscallent.h: Likewise.
507 * linux/sparc/syscallent.h: Likewise.
508 * linux/sparc64/syscallent2.h: Likewise.
509 * linux/sparc64/syscallent.h: Likewise.
510 * linux/syscallent.h: Likewise.
511 * linux/x86_64/syscallent.h: Likewise.
512 * sunos4/syscallent.h: Likewise.
513 * svr4/syscallent.h: Likewise.
514 Fixes RH#159400.
515
Roland McGrathfd583f62005-07-05 03:22:50 +0000516 Remove TF flag from those syscalls which have no filename argument.
517 * freebsd/i386/syscallent.h: Remove TF flag from fstat, pread,
518 pwrite, fstat, sendfile.
519 * linux/alpha/syscallent.h: Remove TF flag from read, write,
520 pread, pwrite, sendfile.
521 * linux/hppa/syscallent.h: Remove TF flag from read, write,
522 pread, pwrite, fstat64, sendfile, ftruncate64.
523 * linux/ia64/syscallent.h: Remove TF flag from read, write,
524 sendfile, fstat, fadvise64.
525 * linux/mips/syscallent.h: Remove TF flag from read, write,
526 fstatfs, fstat, pread, pwrite, sendfile, ftruncate64, fstat64,
527 sendfile64, fadvise64, fstatfs64.
528 * linux/powerpc/syscallent.h: Remove TF flag from read, write,
529 fstat, pread, pwrite, sendfile, ftruncate64, fstat64, sendfile64,
530 fadvise64, fstatfs64, fadvise64_64.
531 * linux/s390/syscallent.h: Remove TF flag from pread, pwrite,
532 sendfile, ftruncate64, fstat64, sendfile64.
533 * linux/s390x/syscallent.h: Remove TF flag from pread, pwrite,
534 sendfile, sendfile64.
535 * linux/sh/syscallent.h: Remove TF flag from pread, pwrite,
536 sendfile, fstat64.
537 * linux/sh64/syscallent.h: Remove TF flag from pread, pwrite,
538 sendfile, ftruncate64, fstat64.
539 * linux/sparc/syscallent.h: Remove TF flag from sendfile, fstat64,
540 pread, pwrite, sendfile64.
541 * linux/sparc64/syscallent2.h: Likewise.
542 * linux/sparc64/syscallent.h: Likewise.
543 * linux/syscallent.h: Remove TF flag from pread, pwrite, sendfile,
544 ftruncate64, fstat64, sendfile64, fadvise64, fadvise64, fstatfs64,
545 fadvise64_64.
546 * linux/x86_64/syscallent.h: Remove TF flag from pread, pwrite,
547 sendfile, fadvise64_64.
548 * svr4/syscallent.h: Remove TF flag from pread, pwrite, ftruncate,
549 fstatvfs64, ftruncate64.
550 Fixes RH#159340.
551
Roland McGrath012ffdf2005-07-04 23:30:30 +00005522005-07-04 Roland McGrath <roland@redhat.com>
553
Roland McGrathbfacc262005-07-04 23:33:42 +0000554 * net.c (sockipv6options): Add IPV6_ADD_MEMBERSHIP,
555 IPV6_DROP_MEMBERSHIP, IPV6_ROUTER_ALERT.
556 From Ulrich Drepper <drepper@redhat.com>.
557 Fixes RH#162450.
558
Roland McGrath012ffdf2005-07-04 23:30:30 +0000559 * net.c (sockipoptions): Fix typos.
560 From Ulrich Drepper <drepper@redhat.com>.
561 Fixes RH#161578.
562
563 * util.c (printnum_int): New function, printnum with s/long/int/.
564 * defs.h: Declare it.
565 * net.c (printsockopt): Use it for int-sized option.
566 Fixes RH#162449.
567 Reported by Ulrich Drepper <drepper@redhat.com>.
568
Roland McGrath43cb21f2005-06-10 03:56:19 +00005692005-06-09 Roland McGrath <roland@redhat.com>
570
571 * configure.ac, NEWS: Version 4.5.12.
572 * debian/changelog, strace.spec: 4.5.12-1.
573
Roland McGrath59a611b2005-06-08 20:45:52 +00005742005-06-08 Dmitry V. Levin <ldv@altlinux.org>
575
576 Minor namespace cleanup.
577 * defs.h (string_quote): Remove declaration.
578 * file.c (openmodessol) [LINUXSPARC]: Make static.
579 (fileflags): Likewise.
580 (aclcmds, aclipc) [HAVE_SYS_ACL_H]: Likewise.
581 (direnttypes) [FREEBSD || LINUX]: Likewise.
582 (xattrflags): Likewise.
583 * process.c (unalignctl_string): Make static.
584 (setarg): Disable.
585 * syscall.c (subcalls_table): Make static.
586 (socket_map) [!(LINUX && (ALPHA || MIPS))]: Likewise.
587 (sparc_socket_decode): Make static, define for [SPARC || SPARC64] only.
588 (decode_subcall): Make static.
589 (syscall_fixup): Likewise.
590 (get_error): Likewise.
591 (syscall_enter): Likewise.
592 * util.c (tv_tv): Disable.
593 (getpc): Likewise.
594 (string_quote): Make static.
595 Fixes RH#159688.
596
Roland McGrathd40a3932005-06-08 18:06:27 +00005972005-05-12 Philippe De Muyter <phdm@macqel.be>
598
599 * util.c (getpc, printcall): Check #if defined(M68K), not M68k.
600 Enables `-i' on m68k machines.
601
Roland McGrath5d731702005-06-07 23:22:26 +00006022005-06-06 Roland McGrath <roland@redhat.com>
603
604 * process.c (struct_user_offsets) [X86_64]: Reorder elements so
605 matching works right.
606 Fixes RH#159787.
607
608 * linux/syscall.h (SYS_socket, SYS_bind, SYS_connect, SYS_listen)
609 (SYS_accept, SYS_getsockname, SYS_getpeername, SYS_socketpair)
610 (SYS_send, SYS_recv, SYS_sendto, SYS_recvfrom, SYS_shutdown)
611 (SYS_setsockopt, SYS_getsockopt, SYS_sendmsg, SYS_recvmsg)
612 (SYS_getsockname, SYS_semop, SYS_semgsub_et, SYS_semget, SYS_semctl)
613 (SYS_semtimedop, SYS_msgsnd, SYS_msgrcv, SYS_msgget)
614 (SYS_msgctl, SYS_shmat, SYS_shmdt, SYS_shmget)
615 (SYS_shmctl): Macros renamed to SYS_sub_*.
616 * syscall.c (dumpio): Match SYS_sub_* if defined instead of SYS_*.
617
618 * linux/syscall.h (SYS_waitid): Define if not defined.
619
620 * linux/syscallent.h: Fix pread/pwrite names to pread64/pwrite64.
621
622 * defs.h (struct sysent): New member `native_scno'.
623 (known_scno): Declare new function.
624 * linux/syscallent.h: Add new final field to interesting syscalls.
625 * syscall.c (known_scno): New function.
626 (dumpio, internal_syscall, syscall_fixup, trace_syscall): Use it.
627 * process.c (internal_fork, internal_exit): Likewise.
628 [IA64] (ARG_STACKSIZE, ARG_PTID, ARG_CTID, ARG_TLS): Likewise.
629 * strace.c (proc_open): Likewise.
630 * util.c [LINUX] (setbpt): Likewise.
631 * linux/syscall.h: Remove [!defined(X86_64)] from conditional
632 for defining SYS_socket_subcall et al.
633 * linux/syscallent.h: Likewise for #error check.
634 * syscall.c (trace_syscall): Likewise for SYS_{socketcall,ipc} cases.
635 Fixes RH#158934.
636
Roland McGrath6286f662005-06-03 02:40:43 +00006372005-06-02 Roland McGrath <roland@redhat.com>
638
639 * file.c (printstatfs64): Cast values to unsigned long long and use
640 %llu formats.
641 Fixes RH#158243.
642
Roland McGrathe8c6eec2005-06-01 18:56:03 +00006432005-05-31 Dmitry V. Levin <ldv@altlinux.org>
644
Roland McGrath712a6bf2005-06-01 19:22:30 +0000645 Deal with memory management issues.
646 * defs.h (tprint_iov): Update prototype.
647 * desc.c (sys_epoll_wait) [HAVE_SYS_EPOLL_H]: Do not allocate
648 epoll_event array of arbitrary size on the stack, to avoid
649 stack overflow.
650 * file.c (print_xattr_val): Check for integer overflow during
651 malloc size calculation, to avoid heap corruption.
652 * io.c (tprint_iov) [HAVE_SYS_UIO_H]: Check for integer overflow
653 during malloc size calculation, to avoid heap corruption.
654 Change iovec array handling to avoid heap memory allocation.
655 * mem.c (get_nodes) [LINUX]: Check for integer overflow during
656 size calculation and do not allocate array of arbitrary size on
657 the stack, to avoid stack overflow.
658 * net.c (printcmsghdr) [HAVE_SENDMSG]: Do not allocate array of
659 arbitrary size on the stack, to avoid stack overflow. Do not
660 trust cmsg.cmsg_len to avoid read beyond the end of allocated
661 object.
662 (printmsghdr) [HAVE_SENDMSG]: Update tprint_iov() usage.
663 * process.c (sys_setgroups): Check for integer overflow during
664 malloc size calculation, to avoid heap corruption. Change gid_t
665 array handling to avoid heap memory allocation.
666 (sys_getgroups): Likewise.
667 (sys_setgroups32) [LINUX]: Likewise.
668 (sys_getgroups32) [LINUX]: Likewise.
669 * stream.c (sys_poll) [HAVE_SYS_POLL_H]: Check for integer
670 overflow during malloc size calculation, to avoid heap corruption.
671 Change pollfd array handling to avoid heap memory allocation.
672 * system.c (sys_sysctl) [LINUX]: Check for integer overflow
673 during malloc size calculation, to avoid heap corruption.
674 * util.c (dumpiov) [HAVE_SYS_UIO_H]: Check for integer overflow
675 during malloc size calculation, to avoid heap corruption.
676 Fixes RH#159196.
677
Roland McGrathb422e0d2005-06-01 19:03:30 +0000678 * util.c (printxval): Change third argument from "char *" to
679 "const char *".
680 (printflags): Add third argument, "const char *", with similar
681 meaning to the third argument of printxval().
682 * defs.h (printxval): Change third argument from "char *" to
683 "const char *".
684 (printflags): Add third argument.
685 * bjm.c (sys_query_module) [LINUX]: Pass third argument to
686 printflags().
687 * desc.c (sys_fcntl): Likewise.
688 (sys_flock) [LOCK_SH]: Likewise.
689 (print_epoll_event) [HAVE_SYS_EPOLL_H]: Likewise.
690 * file.c (sys_open): Likewise.
691 (solaris_open) [LINUXSPARC]: Likewise.
692 (sys_access): Likewise.
693 (sys_chflags, sys_fchflags) [FREEBSD]: Likewise.
694 (realprintstat) [HAVE_LONG_LONG_OFF_T &&
695 HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
696 (printstat64) [HAVE_STAT64 &&
697 HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
698 (sys_setxattr, sys_fsetxattr): Likewise.
699 * ipc.c (sys_msgget, sys_msgsnd, sys_msgrcv, sys_semget,
700 sys_shmget, sys_shmat) [LINUX || SUNOS4 || FREEBSD]: Likewise.
701 (sys_mq_open) [LINUX]: Likewise.
702 (printmqattr) [HAVE_MQUEUE_H]: Likewise.
703 * mem.c (print_mmap) [!HAVE_LONG_LONG_OFF_T]: Likewise.
704 (sys_mmap64) [_LFS64_LARGEFILE || HAVE_LONG_LONG_OFF_T]: Likewise.
705 (sys_mprotect): Likewise.
706 (sys_mremap, sys_madvise, sys_mlockall) [LINUX]: Likewise.
707 (sys_msync) [MS_ASYNC]: Likewise.
708 (sys_mctl) [MC_SYNC]: Likewise.
709 (sys_remap_file_pages, sys_mbind, sys_get_mempolicy) [LINUX]:
710 Likewise.
711 * net.c (printmsghdr) [HAVE_STRUCT_MSGHDR_MSG_CONTROL]: Likewise.
712 (sys_send, sys_sendto): Likewise.
713 (sys_sendmsg) [HAVE_SENDMSG]: Likewise.
714 (sys_recv, sys_recvfrom): Likewise.
715 (sys_recvmsg) [HAVE_SENDMSG]: Likewise.
716 (printicmpfilter) [ICMP_FILTER]: Likewise.
717 * proc.c (proc_ioctl) [SVR4 && !HAVE_MP_PROCFS || FREEBSD]: Likewise.
718 * process.c (sys_clone) [LINUX]: Likewise.
719 (printwaitn): Likewise.
720 (sys_waitid) [SVR4 || LINUX]: Likewise.
721 * signal.c (sys_sigvec) [SUNOS4 || FREEBSD]: Likewise.
722 (sys_sigaction): Likewise.
723 (printcontext) [SVR4]: Likewise.
724 (print_stack_t) [LINUX) || FREEBSD]: Likewise.
725 (sys_rt_sigaction) [LINUX]: Likewise.
726 * sock.c (sock_ioctl) [LINUX]: Likewise.
727 * stream.c (sys_putmsg, sys_getmsg): Likewise.
728 (sys_putpmsg) [SYS_putpmsg]: Likewise.
729 (sys_getpmsg) [SYS_getpmsg]: Likewise.
730 (sys_poll): Likewise.
731 (print_transport_message) [TI_BIND]: Likewise.
732 (stream_ioctl): Likewise.
733 * system.c (sys_mount, sys_reboot): Likewise.
734 (sys_cacheflush) [LINUX && M68K]: Likewise.
735 (sys_capget, sys_capset) [SYS_capget]: Likewise.
736 * term.c (term_ioctl) [TIOCMGET]: Likewise.
737 * time.c (sys_clock_nanosleep, sys_timer_settime) [LINUX]:
738 Likewise.
739 Fixes RH#159310.
740
Roland McGrathe8c6eec2005-06-01 18:56:03 +0000741 * bjm.c (sys_query_module) [LINUX]: Unitize "out of memory"
742 errors reporting style.
743 * strace.c (rebuild_pollv) [USE_PROCFS]: Likewise.
744 * system.c (sys_capget, sys_capset) [SYS_capget]: Likewise.
745 * util.c (printstr): Likewise.
746 (dumpiov) [HAVE_SYS_UIO_H]: Likewise.
747 (fixvfork) [SUNOS4]: Likewise.
748 * desc.c (decode_select): Continue to decode syscall arguments
749 in case of OOM condition.
750 * file.c (sys_getdents): Likewise.
751 (sys_getdents64) [_LFS64_LARGEFILE]: Likewise.
752 (sys_getdirentries) [FREEBSD]: Likewise.
753 * mem.c (sys_mincore): Changed type of variables which deal with
754 malloc size from int to unsigned long.
Roland McGrathe35109a2005-06-08 18:03:12 +0000755 Fixes RH#159308.
Roland McGrathe8c6eec2005-06-01 18:56:03 +0000756
Roland McGratha6ef1a32005-06-01 18:57:27 +00007572005-05-22 Dmitry V. Levin <ldv@altlinux.org>
758
759 * bjm.c [LINUX]: Do not include <linux/linkage.h>. It is not
760 safe to include kernel headers, and this one is not used anyway.
761 Fixes RH#158488.
762
Roland McGrathe776e3e2005-05-26 23:21:13 +00007632005-05-26 Roland McGrath <roland@redhat.com>
764
765 * system.c (sys_sysctl): Check for errors accessing user pointers.
766 Use malloc instead of alloca in case size is insane.
767
Roland McGrath682291e2005-05-09 08:03:06 +00007682005-05-09 Roland McGrath <roland@redhat.com>
769
770 * configure.ac: Check for libaio.h.
771 * desc.c (sys_io_setup, sys_io_submit, sys_io_cancel,
772 sys_io_getevents, sys_io_destroy): New functions.
773 * linux/syscall.h: Declare them.
774 * linux/syscallent.h: Use those for io_* syscalls.
775 * linux/alpha/syscallent.h: Likewise.
776 * linux/hppa/syscallent.h: Likewise.
777 * linux/ia64/syscallent.h: Likewise.
778 * linux/mips/syscallent.h: Likewise.
779 * linux/powerpc/syscallent.h: Likewise.
780 * linux/s390/syscallent.h: Likewise.
781 * linux/s390x/syscallent.h: Likewise.
782 * linux/x86_64/syscallent.h: Likewise.
783 From Zach Brown <zach.brown@oracle.com>.
784 Fixes RH#155065.
785
786 * debian/control (Architecture): Add ppc64.
787 Fixes Debian bug #301089.
788
Roland McGrath05a017b2005-05-09 07:46:07 +00007892005-05-05 Anton Blanchard <anton@samba.org>
790
791 * process.c (ptrace_cmds): Add PTRACE_GETVRREGS and PTRACE_SETVRREGS
792 if defined.
793
7942005-05-09 Roland McGrath <roland@redhat.com>
795
796 * strace.c (main): Refuse negative -s argument value.
797 Fixes Debian bug #303256.
798
Roland McGrathf3b565b2005-05-09 07:40:41 +00007992005-04-25 Anton Blanchard <anton@samba.org>
800
801 * file.c (openmodes): Add O_NOATIME flag if defined.
802
8032005-04-05 Anton Blanchard <anton@samba.org>
804
805 * linux/powerpc/ioctlent.h: Regenerated.
806
807 * signal.c (signame): Don't try and dereference negative index.
808
809 * linux/powerpc/syscallent.h: Add debug_setcontext, vserver,
810 mbind, *_mempolicy, mq_*, sys_kexec_load, add_key, request_key,
811 keyctl, waitid, sys_semtimedop. Fix various other syscalls.
812
813 * ipc.c (shm_resource_flags): New variable, table has SHM_HUGETLB
814 but not IPC_NOWAIT, which have the same value.
815 (sys_shmget): Use that instead of resource_flags.
816
Roland McGratha3734a92005-03-22 23:13:24 +00008172005-03-22 Roland McGrath <roland@redhat.com>
818
Roland McGrathe1f1e572005-03-23 03:19:02 +0000819 * desc.c (decode_select): Increase local buffer size.
820 Fixes RH#151570.
821
Roland McGratha3734a92005-03-22 23:13:24 +0000822 * configure.ac, NEWS: Version 4.5.11.
823 * debian/changelog, strace.spec: 4.5.11-1.
824
825 * linux/arm/syscallent.h: Fix 113 entry (syscall, not vm86old).
826
Roland McGrath3181c512005-03-15 02:40:23 +00008272005-03-14 Roland McGrath <roland@redhat.com>
828
829 * configure.ac, NEWS: Version 4.5.10.
830 * debian/changelog, strace.spec: 4.5.10-1.
831
Roland McGrath0495c932005-03-15 02:17:23 +00008322005-02-26 GOTO Masanori <gotom@debian.or.jp>
833
834 * linux/alpha/syscallent.h: Fix the reversed order of lstat64 and
835 fstat64. Clean up osf_nrecvmsg and osf_ngetsockname.
836
Roland McGrath391a4e72005-03-15 02:16:21 +00008372005-02-28 Andreas Schwab <schwab@suse.de>
838
839 * syscall.c (getrval2): Move #ifdef IA64 inside #ifdef LINUX.
840
8412005-03-14 Roland McGrath <roland@redhat.com>
842
843 * linux/mips/syscallent.h: Update various calls.
844 From Thiemo Seufer <ths@networkno.de>.
845 Fixes Debian bug #256684.
846
847 * debian/control (Architecture): Add s390.
848 Fixes Debian bug #294172.
849
Roland McGrathbfb49e52005-03-06 22:24:52 +00008502005-03-06 Roland McGrath <roland@redhat.com>
851
852 * strace.c (trace) [PTRACE_GETSIGINFO]: Fetch siginfo_t for SIGSEGV
853 and SIGBUS signals, use si_addr in output.
854
Roland McGrath4859f6c2005-03-01 23:03:11 +00008552005-03-01 Roland McGrath <roland@redhat.com>
856
857 * file.c (print_xattr_val): Add a cast.
858
Roland McGrath854694b2005-02-06 01:16:47 +00008592005-02-05 Roland McGrath <roland@redhat.com>
860
Roland McGrathb0a3d4e2005-02-06 01:55:16 +0000861 * desc.c (decode_select): Calculate size of passed fd_set vectors and
862 copy in the user's size rather than the standard sizeof(fd_set).
Roland McGrath391a4e72005-03-15 02:16:21 +0000863 Fixes Debian bug #65654, #284290.
Roland McGrathb0a3d4e2005-02-06 01:55:16 +0000864
865 * util.c (printpath, printpathn): Print NULL and don't try any fetch
866 when ADDR is zero.
867 Fixes Debian bug #63093.
868
Roland McGrath854694b2005-02-06 01:16:47 +0000869 * debian/control (Build-Depends): Fix for s390 and sparc.
870 From Bastian Blank <waldi@debian.org>.
871 Fixes Debian bug #293564.
872
8732004-12-19 Dmitry V. Levin <ldv@altlinux.org>
874
875 * strace.c (main) [!USE_PROCFS]: In child process, raise SIGSTOP
876 right before execv() call. Remove fake_execve() call.
877 * defs.h (fake_execve): Remove unused declaration.
878 * process.c (fake_execve): Remove unused function.
879 Fixes RH#143365.
880
Roland McGrath55f23e72005-02-04 09:29:11 +00008812005-02-04 Roland McGrath <roland@redhat.com>
882
883 * configure.ac, NEWS: Version 4.5.9.
Roland McGrath0c6c17b2005-02-04 09:54:16 +0000884 * debian/changelog, strace.spec: 4.5.9-2.
Roland McGrath55f23e72005-02-04 09:29:11 +0000885
Roland McGrath1e834482005-02-04 09:50:24 +0000886 * file.c (O_LARGEFILE): Omit when #undef'd because it was zero.
887
Roland McGrath94098ef2005-02-02 20:25:36 +00008882005-02-02 Roland McGrath <roland@redhat.com>
889
Roland McGrath026bdab2005-02-03 03:19:43 +0000890 * debian/control: Add strace-udeb package for installer debugging.
891 * debian/rules (binary-arch): Build it.
892 From Joshua Kwan <joshk@triplehelix.org>.
893 Fixes Debian bug #268294.
894
Roland McGrathd08b2f02005-02-02 22:11:37 +0000895 * file.c (openmodes) [O_LARGEFILE] [O_LARGEFILE == 0]: Redefine to
896 known values for Linux.
897
Roland McGrath84219e12005-02-02 20:55:27 +0000898 * util.c (printcall): Print 16 ?s when long is 8 bytes.
899 Fixes RH#146932.
900
Roland McGrath3cad4a62005-02-02 20:32:37 +0000901 * linux/sparc/syscall.h: Declare sys_epoll_create, sys_epoll_ctl,
902 sys_epoll_wait.
903 * linux/sparc64/syscall.h: Just #include "../sparc/syscall.h" here.
904 * ioctl.c (nioctlents2): Add const to type.
905 Fixes Debian bug #278449.
906
Roland McGrath94098ef2005-02-02 20:25:36 +0000907 * sock.c (iffflags): New variable, table of IFF_* values.
908 (print_addr): New function.
909 (sock_ioctl): Handle SIOCGIFADDR, SIOCGIFDSTADDR, SIOCGIFBRDADDR,
910 SIOCGIFNETMASK, SIOCGIFFLAGS, SIOCGIFMETRIC, SIOCGIFMTU, SIOCGIFSLAVE,
911 SIOCGIFHWADDR. Use print_addr for SIOCGIFCONF, SIOCGIFNAME, and
912 SIOCGIFINDEX, and fix their output.
913 From Ulrich Drepper <drepper@redhat.com>.
914 Fixes RH#138223.
Roland McGrath1967a132005-02-02 20:45:37 +0000915 Fixes Debian bug #192164.
Roland McGrath94098ef2005-02-02 20:25:36 +0000916
Roland McGrathac6b7bb2005-02-02 04:42:56 +00009172004-12-20 Dmitry V. Levin <ldv@altlinux.org>
918
Roland McGrath9d721f22005-02-02 04:45:09 +0000919 * configure.ac: Use AC_GNU_SOURCE macro instead of changing CFLAGS.
920 * defs.h [HAVE_CONFIG_H]: Include config.h first.
921 * strace.c: Include "defs.h" first.
922 Fixes RH#143370.
923
Roland McGrathac6b7bb2005-02-02 04:42:56 +0000924 * syscall.c (call_summary): Fix potential NULL dereference.
925 Fixes RH#143369.
926
Roland McGrathdd9efd82005-02-02 04:40:36 +00009272004-12-19 Dmitry V. Levin <ldv@altlinux.org>
928
929 * syscall.c (qual_signal): Check bounds for numeric signal names.
930 Fix parser of symbolic signal names.
931 Fix return code, as required by qualify() function.
932 * syscall.c (qual_desc): Check bounds for descriptor number.
933 * syscall.c (qual_syscall): Correct return code, to be consistent
934 with qualify() and other qual_* functions.
935 Fixes RH#143362.
936
Roland McGrath1b3ca102005-02-02 02:49:03 +00009372005-02-01 Roland McGrath <roland@redhat.com>
938
Roland McGrath0dfeed62005-02-02 04:36:38 +0000939 * system.c [LINUX] (MS_MANDLOCK, MS_NOATIME, MS_NODIRATIME, MS_BIND,
940 MS_MOVE, MS_REC, MS_VERBOSE, MS_POSIXACL, MS_ACTIVE, MS_NOUSER):
941 New macros.
942 [LINUX] (mount_flags): Add them.
943 [LINUX] (sys_mount): If any of (MS_BIND|MS_MOVE|MS_REMOUNT) bits are
944 set in the flags argument, don't try to fetch the filesystem string.
945 Fixes RH#141932.
946
Roland McGrathdc26fff2005-02-02 04:19:19 +0000947 * config.guess: Update from canonical version, timestamp 2004-11-12.
948 * config.sub: Likewise, timestamp 2004-11-30.
949
Roland McGrathb2ba50b2005-02-02 04:16:58 +0000950 * process.c [LINUX] [X86_64] (sys_arch_prctl): New function.
951 * linux/syscall.h: Declare it.
952 * linux/x86_64/syscallent.h: Use it.
953 Part of RH#142667.
954
955 * process.c (sys_sched_setscheduler): Use %#lx format for bad pointer.
956 (sys_sched_getparam, sys_sched_setparam): Likewise.
957 Part of RH#142667.
958
959 * signal.c [HAVE_SIGACTION] [LINUX && X86_64] (SA_RESTORER): Define
960 here too.
961 Part of RH#142667.
962
963 * linux/syscallent.h: Use sys_mincore instead of printargs.
964 * linux/x86_64/syscallent.h: Likewise. Also use sys_getrlimit,
965 sys_semtimedop, sys_umount2.
966 Part of RH#142667.
967
Roland McGrath28eace82005-02-02 03:51:22 +0000968 * syscall.c (qual_signal): Fix inverted return value and bogus
969 argument to qualify_one in the named case.
970
Roland McGrath5f221c32005-02-02 03:38:49 +0000971 * file.c (print_xattr_val): Don't use auto array sized by syscall
972 argument. Use malloc instead, so it can fail for insane values.
973 Fixes Debian bug #283704.
974
Roland McGrath53962332005-02-02 03:11:43 +0000975 * net.c (sys_getsockopt): Fix a format %ld -> %d.
976
977 * linux/syscall.h [IA64] (SYS_semtimedop): #undef it.
978
Roland McGrathbc484bd2005-02-02 03:07:24 +0000979 * syscall.c (syscall_enter) [X86_64]: Fix 32-bit argument register map
980 not to double the middle entry!
981 Fixes RH#146093.
982
Roland McGrath6722dcf2005-02-02 02:54:35 +0000983 * linux/x86_64/syscallent.h: Fix exit_group entry.
984
Roland McGrath1b3ca102005-02-02 02:49:03 +0000985 * util.c (getpc) [S390 || S390X]: Implement it.
986 Patch by David Wilder <wilder@us.ibm.com>.
987
988 * linux/ia64/syscallent.h: Add fadvise64, fstatfs64, statfs64, mbind,
989 [gs]et_mempolicy, mq_*, sys_kexec_load, vserver, and waitid.
990 Fixes RH#146245.
991
9922005-01-22 Andreas Schwab <schwab@suse.de>
993
994 * net.c (sys_getsockopt): Change type of len to int.
995
Roland McGrath914f3aa2004-10-19 23:00:14 +00009962004-10-19 Roland McGrath <roland@redhat.com>
997
Roland McGrathb0756892004-10-20 02:17:58 +0000998 * configure.ac, NEWS: Version 4.5.8.
999 * debian/changelog, strace.spec: 4.5.8-1.
1000
Roland McGrathbe4eeb92004-10-20 02:24:28 +00001001 * file.c (sys_fadvise64): Conditionalize just on [LINUX].
1002
Roland McGrathb0756892004-10-20 02:17:58 +00001003 * configure.ac: Check for sys/epoll.h.
1004 * desc.c: Protect #include <sys/epoll.h> with [HAVE_SYS_EPOLL_H].
1005 (epollctls, epollevents): Protect each entry with #ifdef on its macro.
1006
Roland McGrathe26a3782004-10-20 02:04:19 +00001007 * strace.c (handle_group_exit): Don't detach leader that wasn't
1008 TCB_ATTACHED. Instead mark it with TCB_GROUP_EXITING.
1009 Remove droptcb loop at end, no longer required since 2.6 reports each
1010 thread death.
1011 Fixes RH#135254.
1012
Roland McGrath712bc7a2004-10-20 01:00:45 +00001013 * strace.c (trace): Use handle_group_exit for non-TCB_ATTACHED child
1014 taking signal when it has nclone_threads > 0.
1015
Roland McGrath712bc7a2004-10-20 01:00:45 +00001016 * strace.c (handle_group_exit, trace): Mark leader with
1017 TCB_GROUP_EXITING and don't be surprised at child deaths when their
1018 leader has it set.
1019 Fixes RH#132150.
1020
Roland McGrath223a3ff2004-10-19 23:33:53 +00001021 * process.c (WCOREFLAG): Define if not defined.
1022 (W_STOPCODE, W_EXITCODE): Likewise.
1023 Reported by Marty Leisner <mleisner@eng.mc.xerox.com>.
1024
1025 * sock.c [! LINUX]: Include <sys/socket.h> before <sys/sockio.h>.
1026 Reported by Marty Leisner <mleisner@eng.mc.xerox.com>.
1027
1028 * debian/rules: Make strace64.1.gz symlink to strace.1.gz instead of
1029 strace64.1 to strace.1, which doesn't exist.
1030 Fixes Debian bug #269220.
1031
10322004-09-05 Phil Blundell <pb@nexus.co.uk>
1033
1034 * linux/arm/syscallent.h: New file.
1035
10362004-10-19 Roland McGrath <roland@redhat.com>
1037
1038 * debian/rules (DEB_BUILD_GNU_TYPE, CONFIG_OPTS): New variables.
1039 [$(DEB_HOST_GNU_TYPE) == s390-linux] (build64, HOST64, CC64): Set them.
1040 (build/Makefile): Use $(CONFIG_OPTS).
1041 (build64/Makefile): Pass --host as well as --build.
1042 From Bastian Blank <waldi@debian.org>.
1043 Fixes Debian bug #271500.
1044
1045 * linux/hppa/syscallent.h: Update for 2.6.9 syscalls.
1046 From Randolph Chung <tausq@debian.org>
1047 Fixes Debian bug #273887.
1048
Roland McGrath914f3aa2004-10-19 23:00:14 +00001049 * file.c (sys_llseek): Revert last change.
1050
Roland McGrath223a3ff2004-10-19 23:33:53 +000010512004-09-14 Richard Henderson <rth@twiddle.net>
1052
1053 * linux/alpha/syscallent.h: Add tgkill, *stat64, vserver, mbind,
1054 [gs]et_mempolicy, mq_*, waitid.
1055
Roland McGrath51f9ac02004-10-07 18:51:22 +000010562004-10-07 Roland McGrath <roland@redhat.com>
1057
Roland McGrath0aa53f62004-10-07 19:09:23 +00001058 * file.c (sys_llssek, sys_readahead, sys_fadvise64, sys_fadvise64_64):
1059 Use LONG_LONG macro.
1060 * io.c (sys_pread, sys_pwrite, sys_sendfile): Likewise.
1061
Roland McGrath61b324b2004-10-07 18:59:13 +00001062 * linux/x86_64/syscallent.h: Fix botched table entries.
1063 From Ulrich Drepper <drepper@redhat.com>.
1064
Roland McGrathaa08d712004-10-07 18:53:17 +00001065 * mem.c [LINUX] (sys_mbind, sys_set_mempolicy, sys_get_mempolicy):
1066 New functions.
1067 * linux/syscall.h: Declare them.
1068 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath61b324b2004-10-07 18:59:13 +00001069 From Ulrich Drepper <drepper@redhat.com>.
1070
Roland McGrathaa08d712004-10-07 18:53:17 +00001071 * linux/syscallent.h: Handle mbind, set_mempolicy, get_mempolicy.
1072 From Ulrich Drepper <drepper@redhat.com>.
1073
Roland McGrath51f9ac02004-10-07 18:51:22 +00001074 * file.c [LINUX && (I386 || X86_64)] (sys_fadvise64, sys_fadvise64_64):
1075 New functions.
1076 * linux/syscall.h: Declare them.
1077 * linux/syscallent.h: Handle fadvise64 and fadvise64_64 using those.
Roland McGrathaa08d712004-10-07 18:53:17 +00001078 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath51f9ac02004-10-07 18:51:22 +00001079 From Ulrich Drepper <drepper@redhat.com>.
1080
Roland McGrath2af128b2004-10-06 22:32:04 +000010812004-09-13 Dmitry V. Levin <ldv@altlinux.org>
1082
1083 * linux/ioctlsort.c (main): Omit duplicate lines
1084 (with same name and code) from output.
1085 * linux/ioctlent.sh: Build the list of ioctls defined in
1086 scsi/sg.h (0x22..), scsi/scsi.h and scsi/scsi_ioctl.h (0x53..),
1087 as suggested by Peter Jones <pjones@redhat.com>
1088 * linux/ioctlent.h: Regenerated.
1089 Fixes RH#129808.
1090
Roland McGrath79367f82004-10-06 22:28:17 +000010912004-09-13 Ulrich Drepper <drepper@redhat.com>
1092 Dmitry V. Levin <ldv@altlinux.org>
1093
1094 * time.c [LINUX] (print_rtc): New function, for printing rtc_time
1095 structure.
1096 [LINUX] (rtc_ioctl): New function, for parsing RTC_* ioctls.
1097 * ioctl.c [LINUX] (ioctl_decode): Call rtc_ioctl.
1098 * defs.h [LINUX]: Declare rtc_ioctl.
1099 Fixes RH#58606.
1100
Roland McGrath288a3a02004-10-06 22:12:09 +000011012004-10-06 Roland McGrath <roland@redhat.com>
1102
Roland McGrathd2553bb2004-10-06 22:23:55 +00001103 * desc.c [LINUX] (sys_epoll_create, sys_epoll_ctl, sys_epoll_wait):
1104 New functions.
1105 * linux/syscall.h: Declare them.
1106 * linux/syscallent.h: Use those for epoll_* syscalls.
1107 * linux/alpha/syscallent.h: Likewise.
1108 * linux/hppa/syscallent.h: Likewise.
1109 * linux/ia64/syscallent.h: Likewise.
1110 * linux/powerpc/syscallent.h: Likewise.
1111 * linux/s390/syscallent.h: Likewise.
1112 * linux/s390x/syscallent.h: Likewise.
1113 * linux/sparc/syscallent.h: Likewise.
1114 * linux/sparc64/syscallent.h: Likewise.
1115 * linux/sparc64/syscallent2.h: Likewise.
1116 * linux/x86_64/syscallent.h: Likewise.
1117 From Ulrich Drepper <drepper@redhat.com>.
1118 Fixes RH#134463.
1119
Roland McGrath2803d102004-10-06 22:15:18 +00001120 * resource.c (resources): Add RLIMIT_LOCKS, RLIMIT_SIGPENDING,
1121 and RLIMIT_MSGQUEUE, if defined.
1122 From Ulrich Drepper <drepper@redhat.com>.
1123 Fixes RH#133594.
1124
Roland McGrath288a3a02004-10-06 22:12:09 +00001125 * net.c [HAVE_SENDMSG] (printcmsghdr): New function.
1126 (printmsghdr): Use it.
Roland McGrath2803d102004-10-06 22:15:18 +00001127 From Ulrich Drepper <drepper@redhat.com>.
1128 Fixes RH#131689.
Roland McGrath288a3a02004-10-06 22:12:09 +00001129
1130 * file.c (sprintmode): Add const to return type.
1131 (sprintfstype): Likewise.
1132 * signal.c (printsiginfo): Add a const.
1133
Roland McGrath4455b1d2004-10-06 22:03:22 +000011342004-09-15 Roland McGrath <roland@redhat.com>
1135
1136 * linux/x86_64/syscallent.h: Use sys_waitid.
1137
1138 * linux/syscallent.h: waitid takes 5 arguments, and is in TP category.
1139 * process.c (sys_waitid): Handle fifth argument (struct rusage *).
1140
Roland McGrath813b8af2004-09-11 08:13:27 +000011412004-09-11 Roland McGrath <roland@redhat.com>
1142
1143 * time.c (sys_clock_nanosleep): Print zero flags arg correctly.
1144 (sys_timer_settime): Likewise.
1145 (printsigevent): Print signals by name for SIGEV_SIGNAL.
1146 (sys_timer_create): Print clock ID symbolically.
1147 From Ulrich Drepper <drepper@redhat.com>.
1148 Fixes RH#131420.
1149
Michal Ludvig51d1ebc2004-09-07 14:06:03 +000011502004-09-07 Michal Ludvig <mludvig@suse.cz>
1151
1152 * defs.h (nioctlents1, nsignals2): Fix typos in decls.
1153
Roland McGrath4ee6e692004-09-04 03:39:26 +000011542004-09-03 Roland McGrath <roland@redhat.com>
1155
Roland McGrathce361382004-09-04 04:20:49 +00001156 * syscall.c (qual_options): Add const to defn.
1157 Update all uses.
1158 (call_count, error_count, tv_count): Variables removed.
1159 (struct call_counts, counts): New type and variable.
1160 Update all users of the old three to use the new array of structs.
1161 (trace_syscall): Allocate counts on first use.
1162 (sorted_count): Variable removed.
1163 (call_summary): Allocate locally.
1164
Roland McGrath77019f72004-09-04 03:53:18 +00001165 * syscall.c (sysent0, sysent1, sysent2, sysent): Add const to defn.
1166 (nsyscalls0, nsyscalls1, nsyscalls2): Likewise.
1167 (errnoent0, errnoent1, errnoent2, errnoent): Likewise.
1168 (nerrnos0, nerrnos1, nerrnos2): Likewise.
1169 * signal.c (signalent0, signalent1, signalent2): Likewise.
1170 (nsignals0, nsignals1, nsignals2): Likewise.
1171 (signame): LIkewise.
1172 * ioctl.c (ioctlent0, ioctlent1, ioctlent2): Likewise.
1173 (nioctlents0, nioctlents1, nioctlents2): Likewise.
1174 (ioctl_lookup, ioctl_next_match): Likewise.
1175 * defs.h: Update decls.
1176 * io.c (sys_ioctl): Update users.
1177
Roland McGrath4ee6e692004-09-04 03:39:26 +00001178 * util.c (xlookup, printxval, addflags, printflags): Use const for
1179 struct xlat * argument.
1180 * defs.h (xlookup, printxval, addflags, printflags): Update decls.
1181 * bjm.c: Add const to all struct xlat defns.
1182 * desc.c: Likewise.
1183 * file.c: Likewise.
1184 * ipc.c: Likewise.
1185 * mem.c: Likewise.
1186 * net.c: Likewise.
1187 * proc.c: Likewise.
1188 * process.c: Likewise.
1189 * resource.c: Likewise.
1190 * signal.c: Likewise.
1191 * sock.c: Likewise.
1192 * stream.c: Likewise.
1193 * system.c: Likewise.
1194 * term.c: Likewise.
1195 * time.c: Likewise.
1196 * util.c: Likewise.
1197
Roland McGrathb036f582004-09-01 19:39:59 +000011982004-09-01 Roland McGrath <roland@redhat.com>
1199
1200 * linux/x86_64/syscallent.h: Add new entries for timer_*, clock_*, and
1201 mq_* syscalls, and names only for new calls up to 252.
1202 * linux/syscallent.h: Add waitid.
1203 * linux/x86_64/syscallent.h: Likewise.
1204 * linux/syscall.h: Declare sys_waitid.
1205
1206 * process.c (internal_wait): Take second arg giving index of flags
1207 argument.
1208 * defs.h: Update prototype.
1209 * syscall.c (internal_syscall): Update caller.
1210 Also use internal_wait for SYS_waitid.
1211 * process.c (sys_waitid): Define for [LINUX] as well.
1212 Don't tweak TCB_SUSPENDED--internal_wait does that.
1213 (waitid_types): Conditionalize use of nonstandard P_* macros.
1214
Roland McGrath1651c1c2004-08-31 07:16:21 +000012152004-08-31 Roland McGrath <roland@redhat.com>
1216
Roland McGrath0ef93b72004-08-31 08:17:26 +00001217 * configure.ac, NEWS: Version 4.5.7.
Roland McGrathb036f582004-09-01 19:39:59 +00001218 * debian/changelog: 4.5.7-1.
1219 * strace.spec: 4.5.7-2.
Roland McGrath0ef93b72004-08-31 08:17:26 +00001220
Roland McGrathf5fcbc12004-08-31 08:41:59 +00001221 * debian/rules: Rewrite sparc64 change of 2004-07-12.
1222 Always do each build in a separate build directory.
Roland McGrath0ef93b72004-08-31 08:17:26 +00001223 Fixes Debian bug #254728.
1224
Roland McGrathf5fcbc12004-08-31 08:41:59 +00001225 * time.c (clocknames): Use #ifdef around CLOCK_* uses.
1226
Roland McGrathdc025fa2004-08-31 07:48:03 +00001227 * strace.1: Say that -c shows system CPU time, not real time.
1228 Fixes Debian bug #254438.
1229
1230 * syscall.c (dumpio): Match pread and pwrite system calls too.
1231 Fixes Debian bug #239947.
1232
Roland McGrath1651c1c2004-08-31 07:16:21 +00001233 * net.c (sockoptions): Add all SO_* macros known in Linux 2.6.9.
1234 Fixes Debian bug #171653.
1235
Roland McGrath8e593d22004-08-31 07:03:43 +000012362004-07-12 Dmitry V. Levin <ldv@altlinux.org>
1237
1238 * signal.c [LINUX] (parse_sigset_t): Fix hex strings parser.
1239 Fixes RH#128091.
1240
Roland McGratha0b9ef12004-08-31 06:30:51 +000012412004-08-30 Roland McGrath <roland@redhat.com>
1242
Roland McGrath0a053252004-08-31 07:02:00 +00001243 * strace.c (main): Don't call fake_execve under -c.
1244 From Ulrich Drepper <drepper@redhat.com>.
1245 Fixes RH#129166.
1246
1247 * net.c (sockipoptions): Add some options.
1248 [SOL_IPV6] (sockipv6options): New variable.
1249 (sys_getsockopt, printsockopt): Use it for SOL_IPV6 level.
1250 From Ulrich Drepper <drepper@redhat.com>.
1251 Fixes RH#128391.
1252
Roland McGrath7fbbf022004-08-31 06:52:49 +00001253 * time.c (clocknames): New variable, symbolic names for clock_t.
1254 (sys_clock_settime, sys_clock_gettime, sys_clock_nanosleep): Use it.
1255 From Ulrich Drepper <drepper@redhat.com>.
1256 Fixes RH#129378.
1257
Roland McGrath3a71f192004-08-31 06:49:09 +00001258 * system.c (personality_options): Hard-code values here.
1259 Don't #include <linux/personality.h> at all.
Roland McGrath1651c1c2004-08-31 07:16:21 +00001260 Fixes RH#130965 and Debian bug #40588.
Roland McGrath3a71f192004-08-31 06:49:09 +00001261
Roland McGratha0b9ef12004-08-31 06:30:51 +00001262 * file.c (print_xattr_val): New function to show attribute values.
1263 (sys_setxattr, sys_fsetxattr, sys_getxattr, sys_fgetxattr): Use it.
1264 From Ulrich Drepper <drepper@redhat.com>.
1265 Fixes RH#131177.
1266
Roland McGrath90a5a942004-07-12 07:04:55 +000012672004-07-12 Roland McGrath <roland@redhat.com>
1268
Roland McGrathd51619a2004-07-12 07:56:00 +00001269 * configure.ac, NEWS: Version 4.5.6.
1270 * strace.spec, debian/changelog: 4.5.6-1.
1271
Roland McGrath05cf2952004-07-12 07:54:09 +00001272 * Makefile.am (EXTRA_DIST): Add linux/sparc64 files.
1273
1274 * debian/rules: On sparc-linux, build strace64 as well.
1275 From Ben Collins <bcollins@debian.org>.
1276 Fixes Debian bug #254728.
1277
12782004-07-07 David S. Miller <davem@nuts.davemloft.net>
1279
1280 * linux/sparc/syscallent.h: Sync with reality.
1281 * linux/sparc/syscall.h (sys_sendfile64, sys_futex, sys_gettid,
1282 sys_sched_setaffinity, sys_sched_getaffinity, sys_setxattr,
1283 sys_lsetxattr, sys_fsetxattr, sys_getxattr, sys_lgetxattr,
1284 sys_fgetxattr, sys_listxattr, sys_llistxattr, sys_flistxattr,
1285 sys_removexattr, sys_lremovexattr, sys_fremovexattr,
1286 sys_remap_file_pages, sys_readahead, sys_tgkill, sys_statfs64,
1287 sys_fstatfs64, sys_clock_settime, sys_clock_gettime,
1288 sys_clock_getres, sys_clock_nanosleep, sys_timer_create,
1289 sys_timer_settime, sys_timer_gettime): New declarations.
1290 * linux/sparc64/dummy2.h, linux/sparc64/syscallent2.h,
1291 linux/sparc64/syscall.h, linux/sparc64/errnoent.h,
1292 linux/sparc64/errnoent1.h, linux/sparc64/errnoent2.h,
1293 linux/sparc64/ioctlent.h, linux/sparc64/ioctlent1.h,
1294 linux/sparc64/ioctlent2.h, linux/sparc64/signalent.h,
1295 linux/sparc64/signalent.h, linux/sparc64/signalent.h,
1296 linux/sparc64/signalent1.h, linux/sparc64/signalent2.h,
1297 linux/sparc64/syscall1.h, linux/sparc64/syscallent.h,
1298 linux/sparc64/syscallent1.h: New files.
1299 * defs.h (LINUXSPARC): Define also when SPARC64.
1300 (LINUX && SPARC64): Set SUPPORTED_PERSONALITIES to 3.
1301 Ignore SIGTRAP after execve by defining TCB_WAITEXECVE.
1302 Define possibly missing __NR_exit_group. Declare getrval2.
1303 * configure.ac (sparc64): New architecture case.
1304 * file.c (stat_sparc64): New structure.
1305 (printstat_sparc64): New output routine for that.
1306 (printstat): Call it, if personality is 2.
1307 (printstat64): Likewise.
1308 * util.c: Conditionalize ptrace defines on LINUXSPARC
1309 not LINUX && SPARC.
1310 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1311 to PTRACE_FOOREGS64 so that more sparc code can be shared
1312 between 64-bit and 32-bit.
1313 (_hack_syscall5): Correct trap number when SPARC64.
1314 (PTRACE_WRITE{TEXT,DATA}): Add SPARC64 to ifdef guard.
1315 (getpc): Handle SPARC64 && LINUX.
1316 (printcall): Likewise.
1317 (arg fetching/setting): Use same code for SPARC64 LINUX
1318 as for SPARC.
1319 (setbpt): Handle SPARC64 && LINUX.
1320 (clearbpt): Likewise.
1321 * signal.c: Conditionalize ptrace defines on SPARC and
1322 SPARC64.
1323 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1324 to PTRACE_FOOREGS64 so that more sparc code can be shared
1325 between 64-bit and 32-bit.
1326 (m_siginfo): Use same definition on SPARC64 as SPARC.
1327 (sys_sigreturn): Handle LINUX && SPARC64.
1328 * syscall.c: Conditionalize ptrace defines on SPARC and
1329 SPARC64.
1330 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1331 to PTRACE_FOOREGS64 so that more sparc code can be shared
1332 between 64-bit and 32-bit.
1333 (getscno): Use same static state on SPARC64 as SPARC,
1334 and add SPARC64 handling.
1335 (get_error): Handle LINUX && SPARC64.
1336 (force_result): Likewise.
1337 (syscall_enter): Likewise.
1338 (trace_syscall): Handle sys_socketcall and sys_ipc on SPARC64
1339 just like SPARC.
1340 (getrval2): Handle LINUX && SPARC64.
1341 * process.c: Conditionalize ptrace defines on SPARC and
1342 SPARC64.
1343 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1344 to PTRACE_FOOREGS64 so that more sparc code can be shared
1345 between 64-bit and 32-bit.
1346 (change_syscall): Handle LINUX && SPARC64.
1347 (struct_user_offsets): Ifdef out those which do not exist
1348 on SPARC64.
1349 * net.c (sys_pipe): Handle LINUX && SPARC64.
1350 * ioctl.c: Fix initializer typo for nioctlents2, was
1351 nioctlents1 by accident.
1352
13532004-06-28 Andreas Schwab <schwab@suse.de>
1354
1355 * process.c (internal_exec): Move TCB_WAITEXECVE handling here.
1356 (sys_execve): Remove it here.
1357
13582004-07-12 Roland McGrath <roland@redhat.com>
1359
1360 * Makefile.am (EXTRA_DIST): Add linux/sh64/syscallent.h.
1361
1362 * debian/control (Section): Move to utils, matching Debian override.
1363
Roland McGrath23e86d62004-07-12 07:13:12 +00001364 * net.c (addrfams): Make variable global.
1365 * sock.c (sock_ioctl): Decode the arguments for SIOCGIFNAME,
1366 SIOCGIFINDEX, and SIOCGIFCONF.
1367 From Ulrich Drepper <drepper@redhat.com>.
1368 Fixes RH#126917.
1369
Roland McGrath90a5a942004-07-12 07:04:55 +00001370 * linux/ioctlsort.c: Add some #includes.
1371 [POWERPC]: Kludge out high bits.
1372 * linux/ia64/ioctlent.h: Regenerated using RHEL3 headers.
1373 * linux/powerpc/ioctlent.h: Likewise.
1374
Roland McGrath16110b22004-07-12 05:45:26 +000013752004-07-11 Roland McGrath <roland@redhat.com>
1376
Roland McGrath90a5a942004-07-12 07:04:55 +00001377 * linux/ioctlent.sh: Replace asm with $asm in all places.
1378
Roland McGrath16110b22004-07-12 05:45:26 +00001379 * configure.ac: Add I386 as AM_CONDITIONAL.
1380 * Makefile.am [LINUX]: Add maintainer-mode rules to regenerate
1381 the ioctlent.h file.
1382
Roland McGrath533e52a2004-07-08 19:00:25 +000013832004-07-08 Roland McGrath <roland@redhat.com>
1384
1385 * resource.c (sys_quotactl): Truncate first argument to 32 bits, since
1386 that's what the kernel will do.
1387
13882004-07-07 Roland McGrath <roland@redhat.com>
1389
1390 * linux/ioctlent.sh: Take optional second argument to use as directory
1391 name in place of `asm'.
1392
Roland McGrath2c72f3c2004-06-28 05:24:40 +000013932004-06-27 Roland McGrath <roland@redhat.com>
1394
1395 * configure.ac, NEWS: Version 4.5.5.
1396 * strace.spec, debian/changelog: 4.5.5-1.
1397
Roland McGratha2dec922004-06-23 01:40:57 +000013982004-06-22 Roland McGrath <roland@redhat.com>
1399
1400 * syscall.c (syscall_fixup) [LINUX && X86_64]: For 32-bit process,
1401 sign extend the low 32 bits of RAX to 64 bits.
Roland McGrath7a391df2004-06-23 01:41:30 +00001402 Fixes RH#126547.
Roland McGratha2dec922004-06-23 01:40:57 +00001403
1404 * syscall.c (force_result): [LINUX && X86_64]: Fix RAX*4 -> RAX*8.
1405
Roland McGrath0c542de2004-06-04 02:25:12 +000014062004-06-03 Roland McGrath <roland@redhat.com>
1407
Roland McGrath66a77f12004-06-04 02:36:03 +00001408 * configure.ac, NEWS: Version 4.5.4.
1409 * strace.spec, debian/changelog: 4.5.4-1.
1410
Roland McGrath0c542de2004-06-04 02:25:12 +00001411 * net.c (domains): Add many PF_* values #ifdef PF_*.
1412 (addrfams): Add many AF_* values #ifdef AF_*.
1413 Fixes Debian bug #250506.
1414
Roland McGrath337d3912004-06-04 02:03:15 +000014152004-05-02 Dmitry V. Levin <ldv@altlinux.org>
1416
1417 * linux/ioctlsort.c (compare): When ioctl codes equal, compare
1418 names.
1419 (main): Print a note that program output is generated by
1420 ioctlsort.
1421 * linux/ioctlent.sh: Build the list of ioctls defined in
1422 linux/fb.h (0x46..), linux/kd.h (0x4B..), linux/cdrom.h (0x53..),
1423 asm/ioctls.h (0x54..), linux/vt.h (0x56..), linux/videotext.h
1424 (0x71..), linux/videotext.h (0x72..), asm/sockios.h (0x89..),
1425 linux/sockios.h (0x89..), linux/wireless.h (0x8B..).
1426 * linux/ioctlent.h: Regenerated from linux-2.6.5.
1427 Fixes RH#122257.
1428
Roland McGrath6d52da62004-06-04 01:50:53 +000014292004-06-03 Roland McGrath <roland@redhat.com>
1430
Roland McGrathe01b8ce2004-06-04 02:01:54 +00001431 * debian/control (Architecture): Add amd64.
1432 Fixes Debian bug #246568.
1433
Roland McGrath6d52da62004-06-04 01:50:53 +00001434 * strace.c (main) [LINUX]: Expand TCBTAB as necessary for threads
1435 attached. Attach threads only under -f. Set TCB_FOLLOWFORK in them.
1436 (expand_tcbtab): New function, broken out of ...
1437 * process.c (fork_tcb): ... here, call that.
1438 * defs.h: Declare expand_tcbtab.
1439
Roland McGrath25e82592004-06-04 01:24:12 +000014402004-04-19 Roland McGrath <roland@redhat.com>
1441
1442 * process.c (printstatus): Add a space before | in output.
1443
Roland McGrathea2402e2004-04-16 22:28:48 +000014442004-04-16 Roland McGrath <roland@redhat.com>
1445
1446 * configure.ac: Version 4.5.3.
1447 * strace.spec, debian/changelog: 4.5.3-1.
1448
Roland McGrath025442c2004-04-16 21:59:05 +000014492004-03-18 Dmitry V. Levin <ldv@altlinux.org>
1450
1451 * resource.c (sys_quotactl) [LINUX]: Cast arithmetic shift operand
1452 from long to unsigned long, to fix output of the quotactl command
1453 parser.
Roland McGrathea2402e2004-04-16 22:28:48 +00001454 Fixes RH#118694.
Roland McGrath025442c2004-04-16 21:59:05 +00001455
Roland McGrath8d1bf3c2004-04-16 21:48:43 +000014562004-04-16 Roland McGrath <roland@redhat.com>
1457
Roland McGrath025442c2004-04-16 21:59:05 +00001458 * linux/s390/ioctlent.h, linux/s390x/ioctlent.h: Update DASD ioctls.
1459 From Maxim Shchetynin <maxim@de.ibm.com>.
1460
Roland McGrath8d1bf3c2004-04-16 21:48:43 +00001461 * configure.ac: Check for <mqueue.h>.
1462 * ipc.c (sys_mq_open, printmqattr) [! HAVE_MQUEUE_H]: Don't try to
1463 decode struct mq_attr.
Roland McGrath6508d332004-04-16 21:54:59 +00001464 * NEWS: Mention mq support.
Roland McGrath8d1bf3c2004-04-16 21:48:43 +00001465
1466 * linux/syscall.h: Support new mq_* syscalls on Linux.
1467 * linux/syscallent.h: Likewise.
1468 * linux/dummy.h: Likewise.
1469 * ipc.c: Likewise.
1470 * time.c (printsigevent): Handle SIGEV_THREAD.
1471 From Ulrich Drepper <drepper@redhat.com>.
1472 Fixes RH#120701.
1473
Roland McGrath6421d632004-04-14 02:46:35 +000014742004-04-13 Roland McGrath <roland@redhat.com>
1475
Roland McGrath085bae12004-04-14 02:54:02 +00001476 * net.c (msg_flags): Grok MSG_FIX, MSG_SYN, MSG_RST, MSG_NOSIGNAL,
1477 MSG_MORE.
1478 From Ulrich Drepper <drepper@redhat.com>.
1479 Fixes RH#120541.
1480
Roland McGrath6421d632004-04-14 02:46:35 +00001481 * process.c (printstatus): Mask out bits presented symbolically, and
1482 print "| 0xnnn" if the remaining bits are not all zero.
1483 Fixes Debian bug #240062.
1484
1485 * process.c (print_affinitylist): Rewritten to handle indirect values.
1486 (sys_sched_setaffinity, sys_sched_getaffinity): Update callers.
1487 From Ulrich Drepper <drepper@redhat.com>.
1488 Fixes RH#118685.
1489
1490 * acinclude.m4: Quote first argument to AC_DEFUN in all cases.
1491
Roland McGrath74dcbd82004-04-09 00:25:47 +000014922004-04-08 Roland McGrath <roland@redhat.com>
1493
1494 * strace.c (main) [LINUX]: When attaching for -p, look in
1495 /proc/PID/task for all threads and attach them as presumed
1496 CLONE_THREAD children.
1497 * NEWS: Mention the feature.
Roland McGrath085bae12004-04-14 02:54:02 +00001498 Fixes RH#120462.
Roland McGrath74dcbd82004-04-09 00:25:47 +00001499
Roland McGrath2d1ecca2004-03-02 08:07:20 +000015002004-03-02 Roland McGrath <roland@redhat.com>
1501
Roland McGrath6835f232004-03-02 08:50:47 +00001502 * util.c (setbpt): Fix one missed spot to use new arg0_index macro.
1503 From Michael Holzheu <HOLZHEU@de.ibm.com>.
1504
Roland McGrath2d1ecca2004-03-02 08:07:20 +00001505 * debian/control (Standards-Version): Update to 3.6.1.
1506
Roland McGrath861dc142004-03-01 20:57:16 +000015072004-03-01 Roland McGrath <roland@redhat.com>
1508
Roland McGrath801bf1f2004-03-02 06:38:40 +00001509 * configure.ac, NEWS: Version 4.5.2.
Roland McGrathea2402e2004-04-16 22:28:48 +00001510 * strace.spec, debian/changelog: 4.5.2-1.
Roland McGrath801bf1f2004-03-02 06:38:40 +00001511
Roland McGrath30423402004-03-02 06:54:57 +00001512 * strace.c (main): Avoid potential buffer overruns from ludicrous
1513 arguments or PATH values.
1514 * syscall.c (qual_signal): Bail out for too-long string.
1515
Roland McGrath59aea572004-03-02 06:17:11 +00001516 * mem.c [LINUX]: <asm/mman.h> -> <linux/mman.h>
Roland McGrath5586f9a2004-03-02 06:23:08 +00001517 Fixes Debian bug #223207.
Roland McGrath59aea572004-03-02 06:17:11 +00001518
1519 * linux/sparc/syscall.h: Copy linux/syscall.h decls of sys_sched_*.
Roland McGrath8f30c1d2004-03-02 06:09:35 +00001520
Roland McGrath7da8ff72004-03-01 22:10:58 +00001521 * configure.ac: Check for `struct user_desc' in <asm/ldt.h>.
1522 * process.c [HAVE_STRUCT_USER_DESC]: Use struct user_desc in place of
1523 struct modify_ldt_ldt_s.
1524 * mem.c [HAVE_STRUCT_USER_DESC]: Likewise.
1525
1526 * system.c (sysctl_vm): Conditionalize VM_* macro uses, add some more.
1527 From Tim Yamin <plasmaroo@gentoo.org>.
1528
Roland McGrathce238102004-03-01 22:04:09 +00001529 * process.c (sys_execve): Clear instead of set TCB_WAITEXECVE on
1530 erring syscall.
1531
Roland McGrathe58b8a02004-03-01 21:29:31 +00001532 * configure.ac: Check for `struct pt_all_user_regs'
1533 and `struct ia64_fpreg' in <sys/ptrace.h>.
Roland McGrath4695e942004-03-01 21:31:07 +00001534 * util.c, process.c, syscall.c, signal.c: Work around conflicts between
Roland McGrathe58b8a02004-03-01 21:29:31 +00001535 <sys/ptrace.h> and <linux/ptrace.h> for defining those types.
1536
Roland McGrath4695e942004-03-01 21:31:07 +00001537 * process.c (struct_user_offsets) [LINUX && IA64]: Conditionalize
1538 PT_AR_CSD and PT_AR_SSD uses in case of older kernel headers.
1539
Roland McGrath861dc142004-03-01 20:57:16 +00001540 * util.c [LINUX] (arg0_index, arg1_index): New macros.
1541 [S390 || S390X]: Define them with inverted values.
1542 (setbpt): Use them for u_arg indices.
1543
Roland McGrath24e8d312004-03-01 20:30:51 +000015442004-02-26 Andreas Schwab <schwab@suse.de>
1545
1546 * defs.h [LINUX && IA64]: Declare getrval2 also on IA64.
1547 * net.c (sys_pipe) [LINUX && IA64]: For IA64 use the two return values.
1548 * syscall.c (getrval2) [LINUX && IA64]: Implement for IA64.
1549
Roland McGrath176ac322004-03-01 20:28:19 +000015502004-03-01 Roland McGrath <roland@redhat.com>
1551
1552 * linux/dummy.h (sys_sched_getscheduler, sys_sched_setparam,
1553 sys_sched_getparam, sys_sched_setscheduler, sys_sched_getscheduler,
1554 sys_sched_get_priority_max, sys_sched_get_priority_min): Remove macros.
1555 * process.c [LINUX] (sys_sched_getscheduler, sys_sched_setparam,
1556 sys_sched_getparam, sys_sched_setscheduler, sys_sched_getscheduler,
1557 sys_sched_get_priority_min): New functions.
1558 From Ulrich Drepper <drepper@redhat.com>.
1559 Fixes RH#116990.
1560
Roland McGrath3d3f1c92004-02-20 23:21:34 +000015612004-02-20 Roland McGrath <roland@redhat.com>
1562
1563 * linux/hppa/syscallent.h: Update some syscalls.
1564 From Randolph Chung <tausq@debian.org>.
1565 Fixes Debian bug #231632.
1566
Roland McGrathb233c262004-02-20 22:56:55 +000015672003-12-31 David Mosberger <davidm@hpl.hp.com>
1568
1569 * process.c (internal_exit): For ia64, also recognize IA-32 252
1570 as exit_group().
1571 (change_syscall): For IA64, also support changing IA-32 syscalls.
1572 * syscall.c (internal_syscall): For IA64, also recognize IA-32
1573 syscall 252 (exit_group) as an internal_exit() syscall.
1574 * util.c (SYS_fork): For IA64, define them to the IA-32 syscall
1575 number.
1576 (SYS_vfork): Likewise.
1577 (arg_setup): For IA64 version, also support IA-32 syscalls.
1578 (get_arg0): Likewise.
1579 (get_arg1): Likewise.
1580 (set_arg0): Likewise.
1581 (set_arg1): Likewise.
1582
Roland McGrath13aeab32004-02-20 02:25:42 +000015832004-02-15 Anton Blanchard <anton@samba.org>
1584
1585 * linux/powerpc/syscallent.h: Add rtas call.
1586 Shift multiplexed syscalls to start at 300, we are already about
1587 to hit 256 real syscalls.
1588 * linux/syscall.h: SYS_socket_subcall is now 300 for [POWERPC].
1589
15902004-02-19 Roland McGrath <roland@redhat.com>
1591
1592 * strace.c (main): Use TCP->pid, not PID, in -p message.
1593 Fixes Debian bug #229802.
1594
Roland McGrathec0cf0b2004-01-13 10:18:52 +000015952004-01-13 Roland McGrath <roland@redhat.com>
1596
Roland McGrath13aeab32004-02-20 02:25:42 +00001597 * syscall.c (force_result) [LINUX] [S390 || S390X]: Remove bogus upeek
1598 call.
1599
Roland McGrathec0cf0b2004-01-13 10:18:52 +00001600 * stream.c (internal_stream_ioctl): Fix typo strict -> struct.
1601 Reported by Petter Reinholdtsen <pere@hungry.com>.
1602
Roland McGrath135db892004-01-13 10:14:04 +000016032003-12-31 David Mosberger <davidm@hpl.hp.com>
1604
1605 * process.c (struct_user_offsets) [IA64]: Fix up register name list.
1606
Roland McGrath13aeab32004-02-20 02:25:42 +000016072003-12-14 Anton Blanchard <anton@samba.org>
Roland McGrath135db892004-01-13 10:14:04 +00001608
Roland McGrath75155472004-01-13 10:17:00 +00001609 * file.c (sys_getdents64): Don't cast d_ino and d_off to unsigned long.
1610 Use %llu formats for them.
1611
Roland McGrath135db892004-01-13 10:14:04 +00001612 * file.c [LINUX] (fsmagic): Add SYSFS_MAGIC.
1613
1614 * linux/powerpc/syscallent.h: Update to include recently added
1615 syscalls.
1616
1617 * syscall.c (get_error) [POWERPC]: Cast result to unsigned long for
1618 ppc64, we were misreporting syscalls that really succeeded as having
1619 failed.
1620
Roland McGrath5b7aa682004-01-13 09:52:52 +000016212004-01-13 Roland McGrath <roland@redhat.com>
1622
Roland McGrath8950c692004-01-13 10:00:01 +00001623 * strace.1: Remove comment about vfork on Linux.
1624 Fixes Debian bug #223390.
1625
Roland McGrath5b7aa682004-01-13 09:52:52 +00001626 * file.c (direnttypes): Define under [LINUX] as well. Add DT_UNKNOWN.
1627 (sys_getdents64) [LINUX]: Print d_type field.
1628
Roland McGrath13aeab32004-02-20 02:25:42 +000016292003-12-15 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath8950c692004-01-13 10:00:01 +00001630
1631 * strace.c (trace) [WCOREDUMP]: Show coredump status of the
Roland McGrath135db892004-01-13 10:14:04 +00001632 killed process if available. Fixes RH#112117.
Roland McGrath8950c692004-01-13 10:00:01 +00001633
Roland McGrathcf283032003-11-14 02:57:31 +000016342003-11-13 Roland McGrath <roland@redhat.com>
1635
1636 * configure.ac, NEWS: Version 4.5.1.
1637 * strace.spec, debian/changelog: 4.5.1-1.
1638
Roland McGrath13aeab32004-02-20 02:25:42 +000016392003-09-06 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath0aac8722003-11-14 02:54:09 +00001640
1641 * defs.h (ioctl_lookup): Prototype change.
1642 * ioctl.c (ioctl_next_match): New function.
1643 * defs.h: Declare it.
1644 * io.c (sys_ioctl): Use it, to display all possible ioctl names
1645 when there's more than one match.
1646 * ioctl.c (ioctl_lookup): Likewise.
1647 * stream.c (internal_stream_ioctl): Likewise.
1648 Patch from Solar Designer <solar@openwall.com>.
1649
Roland McGrath09f7a012003-11-13 22:32:32 +000016502003-11-13 Roland McGrath <roland@redhat.com>
1651
1652 * linux/sh/syscallent.h: Use sys_setgroups32, sys_getgroups32.
1653 * linux/sh64/syscallent.h: Likewise.
1654
Roland McGrath13aeab32004-02-20 02:25:42 +000016552003-09-06 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath09f7a012003-11-13 22:32:32 +00001656
Roland McGrathf25ef392003-11-13 22:33:48 +00001657 Fixes for RH#105359.
Roland McGrath09f7a012003-11-13 22:32:32 +00001658 * util.c (printuid): New function.
1659 * defs.h: Declare it.
1660 * file.c (sys_chown): Use it.
1661 * file.c (sys_fchown): Likewise.
1662 * process.c (sys_setreuid, sys_setregid, sys_setresuid,
1663 sys_setresgid): Likewise.
Roland McGrath09f7a012003-11-13 22:32:32 +00001664 * linux/syscallent.h: Better handle getgid32, geteuid32, getegid32,
1665 setreuid32, setregid32, getgroups32, setgroups32, fchown32,
1666 setresuid32, getresuid32, setresgid32, getresgid32, chown32,
1667 setuid32, setgid32, setfsuid32, setfsgid32.
1668 * process.c [LINUX]: Define GETGROUPS32_T.
1669 * process.c [LINUX] (sys_setgroups32, sys_getgroups32):
1670 New functions.
1671 * linux/syscall.h (sys_setgroups32, sys_getgroups32):
1672 Declare them.
1673
Roland McGrath730e8c02003-11-11 21:24:28 +000016742003-11-11 Roland McGrath <roland@redhat.com>
1675
1676 * strace.c (main): Bail with usage error for missing command before we
1677 open the -o file or fiddle uids.
1678
Roland McGrathe52919b2003-11-06 23:41:33 +000016792003-11-06 Roland McGrath <roland@redhat.com>
1680
Roland McGratha0f32e02003-11-07 02:36:45 +00001681 * strace.c (main): Treat piped output more like file output.
1682 Disallow -ff with piped output. Fixes RH#105366.
1683 Reported by Dmitry V. Levin <ldv@altlinux.org>
1684
Roland McGrathe52919b2003-11-06 23:41:33 +00001685 * strace.c (tprintf): Check result of vfprintf and use perror when it
1686 fails while not writing to stderr itself. Fixes Debian bug #218762.
1687
1688 * net.c (printsock): Fix typo in #ifdef AF_NETLINK.
1689 From Ulrich Drepper <drepper@redhat.com>.
1690
Roland McGrathb67e8e32003-11-01 22:11:29 +000016912003-11-01 Roland McGrath <roland@redhat.com>
1692
1693 * syscall.c (trace_syscall) [LINUX]: Calculate ONE_TICK once using
1694 setitimer rather than hard-coding a value based on HZ.
Roland McGrathd4897f82003-11-01 22:13:35 +00001695 Fixes RH#108012, reported by Florian La Roche <laroche@redhat.com>.
Roland McGrathb67e8e32003-11-01 22:11:29 +00001696
Roland McGratha9f76da2003-10-22 06:11:36 +000016972003-10-21 Roland McGrath <roland@redhat.com>
1698
Roland McGrath7aa6d202003-10-22 06:16:42 +00001699 * strace.1: Fixed a few spelling errors.
Roland McGrathb67e8e32003-11-01 22:11:29 +00001700 Fixes Debian bug #217008.
Roland McGrath7aa6d202003-10-22 06:16:42 +00001701
Roland McGratha9f76da2003-10-22 06:11:36 +00001702 * syscall.c: Revert last change, was broken.
1703
Roland McGrath8c74bd92003-10-01 07:50:34 +000017042003-10-01 Roland McGrath <roland@redhat.com>
1705
Roland McGrathe7da3502003-10-01 21:59:50 +00001706 * process.c (internal_clone): Don't suspend parent when call requested
1707 a specific PID that is not a traced child.
1708
Roland McGrath8c74bd92003-10-01 07:50:34 +00001709 * signal.c [LINUX] (parse_sigset_t): Rewrite to process hex strings
1710 from right to left so we don't have to presume the size.
Roland McGrathe7da3502003-10-01 21:59:50 +00001711 Reported by David Woodhouse <dwmw2@redhat.com>.
Roland McGrath8c74bd92003-10-01 07:50:34 +00001712
Roland McGrath268e9042003-09-25 23:06:12 +000017132003-09-25 Roland McGrath <roland@redhat.com>
1714
1715 * mem.c (mmap_prot) [PROT_SEM, PROT_GROWSDOWN, PROT_GROWSUP]: Include
1716 these in the table if they are defined.
1717
Roland McGrath4f59bab2003-09-24 22:22:49 +000017182003-09-24 Roland McGrath <roland@redhat.com>
1719
1720 * configure.ac, NEWS: Version 4.5.
1721 * strace.spec, debian/changelog: 4.5-1.
1722
1723 * syscall.c (get_scno) [LINUX] [S390 || S390X]: Bail out of
1724 instruction decoding branch if TCB_INSYSCALL is clear.
1725 Reported by <jochen@penguin-breeder.org>.
1726
1727 * linux/ioctlent.h: Swap order of overloaded TC* and SNDCTL_* values.
1728
Roland McGrath7633f1e2003-09-23 22:19:43 +000017292003-09-23 Roland McGrath <roland@redhat.com>
1730
Roland McGrath4f59bab2003-09-24 22:22:49 +00001731 * strace.spec: On ppc64 (maybe others later), create an strace64
1732 package as well containing just /usr/bin/strace64.
1733
Roland McGrath7633f1e2003-09-23 22:19:43 +00001734 * signal.c (sprintsigmask): Print RT_%u for __SIGRTMIN..__SIGRTMAX.
1735 Fixes RH#104365.
1736
Roland McGrath109f3d32003-08-21 10:09:01 +000017372003-08-21 Roland McGrath <roland@redhat.com>
1738
Roland McGrath7633f1e2003-09-23 22:19:43 +00001739 * linux/syscallent.h: Fix mlock argument count. Fixes RH#101499.
Roland McGrath109f3d32003-08-21 10:09:01 +00001740 * linux/x86_64/syscallent.h: Likewise.
1741 * linux/s390/syscallent.h: Likewise.
1742 * linux/s390x/syscallent.h: Likewise.
1743
Roland McGrath5bc53452003-08-21 09:58:08 +000017442003-07-28 Daniel Jacobowitz <drow@mvista.com>
1745
1746 * defs.h (ALIGN64): Define for MIPS.
1747 * io.c (PREAD_OFFSET_ARG): Define.
1748 (sys_pread, sys_pwrite): Use it.
1749 * process.c (struct_user_offsets) [SH]: Check whether REG_XDREG0
1750 is defined.
1751 * linux/sh/syscallent.h (pread, pwrite): Take six arguments.
1752 (truncate64, ftruncate64): Pretty-print.
1753 * linux/mips/syscallent.h (pread, pwrite): Take six arguments.
1754 (truncate64, ftruncate64): Take four arguments.
1755
Roland McGrath4d8130c2003-07-17 09:24:04 +000017562003-07-17 Roland McGrath <roland@redhat.com>
1757
1758 * configure.ac, NEWS: Version 4.4.99.
1759 * strace.spec, debian/changelog: 4.4.99-1.
1760
Roland McGrath25969ce2003-07-17 09:03:22 +000017612003-07-15 Anton Blanchard <anton@samba.org>
1762
1763 * ipc.c: Add SHM_HUGETLB field.
1764 Mask out permission bits in msgget, semget and shmget before
1765 printing resource_flags.
1766 Mask execute permission bits (even though we dont currently
1767 use them).
1768
17692003-07-17 Roland McGrath <roland@redhat.com>
1770
1771 * linux/powerpc/syscallent.h (tgkill): New at 250.
1772
1773 * linux/syscallent.h: truncate64/ftruncate64 need 3 args.
1774 From Ulrich Drepper <drepper@redhat.com>.
1775
1776 * linux/syscallent.h: Handle statfs64, fstatfs64, utimes.
1777 * file.c (printstatfs): Print f_fsid and f_frsize.
1778 [LINUX] (printstatfs64, sys_statfs64, sys_fstatfs64): New functions.
1779 * linux/syscall.h: Add decls.
1780 From Ulrich Drepper <drepper@redhat.com>.
1781
17822003-07-09 Roland McGrath <roland@redhat.com>
1783
1784 * linux/ia64/syscallent.h (tgkill): New at 1235.
1785
Roland McGrath004d88d2003-07-09 09:48:21 +000017862003-07-05 Richard Henderson <rth@twiddle.net>
1787
1788 * process.c (sys_clone): Order arguments for alpha the same as x86_64.
1789 * syscall.c (ERESTART_RESTARTBLOCK): New.
1790 (trace_syscall): Print it.
1791 * linux/alpha/syscallent.h (osf_syscall): Name properly.
1792 (osf_set_program_attributes): Fix typo.
1793 (osf_nfssvc): Likewise.
1794 (osf_sigsendset): Likewise.
1795 (getdents64, gettid, readahead, tkill, setxattr, lsetxattr, fsetxattr,
1796 getxattr, lgetxattr, fgetxattr, listxattr, llistxattr, flistxattr,
1797 removexattr, lremovexattr, fremovexattr, futex, sched_setaffinity,
1798 sched_getaffinity, tuxcall, io_setup, io_destroy, io_getevents,
1799 io_submit, io_cancel, exit_group, lookup_dcookie, epoll_create,
1800 epoll_ctl, epoll_wait, remap_file_pages, set_tid_address,
1801 restart_syscall, fadvise, timer_create, timer_settime, timer_gettime,
1802 timer_getoverrun, timer_delete, clock_settime, clock_gettime,
1803 clock_getres, clock_nanosleep, semtimedop): New.
1804
18052003-07-08 Roland McGrath <roland@redhat.com>
1806
1807 * signal.c (sys_tgkill): New function.
1808 * linux/syscall.h: Declare it.
1809 * linux/syscallent.h: Add tgkill.
1810
Roland McGratha9a86192003-06-27 21:20:14 +000018112003-06-27 Roland McGrath <roland@redhat.com>
1812
1813 * configure.ac: Check for type `struct __old_kernel_stat'.
1814 * file.c (convertoldstat, printoldstat): Define under
1815 [LINUX && HAVE_STRUCT___OLD_KERNEL_STAT] rather than a list of archs.
1816 (sys_oldstat, sys_oldfstat, sys_oldlstat): Likewise.
1817 * linux/dummy.h [! HAVE_STRUCT___OLD_KERNEL_STAT]
1818 (sys_oldstat, sys_oldfstat, sys_oldlstat): #define to printargs.
1819
Roland McGrath9df23f92003-06-26 22:23:32 +000018202003-06-26 Roland McGrath <roland@redhat.com>
1821
Roland McGrath4fe23b52003-06-26 22:41:02 +00001822 * configure.ac: SHMEDIA -> SH64
1823 * defs.h: Likewise.
1824 * mem.c: Likewise.
1825 * process.c: Likewise.
1826 * sock.c: Likewise.
1827 * syscall.c: Likewise.
1828 * util.c: Likewise.
1829 * linux/shmedia/syscallent.h: Moved to ...
1830 * linux/sh64/syscallent.h: ... here.
1831
1832 * config.guess: Update from canonical version, timestamp 2003-06-17.
1833 * config.sub: Likewise.
1834
Roland McGrath8f340e32003-06-26 22:29:38 +00001835 * syscall.c (force_result) [LINUX] [ARM]: Fix variable usage.
1836 From: Joshua Neal <tinara@netpipeline.net>.
1837
Roland McGrathc2aa8ea2003-06-26 22:27:32 +00001838 * process.c [LINUX] (sys_futex): Grok FUTEX_REQUEUE and print 5th arg.
1839 * linux/syscallent.h: sys_futex argument count is now 5, not 4.
1840 * linux/ia64/syscallent.h: Likewise.
1841 * linux/powerpc/syscallent.h: Likewise.
1842 * linux/s390/syscallent.h: Likewise.
1843 * linux/s390x/syscallent.h: Likewise.
1844 * linux/x86_64/syscallent.h: Likewise.
1845 From Jakub Jelinek <jakub@redhat.com>.
1846
Roland McGrath9df23f92003-06-26 22:23:32 +00001847 * syscall.c (get_scno) [S390 || S390X]: Fix old vs new mode detection.
1848 From Michael Holzheu <HOLZHEU@de.ibm.com>.
1849
Roland McGrathee911632003-06-23 23:40:04 +000018502003-06-23 Roland McGrath <roland@redhat.com>
1851
1852 * net.c (sys_socket): Decode protocol for PF_INET6 same as PF_INET.
1853 From Ulrich Drepper <drepper@redhat.com>.
1854
Roland McGrathe84e6272003-06-11 05:38:01 +000018552003-06-10 Roland McGrath <roland@redhat.com>
1856
1857 * configure.ac, NEWS: Version 4.4.98.
1858 * strace.spec, debian/changelog: 4.4.98-1.
1859
Roland McGrath3634c272003-06-10 03:06:05 +000018602003-06-09 Roland McGrath <roland@redhat.com>
1861
Roland McGrath767b4302003-06-10 03:38:03 +00001862 * linux/s390x/syscallent.h: Update many syscalls.
1863 * linux/syscall.h (SYS_socket_subcall): Update [S390X] value.
1864
Roland McGrathc38d46e2003-06-10 03:31:34 +00001865 * linux/s390/syscallent.h: Update many syscalls.
1866 * linux/syscall.h (SYS_socket_subcall): Update [S390] value.
1867
Roland McGratheef1fde2003-06-10 03:07:47 +00001868 * linux/shmedia/syscallent.h: New file.
1869 From Stephen Thomas <stephen.thomas@superh.com>.
1870
Roland McGrath3634c272003-06-10 03:06:05 +00001871 * strace.c (trace): Print a message and newline for a WIFEXITED report
1872 from the process we just printed an unterminated syscall line for.
1873
Roland McGrathcf99f9c2003-06-03 07:18:28 +000018742003-06-03 Roland McGrath <roland@redhat.com>
1875
Roland McGrath2c1d5342003-06-03 23:28:58 +00001876 * util.c (printcall) [LINUX]: Fix typo [IA62] -> [IA64].
1877
1878 Linux/ARM improvements from Russell King <rmk@arm.linux.org.uk>:
1879 * defs.h [LINUX] (TCB_WAITEXECVE): Define for [ARM] too.
1880 * process.c (struct_user_offsets) [LINUX] [ARM]: Add ARM registers.
1881 * signal.c [LINUX] (sys_sigreturn) [ARM]: New case.
1882 * syscall.c (get_scno, syscall_fixup) [LINUX] [ARM]: Case rewritten.
1883 (get_error) [LINUX] [ARM]: Update.
1884 (syscall_enter) [LINUX] [ARM]: New case.
1885 * util.c (printcall) [LINUX] [ARM]: New case.
1886
1887 * debian/control (Standards-Version): Update to 3.5.10.
1888
Roland McGrathcf99f9c2003-06-03 07:18:28 +00001889 * strace.c (main): In PATH search, accept only a regular file with
1890 execute bits set. Fixes Debian bug #137103.
1891
Roland McGratha834fbe2003-06-02 19:37:56 +000018922003-06-02 Roland McGrath <roland@redhat.com>
1893
Roland McGrath454a0242003-06-03 01:35:32 +00001894 * strace.c (main): Set -q when given -o and not -p, and not when not
1895 given -o, to match what the man page always said.
1896 Fixes Debian bug #47113, #153678.
1897
Roland McGratha834fbe2003-06-02 19:37:56 +00001898 * configure.ac, NEWS: Version 4.4.97.
1899 * strace.spec, debian/changelog: 4.4.97-1.
1900
1901 * configure.ac, defs.h, mem.c, process.c, sock.c, syscall.c, util.c:
1902 Merged in SHmedia port from Stephen Thomas <stephen.thomas@superh.com>.
1903
1904 * config.guess: Update from ftp://ftp.gnu.org/pub/gnu/config/,
1905 timestamp 2003-05-22.
1906 * config.sub: Likewise, timestamp 2003-05-24.
1907
Roland McGrath5aae8772003-05-23 00:14:17 +000019082003-05-22 Roland McGrath <roland@redhat.com>
1909
Roland McGrathd0835362003-05-23 02:27:37 +00001910 * defs.h (struct tcb): New member `nzombies'.
1911 * strace.c (alloctcb): Initialize it.
1912 (droptcb): Increment our parent's zombie count.
1913 * process.c (internal_wait): Don't go into TCB_SUSPENDED if the
1914 process has zombies it can reap. On the way out, if we reaped
1915 an untraced process, decrement the zombie count.
1916
Roland McGrath7dfd4ed2003-05-23 01:08:50 +00001917 * process.c (sys_clone): Mask CSIGNAL out of flags and print that
1918 separately using signame.
1919
1920 * process.c (internal_clone) [TCB_CLONE_THREAD]: Use ARG_FLAGS instead
1921 of literal 0 for index. Consult the right flags without clobbering
1922 anything when we reparent the new child to the caller's parent thread.
1923
Roland McGrath031b0d82003-05-23 00:29:11 +00001924 * linux/s390/syscallent.h: Fix sys_clone argument count.
1925 * linux/s390x/syscallent.h: Likewise.
1926 * linux/mips/syscallent.h: Likewise.
1927 * linux/alpha/syscallent.h: Likewise.
1928 * linux/powerpc/syscallent.h: Likewise.
1929 * linux/sh/syscallent.h: Likewise.
1930 * linux/sparc/syscallent.h: Likewise.
1931 * linux/hppa/syscallent.h: Likewise.
1932
1933 * process.c [LINUX] [S390 || S390X] (ARG_CTID, ARG_TLS): Fix swapped
1934 indices. Reported by Jakub Jelinek <jakub@redhat.com>.
1935
1936 * signal.c [LINUX] (SI_SIGIO, SI_TKILL): New macros.
1937 [LINUX || SVR4] (siginfo_codes): Add strings for them.
1938
Roland McGrath5aae8772003-05-23 00:14:17 +00001939 * process.c (print_affinitylist): Fix loop condition.
1940 Reported by Ian Wienand <ianw@gelato.unsw.edu.au>.
1941
Roland McGrath872a4362003-04-10 18:58:33 +000019422003-04-10 Roland McGrath <roland@redhat.com>
1943
1944 * syscall.c (qual_desc): Return zero after parsing number.
1945 From Rob Leslie <rob@mars.org>, fixes Debian bug #188379.
1946
Roland McGrath808a4ba2003-04-08 01:47:02 +000019472003-04-07 Roland McGrath <roland@redhat.com>
1948
1949 * linux/syscallent.h: Handle semtimedop subcall of ipc syscall.
1950 * linux/syscall.h: Likewise.
1951 * ipc.c [LINUX] (sys_semtimedop): New function.
1952 From Ulrich Drepper <drepper@redhat.com>.
1953
1954 * ipc.c (sys_semget): Mask off permission bits for resource_flags.
1955 From Ulrich Drepper <drepper@redhat.com>.
1956
Roland McGrathcf43e902003-04-02 01:10:53 +000019572003-04-01 Philippe De Muyter <phdm@macqel.be>
1958
1959 * sock.c, stream.c: Check #ifdef LINUX, not linux.
1960 * file.c: Always provide sys_*attr, regardless of #ifdef XATTR_CREATE.
1961
Roland McGrath10a56fb2003-03-31 01:21:40 +000019622003-03-30 Roland McGrath <roland@redhat.com>
1963
1964 * configure.ac, NEWS: Version 4.4.96.
1965 * strace.spec, debian/changelog: 4.4.96-1.
1966
Roland McGrath347636f2003-03-31 01:05:16 +000019672003-02-26 Stuart Menefy <stuart.menefy@st.com>
1968
1969 Various fixes for SuperH [SH]:
1970 * mem.c (sys_old_mmap): mmap() parameters passed in registers
1971 * net.c (sys_pipe), syscall.c (getrval2): pipe() results returned
1972 in registers
1973 * process.c (change_syscall): Fixed register which holds system
1974 call number
1975 * util.c (arg0_offset, arg1_offset): provide definition
1976 * Makefile.am: Added new files in linux/sh
1977 * linux/sh/syscallent.h: New file.
1978 * linux/sh/errnoent.h: New file.
1979 * linux/sh/ioctlent.h: New file.
1980 * linux/sh/signalent.h: New file.
1981
1982 * linux/ioctlent.sh: Take an arg for location of header files
1983 * syscallent.sh: Replaced lost $
1984
Roland McGrath5467f262003-03-30 23:52:46 +000019852003-03-30 Roland McGrath <roland@redhat.com>
1986
1987 * time.c [LINUX]: Handle new Linux 2.5 clock/timer syscalls.
1988 * linux/syscall.h, linux/syscallent.h, linux/dummy.h: Likewise.
1989 From Ulrich Drepper <drepper@redhat.com>.
1990
1991 * linux/syscallent.h: Use sys_getrlimit for 191.
1992 Use name "old_getrlimit" for 76.
1993 Reported by Ulrich Drepper <drepper@redhat.com>.
1994
Roland McGrath5755ec52003-03-21 07:33:21 +000019952003-03-18 Roland McGrath <roland@redhat.com>
1996
1997 * process.c [LINUX] (sys_clone): Don't dereference parent_tid argument.
1998
Roland McGrath49bad882003-03-18 07:43:53 +000019992003-03-17 Roland McGrath <roland@redhat.com>
2000
2001 * linux/x86_64/syscallent.h: clone takes 5 args.
2002 * process.c [LINUX] (sys_clone) [X86_64]: Fix argument order.
2003
Roland McGrathf22e0c72003-03-15 21:01:43 +000020042003-03-15 Roland McGrath <roland@redhat.com>
2005
2006 * linux/x86_64/syscallent.h: Add exit_group syscall at 231.
2007
Roland McGrath27cad9a2003-03-14 10:33:06 +000020082003-03-14 Roland McGrath <roland@redhat.com>
2009
2010 * linux/x86_64/syscallent.h: Update and add many 2.5 syscalls.
2011
2012 * linux/ia64/syscallent.h: clone takes 5 arguments.
2013 * process.c [LINUX && IA64] (ARG_*): Update for 2.5 clone calls.
2014
Roland McGrath041900f2003-03-12 08:11:33 +000020152003-03-12 Roland McGrath <roland@redhat.com>
2016
Roland McGrath6fbb4e32003-03-12 09:54:45 +00002017 * linux/ia64/syscallent.h: Fix arg counts for clone and clone2.
2018 Use sys_clone for clone2.
2019 * linux/syscall.h: Don't declare sys_clone2.
2020 * process.c (sys_clone): Rewritten to handle both flavors,
2021 print all extra args depending on flag bits.
2022 (sys_clone2): Function removed.
2023
Roland McGrath041900f2003-03-12 08:11:33 +00002024 * linux/ia64/syscallent.h: Add a bunch of 2.5 syscalls.
2025
Roland McGrathb3f8fd62003-03-05 06:29:11 +000020262003-03-04 Roland McGrath <roland@redhat.com>
2027
2028 * syscall.c (get_scno) [IA64]: Do TCB_WAITEXECVE check only when
2029 TCB_INSYSCALL is clear, like other platforms do.
2030
Roland McGrathd2a6c6b2003-03-05 04:08:07 +000020312003-03-04 Ulrich Drepper <drepper@redhat.com>
2032
2033 * mem.c [LINUX] (sys_remap_file_pages): New function.
2034 * linux/syscall.h: Declare it.
2035 * linux/syscallent.h: Use it.
2036 * linux/powerpc/syscallent.h: Likewise.
2037
2038 * process.c [LINUX] (sys_futex): Omit final if op is not FUTEX_WAIT.
2039
Roland McGratha4187c92003-02-26 20:34:14 +000020402003-02-26 Roland McGrath <roland@redhat.com>
2041
2042 * configure.ac: Fix typo in netinet/in.h check.
2043 Also include <sys/types.h> and <sys/socket.h> before <netinet/in.h>.
2044 Reported by Alex Semenyaka <alexs@snark.rinet.ru>.
2045
Roland McGrath66375f62003-02-24 10:18:11 +000020462003-02-24 Roland McGrath <roland@redhat.com>
2047
Roland McGrath74f905d2003-02-24 10:53:48 +00002048 * configure.ac, NEWS: Version 4.4.95.
2049 * strace.spec, debian/changelog: 4.4.95-1.
2050
Roland McGrath66375f62003-02-24 10:18:11 +00002051 * process.c (sys_getresgid): Fix typos in argument access.
2052
Roland McGrath127f7d22003-02-24 07:13:59 +000020532003-02-23 Roland McGrath <roland@redhat.com>
2054
2055 * process.c (sys_getresuid): Fix typos in argument access.
2056 Reported by Anton Blanchard <anton@samba.org>.
2057
Roland McGrath71522342003-02-20 02:45:34 +000020582003-02-19 Roland McGrath <roland@redhat.com>
2059
Roland McGrath45be9602003-02-20 03:26:58 +00002060 * configure.ac, NEWS: Version 4.4.94.
2061 * strace.spec, debian/changelog: 4.4.94-1.
2062
Roland McGrath44fb0432003-02-20 02:56:50 +00002063 * version.c: Removed.
2064 * Makefile.am (strace_SOURCES): Remove it.
2065 * strace.c: Use PACKAGE_NAME and VERSION macros instead of version var.
2066
Roland McGrath71522342003-02-20 02:45:34 +00002067 FreeBSD rfork support changes from Russ Cox <rsc@plan9.bell-labs.com>:
2068 * syscall.c (internal_syscall): Handle SYS_rfork with internal_fork.
2069 * process.c (internal_fork) [SYS_rfork]: Bail if RFPROC flag not set.
2070
Roland McGrath8d276ff2003-01-24 04:32:36 +000020712003-01-23 Roland McGrath <roland@redhat.com>
2072
Roland McGrathff02c902003-01-30 20:15:35 +00002073 * signal.c: Reorder #ifdefs so HAVE_ASM_SIGCONTEXT_H doesn't matter on
2074 SPARC, which doesn't use the header regardless.
2075
2076 * util.c [LINUX && SPARC]: Do renaming kludges around <asm/reg.h>
2077 like signal.c does.
2078
2079 * linux/sparc/syscall.h: Declare sys_getdents64, sys_llseek.
Roland McGrath6ee7d1f2003-01-24 04:39:50 +00002080
2081 * linux/dummy.h [! SYS_getpmsg] (sys_getpmsg): #define to printargs.
2082 [! SYS_putpmsg] (sys_putpmsg): Likewise.
2083
Roland McGrath8d276ff2003-01-24 04:32:36 +00002084 * process.c: Reorder includes to put sys/reg.h before linux/ptrace.h,
2085 since they can conflict.
2086
Roland McGrath6a39c212003-01-22 02:27:59 +000020872003-01-21 Roland McGrath <roland@redhat.com>
2088
Roland McGrath8d276ff2003-01-24 04:32:36 +00002089 * strace.c (usage): Omit -z, since it has never worked properly.
2090 * NEWS: Likewise.
2091
2092 * strace.c (main): Grok new option `-E var=val' or `-E var' to put
2093 var=val in environ or to remove var, respectively.
2094 (usage): Mention it.
2095 * strace.1, NEWS: Document it.
2096
Roland McGrath6a39c212003-01-22 02:27:59 +00002097 * configure.ac, NEWS: Version 4.4.93.
2098 * strace.spec, debian/changelog: 4.4.93-1.
2099 * strace.spec (Source0): Use strace-VERSION.tar.bz2 now.
2100
Roland McGrath08eee592003-01-20 09:04:42 +000021012003-01-20 Roland McGrath <roland@redhat.com>
2102
Roland McGrathb472e1c2003-01-20 10:23:11 +00002103 * defs.h [LINUX] [S390 || S390X] (TCB_WAITEXECVE): Define it.
2104 * syscall.c (get_scno, syscall_fixup) [LINUX] [S390 || S390X]: Handle
2105 TCB_WAITEXECVE state with special kludges.
2106
Roland McGrath08eee592003-01-20 09:04:42 +00002107 * process.c [LINUX] (sys_clone) [S390 || S390X]: Argument order is
2108 reversed from other architectures.
2109
2110 * process.c (sys_execve) [LINUX]: Make setting TCB_WAITEXECVE flag
2111 conditional on [TCB_WAITEXECVE] instead of list of processors.
2112
2113 * util.c (restore_arg0): Evaluate args in no-op defns.
2114
2115 * util.c [S390 || S390X] (arg0_offset, arg1_offset): Fix definitions
2116 for clone call on S390. From Michael Holzheu <holzheu@de.ibm.com>.
2117
Roland McGrath2b157e72003-01-18 00:19:35 +000021182003-01-17 Anton Blanchard <anton@samba.org>
2119
2120 * util.c [LINUX] (setbpt): Handle SYS_vfork like SYS_fork.
2121
2122 * linux/syscall.h (SYS_socket_subcall): 256 also for POWERPC.
2123
Roland McGrath92999db2003-01-14 09:46:33 +000021242003-01-14 Roland McGrath <roland@redhat.com>
2125
Roland McGrathec4bd132003-01-14 23:41:07 +00002126 * linux/powerpc/errnoent.h: Add missing errnos.
2127 * linux/powerpc/ioctlent.h: Update ioctl values.
2128 From Anton Blanchard <anton@samba.org>.
2129
2130 * io.c [LINUX] (sys_pread, sys_pwrite): Fix last change.
2131 From Anton Blanchard <anton@samba.org>.
2132
2133 * linux/hppa/syscallent.h: Use sys_getdents64, sys_truncate64,
2134 sys_ftruncate64, instead of printargs, for those syscalls.
2135 * linux/mips/syscallent.h: Likewise.
2136 * linux/powerpc/syscallent.h: Likewise.
2137 * linux/s390/syscallent.h: Likewise.
2138 * linux/sparc/syscallent.h: Likewise.
2139
2140 * linux/syscall.h (SYS_socket_subcall): Only 256 for S390, S390X.
2141 All others at the moment use linux/syscallent.h, where it's 300.
2142
2143 * strace.1: Update bug reporting info.
2144
2145 * resource.c [LINUX] (quotacmds): Grok new command encodings.
2146 From Nathan Scott <nathans@debian.org>.
2147
Roland McGrathd7bec502003-01-14 10:10:36 +00002148 * configure.ac, NEWS: Version 4.4.92.
2149 * strace.spec, debian/changelog: 4.4.92-1.
2150
Roland McGrathf775ab32003-01-14 09:59:57 +00002151 * configure.ac: Match powerpc* (includes powerpc64), and don't match
2152 ppc (never comes out of config.sub).
Roland McGrathd7bec502003-01-14 10:10:36 +00002153
Roland McGrathf775ab32003-01-14 09:59:57 +00002154 * process.c (sys_ptrace): Use #lx format for address argument.
2155 [POWERPC]: Use sizeof(unsigned long) in place of 4 for multipliers.
2156 * process.c [POWERPC]: Likewise.
2157 * signal.c (sys_sigreturn) [POWERPC]: Likewise.
2158 * syscall.c (get_scno) [POWERPC]: Likewise.
2159 * util.c [POWERPC]: Likewise.
2160 (printnum): Use long for NUM.
2161 From Anton Blanchard <anton@samba.org>.
2162
Roland McGrath92999db2003-01-14 09:46:33 +00002163 * defs.h (ALIGN64): Fix defn for PPC, same as FreeBSD one.
2164
2165 * util.c [LINUX] (restore_arg0, restore_arg1): New macros, defined
2166 appropriately via set_arg0 or no-ops for each architecture.
2167 (clearbpt): Use those instead of set_arg0 and set_arg1.
2168
2169 * defs.h [_LARGEFILE64_SOURCE] (_LFS64_LARGEFILE): Define it.
2170 * linux/syscallent.h: Use sys_getdents64, sys_truncate64,
2171 sys_ftruncate64, instead of printargs, for those syscalls.
2172
2173 * process.c: Use <linux/ptrace.h> regardless of <sys/reg.h>.
2174 (sys_ptrace): Use printxval.
2175 (ptrace_cmds): Make PTRACE_GETREGS et al conditional on #ifdef PTRACE_*
2176 instead of only #ifdef SUNOS4. Add PTRACE_[GS]ETFPXREGS.
2177
2178 * ipc.c (PRINTCTL): New macro. #ifdef IPC_64, factor out the flag and
2179 print it before using printxval.
2180 (sys_msgctl, sys_semctl, sys_shmctl): Use it.
2181
Roland McGrathda5ad2d2003-01-14 07:53:49 +000021822003-01-13 Roland McGrath <roland@redhat.com>
2183
Roland McGrath4e254592003-01-14 07:58:26 +00002184 * config.guess: Update from ftp://ftp.gnu.org/pub/gnu/config/,
2185 timestamp 2003-01-10.
2186 * config.sub: Likewise, timestamp 2003-01-03.
2187 * install-sh: Update from Automake 1.7.2.
2188
Roland McGrathda5ad2d2003-01-14 07:53:49 +00002189 * linux/powerpc/signalent.h: Add SIGRTMIN.
2190 From Anton Blanchard <anton@samba.org>.
2191
2192 * linux/powerpc/syscallent.h: Add missing system calls.
2193 Decode more system calls, we were just printargs for many things.
2194 Remove some x86-specific system calls.
2195 Remove two syscalls between the socket and ipc syscalls,
2196 it was resulting in all IPC syscalls being off by two.
2197
2198 * ioctl.c (ioctl_decode) [POWERPC]: Decode term ioctls like Alpha.
2199 From Anton Blanchard <anton@samba.org>.
2200
2201 * defs.h [POWERPC] (UESP, EIP, EAX, ORIG_EAX): Remove this cruft.
2202 [LINUX && POWERPC && !__powerpc64__] (ALIGN64): New macro.
2203 * io.c (sys_pread, sys_pwrite): Use ALIGN64.
2204 From Anton Blanchard <anton@samba.org>.
2205
2206 * term.c [LINUX]: Get kernel definition of struct termios.
2207 From Anton Blanchard <anton@samba.org>.
2208
2209 * linux/ioctlent.sh: Look in sound/ directory too.
2210 From Anton Blanchard <anton@samba.org>.
2211
2212 * desc.c (printflock64): Fix ADDR argument type.
2213 From Anton Blanchard <anton@samba.org>.
2214
2215 * strace.c [! HAVE_STRSIGNAL]: Clean up #ifdefs on decls for
2216 sys_siglist and _sys_siglist.
2217 Reported by John Hughes <john@Calva.COM>.
2218
2219 * net.c: HAVE_OPTHDR -> HAVE_STRUCT_OPTHDR
2220 Reported by John Hughes <john@Calva.COM>.
2221
2222 * linux/syscall.h [ARM] (SYS_socket_subcall): Set to 300.
2223
Roland McGrathdcfcaf72003-01-10 10:45:13 +000022242003-01-10 Roland McGrath <roland@redhat.com>
2225
Roland McGrathedcf1b02003-01-10 21:43:33 +00002226 * configure.ac, NEWS: Version 4.4.91.
2227 * strace.spec, debian/changelog: 4.4.91-1
2228
Roland McGrath09b371c2003-01-10 20:51:13 +00002229 * util.c [LINUX && X86_64] (arg0_offset, arg1_offset): Use correct
2230 values for x86-64, conditional on current_personality.
2231
Roland McGrath944d10f2003-01-10 20:14:52 +00002232 * strace.c (droptcb): Clear flags word before calling rebuild_pollv.
2233
Roland McGrath03c5c4d2003-01-10 20:06:01 +00002234 * configure.ac: Check struct T_conn_res for QUEUE_ptr or ACCEPTOR_id.
2235 * stream.c (print_transport_message): Use #ifdefs for those members.
2236
2237 * strace.c (rebuild_pollv): Fix typo: struct poll -> struct pollfd.
2238
Roland McGrath516f3492003-01-10 19:55:42 +00002239 * configure.ac: Fix siginfo_t/sig_atomic_t checks.
2240 Use prerequisite #include <netinet/in.h> for netinet/*.h checks.
2241
2242 * strace.c (pfd2tcb): Fix for new tcbtab type.
2243 (rebuild_pollv): Likewise.
2244 (detach): Put variables used under [LINUX] inside #ifdef.
2245
2246 * process.c (change_syscall) [POWERPC]: Add missing return.
2247 * util.c [POWERPC] (arg0_offset): Set to 4*PT_R3, not 4*PT_ORIG_R3.
2248
Roland McGrathdcfcaf72003-01-10 10:45:13 +00002249 * strace.spec: New file.
2250 * debian/changelog: 4.4.90-1
2251 * debian/rules (binary-arch): Depend on build.
2252 (clean): Don't try to run Makefile.in.
2253 * debian/control (Standards-Version): Now 3.5.8.
2254
2255 * configure.ac: Diddle CFLAGS after AC_PROG_CC, not before.
2256
Roland McGrathea496212003-01-10 07:50:29 +000022572003-01-09 Roland McGrath <roland@redhat.com>
2258
2259 * syscall.c (force_result) [S390 || S390X]: Fix typo.
2260
2261 * debian/control: Update Maintainer: field.
2262
Roland McGrath5694e802003-01-09 06:56:39 +000022632003-01-08 Roland McGrath <roland@redhat.com>
2264
2265 * NEWS: Update for 4.4.90 test release.
2266
2267 Support for new Linux 2.5 thread features.
2268 * defs.h [LINUX]: Define __NR_exit_group if not defined.
2269 (struct tcb): New members nclone_threads, nclone_detached,
2270 and nclone_waiting.
2271 (TCB_CLONE_DETACHED, TCB_CLONE_THREAD, TCB_GROUP_EXITING): New macros.
2272 (waiting_parent): Macro removed.
2273 (pid2tcb): Declare it.
2274 * process.c (internal_clone) [TCB_CLONE_THREAD]: Reparent the new
2275 child to our parent if we are a CLONE_THREAD child ourselves.
2276 Maintain TCB_CLONE_THREAD and TCB_CLONE_DETACHED flags and counts.
2277 (internal_wait) [TCB_CLONE_THREAD]: Factor out detached children when
2278 determining if we have any. If TCB_CLONE_THREAD is set, check
2279 parent's children instead of our own, and bump nclone_waiting count.
2280 (internal_exit) [__NR_exit_group]: Set the TCB_GROUP_EXITING flag if
2281 the syscall was exit_group.
2282 * syscall.c (internal_syscall): Use internal_exit for exit_group.
2283 * strace.c (pid2tcb): No longer static.
2284 (alloctcb) [TCB_CLONE_THREAD]: Initialize new fields.
2285 (droptcb) [TCB_CLONE_THREAD]: Maintain new fields.
2286 If we have thread children, set TCB_EXITING and don't clear the TCB.
2287 (resume) [TCB_CLONE_THREAD]: Decrement parent's nclone_waiting.
2288 (detach) [TCB_CLONE_THREAD]: When calling resume, check all thread
2289 children of our parent that might be waiting for us too.
2290 [TCB_GROUP_EXITING] (handle_group_exit): New function.
2291 (trace) [TCB_GROUP_EXITING]: Use that in place of detach or droptcb.
2292
2293 Revamp -f support for Linux.
2294 * util.c [LINUX] (setbpt, clearbpt): New implementations that tweak
2295 the system call to be clone with CLONE_PTRACE set. Various new static
2296 helper functions.
2297 * process.c (internal_clone): Define also #ifdef SYS_clone2.
2298 Initialize TCPCHILD->parent field.
2299 [CLONE_PTRACE]: Don't do PTRACE_ATTACH here, because it's preattached.
2300 Check in case the new child is in the tcb already.
2301 (internal_fork) [LINUX]: Just call internal_clone.
2302 * strace.c (trace) [LINUX]: Under -f/-F, grok an unknown pid
2303 reporting to wait, put it in the TCB with TCB_ATTACHED|TCB_SUSPENDED.
2304
2305 * linux/x86_64/syscallent1.h (sys_oldlstat): #define as printargs.
2306
2307 * file.c [LINUX]: #undef st_[amc]time in case they are macros.
2308
2309 * Makefile.am (AM_CFLAGS): New variable, define to $(WARNFLAGS).
2310
2311 * Makefile.am (EXTRA_DIST): Remove debian/postinst and debian/prerm.
2312
Wichert Akkerman5a9b0862003-01-08 23:44:36 +000023132003-01-09 Wichert Akkerman <wichert@deephackmode.org>
2314
2315 * debian/postinst, debian/prerm: removed, /usr/doc symlink is no
2316 longer used
2317 * debian/rules: no longer install postinst and prerm
Wichert Akkerman136bbb12003-01-08 23:46:03 +00002318 * debian/control: do not end summary with full stop (lintian)
Wichert Akkerman5a9b0862003-01-08 23:44:36 +00002319
Roland McGratha83c22f2002-12-30 09:13:30 +000023202002-12-30 Roland McGrath <roland@redhat.com>
2321
Roland McGrath2850c7e2002-12-30 10:46:02 +00002322 * Makefile.am (bin_SCRIPTS): New variable, list strace-graph.
2323 (EXTRA_DIST): Add missing files.
2324
2325 * configure.ac: Fix asm/sigcontext.h check to include prerequisite.
2326
2327 * syscall.c (qualify_one): New function.
2328 (qual_options): Replace lookup field with qualify, update initializer.
2329 (qualify): Update caller.
2330 (qual_signal, qual_fault, qual_desc): Rewritten from lookup_*.
2331 (qual_syscall): Rewritten lookup_syscall, match name more than once.
2332 Fixes RH#70579, bites IA64 -efoo when foo exists on IA32.
2333
Roland McGrath692b68a2002-12-30 09:33:32 +00002334 * version.c (version): Make const, bump to 4.4.90.
2335 * strace.c: Update decl.
2336
2337 * Makefile.am [LINUX && X86_64]: Remove cruft.
2338 * linux/x86_64/errnoent1.h: New file.
2339 * linux/x86_64/ioctlent1.h: New file.
2340 * linux/x86_64/signalent1.h: New file.
2341 * linux/x86_64/syscallent1.h: New file.
2342 * linux/x86_64/i386-headers.diff: File removed.
2343 * linux/x86_64/makeheaders.sh: File removed.
2344 * linux/x86_64/Makefile.in: File removed.
2345
Roland McGratha83c22f2002-12-30 09:13:30 +00002346 * linux/syscallent.h [X86_64]: Disable sanity checks, subcall stuff is
2347 already broken for 32-bit personality on x86-64.
2348
Roland McGrath30d47f12002-12-30 00:51:51 +000023492002-12-29 Roland McGrath <roland@redhat.com>
2350
Roland McGratha83c22f2002-12-30 09:13:30 +00002351 * configure.ac, Makefile.am: Punt subdirs, handle everything here.
2352 * linux/Makefile.am: File removed.
2353 * freebsd/Makefile.am: File removed.
2354 * sunos4/Makefile.in: File removed.
2355 * svr4/Makefile.in: File removed.
2356
Roland McGrath30d47f12002-12-30 00:51:51 +00002357 * linux/alpha/Makefile.in: File removed.
2358 * linux/hppa/Makefile.in: File removed.
2359 * linux/ia64/Makefile.in: File removed.
2360 * linux/powerpc/Makefile.in: File removed.
2361 * linux/s390/Makefile.in: File removed.
2362 * linux/s390x/Makefile.in: File removed.
2363
23642002-12-26 Roland McGrath <roland@redhat.com>
2365
2366 * syscallent.sh: Grok three flavors of #define line, uniquify.
2367 * linux/hppa/syscallent.sh: File removed.
2368 * linux/powerpc/syscallent.sh: File removed.
2369
2370 * linux/Makefile.am: New file.
2371 * linux/Makefile.in: File removed.
2372 * freebsd/Makefile.am: New file.
2373 * freebsd/i386/Makefile.am: New file.
2374 * freebsd/i386/Makefile.in: File removed.
2375
23762002-12-22 Roland McGrath <roland@redhat.com>
2377
2378 Update to Autoconf 2.57, and Automakify with version 1.7.
2379 * Makefile.am: New file.
2380 * Makefile.in: File removed.
2381 * configure.in: Moved to ...
2382 * configure.ac: ... here. Update for Autoconf 2.5x and Automake.
2383 * aclocal.m4: Moved to ...
2384 * acinclude.m4: ... here. Update for Autoconf 2.5x.
Roland McGratha83c22f2002-12-30 09:13:30 +00002385 * acconfig.h: File removed.
Roland McGrath30d47f12002-12-30 00:51:51 +00002386 * AUTHORS: New file, makes automake happy.
2387 * autogen.sh: File removed.
2388 * README-CVS: Update to recommend autoreconf instead.
2389 * file.c: HAVE_ST_* -> HAVE_STRUCT_STAT_ST_*.
2390 * net.c: HAVE_SIN6_SCOPE_ID -> HAVE_STRUCT_SOCKADDR_IN6_SIN6_SCOPE_ID,
2391 HAVE_MSG_CONTROL -> HAVE_STRUCT_MSGHDR_MSG_CONTROL.
2392 * strace.c: *_DECLARED -> HAVE_DECL_*
2393 * stream.c: HAVE_* -> HAVE_STRUCT_*
2394
2395 * linux/Makefile.in (ioctldefs.h ioctls.h): Use $(SHELL) instead of
2396 sh, and use $(srcdir) to find the script.
2397 * linux/powerpc/Makefile.in (ioctlent.raw): Find ioctlent.sh in ../.
2398 (ioctlsort.o): Use ../ioctlsort.c, not ../../ioctlsort.c.
2399 * linux/x86_64/Makefile.in (headers): Renamed to all.
2400 * linux/alpha/Makefile.in: Add empty install target.
2401 * linux/x86_64/Makefile.in: Likewise.
2402 * linux/powerpc/Makefile.in: Likewise.
2403 * linux/Makefile.in: Likewise.
2404
Roland McGrath85960152002-12-30 00:26:24 +000024052002-12-26 Roland McGrath <roland@redhat.com>
2406
2407 * defs.h [LINUX && MIPS] (MAX_QUALS): Set to 5000, not 4999.
2408 From Daniel Jacobowitz <drow@false.org>.
2409
Roland McGrathc25a62f2002-12-21 23:25:26 +000024102002-12-21 Roland McGrath <roland@redhat.com>
2411
Roland McGrathdf211902002-12-22 03:34:55 +00002412 * linux/syscallent.h: Add some new 2.5 syscall names.
2413 Now clone takes 5 args.
2414 * process.c [LINUX] (clone_flags): Update with 2.5 flag bits.
2415 [LINUX] (sys_clone): Print new args.
2416 * mem.c (print_ldt_entry): Make global.
2417
2418 * linux/syscall.h [I386 || IA64] (SYS_socket_subcall): Bump to 300 for
2419 safety, since up to 260 are already used in 2.5 kernels.
2420 * linux/syscallent.h: Update the table.
2421 * linux/ia64/syscallent.h: Likewise.
2422
Roland McGrathc25a62f2002-12-21 23:25:26 +00002423 * syscall.c (force_result): New function.
2424 * process.c (internal_wait): Handle ECHILD exit from wait call with
2425 WNOHANG flag set; force the return value to 0 in the inferior when it
2426 has live children we are tracing.
Roland McGrath044c8d22002-12-22 03:36:03 +00002427 * NEWS: Mention the bug fix.
Roland McGrathc25a62f2002-12-21 23:25:26 +00002428
Roland McGrath13f0b432002-12-17 10:48:09 +000024292002-12-17 Roland McGrath <roland@redhat.com>
2430
Roland McGrathf57204d2002-12-18 04:36:59 +00002431 * linux/ia64/syscallent.h: Remove placeholders 275-298 to catch up
2432 with linux/syscallent.h additions.
2433
Roland McGrath29f554f2002-12-18 04:16:31 +00002434 * strace.c (tcbtab): Make this a pointer to pointers, not an array.
2435 (tcbtabsize): New variable.
2436 (main): Initialize them using dynamic allocation.
2437 (alloctcb, main): Use tcbtabsize in place of MAX_PROCS; indirect.
2438 (pid2tcb, cleanup): Likewise.
2439 [USE_PROCFS] (pollv): Make this a pointer, not an array; make static.
2440 (rebuild_pollv): Dynamically allocate the vector.
2441 * defs.h (tcbtab): Update decls.
2442 (MAX_PROCS): Macro removed, no more static limit on this.
2443 * process.c (fork_tcb): New function.
2444 (internal_clone, internal_fork): Use it instead of checking nprocs.
2445
Roland McGrath13f0b432002-12-17 10:48:09 +00002446 * strace.c (detach) [LINUX]: Use __WALL (or a second try with __WCLONE)
2447 in wait after sending SIGSTOP.
2448
Roland McGrath915742f2002-12-17 04:51:02 +000024492002-12-16 Roland McGrath <roland@redhat.com>
2450
Roland McGratha581c512002-12-17 05:10:47 +00002451 * signal.c (sprintsigmask): Increase static buffer size to account for
2452 worst possible case. Reported by Daniel Jacobowitz <drow@false.org>.
2453
Roland McGrath915742f2002-12-17 04:51:02 +00002454 * process.c [LINUX] (wait4_options): Fix __WCLONE value. Add
2455 __WNOTHREAD and __WALL.
2456
2457 * strace.c (trace) [LINUX]: Only check errno if wait4 actually fails,
2458 so we don't repeat a wait and thus drop a status. Fixes RH#62591.
2459
Roland McGrath36d87c22002-12-15 23:59:13 +000024602002-12-15 Roland McGrath <roland@redhat.com>
2461
Roland McGrath32be5972002-12-16 20:41:34 +00002462 * process.c (setarg) [POWERPC]: Support it.
2463
2464 * util.c [POWERPC] (LOOP): Fix value, now 0x48000000 (0: b 0b).
2465 Old value was bogus, not even a proper instruction.
2466 From Guy M. Streeter <streeter@redhat.com>.
2467
2468 * strace.c (main) [! USE_PROCFS]: Always reset SIGCHLD to SIG_DFL.
2469
2470 * configure.in: Don't check for putpmsg.
2471 * stream.c (sys_getpmsg, sys_putpmsg): Make these conditional on
2472 #ifdef SYS_*, rather than on HAVE_PUTPMSG.
2473
Roland McGrath2fe77222002-12-16 09:54:16 +00002474 * aclocal.m4 (AC_STAT64): Include <linux/types.h> before <asm/stat.h>
2475 in test. Test our own #ifdef LINUX rather than predefined `linux'.
2476
Roland McGrath36d87c22002-12-15 23:59:13 +00002477 * linux/powerpc/syscallent.h: Use sys_llseek for _llseek.
2478 * linux/sparc/syscallent.h: Likewise.
2479 * linux/hppa/syscallent.h: Likewise.
2480
2481 * syscall.c (syscall_enter) [LINUX && POWERPC]: Define PT_ORIG_R3 if
2482 not defined, since <asm/ptrace.h> defines it only #ifdef __KERNEL__.
2483 * process.c: Likewise.
2484
2485 * desc.c (sys_osf_select): Add missing return type.
2486
2487 * syscall.c (trace_syscall): Use strerror, not sys_errlist/sys_nerr.
2488
2489 * linux/ia64/syscallent.h: Remove macros for sys_delete_module,
2490 sys_nanosleep, both already in linux/dummy.h.
2491
2492 * syscall.c (get_scno): Move static `currpers' inside #ifdef X86_64.
2493 (trace_syscall): Fix return without value.
2494
2495 * linux/syscallent.h: Update table with names of new syscalls
2496 io_setup, io_destroy, io_getvents, io_submit, io_cancel.
2497 * linux/ia64/syscallent.h: Likewise.
2498 * linux/powerpc/syscallent.h: Likewise.
2499
2500 * signal.c [LINUX && I386]: Provide SA_RESTORER constant if not
2501 defined. If the bit is set, print the sa_restorer field of sigaction.
2502
2503 * mem.c: Add sys_{get,set}_thread_area.
2504 * linux/syscall.h: Declare them.
2505 * linux/syscallent.h: Update the table for these.
2506 * linux/dummy.h (sys_modify_ldt): Define only #ifndef I386.
2507 (sys_get_thread_area, sys_set_thread_area): New macros #ifndef I386.
2508
2509 * configure.in: Check for linux/xattr.h and linux/futex.h headers.
2510 * linux/syscall.h: Add sys_* decls for new syscalls getpmsg, putpmsg,
2511 readahead, sendfile64, setxattr, fsetxattr, getxattr, fgetxattr, int
2512 listxattr, flistxattr, removexattr, fremovexattr, sched_setaffinity,
2513 sched_getaffinity, futex.
2514 * linux/syscallent.h: Update the table.
2515 * io.c: Add sys_sendfile64.
2516 * file.c: Add sys_readahead, sys_*xattr.
2517 * process.c: Add sys_futex, sys_*affinity.
2518
2519 * linux/syscall.h (SYS_socket_subcall): Define to 256 on all machines.
2520 (SYS_ipc_subcall): Always SYS_socket_subcall + SYS_socket_nsubcalls.
2521 * linux/syscallent.h: Update the table for socket and ipc subcalls.
2522
Michal Ludvig882eda82002-11-11 12:50:47 +000025232002-11-09 Heiko Carstens <heiko.carstens@de.ibm.com>
2524
2525 Bugfix for s390/s390x:
2526 * syscall.c: Fixed scno derivation for s390/s390x.
2527
Michal Ludvig17f8fb32002-11-06 13:17:21 +000025282002-11-06 Michal Ludvig <mludvig@suse.cz>
2529
Michal Ludvig39c0e942002-11-06 14:00:12 +00002530 Merged patch from Steven J. Hill <sjhill@realitydiluted.com>
2531 to allow the compilation of a native MIPS strace.
2532
25332002-11-06 Michal Ludvig <mludvig@suse.cz>
2534
Roland McGrath36d87c22002-12-15 23:59:13 +00002535 From Marty Leisner <leisner@rochester.rr.com>,
Michal Ludvig882eda82002-11-11 12:50:47 +00002536 rewritten by mludvig:
Michal Ludvig17f8fb32002-11-06 13:17:21 +00002537 * strace.c (not_failing_only): New.
2538 (usage): Added -z switch description.
2539 (main): Added -z switch parsing to not_failing_only variable.
2540 * syscall.c (trace_syscall): Added not_failing_only handling.
2541
Michal Ludvigeb818f02002-10-09 09:16:22 +000025422002-10-08 Heiko Carstens <heiko.carstens@de.ibm.com>
2543
2544 Missing complete changelog for 2002-10-07 commit:
2545 * Makefile.in: Added linux/s390, linux/s390x to ALL_SUBDIRS.
2546 * acconfig.h: New define for s390x.
2547 * config.sub: Added missing define for s390 and new one for s390x.
2548 * configure.in: Added new define for s390x.
2549 * file.c: Added missing #undef dirent64 and new defines for s390x.
2550 * linux/s390: New directory.
2551 * linux/s390/Makefile.in: New file.
2552 * linux/s390/errnoent.h: New file.
2553 * linux/s390/ioctlent.h: New file.
2554 * linux/s390/signalent.h: New file.
2555 * linux/s390/syscallent.h: New file.
2556 * linux/s390x: New directoy.
2557 * linux/s390x/Makefile.in: New file.
2558 * linux/s390x/errnoent.h: New file.
2559 * linux/s390x/ioctlent.h: New file.
2560 * linux/s390x/signalent.h: New file.
2561 * linux/s390x/syscallent.h: New file.
2562 * linux/syscall.h: Added sys_mincore() prototype and added new
2563 s390x defines.
2564 * process.c: Added s390x defines.
2565 (change_syscall): Changed handling for s390.
2566 (setarg): Added missing s390/s390x code in setarg().
2567 * signal.c: Added s390x define.
2568 (sys_sigreturn): Bugfix in s390/s390x code (wrong number of
2569 arguments to sprintsigmask()).
2570 * stream.c (internal_stream_ioctl): Changed int cast to long cast,
2571 since printstr() expects a long.
2572 * syscall.c (decode_subcall): Changed several variables to be long
2573 instead of int to match 64 bit requirements. Added s390x defines.
2574 (syscall_enter): Changed upeek() call to match s390 and s390x
2575 requirements.
2576 * util.c: Added s390x defines.
2577
Michal Ludvig10a88d02002-10-07 14:31:00 +000025782002-10-07 Michal Ludvig <mludvig@suse.cz>
2579
2580 Merged s390x port by Heiko Carstens <Heiko.Carstens@de.ibm.com>
2581 and bugfixes to s390 by D.J. Barrow.
2582
Michal Ludvig53b320f2002-09-23 13:30:09 +000025832002-09-23 Michal Ludvig <mludvig@suse.cz>
2584
Roland McGrath36d87c22002-12-15 23:59:13 +00002585 Merged x86-64 port by Andi Kleen <ak@suse.de>
Michal Ludvig0e035502002-09-23 15:41:01 +00002586 and Michal Ludvig <mludvig@suse.cz>
2587 * Makefile.in: New target 'headers'. Failure ignored.
2588 * acconfig.h: New defines for x86-64.
2589 * configure.in: Ditto.
2590 * defs.h: Ditto.
2591 * file.c: Ditto.
2592 * signal.c: Ditto.
2593 * process.c: Added support for x86-64.
2594 * util.c: Ditto.
2595 * syscall.c: Ditto + added automatic personality switching.
2596 * linux/syscall.h: Ditto.
2597 * linux/x86_64: New directory.
2598 * linux/x86_64/Makefile.in: New file.
2599 * linux/x86_64/gentab.pl: Ditto.
2600 * linux/x86_64/i386-headers.diff: Ditto.
2601 * linux/x86_64/makeheaders.sh: Ditto.
2602 * linux/x86_64/syscallent.h: Ditto.
2603 * mem.c (print_mmap): Always print arg[4] as int.
2604
26052002-09-23 Michal Ludvig <mludvig@suse.cz>
2606
Michal Ludvig53b320f2002-09-23 13:30:09 +00002607 * configure.in: Fix regular expressions.
Roland McGrath36d87c22002-12-15 23:59:13 +00002608 * linux/syscall.h: Added missing braces in prototype of
Michal Ludvig53b320f2002-09-23 13:30:09 +00002609 sys_getdents64().
2610 * file.c: Use '#ifdef LINUX' instead of '#ifdef linux'.
2611 (struct fileflags): Made extern to inhibit compiation warnings.
2612 (sys_getdents64): Merged LINUX and SVR4 part.
Roland McGrath36d87c22002-12-15 23:59:13 +00002613 * syscall.c (get_scno): Split multiline string into two distinct
Michal Ludvig53b320f2002-09-23 13:30:09 +00002614 strings.
2615
John Hughes2c4e3a82002-05-24 10:19:44 +000026162002-05-24 John Hughes <john@calva.com>
2617
2618 * stream.h, net.h: Avoid possible infinite loop caused by
2619 unsigned arithmetic in preceeding change.
2620
John Hughesb6643082002-05-23 11:02:22 +000026212002-05-23 John Hughes <john@calva.com>
2622
John Hughes38ae88d2002-05-23 11:48:58 +00002623 * acconfig.h: Add HAVE_OPTHDR and HAVE_T_OPTHDR defines.
2624
2625 * aclocal.m4: Add tests for struct opthdr in sys/socket.h and
2626 struct t_opthdr in sys/tiuser.h, define HAVE_OPTHDR and HAVE_T_OPTHDR
2627 if found.
2628
2629 * configure.in: use tests for struct opthdr and struct t_opthdr.
2630
2631 * defs.h: add new function print_sock_optmgmt.
2632
2633 * io.c: add hack that lets ioctl decode functions set auxilliary
2634 string return.
2635
2636 * stream.c: better decoding for timod ioctls.
2637
2638 * net.c: add function print_sock_optmgmt, used by timod ioctl
2639 decoding functions in stream.c.
2640
26412002-05-23 John Hughes <john@calva.com>
2642
John Hughescde80ab2002-05-23 11:19:05 +00002643 * acconfig.h: Make autoheader happy about Linux/SuperH
2644
26452002-05-23 John Hughes <john@calva.com>
2646
John Hughesb6643082002-05-23 11:02:22 +00002647 * strace.c: Get rid of warning if not using POLL_HACK
2648
John Hughes93f7fcc2002-05-22 15:46:49 +000026492002-05-22 John Hughes <john@calva.com>
2650
2651 * net.c: Simplify {get,set}sockopt, decode SO_LINGER, cope with
2652 options that are not just ints, cope with systems that don't
2653 #define SOL_TCP and so on.
2654
John Hughesd870b3c2002-05-21 11:24:18 +000026552002-05-21 John Hughes <john@calva.com>
2656
2657 * strace.c: Fix warning if POLL_HACK is used.
2658
John Hughesc61eb3d2002-05-17 11:37:50 +000026592002-05-17 John Hughes <john@calva.com>
2660
John Hughes5eb78d52002-05-17 14:04:24 +00002661 * svr4/ioctlent.sh: Some defines on UW come with too many spaces.
2662
26632002-05-17 John Hughes <john@calva.com>
2664
John Hughese9224782002-05-17 13:58:24 +00002665 * svr4/ioctlent.sh: Cope with #defines wrapped in #ifdefs.
2666
26672002-05-17 John Hughes <john@calva.com>
2668
John Hughesfd15cb32002-05-17 11:41:35 +00002669 * stream.c: tidy up output a little.
2670
26712002-05-17 John Hughes <john@calva.com>
2672
John Hughesc61eb3d2002-05-17 11:37:50 +00002673 * process.c, svr4/dummy.h, svr4/syscall.h: decode arguments
2674 to procpriv syscall.
2675
Wichert Akkermanccef6372002-05-01 16:39:22 +000026762002-05-01 Wichert Akkerman <wichert@deephackmode.org>
2677
2678 * configure.in, defs.h, process.c, sock.c, syscall.c, util.c: merge
2679 patch from Greg Banks <gbanks@pocketpenguins.com> for Linux/SuperH
2680 support
2681
Wichert Akkermanb0c598f2002-04-01 12:48:06 +000026822002-04-01 Wichert Akkerman <wichert@deephackmode.org>
2683
Wichert Akkermaneb8ebda2002-04-01 17:48:02 +00002684 * strace.c: close tcp->outf in droptcb()
2685
26862002-04-01 Wichert Akkerman <wichert@deephackmode.org>
2687
Wichert Akkermanb0c598f2002-04-01 12:48:06 +00002688 * net.c: decode packet options
2689
Wichert Akkermand321ff92002-03-31 18:45:45 +000026902002-03-31 Wichert Akkerman <wichert@deephackmode.org>
2691
Wichert Akkermaned2c74d2002-03-31 20:16:02 +00002692 * linux/{alpha,hppa,ia64,mips,powerpc,sparc}/syscallent.h: regenerated
2693
26942002-03-31 Wichert Akkerman <wichert@deephackmode.org>
2695
Wichert Akkermand321ff92002-03-31 18:45:45 +00002696 * debian/*: added
Wichert Akkerman7ab47b62002-03-31 19:00:02 +00002697 * linux/syscallent.h: fix typo and add the reserved stream syscalls
2698 * defs.h, file.c, io.c: fix signed/unsigned issues
Wichert Akkerman4527dae2002-03-31 19:03:29 +00002699 * syscall.c: check for negative u_errors
Wichert Akkerman235b0ff2002-03-31 19:08:04 +00002700 * cvsbuild: renamed to autogen.sh
Wichert Akkermand321ff92002-03-31 18:45:45 +00002701
Wichert Akkerman8b8ff7c2001-12-27 22:27:30 +000027022001-12-17 Wichert Akkerman <wakkerma@debian.org>
2703
2704 * net.c: add new TCP socket options
2705
John Hughesfa519572001-10-26 08:05:49 +000027062001-10-26 John Hughes <john@calva.com>
2707
2708 * svr4/ioctlent.sh: Cope with #define lines containing
2709 comments that terminate on subsequent lines. Used to
2710 comment out subsequent ioctls!
2711
Wichert Akkerman9fbd0dd2001-10-26 05:20:37 +000027122001-10-25 Wichert Akkerman <wakkerma@debian.org>
2713
2714 * linux/ioctlent.h: regenerated using current scripts so
2715 term ioctls are included
2716
John Hughes19e49982001-10-19 08:59:12 +000027172001-10-19 John Hughes <john@Calva.COM>
2718
2719 * strace.c(proc_open): On SVR4 only trace the syscalls,
2720 signals and faults we care about.
2721
John Hughes42162082001-10-18 14:48:26 +000027222001-10-18 John Hughes <john@Calva.COM>
2723
John Hughesc0c5ac82001-10-19 07:32:14 +00002724 * acconfig.h: Add HAS_SIGINFO_T.
2725 * aclocal.m4: add check for siginfo_t in signal.h.
2726 * configure.in: use check for siginfo_t.
2727 * defs.h: if HAVE_SIGINFO_T the declare printsiginfo. On SVR4
2728 allow access to siginfo when signal recieved.
2729 * process.c: Remove SVR4 only version of printsiginfo.
2730 * signal.c: merge SVR4 and LINUX versions of printsiginfo.
2731 * strace.c: on SVR4 print siginfo when signal recieved.
2732
27332001-10-18 John Hughes <john@Calva.COM>
2734
John Hughes2d8b2c52001-10-18 14:52:24 +00002735 * system.c(sys_ssisys): handle return values for ssisys
2736
27372001-10-18 John Hughes <john@Calva.COM>
2738
John Hughes42162082001-10-18 14:48:26 +00002739 * signal.c: handle sigwait
2740 * svr4/dummy.c: Move sigwait to done
2741 * svr4/syscall.h: handle sigwait
2742
John Hughes9cecf7f2001-10-16 10:20:22 +000027432001-10-16 John Hughes <john@Calva.COM>
2744
John Hughes0aadba42001-10-16 18:19:52 +00002745 * system.c(sys_ssisys): decode some args for ssisys.
2746
27472001-10-16 John Hughes <john@Calva.COM>
2748
John Hughesaca07f32001-10-16 18:12:27 +00002749 * mem.c: MS_SYNC is zero, so must be first in xlat list.
2750
2751 * svr4/dummy.h: memcntl is much like mctl.
2752
27532001-10-16 John Hughes <john@Calva.COM>
2754
John Hughes9cecf7f2001-10-16 10:20:22 +00002755 * util.c (umovestr): UnixWare (svr4?) returns 0 when trying
2756 to read unmapped page. Make it possible to strace ksh.
2757
Wichert Akkerman7b3346b2001-10-09 23:47:38 +000027582001-10-03 David Mosberger <davidm@hpl.hp.com>
2759
2760 * process.c (internal_clone): Avoid race condition by clearing
2761 breakpoint after attaching to child.
2762
27632001-10-02 David Mosberger <davidm@hpl.hp.com>
2764
2765 * linux/ia64/syscallent.h: Define ia32 syscall numbers (originally
2766 by Don Dugger, with my refinements).
2767
2768 * linux/ia64/ioctlent.h: Regenerate and manually merge conflicting
2769 ioctls (TCGETS & SNDCTL_TMR_TIMEBASE, etc.).
2770
2771 * linux/ia64/Makefile.in (ioctldefs.h ioctls.h): Update for
2772 new ioctlent.h generation scheme.
2773
2774 * linux/syscall.h (sys_clone2): Declare.
2775 [IA64] Define ia32 socket, ipc, and extra syscall numbers.
2776
2777 * linux/ioctlent.sh (regexp): Also handle <asm/ioctls.h> so we
2778 don't miss the tty ioctls (unfortunately, some of the sound timer
2779 ioctls are in conflict with them!).
2780
2781 * util.c (setbpt) [IA64]: Add ia32 support (by Don Dugger).
2782 (clrbpt) [IA64]: Ditto.
2783
2784 * syscall.c (internal_syscall): Handle SYS_clone2, SYS32_wait4,
2785 and SYS32_exit.
2786 (get_scno): Get ia32 syscall number from r1 (orig eax) instead of
2787 r8 (eax). Handle TCB_WAITEXECVE.
2788 (syscall_fixup): Handle ia64.
2789 (syscall_enter): Fix argument fetching for ia64.
2790
2791 * strace.c [IA64 && LINUX]: Include <asm/ptrace_offsets.h>.
2792 (trace) [PT_GETSIGINFO]: Print signal address and pc if possible.
2793
2794 * process.c (tcp): New function.
2795 (change_syscall): Add support for ia64 linux.
2796 (sys_execve): Turn on TCB_WAITEXECVE for ia64 linux.
2797
2798 * desc.c (getlk): Cast l_len to "long long" to avoid warnings when
2799 type is narrower.
2800 * resource.c (sprintrlim64): Ditto.
2801
2802 * defs.h (TCB_WAITEXECVE) [IA64]: Define.
2803 [IA64]: Declare "ia32" variable.
2804
2805 * bjm.c: Do not include <linux/module.h>. It's not safe to include
2806 kernel headers. Declare the necessary constants and structures
2807 directly instead.
2808
28092001-10-01 David Mosberger <davidm@hpl.hp.com>
2810
2811 * signal.c (parse_sigset_t): New function.
2812 (sigishandled): Fix off-by-one bug by using parse_sigset_t() and
2813 avoiding relying on internal layout of sigset_t datastructure.
2814
28152001-04-26 David Mosberger <davidm@hpl.hp.com>
2816
2817 * linux/ia64/syscallent.h: Add getunwind().
2818
28192001-04-11 David Mosberger <davidm@hpl.hp.com>
2820
2821 * syscall.c (syscall_enter): Use PT_RBS_END instead of deprecated
2822 PT_AR_BSP. Pick up arguments starting with out0, which is not
2823 always the same as r32 (e.g., consider inlined syscalls).
2824
John Hughesa2278142001-09-28 16:21:30 +000028252001-09-28 John Hughes <john@Calva.COM>
2826
2827 * process.c: FreeBSD-CURRENT no longer has PT_READ_U, and anyway we
2828 were showing it as PT_WRITE_U! Fix from Maxime Henrion.
2829
John Hughes1fcb1d62001-09-18 15:56:53 +000028302001-09-18 John Hughes <john@Calva.COM>
2831
2832 * net.c: fix display of sockaddr structures, sometimes too many "}",
2833 sometimes too few. Fix suggested by Richard Kettlewell.
2834
Wichert Akkerman67e3e632001-08-19 11:43:17 +000028352001-08-19 Wichert Akkerman <wakkerma@debian.org>
2836
2837 * signal.c: do not include asm/sigcontext.h on IA64 since it gets
2838 the struct from bits/sigcontext.h already which signal.h includes.
2839
Wichert Akkerman7b96b572001-08-03 11:37:07 +000028402001-08-03 Wichert Akkerman <wakkerma@debian.org>
2841
Wichert Akkerman7c707a72001-08-03 21:54:08 +00002842 * linux/ioctlent.sh: change regexps so we catch sound ioctls as well in
2843 Linux
2844 * linux/Makefile.in: fix a few things so the ioctl list is generated
2845 properly
2846 * ioctl.c: remember to shift ioctl masks as well
2847
28482001-08-03 Wichert Akkerman <wakkerma@debian.org>
2849
Wichert Akkermancd6aefc2001-08-03 12:27:54 +00002850 * Linux/**/syscallent.h: synchronize section for fcntl and use sys_fcntl
2851 for sys_fcntl as well
2852
28532001-08-03 Wichert Akkerman <wakkerma@debian.org>
2854
Wichert Akkerman0b1120a2001-08-03 12:20:38 +00002855 * linux/hppa/syscallent.h: updated from Matthew Wilcox
2856
28572001-08-03 Wichert Akkerman <wakkerma@debian.org>
2858
Wichert Akkerman82b162e2001-08-03 11:51:28 +00002859 * process.c: seems Linux/IA64 changed register names on us, switch to
2860 using new names.
2861
28622001-08-03 Wichert Akkerman <wakkerma@debian.org>
2863
Wichert Akkerman54b4f792001-08-03 11:43:35 +00002864 * strace.c: set CLOEXEC flag for outputfile
2865
28662001-08-03 Wichert Akkerman <wakkerma@debian.org>
2867
Wichert Akkerman7b96b572001-08-03 11:37:07 +00002868 * linux/sparc/syscall.h, linux/sparc/syscallent.h: add some LFS calls
2869
Wichert Akkerman4f1bbbe2001-07-23 14:43:07 +000028702001-07-23 Wichert Akkerman <wakkerma@debian.org>
2871
2872 * configure.in: Support cross-compiling between architectures
2873
Wichert Akkerman0dc4fc92001-07-13 22:09:05 +000028742001-07-13 Wichert Akkerman <wakkerma@debian.org>
2875
2876 * configure.in: add S390 to architecture list
2877
John Hughes1d08dcf2001-07-10 13:48:44 +000028782001-07-10 John Hughes <john@Calva.COM>
2879
2880 * TODO, defs.h, io.h, net.c, strace.c, syscall.c, util.c: Merge fixes
2881 from Richard Kettlewell <rkettlewell@zeus.com> which add I/O dumping
2882 of args to readv/writev. Also gets rid of redundant printiovec
2883 routine from net.c (duplicate of tprint_iov in util.c).
2884
Wichert Akkerman688c7fc2001-07-02 16:53:25 +000028852001-07-02 Wichert Akkerman <wakkerma@debian.org>
2886
2887 * config.{guess,sub}: updated
2888
John Hughesaa09c6b2001-05-15 14:53:43 +000028892001-05-15 John Hughes <john@Calva.COM>
2890
John Hughes70c5e7a2001-05-15 15:09:14 +00002891 * signal.c: pass a pointer to sigmask to printsigmask from printcontext,
2892 it was just passing the sigmask (ucp->uc_sigmask).
2893
28942001-05-15 John Hughes <john@Calva.COM>
2895
John Hughesaa09c6b2001-05-15 14:53:43 +00002896 * util.c: Don't run off the end of valid memory in umovestr when
2897 USE_PROCFS. Important for FREEBSD systems (which seem to have an
2898 unmapped page just after the args/env area).
2899
John Hughes4e36a812001-04-18 15:11:51 +000029002001-04-18 John Hughes <john@Calva.COM>
2901
2902 * configure.in: test for sys/nscsys.h, the non-stop clusters includes.
2903 * process.c: handle rfork{1,all} and rexecve calls on non-stop clusters.
2904 * syscall.c: treat rfork{1,all} and fork{1,all} as fork like calls.
2905 Treat rexecve as an exec.
2906 * system.c: decode arguments to ssisys call on nsc systems.
2907 * svr4/dummy.h, svr4/syscall.h: now we handle rfork{1,all}, ssisys and
2908 rexecve calls.
2909
Wichert Akkerman35254402001-04-12 09:11:04 +000029102001-04-12 Wichert Akkerman <wakkerma@debian.org>
2911
2912 * process.c: fix cast for powerpc code
2913 * linux/powerpc/syscallent.h: update syscall list
2914 * README: fix address for the strace mailinglist
2915 * signal.c: switch to using /proc/<pid>/status on Linux so we can get
2916 the realtime signals as well
2917
Wichert Akkerman4ca31092001-04-10 10:28:43 +000029182001-04-10 Wichert Akkerman <wakkerma@debian.org>
2919
2920 * Merge patches from Maciej W. Rozycki:
2921 + util.c: add code to print PC for MIPS
2922 + linux/mips/syscallent.h: updated
2923 + system.c: formating fixes for sys_sysmips
Wichert Akkerman42080d82001-04-10 10:32:26 +00002924 + configure.in: test for yet more headers
2925 + stream.c: use configure-headertests instead of relying on OS hints
Wichert Akkerman4ca31092001-04-10 10:28:43 +00002926
Wichert Akkermand6b92492001-04-07 21:37:12 +000029272001-04-07 Wichert Akkerman <wakkerma@debian.org>
2928
Wichert Akkermane70bbe52001-04-07 21:47:30 +00002929 * NEWS: start 4.3.1 items
2930 * version.c: updated to say 4.3.1 (was still 4.2, oops!)
2931
29322001-04-07 Wichert Akkerman <wakkerma@debian.org>
2933
Wichert Akkermand6b92492001-04-07 21:37:12 +00002934 * configure.in: test for asm/sysmips.h and linux/utsname.h
2935 * linux/syscall.h: fix a typo for sys_sysmips
2936 * system.c: include asm/sysmips.h and linux/utsname.h if they exist,
2937 fix typo
2938
Wichert Akkerman4f043ec2001-03-31 16:25:58 +000029392001-03-31 Wichert Akkerman <wakkerma@debian.org>
2940
2941 * linux/mips/ioctlent.h: updated using new Linux ioctl setup
2942
29432001-03-31 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkerman8aada672001-03-31 16:20:33 +00002944
2945 * linux/ia64/ioctlent.h: regenerated
2946
Wichert Akkerman29f0d052001-03-31 16:14:55 +000029472001-03-31 Wichert Akkerman <wakkerma@debian.org>
2948
Wichert Akkermancf715672001-03-31 16:16:57 +00002949 * linux/{alpha,ia64,powerpc}/ioctlent.sh: removed, all archs use the
2950 general Linux ioctlent.sh
2951
29522001-03-31 Wichert Akkerman <wakkerma@debian.org>
2953
Wichert Akkerman29f0d052001-03-31 16:14:55 +00002954 * linux/ioctlent.sh: add dir variable for location of kernel headers
2955
Wichert Akkermanbbf59e92001-03-29 17:43:19 +000029562001-03-29 Wichert Akkerman <wakkerma@debian.org>
2957
Wichert Akkerman00cd74c2001-03-30 16:20:27 +00002958 * linux/ia64/ioctlent.h: updated using new Linux ioctl setup
2959
29602001-03-29 Wichert Akkerman <wakkerma@debian.org>
2961
Wichert Akkerman10767782001-03-29 19:04:25 +00002962 * linux/powerpc/ioctlent.h: updated using new Linux ioctl setup
2963
29642001-03-29 Wichert Akkerman <wakkerma@debian.org>
2965
Wichert Akkermand7fb2062001-03-29 18:16:07 +00002966 * linux/hppa/ioctlent.h: updated using new Linux ioctl setup
2967
29682001-03-29 Wichert Akkerman <wakkerma@debian.org>
2969
Wichert Akkermanbbf59e92001-03-29 17:43:19 +00002970 * linux/alpha/ioctlent.h: updated using new Linux ioctl setup
2971
Wichert Akkerman2f1d87e2001-03-28 14:40:14 +000029722001-03-28 Wichert Akkerman <wakkerma@debian.org>
2973
Wichert Akkerman00a82ee2001-03-28 20:29:17 +00002974 * configure.in: use sparc* so we can compile on sparc64 as well
2975 * process.c, syscall.c: work around double define of fpq, fq and fpu
2976 structs on Linux/sparc, and use regs instead of pt_regs
2977 * don't use asm/sigcontext.h on Linux/sparc
2978
29792001-03-28 Wichert Akkerman <wakkerma@debian.org>
2980
Wichert Akkermanfe8f65d2001-03-28 15:10:49 +00002981 * linux/sparc/ioctlent.h: updated using new Linux ioctl setup
2982
29832001-03-28 Wichert Akkerman <wakkerma@debian.org>
2984
Wichert Akkerman2f1d87e2001-03-28 14:40:14 +00002985 * strace.c: use __WALL as wait4 flag if it exists so we can properly
2986 trace threaded programs
2987
John Hughes8e075fb2001-03-27 13:57:48 +000029882001-03-27 John Hughes <john@Calva.COM>
2989
John Hughesb8a85a42001-03-28 08:05:27 +00002990 * aclocal.m4: add check for endianness of long long.
2991 * acconfig.h: add #define for LITTLE_ENDIAN_LONG_LONG.
2992 * configure.in: check for endianness of long long.
Wichert Akkerman8ab1a3c2001-03-28 14:27:23 +00002993 * defs.h: change LONG_LONG macro to work with either endianness of
John Hughesb8a85a42001-03-28 08:05:27 +00002994 long long.
2995
29962001-03-27 John Hughes <john@Calva.COM>
2997
John Hughes61563572001-03-27 16:47:36 +00002998 * net.c: Make compilable by SCO UDK compiler (doesn't like empty
2999 initialisation list for array).
3000
30012001-03-27 John Hughes <john@Calva.COM>
3002
John Hughes8e075fb2001-03-27 13:57:48 +00003003 * svr4/syscallent.h: ntp_adjtime entry was duplicated on Solaris
3004 systems - bad merge of Harald Boehme's patch by me.
3005
Wichert Akkerman072ea8a2001-03-27 14:46:05 +000030062001-03-27 Wichert Akkerman <wakkerma@debian.org>
3007
3008 * lots of files: add Linux/hppa support
3009
Wichert Akkerman407be9a2001-03-19 10:56:49 +000030102001-03-19 Wichert Akkerman <wakkerma@debian.org>
3011
3012 * linux/mips/syscallent.h: we can't have -1 nargs, change to 0
Wichert Akkermane3bf56a2001-03-19 11:05:17 +00003013 * linux/syscallent.h: not that syscalls 220 and 221 are used now
Wichert Akkerman6f2bbe22001-03-19 11:00:29 +00003014 * config.guess: updated
Wichert Akkerman407be9a2001-03-19 10:56:49 +00003015
Wichert Akkermana9667852001-03-17 17:26:34 +000030162001-03-17 Wichert Akkerman <wakkerma@debian.org>
3017
3018 * linux/ioclsort.c: new file
3019 * linux/ioctlent.sh: complete rewrite to use a more sane approach to get
3020 the ioctl list that doesn't involve attempting to #include all kernel
3021 headers
3022 * linux/.cvsignore: added ioctdefs.h and ioctls.h which are generated
3023 by the new ioctlent.sh
3024 * ioctl.c: only look at the number and type bits for linux, since
3025 ioctlent.sh no longer supplies the others
3026
John Hughes70623be2001-03-08 13:59:00 +000030272001-03-08 John Hughes <john@Calva.COM>
3028
John Hughescf1de752001-03-08 17:27:20 +00003029 * freebsd/syscalls.pl: On FreeBSD we must cope with COMPATibility syscalls,
3030 pretend they have names ending with "?" so that -e trace=stat (for
3031 example) will work.
3032 * freebsd/i386/syscallent.h: add ? to compatability syscalls.
3033 * freebsd/i386/syscall.h: consistency.
3034
30352001-03-08 John Hughes <john@Calva.COM>
3036
John Hughesc0fc3fd2001-03-08 16:10:40 +00003037 * acconfig.h: add new ST_xxx defines.
3038 * aclocal.m4: macros to check for more fields in struct stat.
3039 * configure.in: use new macros to check for fields in struct stat.
3040 * file.c: use new defines to replace #ifdef FREEBSD by #if HAVE_ST_xxx.
3041
30422001-03-08 John Hughes <john@Calva.COM>
3043
John Hughes0c79e012001-03-08 14:40:06 +00003044 * defs.h: rename wimpy get64 as powerful new LONG_LONG
3045 * file.c: use LONG_LONG
3046 * io.c: use LONG_LONG
3047 * mem.c use LONG_LONG
3048
30492001-03-08 John Hughes <john@Calva.COM>
3050
John Hughes70623be2001-03-08 13:59:00 +00003051 * acconfig.h: new #defines HAVE_LONG_LONG_OFF_T and HAVE_LONG_LONG_RLIM_T.
3052 * aclocal.m4: routines to check for long long off_t and rlim_t.
3053 * configure.in: check for long long off_t and rlim_t.
3054 * desc.c: if HAVE_LONG_LONG_OFF_T treat flock as flock64
3055 * file.c: if HAVE_LONG_LONG_OFF_T treat stat,lstat,fstat and lseek as 64
3056 bit versions.
3057 * io.c: if HAVE_LONG_LONG_OFF_T use 64 bit versions of pread and pwrite.
3058 * mem.c: if HAVE_LONG_LONG_OFF_T use 64 bit version of mmap
3059 * resource.c: if HAVE_LONG_LONG_OFF_T use 64 bit versions of getrlimit
3060 and setrlimit.
3061 * freebsd/syscalls.print: don't explicitly use 64 bit versions of calls,
3062 now done automaticaly for us.
3063 * freebsd/i386/syscall.h: ditto.
3064 * freebsd/i386/syscallent.h ditto.
3065
John Hughes5a826b82001-03-07 13:21:24 +000030662001-03-07 John Hughes <john@Calva.COM>
3067
John Hughesb8c9f772001-03-07 16:53:07 +00003068 * desc.c: On FreeBSD flock structure uses 64 bit offsets.
3069 * file.c: On FreeBSD use stat64 and pals instead of stat.
3070 * freebsd/syscalls.print: use stat64, lstat64 and fstat64.
3071 * freebsd/i386/syscall.h: ditto.
3072 * freebsd/i386/syscallent.h: ditto.
3073
30742001-03-07 John Hughes <john@Calva.COM>
3075
John Hughese2f6d872001-03-07 16:03:20 +00003076 * file.c: merge missing part of Harald Böhme's solaris patches,
3077 was only declaring sys_{stat64,lstat64,fstat64} on linux!
3078
30792001-03-07 John Hughes <john@Calva.COM>
3080
John Hughes9dec06c2001-03-07 14:47:19 +00003081 * svr4/dummy.h: fix multiple define warning on non LFS64 systems.
3082 * svr4/syscallent.h: pread/pwrite are TF calls.
3083
30842001-03-07 John Hughes <john@Calva.COM>
3085
John Hughes5a826b82001-03-07 13:21:24 +00003086 * defs.h: add ALIGN64 macro to cope with FreeBSD's strange insistence
3087 on alignment for off_t (64 bit) arguments. Also simplify get64 so
3088 we don't need to know endianness of long long.
3089 * file.c: FreeBSD now uses 64 bit versions of lseek, truncate,
3090 ftruncate, allows reduction in numvber of horrid #if's
3091 * io.c: FreeBSD now uses 64 bit versions of pread, pwrite.
3092 * mem.c: FreeBSD now uses 64 bit version of mmap.
3093 * freebsd/syscalls.print: use 64 bit versions of various syscalls.
3094 * freebsd/i386/syscall.h: use 64 bit versions of various syscalls.
3095 * freebsd/i386/syscallent.h: use 64 bit versions of various syscalls.
3096
John Hughes95ea9c02001-03-07 10:11:02 +000030972001-03-06 John Hughes <john@Calva.COM>
3098
John Hughes7737c8a2001-03-07 10:41:58 +00003099 * file.c: Implement truncate64 and ftruncate64
3100 * svr4/dummy.h: add dummies for truncate64 and ftruncate64 for non
3101 LFS64 systems.
3102 * svr4/syscall.h: add declarations for truncate64 and ftruncate64.
3103
31042001-03-06 John Hughes <john@Calva.COM>
3105
John Hughesc5249902001-03-07 10:39:06 +00003106 * freebsd/syscalls.pl: fix for FreeBSD 4.1 (new optional field in
3107 syscall master file).
3108
31092001-03-06 John Hughes <john@Calva.COM>
3110
John Hughesbb557232001-03-07 10:37:38 +00003111 * syscall.c: fix for FreeBSD 4.1 (SYS_semconfig has disappeared). Also
3112 zap incorrect syscall subarg range check.
3113
31142001-03-06 John Hughes <john@Calva.COM>
3115
John Hughescb8b69d2001-03-07 10:34:27 +00003116 * configure.in, defs.h, desc.c, file.c, io.c, mem.c, net.c, resource.c,
3117 signal.c, syscall.c, svr4/dummy.h, svr4/syscall.h, svr4/syscallent.h:
3118 merge Harald Böhme's solaris patches (_LFS64_LARGEFILE and kernel aio
3119 mostly).
3120
31212001-03-06 John Hughes <john@Calva.COM>
3122
John Hughesbc4935a2001-03-07 10:28:50 +00003123 * dummy.h: add unimplemented UW sycalls
3124 * syscall.h: we can do settimeofday for UW, whopee!
3125 * syscallent.h: fix unimplemented UW syscalls
3126
31272001-03-06 John Hughes <john@Calva.COM>
3128
John Hughesc8f2e8a2001-03-07 10:26:17 +00003129 * aclocal.m4: look for pr_syscall in pr_lwp if we HAVE_MP_PROCFS
3130 * defs.h: add PR_SYSCALL to allow use of pr_lwp.pr_syscall if it exists.
3131 * syscall.c: use PR_SYSCALL instead of pr_syscall, fix up UnixWare code
3132 so it doesn't try to use pr_sysarg.
3133
31342001-03-06 John Hughes <john@Calva.COM>
3135
John Hughes091fe832001-03-07 10:15:39 +00003136 * aclocal.m4: on systems other than linux look for stat64 in sys/stat.h
3137 * file.c: handle xstat version _STAT64_VER, aka stat64.
3138
31392001-03-06 John Hughes <john@Calva.COM>
3140
John Hughes95ea9c02001-03-07 10:11:02 +00003141 * net.c: make sure SOL_ options are defined before using.
3142 * signal.c: declare sigset variable, only used on linux, inside #ifdef.
3143
Wichert Akkermanfa306182001-02-21 16:42:26 +000031442001-02-21 Wichert Akkerman <wakkerma@debian.org>
3145
3146 * net.c: fix format for printing Unix domain sockets
3147
Wichert Akkerman0cbfb322001-02-19 13:35:53 +000031482001-02-19 Wichert Akkerman <wakkerma@debian.org>
3149
3150 * linux/mips/syscallent.h: use new sys_sysmips
3151 * system.c: add sys_sysmips decoding
3152
Wichert Akkerman8c7122c2001-02-16 19:59:55 +000031532001-02-16 Wichert Akkerman <wakkerma@debian.org>
3154
Wichert Akkermanf1850652001-02-16 20:29:03 +00003155 * CREDITS: add Arkadiusz Miskiewicz <misiek@pld.org.pl> who
3156 submitted the IP6 scope ID updates
3157 * acconfig.h: add HAVE_SIN6_SCOPE_ID and HAVE_SIN6_SCOPE_ID_LINUX
3158 * aclocal.m4: add AC_SIN6_SCOPE_ID to check if sin6_scope_id is
3159 available
3160 * configure.in: check for if_indextoname function and sin6_scope_id
3161 * net.c: teach printsock about IP6 scope ids
3162
31632001-02-16 Wichert Akkerman <wakkerma@debian.org>
3164
Wichert Akkerman8c7122c2001-02-16 19:59:55 +00003165 * configure.in: test for netinet/tcp.h and netinet/udp.h existance
3166 * net.c: include netinet/tcp.h and netinet/udp.h if they exist
Wichert Akkermanedf2dcc2001-02-16 20:14:40 +00003167 * Makefile.in: use @mandir@ and @bindir@
Wichert Akkerman8c7122c2001-02-16 19:59:55 +00003168
Wichert Akkermanefdecac2000-11-26 03:59:21 +000031692000-11-26 Wichert Akkerman <wakkerma@debian.org>
3170
3171 * net.c: fix formating error in sys_setsockopt
3172 * net.c: add list of socketlayers and use that for [gs]etsockopt
3173
Roland McGrath36d87c22002-12-15 23:59:13 +000031742000-10-12 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkermand856b992000-10-13 12:47:12 +00003175
3176 * time.c: use sys/timex.h so things compile with 2.2 kernels
3177 * stream.c: test if MSG_* constants are #defined
3178
Wichert Akkerman9b0c31d2000-09-03 21:56:29 +000031792000-09-03 Wichert Akkerman <wakkerma@debian.org>
3180
Wichert Akkermanefdecac2000-11-26 03:59:21 +00003181 * process.c: perform bpt trick for clone as well so we can get the
3182 pid of the child before it starts doing something
3183 * file.c: rename dirent64 struct to kernel_dirent64 so things compile
3184 again with newer libcs
3185 * test/clone.c: improve our testcase a bit
3186 * Merge another patch from Gäel Roualland with FreeBSD updates
Wichert Akkerman9b0c31d2000-09-03 21:56:29 +00003187
Wichert Akkermanbf79f2e2000-09-01 21:03:06 +000031882000-09-01 Wichert Akkerman <wakkerma@debian.org>
3189
Wichert Akkermanefdecac2000-11-26 03:59:21 +00003190 * lots of files: merge patch from Gaël Roualland to add
3191 support for FreeBSD.
Wichert Akkermanbf79f2e2000-09-01 21:03:06 +00003192
Wichert Akkerman16a03d22000-08-10 02:14:04 +000031932000-08-09 Wichert Akkerman <wakkerma@debian.org>
3194
Wichert Akkermand077c452000-08-10 18:16:15 +00003195 * file.c: update to reflect that st_ino suddenly became a long long
3196 in the in Linux 2.4.0-test6
3197
31982000-08-09 Wichert Akkerman <wakkerma@debian.org>
3199
Wichert Akkerman16a03d22000-08-10 02:14:04 +00003200 * test/clone.c: minor fixup
3201 * Another bunch of patches from John Hughes merged:
3202 * signal.c:
3203 + SVR4 printcontext(): sigset_t != sigset_t*
3204 + getcontext returns a value, so print on exit of syscall
3205 + add UC_FP to ucontext_flags for OS writers that can't spell
3206 + sys_signal(): special case SIG_{ERR,DFL,IGN}
3207 + decode_subcall(): only do subcall range checking when needed
3208 * bunch of UnixWare updates
3209 * aclocal.m4, acconfig.h, configure.in: add test for long long type
3210
Wichert Akkerman7987cdf2000-07-05 16:05:39 +000032112000-07-04 Wichert Akkerman <wakkerma@debian.org>
3212
3213 * net.c: add SOL_PACKET and SOL_RAW socket options, update
3214 SOL_IP and SOL_TCP
3215
Wichert Akkermanbd4125c2000-06-27 17:28:06 +000032162000-06-23 Wichert Akkerman <wakkerma@debian.org>
3217
3218 * strace.c: close outf before we exec a child process
3219
Wichert Akkerman43a74822000-06-27 17:33:32 +000032202000-06-09 Ulrich Drepper <drepper@redhat.com>
3221
3222 * configure.in: Don't link against libnsl on Linux, it's unnecessary.
3223 * defs.h (struct tcb): Make auxstr member const.
3224 * file.c (fsmagic): And many more magic numbers.
3225 * util.c: Don't include <linux/ptrace.h> for glibc 2.1 and up.
3226
Wichert Akkerman5ae21ea2000-05-01 01:53:59 +000032272000-04-26 Wichert Akkerman <wakkerma@debian.org>
3228
3229 * defs.h: balance #if/#endif again
3230 * system.c: fix return statements in sys_capget()
3231 * Merge updates from Topi Miettinen <Topi.Miettinen@nic.fi>:
3232 + file.c: add F_[SG]ETSIG to fcntl flags
3233 + strace.c: don't setre[gu]id if not needed
3234 + system.c: handle sys_reboot for Linux
3235 + term.c: add baudrate constants up to B4000000
3236 + linux/**/syscallent.h: note that munlockall has no arguments
3237
32382000-04-25 David Mosberger <davidm@hpl.hp.com>
3239
3240 * CREDITS: fix email address
3241 * process.c: handle PR_[GS]ET_UNALIGN and PR_[GS]ET_KEEPCAPS
3242 * signal.c: honour offset of sigconfig in sigframe structure for
3243 Linux/ia64
3244 * linux/ia64/syscallent.h: Add perfmonctl, pivotroot, mincore, and
3245 madvise syscalls.
3246 * syscall.c (syscall_enter): With Kevin's latest ptrace patches,
3247 AR_BSP points to the _end_ of the active register frame, so we need
3248 to adjust bsp by moving it back by the size of the active frame
3249 before using it.
3250
32512000-04-24 Wichert Akkerman <wakkerma@debian.org>
3252
3253 * process.c: add sparc support to change_syscall
3254
Wichert Akkerman10dfa562000-04-22 18:26:56 +000032552000-04-22 Wichert Akkerman <wakkerma@debian.org>
3256
3257 * linux/mips/syscallent.h: fix some typos
3258
Wichert Akkerman481e45b2000-04-17 07:42:31 +000032592000-04-14 Wichert Akkerman <wakkerma@debian.org>
3260
3261 * linux/mips/syscallent.h: added names for SVR4, SYSV, BSD4.3 and POSIX
3262 syscalls
3263
Wichert Akkermanfd89ced2000-04-13 17:06:09 +000032642000-04-13 Wichert Akkerman <wakkerma@debian.org>
3265
3266 * defs.h: Linux/MIPS uses syscalls up to >4k, so set MAX_QUALS to
3267 4999
3268
Wichert Akkermanc7926982000-04-10 22:22:31 +000032692000-04-09 Wichert Akkerman <wakkerma@debian.org>
3270
3271 * README-linux: updated to note that strace might not compile
3272 with development kernels
3273 * bjm.c: sys_query_module: check if malloc succeeds
3274 * system.c: sys_cap[gs]et(): check if malloc succeeds, only malloc once
3275 * linux/syscallent.h: updated for 2.3.99pre3
3276 * linux/alpha/syscallent.h: updated for 2.3.99pre3, add all osf syscalls
3277 even though Linux doesn't implement them
3278 * syscall.c: add global variables for MIPS registers as well
3279 * syscall.c: move global variables to before get_scno since that uses them
3280 * util.c: oops, misspelled defined
3281 * process.c: fix ptrace calls in change_syscall
3282 * mem.c: decode sys_madvise
3283 * Merge patch from Topi Miettinen <Topi.Miettinen@nic.fi>
3284 + add support for quotactl, fdatasync, mlock, mlockall, munlockall & acct
3285 + small fix for RLIMIT_* and RUSAGE_BOTH
3286 + enhace support for capget and capset
3287
Wichert Akkermanfaf72222000-02-19 23:59:03 +000032882000-02-19 Wichert Akkerman <wakkerma@debian.org>
3289
3290 * test/vfork.c: new file to test vfork traces
3291 * test/.cvsignore: new file
3292 * defs.h: Up maximum number of traced processed to 64
Roland McGrath36d87c22002-12-15 23:59:13 +00003293 * strace.c: Disable some debugging code from davidm
Wichert Akkermanfaf72222000-02-19 23:59:03 +00003294 * implement setarg for more architectures
3295 * implement change_syscall
3296
Wichert Akkerman2ee6e452000-02-18 15:36:12 +000032971999-12-27 Morten Welinder <terra@diku.dk>
3298
3299 * syscall.c (lookup_signal, lookup_desc): isdigit requires an
3300 _unsigned_ char parameter.
3301
Wichert Akkerman12f75d12000-02-14 16:23:40 +000033022000-02-14 Wichert Akkerman <wakkerma@debian.org>
3303
3304 * S390 updates
3305
Wichert Akkerman8b1b40c2000-02-03 21:58:30 +000033062000-02-03 Wichert Akkerman <wakkerma@debian.org>
3307
Wichert Akkerman5ae21ea2000-05-01 01:53:59 +00003308 * Merge Linux/ia64 patches
Wichert Akkerman8b1b40c2000-02-03 21:58:30 +00003309
Pavel Machek4dc3b142000-02-01 17:58:41 +000033102000-01-02 Pavel Machek <pavel@ucw.cz>
3311
3312 * probe if sys/poll.h exists in configure + minor cleanups
3313
3314 * syscall.c: split trace_syscall into few pieces to make code readable
3315
Wichert Akkerman30160182000-01-21 20:31:34 +000033162000-01-21 Wichert Akkerman <wakkerma@debian.org>
3317
3318 * Release version 4.2 to get the current updates out and so
3319 we can concentrate in finishing the clone support.
3320
Wichert Akkerman3ed6dc22000-01-11 14:41:09 +000033212000-01-11 Wichert Akkerman <wakkerma@debian.org>
3322
3323 * Add 1900 to tm_year in sprinttime
3324
Wichert Akkerman0396bdc1999-12-24 23:11:57 +000033251999-12-24 Wichert Akkerman <wakkerma@debian.org>
3326
3327 * file.c: protect printstat64 with STAT64 instead of linux so we can
3328 compile on Linux architectures that don't have it
Wichert Akkerman9148a3b1999-12-24 23:13:55 +00003329 * util.c: fix LOOP for ARM
Wichert Akkerman0396bdc1999-12-24 23:11:57 +00003330
3331Fri Dec 24 18:05:00 EST 1999
3332
Ulrich Drepperc921cb21999-12-24 08:03:35 +000033331999-12-23 Ulrich Drepper <drepper@cygnus.com>
3334
3335 * file.c: Use ugly libc_stat trick also for stat64.
3336 Implement sys_stat64, sys_fstat64, sys_lstat64, and printstat64.
3337 * process.c (internal_clone): Fix a few typos and add definitions to make
3338 it at least compile.
3339 * linux/syscall.h: Declare sys_stat64, sys_lstat64, and sys_fstat64.
3340 * linux/syscallent.h: Define table entries for sys_stat64, sys_lstat64,
3341 and sys_fstat64.
3342 * aclocal.m4: Define AC_STAT64.
3343 * acconfig.h: Define HAVE_STAT64.
3344 * configure.in: Add AC_STAT64.
3345
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003346Thu Dec 23 15:01:37 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3347
3348 * Merge patch from ftp://oss.software.ibm.com/linux390/ to add
3349 support for Linux on the IBM S/390 architecture
Wichert Akkerman7a0b6491999-12-23 15:08:17 +00003350 * process.c: add internal_clone(), currently only shows the options
3351 * syscall.c: use internal_clone to handle SYS_clone
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003352
3353Mon Dec 20 00:27:50 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3354
3355 * Rewrite mmap-handling to support mmap2 on Linux
3356
Wichert Akkermane5be0de1999-12-14 10:46:18 +00003357Tue Dec 14 11:35:16 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3358
3359 * Note that Linux can handle sys_semop() as well
3360
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003361Tue Nov 30 11:05:26 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3362
3363 * Include linux/in6.h for glibc2.0 and older
3364
Wichert Akkermanea78f0f1999-11-29 15:34:02 +00003365Mon Nov 29 16:33:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3366
3367 * Merge patches from John Hughes to make configure support UnixWare
3368
Wichert Akkerman9123ac81999-11-27 21:58:20 +00003369Sat Nov 27 21:38:17 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3370
3371 * Enhance sys_query_module
3372
Wichert Akkermane4aafd41999-11-26 09:54:08 +00003373Fri Nov 26 10:51:55 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3374
3375 * Patches from John Hughes:
3376 + cosmectic fix in sys_getpmsg
Wichert Akkerman48214be1999-11-26 09:55:42 +00003377 + allow net.c to compile on systems without AF_INET6
3378 + Only use long_to_sigset on Linux systems
Wichert Akkerman46956571999-11-26 10:12:59 +00003379 + UnixWare treats sigmask_t and sigmask_t* as the same thing
Wichert Akkerman9dbf1541999-11-26 13:11:29 +00003380 + Add pollhack
Wichert Akkerman3377df71999-11-26 13:14:41 +00003381 + Parse mount arguments for UnixWare
3382 + ACL fixes for UnixWare
Wichert Akkermane4aafd41999-11-26 09:54:08 +00003383
Wichert Akkerman2a64b431999-11-26 00:29:05 +00003384Fri Nov 26 01:28:09 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3385
3386 * Release 4.1 to get all the changes made out there
3387
Wichert Akkermanf5eeabb1999-11-18 17:09:47 +00003388Thu Nov 18 18:04:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3389
3390 * Merge stracefork from Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>
3391 + Socket calls parsed better
3392 + bunch of alpha OSF syscalls added
3393 + Fix alpha 32/64 bit issues
3394
Wichert Akkerman2f473da1999-11-01 19:53:31 +00003395Mon Nov 1 20:52:08 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3396
3397 * Move Linux kernelmodule-functions from system.c to bjm.c and
3398 remove duplicate for sys_create_module
Wichert Akkerman60456d71999-11-01 19:59:33 +00003399 * Linux MIPS updates:
3400 + Play with #ifdef's in net.c to get IPv6 right
3401 + Use printargs for vm86-syscall
Wichert Akkerman2f473da1999-11-01 19:53:31 +00003402
Wichert Akkermanf90da011999-10-31 21:15:38 +00003403Sun Oct 31 22:03:00 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3404
3405 * Merge Linux mips patch from Florian Lohoff <flo@rfc822.org>
3406
Wichert Akkerman50524821999-10-10 22:40:07 +00003407Mon Oct 11 00:36:25 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3408
3409 * Merge patch from Keith Owens <kaos@ocs.com.au> to sys_query_module
3410 and sys_delete_module correctly
3411
Wichert Akkerman15dea971999-10-06 13:06:34 +00003412Wed Oct 6 02:00:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3413
3414 * Update cvsbuild to give a better error if autoconf isn't installed
3415 * Add test for linux/ptrace.h to configure
3416 * Since we define GNU_SOURCE in the Makefile we don't need to define
3417 USE_GNU in file.c anymore
3418
3419Fri Sep 10 04:35:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3420
3421 * #define USE_GNU before including file.c so we get some extra O_* flags
3422
3423Tue Aug 31 16:27:21 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3424
3425 * Add missing } in IPv6 output
3426
Wichert Akkerman7b27ba01999-08-30 23:26:53 +00003427Tue Aug 31 01:23:08 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3428
3429 * Update copyright for strace-graph to BSD to be consistent with
3430 the rest of strace
3431
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00003432Mon Aug 30 00:53:57 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3433
3434 * Merge patch from Daniel Jacobowitz: KERN_JAVA_* and KERN_SECURELVL aren't
3435 defined for all kernelversions
Wichert Akkerman7b27ba01999-08-30 23:26:53 +00003436 * Add strace-graph, written by Richard Braakman <dark@xs4all.nl>
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00003437
3438Thu Aug 19 13:10:15 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
3439
3440 * linux/sparc/syscall.h: Declare create_module/init_module.
3441 * configure.in: Allow compilation in a different directory
3442 than the source one.
3443 * signal.c: Use asm/reg.h and struct regs instead of pt_regs
3444 so that we don't depend on asm/ptrace.h which clashes with
3445 glibc sys/ptrace.h.
3446 * util.c: Likewise.
3447 * syscall.c: Likewise.
3448
Wichert Akkerman5a777661999-08-04 16:03:49 +00003449Wed Aug 4 18:01:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3450
3451 * Syscall 94 on Linux alpha is sys_poll
3452
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00003453Sun Jul 25 14:38:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3454
3455 * Merge in UnixWare patches from John Hughes <john@Calva.COM>
3456
Wichert Akkerman527a8051999-07-15 21:11:37 +00003457Thu Jul 15 23:00:32 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3458
3459 * Merge patch from Maciej W. Rozycki <macro@ds2.pg.gda.pl>:
3460 + Correctly implement fix sys_createmodule (Linux)
3461 + Add limited handlig of sys_initmodule (Linux)
3462
Wichert Akkerman36915a11999-07-13 15:45:02 +00003463Tue Jul 13 17:07:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3464
3465 * Add configure-test for sys/reg.h and use that
3466 * Use sys/reg.h instead of asm/ptrace.h
3467
Wichert Akkermanca446991999-07-09 23:48:58 +00003468Sat Jul 10 01:46:10 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3469
3470 * Remove hack in signal.c for arm architecture
3471 * Add hack so we compile correctly on powerpc
3472
Wichert Akkerman5b4d1281999-07-09 00:32:54 +00003473Fri Jul 9 02:28:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3474
3475 * Add a corrected patch from Daniel Jacobowitz
3476
Wichert Akkermana6013701999-07-08 14:00:58 +00003477Thu Jul 8 16:00:04 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3478
3479 * Merge patch from Daniel Jacobowitz to allow us to use the kernel types
3480 for the stat structure
3481
3482Thu Jun 24 15:54:18 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkerman2b483ba1999-06-24 13:55:29 +00003483
3484 * Fix test for sys/reg include
3485
Wichert Akkermana6013701999-07-08 14:00:58 +00003486Tue Jun 22 17:26:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkermane6f876c1999-06-22 15:28:30 +00003487
3488 * Fixed some Linux/powerpc sillyness, thanks to Daniel Jacobowitz
3489 * Fixed some SunOS compile problems earlier that I forgot to include
3490 here
3491
Wichert Akkerman789ed351999-06-14 10:45:01 +00003492Mon Jun 14 12:44:25 CEST 1999
3493
3494 * Avoid leakint fd into child when forking, patch from
3495 John Hughes <john@Calva.COM>
3496
Wichert Akkerman8829a551999-06-11 13:18:40 +00003497Fri Jun 11 14:54:47 CEST 1999
3498
3499 * Applied IRIX64 patch from Thomas E. Dickey <dickey@clark.net>
3500 * Applied Solaris and manpage updates from Guy Harris <guy@netapp.com>
3501
Wichert Akkermancc4b8f41999-06-09 12:50:10 +00003502Wed Jun 9 14:48:49 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3503
3504 * Brought syscall list for alpha up to date
3505
Wichert Akkermandacfb6e1999-06-03 14:21:07 +00003506Wed Jun 2 18:30:12 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
3507
3508 * system.c: sys_umount2 syscall support.
3509 * linux/sparc/errnoent.h: Update sparc-linux errnos.
3510 * linux/sparc/syscall.h: Update used sparc-linux syscalls.
3511 * linux/sparc/syscallent.h: Match 2.2.9 system calls.
3512 * file.c: sparc-linux asm/stat.h uses dev_t etc. types,
3513 so it needs strace's own copy of the stat structure.
3514 * util.c: Make it compile on sparc-linux.
3515 * strace.c: Fix strace -f and -ff operation on sparc-linux.
3516 * signal.c: rt_sigaction has different arguments on sparc*-linux
3517 and alpha-linux.
3518 * syscall.c: Recognize sparc64-linux binaries.
3519
Ulrich Drepper0d2d3231999-05-29 04:11:48 +00003520Fri May 28 21:09:00 PST Ulrich Drepper <drepper@cygnus.com>
3521
3522 * configure.in: Fix typo (CFLAG -> CFLAGS).
3523
Ulrich Drepper8783c011999-05-29 04:13:58 +00003524 * syscall.c: Don't include linux/ptrace.h explicitly for glibc.
3525
Wichert Akkerman22fe9d21999-05-27 12:00:57 +00003526Thu May 27 13:59:27 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3527
3528 * Add some sysctl support, patch from Ulrich Drepper
3529
Wichert Akkerman9524bb91999-05-25 23:11:18 +00003530Wed May 26 01:04:34 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3531
3532 * Use kernel dirent structure for Linux
3533
Wichert Akkerman2e2553a1999-05-09 00:29:58 +00003534Sun May 9 02:18:30 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3535
3536 * Merge in patches from Andreas Schwab <schwab@issan.cs.uni-dortmund.de>
3537 + some layout and other minor fixes
3538 + add some m68k-specific things to linux/syscallent.h. Note that m68k
3539 is similar enough to i386 to not need it's own subdirectory
3540 + add support for sendfile and mremap syscalls for Linux
3541 * Merge in patches from Sascha Schumann <sascha@schumann.2ns.de>
3542 + ioctls.h vs sys/ioctl.h on Alpha platform
3543 + pointer was casted to an int in stream.c
3544 + strsignal() needs -D_GNU_SOURCE in CFLAGS
3545 + several other casts changed
3546 + correct ARM/POWERPC architecture defines in acconfig.h
3547 * Merge in patches from Morten Welinder <terra@diku.dk>
3548 + add some autoconf-tests for includefiles
3549 + handle solaris version of sigcontext struct (actually I hacked this
3550 up again, but the idea is his :)
3551
Wichert Akkerman7a1f0e91999-04-18 20:23:57 +00003552Sun Apr 18 22:32:42 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3553
3554 * Update syscalls for linux alpha, patch from Bart Warmerdam
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003555 <bartw@debian.org>
Wichert Akkermand4d8e921999-04-18 23:30:29 +00003556 * Update sparc code so it actually compiles
Wichert Akkerman7a1f0e91999-04-18 20:23:57 +00003557
Wichert Akkerman328c5e71999-04-16 00:21:26 +00003558Fri Apr 16 02:18:05 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3559
Wichert Akkerman25d0c4f1999-04-18 19:35:42 +00003560 * Add support for old_*stat functions for Linux. Please note you need
3561 to use reasonably recent kernel headers to compile strace now.
Wichert Akkerman328c5e71999-04-16 00:21:26 +00003562 * Change references to LINUX into linux in file.c
3563 * Fix include for LDT in mem.c
Wichert Akkerman1786d811999-04-15 20:34:14 +00003564
3565Thu Apr 15 22:28:15 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3566
3567 * Change in strace maintainership, jrs passed the torch to me.
3568 * Use autoconf 2.13
3569 * Incorporate all changes already made in the Debian strace package:
3570 + compiles with more Linux kernels
3571 + added support for more Linux architectures
3572 + add support for a lot of extra syscalls
3573 + fix some problems with hanging children
3574 + check stray syscall after execv
3575 + decode capget and capset arguments
3576 + add more constants to net.c
3577 + detect ROSE networking
3578 + add more protocol families to domains
3579 + add IPIP protocol
3580 + added MSG_PROXY and MSG_CTRUNC to msg_flags
3581 + added SO_BSDCOMPAT and SO_REUSEPORT to sockoptions
3582 + added IP, IPX and TCP-options
3583 + added IP, IPX and TCP support to get-/setsockopt()
3584 + added IPX support
3585 + updated handling of signals
3586
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003587Sun Oct 27 22:28:00 1996 J. Richard Sladkey <jrs@world.std.com>
3588
3589 * util.c (umovestr) [LINUX]: Handle Linux like SunOS4
3590 instead of SVR4. That is, read a few bytes at a time
3591 to avoid overrunning the end of the stack.
3592
3593Fri May 31 01:48:49 1996 J. Richard Sladkey <jrs@world.std.com>
3594
3595 * version.c: Version 3.1 is released.
3596
3597Thu May 23 01:04:43 1996 J. Richard Sladkey <jrs@world.std.com>
3598
3599 * aclocal.m4 (AC_DECL_SYS_ERRLIST): Try looking in stdio.h
3600 as well since that's where glibc declares it. Go figure.
3601 * signal.c (sys_sigreturn) [ALPHA]: Use sigcontext
3602 instead of sigcontext_struct since glibc v5+ apparently
3603 plays games with the native OS namespace.
3604 From David Mosberger-Tang <davidm@AZStarNet.com>.
3605
3606Mon May 20 23:17:14 1996 J. Richard Sladkey <jrs@world.std.com>
3607
3608 * version.c: Version 3.0.14 is released.
3609
3610 * aclocal.m4 (AC_STRUCT_MSG_CONTROL): New macro.
3611 * configure.in: Add call to AC_STRUCT_MSG_CONTROL.
3612 * net.c (printmsghdr): Handle BSD 4.3 and 4.4 msghdr members
3613 differently.
3614 Reported by Henrik Storner <storner@osiris.ping.dk>.
3615
3616 * configure.in: (AC_CHECK_{HEADERS,FUNCS}): Add checks for
3617 sys/filio.h and sys/stream.h and remove check for poll.
3618 * desc.c (decode_select, sys_select, sys_oldselect) [LINUX]:
3619 Handle old and new styles of argument passing for select on Linux.
3620 * ioctl.c, stream.c: Conditionalize stream code on presence of
3621 sys/stream.h instead of poll because glibc implements poll but
3622 not the rest of the stream interface.
3623 * signal.c [LINUX]: Standardize on the name sigcontext_struct.
3624 (sys_sigprocmask) [ALPHA]: Handle OSF flavor which is more like
3625 sigsetmask.
3626 * term.c (term_ioctl): Use _VMIN, if present, for TC{G,S}ETA*.
3627 * util.c (umoven, umovestr): Move data in long-sized chunks
3628 at a time, instead of hard coding it to be 4.
3629 From David Mosberger-Tang <davidm@AZStarNet.com>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003630
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003631Mon May 20 01:19:36 1996 J. Richard Sladkey <jrs@world.std.com>
3632
3633 * version.c: Version 3.0.13 is released.
3634
3635 * configure.in (AC_CHECK_HEADERS): Add check for asm/sigcontext.h.
3636 * signal.c [HAVE_ASM_SIGCONTEXT_H]: Conditionally include
3637 asm/sigcontext.h to define sigcontext_struct and don't define it
3638 locally if the header is present.
3639
3640 * syscall.c (nerrnos{0,2}): Correct size computation.
3641
3642 * Makefile.in: Remove dependencies and rules relating to files
3643 normally found in the os directory. Because of the new scheme we
3644 don't know precisely where they come from. Sigh.
3645 * signalent.sh: Make it work for sunos4, linux, and svr4.
3646 * {sunos4,linux{,/alpha},svr4}/Makefile.in: Make rules correspond
3647 to traditional make syntax. Add signalent.h to files which can
3648 unconditionally be rebuilt. Prevent signalent.h from being
3649 unconditionally being rebuilt since it's customized.
3650 * {sunos4,linux{,/alpha},svr4}/{ioctlent,errnoent,signalent}.h:
3651 Use versions built by {ioctlent,errnoent,signaltent}.sh.
3652 * sunos4/ioctlent.sh: Work around sprintf troubles with SunOS
3653 4.1.4 and gcc 2.7.2.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003654
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003655Sun May 19 17:14:09 1996 J. Richard Sladkey <jrs@world.std.com>
3656
3657 * configure.in, Makefile.in: Add OSARCH concept to finish
3658 build support for the alpha.
3659 * Makefile.in, linux/Makefile.in: Rewrite clean, distclean,
3660 and maintainer-clean rules.
3661 * defs.h, ioctlsort.c: Make ioctl code member unsigned.
3662 * ioctl.c, ioctlsort.c (compare): Perform explicit checking
3663 for less, greater, and equal since subtraction on two's
3664 complement numbers isn't an order relation (it isn't transitive)!
3665 * linux/Makefile.in: Add rules for the signalent.h file.
3666 * linux/alpha/Makefile.in: New file.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003667
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003668Sun May 19 01:12:28 1996 J. Richard Sladkey <jrs@world.std.com>
3669
3670 * version.c: Version 3.0.12 is released.
3671
3672 * linux{,alpha}/ioctlent.sh: Tweak for recent kernels.
3673 From Michael E Chastain <mec@duracef.shout.net>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003674
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003675 * defs.h (SUPPORTED_PERSONALITES, DEFAULT_PERSONALITY): New.
3676 * syscall.c (set_personality): New.
3677 * strace.c (main): Call set_personality.
3678 * defs.h, syscall.c, ioctl.c, signal.c: Make sysent, errnoent,
3679 ioctlent, and signalent indirect pointers and redirect them
3680 based on personality.
3681 * {sunos4,svr4,linux{,/alpha}}/signalent.h: New files.
3682 Suggested by Tom Dyas <tdyas@eden.rutgers.edu>.
3683
3684 * util.c (upeek): Handle case where ptrace returns a long
3685 and sizeof(long) != sizeof(int).
3686 From Richard Henderson <richard@twiddle.tamu.edu>
3687
3688Fri May 17 21:03:36 1996 J. Richard Sladkey <jrs@world.std.com>
3689
3690 * version.c: Version 3.0.11 is released.
3691
3692 * many files: Fix more printf warnings for other platforms.
3693
3694 * ipc.c (sys_msgrcv) [LINUX]: Conditionalize definition of ipc_wrapper.
3695
3696 * linux/dummy.h: Handle missing library support for {send,recv}msg.
3697 Reported by Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
3698
3699 * linux/syscall.h (sys_utimes): Fix a typo in the declaration.
3700 From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003701
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003702Fri May 17 00:50:06 1996 J. Richard Sladkey <jrs@world.std.com>
3703
3704 * version.c: Version 3.0.10 is released.
3705
3706 * Makfile.in: Add os/arch to includes so that a given arch
3707 (like alpha) can override the native arch (like i386).
3708 * configure.in: Check for sendmsg.
3709
3710 * net.c: Make sendmsg and recvmsg dependent on an autoconf
3711 test. Reported by Michael E Chastain <mec@duracef.shout.net>.
3712
3713 * acconfig.h, configure.in: Detect the alpha.
3714 * ioctl.c: Handle the alpha.
3715 * defs.h: Make some members long for the alpha. Define
3716 some register nicknames. Add support for WAITEXECVE.
3717 * file.c [ALPHA]: Support the alpha for statfs. Add
3718 osf_statfs and osf_fstatfs for the alpha. Make damn sure
3719 major and minor results are suitable for passing to printf.
3720 * signal.c, syscall.c: Support the alpha.
3721 * process.c: Add alpha user offsets.
3722 * most files: Use %l? for printf arguments since
3723 most are now longs for the alpha.
3724 * linux/alpha/{errnoent.h,ioctlent.{h,sh},syscallent.h}:
3725 New for the alpha.
3726 From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
3727
3728Wed May 15 00:29:37 1996 J. Richard Sladkey <jrs@world.std.com>
3729
3730 * version.c: Version 3.0.9 is released.
3731
3732 * config.in, config.sub, install-sh: Upgrade to autoconf 2.10.
3733
3734 * linux/dummy.h, linux/syscallent.h, linux/syscall.h: Add recent
3735 Linux kernel version system calls.
3736
3737Wed Mar 13 01:03:38 1996 J. Richard Sladkey <jrs@world.std.com>
3738
3739 * ipc.c [SUNOS4]: Add SunOS support for decoding IPC calls.
3740 * syscall.c [SUNOS4]: Compile decode_subcall on SunOS and
3741 decode IPC calls using it.
3742 * sunos4/dummy.h: Alias sys_semop to printargs.
3743 * sunos4/syscall.h: Add new pseudo syscalls for IPC.
3744 * sunos4/syscallent.h: Include new subcalls for IPC.
3745 From Matthias Pfaller <leo@dachau.marco.de>.
3746
3747Tue Feb 13 22:08:25 1996 J. Richard Sladkey <jrs@world.std.com>
3748
3749 * version.c: Version 3.0.8 is released.
3750
3751 * time.c [LINUX]: Explicitly include linux/version.h.
3752
3753 * strace.c (main): Don't let them even *try* to
3754 get strace to attach to itself since some systems
3755 don't handle this case very gracefully.
3756 Reported by David S. Miller <davem@caip.rutgers.edu>.
3757
3758 * Makefile.in (distclean): Fix it for subdirectories.
3759
3760 * sunos4/syscallent.h, svr4/syscallent.h: Fill in the new
3761 sys_flags member for each defined system call.
3762
3763Fri Dec 8 01:17:28 1995 Rick Sladkey <jrs@world.std.com>
3764
3765 * defs.h (TRACE_*): New flags to describe what class
3766 of system call each system call is.
3767 (sysent): Add sys_flags member.
3768 * syscall.c (sysent): Define (and later undef) abbreviations
3769 for the system call class flags.
3770 (lookup_class): New function to translate strings to
3771 system call class flags.
3772 (qualify): Handle new system call class mechanism.
3773 * linux/syscallent.h: Fill in the new sys_flags member
3774 for each defined system call.
3775
3776 * defs.h (print_sock): Remove redundant and non-K&R C
3777 compatible prototype. From Juergen Weigert
3778 <jnweiger@immd4.informatik.uni-erlangen.de>.
3779
3780Thu Dec 7 01:17:40 1995 Rick Sladkey <jrs@world.std.com>
3781
3782 * linux/ioctlent.sh: Tweak to improve ioctl accuracy.
3783 From Michael E Chastain <mec@duracef.shout.net>.
3784
3785 * system.c (includes) [LINUX]: Add linux/nfs.h for recent
3786 kernels. From Michael E Chastain <mec@duracef.shout.net>.
3787
3788Wed Dec 6 21:52:28 1995 Rick Sladkey <jrs@world.std.com>
3789
3790 * file.c (sprintfstype): Enclose string result in double
3791 quotes.
3792
3793 * time.c (sys_adjtimex) [LINUX]: Conditionalize
3794 constantly evolving timex structure.
3795 From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
3796
3797 * defs.h, syscall.c, strace.c: Rename syscall to
3798 trace_syscall and change prototype and all callers
3799 because of broken Linux shared libraries.
3800 From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
3801
3802 * Makefile.in (clean): Check for a file with test -f not
3803 test -d. From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
3804
3805Tue Sep 26 02:32:31 1995 Rick Sladkey <jrs@world.std.com>
3806
3807 * version.c: Version 3.0.7 is released.
3808
3809 * util.c (string_quote): Fix thinko which caused core
3810 dumps for strings with quotes in them.
3811 Reported by Marty Leisner <leisner@sdsp.mc.xerox.com>.
3812
3813 * linux/Makefile.in (errnoent.h rule): Grab all errno.h
3814 files from /usr/include, not just the linux one.
3815 From Michael E Chastain <mec@duracef.shout.net>.
3816
3817 * linux/errnoent.sh: Total rewrite to handle more ioctls with
3818 fewer false positives on more kernel flavors.
3819 From Michael E Chastain <mec@duracef.shout.net>.
3820
3821Mon Sep 4 01:29:22 1995 Rick Sladkey <jrs@world.std.com>
3822
3823 * version.c: Version 3.0.6 is released.
3824
3825 * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
3826 sys_msync.
3827 * mem.c (mctl_funcs, mctl_lockas, sys_mctl): Conditionalize
3828 on MC_SYNC instead of HAVE_MCTL.
3829 (mctl_sync): Conditionalize on MS_ASYNC instead of HAVE_MCTL.
3830 (sys_msync): New function.
3831
3832Sat Sep 2 12:06:04 1995 Rick Sladkey <jrs@world.std.com>
3833
3834 * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
3835 sys_flock and sys_getdents.
3836 * desc.c (flockcmds, sys_flock): Conditionalize on LOCK_SH
3837 not SUNOS4.
3838 * file.c (sys_getdents): Define unconditionally and handle
3839 LINUX case.
3840 * strace.c (main): Disallow username option unless both real
3841 and effective uids are root.
3842
3843Wed Aug 30 01:29:58 1995 Rick Sladkey <jrs@world.std.com>
3844
3845 * strace.c (main): Ensure that run_uid and run_gid are
3846 always set to something meaningful.
3847 (main, newoutf) [!SVR4]: Swap real and effective uids while
3848 opening any output files.
3849 (main) [!SVR4]: Treat effective uid of root as a request
3850 to handle suid binaries correctly using the real uid of
3851 the invoking user.
3852
3853Sat Aug 19 00:06:08 1995 Rick Sladkey <jrs@world.std.com>
3854
3855 * Makefile.in: Add `|| true' to clean rule because
3856 although GNU make 3.74 uses `sh -c' to invoke commands
3857 every other make in the world uses `sh -ec'.
3858
3859 * syscall.c (syscall) [SVR4, MIPS]: The fifth and subsequent
3860 arguments appear to be stored on the stack, not in the
3861 registers following A3 (empirical result).
3862
3863 * defs.h: Add prototype for printsock.
3864 * svr4/dummy.h: Remove generic handling of sys_mount.
3865 * system.c [SVR4, MIPS]: Include several system headers to cleanly
3866 get access to SGI mount information.
3867 (mount_flags, nfs_flags) [SVR4, MIPS]: New objects.
3868 (sys_mount) [SVR4, MIPS]: New function.
3869 (sys_mount) [SVR4, !MIPS]: New function.
3870
3871Tue Jul 4 00:30:34 1995 Rick Sladkey <jrs@world.std.com>
3872
3873 * version.c: Version 3.0.5 is released.
3874
3875 * desc.c, resource.c, strace.c, syscall.c, time.c: Cast tv_sec and
3876 tv_usec members to long when using printf.
3877
3878 * ipc.c: Omit define of __KERNEL__.
3879 ({MSG,SEM,SHM}_{STAT,INFO}): Explicitly define those things we
3880 want which __KERNEL__ used to provide.
3881 (sys_msgrcv): Change reference to ipc_kludge structure to
3882 look-alike ipc_wrapper to avoid dependence on __KERNEL__.
3883
3884 mem.c (mmap_flags) [MAP_{GROWSDOWN,DENYWRITE,EXECUTABLE}]: Add
3885 Linux specific options.
3886
3887 syscall.c: Use SYS_ERRLIST_DECLARED instead of guessing.
3888 [E{RESTART{SYS,NO{INTR,HAND}},NOIOCTLCMD}]: Explicitly define
3889 instead of depending of __KERNEL__.
3890
3891 term.c: Cast c_{i,o,c,l}flag to long when using printf.
3892
3893Tue Jun 6 00:27:48 1995 Rick Sladkey <jrs@world.std.com>
3894
3895 * aclocal.m4 (AC_DECL_SYS_ERRLIST, AC_DECL__SYS_SIGLIST): New.
3896 * configure.in: Call AC_DECL_SYS_ERRLIST, AC_DECL_SYS_SIGLIST,
3897 and AC_DECL__SYS_SIGLIST.
3898 * acconfig.h (SYS_ERRLIST_DECLARED): New.
3899 * strace.c (strerror): Use SYS_ERRLIST_DECLARED.
3900 (strsignal): Use SYS_SIGLIST_DECLARED.
3901
3902 net.c (sys_socket): Omit inadvertent surplus comma when
3903 protocol family isn't PF_INET.
3904
3905 util.c (dumpstr): Fix incorrect printing of one too many
3906 characters when the length is not an even multiple of 16 bytes.
3907 Reported by Juergen Weigert
3908 <jnweiger@immd4.informatik.uni-erlangen.de>.
3909
3910Thu May 4 23:37:47 1995 Rick Sladkey <jrs@world.std.com>
3911
3912 * ioctl.c (compare): Change prototype to match POSIX qsort.
3913 * signal.c (sigishandled) [SVR4]: Omit everything after return.
3914 * strace.c (trace) [SVR4]: Break out of for loop instead of
3915 returning when finished so final return statement is executed.
3916 * syscall.c (internal_syscall): Add more SYS_wait* variations.
3917 (syscall) [LINUX]: Correct typo which commented out the M68K
3918 argument to ifdef.
3919 * util.c (printstr): Cast unsigned char pointer argument
3920 to char pointer in umovestr call.
3921 (dumpstr): Likewise for umoven.
3922
3923Wed May 3 01:10:56 1995 Rick Sladkey <jrs@world.std.com>
3924
3925 * version.c: Version 3.0.4 is released.
3926
3927 * signal.c (sys_sigblock): Move after the definition of
3928 sys_sigsetmask that it calls to avoid an implicit declaration.
3929 * stream.c (transport_user_options, transport_server_options):
3930 Only needed if TI_BIND is defined.
3931 * configure.in: Add -Wno-implicit to WARNFLAGS on SunOS 4.x.
3932
3933 * process.c (internal_fork) [SVR4]: Fix a typo that omitted
3934 the tcp arguement from the call to exiting. Add getrval2
3935 check so no fork processing is done in the child.
3936 (printwaitn): Initialize exited so that its value is defined
3937 for all flows of execution.
3938
3939Tue May 2 22:39:42 1995 Rick Sladkey <jrs@world.std.com>
3940
3941 * linux/dummy.h: Add aliases for sysfs, personality, afs_syscall,
3942 setfsuid, setfsgid, and _llseek syscalls.
3943 * linux/syscall.h: Add prototypes for them.
3944 * linux/syscallent.h: Add them to the syscall entries table.
3945 * system.c (headers) [LINUX]: Include linux/unistd.h to get __NR_*
3946 defines and conditionally include linux/personality.h if
3947 __NR_personality is defined.
3948 (personality_options) [LINUX]: New table.
3949 (sys_personality) [LINUX]: New function.
3950
3951Tue May 2 00:20:39 1995 Rick Sladkey <jrs@world.std.com>
3952
3953 * strace.c (trace) [!SVR4]: Change forever loop to one predicated
3954 on the number of traced processes so that we can have untraced
3955 children (e.g. via popen).
3956
3957 * strace (main) [!SVR4]: Call fake_execve to get the actual
3958 exec and its arguments into the trace.
3959 (environ): Declare it.
3960 * process.c (fake_execve): New function.
3961 (headers): Include sys/syscall.h to get SYS_* defines.
3962
3963 * process.c (sys_execv, sys_execve): Surround argument annotations
3964 with C comment delimiters.
3965 (printargv, printargc): The arg vector is an array of char pointers
3966 not ints.
3967
3968 * strace.c (printleader): Also check for multiple -p arguments
3969 when deciding whether to print the pid field.
3970
3971 * strace.c (strerror) [!HAVE_STRERROR]: New function.
3972 * defs.h (strerror, strsignal): Add these prototypes if we provide
3973 the functions.
3974 * configure.in (AC_CHECK_FUNCS): Add strerror.
3975
3976 * strace.c (main, proc_poller): Add SIGPIPE to the list of caught
3977 and blocked signals.
3978
3979 * strace.c (main): Add username option. Verify they are root before
3980 letting them use it. Look up the ids in the password file. Set
3981 them just before executing the program.
3982 From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
3983
3984Sat Apr 29 00:09:56 1995 Rick Sladkey <jrs@world.std.com>
3985
3986 * version.c: Version 3.0.3 is released.
3987
3988 * system.c (mount_flags) [LINUX]: Omit duplicated MS_NOSUID entry.
3989 From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
3990
3991 * strace.c (outfname): Initialize to NULL.
3992 (main): Defer output file processing until after arguments.
3993 Allow either a pipe or a bang for command arguments.
3994 Check if outfname is NULL instead of checking outf for stderr.
3995 Reinitialize each startup TCB's outf to fix -p/-o ordering bug.
3996 (droptcb): Reset close TCB's outf to NULL instead of stderr.
3997 (tprintf): Avoid calling vfprintf if outf is NULL.
3998
3999 * strace.c (main): Use popen if -o argument begins with a pipe.
4000 From Marty Leisner <leisner@sdsp.mc.xerox.com>.
4001
4002 * process.c (printstatus): Fix a typo where WIFSIGNALED was meant
4003 but WIFSTOPPED was used.
4004
4005 * Makefile.in: Add an EXTRA_DEFS variable and use it in the .c.o
4006 rule to prevent the comment from being untrue.
4007
4008Fri Apr 28 22:01:56 1995 Rick Sladkey <jrs@world.std.com>
4009
4010 * strace.c (sys_exit): Move follow fork code to internal_exit.
4011 (sys_fork): Move follow fork code to internal_fork.
4012 (sys_execv, sys_execve): Move follow fork code to internal_exec.
4013 (sys_waitpid, sys_wait4): Move follow fork code to internal_wait.
4014 (vforking): Remove this static variable and check scno in
4015 internal_fork instead.
4016 (internal_exit, internal_fork, internal_exec, internal_wait): New
4017 functions.
4018 * defs.h: Add prototypes for the new internal_* functions.
4019 * syscall.c (syscall): Move syscall entering trace qualifier check
4020 and reprint checking after context decoding and precede them with
4021 a call to internal_syscall. Precede syscall exiting trace
4022 qualifier check with a call to internal_syscall.
4023 (internal_syscall): New function.
4024
4025 * defs.h (struct tcb): Make scno signed.
4026 * strace.c (syscall) Make u_error signed.
4027 [LINUX, I386]: Avoid unsigned cast in eax check.
4028 * syscall.c (sys_indir): Make i, scno, and nargs signed.
4029 * desc.c (sys_select): Make cumlen unsigned
4030
4031Mon Apr 24 23:52:47 1995 Rick Sladkey <jrs@world.std.com>
4032
4033 * net.c (socktypes): Add SOCK_PACKET.
4034
4035Sun Apr 2 23:50:39 1995 Rick Sladkey <jrs@world.std.com>
4036
4037 * Makefile (clean): Check explicitly for a Makefile in subdirs
4038 before running make in them.
4039
4040Sun Mar 26 12:37:21 1995 Rick Sladkey <jrs@world.std.com>
4041
4042 * strace.c [MIPS] (proc_open): Conditionalize run on MIPS.
4043 [MIPS] (detach): Initialize error for MIPS case.
4044 (trace): Initialize ioctl_result and ioctl_errno for overly helpful
4045 compilers.
4046 * syscall.c (decode_subcall): Move variable i into conditionals
4047 that use use it.
4048 * system.c (syssgi_options): Conditionalize SGI_RECVLMSG and
4049 SGI_SET_FPDEBUG that SGI decided to drop. I don't have the stomach
4050 to change them all.
4051 * term.c (term_ioctl): Force [c_[iocl]flags members to long before
4052 printing since we don't know what the size of their type is.
4053 * util.c [SVR4, MIPS] (umoven): Prevent MIPS from using pread even
4054 if autoconf detects it since it seems to either not work or do
4055 something else entirely on Irix 5.3.
4056
4057Sun Mar 26 00:01:11 1995 Rick Sladkey <jrs@world.std.com>
4058
4059 * version.c: Version 3.0.2 is released.
4060 * linux/dummy.h: Make sys_fchdir like sys_close instead of printargs
4061 so that the file descriptor arg is decimal.
4062
4063Sat Mar 25 22:50:13 1995 Rick Sladkey <jrs@world.std.com>
4064
4065 * net.c [LINUX] (protocols): Explicitly define all IPPROTO_* entries
4066 because on Linux they are enumerators.
4067
4068 * system.c [LINUX] (mount_flags): Handle renaming of MS_SYNC to
4069 MS_SYNCHRONOUS.
4070
4071 * util.c (printxval): When there is no translation, print the actual
4072 number first and the the default value as a C comment.
4073
4074 * net.c (sys_send, sys_sendto, sys_sendmsg, sys_getsockopt,
4075 sys_setsockopt): Change first argument from unsigned to signed to
4076 cater to the frequent practice of calling system calls with a file
4077 descriptor of -1.
4078 * mem.c (sys_mmap): Likewise.
4079
4080Sun Mar 19 13:53:52 1995 Rick Sladkey <jrs@world.std.com>
4081
4082 * signal.c [LINUX] (signalent): Handle old and new values of SIGIO.
4083
4084Sun Dec 11 22:51:51 1994 Rick Sladkey <jrs@world.std.com>
4085
4086 * version.c: Version 3.0.1 is released.
4087 * Makefile.in, configure.in, aclocal.m4: Changes for autoconf 2.0.
4088 * config.guess, config.guess: Update from the FSF.
4089 * install-sh: New from the FSF.
4090
4091Mon Dec 5 20:51:29 1994 Rick Sladkey <jrs@world.std.com>
4092
4093 * Makefile.in: Add m68k arch.
4094 * acconfig.h (M68K): Add m68k define.
4095 * configure.in: Add detection of arch m68k.
4096 * process.c [M68K] (struct_user_offsets): Support m68k registers and
4097 offsets.
4098 * signal.c [M68K] (sigcontext_struct): Support m68k sigcontext
4099 structure.
4100 [M68K] (sys_sigreturn): Support m68k sigreturn handling.
4101 * syscall.c [M68K] (syscall): Support m68k syscall number register
4102 and errno in d0 instead of eax.
4103 * util.c [M68K] (getpc, printcall, setbpt, clearbpt): Support m68k
4104 program counter in PT_PC instead of EIP.
4105 [M68K] (LOOP): Support m68k loop instruction.
4106 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
4107
4108 * mem.c [MAP_ANONYMOUS] (mmap_flags): Correct inadvertent reference
4109 to MAP_FIXED instead of MAP_ANONYMOUS.
4110 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
4111
4112 * signal.c [LINUX] (signalent): Signal 30 is now SIGPWR.
4113 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
4114
4115Mon Dec 5 01:05:46 1994 Rick Sladkey <jrs@world.std.com>
4116
4117 * defs.h (tprintf): Fix typo in non-gcc ansi prototype for tprintf.
4118 Reported by Thanh Ma <tma@encore.com>.
4119
4120 * strace.c (cleanup): Send SIGCONT before SIGTERM because Linux
4121 1.1.62 doesn't continue a traced child when the parent exits.
4122 Reported by Matt Day <mday@artisoft.com>.
4123
4124 * system.c [LINUX]: Include netinet/in.h before arpa/inet.h.
4125
4126 * util.c (printstr): Fix longstanding bug in notating string
4127 continuation.
4128
4129 * strace.c [SVR4] (proc_open): Specifically wait for the child the
4130 child to go into the execve syscall to avoid spurious traces.
4131 [LINUX] (detach): Conditionalize the status variable.
4132
4133Sun Dec 4 23:21:42 1994 Rick Sladkey <jrs@world.std.com>
4134
4135 * Makefile.in: Add mips arch.
4136 * acconfig.h (MIPS): Add mips define.
4137 * configure.in: Add detection of opsys irix5 and arch mips. Check
4138 for prctl function.
4139 Check for sys/sysconfig.h header.
4140 * defs.h (MAX_ARGS): Bump maximum syscall arguments from 8 to 32.
4141 * file.c [SVR4]: Include sys/cred.h.
4142 (access_flags): Update access flags for SGI.
4143 (sprinttime): Change type of sprinttime argument from unsigned
4144 long to time_t.
4145 * process.c [HAVE_PRCTL]: Include sys/prctl.h.
4146 [HAVE_PRCTL] (prctl_options, sys_prctl): New for SGI.
4147 (printsiginfo): Conditionally compile SI_TIMER and SI_MESGQ.
4148 Cast si_band member to long before printing.
4149 * signal.c (sigact_flags): Add _SA_BSDCALL for SGI.
4150 (sigprocmaskcmds): Add SIG_SETMASK32 for SGI.
4151 * strace.c [SVR4] [MIPS]:
4152 (foobar): New dummy signal handler.
4153 (main): Install a dummy signal handler in the child before pausing
4154 to work around an SGI bug in PRSABORT.
4155 (proc_open): Send a interrupt to the child instead of aborting the
4156 syscall which doesn't work on Irix5.2.
4157 * svr4/dummy.h: Add new unfinished SGI syscalls
4158 (e.g. sys_sysmp, sys_sginap, etc.). Handle some SGI syscalls like
4159 existing calls (e.g. sys_ksigaction like sys_sigaction).
4160 Printargs does the print thing for sys_sethostid.
4161 * svr4/syscall.h: Declare all new SGI syscalls.
4162 (SGI_KLUDGE): Define syscall table starting index to be 1 for SGI
4163 and add it to all subcall entry points.
4164 (SYS_pgrpsys_subcall, SYS_sigcall_subcall, SYS_context): Don't
4165 decode as subcalls on MIPS. Instead, use the normal syscalls.
4166 * svr4/syscallent.h [MIPS]: Lead syscall table with a dummy entry
4167 since SGI syscall numbers are off by one.
4168 [MIPS] (sys_pgrpsys): Rename to sys_setpgrp on SGI.
4169 [MIPS] (sys_xenix): Rename to sys_syssgi on SGI.
4170 [MIPS] (sys_sysmachine): Rename to sys_sysmips on SGI.
4171 [MIPS]: Conditionalize SVR4 extension into SGI and Solaris classes.
4172 * syscall.c (dumpio): Validate descriptor against MAX_QUALS.
4173 [HAVE_PR_SYSCALL] (syscall): Conditionalize SYS_vfork.
4174 [MIPS] (syscall): Add SGI section for decoding u_error and u_rval.
4175 Add workaround for broken SGI pr_sysarg on syscall entry.
4176 [SVR4] (syscall): Conditionalize subcall decoding for
4177 SYS_ptrpsys_subcall, SYS_sigcall_subcall and SYS_context_subcall.
4178 [SVR4] [MIPS] (getrval2): Handle SGI.
4179 * syscallent.sh: Dork the sed line to be choosier about SYS_ lines.
4180 * system.c [HAVE_SYSCONFIG_H]: Include sys/sysconfig.h.
4181 [MIPS] (syssgi_options, sys_syssgi): New for SGI.