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