]> granicus.if.org Git - strace/blob - ChangeLog
114c2220b96e23a7085972fa1b95f2ca72765317
[strace] / ChangeLog
1 2000-09-03  Wichert Akkerman <wakkerma@debian.org>
2
3   *  process.c: perform bpt trick for clone as well so we can get the
4      pid of the child before it starts doing something
5   *  file.c: rename dirent64 struct to kernel_dirent64 so things compile
6      again with newer libcs
7
8 2000-09-01  Wichert Akkerman <wakkerma@debian.org>
9
10   *  lots of files: merge patch from GaĆ«l Roualland to add
11      support for FreeBSD.
12
13 2000-08-09  Wichert Akkerman <wakkerma@debian.org>
14
15   * file.c: update to reflect that st_ino suddenly became a long long
16     in the in Linux 2.4.0-test6
17
18 2000-08-09  Wichert Akkerman <wakkerma@debian.org>
19
20   * test/clone.c: minor fixup
21   * Another bunch of patches from John Hughes merged:
22   * signal.c:
23     + SVR4 printcontext(): sigset_t != sigset_t*
24     + getcontext returns a value, so print on exit of syscall
25     + add UC_FP to ucontext_flags for OS writers that can't spell
26     + sys_signal(): special case SIG_{ERR,DFL,IGN}
27     + decode_subcall(): only do subcall range checking when needed
28   * bunch of UnixWare updates
29   * aclocal.m4, acconfig.h, configure.in: add test for long long type
30
31 2000-07-04  Wichert Akkerman <wakkerma@debian.org>
32
33   * net.c: add SOL_PACKET and SOL_RAW socket options, update
34     SOL_IP and SOL_TCP
35
36 2000-06-23  Wichert Akkerman <wakkerma@debian.org>
37
38   * strace.c: close outf before we exec a child process
39
40 2000-06-09  Ulrich Drepper  <drepper@redhat.com>
41
42   * configure.in: Don't link against libnsl on Linux, it's unnecessary.
43   * defs.h (struct tcb): Make auxstr member const.
44   * file.c (fsmagic): And many more magic numbers.
45   * util.c: Don't include <linux/ptrace.h> for glibc 2.1 and up.
46
47 2000-04-26  Wichert Akkerman <wakkerma@debian.org>
48
49   * defs.h: balance #if/#endif again
50   * system.c: fix return statements in sys_capget()
51   * Merge updates from Topi Miettinen <Topi.Miettinen@nic.fi>:
52     + file.c: add F_[SG]ETSIG to fcntl flags
53     + strace.c: don't setre[gu]id if not needed
54     + system.c: handle sys_reboot for Linux
55     + term.c: add baudrate constants up to B4000000
56     + linux/**/syscallent.h: note that munlockall has no arguments
57
58 2000-04-25  David Mosberger  <davidm@hpl.hp.com>
59
60   * CREDITS: fix email address
61   * process.c: handle PR_[GS]ET_UNALIGN and PR_[GS]ET_KEEPCAPS
62   * signal.c: honour offset of sigconfig in sigframe structure for
63     Linux/ia64
64   * linux/ia64/syscallent.h: Add perfmonctl, pivotroot, mincore, and
65     madvise syscalls.
66   * syscall.c (syscall_enter): With Kevin's latest ptrace patches,
67     AR_BSP points to the _end_ of the active register frame, so we need
68     to adjust bsp by moving it back by the size of the active frame
69     before using it.
70
71 2000-04-24  Wichert Akkerman <wakkerma@debian.org>
72
73   * process.c: add sparc support to change_syscall
74
75 2000-04-22  Wichert Akkerman <wakkerma@debian.org>
76
77   * linux/mips/syscallent.h: fix some typos
78
79 2000-04-14  Wichert Akkerman <wakkerma@debian.org>
80
81   * linux/mips/syscallent.h: added names for SVR4, SYSV, BSD4.3 and POSIX
82     syscalls
83
84 2000-04-13  Wichert Akkerman <wakkerma@debian.org>
85
86   * defs.h: Linux/MIPS uses syscalls up to >4k, so set MAX_QUALS to
87     4999
88
89 2000-04-09  Wichert Akkerman <wakkerma@debian.org>
90
91   * README-linux: updated to note that strace might not compile
92     with development kernels
93   * bjm.c: sys_query_module: check if malloc succeeds
94   * system.c: sys_cap[gs]et(): check if malloc succeeds, only malloc once
95   * linux/syscallent.h: updated for 2.3.99pre3
96   * linux/alpha/syscallent.h: updated for 2.3.99pre3, add all osf syscalls
97     even though Linux doesn't implement them
98   * syscall.c: add global variables for MIPS registers as well
99   * syscall.c: move global variables to before get_scno since that uses them
100   * util.c: oops, misspelled defined
101   * process.c: fix ptrace calls in change_syscall
102   * mem.c: decode sys_madvise
103   * Merge patch from Topi Miettinen <Topi.Miettinen@nic.fi>
104     + add support for quotactl, fdatasync, mlock, mlockall, munlockall & acct
105     + small fix for RLIMIT_* and RUSAGE_BOTH
106     + enhace support for capget and capset
107
108 2000-02-19 Wichert Akkerman <wakkerma@debian.org>
109
110   * test/vfork.c: new file to test vfork traces
111   * test/.cvsignore: new file
112   * defs.h: Up maximum number of traced processed to 64
113   * strace.c: Disable some debugging code from davidm 
114   * implement setarg for more architectures
115   * implement change_syscall
116
117 1999-12-27  Morten Welinder  <terra@diku.dk>
118
119         * syscall.c (lookup_signal, lookup_desc): isdigit requires an
120         _unsigned_ char parameter.
121
122 2000-02-14 Wichert Akkerman <wakkerma@debian.org>
123
124   * S390 updates
125
126 2000-02-03 Wichert Akkerman <wakkerma@debian.org>
127
128   * Merge Linux/ia64 patches
129
130 2000-01-02 Pavel Machek      <pavel@ucw.cz>
131
132   * probe if sys/poll.h exists in configure + minor cleanups
133
134   * syscall.c: split trace_syscall into few pieces to make code readable
135
136 2000-01-21 Wichert Akkerman  <wakkerma@debian.org>
137
138   * Release version 4.2 to get the current updates out and so
139     we can concentrate in finishing the clone support.
140
141 2000-01-11 Wichert Akkerman  <wakkerma@debian.org>
142
143   * Add 1900 to tm_year in sprinttime
144
145 1999-12-24  Wichert Akkerman  <wakkerma@debian.org>
146
147  * file.c: protect printstat64 with STAT64 instead of linux so we can
148    compile on Linux architectures that don't have it
149  * util.c: fix LOOP for ARM
150
151 Fri Dec 24 18:05:00 EST 1999
152
153 1999-12-23  Ulrich Drepper  <drepper@cygnus.com>
154
155  * file.c: Use ugly libc_stat trick also for stat64.
156    Implement sys_stat64, sys_fstat64, sys_lstat64, and printstat64.
157  * process.c (internal_clone): Fix a few typos and add definitions to make
158    it at least compile.
159  * linux/syscall.h: Declare sys_stat64, sys_lstat64, and sys_fstat64.
160  * linux/syscallent.h: Define table entries for sys_stat64, sys_lstat64,
161    and sys_fstat64.
162  * aclocal.m4: Define AC_STAT64.
163  * acconfig.h: Define HAVE_STAT64.
164  * configure.in: Add AC_STAT64.
165
166 Thu Dec 23 15:01:37 CET 1999 Wichert Akkerman <wakkerma@debian.org>
167
168   * Merge patch from ftp://oss.software.ibm.com/linux390/ to add
169     support for Linux on the IBM S/390 architecture
170   * process.c: add internal_clone(), currently only shows the options
171   * syscall.c: use internal_clone to handle SYS_clone
172
173 Mon Dec 20 00:27:50 CET 1999 Wichert Akkerman <wakkerma@debian.org>
174
175   * Rewrite mmap-handling to support mmap2 on Linux
176
177 Tue Dec 14 11:35:16 CET 1999 Wichert Akkerman <wakkerma@debian.org>
178
179   * Note that Linux can handle sys_semop() as well
180
181 Tue Nov 30 11:05:26 CET 1999 Wichert Akkerman <wakkerma@debian.org>
182
183   * Include linux/in6.h for glibc2.0 and older
184
185 Mon Nov 29 16:33:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
186
187   * Merge patches from John Hughes to make configure support UnixWare
188
189 Sat Nov 27 21:38:17 CET 1999 Wichert Akkerman <wakkerma@debian.org>
190
191   * Enhance sys_query_module
192
193 Fri Nov 26 10:51:55 CET 1999 Wichert Akkerman <wakkerma@debian.org>
194
195   * Patches from John Hughes:
196     + cosmectic fix in sys_getpmsg
197     + allow net.c to compile on systems without AF_INET6
198     + Only use long_to_sigset on Linux systems
199     + UnixWare treats sigmask_t and sigmask_t* as the same thing
200     + Add pollhack
201     + Parse mount arguments for UnixWare
202     + ACL fixes for UnixWare
203
204 Fri Nov 26 01:28:09 CET 1999 Wichert Akkerman <wakkerma@debian.org>
205
206   * Release 4.1 to get all the changes made out there
207
208 Thu Nov 18 18:04:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
209
210   * Merge stracefork from Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>
211     + Socket calls parsed better
212         + bunch of alpha OSF syscalls added
213         + Fix alpha 32/64 bit issues
214
215 Mon Nov  1 20:52:08 CET 1999 Wichert Akkerman <wakkerma@debian.org>
216
217   * Move Linux kernelmodule-functions from system.c to bjm.c and
218     remove duplicate for sys_create_module
219   * Linux MIPS updates:
220     + Play with #ifdef's in net.c to get IPv6 right
221     + Use printargs for vm86-syscall
222
223 Sun Oct 31 22:03:00 CET 1999 Wichert Akkerman <wakkerma@debian.org>
224
225   * Merge Linux mips patch from Florian Lohoff <flo@rfc822.org>
226
227 Mon Oct 11 00:36:25 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
228
229   * Merge patch from Keith Owens <kaos@ocs.com.au> to sys_query_module
230     and sys_delete_module correctly
231
232 Wed Oct  6 02:00:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
233
234   * Update cvsbuild to give a better error if autoconf isn't installed
235   * Add test for linux/ptrace.h to configure
236   * Since we define GNU_SOURCE in the Makefile we don't need to define
237     USE_GNU in file.c anymore
238
239 Fri Sep 10 04:35:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
240
241   * #define USE_GNU before including file.c so we get some extra O_* flags
242
243 Tue Aug 31 16:27:21 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
244
245   * Add missing } in IPv6 output
246
247 Tue Aug 31 01:23:08 CEST 1999  Wichert Akkerman <wakkerma@debian.org>
248
249   * Update copyright for strace-graph to BSD to be consistent with
250     the rest of strace
251
252 Mon Aug 30 00:53:57 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
253
254   * Merge patch from Daniel Jacobowitz: KERN_JAVA_* and KERN_SECURELVL aren't
255     defined for all kernelversions
256   * Add strace-graph, written by Richard Braakman <dark@xs4all.nl>
257
258 Thu Aug 19 13:10:15 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
259
260   * linux/sparc/syscall.h: Declare create_module/init_module.
261   * configure.in: Allow compilation in a different directory
262     than the source one.
263   * signal.c: Use asm/reg.h and struct regs instead of pt_regs
264     so that we don't depend on asm/ptrace.h which clashes with
265     glibc sys/ptrace.h.
266   * util.c: Likewise.
267   * syscall.c: Likewise.
268
269 Wed Aug  4 18:01:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
270
271   * Syscall 94 on Linux alpha is sys_poll
272
273 Sun Jul 25 14:38:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
274
275   * Merge in UnixWare patches from John Hughes <john@Calva.COM>
276
277 Thu Jul 15 23:00:32 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
278
279   * Merge patch from Maciej W. Rozycki <macro@ds2.pg.gda.pl>:
280     + Correctly implement fix sys_createmodule (Linux)
281     + Add limited handlig of sys_initmodule (Linux)
282
283 Tue Jul 13 17:07:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
284
285   * Add configure-test for sys/reg.h and use that
286   * Use sys/reg.h instead of asm/ptrace.h
287
288 Sat Jul 10 01:46:10 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
289
290   * Remove hack in signal.c for arm architecture
291   * Add hack so we compile correctly on powerpc
292
293 Fri Jul  9 02:28:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
294
295   * Add a corrected patch from Daniel Jacobowitz
296
297 Thu Jul  8 16:00:04 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
298
299   * Merge patch from Daniel Jacobowitz to allow us to use the kernel types
300     for the stat structure
301
302 Thu Jun 24 15:54:18 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
303
304   * Fix test for sys/reg include
305
306 Tue Jun 22 17:26:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
307
308   * Fixed some Linux/powerpc sillyness, thanks to Daniel Jacobowitz
309   * Fixed some SunOS compile problems earlier that I forgot to include
310     here
311
312 Mon Jun 14 12:44:25 CEST 1999
313
314   * Avoid leakint fd into child when forking, patch from
315     John Hughes <john@Calva.COM>
316
317 Fri Jun 11 14:54:47 CEST 1999
318
319   * Applied IRIX64 patch from Thomas E. Dickey <dickey@clark.net>
320   * Applied Solaris and manpage updates from Guy Harris <guy@netapp.com>
321
322 Wed Jun  9 14:48:49 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
323
324   * Brought syscall list for alpha up to date
325
326 Wed Jun  2 18:30:12 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
327
328   * system.c: sys_umount2 syscall support.
329   * linux/sparc/errnoent.h: Update sparc-linux errnos.
330   * linux/sparc/syscall.h: Update used sparc-linux syscalls.
331   * linux/sparc/syscallent.h: Match 2.2.9 system calls.
332   * file.c: sparc-linux asm/stat.h uses dev_t etc. types,
333     so it needs strace's own copy of the stat structure.
334   * util.c: Make it compile on sparc-linux.
335   * strace.c: Fix strace -f and -ff operation on sparc-linux.
336   * signal.c: rt_sigaction has different arguments on sparc*-linux
337     and alpha-linux.
338   * syscall.c: Recognize sparc64-linux binaries.
339
340 Fri May 28 21:09:00 PST Ulrich Drepper <drepper@cygnus.com>
341
342   * configure.in: Fix typo (CFLAG -> CFLAGS).
343
344   * syscall.c: Don't include linux/ptrace.h explicitly for glibc.
345
346 Thu May 27 13:59:27 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
347
348   * Add some sysctl support, patch from Ulrich Drepper
349
350 Wed May 26 01:04:34 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
351
352   * Use kernel dirent structure for Linux
353
354 Sun May  9 02:18:30 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
355
356   * Merge in patches from Andreas Schwab <schwab@issan.cs.uni-dortmund.de>
357     + some layout and other minor fixes
358     + add some m68k-specific things to linux/syscallent.h. Note that m68k
359       is similar enough to i386 to not need it's own subdirectory
360     + add support for sendfile and mremap syscalls for Linux
361   * Merge in patches from Sascha Schumann <sascha@schumann.2ns.de>
362     + ioctls.h vs sys/ioctl.h on Alpha platform
363     + pointer was casted to an int in stream.c
364     + strsignal() needs -D_GNU_SOURCE in CFLAGS
365     + several other casts changed
366     + correct ARM/POWERPC architecture defines in acconfig.h
367   * Merge in patches from Morten Welinder <terra@diku.dk>
368     + add some autoconf-tests for includefiles
369     + handle solaris version of sigcontext struct (actually I hacked this
370       up again, but the idea is his :)
371
372 Sun Apr 18 22:32:42 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
373
374   * Update syscalls for linux alpha, patch from Bart Warmerdam
375     <bartw@debian.org>
376   * Update sparc code so it actually compiles
377
378 Fri Apr 16 02:18:05 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
379
380   * Add support for old_*stat functions for Linux. Please note you need
381     to use reasonably recent kernel headers to compile strace now.
382   * Change references to LINUX into linux in file.c
383   * Fix include for LDT in mem.c
384
385 Thu Apr 15 22:28:15 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
386
387   * Change in strace maintainership, jrs passed the torch to me.
388   * Use autoconf 2.13
389   * Incorporate all changes already made in the Debian strace package:
390     + compiles with more Linux kernels
391     + added support for more Linux architectures
392     + add support for a lot of extra syscalls
393     + fix some problems with hanging children
394     + check stray syscall after execv
395     + decode capget and capset arguments
396     + add more constants to net.c
397     + detect ROSE networking
398     + add more protocol families to domains
399     + add IPIP protocol
400     + added MSG_PROXY and MSG_CTRUNC to msg_flags
401     + added SO_BSDCOMPAT and SO_REUSEPORT to sockoptions
402     + added IP, IPX and TCP-options
403     + added IP, IPX and TCP support to get-/setsockopt()
404     + added IPX support
405     + updated handling of signals
406
407 Sun Oct 27 22:28:00 1996  J. Richard Sladkey  <jrs@world.std.com>
408
409         * util.c (umovestr) [LINUX]: Handle Linux like SunOS4
410         instead of SVR4.  That is, read a few bytes at a time
411         to avoid overrunning the end of the stack.
412
413 Fri May 31 01:48:49 1996  J. Richard Sladkey  <jrs@world.std.com>
414
415         * version.c: Version 3.1 is released.
416
417 Thu May 23 01:04:43 1996  J. Richard Sladkey  <jrs@world.std.com>
418
419         * aclocal.m4 (AC_DECL_SYS_ERRLIST): Try looking in stdio.h
420         as well since that's where glibc declares it.  Go figure.
421         * signal.c (sys_sigreturn) [ALPHA]: Use sigcontext
422         instead of sigcontext_struct since glibc v5+ apparently
423         plays games with the native OS namespace.
424         From David Mosberger-Tang <davidm@AZStarNet.com>.
425
426 Mon May 20 23:17:14 1996  J. Richard Sladkey  <jrs@world.std.com>
427
428         * version.c: Version 3.0.14 is released.
429
430         * aclocal.m4 (AC_STRUCT_MSG_CONTROL): New macro.
431         * configure.in: Add call to AC_STRUCT_MSG_CONTROL.
432         * net.c (printmsghdr): Handle BSD 4.3 and 4.4 msghdr members
433         differently.
434         Reported by Henrik Storner <storner@osiris.ping.dk>.
435
436         * configure.in: (AC_CHECK_{HEADERS,FUNCS}): Add checks for
437         sys/filio.h and sys/stream.h and remove check for poll.
438         * desc.c (decode_select, sys_select, sys_oldselect) [LINUX]:
439         Handle old and new styles of argument passing for select on Linux.
440         * ioctl.c, stream.c: Conditionalize stream code on presence of
441         sys/stream.h instead of poll because glibc implements poll but
442         not the rest of the stream interface.
443         * signal.c [LINUX]: Standardize on the name sigcontext_struct.
444         (sys_sigprocmask) [ALPHA]: Handle OSF flavor which is more like
445         sigsetmask.
446         * term.c (term_ioctl): Use _VMIN, if present, for TC{G,S}ETA*.
447         * util.c (umoven, umovestr): Move data in long-sized chunks
448         at a time, instead of hard coding it to be 4.
449         From David Mosberger-Tang <davidm@AZStarNet.com>.
450
451 Mon May 20 01:19:36 1996  J. Richard Sladkey  <jrs@world.std.com>
452
453         * version.c: Version 3.0.13 is released.
454
455         * configure.in (AC_CHECK_HEADERS): Add check for asm/sigcontext.h.
456         * signal.c [HAVE_ASM_SIGCONTEXT_H]: Conditionally include
457         asm/sigcontext.h to define sigcontext_struct and don't define it
458         locally if the header is present.
459
460         * syscall.c (nerrnos{0,2}): Correct size computation.
461
462         * Makefile.in: Remove dependencies and rules relating to files
463         normally found in the os directory.  Because of the new scheme we
464         don't know precisely where they come from.  Sigh.
465         * signalent.sh: Make it work for sunos4, linux, and svr4.
466         * {sunos4,linux{,/alpha},svr4}/Makefile.in: Make rules correspond
467         to traditional make syntax.  Add signalent.h to files which can
468         unconditionally be rebuilt.  Prevent signalent.h from being
469         unconditionally being rebuilt since it's customized.
470         * {sunos4,linux{,/alpha},svr4}/{ioctlent,errnoent,signalent}.h:
471         Use versions built by {ioctlent,errnoent,signaltent}.sh.
472         * sunos4/ioctlent.sh: Work around sprintf troubles with SunOS
473         4.1.4 and gcc 2.7.2.
474
475 Sun May 19 17:14:09 1996  J. Richard Sladkey  <jrs@world.std.com>
476
477         * configure.in, Makefile.in: Add OSARCH concept to finish
478         build support for the alpha.
479         * Makefile.in, linux/Makefile.in: Rewrite clean, distclean,
480         and maintainer-clean rules.
481         * defs.h, ioctlsort.c: Make ioctl code member unsigned.
482         * ioctl.c, ioctlsort.c (compare): Perform explicit checking
483         for less, greater, and equal since subtraction on two's
484         complement numbers isn't an order relation (it isn't transitive)!
485         * linux/Makefile.in: Add rules for the signalent.h file.
486         * linux/alpha/Makefile.in: New file.
487
488 Sun May 19 01:12:28 1996  J. Richard Sladkey  <jrs@world.std.com>
489
490         * version.c: Version 3.0.12 is released.
491
492         * linux{,alpha}/ioctlent.sh: Tweak for recent kernels.
493         From Michael E Chastain <mec@duracef.shout.net>.
494
495         * defs.h (SUPPORTED_PERSONALITES, DEFAULT_PERSONALITY): New.
496         * syscall.c (set_personality): New.
497         * strace.c (main): Call set_personality.
498         * defs.h, syscall.c, ioctl.c, signal.c: Make sysent, errnoent,
499         ioctlent, and signalent indirect pointers and redirect them
500         based on personality.
501         * {sunos4,svr4,linux{,/alpha}}/signalent.h: New files.
502         Suggested by Tom Dyas <tdyas@eden.rutgers.edu>.
503
504         * util.c (upeek): Handle case where ptrace returns a long
505         and sizeof(long) != sizeof(int).
506         From Richard Henderson <richard@twiddle.tamu.edu>
507
508 Fri May 17 21:03:36 1996  J. Richard Sladkey  <jrs@world.std.com>
509
510         * version.c: Version 3.0.11 is released.
511
512         * many files: Fix more printf warnings for other platforms.
513
514         * ipc.c (sys_msgrcv) [LINUX]: Conditionalize definition of ipc_wrapper.
515
516         * linux/dummy.h: Handle missing library support for {send,recv}msg.
517         Reported by Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
518
519         * linux/syscall.h (sys_utimes): Fix a typo in the declaration.
520         From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
521
522 Fri May 17 00:50:06 1996  J. Richard Sladkey  <jrs@world.std.com>
523
524         * version.c: Version 3.0.10 is released.
525
526         * Makfile.in: Add os/arch to includes so that a given arch
527         (like alpha) can override the native arch (like i386).
528         * configure.in: Check for sendmsg.
529
530         * net.c: Make sendmsg and recvmsg dependent on an autoconf
531         test.  Reported by Michael E Chastain <mec@duracef.shout.net>.
532
533         * acconfig.h, configure.in: Detect the alpha.
534         * ioctl.c: Handle the alpha.
535         * defs.h: Make some members long for the alpha.  Define
536         some register nicknames.  Add support for WAITEXECVE.
537         * file.c [ALPHA]: Support the alpha for statfs.  Add
538         osf_statfs and osf_fstatfs for the alpha.  Make damn sure
539         major and minor results are suitable for passing to printf.
540         * signal.c, syscall.c: Support the alpha.
541         * process.c: Add alpha user offsets.
542         * most files: Use %l? for printf arguments since
543         most are now longs for the alpha.
544         * linux/alpha/{errnoent.h,ioctlent.{h,sh},syscallent.h}:
545         New for the alpha.
546         From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
547
548 Wed May 15 00:29:37 1996  J. Richard Sladkey  <jrs@world.std.com>
549
550         * version.c: Version 3.0.9 is released.
551
552         * config.in, config.sub, install-sh: Upgrade to autoconf 2.10.
553
554         * linux/dummy.h, linux/syscallent.h, linux/syscall.h: Add recent
555         Linux kernel version system calls.
556
557 Wed Mar 13 01:03:38 1996  J. Richard Sladkey  <jrs@world.std.com>
558
559         * ipc.c [SUNOS4]: Add SunOS support for decoding IPC calls.
560         * syscall.c [SUNOS4]: Compile decode_subcall on SunOS and
561         decode IPC calls using it.
562         * sunos4/dummy.h: Alias sys_semop to printargs.
563         * sunos4/syscall.h: Add new pseudo syscalls for IPC.
564         * sunos4/syscallent.h: Include new subcalls for IPC.
565         From Matthias Pfaller <leo@dachau.marco.de>.
566
567 Tue Feb 13 22:08:25 1996  J. Richard Sladkey  <jrs@world.std.com>
568
569         * version.c: Version 3.0.8 is released.
570
571         * time.c [LINUX]: Explicitly include linux/version.h.
572
573         * strace.c (main): Don't let them even *try* to
574         get strace to attach to itself since some systems
575         don't handle this case very gracefully.
576         Reported by David S. Miller <davem@caip.rutgers.edu>.
577
578         * Makefile.in (distclean): Fix it for subdirectories.
579
580         * sunos4/syscallent.h, svr4/syscallent.h: Fill in the new
581         sys_flags member for each defined system call.
582
583 Fri Dec  8 01:17:28 1995  Rick Sladkey  <jrs@world.std.com>
584
585         * defs.h (TRACE_*): New flags to describe what class
586         of system call each system call is.
587         (sysent): Add sys_flags member.
588         * syscall.c (sysent): Define (and later undef) abbreviations
589         for the system call class flags.
590         (lookup_class): New function to translate strings to
591         system call class flags.
592         (qualify): Handle new system call class mechanism.
593         * linux/syscallent.h: Fill in the new sys_flags member
594         for each defined system call.
595
596         * defs.h (print_sock): Remove redundant and non-K&R C
597         compatible prototype.  From Juergen Weigert
598         <jnweiger@immd4.informatik.uni-erlangen.de>.
599
600 Thu Dec  7 01:17:40 1995  Rick Sladkey  <jrs@world.std.com>
601
602         * linux/ioctlent.sh: Tweak to improve ioctl accuracy.
603         From Michael E Chastain <mec@duracef.shout.net>.
604
605         * system.c (includes) [LINUX]: Add linux/nfs.h for recent
606         kernels.  From Michael E Chastain <mec@duracef.shout.net>.
607
608 Wed Dec  6 21:52:28 1995  Rick Sladkey  <jrs@world.std.com>
609
610         * file.c (sprintfstype): Enclose string result in double
611         quotes.
612
613         * time.c (sys_adjtimex) [LINUX]: Conditionalize
614         constantly evolving timex structure.
615         From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
616
617         * defs.h, syscall.c, strace.c: Rename syscall to
618         trace_syscall and change prototype and all callers
619         because of broken Linux shared libraries.
620         From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
621
622         * Makefile.in (clean): Check for a file with test -f not
623         test -d.  From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
624
625 Tue Sep 26 02:32:31 1995  Rick Sladkey  <jrs@world.std.com>
626
627         * version.c: Version 3.0.7 is released.
628
629         * util.c (string_quote): Fix thinko which caused core
630         dumps for strings with quotes in them.
631         Reported by Marty Leisner <leisner@sdsp.mc.xerox.com>.
632
633         * linux/Makefile.in (errnoent.h rule): Grab all errno.h
634         files from /usr/include, not just the linux one.
635         From Michael E Chastain <mec@duracef.shout.net>.
636
637         * linux/errnoent.sh: Total rewrite to handle more ioctls with
638         fewer false positives on more kernel flavors.
639         From Michael E Chastain <mec@duracef.shout.net>.
640
641 Mon Sep  4 01:29:22 1995  Rick Sladkey  <jrs@world.std.com>
642
643         * version.c: Version 3.0.6 is released.
644
645         * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
646         sys_msync.
647         * mem.c (mctl_funcs, mctl_lockas, sys_mctl): Conditionalize
648         on MC_SYNC instead of HAVE_MCTL.
649         (mctl_sync): Conditionalize on MS_ASYNC instead of HAVE_MCTL.
650         (sys_msync): New function.
651
652 Sat Sep  2 12:06:04 1995  Rick Sladkey  <jrs@world.std.com>
653
654         * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
655         sys_flock and sys_getdents.
656         * desc.c (flockcmds, sys_flock): Conditionalize on LOCK_SH
657         not SUNOS4.
658         * file.c (sys_getdents): Define unconditionally and handle
659         LINUX case.
660         * strace.c (main): Disallow username option unless both real
661         and effective uids are root.
662
663 Wed Aug 30 01:29:58 1995  Rick Sladkey  <jrs@world.std.com>
664
665         * strace.c (main): Ensure that run_uid and run_gid are
666         always set to something meaningful.
667         (main, newoutf) [!SVR4]: Swap real and effective uids while
668         opening any output files.
669         (main) [!SVR4]: Treat effective uid of root as a request
670         to handle suid binaries correctly using the real uid of
671         the invoking user.
672
673 Sat Aug 19 00:06:08 1995  Rick Sladkey  <jrs@world.std.com>
674
675         * Makefile.in: Add `|| true' to clean rule because
676         although GNU make 3.74 uses `sh -c' to invoke commands
677         every other make in the world uses `sh -ec'.
678
679         * syscall.c (syscall) [SVR4, MIPS]: The fifth and subsequent
680         arguments appear to be stored on the stack, not in the
681         registers following A3 (empirical result).
682
683         * defs.h: Add prototype for printsock.
684         * svr4/dummy.h: Remove generic handling of sys_mount.
685         * system.c [SVR4, MIPS]: Include several system headers to cleanly
686         get access to SGI mount information.
687         (mount_flags, nfs_flags) [SVR4, MIPS]: New objects.
688         (sys_mount) [SVR4, MIPS]: New function.
689         (sys_mount) [SVR4, !MIPS]: New function.
690
691 Tue Jul  4 00:30:34 1995  Rick Sladkey  <jrs@world.std.com>
692
693         * version.c: Version 3.0.5 is released.
694
695         * desc.c, resource.c, strace.c, syscall.c, time.c: Cast tv_sec and
696         tv_usec members to long when using printf.
697
698         * ipc.c: Omit define of __KERNEL__.
699         ({MSG,SEM,SHM}_{STAT,INFO}): Explicitly define those things we
700         want which __KERNEL__ used to provide.
701         (sys_msgrcv): Change reference to ipc_kludge structure to
702         look-alike ipc_wrapper to avoid dependence on __KERNEL__.
703
704         mem.c (mmap_flags) [MAP_{GROWSDOWN,DENYWRITE,EXECUTABLE}]: Add
705         Linux specific options.
706
707         syscall.c: Use SYS_ERRLIST_DECLARED instead of guessing.
708         [E{RESTART{SYS,NO{INTR,HAND}},NOIOCTLCMD}]: Explicitly define
709         instead of depending of __KERNEL__.
710
711         term.c: Cast c_{i,o,c,l}flag to long when using printf.
712
713 Tue Jun  6 00:27:48 1995  Rick Sladkey  <jrs@world.std.com>
714
715         * aclocal.m4 (AC_DECL_SYS_ERRLIST, AC_DECL__SYS_SIGLIST): New.
716         * configure.in: Call AC_DECL_SYS_ERRLIST, AC_DECL_SYS_SIGLIST,
717         and AC_DECL__SYS_SIGLIST.
718         * acconfig.h (SYS_ERRLIST_DECLARED): New.
719         * strace.c (strerror): Use SYS_ERRLIST_DECLARED.
720         (strsignal): Use SYS_SIGLIST_DECLARED.
721
722         net.c (sys_socket): Omit inadvertent surplus comma when
723         protocol family isn't PF_INET.
724
725         util.c (dumpstr): Fix incorrect printing of one too many
726         characters when the length is not an even multiple of 16 bytes.
727         Reported by Juergen Weigert
728         <jnweiger@immd4.informatik.uni-erlangen.de>.
729
730 Thu May  4 23:37:47 1995  Rick Sladkey  <jrs@world.std.com>
731
732         * ioctl.c (compare): Change prototype to match POSIX qsort.
733         * signal.c (sigishandled) [SVR4]: Omit everything after return.
734         * strace.c (trace) [SVR4]: Break out of for loop instead of
735         returning when finished so final return statement is executed.
736         * syscall.c (internal_syscall): Add more SYS_wait* variations.
737         (syscall) [LINUX]: Correct typo which commented out the M68K
738         argument to ifdef.
739         * util.c (printstr): Cast unsigned char pointer argument
740         to char pointer in umovestr call.
741         (dumpstr): Likewise for umoven.
742
743 Wed May  3 01:10:56 1995  Rick Sladkey  <jrs@world.std.com>
744
745         * version.c: Version 3.0.4 is released.
746
747         * signal.c (sys_sigblock): Move after the definition of
748         sys_sigsetmask that it calls to avoid an implicit declaration.
749         * stream.c (transport_user_options, transport_server_options):
750         Only needed if TI_BIND is defined.
751         * configure.in: Add -Wno-implicit to WARNFLAGS on SunOS 4.x.
752
753         * process.c (internal_fork) [SVR4]: Fix a typo that omitted
754         the tcp arguement from the call to exiting.  Add getrval2
755         check so no fork processing is done in the child.
756         (printwaitn): Initialize exited so that its value is defined
757         for all flows of execution.
758
759 Tue May  2 22:39:42 1995  Rick Sladkey  <jrs@world.std.com>
760
761         * linux/dummy.h: Add aliases for sysfs, personality, afs_syscall,
762         setfsuid, setfsgid, and _llseek syscalls.
763         * linux/syscall.h: Add prototypes for them.
764         * linux/syscallent.h: Add them to the syscall entries table.
765         * system.c (headers) [LINUX]: Include linux/unistd.h to get __NR_*
766         defines and conditionally include linux/personality.h if
767         __NR_personality is defined.
768         (personality_options) [LINUX]: New table.
769         (sys_personality) [LINUX]: New function.
770
771 Tue May  2 00:20:39 1995  Rick Sladkey  <jrs@world.std.com>
772
773         * strace.c (trace) [!SVR4]: Change forever loop to one predicated
774         on the number of traced processes so that we can have untraced
775         children (e.g. via popen).
776
777         * strace (main) [!SVR4]: Call fake_execve to get the actual
778         exec and its arguments into the trace.
779         (environ): Declare it.
780         * process.c (fake_execve): New function.
781         (headers): Include sys/syscall.h to get SYS_* defines.
782
783         * process.c (sys_execv, sys_execve): Surround argument annotations
784         with C comment delimiters.
785         (printargv, printargc): The arg vector is an array of char pointers
786         not ints.
787
788         * strace.c (printleader): Also check for multiple -p arguments
789         when deciding whether to print the pid field.
790
791         * strace.c (strerror) [!HAVE_STRERROR]: New function.
792         * defs.h (strerror, strsignal): Add these prototypes if we provide
793         the functions.
794         * configure.in (AC_CHECK_FUNCS): Add strerror.
795
796         * strace.c (main, proc_poller): Add SIGPIPE to the list of caught
797         and blocked signals.
798
799         * strace.c (main): Add username option.  Verify they are root before
800         letting them use it.  Look up the ids in the password file.  Set
801         them just before executing the program.
802         From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
803
804 Sat Apr 29 00:09:56 1995  Rick Sladkey  <jrs@world.std.com>
805
806         * version.c: Version 3.0.3 is released.
807
808         * system.c (mount_flags) [LINUX]: Omit duplicated MS_NOSUID entry.
809         From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
810
811         * strace.c (outfname): Initialize to NULL.
812         (main): Defer output file processing until after arguments.
813         Allow either a pipe or a bang for command arguments.
814         Check if outfname is NULL instead of checking outf for stderr.
815         Reinitialize each startup TCB's outf to fix -p/-o ordering bug.
816         (droptcb): Reset close TCB's outf to NULL instead of stderr.
817         (tprintf): Avoid calling vfprintf if outf is NULL.
818
819         * strace.c (main): Use popen if -o argument begins with a pipe.
820         From Marty Leisner <leisner@sdsp.mc.xerox.com>.
821
822         * process.c (printstatus): Fix a typo where WIFSIGNALED was meant
823         but WIFSTOPPED was used.
824
825         * Makefile.in: Add an EXTRA_DEFS variable and use it in the .c.o
826         rule to prevent the comment from being untrue.
827
828 Fri Apr 28 22:01:56 1995  Rick Sladkey  <jrs@world.std.com>
829
830         * strace.c (sys_exit): Move follow fork code to internal_exit.
831         (sys_fork): Move follow fork code to internal_fork.
832         (sys_execv, sys_execve): Move follow fork code to internal_exec.
833         (sys_waitpid, sys_wait4): Move follow fork code to internal_wait.
834         (vforking): Remove this static variable and check scno in
835         internal_fork instead.
836         (internal_exit, internal_fork, internal_exec, internal_wait): New
837         functions.
838         * defs.h: Add prototypes for the new internal_* functions.
839         * syscall.c (syscall): Move syscall entering trace qualifier check
840         and reprint checking after context decoding and precede them with
841         a call to internal_syscall.  Precede syscall exiting trace
842         qualifier check with a call to internal_syscall.
843         (internal_syscall): New function.
844
845         * defs.h (struct tcb): Make scno signed.
846         * strace.c (syscall) Make u_error signed.
847         [LINUX, I386]: Avoid unsigned cast in eax check.
848         * syscall.c (sys_indir): Make i, scno, and nargs signed.
849         * desc.c (sys_select): Make cumlen unsigned
850
851 Mon Apr 24 23:52:47 1995  Rick Sladkey  <jrs@world.std.com>
852
853         * net.c (socktypes): Add SOCK_PACKET.
854
855 Sun Apr  2 23:50:39 1995  Rick Sladkey  <jrs@world.std.com>
856
857         * Makefile (clean): Check explicitly for a Makefile in subdirs
858         before running make in them.
859
860 Sun Mar 26 12:37:21 1995  Rick Sladkey  <jrs@world.std.com>
861
862         * strace.c [MIPS] (proc_open): Conditionalize run on MIPS.
863         [MIPS] (detach): Initialize error for MIPS case.
864         (trace): Initialize ioctl_result and ioctl_errno for overly helpful
865         compilers.
866         * syscall.c (decode_subcall): Move variable i into conditionals
867         that use use it.
868         * system.c (syssgi_options): Conditionalize SGI_RECVLMSG and
869         SGI_SET_FPDEBUG that SGI decided to drop.  I don't have the stomach
870         to change them all.
871         * term.c (term_ioctl): Force [c_[iocl]flags members to long before
872         printing since we don't know what the size of their type is.
873         * util.c [SVR4, MIPS] (umoven): Prevent MIPS from using pread even
874         if autoconf detects it since it seems to either not work or do
875         something else entirely on Irix 5.3.
876
877 Sun Mar 26 00:01:11 1995  Rick Sladkey  <jrs@world.std.com>
878
879         * version.c: Version 3.0.2 is released.
880         * linux/dummy.h: Make sys_fchdir like sys_close instead of printargs
881         so that the file descriptor arg is decimal.
882
883 Sat Mar 25 22:50:13 1995  Rick Sladkey  <jrs@world.std.com>
884
885         * net.c [LINUX] (protocols): Explicitly define all IPPROTO_* entries
886         because on Linux they are enumerators.
887
888         * system.c [LINUX] (mount_flags): Handle renaming of MS_SYNC to
889         MS_SYNCHRONOUS.
890
891         * util.c (printxval): When there is no translation, print the actual
892         number first and the the default value as a C comment.
893
894         * net.c (sys_send, sys_sendto, sys_sendmsg, sys_getsockopt,
895         sys_setsockopt): Change first argument from unsigned to signed to
896         cater to the frequent practice of calling system calls with a file
897         descriptor of -1.
898         * mem.c (sys_mmap): Likewise.
899
900 Sun Mar 19 13:53:52 1995  Rick Sladkey  <jrs@world.std.com>
901
902         * signal.c [LINUX] (signalent): Handle old and new values of SIGIO.
903
904 Sun Dec 11 22:51:51 1994  Rick Sladkey  <jrs@world.std.com>
905
906         * version.c: Version 3.0.1 is released.
907         * Makefile.in, configure.in, aclocal.m4: Changes for autoconf 2.0.
908         * config.guess, config.guess: Update from the FSF.
909         * install-sh: New from the FSF.
910
911 Mon Dec  5 20:51:29 1994  Rick Sladkey  <jrs@world.std.com>
912
913         * Makefile.in: Add m68k arch.
914         * acconfig.h (M68K): Add m68k define.
915         * configure.in: Add detection of arch m68k.
916         * process.c [M68K] (struct_user_offsets): Support m68k registers and
917         offsets.
918         * signal.c [M68K] (sigcontext_struct): Support m68k sigcontext
919         structure.
920         [M68K] (sys_sigreturn): Support m68k sigreturn handling.
921         * syscall.c [M68K] (syscall): Support m68k syscall number register
922         and errno in d0 instead of eax.
923         * util.c [M68K] (getpc, printcall, setbpt, clearbpt): Support m68k
924         program counter in PT_PC instead of EIP.
925         [M68K] (LOOP): Support m68k loop instruction.
926         From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
927
928         * mem.c [MAP_ANONYMOUS] (mmap_flags): Correct inadvertent reference
929         to MAP_FIXED instead of MAP_ANONYMOUS.
930         From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
931
932         * signal.c [LINUX] (signalent): Signal 30 is now SIGPWR.
933         From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
934
935 Mon Dec  5 01:05:46 1994  Rick Sladkey  <jrs@world.std.com>
936
937         * defs.h (tprintf): Fix typo in non-gcc ansi prototype for tprintf.
938         Reported by Thanh Ma <tma@encore.com>.
939
940         * strace.c (cleanup): Send SIGCONT before SIGTERM because Linux
941         1.1.62 doesn't continue a traced child when the parent exits.
942         Reported by Matt Day <mday@artisoft.com>.
943
944         * system.c [LINUX]: Include netinet/in.h before arpa/inet.h.
945
946         * util.c (printstr): Fix longstanding bug in notating string
947         continuation.
948
949         * strace.c [SVR4] (proc_open): Specifically wait for the child the
950         child to go into the execve syscall to avoid spurious traces.
951         [LINUX] (detach): Conditionalize the status variable.
952
953 Sun Dec  4 23:21:42 1994  Rick Sladkey  <jrs@world.std.com>
954
955         * Makefile.in: Add mips arch.
956         * acconfig.h (MIPS): Add mips define.
957         * configure.in: Add detection of opsys irix5 and arch mips.  Check
958         for prctl function.
959         Check for sys/sysconfig.h header.
960         * defs.h (MAX_ARGS): Bump maximum syscall arguments from 8 to 32.
961         * file.c [SVR4]: Include sys/cred.h.
962         (access_flags): Update access flags for SGI.
963         (sprinttime): Change type of sprinttime argument from unsigned
964         long to time_t.
965         * process.c [HAVE_PRCTL]: Include sys/prctl.h.
966         [HAVE_PRCTL] (prctl_options, sys_prctl): New for SGI.
967         (printsiginfo): Conditionally compile SI_TIMER and SI_MESGQ.
968         Cast si_band member to long before printing.
969         * signal.c (sigact_flags): Add _SA_BSDCALL for SGI.
970         (sigprocmaskcmds): Add SIG_SETMASK32 for SGI.
971         * strace.c [SVR4] [MIPS]:
972         (foobar): New dummy signal handler.
973         (main): Install a dummy signal handler in the child before pausing
974         to work around an SGI bug in PRSABORT.
975         (proc_open): Send a interrupt to the child instead of aborting the
976         syscall which doesn't work on Irix5.2.
977         * svr4/dummy.h: Add new unfinished SGI syscalls
978         (e.g. sys_sysmp, sys_sginap, etc.).  Handle some SGI syscalls like
979         existing calls (e.g. sys_ksigaction like sys_sigaction).
980         Printargs does the print thing for sys_sethostid.
981         * svr4/syscall.h: Declare all new SGI syscalls.
982         (SGI_KLUDGE): Define syscall table starting index to be 1 for SGI
983         and add it to all subcall entry points.
984         (SYS_pgrpsys_subcall, SYS_sigcall_subcall, SYS_context): Don't
985         decode as subcalls on MIPS. Instead, use the normal syscalls.
986         * svr4/syscallent.h [MIPS]: Lead syscall table with a dummy entry
987         since SGI syscall numbers are off by one.
988         [MIPS] (sys_pgrpsys): Rename to sys_setpgrp on SGI.
989         [MIPS] (sys_xenix): Rename to sys_syssgi on SGI.
990         [MIPS] (sys_sysmachine): Rename to sys_sysmips on SGI.
991         [MIPS]: Conditionalize SVR4 extension into SGI and Solaris classes.
992         * syscall.c (dumpio): Validate descriptor against MAX_QUALS.
993         [HAVE_PR_SYSCALL] (syscall): Conditionalize SYS_vfork.
994         [MIPS] (syscall): Add SGI section for decoding u_error and u_rval.
995         Add workaround for broken SGI pr_sysarg on syscall entry.
996         [SVR4] (syscall): Conditionalize subcall decoding for
997         SYS_ptrpsys_subcall, SYS_sigcall_subcall and SYS_context_subcall.
998         [SVR4] [MIPS] (getrval2): Handle SGI.
999         * syscallent.sh: Dork the sed line to be choosier about SYS_ lines.
1000         * system.c [HAVE_SYSCONFIG_H]: Include sys/sysconfig.h.
1001         [MIPS] (syssgi_options, sys_syssgi): New for SGI.