blob: cf9ee1a5612bcfd91037a23afe940a70cd2ca7fe [file] [log] [blame]
Dmitry V. Levincbd470f2006-10-14 14:23:57 +000012006-10-14 Dmitry V. Levin <ldv@altlinux.org>
2
3 * strace.c (main): Check getcwd() return code.
4
Dmitry V. Levin95ebf5a2006-10-13 20:25:12 +000052006-10-13 Ulrich Drepper <drepper@redhat.com>
6 Bernhard Kaindl <bk@suse.de>
7 Dmitry V. Levin <ldv@altlinux.org>
8 Michael Holzheu <holzheu@de.ibm.com>
9
10 Add hooks for new syscalls. Add decoders for *at, inotify*,
11 pselect6, ppoll and unshare syscalls.
12
13 * defs.h: Declare print_sigset.
14 * desc.c (sys_pselect6): New function.
15 * file.c (decode_open, decode_access, decode_mkdir,
16 decode_readlink, decode_chmod, decode_utimes, decode_mknod):
17 New functions.
18 (sys_open, sys_access, sys_mkdir, sys_readlink, sys_chmod,
19 sys_utimes, sys_mknod): Use them.
20 [LINUX] (fstatatflags, unlinkatflags, inotify_modes): New
21 variables.
22 [LINUX] (print_dirfd, sys_openat, sys_faccessat,
23 sys_newfstatat, sys_mkdirat, sys_linkat, sys_unlinkat,
24 sys_symlinkat, sys_readlinkat, sys_renameat, sys_fchownat,
25 sys_fchmodat, sys_futimesat, sys_mknodat, sys_inotify_add_watch,
26 sys_inotify_rm_watch): New functions.
27 * process.c [LINUX] (sys_unshare): New function.
28 * signal.c (print_sigset): New function.
29 (sys_sigprocmask): Use it.
30 * stream.c (decode_poll): New function.
31 (sys_poll): Use it.
32 [LINUX] (sys_ppoll): New function.
33 * linux/syscall.h: Delcare new syscall handlers.
34 * linux/syscallent.h: Hook up new syscalls.
35 * linux/alpha/syscallent.h: Likewise.
36 * linux/hppa/syscallent.h: Likewise.
37 * linux/ia64/syscallent.h: Likewise.
38 * linux/mips/syscallent.h: Likewise.
39 * linux/powerpc/syscallent.h: Likewise.
40 * linux/s390/syscallent.h: Likewise.
41 * linux/s390x/syscallent.h: Likewise.
42 * linux/sparc/syscallent.h: Likewise.
43 * linux/sparc64/syscallent.h: Likewise.
44 * linux/x86_64/syscallent.h: Likewise.
45 Fixes RH#178633.
46
Dmitry V. Levin96339422006-10-11 23:11:43 +0000472006-10-06 Dmitry V. Levin <ldv@altlinux.org>
48
49 * strace.c [!USE_PROCFS] (trace): Presence of PT_GETSIGINFO
50 macro does not mean that PT_CR_IPSR and PT_CR_IIP macros are
51 also defined, so check them along with PT_GETSIGINFO.
52 Fixes RH#209856.
53
Dmitry V. Levin504eb0b2006-10-11 22:58:31 +0000542006-09-01 Dmitry V. Levin <ldv@altlinux.org>
55
56 * file.c (print_xattr_val): Fix memory corruption bug reported
57 by James Antill.
58 Fixes RH#200621.
59
Dmitry V. Levinaca9a742006-10-11 22:56:49 +0000602006-04-21 Dmitry V. Levin <ldv@altlinux.org>
61
62 * defs.h [LINUX && X86_64 && !__NR_exit_group]: Define
63 __NR_exit_group.
64
Dmitry V. Levin76860f62006-10-11 22:55:25 +0000652006-03-29 Dmitry V. Levin <ldv@altlinux.org>
66
67 Fix race conditions in tcb allocation.
68 * process.c (fork_tcb): Return error code as documented. Do not
69 print "tcb table full" error message.
70 [USE_PROCFS] (internal_fork): Do not print "tcb table full"
71 error message.
72 [SYS_clone || SYS_clone2] (internal_clone, internal_fork): Call
73 fork_tcb() before alloctcb(). Do not print "tcb table full"
74 error message.
75 * strace.c (main): Do not print "tcb table full" error message.
76 (expand_tcbtab): Print error message in case of memory allocation
77 failure.
78 (alloctcb): Print error message when tcb table is full.
79 (trace): Expand tcb table if necessary prior to allocating
80 entry there. Do not print "tcb table full" error message.
81 Fixes RH#180293.
82
Roland McGrathff87ae22006-08-22 07:37:00 +0000832006-08-22 Roland McGrath <roland@redhat.com>
84
85 * ipc.c (sys_msgget, sys_semget, sys_shmget): Show key values in hex.
86 Fixes RH#198179.
87
Roland McGrath6ef291b2006-08-22 06:06:24 +0000882006-08-21 Roland McGrath <roland@redhat.com>
89
90 * linux/syscall.h (SYS_socket_subcall): Bump to 400.
91 * linux/syscallent.h: Update table.
92 * linux/arm/syscallent.h: Likewise.
93 * linux/m68k/syscallent.h: Likewise.
94 * linux/s390/syscallent.h: Likewise.
95 * linux/s390x/syscallent.h: Likewise.
Roland McGrath71030012006-08-22 06:33:45 +000096 * linux/powerpc/syscallent.h: Likewise.
97 * linux/sh/syscallent.h: Likewise.
98 * linux/sh64/syscallent.h: Likewise.
Roland McGrathfd52f8d2006-10-10 00:57:30 +000099 Fixes RH#201462.
Roland McGrath6ef291b2006-08-22 06:06:24 +0000100
Roland McGrath23777062006-04-25 07:22:04 +00001012006-04-25 Roland McGrath <roland@redhat.com>
102
Roland McGrathde170102006-04-25 07:48:06 +0000103 * strace.c (main): Fail when -c is given with -ff.
104 * strace.1: Note their incompatibility.
105 Fixes RH#187847.
106
Roland McGrath5b97ae32006-04-25 07:39:48 +0000107 * strace.c (main): Fail when nonoption args follow -p switches.
108 Fixes Debian#361302.
109
Roland McGrath9d19e162006-04-25 07:33:26 +0000110 * Makefile.am (EXTRA_DIST): Add xlate.el.
111
112 * linux/mips/Makefile.in: File removed, unused cruft.
113 * linux/sparc/Makefile.in: Likewise.
114
Roland McGrath23777062006-04-25 07:22:04 +0000115 * strace.spec (Source0): Use http://dl.sourceforge.net URL.
116
117 * ipc.c (sys_semtimedop): Fixed inverted indirect_ipccall test.
118 * linux/hppa/syscallent.h: Fixed semtimedop entry.
119 From Mike Stroyan <mike.stroyan@hp.com>.
120 Fixes Debian#340239.
121
Roland McGrath9216ba72006-04-25 07:34:44 +00001222006-03-30 Daniel Jacobowitz <dan@codesourcery.com>
123
Roland McGrath5b97ae32006-04-25 07:39:48 +0000124 * linux/arm/syscallent.h: Correct the name of exit. Remove
125 M68K conditionals and sys_security. Correct syscalls 243-282.
126 Fixes Debian#360154.
127
Roland McGrath9216ba72006-04-25 07:34:44 +0000128 * process.c (change_syscall): Add ARM support.
129 * syscall.c (get_scno): Handle ARM EABI.
130 Fixes Debian#360152.
131
Roland McGrath074a8e12006-01-17 06:23:01 +00001322006-01-16 Roland McGrath <roland@redhat.com>
133
134 * configure.ac, NEWS: Version 4.5.14.
135 * debian/changelog, strace.spec: 4.5.14-1.
136
Roland McGrathef6b8bf2006-01-14 00:20:26 +00001372006-01-13 Roland McGrath <roland@redhat.com>
138
139 * debian/control (Build-Depends): Add debhelper.
140
Roland McGrath97a932b2006-01-12 10:19:01 +00001412006-01-12 Roland McGrath <roland@redhat.com>
142
Roland McGrath402c9d12006-01-12 22:35:02 +0000143 * signal.c [LINUX] (sys_restart_syscall): New function.
144 * linux/syscall.h: Declare sys_restart_syscall.
145 * linux/sparc/syscall.h: Likewise.
146 * linux/syscallent.h: Call 0 is restart_syscall.
147 * linux/arm/syscallent.h: Likewise.
148 * linux/powerpc/syscallent.h: Likewise.
149 * linux/m68k/syscallent.h: Likewise.
150 * linux/hppa/syscallent.h: Likewise.
151 * linux/sh/syscallent.h: Likewise.
152 * linux/sparc/syscallent.h: Likewise.
153 * linux/sparc64/syscallent.h: Likewise.
154 * linux/alpha/syscallent.h: Use sys_restart_syscall.
155 * linux/ia64/syscallent.h: Likewise.
156 * linux/mips/syscallent.h: Likewise.
157 * linux/x86_64/syscallent.h: Likewise.
Roland McGrathef6b8bf2006-01-14 00:20:26 +0000158 Fixes RH#165469.
Roland McGrath402c9d12006-01-12 22:35:02 +0000159
1602005-08-08 Dmitry V. Levin <ldv@altlinux.org>
161
162 * system.c [LINUX] (MS_MGC_VAL): New macro.
163 [LINUX] (mount_flags): Add it.
164 [LINUX] (sys_mount): If neither MS_BIND nor MS_MOVE bits are
165 set in the flags argument, try to fetch data string.
166 Fixes RH#165377.
167
1682006-01-12 Roland McGrath <roland@redhat.com>
169
Roland McGrath9ee476f2006-01-12 11:03:48 +0000170 * system.c (sys_sysctl): Don't read off end of NAME when max_strlen
171 exceeds INFO.nlen.
172 From Timo Lindfors <timo.lindfors@iki.fi>.
173 Fixes Debian#339117.
174
175 * debian/rules (binary-arch): Don't pass -s to install. Use dh_strip.
176 Fixes Debian#325132.
177
178 * debian/control (Standards-Version): Update to 3.6.2.
179
Roland McGrath97a932b2006-01-12 10:19:01 +0000180 * defs.h [LINUXSPARC] (PERSONALITY0_WORDSIZE, PERSONALITY1_WORDSIZE):
181 New macros.
182 [SPARC64] (PERSONALITY2_WORDSIZE): New macro.
183 [X86_64] (PERSONALITY0_WORDSIZE, PERSONALITY1_WORDSIZE): New macros.
184 * syscall.c (PERSONALITY0_WORDSIZE): New macro if undefined.
185 (personality_wordsize): New variable.
186 (decode_subcall): Use it for size of argument words.
187 Fixes RH#174354.
188
Roland McGrath49355302006-01-12 09:51:03 +00001892005-11-17 Dmitry V. Levin <ldv@altlinux.org>
190
191 Implement qual_flags support for each personality.
192 * strace.c (main): Move qualify calls after set_personality call.
193 * syscall.c (qual_flags0): New variable..
194 [SUPPORTED_PERSONALITIES >= 2] (qual_flags1): New variable.
195 [SUPPORTED_PERSONALITIES >= 3] (qual_flags2): New variable.
196 (qual_flags): Change variable definition from array to pointer.
197 (set_personality): Initialize qual_flags variable.
198 (qualify_one): Add "pers" argument to specify personality.
199 [SUPPORTED_PERSONALITIES >= 2]: Set qual_flags1 if requested.
200 [SUPPORTED_PERSONALITIES >= 3]: Set qual_flags2 if requested.
201 (qual_syscall): Pass personality to qualify_one.
202 [SUPPORTED_PERSONALITIES >= 2]: Look for syscall also in sysent1
203 table.
204 [SUPPORTED_PERSONALITIES >= 3]: Look for syscall also in sysent2
205 table.
206 (qual_signal): Pass personality to qualify_one.
207 (qual_desc): Likewise.
208 (qualify): Use qualify_one instead of manual qual_flags
209 manipulations.
210 [SUPPORTED_PERSONALITIES >= 2]: Look for syscall also in sysent1
211 table.
212 [SUPPORTED_PERSONALITIES >= 3]: Look for syscall also in sysent2
213 table.
214 * defs.h: Update qual_flags declaration.
215 Fixes RH#173986.
216
Roland McGrath7c061b22006-01-12 09:45:59 +00002172005-11-14 Dmitry V. Levin <ldv@altlinux.org>
218
219 * syscall.c (qual_syscall): Handle numeric syscall specification.
220 Fixes RH#174798.
221
222 * syscall.c (qual_signal, qual_options): Remove redundant argument
223 check.
224
Roland McGrath52f70f72005-12-02 04:34:25 +00002252005-12-01 Roland McGrath <roland@redhat.com>
226
227 * ipc.c (indirect_ipccall) [MIPS || HPPA]: Return false.
228 Fixes Debian#340239.
229
230 * Makefile.am (EXTRA_DIST): Add linux/arm/syscallent.h
231 and linux/m68k/syscallent.h.
232 Fixes Debian#336197.
233
234 * debian/control (Architecture): Add armeb.
235 Fixes Debian#335681.
236
2372005-11-02 Michal Marek <mmarek@suse.cz>
238
239 * strace-graph (handle_trace): follow clone() and vfork() calls.
240
Roland McGrath362f1c32005-12-02 04:23:50 +00002412005-10-25 Heiko Carstens <heiko.carstens@de.ibm.com>
242
243 * linux/s390/syscallent.h: Added ioprio_set, ioprio_get,
244 inotify_init, inotify_add_watch, inotify_rm_watch.
245 Corrected number of arguments for request_key.
246 * linux/s390x/syscallent.h: Likewise.
247
2482005-12-01 Roland McGrath <roland@redhat.com>
249
250 * ipc.c (indirect_ipccall) [IA64]: Return false unless the syscall
251 number is in the low range of IA32 syscalls.
252
2532005-10-07 Andreas Schwab <schwab@suse.de>
254
255 * linux/ia64/syscallent.h: Syscall 1105 is gettid, not ioperm.
256
Roland McGrath89e94ff2005-12-02 03:57:20 +00002572005-12-01 Roland McGrath <roland@redhat.com>
258
Roland McGrath8e5ca842005-12-02 04:08:39 +0000259 * resource.c (resources): Add RLIMIT_NICE, RLIMIT_RTPRIO.
260 Reported by Scott Tsai <scottt958@yahoo.com.tw>.
261
Roland McGrath89e94ff2005-12-02 03:57:20 +0000262 * ipc.c (indirect_ipccall): New function.
263 (sys_msgctl, sys_msgsnd, sys_msgrcv, sys_semop): Use that predicate
264 instead of #ifdef LINUX test.
265 [LINUX] (sys_semtimedop): Likewise.
266 (sys_shmctl, sys_shmat, sys_shmdt): Likewise.
267 Fixes RH#164755.
268
Roland McGrath61b675e2005-12-02 03:44:20 +00002692005-07-31 Ulrich Drepper <drepper@redhat.com>
270
Roland McGrath89e94ff2005-12-02 03:57:20 +0000271 * linux/x86_64/syscallent.h: Fix syscall parameter count for msgrcv and
272 msgctl.
273
Roland McGrath61b675e2005-12-02 03:44:20 +0000274 * ipc.c (sys_msgrcv): Add entering handling and print first parameter
275 there.
276 Fixes RH#164757.
277
Roland McGrathbc38ae72005-12-02 03:59:47 +00002782005-08-08 Dmitry V. Levin <ldv@altlinux.org>
279
280 * strace.1: Update "SEE ALSO" links to reference to valid
281 manpages.
282 Patch from Michail Litvak <mci@owl.openwall.com>.
283 Fixes RH#165375.
284
Roland McGrath68565782005-10-21 22:06:58 +00002852005-10-21 Roland McGrath <roland@redhat.com>
286
287 * util.c (printpathn): Cap N at sizeof path - 1.
288
Roland McGrath0c26d342005-08-03 11:43:03 +00002892005-08-03 Roland McGrath <roland@redhat.com>
290
291 * configure.ac, NEWS: Version 4.5.13.
292 * debian/changelog, strace.spec: 4.5.13-1.
293
Roland McGrath03c3d752005-08-03 12:18:37 +0000294 * configure.ac: Check for struct dqblk.dqb_curblocks field.
Roland McGrath7e946762005-08-03 12:02:14 +0000295 * resource.c [LINUX] (OLD_CMD): New macro.
296 (quotacmds): Use it to hard-wire old O_* values, don't use macros.
Roland McGrath03c3d752005-08-03 12:18:37 +0000297 (sys_quotactl): If dqb_curblocks is not there, it's called
298 dqb_curspace instead. Print dqb_* fields as unsigned long long.
Roland McGrath7e946762005-08-03 12:02:14 +0000299
Roland McGrath9554a482005-08-03 11:29:26 +00003002005-07-19 Michael Schmitz <schmitz@debian.org>
301
302 Long overdue m68k cleanup.
303 * linux/syscallent.h: remove m68k declarations.
304 * linux/m68k/syscallent.h: new file, fixed up declarations
305 to match kernel version 2.6.11. Newer syscalls are sufficiently
306 different from i386 to merit a separate file.
307
3082005-08-03 Roland McGrath <roland@redhat.com>
309
310 * linux/x86_64/syscallent.h: Update init_module argument count.
311 * linux/sparc/syscallent.h: Likewise.
312 * linux/sparc64/syscallent2.h: Likewise.
313 * linux/sparc64/syscallent.h: Likewise.
314 * linux/sh/syscallent.h: Likewise.
315 * linux/sh64/syscallent.h: Likewise.
316 * linux/s390/syscallent.h: Likewise.
317 * linux/s390x/syscallent.h: Likewise.
318 * linux/powerpc/syscallent.h: Likewise.
319 * linux/arm/syscallent.h: Likewise.
320
3212005-07-22 James Lentini <jlentini@gmail.com>
322
323 * bjm.c (sys_init_module): Display all three arguments.
324 * linux/syscallent.h: Update argument count.
325
Roland McGrathe0f6bb02005-08-03 11:23:50 +00003262005-08-03 Roland McGrath <roland@redhat.com>
327
328 * process.c (internal_wait): Don't suspend when known child is known
329 to be exiting already.
330
331 * strace.c (detach): If detaching the last live thread in a group with
332 a zombie leader, then detach the leader too.
333 (handle_group_exit): Use detach, not droptcb, for predeceased thread.
334 Mark process about to take a signal with TCB_GROUP_EXITING flag.
335 Fixes RH#161919.
336
Roland McGrath30afb792005-07-19 07:42:24 +00003372005-07-19 Roland McGrath <roland@redhat.com>
338
339 * defs.h [LINUX] [M68K] (__NR_exit_group): Define it if missing.
340 Fixes Debian#315500.
341
Roland McGrath387d0e52005-07-19 07:13:34 +00003422005-07-14 Heiko Carstens <heiko.carstens@de.ibm.com>
343
344 * linux/s390/syscallent.h (sys_tgkill, vserver, fadvise64_64)
345 (statfs64, fstatfs64, remap_file_pages, mbind, get_mempolicy)
346 (set_mempolicy, mq_open, mq_unlink, mq_timedsend, mq_timedreceive)
347 (mq_notify, mq_getsetattr, sys_kexec_load, add_key, request_key)
348 (keyctl, waitid): Added.
349 * linux/s390x/syscallent.h: Likewise and added missing _llseek.
350 * linux/s390/errnoent.h (ECANCELED, ENOKEY, EKEYEXPIRED)
351 (EKEYREVOKED, EKEYREJECTED, EOWNERDEAD, ENOTRECOVERABLE): Added.
352 * linux/s390x/errnoent.h: Likewise.
353
Roland McGrath415a7d62005-07-05 09:50:40 +00003542005-07-05 Roland McGrath <roland@redhat.com>
355
356 * mem.c [LINUX] (sys_old_mmap) [X86_64]: Extract 32-bit values if
357 child is 32-bit.
358 Fixes RH#162467.
359
Roland McGrathfd583f62005-07-05 03:22:50 +00003602005-06-08 Dmitry V. Levin <ldv@altlinux.org>
361
Roland McGrathe10dc512005-07-05 03:26:03 +0000362 Introduce "-e trace=desc".
363 * defs.h (TRACE_DESC): New flag.
364 * syscall.c: Define TD macro before include of syscallent files
365 and undefine it afterwards.
366 (lookup_class): Recognize "desc" keyword.
367 * strace.1: Document "-e trace=desc".
368 * freebsd/i386/syscallent.h: Mark those syscalls which take a
369 file descriptor as an argument or return a file descriptor with
370 TD flag.
371 * linux/alpha/syscallent.h: Likewise.
372 * linux/hppa/syscallent.h: Likewise.
373 * linux/ia64/syscallent.h: Likewise.
374 * linux/mips/syscallent.h: Likewise.
375 * linux/powerpc/syscallent.h: Likewise.
376 * linux/s390/syscallent.h: Likewise.
377 * linux/s390x/syscallent.h: Likewise.
378 * linux/sh/syscallent.h: Likewise.
379 * linux/sh64/syscallent.h: Likewise.
380 * linux/sparc/syscallent.h: Likewise.
381 * linux/sparc64/syscallent2.h: Likewise.
382 * linux/sparc64/syscallent.h: Likewise.
383 * linux/syscallent.h: Likewise.
384 * linux/x86_64/syscallent.h: Likewise.
385 * sunos4/syscallent.h: Likewise.
386 * svr4/syscallent.h: Likewise.
387 Fixes RH#159400.
388
Roland McGrathfd583f62005-07-05 03:22:50 +0000389 Remove TF flag from those syscalls which have no filename argument.
390 * freebsd/i386/syscallent.h: Remove TF flag from fstat, pread,
391 pwrite, fstat, sendfile.
392 * linux/alpha/syscallent.h: Remove TF flag from read, write,
393 pread, pwrite, sendfile.
394 * linux/hppa/syscallent.h: Remove TF flag from read, write,
395 pread, pwrite, fstat64, sendfile, ftruncate64.
396 * linux/ia64/syscallent.h: Remove TF flag from read, write,
397 sendfile, fstat, fadvise64.
398 * linux/mips/syscallent.h: Remove TF flag from read, write,
399 fstatfs, fstat, pread, pwrite, sendfile, ftruncate64, fstat64,
400 sendfile64, fadvise64, fstatfs64.
401 * linux/powerpc/syscallent.h: Remove TF flag from read, write,
402 fstat, pread, pwrite, sendfile, ftruncate64, fstat64, sendfile64,
403 fadvise64, fstatfs64, fadvise64_64.
404 * linux/s390/syscallent.h: Remove TF flag from pread, pwrite,
405 sendfile, ftruncate64, fstat64, sendfile64.
406 * linux/s390x/syscallent.h: Remove TF flag from pread, pwrite,
407 sendfile, sendfile64.
408 * linux/sh/syscallent.h: Remove TF flag from pread, pwrite,
409 sendfile, fstat64.
410 * linux/sh64/syscallent.h: Remove TF flag from pread, pwrite,
411 sendfile, ftruncate64, fstat64.
412 * linux/sparc/syscallent.h: Remove TF flag from sendfile, fstat64,
413 pread, pwrite, sendfile64.
414 * linux/sparc64/syscallent2.h: Likewise.
415 * linux/sparc64/syscallent.h: Likewise.
416 * linux/syscallent.h: Remove TF flag from pread, pwrite, sendfile,
417 ftruncate64, fstat64, sendfile64, fadvise64, fadvise64, fstatfs64,
418 fadvise64_64.
419 * linux/x86_64/syscallent.h: Remove TF flag from pread, pwrite,
420 sendfile, fadvise64_64.
421 * svr4/syscallent.h: Remove TF flag from pread, pwrite, ftruncate,
422 fstatvfs64, ftruncate64.
423 Fixes RH#159340.
424
Roland McGrath012ffdf2005-07-04 23:30:30 +00004252005-07-04 Roland McGrath <roland@redhat.com>
426
Roland McGrathbfacc262005-07-04 23:33:42 +0000427 * net.c (sockipv6options): Add IPV6_ADD_MEMBERSHIP,
428 IPV6_DROP_MEMBERSHIP, IPV6_ROUTER_ALERT.
429 From Ulrich Drepper <drepper@redhat.com>.
430 Fixes RH#162450.
431
Roland McGrath012ffdf2005-07-04 23:30:30 +0000432 * net.c (sockipoptions): Fix typos.
433 From Ulrich Drepper <drepper@redhat.com>.
434 Fixes RH#161578.
435
436 * util.c (printnum_int): New function, printnum with s/long/int/.
437 * defs.h: Declare it.
438 * net.c (printsockopt): Use it for int-sized option.
439 Fixes RH#162449.
440 Reported by Ulrich Drepper <drepper@redhat.com>.
441
Roland McGrath43cb21f2005-06-10 03:56:19 +00004422005-06-09 Roland McGrath <roland@redhat.com>
443
444 * configure.ac, NEWS: Version 4.5.12.
445 * debian/changelog, strace.spec: 4.5.12-1.
446
Roland McGrath59a611b2005-06-08 20:45:52 +00004472005-06-08 Dmitry V. Levin <ldv@altlinux.org>
448
449 Minor namespace cleanup.
450 * defs.h (string_quote): Remove declaration.
451 * file.c (openmodessol) [LINUXSPARC]: Make static.
452 (fileflags): Likewise.
453 (aclcmds, aclipc) [HAVE_SYS_ACL_H]: Likewise.
454 (direnttypes) [FREEBSD || LINUX]: Likewise.
455 (xattrflags): Likewise.
456 * process.c (unalignctl_string): Make static.
457 (setarg): Disable.
458 * syscall.c (subcalls_table): Make static.
459 (socket_map) [!(LINUX && (ALPHA || MIPS))]: Likewise.
460 (sparc_socket_decode): Make static, define for [SPARC || SPARC64] only.
461 (decode_subcall): Make static.
462 (syscall_fixup): Likewise.
463 (get_error): Likewise.
464 (syscall_enter): Likewise.
465 * util.c (tv_tv): Disable.
466 (getpc): Likewise.
467 (string_quote): Make static.
468 Fixes RH#159688.
469
Roland McGrathd40a3932005-06-08 18:06:27 +00004702005-05-12 Philippe De Muyter <phdm@macqel.be>
471
472 * util.c (getpc, printcall): Check #if defined(M68K), not M68k.
473 Enables `-i' on m68k machines.
474
Roland McGrath5d731702005-06-07 23:22:26 +00004752005-06-06 Roland McGrath <roland@redhat.com>
476
477 * process.c (struct_user_offsets) [X86_64]: Reorder elements so
478 matching works right.
479 Fixes RH#159787.
480
481 * linux/syscall.h (SYS_socket, SYS_bind, SYS_connect, SYS_listen)
482 (SYS_accept, SYS_getsockname, SYS_getpeername, SYS_socketpair)
483 (SYS_send, SYS_recv, SYS_sendto, SYS_recvfrom, SYS_shutdown)
484 (SYS_setsockopt, SYS_getsockopt, SYS_sendmsg, SYS_recvmsg)
485 (SYS_getsockname, SYS_semop, SYS_semgsub_et, SYS_semget, SYS_semctl)
486 (SYS_semtimedop, SYS_msgsnd, SYS_msgrcv, SYS_msgget)
487 (SYS_msgctl, SYS_shmat, SYS_shmdt, SYS_shmget)
488 (SYS_shmctl): Macros renamed to SYS_sub_*.
489 * syscall.c (dumpio): Match SYS_sub_* if defined instead of SYS_*.
490
491 * linux/syscall.h (SYS_waitid): Define if not defined.
492
493 * linux/syscallent.h: Fix pread/pwrite names to pread64/pwrite64.
494
495 * defs.h (struct sysent): New member `native_scno'.
496 (known_scno): Declare new function.
497 * linux/syscallent.h: Add new final field to interesting syscalls.
498 * syscall.c (known_scno): New function.
499 (dumpio, internal_syscall, syscall_fixup, trace_syscall): Use it.
500 * process.c (internal_fork, internal_exit): Likewise.
501 [IA64] (ARG_STACKSIZE, ARG_PTID, ARG_CTID, ARG_TLS): Likewise.
502 * strace.c (proc_open): Likewise.
503 * util.c [LINUX] (setbpt): Likewise.
504 * linux/syscall.h: Remove [!defined(X86_64)] from conditional
505 for defining SYS_socket_subcall et al.
506 * linux/syscallent.h: Likewise for #error check.
507 * syscall.c (trace_syscall): Likewise for SYS_{socketcall,ipc} cases.
508 Fixes RH#158934.
509
Roland McGrath6286f662005-06-03 02:40:43 +00005102005-06-02 Roland McGrath <roland@redhat.com>
511
512 * file.c (printstatfs64): Cast values to unsigned long long and use
513 %llu formats.
514 Fixes RH#158243.
515
Roland McGrathe8c6eec2005-06-01 18:56:03 +00005162005-05-31 Dmitry V. Levin <ldv@altlinux.org>
517
Roland McGrath712a6bf2005-06-01 19:22:30 +0000518 Deal with memory management issues.
519 * defs.h (tprint_iov): Update prototype.
520 * desc.c (sys_epoll_wait) [HAVE_SYS_EPOLL_H]: Do not allocate
521 epoll_event array of arbitrary size on the stack, to avoid
522 stack overflow.
523 * file.c (print_xattr_val): Check for integer overflow during
524 malloc size calculation, to avoid heap corruption.
525 * io.c (tprint_iov) [HAVE_SYS_UIO_H]: Check for integer overflow
526 during malloc size calculation, to avoid heap corruption.
527 Change iovec array handling to avoid heap memory allocation.
528 * mem.c (get_nodes) [LINUX]: Check for integer overflow during
529 size calculation and do not allocate array of arbitrary size on
530 the stack, to avoid stack overflow.
531 * net.c (printcmsghdr) [HAVE_SENDMSG]: Do not allocate array of
532 arbitrary size on the stack, to avoid stack overflow. Do not
533 trust cmsg.cmsg_len to avoid read beyond the end of allocated
534 object.
535 (printmsghdr) [HAVE_SENDMSG]: Update tprint_iov() usage.
536 * process.c (sys_setgroups): Check for integer overflow during
537 malloc size calculation, to avoid heap corruption. Change gid_t
538 array handling to avoid heap memory allocation.
539 (sys_getgroups): Likewise.
540 (sys_setgroups32) [LINUX]: Likewise.
541 (sys_getgroups32) [LINUX]: Likewise.
542 * stream.c (sys_poll) [HAVE_SYS_POLL_H]: Check for integer
543 overflow during malloc size calculation, to avoid heap corruption.
544 Change pollfd array handling to avoid heap memory allocation.
545 * system.c (sys_sysctl) [LINUX]: Check for integer overflow
546 during malloc size calculation, to avoid heap corruption.
547 * util.c (dumpiov) [HAVE_SYS_UIO_H]: Check for integer overflow
548 during malloc size calculation, to avoid heap corruption.
549 Fixes RH#159196.
550
Roland McGrathb422e0d2005-06-01 19:03:30 +0000551 * util.c (printxval): Change third argument from "char *" to
552 "const char *".
553 (printflags): Add third argument, "const char *", with similar
554 meaning to the third argument of printxval().
555 * defs.h (printxval): Change third argument from "char *" to
556 "const char *".
557 (printflags): Add third argument.
558 * bjm.c (sys_query_module) [LINUX]: Pass third argument to
559 printflags().
560 * desc.c (sys_fcntl): Likewise.
561 (sys_flock) [LOCK_SH]: Likewise.
562 (print_epoll_event) [HAVE_SYS_EPOLL_H]: Likewise.
563 * file.c (sys_open): Likewise.
564 (solaris_open) [LINUXSPARC]: Likewise.
565 (sys_access): Likewise.
566 (sys_chflags, sys_fchflags) [FREEBSD]: Likewise.
567 (realprintstat) [HAVE_LONG_LONG_OFF_T &&
568 HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
569 (printstat64) [HAVE_STAT64 &&
570 HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
571 (sys_setxattr, sys_fsetxattr): Likewise.
572 * ipc.c (sys_msgget, sys_msgsnd, sys_msgrcv, sys_semget,
573 sys_shmget, sys_shmat) [LINUX || SUNOS4 || FREEBSD]: Likewise.
574 (sys_mq_open) [LINUX]: Likewise.
575 (printmqattr) [HAVE_MQUEUE_H]: Likewise.
576 * mem.c (print_mmap) [!HAVE_LONG_LONG_OFF_T]: Likewise.
577 (sys_mmap64) [_LFS64_LARGEFILE || HAVE_LONG_LONG_OFF_T]: Likewise.
578 (sys_mprotect): Likewise.
579 (sys_mremap, sys_madvise, sys_mlockall) [LINUX]: Likewise.
580 (sys_msync) [MS_ASYNC]: Likewise.
581 (sys_mctl) [MC_SYNC]: Likewise.
582 (sys_remap_file_pages, sys_mbind, sys_get_mempolicy) [LINUX]:
583 Likewise.
584 * net.c (printmsghdr) [HAVE_STRUCT_MSGHDR_MSG_CONTROL]: Likewise.
585 (sys_send, sys_sendto): Likewise.
586 (sys_sendmsg) [HAVE_SENDMSG]: Likewise.
587 (sys_recv, sys_recvfrom): Likewise.
588 (sys_recvmsg) [HAVE_SENDMSG]: Likewise.
589 (printicmpfilter) [ICMP_FILTER]: Likewise.
590 * proc.c (proc_ioctl) [SVR4 && !HAVE_MP_PROCFS || FREEBSD]: Likewise.
591 * process.c (sys_clone) [LINUX]: Likewise.
592 (printwaitn): Likewise.
593 (sys_waitid) [SVR4 || LINUX]: Likewise.
594 * signal.c (sys_sigvec) [SUNOS4 || FREEBSD]: Likewise.
595 (sys_sigaction): Likewise.
596 (printcontext) [SVR4]: Likewise.
597 (print_stack_t) [LINUX) || FREEBSD]: Likewise.
598 (sys_rt_sigaction) [LINUX]: Likewise.
599 * sock.c (sock_ioctl) [LINUX]: Likewise.
600 * stream.c (sys_putmsg, sys_getmsg): Likewise.
601 (sys_putpmsg) [SYS_putpmsg]: Likewise.
602 (sys_getpmsg) [SYS_getpmsg]: Likewise.
603 (sys_poll): Likewise.
604 (print_transport_message) [TI_BIND]: Likewise.
605 (stream_ioctl): Likewise.
606 * system.c (sys_mount, sys_reboot): Likewise.
607 (sys_cacheflush) [LINUX && M68K]: Likewise.
608 (sys_capget, sys_capset) [SYS_capget]: Likewise.
609 * term.c (term_ioctl) [TIOCMGET]: Likewise.
610 * time.c (sys_clock_nanosleep, sys_timer_settime) [LINUX]:
611 Likewise.
612 Fixes RH#159310.
613
Roland McGrathe8c6eec2005-06-01 18:56:03 +0000614 * bjm.c (sys_query_module) [LINUX]: Unitize "out of memory"
615 errors reporting style.
616 * strace.c (rebuild_pollv) [USE_PROCFS]: Likewise.
617 * system.c (sys_capget, sys_capset) [SYS_capget]: Likewise.
618 * util.c (printstr): Likewise.
619 (dumpiov) [HAVE_SYS_UIO_H]: Likewise.
620 (fixvfork) [SUNOS4]: Likewise.
621 * desc.c (decode_select): Continue to decode syscall arguments
622 in case of OOM condition.
623 * file.c (sys_getdents): Likewise.
624 (sys_getdents64) [_LFS64_LARGEFILE]: Likewise.
625 (sys_getdirentries) [FREEBSD]: Likewise.
626 * mem.c (sys_mincore): Changed type of variables which deal with
627 malloc size from int to unsigned long.
Roland McGrathe35109a2005-06-08 18:03:12 +0000628 Fixes RH#159308.
Roland McGrathe8c6eec2005-06-01 18:56:03 +0000629
Roland McGratha6ef1a32005-06-01 18:57:27 +00006302005-05-22 Dmitry V. Levin <ldv@altlinux.org>
631
632 * bjm.c [LINUX]: Do not include <linux/linkage.h>. It is not
633 safe to include kernel headers, and this one is not used anyway.
634 Fixes RH#158488.
635
Roland McGrathe776e3e2005-05-26 23:21:13 +00006362005-05-26 Roland McGrath <roland@redhat.com>
637
638 * system.c (sys_sysctl): Check for errors accessing user pointers.
639 Use malloc instead of alloca in case size is insane.
640
Roland McGrath682291e2005-05-09 08:03:06 +00006412005-05-09 Roland McGrath <roland@redhat.com>
642
643 * configure.ac: Check for libaio.h.
644 * desc.c (sys_io_setup, sys_io_submit, sys_io_cancel,
645 sys_io_getevents, sys_io_destroy): New functions.
646 * linux/syscall.h: Declare them.
647 * linux/syscallent.h: Use those for io_* syscalls.
648 * linux/alpha/syscallent.h: Likewise.
649 * linux/hppa/syscallent.h: Likewise.
650 * linux/ia64/syscallent.h: Likewise.
651 * linux/mips/syscallent.h: Likewise.
652 * linux/powerpc/syscallent.h: Likewise.
653 * linux/s390/syscallent.h: Likewise.
654 * linux/s390x/syscallent.h: Likewise.
655 * linux/x86_64/syscallent.h: Likewise.
656 From Zach Brown <zach.brown@oracle.com>.
657 Fixes RH#155065.
658
659 * debian/control (Architecture): Add ppc64.
660 Fixes Debian bug #301089.
661
Roland McGrath05a017b2005-05-09 07:46:07 +00006622005-05-05 Anton Blanchard <anton@samba.org>
663
664 * process.c (ptrace_cmds): Add PTRACE_GETVRREGS and PTRACE_SETVRREGS
665 if defined.
666
6672005-05-09 Roland McGrath <roland@redhat.com>
668
669 * strace.c (main): Refuse negative -s argument value.
670 Fixes Debian bug #303256.
671
Roland McGrathf3b565b2005-05-09 07:40:41 +00006722005-04-25 Anton Blanchard <anton@samba.org>
673
674 * file.c (openmodes): Add O_NOATIME flag if defined.
675
6762005-04-05 Anton Blanchard <anton@samba.org>
677
678 * linux/powerpc/ioctlent.h: Regenerated.
679
680 * signal.c (signame): Don't try and dereference negative index.
681
682 * linux/powerpc/syscallent.h: Add debug_setcontext, vserver,
683 mbind, *_mempolicy, mq_*, sys_kexec_load, add_key, request_key,
684 keyctl, waitid, sys_semtimedop. Fix various other syscalls.
685
686 * ipc.c (shm_resource_flags): New variable, table has SHM_HUGETLB
687 but not IPC_NOWAIT, which have the same value.
688 (sys_shmget): Use that instead of resource_flags.
689
Roland McGratha3734a92005-03-22 23:13:24 +00006902005-03-22 Roland McGrath <roland@redhat.com>
691
Roland McGrathe1f1e572005-03-23 03:19:02 +0000692 * desc.c (decode_select): Increase local buffer size.
693 Fixes RH#151570.
694
Roland McGratha3734a92005-03-22 23:13:24 +0000695 * configure.ac, NEWS: Version 4.5.11.
696 * debian/changelog, strace.spec: 4.5.11-1.
697
698 * linux/arm/syscallent.h: Fix 113 entry (syscall, not vm86old).
699
Roland McGrath3181c512005-03-15 02:40:23 +00007002005-03-14 Roland McGrath <roland@redhat.com>
701
702 * configure.ac, NEWS: Version 4.5.10.
703 * debian/changelog, strace.spec: 4.5.10-1.
704
Roland McGrath0495c932005-03-15 02:17:23 +00007052005-02-26 GOTO Masanori <gotom@debian.or.jp>
706
707 * linux/alpha/syscallent.h: Fix the reversed order of lstat64 and
708 fstat64. Clean up osf_nrecvmsg and osf_ngetsockname.
709
Roland McGrath391a4e72005-03-15 02:16:21 +00007102005-02-28 Andreas Schwab <schwab@suse.de>
711
712 * syscall.c (getrval2): Move #ifdef IA64 inside #ifdef LINUX.
713
7142005-03-14 Roland McGrath <roland@redhat.com>
715
716 * linux/mips/syscallent.h: Update various calls.
717 From Thiemo Seufer <ths@networkno.de>.
718 Fixes Debian bug #256684.
719
720 * debian/control (Architecture): Add s390.
721 Fixes Debian bug #294172.
722
Roland McGrathbfb49e52005-03-06 22:24:52 +00007232005-03-06 Roland McGrath <roland@redhat.com>
724
725 * strace.c (trace) [PTRACE_GETSIGINFO]: Fetch siginfo_t for SIGSEGV
726 and SIGBUS signals, use si_addr in output.
727
Roland McGrath4859f6c2005-03-01 23:03:11 +00007282005-03-01 Roland McGrath <roland@redhat.com>
729
730 * file.c (print_xattr_val): Add a cast.
731
Roland McGrath854694b2005-02-06 01:16:47 +00007322005-02-05 Roland McGrath <roland@redhat.com>
733
Roland McGrathb0a3d4e2005-02-06 01:55:16 +0000734 * desc.c (decode_select): Calculate size of passed fd_set vectors and
735 copy in the user's size rather than the standard sizeof(fd_set).
Roland McGrath391a4e72005-03-15 02:16:21 +0000736 Fixes Debian bug #65654, #284290.
Roland McGrathb0a3d4e2005-02-06 01:55:16 +0000737
738 * util.c (printpath, printpathn): Print NULL and don't try any fetch
739 when ADDR is zero.
740 Fixes Debian bug #63093.
741
Roland McGrath854694b2005-02-06 01:16:47 +0000742 * debian/control (Build-Depends): Fix for s390 and sparc.
743 From Bastian Blank <waldi@debian.org>.
744 Fixes Debian bug #293564.
745
7462004-12-19 Dmitry V. Levin <ldv@altlinux.org>
747
748 * strace.c (main) [!USE_PROCFS]: In child process, raise SIGSTOP
749 right before execv() call. Remove fake_execve() call.
750 * defs.h (fake_execve): Remove unused declaration.
751 * process.c (fake_execve): Remove unused function.
752 Fixes RH#143365.
753
Roland McGrath55f23e72005-02-04 09:29:11 +00007542005-02-04 Roland McGrath <roland@redhat.com>
755
756 * configure.ac, NEWS: Version 4.5.9.
Roland McGrath0c6c17b2005-02-04 09:54:16 +0000757 * debian/changelog, strace.spec: 4.5.9-2.
Roland McGrath55f23e72005-02-04 09:29:11 +0000758
Roland McGrath1e834482005-02-04 09:50:24 +0000759 * file.c (O_LARGEFILE): Omit when #undef'd because it was zero.
760
Roland McGrath94098ef2005-02-02 20:25:36 +00007612005-02-02 Roland McGrath <roland@redhat.com>
762
Roland McGrath026bdab2005-02-03 03:19:43 +0000763 * debian/control: Add strace-udeb package for installer debugging.
764 * debian/rules (binary-arch): Build it.
765 From Joshua Kwan <joshk@triplehelix.org>.
766 Fixes Debian bug #268294.
767
Roland McGrathd08b2f02005-02-02 22:11:37 +0000768 * file.c (openmodes) [O_LARGEFILE] [O_LARGEFILE == 0]: Redefine to
769 known values for Linux.
770
Roland McGrath84219e12005-02-02 20:55:27 +0000771 * util.c (printcall): Print 16 ?s when long is 8 bytes.
772 Fixes RH#146932.
773
Roland McGrath3cad4a62005-02-02 20:32:37 +0000774 * linux/sparc/syscall.h: Declare sys_epoll_create, sys_epoll_ctl,
775 sys_epoll_wait.
776 * linux/sparc64/syscall.h: Just #include "../sparc/syscall.h" here.
777 * ioctl.c (nioctlents2): Add const to type.
778 Fixes Debian bug #278449.
779
Roland McGrath94098ef2005-02-02 20:25:36 +0000780 * sock.c (iffflags): New variable, table of IFF_* values.
781 (print_addr): New function.
782 (sock_ioctl): Handle SIOCGIFADDR, SIOCGIFDSTADDR, SIOCGIFBRDADDR,
783 SIOCGIFNETMASK, SIOCGIFFLAGS, SIOCGIFMETRIC, SIOCGIFMTU, SIOCGIFSLAVE,
784 SIOCGIFHWADDR. Use print_addr for SIOCGIFCONF, SIOCGIFNAME, and
785 SIOCGIFINDEX, and fix their output.
786 From Ulrich Drepper <drepper@redhat.com>.
787 Fixes RH#138223.
Roland McGrath1967a132005-02-02 20:45:37 +0000788 Fixes Debian bug #192164.
Roland McGrath94098ef2005-02-02 20:25:36 +0000789
Roland McGrathac6b7bb2005-02-02 04:42:56 +00007902004-12-20 Dmitry V. Levin <ldv@altlinux.org>
791
Roland McGrath9d721f22005-02-02 04:45:09 +0000792 * configure.ac: Use AC_GNU_SOURCE macro instead of changing CFLAGS.
793 * defs.h [HAVE_CONFIG_H]: Include config.h first.
794 * strace.c: Include "defs.h" first.
795 Fixes RH#143370.
796
Roland McGrathac6b7bb2005-02-02 04:42:56 +0000797 * syscall.c (call_summary): Fix potential NULL dereference.
798 Fixes RH#143369.
799
Roland McGrathdd9efd82005-02-02 04:40:36 +00008002004-12-19 Dmitry V. Levin <ldv@altlinux.org>
801
802 * syscall.c (qual_signal): Check bounds for numeric signal names.
803 Fix parser of symbolic signal names.
804 Fix return code, as required by qualify() function.
805 * syscall.c (qual_desc): Check bounds for descriptor number.
806 * syscall.c (qual_syscall): Correct return code, to be consistent
807 with qualify() and other qual_* functions.
808 Fixes RH#143362.
809
Roland McGrath1b3ca102005-02-02 02:49:03 +00008102005-02-01 Roland McGrath <roland@redhat.com>
811
Roland McGrath0dfeed62005-02-02 04:36:38 +0000812 * system.c [LINUX] (MS_MANDLOCK, MS_NOATIME, MS_NODIRATIME, MS_BIND,
813 MS_MOVE, MS_REC, MS_VERBOSE, MS_POSIXACL, MS_ACTIVE, MS_NOUSER):
814 New macros.
815 [LINUX] (mount_flags): Add them.
816 [LINUX] (sys_mount): If any of (MS_BIND|MS_MOVE|MS_REMOUNT) bits are
817 set in the flags argument, don't try to fetch the filesystem string.
818 Fixes RH#141932.
819
Roland McGrathdc26fff2005-02-02 04:19:19 +0000820 * config.guess: Update from canonical version, timestamp 2004-11-12.
821 * config.sub: Likewise, timestamp 2004-11-30.
822
Roland McGrathb2ba50b2005-02-02 04:16:58 +0000823 * process.c [LINUX] [X86_64] (sys_arch_prctl): New function.
824 * linux/syscall.h: Declare it.
825 * linux/x86_64/syscallent.h: Use it.
826 Part of RH#142667.
827
828 * process.c (sys_sched_setscheduler): Use %#lx format for bad pointer.
829 (sys_sched_getparam, sys_sched_setparam): Likewise.
830 Part of RH#142667.
831
832 * signal.c [HAVE_SIGACTION] [LINUX && X86_64] (SA_RESTORER): Define
833 here too.
834 Part of RH#142667.
835
836 * linux/syscallent.h: Use sys_mincore instead of printargs.
837 * linux/x86_64/syscallent.h: Likewise. Also use sys_getrlimit,
838 sys_semtimedop, sys_umount2.
839 Part of RH#142667.
840
Roland McGrath28eace82005-02-02 03:51:22 +0000841 * syscall.c (qual_signal): Fix inverted return value and bogus
842 argument to qualify_one in the named case.
843
Roland McGrath5f221c32005-02-02 03:38:49 +0000844 * file.c (print_xattr_val): Don't use auto array sized by syscall
845 argument. Use malloc instead, so it can fail for insane values.
846 Fixes Debian bug #283704.
847
Roland McGrath53962332005-02-02 03:11:43 +0000848 * net.c (sys_getsockopt): Fix a format %ld -> %d.
849
850 * linux/syscall.h [IA64] (SYS_semtimedop): #undef it.
851
Roland McGrathbc484bd2005-02-02 03:07:24 +0000852 * syscall.c (syscall_enter) [X86_64]: Fix 32-bit argument register map
853 not to double the middle entry!
854 Fixes RH#146093.
855
Roland McGrath6722dcf2005-02-02 02:54:35 +0000856 * linux/x86_64/syscallent.h: Fix exit_group entry.
857
Roland McGrath1b3ca102005-02-02 02:49:03 +0000858 * util.c (getpc) [S390 || S390X]: Implement it.
859 Patch by David Wilder <wilder@us.ibm.com>.
860
861 * linux/ia64/syscallent.h: Add fadvise64, fstatfs64, statfs64, mbind,
862 [gs]et_mempolicy, mq_*, sys_kexec_load, vserver, and waitid.
863 Fixes RH#146245.
864
8652005-01-22 Andreas Schwab <schwab@suse.de>
866
867 * net.c (sys_getsockopt): Change type of len to int.
868
Roland McGrath914f3aa2004-10-19 23:00:14 +00008692004-10-19 Roland McGrath <roland@redhat.com>
870
Roland McGrathb0756892004-10-20 02:17:58 +0000871 * configure.ac, NEWS: Version 4.5.8.
872 * debian/changelog, strace.spec: 4.5.8-1.
873
Roland McGrathbe4eeb92004-10-20 02:24:28 +0000874 * file.c (sys_fadvise64): Conditionalize just on [LINUX].
875
Roland McGrathb0756892004-10-20 02:17:58 +0000876 * configure.ac: Check for sys/epoll.h.
877 * desc.c: Protect #include <sys/epoll.h> with [HAVE_SYS_EPOLL_H].
878 (epollctls, epollevents): Protect each entry with #ifdef on its macro.
879
Roland McGrathe26a3782004-10-20 02:04:19 +0000880 * strace.c (handle_group_exit): Don't detach leader that wasn't
881 TCB_ATTACHED. Instead mark it with TCB_GROUP_EXITING.
882 Remove droptcb loop at end, no longer required since 2.6 reports each
883 thread death.
884 Fixes RH#135254.
885
Roland McGrath712bc7a2004-10-20 01:00:45 +0000886 * strace.c (trace): Use handle_group_exit for non-TCB_ATTACHED child
887 taking signal when it has nclone_threads > 0.
888
Roland McGrath712bc7a2004-10-20 01:00:45 +0000889 * strace.c (handle_group_exit, trace): Mark leader with
890 TCB_GROUP_EXITING and don't be surprised at child deaths when their
891 leader has it set.
892 Fixes RH#132150.
893
Roland McGrath223a3ff2004-10-19 23:33:53 +0000894 * process.c (WCOREFLAG): Define if not defined.
895 (W_STOPCODE, W_EXITCODE): Likewise.
896 Reported by Marty Leisner <mleisner@eng.mc.xerox.com>.
897
898 * sock.c [! LINUX]: Include <sys/socket.h> before <sys/sockio.h>.
899 Reported by Marty Leisner <mleisner@eng.mc.xerox.com>.
900
901 * debian/rules: Make strace64.1.gz symlink to strace.1.gz instead of
902 strace64.1 to strace.1, which doesn't exist.
903 Fixes Debian bug #269220.
904
9052004-09-05 Phil Blundell <pb@nexus.co.uk>
906
907 * linux/arm/syscallent.h: New file.
908
9092004-10-19 Roland McGrath <roland@redhat.com>
910
911 * debian/rules (DEB_BUILD_GNU_TYPE, CONFIG_OPTS): New variables.
912 [$(DEB_HOST_GNU_TYPE) == s390-linux] (build64, HOST64, CC64): Set them.
913 (build/Makefile): Use $(CONFIG_OPTS).
914 (build64/Makefile): Pass --host as well as --build.
915 From Bastian Blank <waldi@debian.org>.
916 Fixes Debian bug #271500.
917
918 * linux/hppa/syscallent.h: Update for 2.6.9 syscalls.
919 From Randolph Chung <tausq@debian.org>
920 Fixes Debian bug #273887.
921
Roland McGrath914f3aa2004-10-19 23:00:14 +0000922 * file.c (sys_llseek): Revert last change.
923
Roland McGrath223a3ff2004-10-19 23:33:53 +00009242004-09-14 Richard Henderson <rth@twiddle.net>
925
926 * linux/alpha/syscallent.h: Add tgkill, *stat64, vserver, mbind,
927 [gs]et_mempolicy, mq_*, waitid.
928
Roland McGrath51f9ac02004-10-07 18:51:22 +00009292004-10-07 Roland McGrath <roland@redhat.com>
930
Roland McGrath0aa53f62004-10-07 19:09:23 +0000931 * file.c (sys_llssek, sys_readahead, sys_fadvise64, sys_fadvise64_64):
932 Use LONG_LONG macro.
933 * io.c (sys_pread, sys_pwrite, sys_sendfile): Likewise.
934
Roland McGrath61b324b2004-10-07 18:59:13 +0000935 * linux/x86_64/syscallent.h: Fix botched table entries.
936 From Ulrich Drepper <drepper@redhat.com>.
937
Roland McGrathaa08d712004-10-07 18:53:17 +0000938 * mem.c [LINUX] (sys_mbind, sys_set_mempolicy, sys_get_mempolicy):
939 New functions.
940 * linux/syscall.h: Declare them.
941 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath61b324b2004-10-07 18:59:13 +0000942 From Ulrich Drepper <drepper@redhat.com>.
943
Roland McGrathaa08d712004-10-07 18:53:17 +0000944 * linux/syscallent.h: Handle mbind, set_mempolicy, get_mempolicy.
945 From Ulrich Drepper <drepper@redhat.com>.
946
Roland McGrath51f9ac02004-10-07 18:51:22 +0000947 * file.c [LINUX && (I386 || X86_64)] (sys_fadvise64, sys_fadvise64_64):
948 New functions.
949 * linux/syscall.h: Declare them.
950 * linux/syscallent.h: Handle fadvise64 and fadvise64_64 using those.
Roland McGrathaa08d712004-10-07 18:53:17 +0000951 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath51f9ac02004-10-07 18:51:22 +0000952 From Ulrich Drepper <drepper@redhat.com>.
953
Roland McGrath2af128b2004-10-06 22:32:04 +00009542004-09-13 Dmitry V. Levin <ldv@altlinux.org>
955
956 * linux/ioctlsort.c (main): Omit duplicate lines
957 (with same name and code) from output.
958 * linux/ioctlent.sh: Build the list of ioctls defined in
959 scsi/sg.h (0x22..), scsi/scsi.h and scsi/scsi_ioctl.h (0x53..),
960 as suggested by Peter Jones <pjones@redhat.com>
961 * linux/ioctlent.h: Regenerated.
962 Fixes RH#129808.
963
Roland McGrath79367f82004-10-06 22:28:17 +00009642004-09-13 Ulrich Drepper <drepper@redhat.com>
965 Dmitry V. Levin <ldv@altlinux.org>
966
967 * time.c [LINUX] (print_rtc): New function, for printing rtc_time
968 structure.
969 [LINUX] (rtc_ioctl): New function, for parsing RTC_* ioctls.
970 * ioctl.c [LINUX] (ioctl_decode): Call rtc_ioctl.
971 * defs.h [LINUX]: Declare rtc_ioctl.
972 Fixes RH#58606.
973
Roland McGrath288a3a02004-10-06 22:12:09 +00009742004-10-06 Roland McGrath <roland@redhat.com>
975
Roland McGrathd2553bb2004-10-06 22:23:55 +0000976 * desc.c [LINUX] (sys_epoll_create, sys_epoll_ctl, sys_epoll_wait):
977 New functions.
978 * linux/syscall.h: Declare them.
979 * linux/syscallent.h: Use those for epoll_* syscalls.
980 * linux/alpha/syscallent.h: Likewise.
981 * linux/hppa/syscallent.h: Likewise.
982 * linux/ia64/syscallent.h: Likewise.
983 * linux/powerpc/syscallent.h: Likewise.
984 * linux/s390/syscallent.h: Likewise.
985 * linux/s390x/syscallent.h: Likewise.
986 * linux/sparc/syscallent.h: Likewise.
987 * linux/sparc64/syscallent.h: Likewise.
988 * linux/sparc64/syscallent2.h: Likewise.
989 * linux/x86_64/syscallent.h: Likewise.
990 From Ulrich Drepper <drepper@redhat.com>.
991 Fixes RH#134463.
992
Roland McGrath2803d102004-10-06 22:15:18 +0000993 * resource.c (resources): Add RLIMIT_LOCKS, RLIMIT_SIGPENDING,
994 and RLIMIT_MSGQUEUE, if defined.
995 From Ulrich Drepper <drepper@redhat.com>.
996 Fixes RH#133594.
997
Roland McGrath288a3a02004-10-06 22:12:09 +0000998 * net.c [HAVE_SENDMSG] (printcmsghdr): New function.
999 (printmsghdr): Use it.
Roland McGrath2803d102004-10-06 22:15:18 +00001000 From Ulrich Drepper <drepper@redhat.com>.
1001 Fixes RH#131689.
Roland McGrath288a3a02004-10-06 22:12:09 +00001002
1003 * file.c (sprintmode): Add const to return type.
1004 (sprintfstype): Likewise.
1005 * signal.c (printsiginfo): Add a const.
1006
Roland McGrath4455b1d2004-10-06 22:03:22 +000010072004-09-15 Roland McGrath <roland@redhat.com>
1008
1009 * linux/x86_64/syscallent.h: Use sys_waitid.
1010
1011 * linux/syscallent.h: waitid takes 5 arguments, and is in TP category.
1012 * process.c (sys_waitid): Handle fifth argument (struct rusage *).
1013
Roland McGrath813b8af2004-09-11 08:13:27 +000010142004-09-11 Roland McGrath <roland@redhat.com>
1015
1016 * time.c (sys_clock_nanosleep): Print zero flags arg correctly.
1017 (sys_timer_settime): Likewise.
1018 (printsigevent): Print signals by name for SIGEV_SIGNAL.
1019 (sys_timer_create): Print clock ID symbolically.
1020 From Ulrich Drepper <drepper@redhat.com>.
1021 Fixes RH#131420.
1022
Michal Ludvig51d1ebc2004-09-07 14:06:03 +000010232004-09-07 Michal Ludvig <mludvig@suse.cz>
1024
1025 * defs.h (nioctlents1, nsignals2): Fix typos in decls.
1026
Roland McGrath4ee6e692004-09-04 03:39:26 +000010272004-09-03 Roland McGrath <roland@redhat.com>
1028
Roland McGrathce361382004-09-04 04:20:49 +00001029 * syscall.c (qual_options): Add const to defn.
1030 Update all uses.
1031 (call_count, error_count, tv_count): Variables removed.
1032 (struct call_counts, counts): New type and variable.
1033 Update all users of the old three to use the new array of structs.
1034 (trace_syscall): Allocate counts on first use.
1035 (sorted_count): Variable removed.
1036 (call_summary): Allocate locally.
1037
Roland McGrath77019f72004-09-04 03:53:18 +00001038 * syscall.c (sysent0, sysent1, sysent2, sysent): Add const to defn.
1039 (nsyscalls0, nsyscalls1, nsyscalls2): Likewise.
1040 (errnoent0, errnoent1, errnoent2, errnoent): Likewise.
1041 (nerrnos0, nerrnos1, nerrnos2): Likewise.
1042 * signal.c (signalent0, signalent1, signalent2): Likewise.
1043 (nsignals0, nsignals1, nsignals2): Likewise.
1044 (signame): LIkewise.
1045 * ioctl.c (ioctlent0, ioctlent1, ioctlent2): Likewise.
1046 (nioctlents0, nioctlents1, nioctlents2): Likewise.
1047 (ioctl_lookup, ioctl_next_match): Likewise.
1048 * defs.h: Update decls.
1049 * io.c (sys_ioctl): Update users.
1050
Roland McGrath4ee6e692004-09-04 03:39:26 +00001051 * util.c (xlookup, printxval, addflags, printflags): Use const for
1052 struct xlat * argument.
1053 * defs.h (xlookup, printxval, addflags, printflags): Update decls.
1054 * bjm.c: Add const to all struct xlat defns.
1055 * desc.c: Likewise.
1056 * file.c: Likewise.
1057 * ipc.c: Likewise.
1058 * mem.c: Likewise.
1059 * net.c: Likewise.
1060 * proc.c: Likewise.
1061 * process.c: Likewise.
1062 * resource.c: Likewise.
1063 * signal.c: Likewise.
1064 * sock.c: Likewise.
1065 * stream.c: Likewise.
1066 * system.c: Likewise.
1067 * term.c: Likewise.
1068 * time.c: Likewise.
1069 * util.c: Likewise.
1070
Roland McGrathb036f582004-09-01 19:39:59 +000010712004-09-01 Roland McGrath <roland@redhat.com>
1072
1073 * linux/x86_64/syscallent.h: Add new entries for timer_*, clock_*, and
1074 mq_* syscalls, and names only for new calls up to 252.
1075 * linux/syscallent.h: Add waitid.
1076 * linux/x86_64/syscallent.h: Likewise.
1077 * linux/syscall.h: Declare sys_waitid.
1078
1079 * process.c (internal_wait): Take second arg giving index of flags
1080 argument.
1081 * defs.h: Update prototype.
1082 * syscall.c (internal_syscall): Update caller.
1083 Also use internal_wait for SYS_waitid.
1084 * process.c (sys_waitid): Define for [LINUX] as well.
1085 Don't tweak TCB_SUSPENDED--internal_wait does that.
1086 (waitid_types): Conditionalize use of nonstandard P_* macros.
1087
Roland McGrath1651c1c2004-08-31 07:16:21 +000010882004-08-31 Roland McGrath <roland@redhat.com>
1089
Roland McGrath0ef93b72004-08-31 08:17:26 +00001090 * configure.ac, NEWS: Version 4.5.7.
Roland McGrathb036f582004-09-01 19:39:59 +00001091 * debian/changelog: 4.5.7-1.
1092 * strace.spec: 4.5.7-2.
Roland McGrath0ef93b72004-08-31 08:17:26 +00001093
Roland McGrathf5fcbc12004-08-31 08:41:59 +00001094 * debian/rules: Rewrite sparc64 change of 2004-07-12.
1095 Always do each build in a separate build directory.
Roland McGrath0ef93b72004-08-31 08:17:26 +00001096 Fixes Debian bug #254728.
1097
Roland McGrathf5fcbc12004-08-31 08:41:59 +00001098 * time.c (clocknames): Use #ifdef around CLOCK_* uses.
1099
Roland McGrathdc025fa2004-08-31 07:48:03 +00001100 * strace.1: Say that -c shows system CPU time, not real time.
1101 Fixes Debian bug #254438.
1102
1103 * syscall.c (dumpio): Match pread and pwrite system calls too.
1104 Fixes Debian bug #239947.
1105
Roland McGrath1651c1c2004-08-31 07:16:21 +00001106 * net.c (sockoptions): Add all SO_* macros known in Linux 2.6.9.
1107 Fixes Debian bug #171653.
1108
Roland McGrath8e593d22004-08-31 07:03:43 +000011092004-07-12 Dmitry V. Levin <ldv@altlinux.org>
1110
1111 * signal.c [LINUX] (parse_sigset_t): Fix hex strings parser.
1112 Fixes RH#128091.
1113
Roland McGratha0b9ef12004-08-31 06:30:51 +000011142004-08-30 Roland McGrath <roland@redhat.com>
1115
Roland McGrath0a053252004-08-31 07:02:00 +00001116 * strace.c (main): Don't call fake_execve under -c.
1117 From Ulrich Drepper <drepper@redhat.com>.
1118 Fixes RH#129166.
1119
1120 * net.c (sockipoptions): Add some options.
1121 [SOL_IPV6] (sockipv6options): New variable.
1122 (sys_getsockopt, printsockopt): Use it for SOL_IPV6 level.
1123 From Ulrich Drepper <drepper@redhat.com>.
1124 Fixes RH#128391.
1125
Roland McGrath7fbbf022004-08-31 06:52:49 +00001126 * time.c (clocknames): New variable, symbolic names for clock_t.
1127 (sys_clock_settime, sys_clock_gettime, sys_clock_nanosleep): Use it.
1128 From Ulrich Drepper <drepper@redhat.com>.
1129 Fixes RH#129378.
1130
Roland McGrath3a71f192004-08-31 06:49:09 +00001131 * system.c (personality_options): Hard-code values here.
1132 Don't #include <linux/personality.h> at all.
Roland McGrath1651c1c2004-08-31 07:16:21 +00001133 Fixes RH#130965 and Debian bug #40588.
Roland McGrath3a71f192004-08-31 06:49:09 +00001134
Roland McGratha0b9ef12004-08-31 06:30:51 +00001135 * file.c (print_xattr_val): New function to show attribute values.
1136 (sys_setxattr, sys_fsetxattr, sys_getxattr, sys_fgetxattr): Use it.
1137 From Ulrich Drepper <drepper@redhat.com>.
1138 Fixes RH#131177.
1139
Roland McGrath90a5a942004-07-12 07:04:55 +000011402004-07-12 Roland McGrath <roland@redhat.com>
1141
Roland McGrathd51619a2004-07-12 07:56:00 +00001142 * configure.ac, NEWS: Version 4.5.6.
1143 * strace.spec, debian/changelog: 4.5.6-1.
1144
Roland McGrath05cf2952004-07-12 07:54:09 +00001145 * Makefile.am (EXTRA_DIST): Add linux/sparc64 files.
1146
1147 * debian/rules: On sparc-linux, build strace64 as well.
1148 From Ben Collins <bcollins@debian.org>.
1149 Fixes Debian bug #254728.
1150
11512004-07-07 David S. Miller <davem@nuts.davemloft.net>
1152
1153 * linux/sparc/syscallent.h: Sync with reality.
1154 * linux/sparc/syscall.h (sys_sendfile64, sys_futex, sys_gettid,
1155 sys_sched_setaffinity, sys_sched_getaffinity, sys_setxattr,
1156 sys_lsetxattr, sys_fsetxattr, sys_getxattr, sys_lgetxattr,
1157 sys_fgetxattr, sys_listxattr, sys_llistxattr, sys_flistxattr,
1158 sys_removexattr, sys_lremovexattr, sys_fremovexattr,
1159 sys_remap_file_pages, sys_readahead, sys_tgkill, sys_statfs64,
1160 sys_fstatfs64, sys_clock_settime, sys_clock_gettime,
1161 sys_clock_getres, sys_clock_nanosleep, sys_timer_create,
1162 sys_timer_settime, sys_timer_gettime): New declarations.
1163 * linux/sparc64/dummy2.h, linux/sparc64/syscallent2.h,
1164 linux/sparc64/syscall.h, linux/sparc64/errnoent.h,
1165 linux/sparc64/errnoent1.h, linux/sparc64/errnoent2.h,
1166 linux/sparc64/ioctlent.h, linux/sparc64/ioctlent1.h,
1167 linux/sparc64/ioctlent2.h, linux/sparc64/signalent.h,
1168 linux/sparc64/signalent.h, linux/sparc64/signalent.h,
1169 linux/sparc64/signalent1.h, linux/sparc64/signalent2.h,
1170 linux/sparc64/syscall1.h, linux/sparc64/syscallent.h,
1171 linux/sparc64/syscallent1.h: New files.
1172 * defs.h (LINUXSPARC): Define also when SPARC64.
1173 (LINUX && SPARC64): Set SUPPORTED_PERSONALITIES to 3.
1174 Ignore SIGTRAP after execve by defining TCB_WAITEXECVE.
1175 Define possibly missing __NR_exit_group. Declare getrval2.
1176 * configure.ac (sparc64): New architecture case.
1177 * file.c (stat_sparc64): New structure.
1178 (printstat_sparc64): New output routine for that.
1179 (printstat): Call it, if personality is 2.
1180 (printstat64): Likewise.
1181 * util.c: Conditionalize ptrace defines on LINUXSPARC
1182 not LINUX && SPARC.
1183 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1184 to PTRACE_FOOREGS64 so that more sparc code can be shared
1185 between 64-bit and 32-bit.
1186 (_hack_syscall5): Correct trap number when SPARC64.
1187 (PTRACE_WRITE{TEXT,DATA}): Add SPARC64 to ifdef guard.
1188 (getpc): Handle SPARC64 && LINUX.
1189 (printcall): Likewise.
1190 (arg fetching/setting): Use same code for SPARC64 LINUX
1191 as for SPARC.
1192 (setbpt): Handle SPARC64 && LINUX.
1193 (clearbpt): Likewise.
1194 * signal.c: Conditionalize ptrace defines on SPARC and
1195 SPARC64.
1196 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1197 to PTRACE_FOOREGS64 so that more sparc code can be shared
1198 between 64-bit and 32-bit.
1199 (m_siginfo): Use same definition on SPARC64 as SPARC.
1200 (sys_sigreturn): Handle LINUX && SPARC64.
1201 * syscall.c: Conditionalize ptrace defines on SPARC and
1202 SPARC64.
1203 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1204 to PTRACE_FOOREGS64 so that more sparc code can be shared
1205 between 64-bit and 32-bit.
1206 (getscno): Use same static state on SPARC64 as SPARC,
1207 and add SPARC64 handling.
1208 (get_error): Handle LINUX && SPARC64.
1209 (force_result): Likewise.
1210 (syscall_enter): Likewise.
1211 (trace_syscall): Handle sys_socketcall and sys_ipc on SPARC64
1212 just like SPARC.
1213 (getrval2): Handle LINUX && SPARC64.
1214 * process.c: Conditionalize ptrace defines on SPARC and
1215 SPARC64.
1216 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1217 to PTRACE_FOOREGS64 so that more sparc code can be shared
1218 between 64-bit and 32-bit.
1219 (change_syscall): Handle LINUX && SPARC64.
1220 (struct_user_offsets): Ifdef out those which do not exist
1221 on SPARC64.
1222 * net.c (sys_pipe): Handle LINUX && SPARC64.
1223 * ioctl.c: Fix initializer typo for nioctlents2, was
1224 nioctlents1 by accident.
1225
12262004-06-28 Andreas Schwab <schwab@suse.de>
1227
1228 * process.c (internal_exec): Move TCB_WAITEXECVE handling here.
1229 (sys_execve): Remove it here.
1230
12312004-07-12 Roland McGrath <roland@redhat.com>
1232
1233 * Makefile.am (EXTRA_DIST): Add linux/sh64/syscallent.h.
1234
1235 * debian/control (Section): Move to utils, matching Debian override.
1236
Roland McGrath23e86d62004-07-12 07:13:12 +00001237 * net.c (addrfams): Make variable global.
1238 * sock.c (sock_ioctl): Decode the arguments for SIOCGIFNAME,
1239 SIOCGIFINDEX, and SIOCGIFCONF.
1240 From Ulrich Drepper <drepper@redhat.com>.
1241 Fixes RH#126917.
1242
Roland McGrath90a5a942004-07-12 07:04:55 +00001243 * linux/ioctlsort.c: Add some #includes.
1244 [POWERPC]: Kludge out high bits.
1245 * linux/ia64/ioctlent.h: Regenerated using RHEL3 headers.
1246 * linux/powerpc/ioctlent.h: Likewise.
1247
Roland McGrath16110b22004-07-12 05:45:26 +000012482004-07-11 Roland McGrath <roland@redhat.com>
1249
Roland McGrath90a5a942004-07-12 07:04:55 +00001250 * linux/ioctlent.sh: Replace asm with $asm in all places.
1251
Roland McGrath16110b22004-07-12 05:45:26 +00001252 * configure.ac: Add I386 as AM_CONDITIONAL.
1253 * Makefile.am [LINUX]: Add maintainer-mode rules to regenerate
1254 the ioctlent.h file.
1255
Roland McGrath533e52a2004-07-08 19:00:25 +000012562004-07-08 Roland McGrath <roland@redhat.com>
1257
1258 * resource.c (sys_quotactl): Truncate first argument to 32 bits, since
1259 that's what the kernel will do.
1260
12612004-07-07 Roland McGrath <roland@redhat.com>
1262
1263 * linux/ioctlent.sh: Take optional second argument to use as directory
1264 name in place of `asm'.
1265
Roland McGrath2c72f3c2004-06-28 05:24:40 +000012662004-06-27 Roland McGrath <roland@redhat.com>
1267
1268 * configure.ac, NEWS: Version 4.5.5.
1269 * strace.spec, debian/changelog: 4.5.5-1.
1270
Roland McGratha2dec922004-06-23 01:40:57 +000012712004-06-22 Roland McGrath <roland@redhat.com>
1272
1273 * syscall.c (syscall_fixup) [LINUX && X86_64]: For 32-bit process,
1274 sign extend the low 32 bits of RAX to 64 bits.
Roland McGrath7a391df2004-06-23 01:41:30 +00001275 Fixes RH#126547.
Roland McGratha2dec922004-06-23 01:40:57 +00001276
1277 * syscall.c (force_result): [LINUX && X86_64]: Fix RAX*4 -> RAX*8.
1278
Roland McGrath0c542de2004-06-04 02:25:12 +000012792004-06-03 Roland McGrath <roland@redhat.com>
1280
Roland McGrath66a77f12004-06-04 02:36:03 +00001281 * configure.ac, NEWS: Version 4.5.4.
1282 * strace.spec, debian/changelog: 4.5.4-1.
1283
Roland McGrath0c542de2004-06-04 02:25:12 +00001284 * net.c (domains): Add many PF_* values #ifdef PF_*.
1285 (addrfams): Add many AF_* values #ifdef AF_*.
1286 Fixes Debian bug #250506.
1287
Roland McGrath337d3912004-06-04 02:03:15 +000012882004-05-02 Dmitry V. Levin <ldv@altlinux.org>
1289
1290 * linux/ioctlsort.c (compare): When ioctl codes equal, compare
1291 names.
1292 (main): Print a note that program output is generated by
1293 ioctlsort.
1294 * linux/ioctlent.sh: Build the list of ioctls defined in
1295 linux/fb.h (0x46..), linux/kd.h (0x4B..), linux/cdrom.h (0x53..),
1296 asm/ioctls.h (0x54..), linux/vt.h (0x56..), linux/videotext.h
1297 (0x71..), linux/videotext.h (0x72..), asm/sockios.h (0x89..),
1298 linux/sockios.h (0x89..), linux/wireless.h (0x8B..).
1299 * linux/ioctlent.h: Regenerated from linux-2.6.5.
1300 Fixes RH#122257.
1301
Roland McGrath6d52da62004-06-04 01:50:53 +000013022004-06-03 Roland McGrath <roland@redhat.com>
1303
Roland McGrathe01b8ce2004-06-04 02:01:54 +00001304 * debian/control (Architecture): Add amd64.
1305 Fixes Debian bug #246568.
1306
Roland McGrath6d52da62004-06-04 01:50:53 +00001307 * strace.c (main) [LINUX]: Expand TCBTAB as necessary for threads
1308 attached. Attach threads only under -f. Set TCB_FOLLOWFORK in them.
1309 (expand_tcbtab): New function, broken out of ...
1310 * process.c (fork_tcb): ... here, call that.
1311 * defs.h: Declare expand_tcbtab.
1312
Roland McGrath25e82592004-06-04 01:24:12 +000013132004-04-19 Roland McGrath <roland@redhat.com>
1314
1315 * process.c (printstatus): Add a space before | in output.
1316
Roland McGrathea2402e2004-04-16 22:28:48 +000013172004-04-16 Roland McGrath <roland@redhat.com>
1318
1319 * configure.ac: Version 4.5.3.
1320 * strace.spec, debian/changelog: 4.5.3-1.
1321
Roland McGrath025442c2004-04-16 21:59:05 +000013222004-03-18 Dmitry V. Levin <ldv@altlinux.org>
1323
1324 * resource.c (sys_quotactl) [LINUX]: Cast arithmetic shift operand
1325 from long to unsigned long, to fix output of the quotactl command
1326 parser.
Roland McGrathea2402e2004-04-16 22:28:48 +00001327 Fixes RH#118694.
Roland McGrath025442c2004-04-16 21:59:05 +00001328
Roland McGrath8d1bf3c2004-04-16 21:48:43 +000013292004-04-16 Roland McGrath <roland@redhat.com>
1330
Roland McGrath025442c2004-04-16 21:59:05 +00001331 * linux/s390/ioctlent.h, linux/s390x/ioctlent.h: Update DASD ioctls.
1332 From Maxim Shchetynin <maxim@de.ibm.com>.
1333
Roland McGrath8d1bf3c2004-04-16 21:48:43 +00001334 * configure.ac: Check for <mqueue.h>.
1335 * ipc.c (sys_mq_open, printmqattr) [! HAVE_MQUEUE_H]: Don't try to
1336 decode struct mq_attr.
Roland McGrath6508d332004-04-16 21:54:59 +00001337 * NEWS: Mention mq support.
Roland McGrath8d1bf3c2004-04-16 21:48:43 +00001338
1339 * linux/syscall.h: Support new mq_* syscalls on Linux.
1340 * linux/syscallent.h: Likewise.
1341 * linux/dummy.h: Likewise.
1342 * ipc.c: Likewise.
1343 * time.c (printsigevent): Handle SIGEV_THREAD.
1344 From Ulrich Drepper <drepper@redhat.com>.
1345 Fixes RH#120701.
1346
Roland McGrath6421d632004-04-14 02:46:35 +000013472004-04-13 Roland McGrath <roland@redhat.com>
1348
Roland McGrath085bae12004-04-14 02:54:02 +00001349 * net.c (msg_flags): Grok MSG_FIX, MSG_SYN, MSG_RST, MSG_NOSIGNAL,
1350 MSG_MORE.
1351 From Ulrich Drepper <drepper@redhat.com>.
1352 Fixes RH#120541.
1353
Roland McGrath6421d632004-04-14 02:46:35 +00001354 * process.c (printstatus): Mask out bits presented symbolically, and
1355 print "| 0xnnn" if the remaining bits are not all zero.
1356 Fixes Debian bug #240062.
1357
1358 * process.c (print_affinitylist): Rewritten to handle indirect values.
1359 (sys_sched_setaffinity, sys_sched_getaffinity): Update callers.
1360 From Ulrich Drepper <drepper@redhat.com>.
1361 Fixes RH#118685.
1362
1363 * acinclude.m4: Quote first argument to AC_DEFUN in all cases.
1364
Roland McGrath74dcbd82004-04-09 00:25:47 +000013652004-04-08 Roland McGrath <roland@redhat.com>
1366
1367 * strace.c (main) [LINUX]: When attaching for -p, look in
1368 /proc/PID/task for all threads and attach them as presumed
1369 CLONE_THREAD children.
1370 * NEWS: Mention the feature.
Roland McGrath085bae12004-04-14 02:54:02 +00001371 Fixes RH#120462.
Roland McGrath74dcbd82004-04-09 00:25:47 +00001372
Roland McGrath2d1ecca2004-03-02 08:07:20 +000013732004-03-02 Roland McGrath <roland@redhat.com>
1374
Roland McGrath6835f232004-03-02 08:50:47 +00001375 * util.c (setbpt): Fix one missed spot to use new arg0_index macro.
1376 From Michael Holzheu <HOLZHEU@de.ibm.com>.
1377
Roland McGrath2d1ecca2004-03-02 08:07:20 +00001378 * debian/control (Standards-Version): Update to 3.6.1.
1379
Roland McGrath861dc142004-03-01 20:57:16 +000013802004-03-01 Roland McGrath <roland@redhat.com>
1381
Roland McGrath801bf1f2004-03-02 06:38:40 +00001382 * configure.ac, NEWS: Version 4.5.2.
Roland McGrathea2402e2004-04-16 22:28:48 +00001383 * strace.spec, debian/changelog: 4.5.2-1.
Roland McGrath801bf1f2004-03-02 06:38:40 +00001384
Roland McGrath30423402004-03-02 06:54:57 +00001385 * strace.c (main): Avoid potential buffer overruns from ludicrous
1386 arguments or PATH values.
1387 * syscall.c (qual_signal): Bail out for too-long string.
1388
Roland McGrath59aea572004-03-02 06:17:11 +00001389 * mem.c [LINUX]: <asm/mman.h> -> <linux/mman.h>
Roland McGrath5586f9a2004-03-02 06:23:08 +00001390 Fixes Debian bug #223207.
Roland McGrath59aea572004-03-02 06:17:11 +00001391
1392 * linux/sparc/syscall.h: Copy linux/syscall.h decls of sys_sched_*.
Roland McGrath8f30c1d2004-03-02 06:09:35 +00001393
Roland McGrath7da8ff72004-03-01 22:10:58 +00001394 * configure.ac: Check for `struct user_desc' in <asm/ldt.h>.
1395 * process.c [HAVE_STRUCT_USER_DESC]: Use struct user_desc in place of
1396 struct modify_ldt_ldt_s.
1397 * mem.c [HAVE_STRUCT_USER_DESC]: Likewise.
1398
1399 * system.c (sysctl_vm): Conditionalize VM_* macro uses, add some more.
1400 From Tim Yamin <plasmaroo@gentoo.org>.
1401
Roland McGrathce238102004-03-01 22:04:09 +00001402 * process.c (sys_execve): Clear instead of set TCB_WAITEXECVE on
1403 erring syscall.
1404
Roland McGrathe58b8a02004-03-01 21:29:31 +00001405 * configure.ac: Check for `struct pt_all_user_regs'
1406 and `struct ia64_fpreg' in <sys/ptrace.h>.
Roland McGrath4695e942004-03-01 21:31:07 +00001407 * util.c, process.c, syscall.c, signal.c: Work around conflicts between
Roland McGrathe58b8a02004-03-01 21:29:31 +00001408 <sys/ptrace.h> and <linux/ptrace.h> for defining those types.
1409
Roland McGrath4695e942004-03-01 21:31:07 +00001410 * process.c (struct_user_offsets) [LINUX && IA64]: Conditionalize
1411 PT_AR_CSD and PT_AR_SSD uses in case of older kernel headers.
1412
Roland McGrath861dc142004-03-01 20:57:16 +00001413 * util.c [LINUX] (arg0_index, arg1_index): New macros.
1414 [S390 || S390X]: Define them with inverted values.
1415 (setbpt): Use them for u_arg indices.
1416
Roland McGrath24e8d312004-03-01 20:30:51 +000014172004-02-26 Andreas Schwab <schwab@suse.de>
1418
1419 * defs.h [LINUX && IA64]: Declare getrval2 also on IA64.
1420 * net.c (sys_pipe) [LINUX && IA64]: For IA64 use the two return values.
1421 * syscall.c (getrval2) [LINUX && IA64]: Implement for IA64.
1422
Roland McGrath176ac322004-03-01 20:28:19 +000014232004-03-01 Roland McGrath <roland@redhat.com>
1424
1425 * linux/dummy.h (sys_sched_getscheduler, sys_sched_setparam,
1426 sys_sched_getparam, sys_sched_setscheduler, sys_sched_getscheduler,
1427 sys_sched_get_priority_max, sys_sched_get_priority_min): Remove macros.
1428 * process.c [LINUX] (sys_sched_getscheduler, sys_sched_setparam,
1429 sys_sched_getparam, sys_sched_setscheduler, sys_sched_getscheduler,
1430 sys_sched_get_priority_min): New functions.
1431 From Ulrich Drepper <drepper@redhat.com>.
1432 Fixes RH#116990.
1433
Roland McGrath3d3f1c92004-02-20 23:21:34 +000014342004-02-20 Roland McGrath <roland@redhat.com>
1435
1436 * linux/hppa/syscallent.h: Update some syscalls.
1437 From Randolph Chung <tausq@debian.org>.
1438 Fixes Debian bug #231632.
1439
Roland McGrathb233c262004-02-20 22:56:55 +000014402003-12-31 David Mosberger <davidm@hpl.hp.com>
1441
1442 * process.c (internal_exit): For ia64, also recognize IA-32 252
1443 as exit_group().
1444 (change_syscall): For IA64, also support changing IA-32 syscalls.
1445 * syscall.c (internal_syscall): For IA64, also recognize IA-32
1446 syscall 252 (exit_group) as an internal_exit() syscall.
1447 * util.c (SYS_fork): For IA64, define them to the IA-32 syscall
1448 number.
1449 (SYS_vfork): Likewise.
1450 (arg_setup): For IA64 version, also support IA-32 syscalls.
1451 (get_arg0): Likewise.
1452 (get_arg1): Likewise.
1453 (set_arg0): Likewise.
1454 (set_arg1): Likewise.
1455
Roland McGrath13aeab32004-02-20 02:25:42 +000014562004-02-15 Anton Blanchard <anton@samba.org>
1457
1458 * linux/powerpc/syscallent.h: Add rtas call.
1459 Shift multiplexed syscalls to start at 300, we are already about
1460 to hit 256 real syscalls.
1461 * linux/syscall.h: SYS_socket_subcall is now 300 for [POWERPC].
1462
14632004-02-19 Roland McGrath <roland@redhat.com>
1464
1465 * strace.c (main): Use TCP->pid, not PID, in -p message.
1466 Fixes Debian bug #229802.
1467
Roland McGrathec0cf0b2004-01-13 10:18:52 +000014682004-01-13 Roland McGrath <roland@redhat.com>
1469
Roland McGrath13aeab32004-02-20 02:25:42 +00001470 * syscall.c (force_result) [LINUX] [S390 || S390X]: Remove bogus upeek
1471 call.
1472
Roland McGrathec0cf0b2004-01-13 10:18:52 +00001473 * stream.c (internal_stream_ioctl): Fix typo strict -> struct.
1474 Reported by Petter Reinholdtsen <pere@hungry.com>.
1475
Roland McGrath135db892004-01-13 10:14:04 +000014762003-12-31 David Mosberger <davidm@hpl.hp.com>
1477
1478 * process.c (struct_user_offsets) [IA64]: Fix up register name list.
1479
Roland McGrath13aeab32004-02-20 02:25:42 +000014802003-12-14 Anton Blanchard <anton@samba.org>
Roland McGrath135db892004-01-13 10:14:04 +00001481
Roland McGrath75155472004-01-13 10:17:00 +00001482 * file.c (sys_getdents64): Don't cast d_ino and d_off to unsigned long.
1483 Use %llu formats for them.
1484
Roland McGrath135db892004-01-13 10:14:04 +00001485 * file.c [LINUX] (fsmagic): Add SYSFS_MAGIC.
1486
1487 * linux/powerpc/syscallent.h: Update to include recently added
1488 syscalls.
1489
1490 * syscall.c (get_error) [POWERPC]: Cast result to unsigned long for
1491 ppc64, we were misreporting syscalls that really succeeded as having
1492 failed.
1493
Roland McGrath5b7aa682004-01-13 09:52:52 +000014942004-01-13 Roland McGrath <roland@redhat.com>
1495
Roland McGrath8950c692004-01-13 10:00:01 +00001496 * strace.1: Remove comment about vfork on Linux.
1497 Fixes Debian bug #223390.
1498
Roland McGrath5b7aa682004-01-13 09:52:52 +00001499 * file.c (direnttypes): Define under [LINUX] as well. Add DT_UNKNOWN.
1500 (sys_getdents64) [LINUX]: Print d_type field.
1501
Roland McGrath13aeab32004-02-20 02:25:42 +000015022003-12-15 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath8950c692004-01-13 10:00:01 +00001503
1504 * strace.c (trace) [WCOREDUMP]: Show coredump status of the
Roland McGrath135db892004-01-13 10:14:04 +00001505 killed process if available. Fixes RH#112117.
Roland McGrath8950c692004-01-13 10:00:01 +00001506
Roland McGrathcf283032003-11-14 02:57:31 +000015072003-11-13 Roland McGrath <roland@redhat.com>
1508
1509 * configure.ac, NEWS: Version 4.5.1.
1510 * strace.spec, debian/changelog: 4.5.1-1.
1511
Roland McGrath13aeab32004-02-20 02:25:42 +000015122003-09-06 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath0aac8722003-11-14 02:54:09 +00001513
1514 * defs.h (ioctl_lookup): Prototype change.
1515 * ioctl.c (ioctl_next_match): New function.
1516 * defs.h: Declare it.
1517 * io.c (sys_ioctl): Use it, to display all possible ioctl names
1518 when there's more than one match.
1519 * ioctl.c (ioctl_lookup): Likewise.
1520 * stream.c (internal_stream_ioctl): Likewise.
1521 Patch from Solar Designer <solar@openwall.com>.
1522
Roland McGrath09f7a012003-11-13 22:32:32 +000015232003-11-13 Roland McGrath <roland@redhat.com>
1524
1525 * linux/sh/syscallent.h: Use sys_setgroups32, sys_getgroups32.
1526 * linux/sh64/syscallent.h: Likewise.
1527
Roland McGrath13aeab32004-02-20 02:25:42 +000015282003-09-06 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath09f7a012003-11-13 22:32:32 +00001529
Roland McGrathf25ef392003-11-13 22:33:48 +00001530 Fixes for RH#105359.
Roland McGrath09f7a012003-11-13 22:32:32 +00001531 * util.c (printuid): New function.
1532 * defs.h: Declare it.
1533 * file.c (sys_chown): Use it.
1534 * file.c (sys_fchown): Likewise.
1535 * process.c (sys_setreuid, sys_setregid, sys_setresuid,
1536 sys_setresgid): Likewise.
Roland McGrath09f7a012003-11-13 22:32:32 +00001537 * linux/syscallent.h: Better handle getgid32, geteuid32, getegid32,
1538 setreuid32, setregid32, getgroups32, setgroups32, fchown32,
1539 setresuid32, getresuid32, setresgid32, getresgid32, chown32,
1540 setuid32, setgid32, setfsuid32, setfsgid32.
1541 * process.c [LINUX]: Define GETGROUPS32_T.
1542 * process.c [LINUX] (sys_setgroups32, sys_getgroups32):
1543 New functions.
1544 * linux/syscall.h (sys_setgroups32, sys_getgroups32):
1545 Declare them.
1546
Roland McGrath730e8c02003-11-11 21:24:28 +000015472003-11-11 Roland McGrath <roland@redhat.com>
1548
1549 * strace.c (main): Bail with usage error for missing command before we
1550 open the -o file or fiddle uids.
1551
Roland McGrathe52919b2003-11-06 23:41:33 +000015522003-11-06 Roland McGrath <roland@redhat.com>
1553
Roland McGratha0f32e02003-11-07 02:36:45 +00001554 * strace.c (main): Treat piped output more like file output.
1555 Disallow -ff with piped output. Fixes RH#105366.
1556 Reported by Dmitry V. Levin <ldv@altlinux.org>
1557
Roland McGrathe52919b2003-11-06 23:41:33 +00001558 * strace.c (tprintf): Check result of vfprintf and use perror when it
1559 fails while not writing to stderr itself. Fixes Debian bug #218762.
1560
1561 * net.c (printsock): Fix typo in #ifdef AF_NETLINK.
1562 From Ulrich Drepper <drepper@redhat.com>.
1563
Roland McGrathb67e8e32003-11-01 22:11:29 +000015642003-11-01 Roland McGrath <roland@redhat.com>
1565
1566 * syscall.c (trace_syscall) [LINUX]: Calculate ONE_TICK once using
1567 setitimer rather than hard-coding a value based on HZ.
Roland McGrathd4897f82003-11-01 22:13:35 +00001568 Fixes RH#108012, reported by Florian La Roche <laroche@redhat.com>.
Roland McGrathb67e8e32003-11-01 22:11:29 +00001569
Roland McGratha9f76da2003-10-22 06:11:36 +000015702003-10-21 Roland McGrath <roland@redhat.com>
1571
Roland McGrath7aa6d202003-10-22 06:16:42 +00001572 * strace.1: Fixed a few spelling errors.
Roland McGrathb67e8e32003-11-01 22:11:29 +00001573 Fixes Debian bug #217008.
Roland McGrath7aa6d202003-10-22 06:16:42 +00001574
Roland McGratha9f76da2003-10-22 06:11:36 +00001575 * syscall.c: Revert last change, was broken.
1576
Roland McGrath8c74bd92003-10-01 07:50:34 +000015772003-10-01 Roland McGrath <roland@redhat.com>
1578
Roland McGrathe7da3502003-10-01 21:59:50 +00001579 * process.c (internal_clone): Don't suspend parent when call requested
1580 a specific PID that is not a traced child.
1581
Roland McGrath8c74bd92003-10-01 07:50:34 +00001582 * signal.c [LINUX] (parse_sigset_t): Rewrite to process hex strings
1583 from right to left so we don't have to presume the size.
Roland McGrathe7da3502003-10-01 21:59:50 +00001584 Reported by David Woodhouse <dwmw2@redhat.com>.
Roland McGrath8c74bd92003-10-01 07:50:34 +00001585
Roland McGrath268e9042003-09-25 23:06:12 +000015862003-09-25 Roland McGrath <roland@redhat.com>
1587
1588 * mem.c (mmap_prot) [PROT_SEM, PROT_GROWSDOWN, PROT_GROWSUP]: Include
1589 these in the table if they are defined.
1590
Roland McGrath4f59bab2003-09-24 22:22:49 +000015912003-09-24 Roland McGrath <roland@redhat.com>
1592
1593 * configure.ac, NEWS: Version 4.5.
1594 * strace.spec, debian/changelog: 4.5-1.
1595
1596 * syscall.c (get_scno) [LINUX] [S390 || S390X]: Bail out of
1597 instruction decoding branch if TCB_INSYSCALL is clear.
1598 Reported by <jochen@penguin-breeder.org>.
1599
1600 * linux/ioctlent.h: Swap order of overloaded TC* and SNDCTL_* values.
1601
Roland McGrath7633f1e2003-09-23 22:19:43 +000016022003-09-23 Roland McGrath <roland@redhat.com>
1603
Roland McGrath4f59bab2003-09-24 22:22:49 +00001604 * strace.spec: On ppc64 (maybe others later), create an strace64
1605 package as well containing just /usr/bin/strace64.
1606
Roland McGrath7633f1e2003-09-23 22:19:43 +00001607 * signal.c (sprintsigmask): Print RT_%u for __SIGRTMIN..__SIGRTMAX.
1608 Fixes RH#104365.
1609
Roland McGrath109f3d32003-08-21 10:09:01 +000016102003-08-21 Roland McGrath <roland@redhat.com>
1611
Roland McGrath7633f1e2003-09-23 22:19:43 +00001612 * linux/syscallent.h: Fix mlock argument count. Fixes RH#101499.
Roland McGrath109f3d32003-08-21 10:09:01 +00001613 * linux/x86_64/syscallent.h: Likewise.
1614 * linux/s390/syscallent.h: Likewise.
1615 * linux/s390x/syscallent.h: Likewise.
1616
Roland McGrath5bc53452003-08-21 09:58:08 +000016172003-07-28 Daniel Jacobowitz <drow@mvista.com>
1618
1619 * defs.h (ALIGN64): Define for MIPS.
1620 * io.c (PREAD_OFFSET_ARG): Define.
1621 (sys_pread, sys_pwrite): Use it.
1622 * process.c (struct_user_offsets) [SH]: Check whether REG_XDREG0
1623 is defined.
1624 * linux/sh/syscallent.h (pread, pwrite): Take six arguments.
1625 (truncate64, ftruncate64): Pretty-print.
1626 * linux/mips/syscallent.h (pread, pwrite): Take six arguments.
1627 (truncate64, ftruncate64): Take four arguments.
1628
Roland McGrath4d8130c2003-07-17 09:24:04 +000016292003-07-17 Roland McGrath <roland@redhat.com>
1630
1631 * configure.ac, NEWS: Version 4.4.99.
1632 * strace.spec, debian/changelog: 4.4.99-1.
1633
Roland McGrath25969ce2003-07-17 09:03:22 +000016342003-07-15 Anton Blanchard <anton@samba.org>
1635
1636 * ipc.c: Add SHM_HUGETLB field.
1637 Mask out permission bits in msgget, semget and shmget before
1638 printing resource_flags.
1639 Mask execute permission bits (even though we dont currently
1640 use them).
1641
16422003-07-17 Roland McGrath <roland@redhat.com>
1643
1644 * linux/powerpc/syscallent.h (tgkill): New at 250.
1645
1646 * linux/syscallent.h: truncate64/ftruncate64 need 3 args.
1647 From Ulrich Drepper <drepper@redhat.com>.
1648
1649 * linux/syscallent.h: Handle statfs64, fstatfs64, utimes.
1650 * file.c (printstatfs): Print f_fsid and f_frsize.
1651 [LINUX] (printstatfs64, sys_statfs64, sys_fstatfs64): New functions.
1652 * linux/syscall.h: Add decls.
1653 From Ulrich Drepper <drepper@redhat.com>.
1654
16552003-07-09 Roland McGrath <roland@redhat.com>
1656
1657 * linux/ia64/syscallent.h (tgkill): New at 1235.
1658
Roland McGrath004d88d2003-07-09 09:48:21 +000016592003-07-05 Richard Henderson <rth@twiddle.net>
1660
1661 * process.c (sys_clone): Order arguments for alpha the same as x86_64.
1662 * syscall.c (ERESTART_RESTARTBLOCK): New.
1663 (trace_syscall): Print it.
1664 * linux/alpha/syscallent.h (osf_syscall): Name properly.
1665 (osf_set_program_attributes): Fix typo.
1666 (osf_nfssvc): Likewise.
1667 (osf_sigsendset): Likewise.
1668 (getdents64, gettid, readahead, tkill, setxattr, lsetxattr, fsetxattr,
1669 getxattr, lgetxattr, fgetxattr, listxattr, llistxattr, flistxattr,
1670 removexattr, lremovexattr, fremovexattr, futex, sched_setaffinity,
1671 sched_getaffinity, tuxcall, io_setup, io_destroy, io_getevents,
1672 io_submit, io_cancel, exit_group, lookup_dcookie, epoll_create,
1673 epoll_ctl, epoll_wait, remap_file_pages, set_tid_address,
1674 restart_syscall, fadvise, timer_create, timer_settime, timer_gettime,
1675 timer_getoverrun, timer_delete, clock_settime, clock_gettime,
1676 clock_getres, clock_nanosleep, semtimedop): New.
1677
16782003-07-08 Roland McGrath <roland@redhat.com>
1679
1680 * signal.c (sys_tgkill): New function.
1681 * linux/syscall.h: Declare it.
1682 * linux/syscallent.h: Add tgkill.
1683
Roland McGratha9a86192003-06-27 21:20:14 +000016842003-06-27 Roland McGrath <roland@redhat.com>
1685
1686 * configure.ac: Check for type `struct __old_kernel_stat'.
1687 * file.c (convertoldstat, printoldstat): Define under
1688 [LINUX && HAVE_STRUCT___OLD_KERNEL_STAT] rather than a list of archs.
1689 (sys_oldstat, sys_oldfstat, sys_oldlstat): Likewise.
1690 * linux/dummy.h [! HAVE_STRUCT___OLD_KERNEL_STAT]
1691 (sys_oldstat, sys_oldfstat, sys_oldlstat): #define to printargs.
1692
Roland McGrath9df23f92003-06-26 22:23:32 +000016932003-06-26 Roland McGrath <roland@redhat.com>
1694
Roland McGrath4fe23b52003-06-26 22:41:02 +00001695 * configure.ac: SHMEDIA -> SH64
1696 * defs.h: Likewise.
1697 * mem.c: Likewise.
1698 * process.c: Likewise.
1699 * sock.c: Likewise.
1700 * syscall.c: Likewise.
1701 * util.c: Likewise.
1702 * linux/shmedia/syscallent.h: Moved to ...
1703 * linux/sh64/syscallent.h: ... here.
1704
1705 * config.guess: Update from canonical version, timestamp 2003-06-17.
1706 * config.sub: Likewise.
1707
Roland McGrath8f340e32003-06-26 22:29:38 +00001708 * syscall.c (force_result) [LINUX] [ARM]: Fix variable usage.
1709 From: Joshua Neal <tinara@netpipeline.net>.
1710
Roland McGrathc2aa8ea2003-06-26 22:27:32 +00001711 * process.c [LINUX] (sys_futex): Grok FUTEX_REQUEUE and print 5th arg.
1712 * linux/syscallent.h: sys_futex argument count is now 5, not 4.
1713 * linux/ia64/syscallent.h: Likewise.
1714 * linux/powerpc/syscallent.h: Likewise.
1715 * linux/s390/syscallent.h: Likewise.
1716 * linux/s390x/syscallent.h: Likewise.
1717 * linux/x86_64/syscallent.h: Likewise.
1718 From Jakub Jelinek <jakub@redhat.com>.
1719
Roland McGrath9df23f92003-06-26 22:23:32 +00001720 * syscall.c (get_scno) [S390 || S390X]: Fix old vs new mode detection.
1721 From Michael Holzheu <HOLZHEU@de.ibm.com>.
1722
Roland McGrathee911632003-06-23 23:40:04 +000017232003-06-23 Roland McGrath <roland@redhat.com>
1724
1725 * net.c (sys_socket): Decode protocol for PF_INET6 same as PF_INET.
1726 From Ulrich Drepper <drepper@redhat.com>.
1727
Roland McGrathe84e6272003-06-11 05:38:01 +000017282003-06-10 Roland McGrath <roland@redhat.com>
1729
1730 * configure.ac, NEWS: Version 4.4.98.
1731 * strace.spec, debian/changelog: 4.4.98-1.
1732
Roland McGrath3634c272003-06-10 03:06:05 +000017332003-06-09 Roland McGrath <roland@redhat.com>
1734
Roland McGrath767b4302003-06-10 03:38:03 +00001735 * linux/s390x/syscallent.h: Update many syscalls.
1736 * linux/syscall.h (SYS_socket_subcall): Update [S390X] value.
1737
Roland McGrathc38d46e2003-06-10 03:31:34 +00001738 * linux/s390/syscallent.h: Update many syscalls.
1739 * linux/syscall.h (SYS_socket_subcall): Update [S390] value.
1740
Roland McGratheef1fde2003-06-10 03:07:47 +00001741 * linux/shmedia/syscallent.h: New file.
1742 From Stephen Thomas <stephen.thomas@superh.com>.
1743
Roland McGrath3634c272003-06-10 03:06:05 +00001744 * strace.c (trace): Print a message and newline for a WIFEXITED report
1745 from the process we just printed an unterminated syscall line for.
1746
Roland McGrathcf99f9c2003-06-03 07:18:28 +000017472003-06-03 Roland McGrath <roland@redhat.com>
1748
Roland McGrath2c1d5342003-06-03 23:28:58 +00001749 * util.c (printcall) [LINUX]: Fix typo [IA62] -> [IA64].
1750
1751 Linux/ARM improvements from Russell King <rmk@arm.linux.org.uk>:
1752 * defs.h [LINUX] (TCB_WAITEXECVE): Define for [ARM] too.
1753 * process.c (struct_user_offsets) [LINUX] [ARM]: Add ARM registers.
1754 * signal.c [LINUX] (sys_sigreturn) [ARM]: New case.
1755 * syscall.c (get_scno, syscall_fixup) [LINUX] [ARM]: Case rewritten.
1756 (get_error) [LINUX] [ARM]: Update.
1757 (syscall_enter) [LINUX] [ARM]: New case.
1758 * util.c (printcall) [LINUX] [ARM]: New case.
1759
1760 * debian/control (Standards-Version): Update to 3.5.10.
1761
Roland McGrathcf99f9c2003-06-03 07:18:28 +00001762 * strace.c (main): In PATH search, accept only a regular file with
1763 execute bits set. Fixes Debian bug #137103.
1764
Roland McGratha834fbe2003-06-02 19:37:56 +000017652003-06-02 Roland McGrath <roland@redhat.com>
1766
Roland McGrath454a0242003-06-03 01:35:32 +00001767 * strace.c (main): Set -q when given -o and not -p, and not when not
1768 given -o, to match what the man page always said.
1769 Fixes Debian bug #47113, #153678.
1770
Roland McGratha834fbe2003-06-02 19:37:56 +00001771 * configure.ac, NEWS: Version 4.4.97.
1772 * strace.spec, debian/changelog: 4.4.97-1.
1773
1774 * configure.ac, defs.h, mem.c, process.c, sock.c, syscall.c, util.c:
1775 Merged in SHmedia port from Stephen Thomas <stephen.thomas@superh.com>.
1776
1777 * config.guess: Update from ftp://ftp.gnu.org/pub/gnu/config/,
1778 timestamp 2003-05-22.
1779 * config.sub: Likewise, timestamp 2003-05-24.
1780
Roland McGrath5aae8772003-05-23 00:14:17 +000017812003-05-22 Roland McGrath <roland@redhat.com>
1782
Roland McGrathd0835362003-05-23 02:27:37 +00001783 * defs.h (struct tcb): New member `nzombies'.
1784 * strace.c (alloctcb): Initialize it.
1785 (droptcb): Increment our parent's zombie count.
1786 * process.c (internal_wait): Don't go into TCB_SUSPENDED if the
1787 process has zombies it can reap. On the way out, if we reaped
1788 an untraced process, decrement the zombie count.
1789
Roland McGrath7dfd4ed2003-05-23 01:08:50 +00001790 * process.c (sys_clone): Mask CSIGNAL out of flags and print that
1791 separately using signame.
1792
1793 * process.c (internal_clone) [TCB_CLONE_THREAD]: Use ARG_FLAGS instead
1794 of literal 0 for index. Consult the right flags without clobbering
1795 anything when we reparent the new child to the caller's parent thread.
1796
Roland McGrath031b0d82003-05-23 00:29:11 +00001797 * linux/s390/syscallent.h: Fix sys_clone argument count.
1798 * linux/s390x/syscallent.h: Likewise.
1799 * linux/mips/syscallent.h: Likewise.
1800 * linux/alpha/syscallent.h: Likewise.
1801 * linux/powerpc/syscallent.h: Likewise.
1802 * linux/sh/syscallent.h: Likewise.
1803 * linux/sparc/syscallent.h: Likewise.
1804 * linux/hppa/syscallent.h: Likewise.
1805
1806 * process.c [LINUX] [S390 || S390X] (ARG_CTID, ARG_TLS): Fix swapped
1807 indices. Reported by Jakub Jelinek <jakub@redhat.com>.
1808
1809 * signal.c [LINUX] (SI_SIGIO, SI_TKILL): New macros.
1810 [LINUX || SVR4] (siginfo_codes): Add strings for them.
1811
Roland McGrath5aae8772003-05-23 00:14:17 +00001812 * process.c (print_affinitylist): Fix loop condition.
1813 Reported by Ian Wienand <ianw@gelato.unsw.edu.au>.
1814
Roland McGrath872a4362003-04-10 18:58:33 +000018152003-04-10 Roland McGrath <roland@redhat.com>
1816
1817 * syscall.c (qual_desc): Return zero after parsing number.
1818 From Rob Leslie <rob@mars.org>, fixes Debian bug #188379.
1819
Roland McGrath808a4ba2003-04-08 01:47:02 +000018202003-04-07 Roland McGrath <roland@redhat.com>
1821
1822 * linux/syscallent.h: Handle semtimedop subcall of ipc syscall.
1823 * linux/syscall.h: Likewise.
1824 * ipc.c [LINUX] (sys_semtimedop): New function.
1825 From Ulrich Drepper <drepper@redhat.com>.
1826
1827 * ipc.c (sys_semget): Mask off permission bits for resource_flags.
1828 From Ulrich Drepper <drepper@redhat.com>.
1829
Roland McGrathcf43e902003-04-02 01:10:53 +000018302003-04-01 Philippe De Muyter <phdm@macqel.be>
1831
1832 * sock.c, stream.c: Check #ifdef LINUX, not linux.
1833 * file.c: Always provide sys_*attr, regardless of #ifdef XATTR_CREATE.
1834
Roland McGrath10a56fb2003-03-31 01:21:40 +000018352003-03-30 Roland McGrath <roland@redhat.com>
1836
1837 * configure.ac, NEWS: Version 4.4.96.
1838 * strace.spec, debian/changelog: 4.4.96-1.
1839
Roland McGrath347636f2003-03-31 01:05:16 +000018402003-02-26 Stuart Menefy <stuart.menefy@st.com>
1841
1842 Various fixes for SuperH [SH]:
1843 * mem.c (sys_old_mmap): mmap() parameters passed in registers
1844 * net.c (sys_pipe), syscall.c (getrval2): pipe() results returned
1845 in registers
1846 * process.c (change_syscall): Fixed register which holds system
1847 call number
1848 * util.c (arg0_offset, arg1_offset): provide definition
1849 * Makefile.am: Added new files in linux/sh
1850 * linux/sh/syscallent.h: New file.
1851 * linux/sh/errnoent.h: New file.
1852 * linux/sh/ioctlent.h: New file.
1853 * linux/sh/signalent.h: New file.
1854
1855 * linux/ioctlent.sh: Take an arg for location of header files
1856 * syscallent.sh: Replaced lost $
1857
Roland McGrath5467f262003-03-30 23:52:46 +000018582003-03-30 Roland McGrath <roland@redhat.com>
1859
1860 * time.c [LINUX]: Handle new Linux 2.5 clock/timer syscalls.
1861 * linux/syscall.h, linux/syscallent.h, linux/dummy.h: Likewise.
1862 From Ulrich Drepper <drepper@redhat.com>.
1863
1864 * linux/syscallent.h: Use sys_getrlimit for 191.
1865 Use name "old_getrlimit" for 76.
1866 Reported by Ulrich Drepper <drepper@redhat.com>.
1867
Roland McGrath5755ec52003-03-21 07:33:21 +000018682003-03-18 Roland McGrath <roland@redhat.com>
1869
1870 * process.c [LINUX] (sys_clone): Don't dereference parent_tid argument.
1871
Roland McGrath49bad882003-03-18 07:43:53 +000018722003-03-17 Roland McGrath <roland@redhat.com>
1873
1874 * linux/x86_64/syscallent.h: clone takes 5 args.
1875 * process.c [LINUX] (sys_clone) [X86_64]: Fix argument order.
1876
Roland McGrathf22e0c72003-03-15 21:01:43 +000018772003-03-15 Roland McGrath <roland@redhat.com>
1878
1879 * linux/x86_64/syscallent.h: Add exit_group syscall at 231.
1880
Roland McGrath27cad9a2003-03-14 10:33:06 +000018812003-03-14 Roland McGrath <roland@redhat.com>
1882
1883 * linux/x86_64/syscallent.h: Update and add many 2.5 syscalls.
1884
1885 * linux/ia64/syscallent.h: clone takes 5 arguments.
1886 * process.c [LINUX && IA64] (ARG_*): Update for 2.5 clone calls.
1887
Roland McGrath041900f2003-03-12 08:11:33 +000018882003-03-12 Roland McGrath <roland@redhat.com>
1889
Roland McGrath6fbb4e32003-03-12 09:54:45 +00001890 * linux/ia64/syscallent.h: Fix arg counts for clone and clone2.
1891 Use sys_clone for clone2.
1892 * linux/syscall.h: Don't declare sys_clone2.
1893 * process.c (sys_clone): Rewritten to handle both flavors,
1894 print all extra args depending on flag bits.
1895 (sys_clone2): Function removed.
1896
Roland McGrath041900f2003-03-12 08:11:33 +00001897 * linux/ia64/syscallent.h: Add a bunch of 2.5 syscalls.
1898
Roland McGrathb3f8fd62003-03-05 06:29:11 +000018992003-03-04 Roland McGrath <roland@redhat.com>
1900
1901 * syscall.c (get_scno) [IA64]: Do TCB_WAITEXECVE check only when
1902 TCB_INSYSCALL is clear, like other platforms do.
1903
Roland McGrathd2a6c6b2003-03-05 04:08:07 +000019042003-03-04 Ulrich Drepper <drepper@redhat.com>
1905
1906 * mem.c [LINUX] (sys_remap_file_pages): New function.
1907 * linux/syscall.h: Declare it.
1908 * linux/syscallent.h: Use it.
1909 * linux/powerpc/syscallent.h: Likewise.
1910
1911 * process.c [LINUX] (sys_futex): Omit final if op is not FUTEX_WAIT.
1912
Roland McGratha4187c92003-02-26 20:34:14 +000019132003-02-26 Roland McGrath <roland@redhat.com>
1914
1915 * configure.ac: Fix typo in netinet/in.h check.
1916 Also include <sys/types.h> and <sys/socket.h> before <netinet/in.h>.
1917 Reported by Alex Semenyaka <alexs@snark.rinet.ru>.
1918
Roland McGrath66375f62003-02-24 10:18:11 +000019192003-02-24 Roland McGrath <roland@redhat.com>
1920
Roland McGrath74f905d2003-02-24 10:53:48 +00001921 * configure.ac, NEWS: Version 4.4.95.
1922 * strace.spec, debian/changelog: 4.4.95-1.
1923
Roland McGrath66375f62003-02-24 10:18:11 +00001924 * process.c (sys_getresgid): Fix typos in argument access.
1925
Roland McGrath127f7d22003-02-24 07:13:59 +000019262003-02-23 Roland McGrath <roland@redhat.com>
1927
1928 * process.c (sys_getresuid): Fix typos in argument access.
1929 Reported by Anton Blanchard <anton@samba.org>.
1930
Roland McGrath71522342003-02-20 02:45:34 +000019312003-02-19 Roland McGrath <roland@redhat.com>
1932
Roland McGrath45be9602003-02-20 03:26:58 +00001933 * configure.ac, NEWS: Version 4.4.94.
1934 * strace.spec, debian/changelog: 4.4.94-1.
1935
Roland McGrath44fb0432003-02-20 02:56:50 +00001936 * version.c: Removed.
1937 * Makefile.am (strace_SOURCES): Remove it.
1938 * strace.c: Use PACKAGE_NAME and VERSION macros instead of version var.
1939
Roland McGrath71522342003-02-20 02:45:34 +00001940 FreeBSD rfork support changes from Russ Cox <rsc@plan9.bell-labs.com>:
1941 * syscall.c (internal_syscall): Handle SYS_rfork with internal_fork.
1942 * process.c (internal_fork) [SYS_rfork]: Bail if RFPROC flag not set.
1943
Roland McGrath8d276ff2003-01-24 04:32:36 +000019442003-01-23 Roland McGrath <roland@redhat.com>
1945
Roland McGrathff02c902003-01-30 20:15:35 +00001946 * signal.c: Reorder #ifdefs so HAVE_ASM_SIGCONTEXT_H doesn't matter on
1947 SPARC, which doesn't use the header regardless.
1948
1949 * util.c [LINUX && SPARC]: Do renaming kludges around <asm/reg.h>
1950 like signal.c does.
1951
1952 * linux/sparc/syscall.h: Declare sys_getdents64, sys_llseek.
Roland McGrath6ee7d1f2003-01-24 04:39:50 +00001953
1954 * linux/dummy.h [! SYS_getpmsg] (sys_getpmsg): #define to printargs.
1955 [! SYS_putpmsg] (sys_putpmsg): Likewise.
1956
Roland McGrath8d276ff2003-01-24 04:32:36 +00001957 * process.c: Reorder includes to put sys/reg.h before linux/ptrace.h,
1958 since they can conflict.
1959
Roland McGrath6a39c212003-01-22 02:27:59 +000019602003-01-21 Roland McGrath <roland@redhat.com>
1961
Roland McGrath8d276ff2003-01-24 04:32:36 +00001962 * strace.c (usage): Omit -z, since it has never worked properly.
1963 * NEWS: Likewise.
1964
1965 * strace.c (main): Grok new option `-E var=val' or `-E var' to put
1966 var=val in environ or to remove var, respectively.
1967 (usage): Mention it.
1968 * strace.1, NEWS: Document it.
1969
Roland McGrath6a39c212003-01-22 02:27:59 +00001970 * configure.ac, NEWS: Version 4.4.93.
1971 * strace.spec, debian/changelog: 4.4.93-1.
1972 * strace.spec (Source0): Use strace-VERSION.tar.bz2 now.
1973
Roland McGrath08eee592003-01-20 09:04:42 +000019742003-01-20 Roland McGrath <roland@redhat.com>
1975
Roland McGrathb472e1c2003-01-20 10:23:11 +00001976 * defs.h [LINUX] [S390 || S390X] (TCB_WAITEXECVE): Define it.
1977 * syscall.c (get_scno, syscall_fixup) [LINUX] [S390 || S390X]: Handle
1978 TCB_WAITEXECVE state with special kludges.
1979
Roland McGrath08eee592003-01-20 09:04:42 +00001980 * process.c [LINUX] (sys_clone) [S390 || S390X]: Argument order is
1981 reversed from other architectures.
1982
1983 * process.c (sys_execve) [LINUX]: Make setting TCB_WAITEXECVE flag
1984 conditional on [TCB_WAITEXECVE] instead of list of processors.
1985
1986 * util.c (restore_arg0): Evaluate args in no-op defns.
1987
1988 * util.c [S390 || S390X] (arg0_offset, arg1_offset): Fix definitions
1989 for clone call on S390. From Michael Holzheu <holzheu@de.ibm.com>.
1990
Roland McGrath2b157e72003-01-18 00:19:35 +000019912003-01-17 Anton Blanchard <anton@samba.org>
1992
1993 * util.c [LINUX] (setbpt): Handle SYS_vfork like SYS_fork.
1994
1995 * linux/syscall.h (SYS_socket_subcall): 256 also for POWERPC.
1996
Roland McGrath92999db2003-01-14 09:46:33 +000019972003-01-14 Roland McGrath <roland@redhat.com>
1998
Roland McGrathec4bd132003-01-14 23:41:07 +00001999 * linux/powerpc/errnoent.h: Add missing errnos.
2000 * linux/powerpc/ioctlent.h: Update ioctl values.
2001 From Anton Blanchard <anton@samba.org>.
2002
2003 * io.c [LINUX] (sys_pread, sys_pwrite): Fix last change.
2004 From Anton Blanchard <anton@samba.org>.
2005
2006 * linux/hppa/syscallent.h: Use sys_getdents64, sys_truncate64,
2007 sys_ftruncate64, instead of printargs, for those syscalls.
2008 * linux/mips/syscallent.h: Likewise.
2009 * linux/powerpc/syscallent.h: Likewise.
2010 * linux/s390/syscallent.h: Likewise.
2011 * linux/sparc/syscallent.h: Likewise.
2012
2013 * linux/syscall.h (SYS_socket_subcall): Only 256 for S390, S390X.
2014 All others at the moment use linux/syscallent.h, where it's 300.
2015
2016 * strace.1: Update bug reporting info.
2017
2018 * resource.c [LINUX] (quotacmds): Grok new command encodings.
2019 From Nathan Scott <nathans@debian.org>.
2020
Roland McGrathd7bec502003-01-14 10:10:36 +00002021 * configure.ac, NEWS: Version 4.4.92.
2022 * strace.spec, debian/changelog: 4.4.92-1.
2023
Roland McGrathf775ab32003-01-14 09:59:57 +00002024 * configure.ac: Match powerpc* (includes powerpc64), and don't match
2025 ppc (never comes out of config.sub).
Roland McGrathd7bec502003-01-14 10:10:36 +00002026
Roland McGrathf775ab32003-01-14 09:59:57 +00002027 * process.c (sys_ptrace): Use #lx format for address argument.
2028 [POWERPC]: Use sizeof(unsigned long) in place of 4 for multipliers.
2029 * process.c [POWERPC]: Likewise.
2030 * signal.c (sys_sigreturn) [POWERPC]: Likewise.
2031 * syscall.c (get_scno) [POWERPC]: Likewise.
2032 * util.c [POWERPC]: Likewise.
2033 (printnum): Use long for NUM.
2034 From Anton Blanchard <anton@samba.org>.
2035
Roland McGrath92999db2003-01-14 09:46:33 +00002036 * defs.h (ALIGN64): Fix defn for PPC, same as FreeBSD one.
2037
2038 * util.c [LINUX] (restore_arg0, restore_arg1): New macros, defined
2039 appropriately via set_arg0 or no-ops for each architecture.
2040 (clearbpt): Use those instead of set_arg0 and set_arg1.
2041
2042 * defs.h [_LARGEFILE64_SOURCE] (_LFS64_LARGEFILE): Define it.
2043 * linux/syscallent.h: Use sys_getdents64, sys_truncate64,
2044 sys_ftruncate64, instead of printargs, for those syscalls.
2045
2046 * process.c: Use <linux/ptrace.h> regardless of <sys/reg.h>.
2047 (sys_ptrace): Use printxval.
2048 (ptrace_cmds): Make PTRACE_GETREGS et al conditional on #ifdef PTRACE_*
2049 instead of only #ifdef SUNOS4. Add PTRACE_[GS]ETFPXREGS.
2050
2051 * ipc.c (PRINTCTL): New macro. #ifdef IPC_64, factor out the flag and
2052 print it before using printxval.
2053 (sys_msgctl, sys_semctl, sys_shmctl): Use it.
2054
Roland McGrathda5ad2d2003-01-14 07:53:49 +000020552003-01-13 Roland McGrath <roland@redhat.com>
2056
Roland McGrath4e254592003-01-14 07:58:26 +00002057 * config.guess: Update from ftp://ftp.gnu.org/pub/gnu/config/,
2058 timestamp 2003-01-10.
2059 * config.sub: Likewise, timestamp 2003-01-03.
2060 * install-sh: Update from Automake 1.7.2.
2061
Roland McGrathda5ad2d2003-01-14 07:53:49 +00002062 * linux/powerpc/signalent.h: Add SIGRTMIN.
2063 From Anton Blanchard <anton@samba.org>.
2064
2065 * linux/powerpc/syscallent.h: Add missing system calls.
2066 Decode more system calls, we were just printargs for many things.
2067 Remove some x86-specific system calls.
2068 Remove two syscalls between the socket and ipc syscalls,
2069 it was resulting in all IPC syscalls being off by two.
2070
2071 * ioctl.c (ioctl_decode) [POWERPC]: Decode term ioctls like Alpha.
2072 From Anton Blanchard <anton@samba.org>.
2073
2074 * defs.h [POWERPC] (UESP, EIP, EAX, ORIG_EAX): Remove this cruft.
2075 [LINUX && POWERPC && !__powerpc64__] (ALIGN64): New macro.
2076 * io.c (sys_pread, sys_pwrite): Use ALIGN64.
2077 From Anton Blanchard <anton@samba.org>.
2078
2079 * term.c [LINUX]: Get kernel definition of struct termios.
2080 From Anton Blanchard <anton@samba.org>.
2081
2082 * linux/ioctlent.sh: Look in sound/ directory too.
2083 From Anton Blanchard <anton@samba.org>.
2084
2085 * desc.c (printflock64): Fix ADDR argument type.
2086 From Anton Blanchard <anton@samba.org>.
2087
2088 * strace.c [! HAVE_STRSIGNAL]: Clean up #ifdefs on decls for
2089 sys_siglist and _sys_siglist.
2090 Reported by John Hughes <john@Calva.COM>.
2091
2092 * net.c: HAVE_OPTHDR -> HAVE_STRUCT_OPTHDR
2093 Reported by John Hughes <john@Calva.COM>.
2094
2095 * linux/syscall.h [ARM] (SYS_socket_subcall): Set to 300.
2096
Roland McGrathdcfcaf72003-01-10 10:45:13 +000020972003-01-10 Roland McGrath <roland@redhat.com>
2098
Roland McGrathedcf1b02003-01-10 21:43:33 +00002099 * configure.ac, NEWS: Version 4.4.91.
2100 * strace.spec, debian/changelog: 4.4.91-1
2101
Roland McGrath09b371c2003-01-10 20:51:13 +00002102 * util.c [LINUX && X86_64] (arg0_offset, arg1_offset): Use correct
2103 values for x86-64, conditional on current_personality.
2104
Roland McGrath944d10f2003-01-10 20:14:52 +00002105 * strace.c (droptcb): Clear flags word before calling rebuild_pollv.
2106
Roland McGrath03c5c4d2003-01-10 20:06:01 +00002107 * configure.ac: Check struct T_conn_res for QUEUE_ptr or ACCEPTOR_id.
2108 * stream.c (print_transport_message): Use #ifdefs for those members.
2109
2110 * strace.c (rebuild_pollv): Fix typo: struct poll -> struct pollfd.
2111
Roland McGrath516f3492003-01-10 19:55:42 +00002112 * configure.ac: Fix siginfo_t/sig_atomic_t checks.
2113 Use prerequisite #include <netinet/in.h> for netinet/*.h checks.
2114
2115 * strace.c (pfd2tcb): Fix for new tcbtab type.
2116 (rebuild_pollv): Likewise.
2117 (detach): Put variables used under [LINUX] inside #ifdef.
2118
2119 * process.c (change_syscall) [POWERPC]: Add missing return.
2120 * util.c [POWERPC] (arg0_offset): Set to 4*PT_R3, not 4*PT_ORIG_R3.
2121
Roland McGrathdcfcaf72003-01-10 10:45:13 +00002122 * strace.spec: New file.
2123 * debian/changelog: 4.4.90-1
2124 * debian/rules (binary-arch): Depend on build.
2125 (clean): Don't try to run Makefile.in.
2126 * debian/control (Standards-Version): Now 3.5.8.
2127
2128 * configure.ac: Diddle CFLAGS after AC_PROG_CC, not before.
2129
Roland McGrathea496212003-01-10 07:50:29 +000021302003-01-09 Roland McGrath <roland@redhat.com>
2131
2132 * syscall.c (force_result) [S390 || S390X]: Fix typo.
2133
2134 * debian/control: Update Maintainer: field.
2135
Roland McGrath5694e802003-01-09 06:56:39 +000021362003-01-08 Roland McGrath <roland@redhat.com>
2137
2138 * NEWS: Update for 4.4.90 test release.
2139
2140 Support for new Linux 2.5 thread features.
2141 * defs.h [LINUX]: Define __NR_exit_group if not defined.
2142 (struct tcb): New members nclone_threads, nclone_detached,
2143 and nclone_waiting.
2144 (TCB_CLONE_DETACHED, TCB_CLONE_THREAD, TCB_GROUP_EXITING): New macros.
2145 (waiting_parent): Macro removed.
2146 (pid2tcb): Declare it.
2147 * process.c (internal_clone) [TCB_CLONE_THREAD]: Reparent the new
2148 child to our parent if we are a CLONE_THREAD child ourselves.
2149 Maintain TCB_CLONE_THREAD and TCB_CLONE_DETACHED flags and counts.
2150 (internal_wait) [TCB_CLONE_THREAD]: Factor out detached children when
2151 determining if we have any. If TCB_CLONE_THREAD is set, check
2152 parent's children instead of our own, and bump nclone_waiting count.
2153 (internal_exit) [__NR_exit_group]: Set the TCB_GROUP_EXITING flag if
2154 the syscall was exit_group.
2155 * syscall.c (internal_syscall): Use internal_exit for exit_group.
2156 * strace.c (pid2tcb): No longer static.
2157 (alloctcb) [TCB_CLONE_THREAD]: Initialize new fields.
2158 (droptcb) [TCB_CLONE_THREAD]: Maintain new fields.
2159 If we have thread children, set TCB_EXITING and don't clear the TCB.
2160 (resume) [TCB_CLONE_THREAD]: Decrement parent's nclone_waiting.
2161 (detach) [TCB_CLONE_THREAD]: When calling resume, check all thread
2162 children of our parent that might be waiting for us too.
2163 [TCB_GROUP_EXITING] (handle_group_exit): New function.
2164 (trace) [TCB_GROUP_EXITING]: Use that in place of detach or droptcb.
2165
2166 Revamp -f support for Linux.
2167 * util.c [LINUX] (setbpt, clearbpt): New implementations that tweak
2168 the system call to be clone with CLONE_PTRACE set. Various new static
2169 helper functions.
2170 * process.c (internal_clone): Define also #ifdef SYS_clone2.
2171 Initialize TCPCHILD->parent field.
2172 [CLONE_PTRACE]: Don't do PTRACE_ATTACH here, because it's preattached.
2173 Check in case the new child is in the tcb already.
2174 (internal_fork) [LINUX]: Just call internal_clone.
2175 * strace.c (trace) [LINUX]: Under -f/-F, grok an unknown pid
2176 reporting to wait, put it in the TCB with TCB_ATTACHED|TCB_SUSPENDED.
2177
2178 * linux/x86_64/syscallent1.h (sys_oldlstat): #define as printargs.
2179
2180 * file.c [LINUX]: #undef st_[amc]time in case they are macros.
2181
2182 * Makefile.am (AM_CFLAGS): New variable, define to $(WARNFLAGS).
2183
2184 * Makefile.am (EXTRA_DIST): Remove debian/postinst and debian/prerm.
2185
Wichert Akkerman5a9b0862003-01-08 23:44:36 +000021862003-01-09 Wichert Akkerman <wichert@deephackmode.org>
2187
2188 * debian/postinst, debian/prerm: removed, /usr/doc symlink is no
2189 longer used
2190 * debian/rules: no longer install postinst and prerm
Wichert Akkerman136bbb12003-01-08 23:46:03 +00002191 * debian/control: do not end summary with full stop (lintian)
Wichert Akkerman5a9b0862003-01-08 23:44:36 +00002192
Roland McGratha83c22f2002-12-30 09:13:30 +000021932002-12-30 Roland McGrath <roland@redhat.com>
2194
Roland McGrath2850c7e2002-12-30 10:46:02 +00002195 * Makefile.am (bin_SCRIPTS): New variable, list strace-graph.
2196 (EXTRA_DIST): Add missing files.
2197
2198 * configure.ac: Fix asm/sigcontext.h check to include prerequisite.
2199
2200 * syscall.c (qualify_one): New function.
2201 (qual_options): Replace lookup field with qualify, update initializer.
2202 (qualify): Update caller.
2203 (qual_signal, qual_fault, qual_desc): Rewritten from lookup_*.
2204 (qual_syscall): Rewritten lookup_syscall, match name more than once.
2205 Fixes RH#70579, bites IA64 -efoo when foo exists on IA32.
2206
Roland McGrath692b68a2002-12-30 09:33:32 +00002207 * version.c (version): Make const, bump to 4.4.90.
2208 * strace.c: Update decl.
2209
2210 * Makefile.am [LINUX && X86_64]: Remove cruft.
2211 * linux/x86_64/errnoent1.h: New file.
2212 * linux/x86_64/ioctlent1.h: New file.
2213 * linux/x86_64/signalent1.h: New file.
2214 * linux/x86_64/syscallent1.h: New file.
2215 * linux/x86_64/i386-headers.diff: File removed.
2216 * linux/x86_64/makeheaders.sh: File removed.
2217 * linux/x86_64/Makefile.in: File removed.
2218
Roland McGratha83c22f2002-12-30 09:13:30 +00002219 * linux/syscallent.h [X86_64]: Disable sanity checks, subcall stuff is
2220 already broken for 32-bit personality on x86-64.
2221
Roland McGrath30d47f12002-12-30 00:51:51 +000022222002-12-29 Roland McGrath <roland@redhat.com>
2223
Roland McGratha83c22f2002-12-30 09:13:30 +00002224 * configure.ac, Makefile.am: Punt subdirs, handle everything here.
2225 * linux/Makefile.am: File removed.
2226 * freebsd/Makefile.am: File removed.
2227 * sunos4/Makefile.in: File removed.
2228 * svr4/Makefile.in: File removed.
2229
Roland McGrath30d47f12002-12-30 00:51:51 +00002230 * linux/alpha/Makefile.in: File removed.
2231 * linux/hppa/Makefile.in: File removed.
2232 * linux/ia64/Makefile.in: File removed.
2233 * linux/powerpc/Makefile.in: File removed.
2234 * linux/s390/Makefile.in: File removed.
2235 * linux/s390x/Makefile.in: File removed.
2236
22372002-12-26 Roland McGrath <roland@redhat.com>
2238
2239 * syscallent.sh: Grok three flavors of #define line, uniquify.
2240 * linux/hppa/syscallent.sh: File removed.
2241 * linux/powerpc/syscallent.sh: File removed.
2242
2243 * linux/Makefile.am: New file.
2244 * linux/Makefile.in: File removed.
2245 * freebsd/Makefile.am: New file.
2246 * freebsd/i386/Makefile.am: New file.
2247 * freebsd/i386/Makefile.in: File removed.
2248
22492002-12-22 Roland McGrath <roland@redhat.com>
2250
2251 Update to Autoconf 2.57, and Automakify with version 1.7.
2252 * Makefile.am: New file.
2253 * Makefile.in: File removed.
2254 * configure.in: Moved to ...
2255 * configure.ac: ... here. Update for Autoconf 2.5x and Automake.
2256 * aclocal.m4: Moved to ...
2257 * acinclude.m4: ... here. Update for Autoconf 2.5x.
Roland McGratha83c22f2002-12-30 09:13:30 +00002258 * acconfig.h: File removed.
Roland McGrath30d47f12002-12-30 00:51:51 +00002259 * AUTHORS: New file, makes automake happy.
2260 * autogen.sh: File removed.
2261 * README-CVS: Update to recommend autoreconf instead.
2262 * file.c: HAVE_ST_* -> HAVE_STRUCT_STAT_ST_*.
2263 * net.c: HAVE_SIN6_SCOPE_ID -> HAVE_STRUCT_SOCKADDR_IN6_SIN6_SCOPE_ID,
2264 HAVE_MSG_CONTROL -> HAVE_STRUCT_MSGHDR_MSG_CONTROL.
2265 * strace.c: *_DECLARED -> HAVE_DECL_*
2266 * stream.c: HAVE_* -> HAVE_STRUCT_*
2267
2268 * linux/Makefile.in (ioctldefs.h ioctls.h): Use $(SHELL) instead of
2269 sh, and use $(srcdir) to find the script.
2270 * linux/powerpc/Makefile.in (ioctlent.raw): Find ioctlent.sh in ../.
2271 (ioctlsort.o): Use ../ioctlsort.c, not ../../ioctlsort.c.
2272 * linux/x86_64/Makefile.in (headers): Renamed to all.
2273 * linux/alpha/Makefile.in: Add empty install target.
2274 * linux/x86_64/Makefile.in: Likewise.
2275 * linux/powerpc/Makefile.in: Likewise.
2276 * linux/Makefile.in: Likewise.
2277
Roland McGrath85960152002-12-30 00:26:24 +000022782002-12-26 Roland McGrath <roland@redhat.com>
2279
2280 * defs.h [LINUX && MIPS] (MAX_QUALS): Set to 5000, not 4999.
2281 From Daniel Jacobowitz <drow@false.org>.
2282
Roland McGrathc25a62f2002-12-21 23:25:26 +000022832002-12-21 Roland McGrath <roland@redhat.com>
2284
Roland McGrathdf211902002-12-22 03:34:55 +00002285 * linux/syscallent.h: Add some new 2.5 syscall names.
2286 Now clone takes 5 args.
2287 * process.c [LINUX] (clone_flags): Update with 2.5 flag bits.
2288 [LINUX] (sys_clone): Print new args.
2289 * mem.c (print_ldt_entry): Make global.
2290
2291 * linux/syscall.h [I386 || IA64] (SYS_socket_subcall): Bump to 300 for
2292 safety, since up to 260 are already used in 2.5 kernels.
2293 * linux/syscallent.h: Update the table.
2294 * linux/ia64/syscallent.h: Likewise.
2295
Roland McGrathc25a62f2002-12-21 23:25:26 +00002296 * syscall.c (force_result): New function.
2297 * process.c (internal_wait): Handle ECHILD exit from wait call with
2298 WNOHANG flag set; force the return value to 0 in the inferior when it
2299 has live children we are tracing.
Roland McGrath044c8d22002-12-22 03:36:03 +00002300 * NEWS: Mention the bug fix.
Roland McGrathc25a62f2002-12-21 23:25:26 +00002301
Roland McGrath13f0b432002-12-17 10:48:09 +000023022002-12-17 Roland McGrath <roland@redhat.com>
2303
Roland McGrathf57204d2002-12-18 04:36:59 +00002304 * linux/ia64/syscallent.h: Remove placeholders 275-298 to catch up
2305 with linux/syscallent.h additions.
2306
Roland McGrath29f554f2002-12-18 04:16:31 +00002307 * strace.c (tcbtab): Make this a pointer to pointers, not an array.
2308 (tcbtabsize): New variable.
2309 (main): Initialize them using dynamic allocation.
2310 (alloctcb, main): Use tcbtabsize in place of MAX_PROCS; indirect.
2311 (pid2tcb, cleanup): Likewise.
2312 [USE_PROCFS] (pollv): Make this a pointer, not an array; make static.
2313 (rebuild_pollv): Dynamically allocate the vector.
2314 * defs.h (tcbtab): Update decls.
2315 (MAX_PROCS): Macro removed, no more static limit on this.
2316 * process.c (fork_tcb): New function.
2317 (internal_clone, internal_fork): Use it instead of checking nprocs.
2318
Roland McGrath13f0b432002-12-17 10:48:09 +00002319 * strace.c (detach) [LINUX]: Use __WALL (or a second try with __WCLONE)
2320 in wait after sending SIGSTOP.
2321
Roland McGrath915742f2002-12-17 04:51:02 +000023222002-12-16 Roland McGrath <roland@redhat.com>
2323
Roland McGratha581c512002-12-17 05:10:47 +00002324 * signal.c (sprintsigmask): Increase static buffer size to account for
2325 worst possible case. Reported by Daniel Jacobowitz <drow@false.org>.
2326
Roland McGrath915742f2002-12-17 04:51:02 +00002327 * process.c [LINUX] (wait4_options): Fix __WCLONE value. Add
2328 __WNOTHREAD and __WALL.
2329
2330 * strace.c (trace) [LINUX]: Only check errno if wait4 actually fails,
2331 so we don't repeat a wait and thus drop a status. Fixes RH#62591.
2332
Roland McGrath36d87c22002-12-15 23:59:13 +000023332002-12-15 Roland McGrath <roland@redhat.com>
2334
Roland McGrath32be5972002-12-16 20:41:34 +00002335 * process.c (setarg) [POWERPC]: Support it.
2336
2337 * util.c [POWERPC] (LOOP): Fix value, now 0x48000000 (0: b 0b).
2338 Old value was bogus, not even a proper instruction.
2339 From Guy M. Streeter <streeter@redhat.com>.
2340
2341 * strace.c (main) [! USE_PROCFS]: Always reset SIGCHLD to SIG_DFL.
2342
2343 * configure.in: Don't check for putpmsg.
2344 * stream.c (sys_getpmsg, sys_putpmsg): Make these conditional on
2345 #ifdef SYS_*, rather than on HAVE_PUTPMSG.
2346
Roland McGrath2fe77222002-12-16 09:54:16 +00002347 * aclocal.m4 (AC_STAT64): Include <linux/types.h> before <asm/stat.h>
2348 in test. Test our own #ifdef LINUX rather than predefined `linux'.
2349
Roland McGrath36d87c22002-12-15 23:59:13 +00002350 * linux/powerpc/syscallent.h: Use sys_llseek for _llseek.
2351 * linux/sparc/syscallent.h: Likewise.
2352 * linux/hppa/syscallent.h: Likewise.
2353
2354 * syscall.c (syscall_enter) [LINUX && POWERPC]: Define PT_ORIG_R3 if
2355 not defined, since <asm/ptrace.h> defines it only #ifdef __KERNEL__.
2356 * process.c: Likewise.
2357
2358 * desc.c (sys_osf_select): Add missing return type.
2359
2360 * syscall.c (trace_syscall): Use strerror, not sys_errlist/sys_nerr.
2361
2362 * linux/ia64/syscallent.h: Remove macros for sys_delete_module,
2363 sys_nanosleep, both already in linux/dummy.h.
2364
2365 * syscall.c (get_scno): Move static `currpers' inside #ifdef X86_64.
2366 (trace_syscall): Fix return without value.
2367
2368 * linux/syscallent.h: Update table with names of new syscalls
2369 io_setup, io_destroy, io_getvents, io_submit, io_cancel.
2370 * linux/ia64/syscallent.h: Likewise.
2371 * linux/powerpc/syscallent.h: Likewise.
2372
2373 * signal.c [LINUX && I386]: Provide SA_RESTORER constant if not
2374 defined. If the bit is set, print the sa_restorer field of sigaction.
2375
2376 * mem.c: Add sys_{get,set}_thread_area.
2377 * linux/syscall.h: Declare them.
2378 * linux/syscallent.h: Update the table for these.
2379 * linux/dummy.h (sys_modify_ldt): Define only #ifndef I386.
2380 (sys_get_thread_area, sys_set_thread_area): New macros #ifndef I386.
2381
2382 * configure.in: Check for linux/xattr.h and linux/futex.h headers.
2383 * linux/syscall.h: Add sys_* decls for new syscalls getpmsg, putpmsg,
2384 readahead, sendfile64, setxattr, fsetxattr, getxattr, fgetxattr, int
2385 listxattr, flistxattr, removexattr, fremovexattr, sched_setaffinity,
2386 sched_getaffinity, futex.
2387 * linux/syscallent.h: Update the table.
2388 * io.c: Add sys_sendfile64.
2389 * file.c: Add sys_readahead, sys_*xattr.
2390 * process.c: Add sys_futex, sys_*affinity.
2391
2392 * linux/syscall.h (SYS_socket_subcall): Define to 256 on all machines.
2393 (SYS_ipc_subcall): Always SYS_socket_subcall + SYS_socket_nsubcalls.
2394 * linux/syscallent.h: Update the table for socket and ipc subcalls.
2395
Michal Ludvig882eda82002-11-11 12:50:47 +000023962002-11-09 Heiko Carstens <heiko.carstens@de.ibm.com>
2397
2398 Bugfix for s390/s390x:
2399 * syscall.c: Fixed scno derivation for s390/s390x.
2400
Michal Ludvig17f8fb32002-11-06 13:17:21 +000024012002-11-06 Michal Ludvig <mludvig@suse.cz>
2402
Michal Ludvig39c0e942002-11-06 14:00:12 +00002403 Merged patch from Steven J. Hill <sjhill@realitydiluted.com>
2404 to allow the compilation of a native MIPS strace.
2405
24062002-11-06 Michal Ludvig <mludvig@suse.cz>
2407
Roland McGrath36d87c22002-12-15 23:59:13 +00002408 From Marty Leisner <leisner@rochester.rr.com>,
Michal Ludvig882eda82002-11-11 12:50:47 +00002409 rewritten by mludvig:
Michal Ludvig17f8fb32002-11-06 13:17:21 +00002410 * strace.c (not_failing_only): New.
2411 (usage): Added -z switch description.
2412 (main): Added -z switch parsing to not_failing_only variable.
2413 * syscall.c (trace_syscall): Added not_failing_only handling.
2414
Michal Ludvigeb818f02002-10-09 09:16:22 +000024152002-10-08 Heiko Carstens <heiko.carstens@de.ibm.com>
2416
2417 Missing complete changelog for 2002-10-07 commit:
2418 * Makefile.in: Added linux/s390, linux/s390x to ALL_SUBDIRS.
2419 * acconfig.h: New define for s390x.
2420 * config.sub: Added missing define for s390 and new one for s390x.
2421 * configure.in: Added new define for s390x.
2422 * file.c: Added missing #undef dirent64 and new defines for s390x.
2423 * linux/s390: New directory.
2424 * linux/s390/Makefile.in: New file.
2425 * linux/s390/errnoent.h: New file.
2426 * linux/s390/ioctlent.h: New file.
2427 * linux/s390/signalent.h: New file.
2428 * linux/s390/syscallent.h: New file.
2429 * linux/s390x: New directoy.
2430 * linux/s390x/Makefile.in: New file.
2431 * linux/s390x/errnoent.h: New file.
2432 * linux/s390x/ioctlent.h: New file.
2433 * linux/s390x/signalent.h: New file.
2434 * linux/s390x/syscallent.h: New file.
2435 * linux/syscall.h: Added sys_mincore() prototype and added new
2436 s390x defines.
2437 * process.c: Added s390x defines.
2438 (change_syscall): Changed handling for s390.
2439 (setarg): Added missing s390/s390x code in setarg().
2440 * signal.c: Added s390x define.
2441 (sys_sigreturn): Bugfix in s390/s390x code (wrong number of
2442 arguments to sprintsigmask()).
2443 * stream.c (internal_stream_ioctl): Changed int cast to long cast,
2444 since printstr() expects a long.
2445 * syscall.c (decode_subcall): Changed several variables to be long
2446 instead of int to match 64 bit requirements. Added s390x defines.
2447 (syscall_enter): Changed upeek() call to match s390 and s390x
2448 requirements.
2449 * util.c: Added s390x defines.
2450
Michal Ludvig10a88d02002-10-07 14:31:00 +000024512002-10-07 Michal Ludvig <mludvig@suse.cz>
2452
2453 Merged s390x port by Heiko Carstens <Heiko.Carstens@de.ibm.com>
2454 and bugfixes to s390 by D.J. Barrow.
2455
Michal Ludvig53b320f2002-09-23 13:30:09 +000024562002-09-23 Michal Ludvig <mludvig@suse.cz>
2457
Roland McGrath36d87c22002-12-15 23:59:13 +00002458 Merged x86-64 port by Andi Kleen <ak@suse.de>
Michal Ludvig0e035502002-09-23 15:41:01 +00002459 and Michal Ludvig <mludvig@suse.cz>
2460 * Makefile.in: New target 'headers'. Failure ignored.
2461 * acconfig.h: New defines for x86-64.
2462 * configure.in: Ditto.
2463 * defs.h: Ditto.
2464 * file.c: Ditto.
2465 * signal.c: Ditto.
2466 * process.c: Added support for x86-64.
2467 * util.c: Ditto.
2468 * syscall.c: Ditto + added automatic personality switching.
2469 * linux/syscall.h: Ditto.
2470 * linux/x86_64: New directory.
2471 * linux/x86_64/Makefile.in: New file.
2472 * linux/x86_64/gentab.pl: Ditto.
2473 * linux/x86_64/i386-headers.diff: Ditto.
2474 * linux/x86_64/makeheaders.sh: Ditto.
2475 * linux/x86_64/syscallent.h: Ditto.
2476 * mem.c (print_mmap): Always print arg[4] as int.
2477
24782002-09-23 Michal Ludvig <mludvig@suse.cz>
2479
Michal Ludvig53b320f2002-09-23 13:30:09 +00002480 * configure.in: Fix regular expressions.
Roland McGrath36d87c22002-12-15 23:59:13 +00002481 * linux/syscall.h: Added missing braces in prototype of
Michal Ludvig53b320f2002-09-23 13:30:09 +00002482 sys_getdents64().
2483 * file.c: Use '#ifdef LINUX' instead of '#ifdef linux'.
2484 (struct fileflags): Made extern to inhibit compiation warnings.
2485 (sys_getdents64): Merged LINUX and SVR4 part.
Roland McGrath36d87c22002-12-15 23:59:13 +00002486 * syscall.c (get_scno): Split multiline string into two distinct
Michal Ludvig53b320f2002-09-23 13:30:09 +00002487 strings.
2488
John Hughes2c4e3a82002-05-24 10:19:44 +000024892002-05-24 John Hughes <john@calva.com>
2490
2491 * stream.h, net.h: Avoid possible infinite loop caused by
2492 unsigned arithmetic in preceeding change.
2493
John Hughesb6643082002-05-23 11:02:22 +000024942002-05-23 John Hughes <john@calva.com>
2495
John Hughes38ae88d2002-05-23 11:48:58 +00002496 * acconfig.h: Add HAVE_OPTHDR and HAVE_T_OPTHDR defines.
2497
2498 * aclocal.m4: Add tests for struct opthdr in sys/socket.h and
2499 struct t_opthdr in sys/tiuser.h, define HAVE_OPTHDR and HAVE_T_OPTHDR
2500 if found.
2501
2502 * configure.in: use tests for struct opthdr and struct t_opthdr.
2503
2504 * defs.h: add new function print_sock_optmgmt.
2505
2506 * io.c: add hack that lets ioctl decode functions set auxilliary
2507 string return.
2508
2509 * stream.c: better decoding for timod ioctls.
2510
2511 * net.c: add function print_sock_optmgmt, used by timod ioctl
2512 decoding functions in stream.c.
2513
25142002-05-23 John Hughes <john@calva.com>
2515
John Hughescde80ab2002-05-23 11:19:05 +00002516 * acconfig.h: Make autoheader happy about Linux/SuperH
2517
25182002-05-23 John Hughes <john@calva.com>
2519
John Hughesb6643082002-05-23 11:02:22 +00002520 * strace.c: Get rid of warning if not using POLL_HACK
2521
John Hughes93f7fcc2002-05-22 15:46:49 +000025222002-05-22 John Hughes <john@calva.com>
2523
2524 * net.c: Simplify {get,set}sockopt, decode SO_LINGER, cope with
2525 options that are not just ints, cope with systems that don't
2526 #define SOL_TCP and so on.
2527
John Hughesd870b3c2002-05-21 11:24:18 +000025282002-05-21 John Hughes <john@calva.com>
2529
2530 * strace.c: Fix warning if POLL_HACK is used.
2531
John Hughesc61eb3d2002-05-17 11:37:50 +000025322002-05-17 John Hughes <john@calva.com>
2533
John Hughes5eb78d52002-05-17 14:04:24 +00002534 * svr4/ioctlent.sh: Some defines on UW come with too many spaces.
2535
25362002-05-17 John Hughes <john@calva.com>
2537
John Hughese9224782002-05-17 13:58:24 +00002538 * svr4/ioctlent.sh: Cope with #defines wrapped in #ifdefs.
2539
25402002-05-17 John Hughes <john@calva.com>
2541
John Hughesfd15cb32002-05-17 11:41:35 +00002542 * stream.c: tidy up output a little.
2543
25442002-05-17 John Hughes <john@calva.com>
2545
John Hughesc61eb3d2002-05-17 11:37:50 +00002546 * process.c, svr4/dummy.h, svr4/syscall.h: decode arguments
2547 to procpriv syscall.
2548
Wichert Akkermanccef6372002-05-01 16:39:22 +000025492002-05-01 Wichert Akkerman <wichert@deephackmode.org>
2550
2551 * configure.in, defs.h, process.c, sock.c, syscall.c, util.c: merge
2552 patch from Greg Banks <gbanks@pocketpenguins.com> for Linux/SuperH
2553 support
2554
Wichert Akkermanb0c598f2002-04-01 12:48:06 +000025552002-04-01 Wichert Akkerman <wichert@deephackmode.org>
2556
Wichert Akkermaneb8ebda2002-04-01 17:48:02 +00002557 * strace.c: close tcp->outf in droptcb()
2558
25592002-04-01 Wichert Akkerman <wichert@deephackmode.org>
2560
Wichert Akkermanb0c598f2002-04-01 12:48:06 +00002561 * net.c: decode packet options
2562
Wichert Akkermand321ff92002-03-31 18:45:45 +000025632002-03-31 Wichert Akkerman <wichert@deephackmode.org>
2564
Wichert Akkermaned2c74d2002-03-31 20:16:02 +00002565 * linux/{alpha,hppa,ia64,mips,powerpc,sparc}/syscallent.h: regenerated
2566
25672002-03-31 Wichert Akkerman <wichert@deephackmode.org>
2568
Wichert Akkermand321ff92002-03-31 18:45:45 +00002569 * debian/*: added
Wichert Akkerman7ab47b62002-03-31 19:00:02 +00002570 * linux/syscallent.h: fix typo and add the reserved stream syscalls
2571 * defs.h, file.c, io.c: fix signed/unsigned issues
Wichert Akkerman4527dae2002-03-31 19:03:29 +00002572 * syscall.c: check for negative u_errors
Wichert Akkerman235b0ff2002-03-31 19:08:04 +00002573 * cvsbuild: renamed to autogen.sh
Wichert Akkermand321ff92002-03-31 18:45:45 +00002574
Wichert Akkerman8b8ff7c2001-12-27 22:27:30 +000025752001-12-17 Wichert Akkerman <wakkerma@debian.org>
2576
2577 * net.c: add new TCP socket options
2578
John Hughesfa519572001-10-26 08:05:49 +000025792001-10-26 John Hughes <john@calva.com>
2580
2581 * svr4/ioctlent.sh: Cope with #define lines containing
2582 comments that terminate on subsequent lines. Used to
2583 comment out subsequent ioctls!
2584
Wichert Akkerman9fbd0dd2001-10-26 05:20:37 +000025852001-10-25 Wichert Akkerman <wakkerma@debian.org>
2586
2587 * linux/ioctlent.h: regenerated using current scripts so
2588 term ioctls are included
2589
John Hughes19e49982001-10-19 08:59:12 +000025902001-10-19 John Hughes <john@Calva.COM>
2591
2592 * strace.c(proc_open): On SVR4 only trace the syscalls,
2593 signals and faults we care about.
2594
John Hughes42162082001-10-18 14:48:26 +000025952001-10-18 John Hughes <john@Calva.COM>
2596
John Hughesc0c5ac82001-10-19 07:32:14 +00002597 * acconfig.h: Add HAS_SIGINFO_T.
2598 * aclocal.m4: add check for siginfo_t in signal.h.
2599 * configure.in: use check for siginfo_t.
2600 * defs.h: if HAVE_SIGINFO_T the declare printsiginfo. On SVR4
2601 allow access to siginfo when signal recieved.
2602 * process.c: Remove SVR4 only version of printsiginfo.
2603 * signal.c: merge SVR4 and LINUX versions of printsiginfo.
2604 * strace.c: on SVR4 print siginfo when signal recieved.
2605
26062001-10-18 John Hughes <john@Calva.COM>
2607
John Hughes2d8b2c52001-10-18 14:52:24 +00002608 * system.c(sys_ssisys): handle return values for ssisys
2609
26102001-10-18 John Hughes <john@Calva.COM>
2611
John Hughes42162082001-10-18 14:48:26 +00002612 * signal.c: handle sigwait
2613 * svr4/dummy.c: Move sigwait to done
2614 * svr4/syscall.h: handle sigwait
2615
John Hughes9cecf7f2001-10-16 10:20:22 +000026162001-10-16 John Hughes <john@Calva.COM>
2617
John Hughes0aadba42001-10-16 18:19:52 +00002618 * system.c(sys_ssisys): decode some args for ssisys.
2619
26202001-10-16 John Hughes <john@Calva.COM>
2621
John Hughesaca07f32001-10-16 18:12:27 +00002622 * mem.c: MS_SYNC is zero, so must be first in xlat list.
2623
2624 * svr4/dummy.h: memcntl is much like mctl.
2625
26262001-10-16 John Hughes <john@Calva.COM>
2627
John Hughes9cecf7f2001-10-16 10:20:22 +00002628 * util.c (umovestr): UnixWare (svr4?) returns 0 when trying
2629 to read unmapped page. Make it possible to strace ksh.
2630
Wichert Akkerman7b3346b2001-10-09 23:47:38 +000026312001-10-03 David Mosberger <davidm@hpl.hp.com>
2632
2633 * process.c (internal_clone): Avoid race condition by clearing
2634 breakpoint after attaching to child.
2635
26362001-10-02 David Mosberger <davidm@hpl.hp.com>
2637
2638 * linux/ia64/syscallent.h: Define ia32 syscall numbers (originally
2639 by Don Dugger, with my refinements).
2640
2641 * linux/ia64/ioctlent.h: Regenerate and manually merge conflicting
2642 ioctls (TCGETS & SNDCTL_TMR_TIMEBASE, etc.).
2643
2644 * linux/ia64/Makefile.in (ioctldefs.h ioctls.h): Update for
2645 new ioctlent.h generation scheme.
2646
2647 * linux/syscall.h (sys_clone2): Declare.
2648 [IA64] Define ia32 socket, ipc, and extra syscall numbers.
2649
2650 * linux/ioctlent.sh (regexp): Also handle <asm/ioctls.h> so we
2651 don't miss the tty ioctls (unfortunately, some of the sound timer
2652 ioctls are in conflict with them!).
2653
2654 * util.c (setbpt) [IA64]: Add ia32 support (by Don Dugger).
2655 (clrbpt) [IA64]: Ditto.
2656
2657 * syscall.c (internal_syscall): Handle SYS_clone2, SYS32_wait4,
2658 and SYS32_exit.
2659 (get_scno): Get ia32 syscall number from r1 (orig eax) instead of
2660 r8 (eax). Handle TCB_WAITEXECVE.
2661 (syscall_fixup): Handle ia64.
2662 (syscall_enter): Fix argument fetching for ia64.
2663
2664 * strace.c [IA64 && LINUX]: Include <asm/ptrace_offsets.h>.
2665 (trace) [PT_GETSIGINFO]: Print signal address and pc if possible.
2666
2667 * process.c (tcp): New function.
2668 (change_syscall): Add support for ia64 linux.
2669 (sys_execve): Turn on TCB_WAITEXECVE for ia64 linux.
2670
2671 * desc.c (getlk): Cast l_len to "long long" to avoid warnings when
2672 type is narrower.
2673 * resource.c (sprintrlim64): Ditto.
2674
2675 * defs.h (TCB_WAITEXECVE) [IA64]: Define.
2676 [IA64]: Declare "ia32" variable.
2677
2678 * bjm.c: Do not include <linux/module.h>. It's not safe to include
2679 kernel headers. Declare the necessary constants and structures
2680 directly instead.
2681
26822001-10-01 David Mosberger <davidm@hpl.hp.com>
2683
2684 * signal.c (parse_sigset_t): New function.
2685 (sigishandled): Fix off-by-one bug by using parse_sigset_t() and
2686 avoiding relying on internal layout of sigset_t datastructure.
2687
26882001-04-26 David Mosberger <davidm@hpl.hp.com>
2689
2690 * linux/ia64/syscallent.h: Add getunwind().
2691
26922001-04-11 David Mosberger <davidm@hpl.hp.com>
2693
2694 * syscall.c (syscall_enter): Use PT_RBS_END instead of deprecated
2695 PT_AR_BSP. Pick up arguments starting with out0, which is not
2696 always the same as r32 (e.g., consider inlined syscalls).
2697
John Hughesa2278142001-09-28 16:21:30 +000026982001-09-28 John Hughes <john@Calva.COM>
2699
2700 * process.c: FreeBSD-CURRENT no longer has PT_READ_U, and anyway we
2701 were showing it as PT_WRITE_U! Fix from Maxime Henrion.
2702
John Hughes1fcb1d62001-09-18 15:56:53 +000027032001-09-18 John Hughes <john@Calva.COM>
2704
2705 * net.c: fix display of sockaddr structures, sometimes too many "}",
2706 sometimes too few. Fix suggested by Richard Kettlewell.
2707
Wichert Akkerman67e3e632001-08-19 11:43:17 +000027082001-08-19 Wichert Akkerman <wakkerma@debian.org>
2709
2710 * signal.c: do not include asm/sigcontext.h on IA64 since it gets
2711 the struct from bits/sigcontext.h already which signal.h includes.
2712
Wichert Akkerman7b96b572001-08-03 11:37:07 +000027132001-08-03 Wichert Akkerman <wakkerma@debian.org>
2714
Wichert Akkerman7c707a72001-08-03 21:54:08 +00002715 * linux/ioctlent.sh: change regexps so we catch sound ioctls as well in
2716 Linux
2717 * linux/Makefile.in: fix a few things so the ioctl list is generated
2718 properly
2719 * ioctl.c: remember to shift ioctl masks as well
2720
27212001-08-03 Wichert Akkerman <wakkerma@debian.org>
2722
Wichert Akkermancd6aefc2001-08-03 12:27:54 +00002723 * Linux/**/syscallent.h: synchronize section for fcntl and use sys_fcntl
2724 for sys_fcntl as well
2725
27262001-08-03 Wichert Akkerman <wakkerma@debian.org>
2727
Wichert Akkerman0b1120a2001-08-03 12:20:38 +00002728 * linux/hppa/syscallent.h: updated from Matthew Wilcox
2729
27302001-08-03 Wichert Akkerman <wakkerma@debian.org>
2731
Wichert Akkerman82b162e2001-08-03 11:51:28 +00002732 * process.c: seems Linux/IA64 changed register names on us, switch to
2733 using new names.
2734
27352001-08-03 Wichert Akkerman <wakkerma@debian.org>
2736
Wichert Akkerman54b4f792001-08-03 11:43:35 +00002737 * strace.c: set CLOEXEC flag for outputfile
2738
27392001-08-03 Wichert Akkerman <wakkerma@debian.org>
2740
Wichert Akkerman7b96b572001-08-03 11:37:07 +00002741 * linux/sparc/syscall.h, linux/sparc/syscallent.h: add some LFS calls
2742
Wichert Akkerman4f1bbbe2001-07-23 14:43:07 +000027432001-07-23 Wichert Akkerman <wakkerma@debian.org>
2744
2745 * configure.in: Support cross-compiling between architectures
2746
Wichert Akkerman0dc4fc92001-07-13 22:09:05 +000027472001-07-13 Wichert Akkerman <wakkerma@debian.org>
2748
2749 * configure.in: add S390 to architecture list
2750
John Hughes1d08dcf2001-07-10 13:48:44 +000027512001-07-10 John Hughes <john@Calva.COM>
2752
2753 * TODO, defs.h, io.h, net.c, strace.c, syscall.c, util.c: Merge fixes
2754 from Richard Kettlewell <rkettlewell@zeus.com> which add I/O dumping
2755 of args to readv/writev. Also gets rid of redundant printiovec
2756 routine from net.c (duplicate of tprint_iov in util.c).
2757
Wichert Akkerman688c7fc2001-07-02 16:53:25 +000027582001-07-02 Wichert Akkerman <wakkerma@debian.org>
2759
2760 * config.{guess,sub}: updated
2761
John Hughesaa09c6b2001-05-15 14:53:43 +000027622001-05-15 John Hughes <john@Calva.COM>
2763
John Hughes70c5e7a2001-05-15 15:09:14 +00002764 * signal.c: pass a pointer to sigmask to printsigmask from printcontext,
2765 it was just passing the sigmask (ucp->uc_sigmask).
2766
27672001-05-15 John Hughes <john@Calva.COM>
2768
John Hughesaa09c6b2001-05-15 14:53:43 +00002769 * util.c: Don't run off the end of valid memory in umovestr when
2770 USE_PROCFS. Important for FREEBSD systems (which seem to have an
2771 unmapped page just after the args/env area).
2772
John Hughes4e36a812001-04-18 15:11:51 +000027732001-04-18 John Hughes <john@Calva.COM>
2774
2775 * configure.in: test for sys/nscsys.h, the non-stop clusters includes.
2776 * process.c: handle rfork{1,all} and rexecve calls on non-stop clusters.
2777 * syscall.c: treat rfork{1,all} and fork{1,all} as fork like calls.
2778 Treat rexecve as an exec.
2779 * system.c: decode arguments to ssisys call on nsc systems.
2780 * svr4/dummy.h, svr4/syscall.h: now we handle rfork{1,all}, ssisys and
2781 rexecve calls.
2782
Wichert Akkerman35254402001-04-12 09:11:04 +000027832001-04-12 Wichert Akkerman <wakkerma@debian.org>
2784
2785 * process.c: fix cast for powerpc code
2786 * linux/powerpc/syscallent.h: update syscall list
2787 * README: fix address for the strace mailinglist
2788 * signal.c: switch to using /proc/<pid>/status on Linux so we can get
2789 the realtime signals as well
2790
Wichert Akkerman4ca31092001-04-10 10:28:43 +000027912001-04-10 Wichert Akkerman <wakkerma@debian.org>
2792
2793 * Merge patches from Maciej W. Rozycki:
2794 + util.c: add code to print PC for MIPS
2795 + linux/mips/syscallent.h: updated
2796 + system.c: formating fixes for sys_sysmips
Wichert Akkerman42080d82001-04-10 10:32:26 +00002797 + configure.in: test for yet more headers
2798 + stream.c: use configure-headertests instead of relying on OS hints
Wichert Akkerman4ca31092001-04-10 10:28:43 +00002799
Wichert Akkermand6b92492001-04-07 21:37:12 +000028002001-04-07 Wichert Akkerman <wakkerma@debian.org>
2801
Wichert Akkermane70bbe52001-04-07 21:47:30 +00002802 * NEWS: start 4.3.1 items
2803 * version.c: updated to say 4.3.1 (was still 4.2, oops!)
2804
28052001-04-07 Wichert Akkerman <wakkerma@debian.org>
2806
Wichert Akkermand6b92492001-04-07 21:37:12 +00002807 * configure.in: test for asm/sysmips.h and linux/utsname.h
2808 * linux/syscall.h: fix a typo for sys_sysmips
2809 * system.c: include asm/sysmips.h and linux/utsname.h if they exist,
2810 fix typo
2811
Wichert Akkerman4f043ec2001-03-31 16:25:58 +000028122001-03-31 Wichert Akkerman <wakkerma@debian.org>
2813
2814 * linux/mips/ioctlent.h: updated using new Linux ioctl setup
2815
28162001-03-31 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkerman8aada672001-03-31 16:20:33 +00002817
2818 * linux/ia64/ioctlent.h: regenerated
2819
Wichert Akkerman29f0d052001-03-31 16:14:55 +000028202001-03-31 Wichert Akkerman <wakkerma@debian.org>
2821
Wichert Akkermancf715672001-03-31 16:16:57 +00002822 * linux/{alpha,ia64,powerpc}/ioctlent.sh: removed, all archs use the
2823 general Linux ioctlent.sh
2824
28252001-03-31 Wichert Akkerman <wakkerma@debian.org>
2826
Wichert Akkerman29f0d052001-03-31 16:14:55 +00002827 * linux/ioctlent.sh: add dir variable for location of kernel headers
2828
Wichert Akkermanbbf59e92001-03-29 17:43:19 +000028292001-03-29 Wichert Akkerman <wakkerma@debian.org>
2830
Wichert Akkerman00cd74c2001-03-30 16:20:27 +00002831 * linux/ia64/ioctlent.h: updated using new Linux ioctl setup
2832
28332001-03-29 Wichert Akkerman <wakkerma@debian.org>
2834
Wichert Akkerman10767782001-03-29 19:04:25 +00002835 * linux/powerpc/ioctlent.h: updated using new Linux ioctl setup
2836
28372001-03-29 Wichert Akkerman <wakkerma@debian.org>
2838
Wichert Akkermand7fb2062001-03-29 18:16:07 +00002839 * linux/hppa/ioctlent.h: updated using new Linux ioctl setup
2840
28412001-03-29 Wichert Akkerman <wakkerma@debian.org>
2842
Wichert Akkermanbbf59e92001-03-29 17:43:19 +00002843 * linux/alpha/ioctlent.h: updated using new Linux ioctl setup
2844
Wichert Akkerman2f1d87e2001-03-28 14:40:14 +000028452001-03-28 Wichert Akkerman <wakkerma@debian.org>
2846
Wichert Akkerman00a82ee2001-03-28 20:29:17 +00002847 * configure.in: use sparc* so we can compile on sparc64 as well
2848 * process.c, syscall.c: work around double define of fpq, fq and fpu
2849 structs on Linux/sparc, and use regs instead of pt_regs
2850 * don't use asm/sigcontext.h on Linux/sparc
2851
28522001-03-28 Wichert Akkerman <wakkerma@debian.org>
2853
Wichert Akkermanfe8f65d2001-03-28 15:10:49 +00002854 * linux/sparc/ioctlent.h: updated using new Linux ioctl setup
2855
28562001-03-28 Wichert Akkerman <wakkerma@debian.org>
2857
Wichert Akkerman2f1d87e2001-03-28 14:40:14 +00002858 * strace.c: use __WALL as wait4 flag if it exists so we can properly
2859 trace threaded programs
2860
John Hughes8e075fb2001-03-27 13:57:48 +000028612001-03-27 John Hughes <john@Calva.COM>
2862
John Hughesb8a85a42001-03-28 08:05:27 +00002863 * aclocal.m4: add check for endianness of long long.
2864 * acconfig.h: add #define for LITTLE_ENDIAN_LONG_LONG.
2865 * configure.in: check for endianness of long long.
Wichert Akkerman8ab1a3c2001-03-28 14:27:23 +00002866 * defs.h: change LONG_LONG macro to work with either endianness of
John Hughesb8a85a42001-03-28 08:05:27 +00002867 long long.
2868
28692001-03-27 John Hughes <john@Calva.COM>
2870
John Hughes61563572001-03-27 16:47:36 +00002871 * net.c: Make compilable by SCO UDK compiler (doesn't like empty
2872 initialisation list for array).
2873
28742001-03-27 John Hughes <john@Calva.COM>
2875
John Hughes8e075fb2001-03-27 13:57:48 +00002876 * svr4/syscallent.h: ntp_adjtime entry was duplicated on Solaris
2877 systems - bad merge of Harald Boehme's patch by me.
2878
Wichert Akkerman072ea8a2001-03-27 14:46:05 +000028792001-03-27 Wichert Akkerman <wakkerma@debian.org>
2880
2881 * lots of files: add Linux/hppa support
2882
Wichert Akkerman407be9a2001-03-19 10:56:49 +000028832001-03-19 Wichert Akkerman <wakkerma@debian.org>
2884
2885 * linux/mips/syscallent.h: we can't have -1 nargs, change to 0
Wichert Akkermane3bf56a2001-03-19 11:05:17 +00002886 * linux/syscallent.h: not that syscalls 220 and 221 are used now
Wichert Akkerman6f2bbe22001-03-19 11:00:29 +00002887 * config.guess: updated
Wichert Akkerman407be9a2001-03-19 10:56:49 +00002888
Wichert Akkermana9667852001-03-17 17:26:34 +000028892001-03-17 Wichert Akkerman <wakkerma@debian.org>
2890
2891 * linux/ioclsort.c: new file
2892 * linux/ioctlent.sh: complete rewrite to use a more sane approach to get
2893 the ioctl list that doesn't involve attempting to #include all kernel
2894 headers
2895 * linux/.cvsignore: added ioctdefs.h and ioctls.h which are generated
2896 by the new ioctlent.sh
2897 * ioctl.c: only look at the number and type bits for linux, since
2898 ioctlent.sh no longer supplies the others
2899
John Hughes70623be2001-03-08 13:59:00 +000029002001-03-08 John Hughes <john@Calva.COM>
2901
John Hughescf1de752001-03-08 17:27:20 +00002902 * freebsd/syscalls.pl: On FreeBSD we must cope with COMPATibility syscalls,
2903 pretend they have names ending with "?" so that -e trace=stat (for
2904 example) will work.
2905 * freebsd/i386/syscallent.h: add ? to compatability syscalls.
2906 * freebsd/i386/syscall.h: consistency.
2907
29082001-03-08 John Hughes <john@Calva.COM>
2909
John Hughesc0fc3fd2001-03-08 16:10:40 +00002910 * acconfig.h: add new ST_xxx defines.
2911 * aclocal.m4: macros to check for more fields in struct stat.
2912 * configure.in: use new macros to check for fields in struct stat.
2913 * file.c: use new defines to replace #ifdef FREEBSD by #if HAVE_ST_xxx.
2914
29152001-03-08 John Hughes <john@Calva.COM>
2916
John Hughes0c79e012001-03-08 14:40:06 +00002917 * defs.h: rename wimpy get64 as powerful new LONG_LONG
2918 * file.c: use LONG_LONG
2919 * io.c: use LONG_LONG
2920 * mem.c use LONG_LONG
2921
29222001-03-08 John Hughes <john@Calva.COM>
2923
John Hughes70623be2001-03-08 13:59:00 +00002924 * acconfig.h: new #defines HAVE_LONG_LONG_OFF_T and HAVE_LONG_LONG_RLIM_T.
2925 * aclocal.m4: routines to check for long long off_t and rlim_t.
2926 * configure.in: check for long long off_t and rlim_t.
2927 * desc.c: if HAVE_LONG_LONG_OFF_T treat flock as flock64
2928 * file.c: if HAVE_LONG_LONG_OFF_T treat stat,lstat,fstat and lseek as 64
2929 bit versions.
2930 * io.c: if HAVE_LONG_LONG_OFF_T use 64 bit versions of pread and pwrite.
2931 * mem.c: if HAVE_LONG_LONG_OFF_T use 64 bit version of mmap
2932 * resource.c: if HAVE_LONG_LONG_OFF_T use 64 bit versions of getrlimit
2933 and setrlimit.
2934 * freebsd/syscalls.print: don't explicitly use 64 bit versions of calls,
2935 now done automaticaly for us.
2936 * freebsd/i386/syscall.h: ditto.
2937 * freebsd/i386/syscallent.h ditto.
2938
John Hughes5a826b82001-03-07 13:21:24 +000029392001-03-07 John Hughes <john@Calva.COM>
2940
John Hughesb8c9f772001-03-07 16:53:07 +00002941 * desc.c: On FreeBSD flock structure uses 64 bit offsets.
2942 * file.c: On FreeBSD use stat64 and pals instead of stat.
2943 * freebsd/syscalls.print: use stat64, lstat64 and fstat64.
2944 * freebsd/i386/syscall.h: ditto.
2945 * freebsd/i386/syscallent.h: ditto.
2946
29472001-03-07 John Hughes <john@Calva.COM>
2948
John Hughese2f6d872001-03-07 16:03:20 +00002949 * file.c: merge missing part of Harald Böhme's solaris patches,
2950 was only declaring sys_{stat64,lstat64,fstat64} on linux!
2951
29522001-03-07 John Hughes <john@Calva.COM>
2953
John Hughes9dec06c2001-03-07 14:47:19 +00002954 * svr4/dummy.h: fix multiple define warning on non LFS64 systems.
2955 * svr4/syscallent.h: pread/pwrite are TF calls.
2956
29572001-03-07 John Hughes <john@Calva.COM>
2958
John Hughes5a826b82001-03-07 13:21:24 +00002959 * defs.h: add ALIGN64 macro to cope with FreeBSD's strange insistence
2960 on alignment for off_t (64 bit) arguments. Also simplify get64 so
2961 we don't need to know endianness of long long.
2962 * file.c: FreeBSD now uses 64 bit versions of lseek, truncate,
2963 ftruncate, allows reduction in numvber of horrid #if's
2964 * io.c: FreeBSD now uses 64 bit versions of pread, pwrite.
2965 * mem.c: FreeBSD now uses 64 bit version of mmap.
2966 * freebsd/syscalls.print: use 64 bit versions of various syscalls.
2967 * freebsd/i386/syscall.h: use 64 bit versions of various syscalls.
2968 * freebsd/i386/syscallent.h: use 64 bit versions of various syscalls.
2969
John Hughes95ea9c02001-03-07 10:11:02 +000029702001-03-06 John Hughes <john@Calva.COM>
2971
John Hughes7737c8a2001-03-07 10:41:58 +00002972 * file.c: Implement truncate64 and ftruncate64
2973 * svr4/dummy.h: add dummies for truncate64 and ftruncate64 for non
2974 LFS64 systems.
2975 * svr4/syscall.h: add declarations for truncate64 and ftruncate64.
2976
29772001-03-06 John Hughes <john@Calva.COM>
2978
John Hughesc5249902001-03-07 10:39:06 +00002979 * freebsd/syscalls.pl: fix for FreeBSD 4.1 (new optional field in
2980 syscall master file).
2981
29822001-03-06 John Hughes <john@Calva.COM>
2983
John Hughesbb557232001-03-07 10:37:38 +00002984 * syscall.c: fix for FreeBSD 4.1 (SYS_semconfig has disappeared). Also
2985 zap incorrect syscall subarg range check.
2986
29872001-03-06 John Hughes <john@Calva.COM>
2988
John Hughescb8b69d2001-03-07 10:34:27 +00002989 * configure.in, defs.h, desc.c, file.c, io.c, mem.c, net.c, resource.c,
2990 signal.c, syscall.c, svr4/dummy.h, svr4/syscall.h, svr4/syscallent.h:
2991 merge Harald Böhme's solaris patches (_LFS64_LARGEFILE and kernel aio
2992 mostly).
2993
29942001-03-06 John Hughes <john@Calva.COM>
2995
John Hughesbc4935a2001-03-07 10:28:50 +00002996 * dummy.h: add unimplemented UW sycalls
2997 * syscall.h: we can do settimeofday for UW, whopee!
2998 * syscallent.h: fix unimplemented UW syscalls
2999
30002001-03-06 John Hughes <john@Calva.COM>
3001
John Hughesc8f2e8a2001-03-07 10:26:17 +00003002 * aclocal.m4: look for pr_syscall in pr_lwp if we HAVE_MP_PROCFS
3003 * defs.h: add PR_SYSCALL to allow use of pr_lwp.pr_syscall if it exists.
3004 * syscall.c: use PR_SYSCALL instead of pr_syscall, fix up UnixWare code
3005 so it doesn't try to use pr_sysarg.
3006
30072001-03-06 John Hughes <john@Calva.COM>
3008
John Hughes091fe832001-03-07 10:15:39 +00003009 * aclocal.m4: on systems other than linux look for stat64 in sys/stat.h
3010 * file.c: handle xstat version _STAT64_VER, aka stat64.
3011
30122001-03-06 John Hughes <john@Calva.COM>
3013
John Hughes95ea9c02001-03-07 10:11:02 +00003014 * net.c: make sure SOL_ options are defined before using.
3015 * signal.c: declare sigset variable, only used on linux, inside #ifdef.
3016
Wichert Akkermanfa306182001-02-21 16:42:26 +000030172001-02-21 Wichert Akkerman <wakkerma@debian.org>
3018
3019 * net.c: fix format for printing Unix domain sockets
3020
Wichert Akkerman0cbfb322001-02-19 13:35:53 +000030212001-02-19 Wichert Akkerman <wakkerma@debian.org>
3022
3023 * linux/mips/syscallent.h: use new sys_sysmips
3024 * system.c: add sys_sysmips decoding
3025
Wichert Akkerman8c7122c2001-02-16 19:59:55 +000030262001-02-16 Wichert Akkerman <wakkerma@debian.org>
3027
Wichert Akkermanf1850652001-02-16 20:29:03 +00003028 * CREDITS: add Arkadiusz Miskiewicz <misiek@pld.org.pl> who
3029 submitted the IP6 scope ID updates
3030 * acconfig.h: add HAVE_SIN6_SCOPE_ID and HAVE_SIN6_SCOPE_ID_LINUX
3031 * aclocal.m4: add AC_SIN6_SCOPE_ID to check if sin6_scope_id is
3032 available
3033 * configure.in: check for if_indextoname function and sin6_scope_id
3034 * net.c: teach printsock about IP6 scope ids
3035
30362001-02-16 Wichert Akkerman <wakkerma@debian.org>
3037
Wichert Akkerman8c7122c2001-02-16 19:59:55 +00003038 * configure.in: test for netinet/tcp.h and netinet/udp.h existance
3039 * net.c: include netinet/tcp.h and netinet/udp.h if they exist
Wichert Akkermanedf2dcc2001-02-16 20:14:40 +00003040 * Makefile.in: use @mandir@ and @bindir@
Wichert Akkerman8c7122c2001-02-16 19:59:55 +00003041
Wichert Akkermanefdecac2000-11-26 03:59:21 +000030422000-11-26 Wichert Akkerman <wakkerma@debian.org>
3043
3044 * net.c: fix formating error in sys_setsockopt
3045 * net.c: add list of socketlayers and use that for [gs]etsockopt
3046
Roland McGrath36d87c22002-12-15 23:59:13 +000030472000-10-12 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkermand856b992000-10-13 12:47:12 +00003048
3049 * time.c: use sys/timex.h so things compile with 2.2 kernels
3050 * stream.c: test if MSG_* constants are #defined
3051
Wichert Akkerman9b0c31d2000-09-03 21:56:29 +000030522000-09-03 Wichert Akkerman <wakkerma@debian.org>
3053
Wichert Akkermanefdecac2000-11-26 03:59:21 +00003054 * process.c: perform bpt trick for clone as well so we can get the
3055 pid of the child before it starts doing something
3056 * file.c: rename dirent64 struct to kernel_dirent64 so things compile
3057 again with newer libcs
3058 * test/clone.c: improve our testcase a bit
3059 * Merge another patch from Gäel Roualland with FreeBSD updates
Wichert Akkerman9b0c31d2000-09-03 21:56:29 +00003060
Wichert Akkermanbf79f2e2000-09-01 21:03:06 +000030612000-09-01 Wichert Akkerman <wakkerma@debian.org>
3062
Wichert Akkermanefdecac2000-11-26 03:59:21 +00003063 * lots of files: merge patch from Gaël Roualland to add
3064 support for FreeBSD.
Wichert Akkermanbf79f2e2000-09-01 21:03:06 +00003065
Wichert Akkerman16a03d22000-08-10 02:14:04 +000030662000-08-09 Wichert Akkerman <wakkerma@debian.org>
3067
Wichert Akkermand077c452000-08-10 18:16:15 +00003068 * file.c: update to reflect that st_ino suddenly became a long long
3069 in the in Linux 2.4.0-test6
3070
30712000-08-09 Wichert Akkerman <wakkerma@debian.org>
3072
Wichert Akkerman16a03d22000-08-10 02:14:04 +00003073 * test/clone.c: minor fixup
3074 * Another bunch of patches from John Hughes merged:
3075 * signal.c:
3076 + SVR4 printcontext(): sigset_t != sigset_t*
3077 + getcontext returns a value, so print on exit of syscall
3078 + add UC_FP to ucontext_flags for OS writers that can't spell
3079 + sys_signal(): special case SIG_{ERR,DFL,IGN}
3080 + decode_subcall(): only do subcall range checking when needed
3081 * bunch of UnixWare updates
3082 * aclocal.m4, acconfig.h, configure.in: add test for long long type
3083
Wichert Akkerman7987cdf2000-07-05 16:05:39 +000030842000-07-04 Wichert Akkerman <wakkerma@debian.org>
3085
3086 * net.c: add SOL_PACKET and SOL_RAW socket options, update
3087 SOL_IP and SOL_TCP
3088
Wichert Akkermanbd4125c2000-06-27 17:28:06 +000030892000-06-23 Wichert Akkerman <wakkerma@debian.org>
3090
3091 * strace.c: close outf before we exec a child process
3092
Wichert Akkerman43a74822000-06-27 17:33:32 +000030932000-06-09 Ulrich Drepper <drepper@redhat.com>
3094
3095 * configure.in: Don't link against libnsl on Linux, it's unnecessary.
3096 * defs.h (struct tcb): Make auxstr member const.
3097 * file.c (fsmagic): And many more magic numbers.
3098 * util.c: Don't include <linux/ptrace.h> for glibc 2.1 and up.
3099
Wichert Akkerman5ae21ea2000-05-01 01:53:59 +000031002000-04-26 Wichert Akkerman <wakkerma@debian.org>
3101
3102 * defs.h: balance #if/#endif again
3103 * system.c: fix return statements in sys_capget()
3104 * Merge updates from Topi Miettinen <Topi.Miettinen@nic.fi>:
3105 + file.c: add F_[SG]ETSIG to fcntl flags
3106 + strace.c: don't setre[gu]id if not needed
3107 + system.c: handle sys_reboot for Linux
3108 + term.c: add baudrate constants up to B4000000
3109 + linux/**/syscallent.h: note that munlockall has no arguments
3110
31112000-04-25 David Mosberger <davidm@hpl.hp.com>
3112
3113 * CREDITS: fix email address
3114 * process.c: handle PR_[GS]ET_UNALIGN and PR_[GS]ET_KEEPCAPS
3115 * signal.c: honour offset of sigconfig in sigframe structure for
3116 Linux/ia64
3117 * linux/ia64/syscallent.h: Add perfmonctl, pivotroot, mincore, and
3118 madvise syscalls.
3119 * syscall.c (syscall_enter): With Kevin's latest ptrace patches,
3120 AR_BSP points to the _end_ of the active register frame, so we need
3121 to adjust bsp by moving it back by the size of the active frame
3122 before using it.
3123
31242000-04-24 Wichert Akkerman <wakkerma@debian.org>
3125
3126 * process.c: add sparc support to change_syscall
3127
Wichert Akkerman10dfa562000-04-22 18:26:56 +000031282000-04-22 Wichert Akkerman <wakkerma@debian.org>
3129
3130 * linux/mips/syscallent.h: fix some typos
3131
Wichert Akkerman481e45b2000-04-17 07:42:31 +000031322000-04-14 Wichert Akkerman <wakkerma@debian.org>
3133
3134 * linux/mips/syscallent.h: added names for SVR4, SYSV, BSD4.3 and POSIX
3135 syscalls
3136
Wichert Akkermanfd89ced2000-04-13 17:06:09 +000031372000-04-13 Wichert Akkerman <wakkerma@debian.org>
3138
3139 * defs.h: Linux/MIPS uses syscalls up to >4k, so set MAX_QUALS to
3140 4999
3141
Wichert Akkermanc7926982000-04-10 22:22:31 +000031422000-04-09 Wichert Akkerman <wakkerma@debian.org>
3143
3144 * README-linux: updated to note that strace might not compile
3145 with development kernels
3146 * bjm.c: sys_query_module: check if malloc succeeds
3147 * system.c: sys_cap[gs]et(): check if malloc succeeds, only malloc once
3148 * linux/syscallent.h: updated for 2.3.99pre3
3149 * linux/alpha/syscallent.h: updated for 2.3.99pre3, add all osf syscalls
3150 even though Linux doesn't implement them
3151 * syscall.c: add global variables for MIPS registers as well
3152 * syscall.c: move global variables to before get_scno since that uses them
3153 * util.c: oops, misspelled defined
3154 * process.c: fix ptrace calls in change_syscall
3155 * mem.c: decode sys_madvise
3156 * Merge patch from Topi Miettinen <Topi.Miettinen@nic.fi>
3157 + add support for quotactl, fdatasync, mlock, mlockall, munlockall & acct
3158 + small fix for RLIMIT_* and RUSAGE_BOTH
3159 + enhace support for capget and capset
3160
Wichert Akkermanfaf72222000-02-19 23:59:03 +000031612000-02-19 Wichert Akkerman <wakkerma@debian.org>
3162
3163 * test/vfork.c: new file to test vfork traces
3164 * test/.cvsignore: new file
3165 * defs.h: Up maximum number of traced processed to 64
Roland McGrath36d87c22002-12-15 23:59:13 +00003166 * strace.c: Disable some debugging code from davidm
Wichert Akkermanfaf72222000-02-19 23:59:03 +00003167 * implement setarg for more architectures
3168 * implement change_syscall
3169
Wichert Akkerman2ee6e452000-02-18 15:36:12 +000031701999-12-27 Morten Welinder <terra@diku.dk>
3171
3172 * syscall.c (lookup_signal, lookup_desc): isdigit requires an
3173 _unsigned_ char parameter.
3174
Wichert Akkerman12f75d12000-02-14 16:23:40 +000031752000-02-14 Wichert Akkerman <wakkerma@debian.org>
3176
3177 * S390 updates
3178
Wichert Akkerman8b1b40c2000-02-03 21:58:30 +000031792000-02-03 Wichert Akkerman <wakkerma@debian.org>
3180
Wichert Akkerman5ae21ea2000-05-01 01:53:59 +00003181 * Merge Linux/ia64 patches
Wichert Akkerman8b1b40c2000-02-03 21:58:30 +00003182
Pavel Machek4dc3b142000-02-01 17:58:41 +000031832000-01-02 Pavel Machek <pavel@ucw.cz>
3184
3185 * probe if sys/poll.h exists in configure + minor cleanups
3186
3187 * syscall.c: split trace_syscall into few pieces to make code readable
3188
Wichert Akkerman30160182000-01-21 20:31:34 +000031892000-01-21 Wichert Akkerman <wakkerma@debian.org>
3190
3191 * Release version 4.2 to get the current updates out and so
3192 we can concentrate in finishing the clone support.
3193
Wichert Akkerman3ed6dc22000-01-11 14:41:09 +000031942000-01-11 Wichert Akkerman <wakkerma@debian.org>
3195
3196 * Add 1900 to tm_year in sprinttime
3197
Wichert Akkerman0396bdc1999-12-24 23:11:57 +000031981999-12-24 Wichert Akkerman <wakkerma@debian.org>
3199
3200 * file.c: protect printstat64 with STAT64 instead of linux so we can
3201 compile on Linux architectures that don't have it
Wichert Akkerman9148a3b1999-12-24 23:13:55 +00003202 * util.c: fix LOOP for ARM
Wichert Akkerman0396bdc1999-12-24 23:11:57 +00003203
3204Fri Dec 24 18:05:00 EST 1999
3205
Ulrich Drepperc921cb21999-12-24 08:03:35 +000032061999-12-23 Ulrich Drepper <drepper@cygnus.com>
3207
3208 * file.c: Use ugly libc_stat trick also for stat64.
3209 Implement sys_stat64, sys_fstat64, sys_lstat64, and printstat64.
3210 * process.c (internal_clone): Fix a few typos and add definitions to make
3211 it at least compile.
3212 * linux/syscall.h: Declare sys_stat64, sys_lstat64, and sys_fstat64.
3213 * linux/syscallent.h: Define table entries for sys_stat64, sys_lstat64,
3214 and sys_fstat64.
3215 * aclocal.m4: Define AC_STAT64.
3216 * acconfig.h: Define HAVE_STAT64.
3217 * configure.in: Add AC_STAT64.
3218
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003219Thu Dec 23 15:01:37 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3220
3221 * Merge patch from ftp://oss.software.ibm.com/linux390/ to add
3222 support for Linux on the IBM S/390 architecture
Wichert Akkerman7a0b6491999-12-23 15:08:17 +00003223 * process.c: add internal_clone(), currently only shows the options
3224 * syscall.c: use internal_clone to handle SYS_clone
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003225
3226Mon Dec 20 00:27:50 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3227
3228 * Rewrite mmap-handling to support mmap2 on Linux
3229
Wichert Akkermane5be0de1999-12-14 10:46:18 +00003230Tue Dec 14 11:35:16 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3231
3232 * Note that Linux can handle sys_semop() as well
3233
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003234Tue Nov 30 11:05:26 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3235
3236 * Include linux/in6.h for glibc2.0 and older
3237
Wichert Akkermanea78f0f1999-11-29 15:34:02 +00003238Mon Nov 29 16:33:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3239
3240 * Merge patches from John Hughes to make configure support UnixWare
3241
Wichert Akkerman9123ac81999-11-27 21:58:20 +00003242Sat Nov 27 21:38:17 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3243
3244 * Enhance sys_query_module
3245
Wichert Akkermane4aafd41999-11-26 09:54:08 +00003246Fri Nov 26 10:51:55 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3247
3248 * Patches from John Hughes:
3249 + cosmectic fix in sys_getpmsg
Wichert Akkerman48214be1999-11-26 09:55:42 +00003250 + allow net.c to compile on systems without AF_INET6
3251 + Only use long_to_sigset on Linux systems
Wichert Akkerman46956571999-11-26 10:12:59 +00003252 + UnixWare treats sigmask_t and sigmask_t* as the same thing
Wichert Akkerman9dbf1541999-11-26 13:11:29 +00003253 + Add pollhack
Wichert Akkerman3377df71999-11-26 13:14:41 +00003254 + Parse mount arguments for UnixWare
3255 + ACL fixes for UnixWare
Wichert Akkermane4aafd41999-11-26 09:54:08 +00003256
Wichert Akkerman2a64b431999-11-26 00:29:05 +00003257Fri Nov 26 01:28:09 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3258
3259 * Release 4.1 to get all the changes made out there
3260
Wichert Akkermanf5eeabb1999-11-18 17:09:47 +00003261Thu Nov 18 18:04:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3262
3263 * Merge stracefork from Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>
3264 + Socket calls parsed better
3265 + bunch of alpha OSF syscalls added
3266 + Fix alpha 32/64 bit issues
3267
Wichert Akkerman2f473da1999-11-01 19:53:31 +00003268Mon Nov 1 20:52:08 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3269
3270 * Move Linux kernelmodule-functions from system.c to bjm.c and
3271 remove duplicate for sys_create_module
Wichert Akkerman60456d71999-11-01 19:59:33 +00003272 * Linux MIPS updates:
3273 + Play with #ifdef's in net.c to get IPv6 right
3274 + Use printargs for vm86-syscall
Wichert Akkerman2f473da1999-11-01 19:53:31 +00003275
Wichert Akkermanf90da011999-10-31 21:15:38 +00003276Sun Oct 31 22:03:00 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3277
3278 * Merge Linux mips patch from Florian Lohoff <flo@rfc822.org>
3279
Wichert Akkerman50524821999-10-10 22:40:07 +00003280Mon Oct 11 00:36:25 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3281
3282 * Merge patch from Keith Owens <kaos@ocs.com.au> to sys_query_module
3283 and sys_delete_module correctly
3284
Wichert Akkerman15dea971999-10-06 13:06:34 +00003285Wed Oct 6 02:00:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3286
3287 * Update cvsbuild to give a better error if autoconf isn't installed
3288 * Add test for linux/ptrace.h to configure
3289 * Since we define GNU_SOURCE in the Makefile we don't need to define
3290 USE_GNU in file.c anymore
3291
3292Fri Sep 10 04:35:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3293
3294 * #define USE_GNU before including file.c so we get some extra O_* flags
3295
3296Tue Aug 31 16:27:21 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3297
3298 * Add missing } in IPv6 output
3299
Wichert Akkerman7b27ba01999-08-30 23:26:53 +00003300Tue Aug 31 01:23:08 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3301
3302 * Update copyright for strace-graph to BSD to be consistent with
3303 the rest of strace
3304
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00003305Mon Aug 30 00:53:57 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3306
3307 * Merge patch from Daniel Jacobowitz: KERN_JAVA_* and KERN_SECURELVL aren't
3308 defined for all kernelversions
Wichert Akkerman7b27ba01999-08-30 23:26:53 +00003309 * Add strace-graph, written by Richard Braakman <dark@xs4all.nl>
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00003310
3311Thu Aug 19 13:10:15 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
3312
3313 * linux/sparc/syscall.h: Declare create_module/init_module.
3314 * configure.in: Allow compilation in a different directory
3315 than the source one.
3316 * signal.c: Use asm/reg.h and struct regs instead of pt_regs
3317 so that we don't depend on asm/ptrace.h which clashes with
3318 glibc sys/ptrace.h.
3319 * util.c: Likewise.
3320 * syscall.c: Likewise.
3321
Wichert Akkerman5a777661999-08-04 16:03:49 +00003322Wed Aug 4 18:01:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3323
3324 * Syscall 94 on Linux alpha is sys_poll
3325
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00003326Sun Jul 25 14:38:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3327
3328 * Merge in UnixWare patches from John Hughes <john@Calva.COM>
3329
Wichert Akkerman527a8051999-07-15 21:11:37 +00003330Thu Jul 15 23:00:32 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3331
3332 * Merge patch from Maciej W. Rozycki <macro@ds2.pg.gda.pl>:
3333 + Correctly implement fix sys_createmodule (Linux)
3334 + Add limited handlig of sys_initmodule (Linux)
3335
Wichert Akkerman36915a11999-07-13 15:45:02 +00003336Tue Jul 13 17:07:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3337
3338 * Add configure-test for sys/reg.h and use that
3339 * Use sys/reg.h instead of asm/ptrace.h
3340
Wichert Akkermanca446991999-07-09 23:48:58 +00003341Sat Jul 10 01:46:10 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3342
3343 * Remove hack in signal.c for arm architecture
3344 * Add hack so we compile correctly on powerpc
3345
Wichert Akkerman5b4d1281999-07-09 00:32:54 +00003346Fri Jul 9 02:28:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3347
3348 * Add a corrected patch from Daniel Jacobowitz
3349
Wichert Akkermana6013701999-07-08 14:00:58 +00003350Thu Jul 8 16:00:04 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3351
3352 * Merge patch from Daniel Jacobowitz to allow us to use the kernel types
3353 for the stat structure
3354
3355Thu Jun 24 15:54:18 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkerman2b483ba1999-06-24 13:55:29 +00003356
3357 * Fix test for sys/reg include
3358
Wichert Akkermana6013701999-07-08 14:00:58 +00003359Tue Jun 22 17:26:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkermane6f876c1999-06-22 15:28:30 +00003360
3361 * Fixed some Linux/powerpc sillyness, thanks to Daniel Jacobowitz
3362 * Fixed some SunOS compile problems earlier that I forgot to include
3363 here
3364
Wichert Akkerman789ed351999-06-14 10:45:01 +00003365Mon Jun 14 12:44:25 CEST 1999
3366
3367 * Avoid leakint fd into child when forking, patch from
3368 John Hughes <john@Calva.COM>
3369
Wichert Akkerman8829a551999-06-11 13:18:40 +00003370Fri Jun 11 14:54:47 CEST 1999
3371
3372 * Applied IRIX64 patch from Thomas E. Dickey <dickey@clark.net>
3373 * Applied Solaris and manpage updates from Guy Harris <guy@netapp.com>
3374
Wichert Akkermancc4b8f41999-06-09 12:50:10 +00003375Wed Jun 9 14:48:49 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3376
3377 * Brought syscall list for alpha up to date
3378
Wichert Akkermandacfb6e1999-06-03 14:21:07 +00003379Wed Jun 2 18:30:12 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
3380
3381 * system.c: sys_umount2 syscall support.
3382 * linux/sparc/errnoent.h: Update sparc-linux errnos.
3383 * linux/sparc/syscall.h: Update used sparc-linux syscalls.
3384 * linux/sparc/syscallent.h: Match 2.2.9 system calls.
3385 * file.c: sparc-linux asm/stat.h uses dev_t etc. types,
3386 so it needs strace's own copy of the stat structure.
3387 * util.c: Make it compile on sparc-linux.
3388 * strace.c: Fix strace -f and -ff operation on sparc-linux.
3389 * signal.c: rt_sigaction has different arguments on sparc*-linux
3390 and alpha-linux.
3391 * syscall.c: Recognize sparc64-linux binaries.
3392
Ulrich Drepper0d2d3231999-05-29 04:11:48 +00003393Fri May 28 21:09:00 PST Ulrich Drepper <drepper@cygnus.com>
3394
3395 * configure.in: Fix typo (CFLAG -> CFLAGS).
3396
Ulrich Drepper8783c011999-05-29 04:13:58 +00003397 * syscall.c: Don't include linux/ptrace.h explicitly for glibc.
3398
Wichert Akkerman22fe9d21999-05-27 12:00:57 +00003399Thu May 27 13:59:27 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3400
3401 * Add some sysctl support, patch from Ulrich Drepper
3402
Wichert Akkerman9524bb91999-05-25 23:11:18 +00003403Wed May 26 01:04:34 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3404
3405 * Use kernel dirent structure for Linux
3406
Wichert Akkerman2e2553a1999-05-09 00:29:58 +00003407Sun May 9 02:18:30 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3408
3409 * Merge in patches from Andreas Schwab <schwab@issan.cs.uni-dortmund.de>
3410 + some layout and other minor fixes
3411 + add some m68k-specific things to linux/syscallent.h. Note that m68k
3412 is similar enough to i386 to not need it's own subdirectory
3413 + add support for sendfile and mremap syscalls for Linux
3414 * Merge in patches from Sascha Schumann <sascha@schumann.2ns.de>
3415 + ioctls.h vs sys/ioctl.h on Alpha platform
3416 + pointer was casted to an int in stream.c
3417 + strsignal() needs -D_GNU_SOURCE in CFLAGS
3418 + several other casts changed
3419 + correct ARM/POWERPC architecture defines in acconfig.h
3420 * Merge in patches from Morten Welinder <terra@diku.dk>
3421 + add some autoconf-tests for includefiles
3422 + handle solaris version of sigcontext struct (actually I hacked this
3423 up again, but the idea is his :)
3424
Wichert Akkerman7a1f0e91999-04-18 20:23:57 +00003425Sun Apr 18 22:32:42 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3426
3427 * Update syscalls for linux alpha, patch from Bart Warmerdam
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003428 <bartw@debian.org>
Wichert Akkermand4d8e921999-04-18 23:30:29 +00003429 * Update sparc code so it actually compiles
Wichert Akkerman7a1f0e91999-04-18 20:23:57 +00003430
Wichert Akkerman328c5e71999-04-16 00:21:26 +00003431Fri Apr 16 02:18:05 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3432
Wichert Akkerman25d0c4f1999-04-18 19:35:42 +00003433 * Add support for old_*stat functions for Linux. Please note you need
3434 to use reasonably recent kernel headers to compile strace now.
Wichert Akkerman328c5e71999-04-16 00:21:26 +00003435 * Change references to LINUX into linux in file.c
3436 * Fix include for LDT in mem.c
Wichert Akkerman1786d811999-04-15 20:34:14 +00003437
3438Thu Apr 15 22:28:15 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
3439
3440 * Change in strace maintainership, jrs passed the torch to me.
3441 * Use autoconf 2.13
3442 * Incorporate all changes already made in the Debian strace package:
3443 + compiles with more Linux kernels
3444 + added support for more Linux architectures
3445 + add support for a lot of extra syscalls
3446 + fix some problems with hanging children
3447 + check stray syscall after execv
3448 + decode capget and capset arguments
3449 + add more constants to net.c
3450 + detect ROSE networking
3451 + add more protocol families to domains
3452 + add IPIP protocol
3453 + added MSG_PROXY and MSG_CTRUNC to msg_flags
3454 + added SO_BSDCOMPAT and SO_REUSEPORT to sockoptions
3455 + added IP, IPX and TCP-options
3456 + added IP, IPX and TCP support to get-/setsockopt()
3457 + added IPX support
3458 + updated handling of signals
3459
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003460Sun Oct 27 22:28:00 1996 J. Richard Sladkey <jrs@world.std.com>
3461
3462 * util.c (umovestr) [LINUX]: Handle Linux like SunOS4
3463 instead of SVR4. That is, read a few bytes at a time
3464 to avoid overrunning the end of the stack.
3465
3466Fri May 31 01:48:49 1996 J. Richard Sladkey <jrs@world.std.com>
3467
3468 * version.c: Version 3.1 is released.
3469
3470Thu May 23 01:04:43 1996 J. Richard Sladkey <jrs@world.std.com>
3471
3472 * aclocal.m4 (AC_DECL_SYS_ERRLIST): Try looking in stdio.h
3473 as well since that's where glibc declares it. Go figure.
3474 * signal.c (sys_sigreturn) [ALPHA]: Use sigcontext
3475 instead of sigcontext_struct since glibc v5+ apparently
3476 plays games with the native OS namespace.
3477 From David Mosberger-Tang <davidm@AZStarNet.com>.
3478
3479Mon May 20 23:17:14 1996 J. Richard Sladkey <jrs@world.std.com>
3480
3481 * version.c: Version 3.0.14 is released.
3482
3483 * aclocal.m4 (AC_STRUCT_MSG_CONTROL): New macro.
3484 * configure.in: Add call to AC_STRUCT_MSG_CONTROL.
3485 * net.c (printmsghdr): Handle BSD 4.3 and 4.4 msghdr members
3486 differently.
3487 Reported by Henrik Storner <storner@osiris.ping.dk>.
3488
3489 * configure.in: (AC_CHECK_{HEADERS,FUNCS}): Add checks for
3490 sys/filio.h and sys/stream.h and remove check for poll.
3491 * desc.c (decode_select, sys_select, sys_oldselect) [LINUX]:
3492 Handle old and new styles of argument passing for select on Linux.
3493 * ioctl.c, stream.c: Conditionalize stream code on presence of
3494 sys/stream.h instead of poll because glibc implements poll but
3495 not the rest of the stream interface.
3496 * signal.c [LINUX]: Standardize on the name sigcontext_struct.
3497 (sys_sigprocmask) [ALPHA]: Handle OSF flavor which is more like
3498 sigsetmask.
3499 * term.c (term_ioctl): Use _VMIN, if present, for TC{G,S}ETA*.
3500 * util.c (umoven, umovestr): Move data in long-sized chunks
3501 at a time, instead of hard coding it to be 4.
3502 From David Mosberger-Tang <davidm@AZStarNet.com>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003503
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003504Mon May 20 01:19:36 1996 J. Richard Sladkey <jrs@world.std.com>
3505
3506 * version.c: Version 3.0.13 is released.
3507
3508 * configure.in (AC_CHECK_HEADERS): Add check for asm/sigcontext.h.
3509 * signal.c [HAVE_ASM_SIGCONTEXT_H]: Conditionally include
3510 asm/sigcontext.h to define sigcontext_struct and don't define it
3511 locally if the header is present.
3512
3513 * syscall.c (nerrnos{0,2}): Correct size computation.
3514
3515 * Makefile.in: Remove dependencies and rules relating to files
3516 normally found in the os directory. Because of the new scheme we
3517 don't know precisely where they come from. Sigh.
3518 * signalent.sh: Make it work for sunos4, linux, and svr4.
3519 * {sunos4,linux{,/alpha},svr4}/Makefile.in: Make rules correspond
3520 to traditional make syntax. Add signalent.h to files which can
3521 unconditionally be rebuilt. Prevent signalent.h from being
3522 unconditionally being rebuilt since it's customized.
3523 * {sunos4,linux{,/alpha},svr4}/{ioctlent,errnoent,signalent}.h:
3524 Use versions built by {ioctlent,errnoent,signaltent}.sh.
3525 * sunos4/ioctlent.sh: Work around sprintf troubles with SunOS
3526 4.1.4 and gcc 2.7.2.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003527
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003528Sun May 19 17:14:09 1996 J. Richard Sladkey <jrs@world.std.com>
3529
3530 * configure.in, Makefile.in: Add OSARCH concept to finish
3531 build support for the alpha.
3532 * Makefile.in, linux/Makefile.in: Rewrite clean, distclean,
3533 and maintainer-clean rules.
3534 * defs.h, ioctlsort.c: Make ioctl code member unsigned.
3535 * ioctl.c, ioctlsort.c (compare): Perform explicit checking
3536 for less, greater, and equal since subtraction on two's
3537 complement numbers isn't an order relation (it isn't transitive)!
3538 * linux/Makefile.in: Add rules for the signalent.h file.
3539 * linux/alpha/Makefile.in: New file.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003540
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003541Sun May 19 01:12:28 1996 J. Richard Sladkey <jrs@world.std.com>
3542
3543 * version.c: Version 3.0.12 is released.
3544
3545 * linux{,alpha}/ioctlent.sh: Tweak for recent kernels.
3546 From Michael E Chastain <mec@duracef.shout.net>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003547
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003548 * defs.h (SUPPORTED_PERSONALITES, DEFAULT_PERSONALITY): New.
3549 * syscall.c (set_personality): New.
3550 * strace.c (main): Call set_personality.
3551 * defs.h, syscall.c, ioctl.c, signal.c: Make sysent, errnoent,
3552 ioctlent, and signalent indirect pointers and redirect them
3553 based on personality.
3554 * {sunos4,svr4,linux{,/alpha}}/signalent.h: New files.
3555 Suggested by Tom Dyas <tdyas@eden.rutgers.edu>.
3556
3557 * util.c (upeek): Handle case where ptrace returns a long
3558 and sizeof(long) != sizeof(int).
3559 From Richard Henderson <richard@twiddle.tamu.edu>
3560
3561Fri May 17 21:03:36 1996 J. Richard Sladkey <jrs@world.std.com>
3562
3563 * version.c: Version 3.0.11 is released.
3564
3565 * many files: Fix more printf warnings for other platforms.
3566
3567 * ipc.c (sys_msgrcv) [LINUX]: Conditionalize definition of ipc_wrapper.
3568
3569 * linux/dummy.h: Handle missing library support for {send,recv}msg.
3570 Reported by Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
3571
3572 * linux/syscall.h (sys_utimes): Fix a typo in the declaration.
3573 From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00003574
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00003575Fri May 17 00:50:06 1996 J. Richard Sladkey <jrs@world.std.com>
3576
3577 * version.c: Version 3.0.10 is released.
3578
3579 * Makfile.in: Add os/arch to includes so that a given arch
3580 (like alpha) can override the native arch (like i386).
3581 * configure.in: Check for sendmsg.
3582
3583 * net.c: Make sendmsg and recvmsg dependent on an autoconf
3584 test. Reported by Michael E Chastain <mec@duracef.shout.net>.
3585
3586 * acconfig.h, configure.in: Detect the alpha.
3587 * ioctl.c: Handle the alpha.
3588 * defs.h: Make some members long for the alpha. Define
3589 some register nicknames. Add support for WAITEXECVE.
3590 * file.c [ALPHA]: Support the alpha for statfs. Add
3591 osf_statfs and osf_fstatfs for the alpha. Make damn sure
3592 major and minor results are suitable for passing to printf.
3593 * signal.c, syscall.c: Support the alpha.
3594 * process.c: Add alpha user offsets.
3595 * most files: Use %l? for printf arguments since
3596 most are now longs for the alpha.
3597 * linux/alpha/{errnoent.h,ioctlent.{h,sh},syscallent.h}:
3598 New for the alpha.
3599 From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
3600
3601Wed May 15 00:29:37 1996 J. Richard Sladkey <jrs@world.std.com>
3602
3603 * version.c: Version 3.0.9 is released.
3604
3605 * config.in, config.sub, install-sh: Upgrade to autoconf 2.10.
3606
3607 * linux/dummy.h, linux/syscallent.h, linux/syscall.h: Add recent
3608 Linux kernel version system calls.
3609
3610Wed Mar 13 01:03:38 1996 J. Richard Sladkey <jrs@world.std.com>
3611
3612 * ipc.c [SUNOS4]: Add SunOS support for decoding IPC calls.
3613 * syscall.c [SUNOS4]: Compile decode_subcall on SunOS and
3614 decode IPC calls using it.
3615 * sunos4/dummy.h: Alias sys_semop to printargs.
3616 * sunos4/syscall.h: Add new pseudo syscalls for IPC.
3617 * sunos4/syscallent.h: Include new subcalls for IPC.
3618 From Matthias Pfaller <leo@dachau.marco.de>.
3619
3620Tue Feb 13 22:08:25 1996 J. Richard Sladkey <jrs@world.std.com>
3621
3622 * version.c: Version 3.0.8 is released.
3623
3624 * time.c [LINUX]: Explicitly include linux/version.h.
3625
3626 * strace.c (main): Don't let them even *try* to
3627 get strace to attach to itself since some systems
3628 don't handle this case very gracefully.
3629 Reported by David S. Miller <davem@caip.rutgers.edu>.
3630
3631 * Makefile.in (distclean): Fix it for subdirectories.
3632
3633 * sunos4/syscallent.h, svr4/syscallent.h: Fill in the new
3634 sys_flags member for each defined system call.
3635
3636Fri Dec 8 01:17:28 1995 Rick Sladkey <jrs@world.std.com>
3637
3638 * defs.h (TRACE_*): New flags to describe what class
3639 of system call each system call is.
3640 (sysent): Add sys_flags member.
3641 * syscall.c (sysent): Define (and later undef) abbreviations
3642 for the system call class flags.
3643 (lookup_class): New function to translate strings to
3644 system call class flags.
3645 (qualify): Handle new system call class mechanism.
3646 * linux/syscallent.h: Fill in the new sys_flags member
3647 for each defined system call.
3648
3649 * defs.h (print_sock): Remove redundant and non-K&R C
3650 compatible prototype. From Juergen Weigert
3651 <jnweiger@immd4.informatik.uni-erlangen.de>.
3652
3653Thu Dec 7 01:17:40 1995 Rick Sladkey <jrs@world.std.com>
3654
3655 * linux/ioctlent.sh: Tweak to improve ioctl accuracy.
3656 From Michael E Chastain <mec@duracef.shout.net>.
3657
3658 * system.c (includes) [LINUX]: Add linux/nfs.h for recent
3659 kernels. From Michael E Chastain <mec@duracef.shout.net>.
3660
3661Wed Dec 6 21:52:28 1995 Rick Sladkey <jrs@world.std.com>
3662
3663 * file.c (sprintfstype): Enclose string result in double
3664 quotes.
3665
3666 * time.c (sys_adjtimex) [LINUX]: Conditionalize
3667 constantly evolving timex structure.
3668 From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
3669
3670 * defs.h, syscall.c, strace.c: Rename syscall to
3671 trace_syscall and change prototype and all callers
3672 because of broken Linux shared libraries.
3673 From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
3674
3675 * Makefile.in (clean): Check for a file with test -f not
3676 test -d. From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
3677
3678Tue Sep 26 02:32:31 1995 Rick Sladkey <jrs@world.std.com>
3679
3680 * version.c: Version 3.0.7 is released.
3681
3682 * util.c (string_quote): Fix thinko which caused core
3683 dumps for strings with quotes in them.
3684 Reported by Marty Leisner <leisner@sdsp.mc.xerox.com>.
3685
3686 * linux/Makefile.in (errnoent.h rule): Grab all errno.h
3687 files from /usr/include, not just the linux one.
3688 From Michael E Chastain <mec@duracef.shout.net>.
3689
3690 * linux/errnoent.sh: Total rewrite to handle more ioctls with
3691 fewer false positives on more kernel flavors.
3692 From Michael E Chastain <mec@duracef.shout.net>.
3693
3694Mon Sep 4 01:29:22 1995 Rick Sladkey <jrs@world.std.com>
3695
3696 * version.c: Version 3.0.6 is released.
3697
3698 * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
3699 sys_msync.
3700 * mem.c (mctl_funcs, mctl_lockas, sys_mctl): Conditionalize
3701 on MC_SYNC instead of HAVE_MCTL.
3702 (mctl_sync): Conditionalize on MS_ASYNC instead of HAVE_MCTL.
3703 (sys_msync): New function.
3704
3705Sat Sep 2 12:06:04 1995 Rick Sladkey <jrs@world.std.com>
3706
3707 * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
3708 sys_flock and sys_getdents.
3709 * desc.c (flockcmds, sys_flock): Conditionalize on LOCK_SH
3710 not SUNOS4.
3711 * file.c (sys_getdents): Define unconditionally and handle
3712 LINUX case.
3713 * strace.c (main): Disallow username option unless both real
3714 and effective uids are root.
3715
3716Wed Aug 30 01:29:58 1995 Rick Sladkey <jrs@world.std.com>
3717
3718 * strace.c (main): Ensure that run_uid and run_gid are
3719 always set to something meaningful.
3720 (main, newoutf) [!SVR4]: Swap real and effective uids while
3721 opening any output files.
3722 (main) [!SVR4]: Treat effective uid of root as a request
3723 to handle suid binaries correctly using the real uid of
3724 the invoking user.
3725
3726Sat Aug 19 00:06:08 1995 Rick Sladkey <jrs@world.std.com>
3727
3728 * Makefile.in: Add `|| true' to clean rule because
3729 although GNU make 3.74 uses `sh -c' to invoke commands
3730 every other make in the world uses `sh -ec'.
3731
3732 * syscall.c (syscall) [SVR4, MIPS]: The fifth and subsequent
3733 arguments appear to be stored on the stack, not in the
3734 registers following A3 (empirical result).
3735
3736 * defs.h: Add prototype for printsock.
3737 * svr4/dummy.h: Remove generic handling of sys_mount.
3738 * system.c [SVR4, MIPS]: Include several system headers to cleanly
3739 get access to SGI mount information.
3740 (mount_flags, nfs_flags) [SVR4, MIPS]: New objects.
3741 (sys_mount) [SVR4, MIPS]: New function.
3742 (sys_mount) [SVR4, !MIPS]: New function.
3743
3744Tue Jul 4 00:30:34 1995 Rick Sladkey <jrs@world.std.com>
3745
3746 * version.c: Version 3.0.5 is released.
3747
3748 * desc.c, resource.c, strace.c, syscall.c, time.c: Cast tv_sec and
3749 tv_usec members to long when using printf.
3750
3751 * ipc.c: Omit define of __KERNEL__.
3752 ({MSG,SEM,SHM}_{STAT,INFO}): Explicitly define those things we
3753 want which __KERNEL__ used to provide.
3754 (sys_msgrcv): Change reference to ipc_kludge structure to
3755 look-alike ipc_wrapper to avoid dependence on __KERNEL__.
3756
3757 mem.c (mmap_flags) [MAP_{GROWSDOWN,DENYWRITE,EXECUTABLE}]: Add
3758 Linux specific options.
3759
3760 syscall.c: Use SYS_ERRLIST_DECLARED instead of guessing.
3761 [E{RESTART{SYS,NO{INTR,HAND}},NOIOCTLCMD}]: Explicitly define
3762 instead of depending of __KERNEL__.
3763
3764 term.c: Cast c_{i,o,c,l}flag to long when using printf.
3765
3766Tue Jun 6 00:27:48 1995 Rick Sladkey <jrs@world.std.com>
3767
3768 * aclocal.m4 (AC_DECL_SYS_ERRLIST, AC_DECL__SYS_SIGLIST): New.
3769 * configure.in: Call AC_DECL_SYS_ERRLIST, AC_DECL_SYS_SIGLIST,
3770 and AC_DECL__SYS_SIGLIST.
3771 * acconfig.h (SYS_ERRLIST_DECLARED): New.
3772 * strace.c (strerror): Use SYS_ERRLIST_DECLARED.
3773 (strsignal): Use SYS_SIGLIST_DECLARED.
3774
3775 net.c (sys_socket): Omit inadvertent surplus comma when
3776 protocol family isn't PF_INET.
3777
3778 util.c (dumpstr): Fix incorrect printing of one too many
3779 characters when the length is not an even multiple of 16 bytes.
3780 Reported by Juergen Weigert
3781 <jnweiger@immd4.informatik.uni-erlangen.de>.
3782
3783Thu May 4 23:37:47 1995 Rick Sladkey <jrs@world.std.com>
3784
3785 * ioctl.c (compare): Change prototype to match POSIX qsort.
3786 * signal.c (sigishandled) [SVR4]: Omit everything after return.
3787 * strace.c (trace) [SVR4]: Break out of for loop instead of
3788 returning when finished so final return statement is executed.
3789 * syscall.c (internal_syscall): Add more SYS_wait* variations.
3790 (syscall) [LINUX]: Correct typo which commented out the M68K
3791 argument to ifdef.
3792 * util.c (printstr): Cast unsigned char pointer argument
3793 to char pointer in umovestr call.
3794 (dumpstr): Likewise for umoven.
3795
3796Wed May 3 01:10:56 1995 Rick Sladkey <jrs@world.std.com>
3797
3798 * version.c: Version 3.0.4 is released.
3799
3800 * signal.c (sys_sigblock): Move after the definition of
3801 sys_sigsetmask that it calls to avoid an implicit declaration.
3802 * stream.c (transport_user_options, transport_server_options):
3803 Only needed if TI_BIND is defined.
3804 * configure.in: Add -Wno-implicit to WARNFLAGS on SunOS 4.x.
3805
3806 * process.c (internal_fork) [SVR4]: Fix a typo that omitted
3807 the tcp arguement from the call to exiting. Add getrval2
3808 check so no fork processing is done in the child.
3809 (printwaitn): Initialize exited so that its value is defined
3810 for all flows of execution.
3811
3812Tue May 2 22:39:42 1995 Rick Sladkey <jrs@world.std.com>
3813
3814 * linux/dummy.h: Add aliases for sysfs, personality, afs_syscall,
3815 setfsuid, setfsgid, and _llseek syscalls.
3816 * linux/syscall.h: Add prototypes for them.
3817 * linux/syscallent.h: Add them to the syscall entries table.
3818 * system.c (headers) [LINUX]: Include linux/unistd.h to get __NR_*
3819 defines and conditionally include linux/personality.h if
3820 __NR_personality is defined.
3821 (personality_options) [LINUX]: New table.
3822 (sys_personality) [LINUX]: New function.
3823
3824Tue May 2 00:20:39 1995 Rick Sladkey <jrs@world.std.com>
3825
3826 * strace.c (trace) [!SVR4]: Change forever loop to one predicated
3827 on the number of traced processes so that we can have untraced
3828 children (e.g. via popen).
3829
3830 * strace (main) [!SVR4]: Call fake_execve to get the actual
3831 exec and its arguments into the trace.
3832 (environ): Declare it.
3833 * process.c (fake_execve): New function.
3834 (headers): Include sys/syscall.h to get SYS_* defines.
3835
3836 * process.c (sys_execv, sys_execve): Surround argument annotations
3837 with C comment delimiters.
3838 (printargv, printargc): The arg vector is an array of char pointers
3839 not ints.
3840
3841 * strace.c (printleader): Also check for multiple -p arguments
3842 when deciding whether to print the pid field.
3843
3844 * strace.c (strerror) [!HAVE_STRERROR]: New function.
3845 * defs.h (strerror, strsignal): Add these prototypes if we provide
3846 the functions.
3847 * configure.in (AC_CHECK_FUNCS): Add strerror.
3848
3849 * strace.c (main, proc_poller): Add SIGPIPE to the list of caught
3850 and blocked signals.
3851
3852 * strace.c (main): Add username option. Verify they are root before
3853 letting them use it. Look up the ids in the password file. Set
3854 them just before executing the program.
3855 From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
3856
3857Sat Apr 29 00:09:56 1995 Rick Sladkey <jrs@world.std.com>
3858
3859 * version.c: Version 3.0.3 is released.
3860
3861 * system.c (mount_flags) [LINUX]: Omit duplicated MS_NOSUID entry.
3862 From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
3863
3864 * strace.c (outfname): Initialize to NULL.
3865 (main): Defer output file processing until after arguments.
3866 Allow either a pipe or a bang for command arguments.
3867 Check if outfname is NULL instead of checking outf for stderr.
3868 Reinitialize each startup TCB's outf to fix -p/-o ordering bug.
3869 (droptcb): Reset close TCB's outf to NULL instead of stderr.
3870 (tprintf): Avoid calling vfprintf if outf is NULL.
3871
3872 * strace.c (main): Use popen if -o argument begins with a pipe.
3873 From Marty Leisner <leisner@sdsp.mc.xerox.com>.
3874
3875 * process.c (printstatus): Fix a typo where WIFSIGNALED was meant
3876 but WIFSTOPPED was used.
3877
3878 * Makefile.in: Add an EXTRA_DEFS variable and use it in the .c.o
3879 rule to prevent the comment from being untrue.
3880
3881Fri Apr 28 22:01:56 1995 Rick Sladkey <jrs@world.std.com>
3882
3883 * strace.c (sys_exit): Move follow fork code to internal_exit.
3884 (sys_fork): Move follow fork code to internal_fork.
3885 (sys_execv, sys_execve): Move follow fork code to internal_exec.
3886 (sys_waitpid, sys_wait4): Move follow fork code to internal_wait.
3887 (vforking): Remove this static variable and check scno in
3888 internal_fork instead.
3889 (internal_exit, internal_fork, internal_exec, internal_wait): New
3890 functions.
3891 * defs.h: Add prototypes for the new internal_* functions.
3892 * syscall.c (syscall): Move syscall entering trace qualifier check
3893 and reprint checking after context decoding and precede them with
3894 a call to internal_syscall. Precede syscall exiting trace
3895 qualifier check with a call to internal_syscall.
3896 (internal_syscall): New function.
3897
3898 * defs.h (struct tcb): Make scno signed.
3899 * strace.c (syscall) Make u_error signed.
3900 [LINUX, I386]: Avoid unsigned cast in eax check.
3901 * syscall.c (sys_indir): Make i, scno, and nargs signed.
3902 * desc.c (sys_select): Make cumlen unsigned
3903
3904Mon Apr 24 23:52:47 1995 Rick Sladkey <jrs@world.std.com>
3905
3906 * net.c (socktypes): Add SOCK_PACKET.
3907
3908Sun Apr 2 23:50:39 1995 Rick Sladkey <jrs@world.std.com>
3909
3910 * Makefile (clean): Check explicitly for a Makefile in subdirs
3911 before running make in them.
3912
3913Sun Mar 26 12:37:21 1995 Rick Sladkey <jrs@world.std.com>
3914
3915 * strace.c [MIPS] (proc_open): Conditionalize run on MIPS.
3916 [MIPS] (detach): Initialize error for MIPS case.
3917 (trace): Initialize ioctl_result and ioctl_errno for overly helpful
3918 compilers.
3919 * syscall.c (decode_subcall): Move variable i into conditionals
3920 that use use it.
3921 * system.c (syssgi_options): Conditionalize SGI_RECVLMSG and
3922 SGI_SET_FPDEBUG that SGI decided to drop. I don't have the stomach
3923 to change them all.
3924 * term.c (term_ioctl): Force [c_[iocl]flags members to long before
3925 printing since we don't know what the size of their type is.
3926 * util.c [SVR4, MIPS] (umoven): Prevent MIPS from using pread even
3927 if autoconf detects it since it seems to either not work or do
3928 something else entirely on Irix 5.3.
3929
3930Sun Mar 26 00:01:11 1995 Rick Sladkey <jrs@world.std.com>
3931
3932 * version.c: Version 3.0.2 is released.
3933 * linux/dummy.h: Make sys_fchdir like sys_close instead of printargs
3934 so that the file descriptor arg is decimal.
3935
3936Sat Mar 25 22:50:13 1995 Rick Sladkey <jrs@world.std.com>
3937
3938 * net.c [LINUX] (protocols): Explicitly define all IPPROTO_* entries
3939 because on Linux they are enumerators.
3940
3941 * system.c [LINUX] (mount_flags): Handle renaming of MS_SYNC to
3942 MS_SYNCHRONOUS.
3943
3944 * util.c (printxval): When there is no translation, print the actual
3945 number first and the the default value as a C comment.
3946
3947 * net.c (sys_send, sys_sendto, sys_sendmsg, sys_getsockopt,
3948 sys_setsockopt): Change first argument from unsigned to signed to
3949 cater to the frequent practice of calling system calls with a file
3950 descriptor of -1.
3951 * mem.c (sys_mmap): Likewise.
3952
3953Sun Mar 19 13:53:52 1995 Rick Sladkey <jrs@world.std.com>
3954
3955 * signal.c [LINUX] (signalent): Handle old and new values of SIGIO.
3956
3957Sun Dec 11 22:51:51 1994 Rick Sladkey <jrs@world.std.com>
3958
3959 * version.c: Version 3.0.1 is released.
3960 * Makefile.in, configure.in, aclocal.m4: Changes for autoconf 2.0.
3961 * config.guess, config.guess: Update from the FSF.
3962 * install-sh: New from the FSF.
3963
3964Mon Dec 5 20:51:29 1994 Rick Sladkey <jrs@world.std.com>
3965
3966 * Makefile.in: Add m68k arch.
3967 * acconfig.h (M68K): Add m68k define.
3968 * configure.in: Add detection of arch m68k.
3969 * process.c [M68K] (struct_user_offsets): Support m68k registers and
3970 offsets.
3971 * signal.c [M68K] (sigcontext_struct): Support m68k sigcontext
3972 structure.
3973 [M68K] (sys_sigreturn): Support m68k sigreturn handling.
3974 * syscall.c [M68K] (syscall): Support m68k syscall number register
3975 and errno in d0 instead of eax.
3976 * util.c [M68K] (getpc, printcall, setbpt, clearbpt): Support m68k
3977 program counter in PT_PC instead of EIP.
3978 [M68K] (LOOP): Support m68k loop instruction.
3979 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
3980
3981 * mem.c [MAP_ANONYMOUS] (mmap_flags): Correct inadvertent reference
3982 to MAP_FIXED instead of MAP_ANONYMOUS.
3983 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
3984
3985 * signal.c [LINUX] (signalent): Signal 30 is now SIGPWR.
3986 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
3987
3988Mon Dec 5 01:05:46 1994 Rick Sladkey <jrs@world.std.com>
3989
3990 * defs.h (tprintf): Fix typo in non-gcc ansi prototype for tprintf.
3991 Reported by Thanh Ma <tma@encore.com>.
3992
3993 * strace.c (cleanup): Send SIGCONT before SIGTERM because Linux
3994 1.1.62 doesn't continue a traced child when the parent exits.
3995 Reported by Matt Day <mday@artisoft.com>.
3996
3997 * system.c [LINUX]: Include netinet/in.h before arpa/inet.h.
3998
3999 * util.c (printstr): Fix longstanding bug in notating string
4000 continuation.
4001
4002 * strace.c [SVR4] (proc_open): Specifically wait for the child the
4003 child to go into the execve syscall to avoid spurious traces.
4004 [LINUX] (detach): Conditionalize the status variable.
4005
4006Sun Dec 4 23:21:42 1994 Rick Sladkey <jrs@world.std.com>
4007
4008 * Makefile.in: Add mips arch.
4009 * acconfig.h (MIPS): Add mips define.
4010 * configure.in: Add detection of opsys irix5 and arch mips. Check
4011 for prctl function.
4012 Check for sys/sysconfig.h header.
4013 * defs.h (MAX_ARGS): Bump maximum syscall arguments from 8 to 32.
4014 * file.c [SVR4]: Include sys/cred.h.
4015 (access_flags): Update access flags for SGI.
4016 (sprinttime): Change type of sprinttime argument from unsigned
4017 long to time_t.
4018 * process.c [HAVE_PRCTL]: Include sys/prctl.h.
4019 [HAVE_PRCTL] (prctl_options, sys_prctl): New for SGI.
4020 (printsiginfo): Conditionally compile SI_TIMER and SI_MESGQ.
4021 Cast si_band member to long before printing.
4022 * signal.c (sigact_flags): Add _SA_BSDCALL for SGI.
4023 (sigprocmaskcmds): Add SIG_SETMASK32 for SGI.
4024 * strace.c [SVR4] [MIPS]:
4025 (foobar): New dummy signal handler.
4026 (main): Install a dummy signal handler in the child before pausing
4027 to work around an SGI bug in PRSABORT.
4028 (proc_open): Send a interrupt to the child instead of aborting the
4029 syscall which doesn't work on Irix5.2.
4030 * svr4/dummy.h: Add new unfinished SGI syscalls
4031 (e.g. sys_sysmp, sys_sginap, etc.). Handle some SGI syscalls like
4032 existing calls (e.g. sys_ksigaction like sys_sigaction).
4033 Printargs does the print thing for sys_sethostid.
4034 * svr4/syscall.h: Declare all new SGI syscalls.
4035 (SGI_KLUDGE): Define syscall table starting index to be 1 for SGI
4036 and add it to all subcall entry points.
4037 (SYS_pgrpsys_subcall, SYS_sigcall_subcall, SYS_context): Don't
4038 decode as subcalls on MIPS. Instead, use the normal syscalls.
4039 * svr4/syscallent.h [MIPS]: Lead syscall table with a dummy entry
4040 since SGI syscall numbers are off by one.
4041 [MIPS] (sys_pgrpsys): Rename to sys_setpgrp on SGI.
4042 [MIPS] (sys_xenix): Rename to sys_syssgi on SGI.
4043 [MIPS] (sys_sysmachine): Rename to sys_sysmips on SGI.
4044 [MIPS]: Conditionalize SVR4 extension into SGI and Solaris classes.
4045 * syscall.c (dumpio): Validate descriptor against MAX_QUALS.
4046 [HAVE_PR_SYSCALL] (syscall): Conditionalize SYS_vfork.
4047 [MIPS] (syscall): Add SGI section for decoding u_error and u_rval.
4048 Add workaround for broken SGI pr_sysarg on syscall entry.
4049 [SVR4] (syscall): Conditionalize subcall decoding for
4050 SYS_ptrpsys_subcall, SYS_sigcall_subcall and SYS_context_subcall.
4051 [SVR4] [MIPS] (getrval2): Handle SGI.
4052 * syscallent.sh: Dork the sed line to be choosier about SYS_ lines.
4053 * system.c [HAVE_SYSCONFIG_H]: Include sys/sysconfig.h.
4054 [MIPS] (syssgi_options, sys_syssgi): New for SGI.