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