blob: 116899ae3082e39572acd4b87b6595e68f33582a [file] [log] [blame]
Roland McGrathfdf5f402007-11-19 22:15:02 +000012007-11-19 Roland McGrath <roland@redhat.com>
2
3 * strace.spec: Add BuildRequires on libaio-devel, libacl-devel.
4
Roland McGrath648fc872007-11-19 22:10:38 +000052007-11-19 Andreas Schwab <schwab@suse.de>
6
Roland McGrathf492bdf2007-11-19 22:11:49 +00007 * process.c (sys_ptrace) [IA64]: For PTRACE_PEEKDATA,
8 PTRACE_PEEKTEXT and PTRACE_PEEKUSER the data is returned directly.
9
Roland McGrath648fc872007-11-19 22:10:38 +000010 * linux/syscallent.h: Fix argument count for getdents64.
11 * linux/arm/syscallent.h: Likewise.
12 * linux/m68k/syscallent.h: Likewise.
13 * linux/x86_64/syscallent.h: Likewise.
14
15 * linux/ia64/syscallent.h: Use sys_getdents64.
16 * linux/sh/syscallent.h: Likewise.
17
Roland McGrathc6efe6e2007-11-13 08:12:16 +0000182007-11-06 Jan Kratochvil <jan.kratochvil@redhat.com>
19
20 * strace.c [LINUX] (droptcb): Recurse on TCP->parent if it is a
21 TCB_EXITING zombie group leader.
22 * test/childthread.c: New file.
23 * test/.cvsignore, test/Makefile: Add it.
24 Code advisory: Roland McGrath
25 Fixes RH#354261.
26
Roland McGrathecdfe0f2007-11-03 23:58:11 +0000272007-11-03 Roland McGrath <roland@redhat.com>
28
29 * process.c (prctl_options): Add numerous constants.
30 From Sami Farin <safari@u.safari.iki.fi>.
31 Fixes RH#364401.
32
Roland McGrathdb63f102007-11-03 23:34:17 +0000332007-11-03 Jan Kratochvil <jan.kratochvil@redhat.com>
34
35 * strace.c (main): Move the STARTUP_CHILD call before setting up the
36 signal handlers. New comment about the valid internal states.
37
Roland McGrathf189d6d2007-11-04 00:00:08 +0000382007-11-02 Thiemo Seufer <ths@networkno.de>
39
40 * signal.c (m_siginfo_t): Add for MIPS.
41 (sys_sigreturn): struct sigcontext on MIPS has no sigset_t member,
42 acquire the signal mask with the same trick as on Sparc.
43 Fixes Debian#448802.
44
Roland McGrathe0201382007-11-01 21:54:17 +0000452007-11-01 Roland McGrath <roland@redhat.com>
46
Roland McGrath78118592007-11-01 23:54:24 +000047 * util.c (string_quote): Return nonzero if the string was unterminated.
48 (printstr): Use that value instead of just our own test.
49 (printpathn): Likewise.
50 Fixes RH#358241.
51
52 * linux/mips/syscallent.h: Fix argument count for fadvise64_64.
53 From Paul Mundt <lethal@linux-sh.org>.
54
55 * linux/mips/syscallent.h: Fix argument count for lookup_dcookie.
56 From Paul Mundt <lethal@linux-sh.org>.
57
Roland McGrathe0201382007-11-01 21:54:17 +000058 * linux/sh64/syscallent.h: Fix SYS_socket_subcall check.
59 From Paul Mundt <lethal@linux-sh.org>.
60
61 * linux/sh/syscallent.h: Update numerous calls.
62 From Paul Mundt <lethal@linux-sh.org>.
63
Roland McGrathd017e342007-11-01 21:50:58 +0000642007-09-22 Dmitry V. Levin <ldv@altlinux.org>
65
Roland McGrathe0201382007-11-01 21:54:17 +000066 * desc.c (sys_pselect6): Decode signal mask when entering syscall.
67 Relax signal mask size check.
68
Roland McGrathd017e342007-11-01 21:50:58 +000069 * time.c (print_timespec, sprint_timespec): New functions.
70 * defs.h (print_timespec, sprint_timespec): Declare them.
71 * desc.c (sys_io_getevents): Use print_timespec.
72 * stream.c (sys_ppoll): Likewise.
73 (decode_poll): Use sprint_timespec.
74
752007-09-22 Alan Curry <pacman@world.std.com>
76 Dmitry V. Levin <ldv@altlinux.org>
77
78 * stream.c (decode_poll): Rearrange so that arguments are decoded
79 and printed on syscall entry, except for revents and the output
80 timespec which are now printed in the auxstr.
81 (sys_poll): Print the input timeout argument on syscall entry.
82 [LINUX] (sys_ppoll): Likewise.
83 Fixes Debian#369651.
84
852007-09-22 Dmitry V. Levin <ldv@altlinux.org>
86
87 * desc.c (sprintflags): Remove static qualifier, add "prefix"
88 argument, move function to ...
89 * util.c (sprintflags): ... here.
90 * defs.h (sprintflags): Declare it.
91
Roland McGrath09d52282007-11-01 21:32:52 +0000922007-11-01 Roland McGrath <roland@redhat.com>
93
Roland McGrathc210f422007-11-01 21:42:29 +000094 * syscall.c (get_scno) [ARM]: Check TCB_WAITEXECVE.
95 Reported by Bernhard Fischer <rep.dot.nop@gmail.com>.
96
Roland McGrath436d5182007-11-01 21:37:36 +000097 * net.c (sockpacketoptions): Make PACKET_ADD_MEMBERSHIP and
98 PACKET_DROP_MEMBERSHIP conditional.
99 From Bernhard Fischer <rep.dot.nop@gmail.com>.
100
Roland McGrath09d52282007-11-01 21:32:52 +0000101 * configure.ac: Match sh64* for SH64, sh* for SH.
102 Reported by Bernhard Fischer <rep.dot.nop@gmail.com>.
103
Dmitry V. Levinbea02032007-10-08 21:48:01 +00001042007-10-01 Dmitry V. Levin <ldv@altlinux.org>
105
Dmitry V. Levinb6c32f42007-10-08 23:31:19 +0000106 * net.c (printsock): Output AF_UNIX socket address using
107 printpathn() to avoid unprintable characters in output.
108 Suggested by Neil Campbell.
109
1102007-10-01 Dmitry V. Levin <ldv@altlinux.org>
111
Dmitry V. Levinbea02032007-10-08 21:48:01 +0000112 * util.c (string_quote): Move quoting code from ...
113 (printstr) ... here. Use string_quote.
114 (printpathn): Update for new string_quote interface.
115 (printpath): Use printpathn.
116
Dmitry V. Levin08b623e2007-10-08 21:04:41 +00001172007-09-25 Dmitry V. Levin <ldv@altlinux.org>
118
Dmitry V. Levin19bab502007-10-08 21:28:18 +0000119 * strace.c (main): Use calloc for tcbtab allocation.
Dmitry V. Levin08b623e2007-10-08 21:04:41 +0000120 Check calloc return value.
121 Reported by Bai Weidong.
122
Roland McGrath4df814f2007-09-12 01:26:48 +00001232007-09-11 Roland McGrath <roland@redhat.com>
124
125 * linux/sparc/syscall.h: Add missing decls.
126 * linux/sparc/syscallent.h: Correct entries for setgroups32,
127 getgroups32, sys_getdents64.
128 From Jakub Bogusz <qboosh@pld-linux.org>.
129
130 * linux/alpha/syscallent.h: Correct entries for madvise, setresgid,
131 getresgid, pivot_root, mincore, pciconfig_iobase, getdents64.
132 From Jakub Bogusz <qboosh@pld-linux.org>.
133
134 * linux/syscallent.h: Fix getegid32 entry.
135 From Jakub Bogusz <qboosh@pld-linux.org>.
136
137 * defs.h [LINUXSPARC]: Use asm/psrcompat.h for [SPARC64], not asm/psr.h.
138 From Jakub Bogusz <qboosh@pld-linux.org>.
139
140 * mem.c (sys_getpagesize): Define for [SPARC || SPARC64] too.
141 From Jakub Bogusz <qboosh@pld-linux.org>.
142
Dmitry V. Levinc18c7032007-08-22 21:43:30 +00001432007-08-20 Dmitry V. Levin <ldv@altlinux.org>
144
145 * syscall.c (qual_syscall, qualify): Fix nsyscalls and MAX_QUALS misuse.
146 Reported by Xiaoning Ding.
147
Roland McGrath2f33e912007-08-07 01:23:08 +00001482007-08-06 Jan Kratochvil <jan.kratochvil@redhat.com>
149 Roland McGrath <roland@redhat.com>
150
151 * file.c [!HAVE_STAT64 && LINUX && X86_64] (struct stat64): Define it.
152 [!HAVE_STAT64 && LINUX && X86_64] (HAVE_STAT64, STAT64_SIZE): Define.
153 [HAVE_STAT64] (printstat64) [STAT64_SIZE]: Add compile-time assertion.
154 Fixes RH#222275.
Roland McGrath6f694b22007-08-07 01:05:22 +0000155
156 * file.c (printstat64): Test [HAVE_LONG_LONG] for st_size printing
157 and cast to widest type available.
158
Roland McGrathf76fca52007-08-07 01:00:32 +00001592007-08-03 Ulrich Drepper <drepper@redhat.com>
160
161 * file.c (open_mode_flags): Add O_CLOEXEC.
162 * net.c (msg_flags): Add MSG_CMSG_CLOEXEC.
Roland McGrathb8152c12007-11-19 22:23:25 +0000163 Fixes RH#365781.
Roland McGrathf76fca52007-08-07 01:00:32 +0000164
Roland McGrath7b5dd1e2007-08-03 09:59:13 +00001652007-08-03 Roland McGrath <roland@redhat.com>
166
Roland McGrathf30de7e2007-08-03 10:28:59 +0000167 * configure.ac, NEWS: Version 4.5.16.
168 * debian/changelog, strace.spec: 4.5.16-1.
169
Roland McGrath7b5dd1e2007-08-03 09:59:13 +0000170 * debian/control (Build-Depends): Replace libc6-dev-s390x and
171 libc6-dev-sparc64 with gcc-multilib.
172 * debian/rules: Replace sparc-linux, s390-linux conditionals with
173 general "arch64_map" hair, handle x86_64 and powerpc64 too.
174 From Matthias Klose <doko@cs.tu-berlin.de>.
175 Fixes Debian#435303.
176
Roland McGrath328c2352007-08-03 10:04:52 +00001772007-08-02 Jan Kratochvil <jan.kratochvil@redhat.com>
178
179 * strace.c (detach): Moved the resume notification code to ...
180 (resume_from_tcp): ... a new function here.
181 (handle_group_exit): No longer detach also the thread group leader.
182 (trace): Fixed panic on exit of the TCB_GROUP_EXITING leader itself.
183 Fixes RH#247907.
184
185 * test/leaderkill.c (start): Renamed to ...
186 (start0): ... here.
187 (start1): New function.
188 (main): Created a new spare thread.
189
Roland McGrathe36e4ca2007-08-02 01:13:36 +00001902007-08-01 Roland McGrath <roland@redhat.com>
191
Roland McGrath1dee3a82007-08-02 02:22:10 +0000192 * util.c (umoven): Don't perror for EIO.
193 (umovestr): Likewise.
194
Roland McGrath8e7174f2007-08-02 02:13:08 +0000195 * process.c (printargv): Handle boundary cases correctly.
196 Handle biarch fetching correctly.
197
198 * util.c (printstr): Don't print ... if the string matches the length
199 limit exactly.
200
Roland McGrathdd519cc2007-08-02 01:47:12 +0000201 * linux/sparc64/syscallent.h: Just #include the sparc file.
202 * linux/sparc64/syscallent1.h: Likewise.
203 * linux/sparc64/syscallent2.h: Likewise.
204
Roland McGrathd9ac0252007-08-02 01:44:20 +0000205 * linux/arm/syscallent.h: Add entry for getcpu.
206 * linux/hppa/syscallent.h: Likewise.
207 * linux/ia64/syscallent.h: Likewise.
208 * linux/mips/syscallent.h: Likewise.
209 * linux/powerpc/syscallent.h: Likewise.
210 * linux/s390/syscallent.h: Likewise.
211 * linux/s390x/syscallent.h: Likewise.
212 * linux/sh/syscallent.h: Likewise.
213 * linux/sh64/syscallent.h: Likewise.
214 * linux/sparc/syscallent.h: Likewise.
215 * linux/sparc64/syscallent.h: Likewise.
216
Roland McGrathe9fcf732007-08-02 01:37:07 +0000217 * linux/arm/syscallent.h: Add entry for eventfd.
218 * linux/ia64/syscallent.h: Likewise.
219 * linux/mips/syscallent.h: Likewise.
220 * linux/powerpc/syscallent.h: Likewise.
221 * linux/s390/syscallent.h: Likewise.
222 * linux/s390x/syscallent.h: Likewise.
223 * linux/sh/syscallent.h: Likewise.
224 * linux/sh64/syscallent.h: Likewise.
225 * linux/sparc/syscallent.h: Likewise.
226 * linux/sparc64/syscallent.h: Likewise.
227
Roland McGrath5d465792007-08-02 01:31:21 +0000228 * linux/arm/syscallent.h: Add entry for timerfd.
Roland McGrath488a1402007-08-02 01:23:52 +0000229 * linux/ia64/syscallent.h: Likewise.
Roland McGrath5d465792007-08-02 01:31:21 +0000230 * linux/mips/syscallent.h: Likewise.
231 * linux/powerpc/syscallent.h: Likewise.
232 * linux/s390/syscallent.h: Likewise.
233 * linux/s390x/syscallent.h: Likewise.
234 * linux/sh/syscallent.h: Likewise.
235 * linux/sh64/syscallent.h: Likewise.
236 * linux/sparc/syscallent.h: Likewise.
237 * linux/sparc64/syscallent.h: Likewise.
238
239 * linux/arm/syscallent.h: Add entry for signalfd.
240 * linux/ia64/syscallent.h: Likewise.
241 * linux/mips/syscallent.h: Likewise.
242 * linux/powerpc/syscallent.h: Likewise.
243 * linux/s390/syscallent.h: Likewise.
244 * linux/s390x/syscallent.h: Likewise.
245 * linux/sh/syscallent.h: Likewise.
246 * linux/sh64/syscallent.h: Likewise.
247 * linux/sparc/syscallent.h: Likewise.
248 * linux/sparc64/syscallent.h: Likewise.
Roland McGrath488a1402007-08-02 01:23:52 +0000249
Roland McGrathe36e4ca2007-08-02 01:13:36 +0000250 * linux/hppa/syscallent.h: Add entry for epoll_pwait.
251 * linux/ia64/syscallent.h: Likewise.
252 * linux/mips/syscallent.h: Likewise.
253 * linux/powerpc/syscallent.h: Likewise.
254 * linux/s390/syscallent.h: Likewise.
255 * linux/s390x/syscallent.h: Likewise.
256 * linux/sh/syscallent.h: Likewise.
257 * linux/sh64/syscallent.h: Likewise.
258 * linux/sparc/syscallent.h: Likewise.
259 * linux/sparc64/syscallent.h: Likewise.
260
Roland McGrathe9fcf732007-08-02 01:37:07 +00002612007-07-23 Ulrich Drepper <drepper@redhat.com>
262
Roland McGrathb8c91632007-08-02 01:38:01 +0000263 * process.c (sys_getcpu): New function.
264 * linux/syscall.h: Declare sys_getcpu.
265 * linux/syscallent.h: Add entry for getcpu.
266
Roland McGrathe9fcf732007-08-02 01:37:07 +0000267 * desc.c (sys_eventfd): New function.
268 * linux/syscall.h: Declare sys_eventfd.
269 * linux/syscallent.h: Add entry for eventfd.
270 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath5d465792007-08-02 01:31:21 +0000271
272 * time.c (printitv_bitness): Add missing braces to enclose
273 conditional code.
274 (TDF_TIMER_ABSTIME): Define if not already.
275 (timerfdflags): New variable.
276 (sys_timerfd): New function.
277 * linux/syscall.h: Declare sys_timerfd.
278 * linux/syscallent.h: Add timerfd entry.
279 * linux/x86_64/syscallent.h: Likewise.
Roland McGrathe36e4ca2007-08-02 01:13:36 +0000280
Roland McGrath488a1402007-08-02 01:23:52 +0000281 * linux/syscall.h: Declare sys_signalfd.
282 * linux/syscallent.h: Add entry for signalfd.
283 * linux/x86_64/syscallent.h: Likewise.
284 * signal.c (sys_signalfd): New function.
285
Roland McGrathe36e4ca2007-08-02 01:13:36 +0000286 * desc.c (sys_epoll_wait): Move body of function to ...
287 (epoll_wait_common): ...here. New function.
288 (sys_epoll_pwait): New function.
289 * linux/syscall.h: Declare sys_epoll_pwait.
290 * linux/syscallent.h: Add entry for epoll_pwait.
291 * linux/x86_64/syscallent.h: Likewise.
292
Roland McGrath2149fc02007-07-24 01:38:31 +00002932007-07-23 Roland McGrath <roland@redhat.com>
294
Roland McGrathb2c4f502007-07-24 01:59:02 +0000295 * time.c (printtv_bitness): SPECIAL only counts when tv_sec == 0.
296
Roland McGrathb912ffe2007-07-24 01:53:09 +0000297 * linux/arm/syscallent.h: Add move_pages.
298 * linux/hppa/syscallent.h: Likewise.
299 * linux/ia64/syscallent.h: Likewise.
300 * linux/m68k/syscallent.h: Likewise.
301 * linux/mips/syscallent.h: Likewise.
302 * linux/powerpc/syscallent.h: Likewise.
303 * linux/s390/syscallent.h: Likewise.
304 * linux/s390x/syscallent.h: Likewise.
305 * linux/sh/syscallent.h: Likewise.
306 * linux/sh64/syscallent.h: Likewise.
307 * linux/sparc/syscallent.h: Likewise.
308 * linux/sparc64/syscallent.h: Likewise.
309
310 * linux/syscallent.h: move_pages takes 6 args, not 5.
311 * linux/x86_64/syscallent.h: Likewise.
312
3132007-07-23 Ulrich Drepper <drepper@redhat.com>
314
Roland McGrathb2c4f502007-07-24 01:59:02 +0000315 * defs.h: Add new parameter to printtv_bitness prototype.
316 (printttv): Pass zero for the new parameter.
317 (printtv_special): New macro.
318 * desc.c (decode_select): Pass zero for the new parameter of
319 printtv_bitness.
320 * file.c (utimensatflags): New macro.
321 (sys_osf_utimes): Pass zero for the new parameter of
322 printtv_bitness.
323 (sys_utimes): Likewise.
324 (sys_futimesat): Likewise.
325 (decode_utimes): Add new parameter. Pass it to the
326 printtv_bitness calls. Fix printing of time values.
327 (sys_utimensat): New function.
328 * time.c (UTIME_NOW, UTIME_OMIT): Define if not already
329 happened.
330 (printtv_bitness): Add new parameter. Print special UTIME_*
331 values as strings if set.
332 (sys_osf_gettimeofday): Pass zero for the new parameter of
333 printtv_bitness.
334 (sys_osf_settimeofday): Likewise.
335 * linux/syscall.h: Declare sys_utimensat.
336 * linux/syscallent.h: Add utimensat entry.
337 * linux/x86_64/syscallent.h: Likewise.
338
Roland McGrathb912ffe2007-07-24 01:53:09 +0000339 * mem.c (move_pages_flags): New variable.
340 (sys_move_pages): New function.
341 * linux/syscall.h: Declare sys_move_pages.
342 * linux/syscallent.h: Add entry for sys_move_pages.
343 * linux/x86_64/syscallent.h: Likewise.
344
345 * mem.c (MPOL_MF_MOVE, MPOL_MF_MOVE_ALL): Define.
346 (mbindflags): Add MPOL_MF_MOVE and MPOL_MF_MOVE_ALL entries.
347
3482007-07-23 Roland McGrath <roland@redhat.com>
349
Roland McGrath2149fc02007-07-24 01:38:31 +0000350 * util.c (tv_add): Fix rounding comparison.
351 Reported by Bai Weidong <baiwd@cn.fujitsu.com>.
352
Roland McGrathcbf40602007-07-11 07:11:24 +00003532007-07-11 Roland McGrath <roland@redhat.com>
354
Roland McGratha7f34142007-07-11 09:04:26 +0000355 * count.c (call_summary_pers): Use tv_float conversion for output of
356 cumulative time, in case it is negative from bogus -O value.
357 From Lai JiangShan <laijs@cn.fujitsu.com>.
358
Roland McGrath0adfb522007-07-11 08:35:15 +0000359 * strace.c (handle_group_exit): Detach TCP before LEADER.
360 Don't use PTRACE_KILL on LEADER.
361
Roland McGrath70b2f0a2007-07-11 07:23:44 +0000362 * util.c (printstr): Fix size calculation for outstr allocation.
363
Roland McGrathcbf40602007-07-11 07:11:24 +0000364 * configure.ac (struct sigcontext.sc_hi2): Use #ifdef around
365 <asm/sigcontext.h> to match signal.c include conditions.
366
Roland McGrath02687832007-07-05 19:09:14 +00003672007-07-05 Roland McGrath <roland@redhat.com>
368
Roland McGrath96affab2007-07-05 20:55:15 +0000369 * debian/rules: Use debian/$(package) instead of debian/tmp as temp dir.
370
Roland McGrathb3205c82007-07-05 20:50:56 +0000371 * configure.ac: Use <stddef.h> before <linux/socket.h>.
372
373 * debian/changelog: Harmonize with debian version.
374 * debian/control (Uploaders): Fix surname spelling.
375 (Build-Depends): Make debhelper requirement (>= 5.0.0).
376 (Standards-Version): Update to 3.7.2.
377
Roland McGrath1be68c42007-07-05 20:34:43 +0000378 * .cvsignore: Add some automake-created files.
379
Roland McGrathf9fe6452007-07-05 20:32:19 +0000380 * file.c (sys_utime): Use personality_wordsize to handle biarch.
381 Fixes RH#247185.
382
383 * signal.c (sys_sigreturn) [MIPS]: Pass 3rd arg to sprintsigmask.
384 From Zhang Le <zhilg@users.sourceforge.net>.
385
Roland McGrath4acaaa12007-07-05 20:03:21 +0000386 * strace.c (strace_fopen): [_LFS64_LARGEFILE]: Use fopen64.
387 Fixes Debian#385310.
388
Roland McGrath6176a1a2007-07-05 19:31:52 +0000389 * strace.c (main): Fix error message for unfound -u user.
390 From Srinivasa Ds <srinivasa@in.ibm.com>.
Roland McGrath599df142007-07-05 19:37:07 +0000391 Fixes RH#247170.
Roland McGrath6176a1a2007-07-05 19:31:52 +0000392
393 * debian/control (Architecture): Add armel.
394
Roland McGratha41eb902007-07-05 19:28:52 +0000395 * linux/syscallent.h: Fix sys_delete_module arg count.
396 * linux/alpha/syscallent.h: Likewise.
397 * linux/arm/syscallent.h: Likewise.
398 * linux/hppa/syscallent.h: Likewise.
399 * linux/ia64/syscallent.h: Likewise.
400 * linux/m68k/syscallent.h: Likewise.
401 * linux/mips/syscallent.h: Likewise.
402 * linux/powerpc/syscallent.h: Likewise.
403 * linux/s390/syscallent.h: Likewise.
404 * linux/s390x/syscallent.h: Likewise.
405 * linux/sh/syscallent.h: Likewise.
406 * linux/sh64/syscallent.h: Likewise.
407 * linux/sparc/syscallent.h: Likewise.
408 * linux/sparc64/syscallent.h: Likewise.
409 * linux/sparc64/syscallent2.h: Likewise.
410 * linux/x86_64/syscallent.h: Likewise.
411 * linux/dummy.h (sys_delete_module): Use sys_open.
412 From Johannes Stezenbach <js@linuxtv.org>.
413
Roland McGrath02687832007-07-05 19:09:14 +0000414 * configure.ac: Check for struct sigcontext.sc_hi2.
415 * signal.c (sys_sigreturn) [MIPS]: Use sc_hi2 vs sc_sigset if found.
Roland McGrathc219f7c2007-07-05 18:59:16 +0000416
417 * process.c [LINUX] (futexops): Add many new values.
418 [LINUX] (futexwakeops, futexwakecmps): New tables.
419 [LINUX] (sys_futex): Use them.
420 From Ulrich Drepper <drepper@redhat.com>.
421 Fixes RH#241467.
422
Roland McGrath70e4b462007-07-05 18:43:24 +00004232007-07-05 Jan Kratochvil <jan.kratochvil@redhat.com>
424
425 * strace.c (detach): New prototype. Extended the function comment.
426 [LINUX] (detach): Call droptcb() instead of the wrongly parametrized
427 detach() call.
428 (handle_group_exit): Call droptcb() instead of the wrongly parametrized
429 detach() call. Always call detach() only once from the group leader.
430 Comment the leader killing known bug tested by `test/leaderkill.c'.
431 Code advisory: Roland McGrath
432 Fixes RH#240961.
433
434 * test/leaderkill.c: New file.
435 * test/.cvsignore, test/Makefile: Add it.
436
Roland McGratha7b4e0a2007-07-05 19:01:39 +00004372007-03-21 Andreas Schwab <schwab@suse.de>
438
439 * file.c (sys_newfstatat): Don't use printstat64 on ppc64.
440
Dmitry V. Levinb011af52007-06-30 11:37:09 +00004412007-03-29 Vladimir Nadvornik <nadvornik@suse.cz>
442 Dmitry V. Levin <ldv@altlinux.org>
443
444 Trace linux SG_IO ioctl arguments and results.
445 * scsi.c: New file.
Roland McGrath70e4b462007-07-05 18:43:24 +0000446 * Makefile.am (strace_SOURCES): Add it.
Dmitry V. Levinb011af52007-06-30 11:37:09 +0000447 * defs.h (scsi_ioctl): New function.
448 * ioctl.c (ioctl_decode): Use scsi_ioctl().
449
Dmitry V. Levinfefdd972007-06-29 21:25:56 +00004502007-06-28 Dmitry V. Levin <ldv@altlinux.org>
451
452 * util.c (tv_mul): Multiply tv_usec properly.
453 Patch from Cai Fei <caifei@cn.fujitsu.com>.
454
Roland McGrath8a483d82007-06-11 22:06:37 +00004552007-06-11 Jan Kratochvil <jan.kratochvil@redhat.com>
456
457 Never interrupt when the attached traced process would be left stopped.
458 * strace.c (main): `-p' attaching moved to ...
459 (startup_attach): ... a new function, renamed a variable C to TCBI.
460 Block interrupting signals since the first tracee has been attached.
461 New comment about INTERRUPTED in the nonthreaded case.
462 [LINUX] (startup_attach): Check INTERRUPTED after each attached thread.
463 (main): Command spawning moved to ...
464 (startup_child): ... a new function, replaced RETURN with EXIT.
465 [LINUX] (detach): New variable CATCH_SIGSTOP, do not signal
466 new SIGSTOP for processes still in TCB_STARTUP.
467 (main): Move signals and BLOCKED_SET init before the tracees attaching,
468 [SUNOS4] (trace): Removed fixvfork () call as a dead code, SIGSTOP must
469 have been already caught before clearing TCB_STARTUP.
470 (trace): Removed the `!WIFSTOPPED(status)' dead code.
471 Clear TCB_STARTUP only in the case the received signal was SIGSTOP.
472 New comment when `TCB_BPTSET && TCB_STARTUP' combination can be set.
473 Code advisory: Roland McGrath
474 Fixes RH#240986.
475
Roland McGrath625c9982007-06-02 00:07:38 +00004762007-05-24 Jan Kratochvil <jan.kratochvil@redhat.com>
477
478 * strace.c [LINUX] (my_tgkill): New macro.
479 [LINUX] (detach): Use my_tgkill () instead of kill(2).
480 Fixes RH#240962.
481
Dmitry V. Levin71f1a132007-03-29 23:30:09 +00004822007-03-30 Dmitry V. Levin <ldv@altlinux.org>
483
484 * mem.c (mmap_flags): Add MAP_32BIT.
485 Reported by Kirill A. Shutemov.
486
Dmitry V. Levin40284242007-03-21 13:52:14 +00004872007-01-12 Dmitry V. Levin <ldv@altlinux.org>
488
Dmitry V. Levin652e4482007-03-21 14:18:17 +0000489 * sock.c (sock_ioctl): Check umove() return code.
Roland McGrathf30de7e2007-08-03 10:28:59 +0000490 [LINUX]: Handle SIOCGIFTXQLEN and SIOCGIFMAP.
Dmitry V. Levin40284242007-03-21 13:52:14 +0000491
Roland McGrath9f825d32007-03-16 21:56:17 +00004922007-03-16 Roland McGrath <roland@redhat.com>
493
494 * linux/s390/syscallent.h: Use sys_restart_syscall for 7.
495 * linux/s390x/syscallent.h: Likewise.
496
Roland McGrathc6696f52007-02-18 22:56:46 +00004972007-02-18 Roland McGrath <roland@redhat.com>
498
499 * strace.spec (Summary): Remove trailing period.
500 (%files): Add %doc files.
501 (%changelog): Double %s in text.
502 (BuildRoot): Change to Fedora canonical.
503 (%install): Don't use %makeinstall macro.
504 (%build): Use %{?_smp_mflags}.
505
Roland McGrath0a45fae2007-01-16 23:25:34 +00005062007-01-16 Roland McGrath <roland@redhat.com>
507
508 * configure.ac, NEWS: Version 4.5.15.
509 * debian/changelog, strace.spec: 4.5.15-1.
510
Dmitry V. Levin817b7082007-01-16 15:10:07 +00005112007-01-16 Dmitry V. Levin <ldv@altlinux.org>
512
513 Update mount parser to match kernel behaviour.
514 * system.c [LINUX] (MS_VERBOSE): Rename to MS_SILENT.
515 [LINUX] (MS_UNBINDABLE, MS_PRIVATE, MS_SLAVE, MS_SHARED):
516 New macros.
517 [LINUX] (mount_flags): Add them.
518 [LINUX] (MS_MGC_MSK): New macro.
519 [LINUX] (sys_mount): Update parser to match kernel behaviour:
520 discard MS_MGC_VAL magic, do not decode type and/or data
521 strings when specified flags do not imply valid strings.
522
Dmitry V. Levin71d70892007-01-13 11:17:38 +00005232007-01-12 Dmitry V. Levin <ldv@altlinux.org>
524
525 * time.c [LINUX] (tprint_timex32, tprint_timex): Decode adjtimex
526 modes as flags.
527
Dmitry V. Levin9b5b67e2007-01-11 23:19:55 +00005282007-01-11 Dmitry V. Levin <ldv@altlinux.org>
529
Dmitry V. Levin5c7ad8c2007-01-13 11:15:48 +0000530 Update umount parser.
531 * system.c [LINUX] (MNT_FORCE, MNT_DETACH, MNT_EXPIRE): New macros.
532 [LINUX] (umount_flags): New xlat structure with MNT_* entries.
533 [LINUX] (sys_umount2): Use umount_flags.
534
Dmitry V. Levin9b5b67e2007-01-11 23:19:55 +0000535 Fix open(2) flags parser.
536 * defs.h (tprint_open_modes): New function.
537 * desc.c (sprint_open_modes): New function.
538 (sys_fcntl): Use tprint_open_modes() and sprint_open_modes().
539 * file.c (openmodes): Split xlat into open_access_modes and
540 open_mode_flags.
541 (tprint_open_modes): New function.
542 (decode_open): Use it.
543 * ipc.c (sys_mq_open, printmqattr): Likewise.
544 Fixes RH#222385.
545
Roland McGratha9e32242007-01-11 22:22:54 +00005462007-01-11 Roland McGrath <roland@redhat.com>
547
548 * configure.ac, NEWS: Version 4.5.15.
549 * debian/changelog, strace.spec: 4.5.15-1.
550
Roland McGrath7a399402007-01-11 22:42:45 +0000551 * debian/control (Uploaders): Add Frederik Schueler <fs@debian.org>.
552
Roland McGratha9e32242007-01-11 22:22:54 +0000553 * strace.spec (Release): Use %{?dist}.
554
Roland McGrath4724f3b2007-01-11 22:26:04 +0000555 * system.c [LINUX] (CTL_CPU): Define in case header is missing it.
556
Dmitry V. Levinab9008b2007-01-11 22:05:04 +00005572006-12-27 Dmitry V. Levin <ldv@altlinux.org>
558
Roland McGratha9e32242007-01-11 22:22:54 +0000559 Add const qualifier to xlookup() return value.
Dmitry V. Levinab9008b2007-01-11 22:05:04 +0000560 * defs.h (xlookup): Add const qualifier to return value.
561 * desc.c (sprintflags): Likewise.
562 * process.c (printpriv): Update xlookup() use.
Roland McGratha9e32242007-01-11 22:22:54 +0000563 * signal.c (sprintsigmask): Add const qualifier to first argument and
564 return value.
Dmitry V. Levinab9008b2007-01-11 22:05:04 +0000565 * util.c (xlookup): Add const qualifier to return value.
566 (printxval): Update xlookup() use.
567
Dmitry V. Levin7d61ff12006-12-21 21:15:04 +00005682006-12-21 Dmitry V. Levin <ldv@altlinux.org>
569
570 Move counts code to separate file.
571 * count.c: New file.
572 * Makefile.am (strace_SOURCES): Add count.c.
573 * syscall.c (call_counts, countv, counts, shortest, time_cmp,
574 syscall_cmp, count_cmp, sortfun, overhead, set_sortby,
575 set_overhead, call_summary_pers, call_summary): Move to count.c
576 * count.c (count_syscall): New function.
577 * defs.h (count_syscall): Declare it.
578 * syscall.c (trace_syscall): Use it.
579
Dmitry V. Levin3abe8b22006-12-20 22:37:21 +00005802006-12-20 Dmitry V. Levin <ldv@altlinux.org>
581
Dmitry V. Levinb2f86992006-12-21 11:44:28 +0000582 * syscall.c (internal_syscall): Change conditions for internal_exit,
583 internal_fork, internal_clone, internal_exec and internal_wait
584 calls from switching on known scno values to switching on known
585 sysent[tcp->scno].sys_func values.
586 Fixes RH#179740.
587
Dmitry V. Levin3abe8b22006-12-20 22:37:21 +0000588 Show system call summary for each personality.
589 * syscall.c (countv): New call_counts pointers array.
590 (counts): Convert to macro wrapper around countv.
591 (call_summary_pers): New function.
592 (call_summary): Use it for each personality.
593 Fixes RH#192193.
594
Dmitry V. Levin10de62b2006-12-13 21:45:31 +00005952006-12-12 Dmitry V. Levin <ldv@altlinux.org>
596
597 Fix -ff -o behaviour. Fix piping trace output.
598 * defs.h (newoutf): Remove.
599 (alloctcb): Rename to alloc_tcb. Add alloctcb() macro wrapper
600 around alloc_tcb().
601 * process.c [!USE_PROCFS] (internal_clone, internal_fork):
602 Remove newoutf() call.
603 * strace.c (set_cloexec_flag, strace_fopen, strace_popen,
604 swap_uid): New functions.
605 (popen_pid): New variable.
606 (newoutf): Make static, use strace_fopen().
607 (main): Use strace_fopen() and strace_popen(), remove uids
608 swapping. Do not open outfname when followfork > 1.
609 Reinitialize tcp->outf properly.
610 (alloctcb): Rename to alloc_tcb. Use newoutf().
611 (trace): Check popen_pid. Remove newoutf() call.
612 [USE_PROCFS] (proc_open, proc_poll_open): Use set_cloexec_flag().
Dmitry V. Levin16f27942006-12-21 21:00:34 +0000613 Fixes RH#204950, RH#218435, Debian#353935.
Dmitry V. Levin10de62b2006-12-13 21:45:31 +0000614
Dmitry V. Levinb9fe0112006-12-13 16:59:44 +00006152006-12-10 Dmitry V. Levin <ldv@altlinux.org>
616
Dmitry V. Levind3cb3922006-12-13 17:45:02 +0000617 Add biarch support for "struct sigevent".
618 * time.c [LINUX && SUPPORTED_PERSONALITIES > 1] (printsigevent32):
619 New function.
620 [LINUX] (printsigevent): [SUPPORTED_PERSONALITIES > 1]
621 Handle 32-bit personality.
622
Dmitry V. Levin165b15d2006-12-13 17:43:45 +0000623 Add biarch support for "struct timex".
624 * time.c [LINUX && SUPPORTED_PERSONALITIES > 1] (tprint_timex32):
625 New function.
626 [LINUX] (tprint_timex): New function.
627 [LINUX] (sys_adjtimex): Use it.
628
Dmitry V. Levin1a684d62006-12-13 17:42:32 +0000629 Enhance adjtimex parser.
630 * time.c [LINUX] (adjtimex_modes, adjtimex_status,
631 adjtimex_state): New xlat structures.
632 [LINUX] (sys_adjtimex): Print the whole struct timex.
633 Decode modes, status and return code.
634
Dmitry V. Levin1cad25d2006-12-13 17:14:36 +0000635 Add biarch support for "struct itimerval".
636 * time.c (printitv): Rename to printitv_bitness().
637 Add printitv() macro wrapper around printitv_bitness().
638 (printitv_bitness): Handle 32-bit personality.
639 [ALPHA] (sys_osf_getitimer, sys_osf_setitimer):
640 Use printitv_bitness().
641 (tprint_timeval, tprint_timeval32): New functions.
642 (printtv_bitness, printitv_bitness, sys_adjtimex): Use them.
643 (printitv32): Remove.
644
645 Add biarch support for "struct timeval".
646 * defs.h (bitness_t): New enum type.
647 (printtv_bitness, sprinttv): New function prototypes.
648 (printtv): Convert to macro wrapper around printtv_bitness().
649 (printtv32): Remove.
650 * desc.c (decode_select): Use printtv_bitness() and sprinttv().
651 (sys_oldselect, sys_osf_select, sys_select, sys_pselect6):
652 Update decode_select() use.
653 * file.c [ALPHA] (sys_osf_utimes): Use printtv_bitness().
654 * time.c (printtv_bitness, sprinttv): New functions.
655 (printtv, printtv32): Remove.
656 [ALPHA] (sys_osf_settimeofday, sys_osf_settimeofday):
657 Use printtv_bitness().
658 Fixes RH#171626, RH#173050.
659
Dmitry V. Levin4ebb4e32006-12-13 17:08:08 +0000660 Add biarch support for "struct iovec".
661 * defs.h (personality_wordsize): Add.
662 * io.c [HAVE_SYS_UIO_H] (tprint_iov): [LINUX &&
663 SUPPORTED_PERSONALITIES > 1] Handle 32-bit personality.
664 * util.c [HAVE_SYS_UIO_H] (dumpiov): [LINUX &&
665 SUPPORTED_PERSONALITIES > 1] Likewise.
666 Patch from Jakub Jelinek.
667 Fixes RH#218433.
668
Dmitry V. Levinac518d12006-12-13 17:03:02 +0000669 * time.c (sys_timer_create): Check umove() return code.
670
Dmitry V. Levinb9fe0112006-12-13 16:59:44 +0000671 Make several global variables static.
672 #ifdef definitions of rarely unused functions.
673 * defs.h (rflag, tflag, outfname): Remove.
674 * strace.c (iflag, interactive, pflag_seen, rflag, tflag,
675 outfname, username): Make static.
676 * desc.c (sys_getdtablesize): Define only for
677 ALPHA || FREEBSD || SUNOS4.
678 * file.c (sys_fchroot): Define only for SUNOS4 || SVR4.
679 (sys_mkfifo): Define only for FREEBSD.
680 * mem.c (sys_sbrk): Define only for FREEBSD || SUNOS4.
681 (sys_getpagesize): Define only for
682 ALPHA || FREEBSD || IA64 || SUNOS4 || SVR4.
683 * net.c (sys_so_socket): Define only for SVR4.
684 * process.c (sys_gethostid): Define only for
685 FREEBSD || SUNOS4 || SVR4.
686 (sys_gethostname): Define only for
687 ALPHA || FREEBSD || SUNOS4 || SVR4.
688 (sys_setpgrp): Define only for ALPHA || SUNOS4 || SVR4.
689 (sys_execv): Define only for SPARC || SPARC64 || SUNOS4.
690 * signal.c (sys_sigblock): Define only for FREEBSD || SUNOS4.
691 (sys_sighold, sys_sigwait): Define only for SVR4.
692 (sys_killpg): Define only for FREEBSD || SUNOS4.
693 * stream.c (sys_getmsg): Define only for
694 SPARC || SPARC64 || SUNOS4 || SVR4.
695 * syscall.c (sys_indir): Define only for SUNOS4.
696
Dmitry V. Levin35a55782006-12-04 13:48:10 +00006972006-11-27 Dmitry V. Levin <ldv@altlinux.org>
698
699 * system.c [LINUX]: Define CTL_PROC, since Linux 2.6.18+ headers
700 removed CTL_PROC enum. Patch from Jakub Jelinek.
701 [LINUX] (sysctl_root): Add CTL_BUS, CTL_ABI and CTL_CPU.
702
Dmitry V. Levina6946662006-12-04 13:46:28 +00007032006-11-20 Jakub Jelinek <jakub@redhat.com>
704
705 * linux/ia64/syscallent.h: Add #if check to make sure that
706 SYS_socket_subcall adjustment isn't forgotten again.
707
Dmitry V. Levinef5c3d62006-10-16 00:26:47 +00007082006-10-16 Dmitry V. Levin <ldv@altlinux.org>
709
710 Implement comprehensive quotactl(2) parser for Linux.
711 * Makefile.am (strace_SOURCES): Add quota.c.
712 * quota.c: New file.
713 * resource.c: Remove old quotactl(2) parser.
714 Fixes RH#118696.
715
Dmitry V. Levincbd470f2006-10-14 14:23:57 +00007162006-10-14 Dmitry V. Levin <ldv@altlinux.org>
717
Roland McGratha0de7c12007-01-16 01:02:38 +0000718 * configure.ac (AC_CHECK_HEADERS): Add inttypes.h.
Dmitry V. Levin1f336e52006-10-14 20:20:46 +0000719 * file.c [_LFS64_LARGEFILE && (LINUX || SVR4)]:
720 Include <inttypes.h>.
721 (sys_getdents64): Use PRIu64/PRId64 to avoid gcc warnings on
722 64-bit platforms.
723
Dmitry V. Levincbd470f2006-10-14 14:23:57 +0000724 * strace.c (main): Check getcwd() return code.
725
Dmitry V. Levin95ebf5a2006-10-13 20:25:12 +00007262006-10-13 Ulrich Drepper <drepper@redhat.com>
727 Bernhard Kaindl <bk@suse.de>
728 Dmitry V. Levin <ldv@altlinux.org>
729 Michael Holzheu <holzheu@de.ibm.com>
730
731 Add hooks for new syscalls. Add decoders for *at, inotify*,
732 pselect6, ppoll and unshare syscalls.
733
734 * defs.h: Declare print_sigset.
735 * desc.c (sys_pselect6): New function.
736 * file.c (decode_open, decode_access, decode_mkdir,
737 decode_readlink, decode_chmod, decode_utimes, decode_mknod):
738 New functions.
739 (sys_open, sys_access, sys_mkdir, sys_readlink, sys_chmod,
740 sys_utimes, sys_mknod): Use them.
741 [LINUX] (fstatatflags, unlinkatflags, inotify_modes): New
742 variables.
743 [LINUX] (print_dirfd, sys_openat, sys_faccessat,
744 sys_newfstatat, sys_mkdirat, sys_linkat, sys_unlinkat,
745 sys_symlinkat, sys_readlinkat, sys_renameat, sys_fchownat,
746 sys_fchmodat, sys_futimesat, sys_mknodat, sys_inotify_add_watch,
747 sys_inotify_rm_watch): New functions.
748 * process.c [LINUX] (sys_unshare): New function.
749 * signal.c (print_sigset): New function.
750 (sys_sigprocmask): Use it.
751 * stream.c (decode_poll): New function.
752 (sys_poll): Use it.
753 [LINUX] (sys_ppoll): New function.
754 * linux/syscall.h: Delcare new syscall handlers.
755 * linux/syscallent.h: Hook up new syscalls.
756 * linux/alpha/syscallent.h: Likewise.
757 * linux/hppa/syscallent.h: Likewise.
758 * linux/ia64/syscallent.h: Likewise.
759 * linux/mips/syscallent.h: Likewise.
760 * linux/powerpc/syscallent.h: Likewise.
761 * linux/s390/syscallent.h: Likewise.
762 * linux/s390x/syscallent.h: Likewise.
763 * linux/sparc/syscallent.h: Likewise.
764 * linux/sparc64/syscallent.h: Likewise.
765 * linux/x86_64/syscallent.h: Likewise.
766 Fixes RH#178633.
767
Dmitry V. Levin96339422006-10-11 23:11:43 +00007682006-10-06 Dmitry V. Levin <ldv@altlinux.org>
769
770 * strace.c [!USE_PROCFS] (trace): Presence of PT_GETSIGINFO
771 macro does not mean that PT_CR_IPSR and PT_CR_IIP macros are
772 also defined, so check them along with PT_GETSIGINFO.
773 Fixes RH#209856.
774
Dmitry V. Levin504eb0b2006-10-11 22:58:31 +00007752006-09-01 Dmitry V. Levin <ldv@altlinux.org>
776
777 * file.c (print_xattr_val): Fix memory corruption bug reported
778 by James Antill.
779 Fixes RH#200621.
780
Dmitry V. Levinaca9a742006-10-11 22:56:49 +00007812006-04-21 Dmitry V. Levin <ldv@altlinux.org>
782
783 * defs.h [LINUX && X86_64 && !__NR_exit_group]: Define
784 __NR_exit_group.
785
Dmitry V. Levin76860f62006-10-11 22:55:25 +00007862006-03-29 Dmitry V. Levin <ldv@altlinux.org>
787
788 Fix race conditions in tcb allocation.
789 * process.c (fork_tcb): Return error code as documented. Do not
790 print "tcb table full" error message.
791 [USE_PROCFS] (internal_fork): Do not print "tcb table full"
792 error message.
793 [SYS_clone || SYS_clone2] (internal_clone, internal_fork): Call
794 fork_tcb() before alloctcb(). Do not print "tcb table full"
795 error message.
796 * strace.c (main): Do not print "tcb table full" error message.
797 (expand_tcbtab): Print error message in case of memory allocation
798 failure.
799 (alloctcb): Print error message when tcb table is full.
800 (trace): Expand tcb table if necessary prior to allocating
801 entry there. Do not print "tcb table full" error message.
802 Fixes RH#180293.
803
Roland McGrathff87ae22006-08-22 07:37:00 +00008042006-08-22 Roland McGrath <roland@redhat.com>
805
806 * ipc.c (sys_msgget, sys_semget, sys_shmget): Show key values in hex.
807 Fixes RH#198179.
808
Roland McGrath6ef291b2006-08-22 06:06:24 +00008092006-08-21 Roland McGrath <roland@redhat.com>
810
811 * linux/syscall.h (SYS_socket_subcall): Bump to 400.
812 * linux/syscallent.h: Update table.
813 * linux/arm/syscallent.h: Likewise.
814 * linux/m68k/syscallent.h: Likewise.
815 * linux/s390/syscallent.h: Likewise.
816 * linux/s390x/syscallent.h: Likewise.
Roland McGrath71030012006-08-22 06:33:45 +0000817 * linux/powerpc/syscallent.h: Likewise.
818 * linux/sh/syscallent.h: Likewise.
819 * linux/sh64/syscallent.h: Likewise.
Roland McGrathfd52f8d2006-10-10 00:57:30 +0000820 Fixes RH#201462.
Roland McGrath6ef291b2006-08-22 06:06:24 +0000821
Roland McGrath23777062006-04-25 07:22:04 +00008222006-04-25 Roland McGrath <roland@redhat.com>
823
Roland McGrathde170102006-04-25 07:48:06 +0000824 * strace.c (main): Fail when -c is given with -ff.
825 * strace.1: Note their incompatibility.
826 Fixes RH#187847.
827
Roland McGrath5b97ae32006-04-25 07:39:48 +0000828 * strace.c (main): Fail when nonoption args follow -p switches.
829 Fixes Debian#361302.
830
Roland McGrath9d19e162006-04-25 07:33:26 +0000831 * Makefile.am (EXTRA_DIST): Add xlate.el.
832
833 * linux/mips/Makefile.in: File removed, unused cruft.
834 * linux/sparc/Makefile.in: Likewise.
835
Roland McGrath23777062006-04-25 07:22:04 +0000836 * strace.spec (Source0): Use http://dl.sourceforge.net URL.
837
838 * ipc.c (sys_semtimedop): Fixed inverted indirect_ipccall test.
839 * linux/hppa/syscallent.h: Fixed semtimedop entry.
840 From Mike Stroyan <mike.stroyan@hp.com>.
841 Fixes Debian#340239.
842
Roland McGrath9216ba72006-04-25 07:34:44 +00008432006-03-30 Daniel Jacobowitz <dan@codesourcery.com>
844
Roland McGrath5b97ae32006-04-25 07:39:48 +0000845 * linux/arm/syscallent.h: Correct the name of exit. Remove
846 M68K conditionals and sys_security. Correct syscalls 243-282.
847 Fixes Debian#360154.
848
Roland McGrath9216ba72006-04-25 07:34:44 +0000849 * process.c (change_syscall): Add ARM support.
850 * syscall.c (get_scno): Handle ARM EABI.
851 Fixes Debian#360152.
852
Roland McGrath074a8e12006-01-17 06:23:01 +00008532006-01-16 Roland McGrath <roland@redhat.com>
854
855 * configure.ac, NEWS: Version 4.5.14.
856 * debian/changelog, strace.spec: 4.5.14-1.
857
Roland McGrathef6b8bf2006-01-14 00:20:26 +00008582006-01-13 Roland McGrath <roland@redhat.com>
859
860 * debian/control (Build-Depends): Add debhelper.
861
Roland McGrath97a932b2006-01-12 10:19:01 +00008622006-01-12 Roland McGrath <roland@redhat.com>
863
Roland McGrath402c9d12006-01-12 22:35:02 +0000864 * signal.c [LINUX] (sys_restart_syscall): New function.
865 * linux/syscall.h: Declare sys_restart_syscall.
866 * linux/sparc/syscall.h: Likewise.
867 * linux/syscallent.h: Call 0 is restart_syscall.
868 * linux/arm/syscallent.h: Likewise.
869 * linux/powerpc/syscallent.h: Likewise.
870 * linux/m68k/syscallent.h: Likewise.
871 * linux/hppa/syscallent.h: Likewise.
872 * linux/sh/syscallent.h: Likewise.
873 * linux/sparc/syscallent.h: Likewise.
874 * linux/sparc64/syscallent.h: Likewise.
875 * linux/alpha/syscallent.h: Use sys_restart_syscall.
876 * linux/ia64/syscallent.h: Likewise.
877 * linux/mips/syscallent.h: Likewise.
878 * linux/x86_64/syscallent.h: Likewise.
Dmitry V. Levin16f27942006-12-21 21:00:34 +0000879 Fixes RH#165469, Debian#350641.
Roland McGrath402c9d12006-01-12 22:35:02 +0000880
8812005-08-08 Dmitry V. Levin <ldv@altlinux.org>
882
883 * system.c [LINUX] (MS_MGC_VAL): New macro.
884 [LINUX] (mount_flags): Add it.
885 [LINUX] (sys_mount): If neither MS_BIND nor MS_MOVE bits are
886 set in the flags argument, try to fetch data string.
887 Fixes RH#165377.
888
8892006-01-12 Roland McGrath <roland@redhat.com>
890
Roland McGrath9ee476f2006-01-12 11:03:48 +0000891 * system.c (sys_sysctl): Don't read off end of NAME when max_strlen
892 exceeds INFO.nlen.
893 From Timo Lindfors <timo.lindfors@iki.fi>.
894 Fixes Debian#339117.
895
896 * debian/rules (binary-arch): Don't pass -s to install. Use dh_strip.
897 Fixes Debian#325132.
898
899 * debian/control (Standards-Version): Update to 3.6.2.
900
Roland McGrath97a932b2006-01-12 10:19:01 +0000901 * defs.h [LINUXSPARC] (PERSONALITY0_WORDSIZE, PERSONALITY1_WORDSIZE):
902 New macros.
903 [SPARC64] (PERSONALITY2_WORDSIZE): New macro.
904 [X86_64] (PERSONALITY0_WORDSIZE, PERSONALITY1_WORDSIZE): New macros.
905 * syscall.c (PERSONALITY0_WORDSIZE): New macro if undefined.
906 (personality_wordsize): New variable.
907 (decode_subcall): Use it for size of argument words.
908 Fixes RH#174354.
909
Roland McGrath49355302006-01-12 09:51:03 +00009102005-11-17 Dmitry V. Levin <ldv@altlinux.org>
911
912 Implement qual_flags support for each personality.
913 * strace.c (main): Move qualify calls after set_personality call.
914 * syscall.c (qual_flags0): New variable..
915 [SUPPORTED_PERSONALITIES >= 2] (qual_flags1): New variable.
916 [SUPPORTED_PERSONALITIES >= 3] (qual_flags2): New variable.
917 (qual_flags): Change variable definition from array to pointer.
918 (set_personality): Initialize qual_flags variable.
919 (qualify_one): Add "pers" argument to specify personality.
920 [SUPPORTED_PERSONALITIES >= 2]: Set qual_flags1 if requested.
921 [SUPPORTED_PERSONALITIES >= 3]: Set qual_flags2 if requested.
922 (qual_syscall): Pass personality to qualify_one.
923 [SUPPORTED_PERSONALITIES >= 2]: Look for syscall also in sysent1
924 table.
925 [SUPPORTED_PERSONALITIES >= 3]: Look for syscall also in sysent2
926 table.
927 (qual_signal): Pass personality to qualify_one.
928 (qual_desc): Likewise.
929 (qualify): Use qualify_one instead of manual qual_flags
930 manipulations.
931 [SUPPORTED_PERSONALITIES >= 2]: Look for syscall also in sysent1
932 table.
933 [SUPPORTED_PERSONALITIES >= 3]: Look for syscall also in sysent2
934 table.
935 * defs.h: Update qual_flags declaration.
936 Fixes RH#173986.
937
Roland McGrath7c061b22006-01-12 09:45:59 +00009382005-11-14 Dmitry V. Levin <ldv@altlinux.org>
939
940 * syscall.c (qual_syscall): Handle numeric syscall specification.
941 Fixes RH#174798.
942
943 * syscall.c (qual_signal, qual_options): Remove redundant argument
944 check.
945
Roland McGrath52f70f72005-12-02 04:34:25 +00009462005-12-01 Roland McGrath <roland@redhat.com>
947
948 * ipc.c (indirect_ipccall) [MIPS || HPPA]: Return false.
949 Fixes Debian#340239.
950
951 * Makefile.am (EXTRA_DIST): Add linux/arm/syscallent.h
952 and linux/m68k/syscallent.h.
953 Fixes Debian#336197.
954
955 * debian/control (Architecture): Add armeb.
956 Fixes Debian#335681.
957
9582005-11-02 Michal Marek <mmarek@suse.cz>
959
960 * strace-graph (handle_trace): follow clone() and vfork() calls.
961
Roland McGrath362f1c32005-12-02 04:23:50 +00009622005-10-25 Heiko Carstens <heiko.carstens@de.ibm.com>
963
964 * linux/s390/syscallent.h: Added ioprio_set, ioprio_get,
965 inotify_init, inotify_add_watch, inotify_rm_watch.
966 Corrected number of arguments for request_key.
967 * linux/s390x/syscallent.h: Likewise.
968
9692005-12-01 Roland McGrath <roland@redhat.com>
970
971 * ipc.c (indirect_ipccall) [IA64]: Return false unless the syscall
972 number is in the low range of IA32 syscalls.
973
9742005-10-07 Andreas Schwab <schwab@suse.de>
975
976 * linux/ia64/syscallent.h: Syscall 1105 is gettid, not ioperm.
977
Roland McGrath89e94ff2005-12-02 03:57:20 +00009782005-12-01 Roland McGrath <roland@redhat.com>
979
Roland McGrath8e5ca842005-12-02 04:08:39 +0000980 * resource.c (resources): Add RLIMIT_NICE, RLIMIT_RTPRIO.
981 Reported by Scott Tsai <scottt958@yahoo.com.tw>.
982
Roland McGrath89e94ff2005-12-02 03:57:20 +0000983 * ipc.c (indirect_ipccall): New function.
984 (sys_msgctl, sys_msgsnd, sys_msgrcv, sys_semop): Use that predicate
985 instead of #ifdef LINUX test.
986 [LINUX] (sys_semtimedop): Likewise.
987 (sys_shmctl, sys_shmat, sys_shmdt): Likewise.
988 Fixes RH#164755.
989
Roland McGrath61b675e2005-12-02 03:44:20 +00009902005-07-31 Ulrich Drepper <drepper@redhat.com>
991
Roland McGrath89e94ff2005-12-02 03:57:20 +0000992 * linux/x86_64/syscallent.h: Fix syscall parameter count for msgrcv and
993 msgctl.
994
Roland McGrath61b675e2005-12-02 03:44:20 +0000995 * ipc.c (sys_msgrcv): Add entering handling and print first parameter
996 there.
997 Fixes RH#164757.
998
Roland McGrathbc38ae72005-12-02 03:59:47 +00009992005-08-08 Dmitry V. Levin <ldv@altlinux.org>
1000
1001 * strace.1: Update "SEE ALSO" links to reference to valid
1002 manpages.
1003 Patch from Michail Litvak <mci@owl.openwall.com>.
1004 Fixes RH#165375.
1005
Roland McGrath68565782005-10-21 22:06:58 +000010062005-10-21 Roland McGrath <roland@redhat.com>
1007
1008 * util.c (printpathn): Cap N at sizeof path - 1.
1009
Roland McGrath0c26d342005-08-03 11:43:03 +000010102005-08-03 Roland McGrath <roland@redhat.com>
1011
1012 * configure.ac, NEWS: Version 4.5.13.
1013 * debian/changelog, strace.spec: 4.5.13-1.
1014
Roland McGrath03c3d752005-08-03 12:18:37 +00001015 * configure.ac: Check for struct dqblk.dqb_curblocks field.
Roland McGrath7e946762005-08-03 12:02:14 +00001016 * resource.c [LINUX] (OLD_CMD): New macro.
1017 (quotacmds): Use it to hard-wire old O_* values, don't use macros.
Roland McGrath03c3d752005-08-03 12:18:37 +00001018 (sys_quotactl): If dqb_curblocks is not there, it's called
1019 dqb_curspace instead. Print dqb_* fields as unsigned long long.
Roland McGrath7e946762005-08-03 12:02:14 +00001020
Roland McGrath9554a482005-08-03 11:29:26 +000010212005-07-19 Michael Schmitz <schmitz@debian.org>
1022
1023 Long overdue m68k cleanup.
1024 * linux/syscallent.h: remove m68k declarations.
1025 * linux/m68k/syscallent.h: new file, fixed up declarations
1026 to match kernel version 2.6.11. Newer syscalls are sufficiently
1027 different from i386 to merit a separate file.
1028
10292005-08-03 Roland McGrath <roland@redhat.com>
1030
1031 * linux/x86_64/syscallent.h: Update init_module argument count.
1032 * linux/sparc/syscallent.h: Likewise.
1033 * linux/sparc64/syscallent2.h: Likewise.
1034 * linux/sparc64/syscallent.h: Likewise.
1035 * linux/sh/syscallent.h: Likewise.
1036 * linux/sh64/syscallent.h: Likewise.
1037 * linux/s390/syscallent.h: Likewise.
1038 * linux/s390x/syscallent.h: Likewise.
1039 * linux/powerpc/syscallent.h: Likewise.
1040 * linux/arm/syscallent.h: Likewise.
1041
10422005-07-22 James Lentini <jlentini@gmail.com>
1043
1044 * bjm.c (sys_init_module): Display all three arguments.
1045 * linux/syscallent.h: Update argument count.
1046
Roland McGrathe0f6bb02005-08-03 11:23:50 +000010472005-08-03 Roland McGrath <roland@redhat.com>
1048
1049 * process.c (internal_wait): Don't suspend when known child is known
1050 to be exiting already.
1051
1052 * strace.c (detach): If detaching the last live thread in a group with
1053 a zombie leader, then detach the leader too.
1054 (handle_group_exit): Use detach, not droptcb, for predeceased thread.
1055 Mark process about to take a signal with TCB_GROUP_EXITING flag.
1056 Fixes RH#161919.
1057
Roland McGrath30afb792005-07-19 07:42:24 +000010582005-07-19 Roland McGrath <roland@redhat.com>
1059
1060 * defs.h [LINUX] [M68K] (__NR_exit_group): Define it if missing.
1061 Fixes Debian#315500.
1062
Roland McGrath387d0e52005-07-19 07:13:34 +000010632005-07-14 Heiko Carstens <heiko.carstens@de.ibm.com>
1064
1065 * linux/s390/syscallent.h (sys_tgkill, vserver, fadvise64_64)
1066 (statfs64, fstatfs64, remap_file_pages, mbind, get_mempolicy)
1067 (set_mempolicy, mq_open, mq_unlink, mq_timedsend, mq_timedreceive)
1068 (mq_notify, mq_getsetattr, sys_kexec_load, add_key, request_key)
1069 (keyctl, waitid): Added.
1070 * linux/s390x/syscallent.h: Likewise and added missing _llseek.
1071 * linux/s390/errnoent.h (ECANCELED, ENOKEY, EKEYEXPIRED)
1072 (EKEYREVOKED, EKEYREJECTED, EOWNERDEAD, ENOTRECOVERABLE): Added.
1073 * linux/s390x/errnoent.h: Likewise.
1074
Roland McGrath415a7d62005-07-05 09:50:40 +000010752005-07-05 Roland McGrath <roland@redhat.com>
1076
1077 * mem.c [LINUX] (sys_old_mmap) [X86_64]: Extract 32-bit values if
1078 child is 32-bit.
1079 Fixes RH#162467.
1080
Roland McGrathfd583f62005-07-05 03:22:50 +000010812005-06-08 Dmitry V. Levin <ldv@altlinux.org>
1082
Roland McGrathe10dc512005-07-05 03:26:03 +00001083 Introduce "-e trace=desc".
1084 * defs.h (TRACE_DESC): New flag.
1085 * syscall.c: Define TD macro before include of syscallent files
1086 and undefine it afterwards.
1087 (lookup_class): Recognize "desc" keyword.
1088 * strace.1: Document "-e trace=desc".
1089 * freebsd/i386/syscallent.h: Mark those syscalls which take a
1090 file descriptor as an argument or return a file descriptor with
1091 TD flag.
1092 * linux/alpha/syscallent.h: Likewise.
1093 * linux/hppa/syscallent.h: Likewise.
1094 * linux/ia64/syscallent.h: Likewise.
1095 * linux/mips/syscallent.h: Likewise.
1096 * linux/powerpc/syscallent.h: Likewise.
1097 * linux/s390/syscallent.h: Likewise.
1098 * linux/s390x/syscallent.h: Likewise.
1099 * linux/sh/syscallent.h: Likewise.
1100 * linux/sh64/syscallent.h: Likewise.
1101 * linux/sparc/syscallent.h: Likewise.
1102 * linux/sparc64/syscallent2.h: Likewise.
1103 * linux/sparc64/syscallent.h: Likewise.
1104 * linux/syscallent.h: Likewise.
1105 * linux/x86_64/syscallent.h: Likewise.
1106 * sunos4/syscallent.h: Likewise.
1107 * svr4/syscallent.h: Likewise.
1108 Fixes RH#159400.
1109
Roland McGrathfd583f62005-07-05 03:22:50 +00001110 Remove TF flag from those syscalls which have no filename argument.
1111 * freebsd/i386/syscallent.h: Remove TF flag from fstat, pread,
1112 pwrite, fstat, sendfile.
1113 * linux/alpha/syscallent.h: Remove TF flag from read, write,
1114 pread, pwrite, sendfile.
1115 * linux/hppa/syscallent.h: Remove TF flag from read, write,
1116 pread, pwrite, fstat64, sendfile, ftruncate64.
1117 * linux/ia64/syscallent.h: Remove TF flag from read, write,
1118 sendfile, fstat, fadvise64.
1119 * linux/mips/syscallent.h: Remove TF flag from read, write,
1120 fstatfs, fstat, pread, pwrite, sendfile, ftruncate64, fstat64,
1121 sendfile64, fadvise64, fstatfs64.
1122 * linux/powerpc/syscallent.h: Remove TF flag from read, write,
1123 fstat, pread, pwrite, sendfile, ftruncate64, fstat64, sendfile64,
1124 fadvise64, fstatfs64, fadvise64_64.
1125 * linux/s390/syscallent.h: Remove TF flag from pread, pwrite,
1126 sendfile, ftruncate64, fstat64, sendfile64.
1127 * linux/s390x/syscallent.h: Remove TF flag from pread, pwrite,
1128 sendfile, sendfile64.
1129 * linux/sh/syscallent.h: Remove TF flag from pread, pwrite,
1130 sendfile, fstat64.
1131 * linux/sh64/syscallent.h: Remove TF flag from pread, pwrite,
1132 sendfile, ftruncate64, fstat64.
1133 * linux/sparc/syscallent.h: Remove TF flag from sendfile, fstat64,
1134 pread, pwrite, sendfile64.
1135 * linux/sparc64/syscallent2.h: Likewise.
1136 * linux/sparc64/syscallent.h: Likewise.
1137 * linux/syscallent.h: Remove TF flag from pread, pwrite, sendfile,
1138 ftruncate64, fstat64, sendfile64, fadvise64, fadvise64, fstatfs64,
1139 fadvise64_64.
1140 * linux/x86_64/syscallent.h: Remove TF flag from pread, pwrite,
1141 sendfile, fadvise64_64.
1142 * svr4/syscallent.h: Remove TF flag from pread, pwrite, ftruncate,
1143 fstatvfs64, ftruncate64.
1144 Fixes RH#159340.
1145
Roland McGrath012ffdf2005-07-04 23:30:30 +000011462005-07-04 Roland McGrath <roland@redhat.com>
1147
Roland McGrathbfacc262005-07-04 23:33:42 +00001148 * net.c (sockipv6options): Add IPV6_ADD_MEMBERSHIP,
1149 IPV6_DROP_MEMBERSHIP, IPV6_ROUTER_ALERT.
1150 From Ulrich Drepper <drepper@redhat.com>.
1151 Fixes RH#162450.
1152
Roland McGrath012ffdf2005-07-04 23:30:30 +00001153 * net.c (sockipoptions): Fix typos.
1154 From Ulrich Drepper <drepper@redhat.com>.
1155 Fixes RH#161578.
1156
1157 * util.c (printnum_int): New function, printnum with s/long/int/.
1158 * defs.h: Declare it.
1159 * net.c (printsockopt): Use it for int-sized option.
1160 Fixes RH#162449.
1161 Reported by Ulrich Drepper <drepper@redhat.com>.
1162
Roland McGrath43cb21f2005-06-10 03:56:19 +000011632005-06-09 Roland McGrath <roland@redhat.com>
1164
1165 * configure.ac, NEWS: Version 4.5.12.
1166 * debian/changelog, strace.spec: 4.5.12-1.
1167
Roland McGrath59a611b2005-06-08 20:45:52 +000011682005-06-08 Dmitry V. Levin <ldv@altlinux.org>
1169
1170 Minor namespace cleanup.
1171 * defs.h (string_quote): Remove declaration.
1172 * file.c (openmodessol) [LINUXSPARC]: Make static.
1173 (fileflags): Likewise.
1174 (aclcmds, aclipc) [HAVE_SYS_ACL_H]: Likewise.
1175 (direnttypes) [FREEBSD || LINUX]: Likewise.
1176 (xattrflags): Likewise.
1177 * process.c (unalignctl_string): Make static.
1178 (setarg): Disable.
1179 * syscall.c (subcalls_table): Make static.
1180 (socket_map) [!(LINUX && (ALPHA || MIPS))]: Likewise.
1181 (sparc_socket_decode): Make static, define for [SPARC || SPARC64] only.
1182 (decode_subcall): Make static.
1183 (syscall_fixup): Likewise.
1184 (get_error): Likewise.
1185 (syscall_enter): Likewise.
1186 * util.c (tv_tv): Disable.
1187 (getpc): Likewise.
1188 (string_quote): Make static.
1189 Fixes RH#159688.
1190
Roland McGrathd40a3932005-06-08 18:06:27 +000011912005-05-12 Philippe De Muyter <phdm@macqel.be>
1192
1193 * util.c (getpc, printcall): Check #if defined(M68K), not M68k.
1194 Enables `-i' on m68k machines.
1195
Roland McGrath5d731702005-06-07 23:22:26 +000011962005-06-06 Roland McGrath <roland@redhat.com>
1197
1198 * process.c (struct_user_offsets) [X86_64]: Reorder elements so
1199 matching works right.
1200 Fixes RH#159787.
1201
1202 * linux/syscall.h (SYS_socket, SYS_bind, SYS_connect, SYS_listen)
1203 (SYS_accept, SYS_getsockname, SYS_getpeername, SYS_socketpair)
1204 (SYS_send, SYS_recv, SYS_sendto, SYS_recvfrom, SYS_shutdown)
1205 (SYS_setsockopt, SYS_getsockopt, SYS_sendmsg, SYS_recvmsg)
1206 (SYS_getsockname, SYS_semop, SYS_semgsub_et, SYS_semget, SYS_semctl)
1207 (SYS_semtimedop, SYS_msgsnd, SYS_msgrcv, SYS_msgget)
1208 (SYS_msgctl, SYS_shmat, SYS_shmdt, SYS_shmget)
1209 (SYS_shmctl): Macros renamed to SYS_sub_*.
1210 * syscall.c (dumpio): Match SYS_sub_* if defined instead of SYS_*.
1211
1212 * linux/syscall.h (SYS_waitid): Define if not defined.
1213
1214 * linux/syscallent.h: Fix pread/pwrite names to pread64/pwrite64.
1215
1216 * defs.h (struct sysent): New member `native_scno'.
1217 (known_scno): Declare new function.
1218 * linux/syscallent.h: Add new final field to interesting syscalls.
1219 * syscall.c (known_scno): New function.
1220 (dumpio, internal_syscall, syscall_fixup, trace_syscall): Use it.
1221 * process.c (internal_fork, internal_exit): Likewise.
1222 [IA64] (ARG_STACKSIZE, ARG_PTID, ARG_CTID, ARG_TLS): Likewise.
1223 * strace.c (proc_open): Likewise.
1224 * util.c [LINUX] (setbpt): Likewise.
1225 * linux/syscall.h: Remove [!defined(X86_64)] from conditional
1226 for defining SYS_socket_subcall et al.
1227 * linux/syscallent.h: Likewise for #error check.
1228 * syscall.c (trace_syscall): Likewise for SYS_{socketcall,ipc} cases.
1229 Fixes RH#158934.
1230
Roland McGrath6286f662005-06-03 02:40:43 +000012312005-06-02 Roland McGrath <roland@redhat.com>
1232
1233 * file.c (printstatfs64): Cast values to unsigned long long and use
1234 %llu formats.
1235 Fixes RH#158243.
1236
Roland McGrathe8c6eec2005-06-01 18:56:03 +000012372005-05-31 Dmitry V. Levin <ldv@altlinux.org>
1238
Roland McGrath712a6bf2005-06-01 19:22:30 +00001239 Deal with memory management issues.
1240 * defs.h (tprint_iov): Update prototype.
1241 * desc.c (sys_epoll_wait) [HAVE_SYS_EPOLL_H]: Do not allocate
1242 epoll_event array of arbitrary size on the stack, to avoid
1243 stack overflow.
1244 * file.c (print_xattr_val): Check for integer overflow during
1245 malloc size calculation, to avoid heap corruption.
1246 * io.c (tprint_iov) [HAVE_SYS_UIO_H]: Check for integer overflow
1247 during malloc size calculation, to avoid heap corruption.
1248 Change iovec array handling to avoid heap memory allocation.
1249 * mem.c (get_nodes) [LINUX]: Check for integer overflow during
1250 size calculation and do not allocate array of arbitrary size on
1251 the stack, to avoid stack overflow.
1252 * net.c (printcmsghdr) [HAVE_SENDMSG]: Do not allocate array of
1253 arbitrary size on the stack, to avoid stack overflow. Do not
1254 trust cmsg.cmsg_len to avoid read beyond the end of allocated
1255 object.
1256 (printmsghdr) [HAVE_SENDMSG]: Update tprint_iov() usage.
1257 * process.c (sys_setgroups): Check for integer overflow during
1258 malloc size calculation, to avoid heap corruption. Change gid_t
1259 array handling to avoid heap memory allocation.
1260 (sys_getgroups): Likewise.
1261 (sys_setgroups32) [LINUX]: Likewise.
1262 (sys_getgroups32) [LINUX]: Likewise.
1263 * stream.c (sys_poll) [HAVE_SYS_POLL_H]: Check for integer
1264 overflow during malloc size calculation, to avoid heap corruption.
1265 Change pollfd array handling to avoid heap memory allocation.
1266 * system.c (sys_sysctl) [LINUX]: Check for integer overflow
1267 during malloc size calculation, to avoid heap corruption.
1268 * util.c (dumpiov) [HAVE_SYS_UIO_H]: Check for integer overflow
1269 during malloc size calculation, to avoid heap corruption.
1270 Fixes RH#159196.
1271
Roland McGrathb422e0d2005-06-01 19:03:30 +00001272 * util.c (printxval): Change third argument from "char *" to
1273 "const char *".
1274 (printflags): Add third argument, "const char *", with similar
1275 meaning to the third argument of printxval().
1276 * defs.h (printxval): Change third argument from "char *" to
1277 "const char *".
1278 (printflags): Add third argument.
1279 * bjm.c (sys_query_module) [LINUX]: Pass third argument to
1280 printflags().
1281 * desc.c (sys_fcntl): Likewise.
1282 (sys_flock) [LOCK_SH]: Likewise.
1283 (print_epoll_event) [HAVE_SYS_EPOLL_H]: Likewise.
1284 * file.c (sys_open): Likewise.
1285 (solaris_open) [LINUXSPARC]: Likewise.
1286 (sys_access): Likewise.
1287 (sys_chflags, sys_fchflags) [FREEBSD]: Likewise.
1288 (realprintstat) [HAVE_LONG_LONG_OFF_T &&
1289 HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
1290 (printstat64) [HAVE_STAT64 &&
1291 HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
1292 (sys_setxattr, sys_fsetxattr): Likewise.
1293 * ipc.c (sys_msgget, sys_msgsnd, sys_msgrcv, sys_semget,
1294 sys_shmget, sys_shmat) [LINUX || SUNOS4 || FREEBSD]: Likewise.
1295 (sys_mq_open) [LINUX]: Likewise.
1296 (printmqattr) [HAVE_MQUEUE_H]: Likewise.
1297 * mem.c (print_mmap) [!HAVE_LONG_LONG_OFF_T]: Likewise.
1298 (sys_mmap64) [_LFS64_LARGEFILE || HAVE_LONG_LONG_OFF_T]: Likewise.
1299 (sys_mprotect): Likewise.
1300 (sys_mremap, sys_madvise, sys_mlockall) [LINUX]: Likewise.
1301 (sys_msync) [MS_ASYNC]: Likewise.
1302 (sys_mctl) [MC_SYNC]: Likewise.
1303 (sys_remap_file_pages, sys_mbind, sys_get_mempolicy) [LINUX]:
1304 Likewise.
1305 * net.c (printmsghdr) [HAVE_STRUCT_MSGHDR_MSG_CONTROL]: Likewise.
1306 (sys_send, sys_sendto): Likewise.
1307 (sys_sendmsg) [HAVE_SENDMSG]: Likewise.
1308 (sys_recv, sys_recvfrom): Likewise.
1309 (sys_recvmsg) [HAVE_SENDMSG]: Likewise.
1310 (printicmpfilter) [ICMP_FILTER]: Likewise.
1311 * proc.c (proc_ioctl) [SVR4 && !HAVE_MP_PROCFS || FREEBSD]: Likewise.
1312 * process.c (sys_clone) [LINUX]: Likewise.
1313 (printwaitn): Likewise.
1314 (sys_waitid) [SVR4 || LINUX]: Likewise.
1315 * signal.c (sys_sigvec) [SUNOS4 || FREEBSD]: Likewise.
1316 (sys_sigaction): Likewise.
1317 (printcontext) [SVR4]: Likewise.
1318 (print_stack_t) [LINUX) || FREEBSD]: Likewise.
1319 (sys_rt_sigaction) [LINUX]: Likewise.
1320 * sock.c (sock_ioctl) [LINUX]: Likewise.
1321 * stream.c (sys_putmsg, sys_getmsg): Likewise.
1322 (sys_putpmsg) [SYS_putpmsg]: Likewise.
1323 (sys_getpmsg) [SYS_getpmsg]: Likewise.
1324 (sys_poll): Likewise.
1325 (print_transport_message) [TI_BIND]: Likewise.
1326 (stream_ioctl): Likewise.
1327 * system.c (sys_mount, sys_reboot): Likewise.
1328 (sys_cacheflush) [LINUX && M68K]: Likewise.
1329 (sys_capget, sys_capset) [SYS_capget]: Likewise.
1330 * term.c (term_ioctl) [TIOCMGET]: Likewise.
1331 * time.c (sys_clock_nanosleep, sys_timer_settime) [LINUX]:
1332 Likewise.
1333 Fixes RH#159310.
1334
Roland McGrathe8c6eec2005-06-01 18:56:03 +00001335 * bjm.c (sys_query_module) [LINUX]: Unitize "out of memory"
1336 errors reporting style.
1337 * strace.c (rebuild_pollv) [USE_PROCFS]: Likewise.
1338 * system.c (sys_capget, sys_capset) [SYS_capget]: Likewise.
1339 * util.c (printstr): Likewise.
1340 (dumpiov) [HAVE_SYS_UIO_H]: Likewise.
1341 (fixvfork) [SUNOS4]: Likewise.
1342 * desc.c (decode_select): Continue to decode syscall arguments
1343 in case of OOM condition.
1344 * file.c (sys_getdents): Likewise.
1345 (sys_getdents64) [_LFS64_LARGEFILE]: Likewise.
1346 (sys_getdirentries) [FREEBSD]: Likewise.
1347 * mem.c (sys_mincore): Changed type of variables which deal with
1348 malloc size from int to unsigned long.
Roland McGrathe35109a2005-06-08 18:03:12 +00001349 Fixes RH#159308.
Roland McGrathe8c6eec2005-06-01 18:56:03 +00001350
Roland McGratha6ef1a32005-06-01 18:57:27 +000013512005-05-22 Dmitry V. Levin <ldv@altlinux.org>
1352
1353 * bjm.c [LINUX]: Do not include <linux/linkage.h>. It is not
1354 safe to include kernel headers, and this one is not used anyway.
1355 Fixes RH#158488.
1356
Roland McGrathe776e3e2005-05-26 23:21:13 +000013572005-05-26 Roland McGrath <roland@redhat.com>
1358
1359 * system.c (sys_sysctl): Check for errors accessing user pointers.
1360 Use malloc instead of alloca in case size is insane.
1361
Roland McGrath682291e2005-05-09 08:03:06 +000013622005-05-09 Roland McGrath <roland@redhat.com>
1363
1364 * configure.ac: Check for libaio.h.
1365 * desc.c (sys_io_setup, sys_io_submit, sys_io_cancel,
1366 sys_io_getevents, sys_io_destroy): New functions.
1367 * linux/syscall.h: Declare them.
1368 * linux/syscallent.h: Use those for io_* syscalls.
1369 * linux/alpha/syscallent.h: Likewise.
1370 * linux/hppa/syscallent.h: Likewise.
1371 * linux/ia64/syscallent.h: Likewise.
1372 * linux/mips/syscallent.h: Likewise.
1373 * linux/powerpc/syscallent.h: Likewise.
1374 * linux/s390/syscallent.h: Likewise.
1375 * linux/s390x/syscallent.h: Likewise.
1376 * linux/x86_64/syscallent.h: Likewise.
1377 From Zach Brown <zach.brown@oracle.com>.
1378 Fixes RH#155065.
1379
1380 * debian/control (Architecture): Add ppc64.
1381 Fixes Debian bug #301089.
1382
Roland McGrath05a017b2005-05-09 07:46:07 +000013832005-05-05 Anton Blanchard <anton@samba.org>
1384
1385 * process.c (ptrace_cmds): Add PTRACE_GETVRREGS and PTRACE_SETVRREGS
1386 if defined.
1387
13882005-05-09 Roland McGrath <roland@redhat.com>
1389
1390 * strace.c (main): Refuse negative -s argument value.
1391 Fixes Debian bug #303256.
1392
Roland McGrathf3b565b2005-05-09 07:40:41 +000013932005-04-25 Anton Blanchard <anton@samba.org>
1394
1395 * file.c (openmodes): Add O_NOATIME flag if defined.
1396
13972005-04-05 Anton Blanchard <anton@samba.org>
1398
1399 * linux/powerpc/ioctlent.h: Regenerated.
1400
1401 * signal.c (signame): Don't try and dereference negative index.
1402
1403 * linux/powerpc/syscallent.h: Add debug_setcontext, vserver,
1404 mbind, *_mempolicy, mq_*, sys_kexec_load, add_key, request_key,
1405 keyctl, waitid, sys_semtimedop. Fix various other syscalls.
1406
1407 * ipc.c (shm_resource_flags): New variable, table has SHM_HUGETLB
1408 but not IPC_NOWAIT, which have the same value.
1409 (sys_shmget): Use that instead of resource_flags.
1410
Roland McGratha3734a92005-03-22 23:13:24 +000014112005-03-22 Roland McGrath <roland@redhat.com>
1412
Roland McGrathe1f1e572005-03-23 03:19:02 +00001413 * desc.c (decode_select): Increase local buffer size.
1414 Fixes RH#151570.
1415
Roland McGratha3734a92005-03-22 23:13:24 +00001416 * configure.ac, NEWS: Version 4.5.11.
1417 * debian/changelog, strace.spec: 4.5.11-1.
1418
1419 * linux/arm/syscallent.h: Fix 113 entry (syscall, not vm86old).
1420
Roland McGrath3181c512005-03-15 02:40:23 +000014212005-03-14 Roland McGrath <roland@redhat.com>
1422
1423 * configure.ac, NEWS: Version 4.5.10.
1424 * debian/changelog, strace.spec: 4.5.10-1.
1425
Roland McGrath0495c932005-03-15 02:17:23 +000014262005-02-26 GOTO Masanori <gotom@debian.or.jp>
1427
1428 * linux/alpha/syscallent.h: Fix the reversed order of lstat64 and
1429 fstat64. Clean up osf_nrecvmsg and osf_ngetsockname.
1430
Roland McGrath391a4e72005-03-15 02:16:21 +000014312005-02-28 Andreas Schwab <schwab@suse.de>
1432
1433 * syscall.c (getrval2): Move #ifdef IA64 inside #ifdef LINUX.
1434
14352005-03-14 Roland McGrath <roland@redhat.com>
1436
1437 * linux/mips/syscallent.h: Update various calls.
1438 From Thiemo Seufer <ths@networkno.de>.
1439 Fixes Debian bug #256684.
1440
1441 * debian/control (Architecture): Add s390.
1442 Fixes Debian bug #294172.
1443
Roland McGrathbfb49e52005-03-06 22:24:52 +000014442005-03-06 Roland McGrath <roland@redhat.com>
1445
1446 * strace.c (trace) [PTRACE_GETSIGINFO]: Fetch siginfo_t for SIGSEGV
1447 and SIGBUS signals, use si_addr in output.
1448
Roland McGrath4859f6c2005-03-01 23:03:11 +000014492005-03-01 Roland McGrath <roland@redhat.com>
1450
1451 * file.c (print_xattr_val): Add a cast.
1452
Roland McGrath854694b2005-02-06 01:16:47 +000014532005-02-05 Roland McGrath <roland@redhat.com>
1454
Roland McGrathb0a3d4e2005-02-06 01:55:16 +00001455 * desc.c (decode_select): Calculate size of passed fd_set vectors and
1456 copy in the user's size rather than the standard sizeof(fd_set).
Roland McGrath391a4e72005-03-15 02:16:21 +00001457 Fixes Debian bug #65654, #284290.
Roland McGrathb0a3d4e2005-02-06 01:55:16 +00001458
1459 * util.c (printpath, printpathn): Print NULL and don't try any fetch
1460 when ADDR is zero.
1461 Fixes Debian bug #63093.
1462
Roland McGrath854694b2005-02-06 01:16:47 +00001463 * debian/control (Build-Depends): Fix for s390 and sparc.
1464 From Bastian Blank <waldi@debian.org>.
1465 Fixes Debian bug #293564.
1466
14672004-12-19 Dmitry V. Levin <ldv@altlinux.org>
1468
1469 * strace.c (main) [!USE_PROCFS]: In child process, raise SIGSTOP
1470 right before execv() call. Remove fake_execve() call.
1471 * defs.h (fake_execve): Remove unused declaration.
1472 * process.c (fake_execve): Remove unused function.
1473 Fixes RH#143365.
1474
Roland McGrath55f23e72005-02-04 09:29:11 +000014752005-02-04 Roland McGrath <roland@redhat.com>
1476
1477 * configure.ac, NEWS: Version 4.5.9.
Roland McGrath0c6c17b2005-02-04 09:54:16 +00001478 * debian/changelog, strace.spec: 4.5.9-2.
Roland McGrath55f23e72005-02-04 09:29:11 +00001479
Roland McGrath1e834482005-02-04 09:50:24 +00001480 * file.c (O_LARGEFILE): Omit when #undef'd because it was zero.
1481
Roland McGrath94098ef2005-02-02 20:25:36 +000014822005-02-02 Roland McGrath <roland@redhat.com>
1483
Roland McGrath026bdab2005-02-03 03:19:43 +00001484 * debian/control: Add strace-udeb package for installer debugging.
1485 * debian/rules (binary-arch): Build it.
1486 From Joshua Kwan <joshk@triplehelix.org>.
1487 Fixes Debian bug #268294.
1488
Roland McGrathd08b2f02005-02-02 22:11:37 +00001489 * file.c (openmodes) [O_LARGEFILE] [O_LARGEFILE == 0]: Redefine to
1490 known values for Linux.
1491
Roland McGrath84219e12005-02-02 20:55:27 +00001492 * util.c (printcall): Print 16 ?s when long is 8 bytes.
1493 Fixes RH#146932.
1494
Roland McGrath3cad4a62005-02-02 20:32:37 +00001495 * linux/sparc/syscall.h: Declare sys_epoll_create, sys_epoll_ctl,
1496 sys_epoll_wait.
1497 * linux/sparc64/syscall.h: Just #include "../sparc/syscall.h" here.
1498 * ioctl.c (nioctlents2): Add const to type.
1499 Fixes Debian bug #278449.
1500
Roland McGrath94098ef2005-02-02 20:25:36 +00001501 * sock.c (iffflags): New variable, table of IFF_* values.
1502 (print_addr): New function.
1503 (sock_ioctl): Handle SIOCGIFADDR, SIOCGIFDSTADDR, SIOCGIFBRDADDR,
1504 SIOCGIFNETMASK, SIOCGIFFLAGS, SIOCGIFMETRIC, SIOCGIFMTU, SIOCGIFSLAVE,
1505 SIOCGIFHWADDR. Use print_addr for SIOCGIFCONF, SIOCGIFNAME, and
1506 SIOCGIFINDEX, and fix their output.
1507 From Ulrich Drepper <drepper@redhat.com>.
1508 Fixes RH#138223.
Roland McGrath1967a132005-02-02 20:45:37 +00001509 Fixes Debian bug #192164.
Roland McGrath94098ef2005-02-02 20:25:36 +00001510
Roland McGrathac6b7bb2005-02-02 04:42:56 +000015112004-12-20 Dmitry V. Levin <ldv@altlinux.org>
1512
Roland McGrath9d721f22005-02-02 04:45:09 +00001513 * configure.ac: Use AC_GNU_SOURCE macro instead of changing CFLAGS.
1514 * defs.h [HAVE_CONFIG_H]: Include config.h first.
1515 * strace.c: Include "defs.h" first.
1516 Fixes RH#143370.
1517
Roland McGrathac6b7bb2005-02-02 04:42:56 +00001518 * syscall.c (call_summary): Fix potential NULL dereference.
1519 Fixes RH#143369.
1520
Roland McGrathdd9efd82005-02-02 04:40:36 +000015212004-12-19 Dmitry V. Levin <ldv@altlinux.org>
1522
1523 * syscall.c (qual_signal): Check bounds for numeric signal names.
1524 Fix parser of symbolic signal names.
1525 Fix return code, as required by qualify() function.
1526 * syscall.c (qual_desc): Check bounds for descriptor number.
1527 * syscall.c (qual_syscall): Correct return code, to be consistent
1528 with qualify() and other qual_* functions.
1529 Fixes RH#143362.
1530
Roland McGrath1b3ca102005-02-02 02:49:03 +000015312005-02-01 Roland McGrath <roland@redhat.com>
1532
Roland McGrath0dfeed62005-02-02 04:36:38 +00001533 * system.c [LINUX] (MS_MANDLOCK, MS_NOATIME, MS_NODIRATIME, MS_BIND,
1534 MS_MOVE, MS_REC, MS_VERBOSE, MS_POSIXACL, MS_ACTIVE, MS_NOUSER):
1535 New macros.
1536 [LINUX] (mount_flags): Add them.
1537 [LINUX] (sys_mount): If any of (MS_BIND|MS_MOVE|MS_REMOUNT) bits are
1538 set in the flags argument, don't try to fetch the filesystem string.
1539 Fixes RH#141932.
1540
Roland McGrathdc26fff2005-02-02 04:19:19 +00001541 * config.guess: Update from canonical version, timestamp 2004-11-12.
1542 * config.sub: Likewise, timestamp 2004-11-30.
1543
Roland McGrathb2ba50b2005-02-02 04:16:58 +00001544 * process.c [LINUX] [X86_64] (sys_arch_prctl): New function.
1545 * linux/syscall.h: Declare it.
1546 * linux/x86_64/syscallent.h: Use it.
1547 Part of RH#142667.
1548
1549 * process.c (sys_sched_setscheduler): Use %#lx format for bad pointer.
1550 (sys_sched_getparam, sys_sched_setparam): Likewise.
1551 Part of RH#142667.
1552
1553 * signal.c [HAVE_SIGACTION] [LINUX && X86_64] (SA_RESTORER): Define
1554 here too.
1555 Part of RH#142667.
1556
1557 * linux/syscallent.h: Use sys_mincore instead of printargs.
1558 * linux/x86_64/syscallent.h: Likewise. Also use sys_getrlimit,
1559 sys_semtimedop, sys_umount2.
1560 Part of RH#142667.
1561
Roland McGrath28eace82005-02-02 03:51:22 +00001562 * syscall.c (qual_signal): Fix inverted return value and bogus
1563 argument to qualify_one in the named case.
1564
Roland McGrath5f221c32005-02-02 03:38:49 +00001565 * file.c (print_xattr_val): Don't use auto array sized by syscall
1566 argument. Use malloc instead, so it can fail for insane values.
1567 Fixes Debian bug #283704.
1568
Roland McGrath53962332005-02-02 03:11:43 +00001569 * net.c (sys_getsockopt): Fix a format %ld -> %d.
1570
1571 * linux/syscall.h [IA64] (SYS_semtimedop): #undef it.
1572
Roland McGrathbc484bd2005-02-02 03:07:24 +00001573 * syscall.c (syscall_enter) [X86_64]: Fix 32-bit argument register map
1574 not to double the middle entry!
1575 Fixes RH#146093.
1576
Roland McGrath6722dcf2005-02-02 02:54:35 +00001577 * linux/x86_64/syscallent.h: Fix exit_group entry.
1578
Roland McGrath1b3ca102005-02-02 02:49:03 +00001579 * util.c (getpc) [S390 || S390X]: Implement it.
1580 Patch by David Wilder <wilder@us.ibm.com>.
1581
1582 * linux/ia64/syscallent.h: Add fadvise64, fstatfs64, statfs64, mbind,
1583 [gs]et_mempolicy, mq_*, sys_kexec_load, vserver, and waitid.
1584 Fixes RH#146245.
1585
15862005-01-22 Andreas Schwab <schwab@suse.de>
1587
1588 * net.c (sys_getsockopt): Change type of len to int.
1589
Roland McGrath914f3aa2004-10-19 23:00:14 +000015902004-10-19 Roland McGrath <roland@redhat.com>
1591
Roland McGrathb0756892004-10-20 02:17:58 +00001592 * configure.ac, NEWS: Version 4.5.8.
1593 * debian/changelog, strace.spec: 4.5.8-1.
1594
Roland McGrathbe4eeb92004-10-20 02:24:28 +00001595 * file.c (sys_fadvise64): Conditionalize just on [LINUX].
1596
Roland McGrathb0756892004-10-20 02:17:58 +00001597 * configure.ac: Check for sys/epoll.h.
1598 * desc.c: Protect #include <sys/epoll.h> with [HAVE_SYS_EPOLL_H].
1599 (epollctls, epollevents): Protect each entry with #ifdef on its macro.
1600
Roland McGrathe26a3782004-10-20 02:04:19 +00001601 * strace.c (handle_group_exit): Don't detach leader that wasn't
1602 TCB_ATTACHED. Instead mark it with TCB_GROUP_EXITING.
1603 Remove droptcb loop at end, no longer required since 2.6 reports each
1604 thread death.
1605 Fixes RH#135254.
1606
Roland McGrath712bc7a2004-10-20 01:00:45 +00001607 * strace.c (trace): Use handle_group_exit for non-TCB_ATTACHED child
1608 taking signal when it has nclone_threads > 0.
1609
Roland McGrath712bc7a2004-10-20 01:00:45 +00001610 * strace.c (handle_group_exit, trace): Mark leader with
1611 TCB_GROUP_EXITING and don't be surprised at child deaths when their
1612 leader has it set.
1613 Fixes RH#132150.
1614
Roland McGrath223a3ff2004-10-19 23:33:53 +00001615 * process.c (WCOREFLAG): Define if not defined.
1616 (W_STOPCODE, W_EXITCODE): Likewise.
1617 Reported by Marty Leisner <mleisner@eng.mc.xerox.com>.
1618
1619 * sock.c [! LINUX]: Include <sys/socket.h> before <sys/sockio.h>.
1620 Reported by Marty Leisner <mleisner@eng.mc.xerox.com>.
1621
1622 * debian/rules: Make strace64.1.gz symlink to strace.1.gz instead of
1623 strace64.1 to strace.1, which doesn't exist.
1624 Fixes Debian bug #269220.
1625
16262004-09-05 Phil Blundell <pb@nexus.co.uk>
1627
1628 * linux/arm/syscallent.h: New file.
1629
16302004-10-19 Roland McGrath <roland@redhat.com>
1631
1632 * debian/rules (DEB_BUILD_GNU_TYPE, CONFIG_OPTS): New variables.
1633 [$(DEB_HOST_GNU_TYPE) == s390-linux] (build64, HOST64, CC64): Set them.
1634 (build/Makefile): Use $(CONFIG_OPTS).
1635 (build64/Makefile): Pass --host as well as --build.
1636 From Bastian Blank <waldi@debian.org>.
1637 Fixes Debian bug #271500.
1638
1639 * linux/hppa/syscallent.h: Update for 2.6.9 syscalls.
1640 From Randolph Chung <tausq@debian.org>
1641 Fixes Debian bug #273887.
1642
Roland McGrath914f3aa2004-10-19 23:00:14 +00001643 * file.c (sys_llseek): Revert last change.
1644
Roland McGrath223a3ff2004-10-19 23:33:53 +000016452004-09-14 Richard Henderson <rth@twiddle.net>
1646
1647 * linux/alpha/syscallent.h: Add tgkill, *stat64, vserver, mbind,
1648 [gs]et_mempolicy, mq_*, waitid.
1649
Roland McGrath51f9ac02004-10-07 18:51:22 +000016502004-10-07 Roland McGrath <roland@redhat.com>
1651
Roland McGrath0aa53f62004-10-07 19:09:23 +00001652 * file.c (sys_llssek, sys_readahead, sys_fadvise64, sys_fadvise64_64):
1653 Use LONG_LONG macro.
1654 * io.c (sys_pread, sys_pwrite, sys_sendfile): Likewise.
1655
Roland McGrath61b324b2004-10-07 18:59:13 +00001656 * linux/x86_64/syscallent.h: Fix botched table entries.
1657 From Ulrich Drepper <drepper@redhat.com>.
1658
Roland McGrathaa08d712004-10-07 18:53:17 +00001659 * mem.c [LINUX] (sys_mbind, sys_set_mempolicy, sys_get_mempolicy):
1660 New functions.
1661 * linux/syscall.h: Declare them.
1662 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath61b324b2004-10-07 18:59:13 +00001663 From Ulrich Drepper <drepper@redhat.com>.
1664
Roland McGrathaa08d712004-10-07 18:53:17 +00001665 * linux/syscallent.h: Handle mbind, set_mempolicy, get_mempolicy.
1666 From Ulrich Drepper <drepper@redhat.com>.
1667
Roland McGrath51f9ac02004-10-07 18:51:22 +00001668 * file.c [LINUX && (I386 || X86_64)] (sys_fadvise64, sys_fadvise64_64):
1669 New functions.
1670 * linux/syscall.h: Declare them.
1671 * linux/syscallent.h: Handle fadvise64 and fadvise64_64 using those.
Roland McGrathaa08d712004-10-07 18:53:17 +00001672 * linux/x86_64/syscallent.h: Likewise.
Roland McGrath51f9ac02004-10-07 18:51:22 +00001673 From Ulrich Drepper <drepper@redhat.com>.
1674
Roland McGrath2af128b2004-10-06 22:32:04 +000016752004-09-13 Dmitry V. Levin <ldv@altlinux.org>
1676
1677 * linux/ioctlsort.c (main): Omit duplicate lines
1678 (with same name and code) from output.
1679 * linux/ioctlent.sh: Build the list of ioctls defined in
1680 scsi/sg.h (0x22..), scsi/scsi.h and scsi/scsi_ioctl.h (0x53..),
1681 as suggested by Peter Jones <pjones@redhat.com>
1682 * linux/ioctlent.h: Regenerated.
1683 Fixes RH#129808.
1684
Roland McGrath79367f82004-10-06 22:28:17 +000016852004-09-13 Ulrich Drepper <drepper@redhat.com>
1686 Dmitry V. Levin <ldv@altlinux.org>
1687
1688 * time.c [LINUX] (print_rtc): New function, for printing rtc_time
1689 structure.
1690 [LINUX] (rtc_ioctl): New function, for parsing RTC_* ioctls.
1691 * ioctl.c [LINUX] (ioctl_decode): Call rtc_ioctl.
1692 * defs.h [LINUX]: Declare rtc_ioctl.
1693 Fixes RH#58606.
1694
Roland McGrath288a3a02004-10-06 22:12:09 +000016952004-10-06 Roland McGrath <roland@redhat.com>
1696
Roland McGrathd2553bb2004-10-06 22:23:55 +00001697 * desc.c [LINUX] (sys_epoll_create, sys_epoll_ctl, sys_epoll_wait):
1698 New functions.
1699 * linux/syscall.h: Declare them.
1700 * linux/syscallent.h: Use those for epoll_* syscalls.
1701 * linux/alpha/syscallent.h: Likewise.
1702 * linux/hppa/syscallent.h: Likewise.
1703 * linux/ia64/syscallent.h: Likewise.
1704 * linux/powerpc/syscallent.h: Likewise.
1705 * linux/s390/syscallent.h: Likewise.
1706 * linux/s390x/syscallent.h: Likewise.
1707 * linux/sparc/syscallent.h: Likewise.
1708 * linux/sparc64/syscallent.h: Likewise.
1709 * linux/sparc64/syscallent2.h: Likewise.
1710 * linux/x86_64/syscallent.h: Likewise.
1711 From Ulrich Drepper <drepper@redhat.com>.
1712 Fixes RH#134463.
1713
Roland McGrath2803d102004-10-06 22:15:18 +00001714 * resource.c (resources): Add RLIMIT_LOCKS, RLIMIT_SIGPENDING,
1715 and RLIMIT_MSGQUEUE, if defined.
1716 From Ulrich Drepper <drepper@redhat.com>.
1717 Fixes RH#133594.
1718
Roland McGrath288a3a02004-10-06 22:12:09 +00001719 * net.c [HAVE_SENDMSG] (printcmsghdr): New function.
1720 (printmsghdr): Use it.
Roland McGrath2803d102004-10-06 22:15:18 +00001721 From Ulrich Drepper <drepper@redhat.com>.
1722 Fixes RH#131689.
Roland McGrath288a3a02004-10-06 22:12:09 +00001723
1724 * file.c (sprintmode): Add const to return type.
1725 (sprintfstype): Likewise.
1726 * signal.c (printsiginfo): Add a const.
1727
Roland McGrath4455b1d2004-10-06 22:03:22 +000017282004-09-15 Roland McGrath <roland@redhat.com>
1729
1730 * linux/x86_64/syscallent.h: Use sys_waitid.
1731
1732 * linux/syscallent.h: waitid takes 5 arguments, and is in TP category.
1733 * process.c (sys_waitid): Handle fifth argument (struct rusage *).
1734
Roland McGrath813b8af2004-09-11 08:13:27 +000017352004-09-11 Roland McGrath <roland@redhat.com>
1736
1737 * time.c (sys_clock_nanosleep): Print zero flags arg correctly.
1738 (sys_timer_settime): Likewise.
1739 (printsigevent): Print signals by name for SIGEV_SIGNAL.
1740 (sys_timer_create): Print clock ID symbolically.
1741 From Ulrich Drepper <drepper@redhat.com>.
1742 Fixes RH#131420.
1743
Michal Ludvig51d1ebc2004-09-07 14:06:03 +000017442004-09-07 Michal Ludvig <mludvig@suse.cz>
1745
1746 * defs.h (nioctlents1, nsignals2): Fix typos in decls.
1747
Roland McGrath4ee6e692004-09-04 03:39:26 +000017482004-09-03 Roland McGrath <roland@redhat.com>
1749
Roland McGrathce361382004-09-04 04:20:49 +00001750 * syscall.c (qual_options): Add const to defn.
1751 Update all uses.
1752 (call_count, error_count, tv_count): Variables removed.
1753 (struct call_counts, counts): New type and variable.
1754 Update all users of the old three to use the new array of structs.
1755 (trace_syscall): Allocate counts on first use.
1756 (sorted_count): Variable removed.
1757 (call_summary): Allocate locally.
1758
Roland McGrath77019f72004-09-04 03:53:18 +00001759 * syscall.c (sysent0, sysent1, sysent2, sysent): Add const to defn.
1760 (nsyscalls0, nsyscalls1, nsyscalls2): Likewise.
1761 (errnoent0, errnoent1, errnoent2, errnoent): Likewise.
1762 (nerrnos0, nerrnos1, nerrnos2): Likewise.
1763 * signal.c (signalent0, signalent1, signalent2): Likewise.
1764 (nsignals0, nsignals1, nsignals2): Likewise.
1765 (signame): LIkewise.
1766 * ioctl.c (ioctlent0, ioctlent1, ioctlent2): Likewise.
1767 (nioctlents0, nioctlents1, nioctlents2): Likewise.
1768 (ioctl_lookup, ioctl_next_match): Likewise.
1769 * defs.h: Update decls.
1770 * io.c (sys_ioctl): Update users.
1771
Roland McGrath4ee6e692004-09-04 03:39:26 +00001772 * util.c (xlookup, printxval, addflags, printflags): Use const for
1773 struct xlat * argument.
1774 * defs.h (xlookup, printxval, addflags, printflags): Update decls.
1775 * bjm.c: Add const to all struct xlat defns.
1776 * desc.c: Likewise.
1777 * file.c: Likewise.
1778 * ipc.c: Likewise.
1779 * mem.c: Likewise.
1780 * net.c: Likewise.
1781 * proc.c: Likewise.
1782 * process.c: Likewise.
1783 * resource.c: Likewise.
1784 * signal.c: Likewise.
1785 * sock.c: Likewise.
1786 * stream.c: Likewise.
1787 * system.c: Likewise.
1788 * term.c: Likewise.
1789 * time.c: Likewise.
1790 * util.c: Likewise.
1791
Roland McGrathb036f582004-09-01 19:39:59 +000017922004-09-01 Roland McGrath <roland@redhat.com>
1793
1794 * linux/x86_64/syscallent.h: Add new entries for timer_*, clock_*, and
1795 mq_* syscalls, and names only for new calls up to 252.
1796 * linux/syscallent.h: Add waitid.
1797 * linux/x86_64/syscallent.h: Likewise.
1798 * linux/syscall.h: Declare sys_waitid.
1799
1800 * process.c (internal_wait): Take second arg giving index of flags
1801 argument.
1802 * defs.h: Update prototype.
1803 * syscall.c (internal_syscall): Update caller.
1804 Also use internal_wait for SYS_waitid.
1805 * process.c (sys_waitid): Define for [LINUX] as well.
1806 Don't tweak TCB_SUSPENDED--internal_wait does that.
1807 (waitid_types): Conditionalize use of nonstandard P_* macros.
1808
Roland McGrath1651c1c2004-08-31 07:16:21 +000018092004-08-31 Roland McGrath <roland@redhat.com>
1810
Roland McGrath0ef93b72004-08-31 08:17:26 +00001811 * configure.ac, NEWS: Version 4.5.7.
Roland McGrathb036f582004-09-01 19:39:59 +00001812 * debian/changelog: 4.5.7-1.
1813 * strace.spec: 4.5.7-2.
Roland McGrath0ef93b72004-08-31 08:17:26 +00001814
Roland McGrathf5fcbc12004-08-31 08:41:59 +00001815 * debian/rules: Rewrite sparc64 change of 2004-07-12.
1816 Always do each build in a separate build directory.
Roland McGrath0ef93b72004-08-31 08:17:26 +00001817 Fixes Debian bug #254728.
1818
Roland McGrathf5fcbc12004-08-31 08:41:59 +00001819 * time.c (clocknames): Use #ifdef around CLOCK_* uses.
1820
Roland McGrathdc025fa2004-08-31 07:48:03 +00001821 * strace.1: Say that -c shows system CPU time, not real time.
1822 Fixes Debian bug #254438.
1823
1824 * syscall.c (dumpio): Match pread and pwrite system calls too.
1825 Fixes Debian bug #239947.
1826
Roland McGrath1651c1c2004-08-31 07:16:21 +00001827 * net.c (sockoptions): Add all SO_* macros known in Linux 2.6.9.
1828 Fixes Debian bug #171653.
1829
Roland McGrath8e593d22004-08-31 07:03:43 +000018302004-07-12 Dmitry V. Levin <ldv@altlinux.org>
1831
1832 * signal.c [LINUX] (parse_sigset_t): Fix hex strings parser.
1833 Fixes RH#128091.
1834
Roland McGratha0b9ef12004-08-31 06:30:51 +000018352004-08-30 Roland McGrath <roland@redhat.com>
1836
Roland McGrath0a053252004-08-31 07:02:00 +00001837 * strace.c (main): Don't call fake_execve under -c.
1838 From Ulrich Drepper <drepper@redhat.com>.
1839 Fixes RH#129166.
1840
1841 * net.c (sockipoptions): Add some options.
1842 [SOL_IPV6] (sockipv6options): New variable.
1843 (sys_getsockopt, printsockopt): Use it for SOL_IPV6 level.
1844 From Ulrich Drepper <drepper@redhat.com>.
1845 Fixes RH#128391.
1846
Roland McGrath7fbbf022004-08-31 06:52:49 +00001847 * time.c (clocknames): New variable, symbolic names for clock_t.
1848 (sys_clock_settime, sys_clock_gettime, sys_clock_nanosleep): Use it.
1849 From Ulrich Drepper <drepper@redhat.com>.
1850 Fixes RH#129378.
1851
Roland McGrath3a71f192004-08-31 06:49:09 +00001852 * system.c (personality_options): Hard-code values here.
1853 Don't #include <linux/personality.h> at all.
Roland McGrath1651c1c2004-08-31 07:16:21 +00001854 Fixes RH#130965 and Debian bug #40588.
Roland McGrath3a71f192004-08-31 06:49:09 +00001855
Roland McGratha0b9ef12004-08-31 06:30:51 +00001856 * file.c (print_xattr_val): New function to show attribute values.
1857 (sys_setxattr, sys_fsetxattr, sys_getxattr, sys_fgetxattr): Use it.
1858 From Ulrich Drepper <drepper@redhat.com>.
1859 Fixes RH#131177.
1860
Roland McGrath90a5a942004-07-12 07:04:55 +000018612004-07-12 Roland McGrath <roland@redhat.com>
1862
Roland McGrathd51619a2004-07-12 07:56:00 +00001863 * configure.ac, NEWS: Version 4.5.6.
1864 * strace.spec, debian/changelog: 4.5.6-1.
1865
Roland McGrath05cf2952004-07-12 07:54:09 +00001866 * Makefile.am (EXTRA_DIST): Add linux/sparc64 files.
1867
1868 * debian/rules: On sparc-linux, build strace64 as well.
1869 From Ben Collins <bcollins@debian.org>.
1870 Fixes Debian bug #254728.
1871
18722004-07-07 David S. Miller <davem@nuts.davemloft.net>
1873
1874 * linux/sparc/syscallent.h: Sync with reality.
1875 * linux/sparc/syscall.h (sys_sendfile64, sys_futex, sys_gettid,
1876 sys_sched_setaffinity, sys_sched_getaffinity, sys_setxattr,
1877 sys_lsetxattr, sys_fsetxattr, sys_getxattr, sys_lgetxattr,
1878 sys_fgetxattr, sys_listxattr, sys_llistxattr, sys_flistxattr,
1879 sys_removexattr, sys_lremovexattr, sys_fremovexattr,
1880 sys_remap_file_pages, sys_readahead, sys_tgkill, sys_statfs64,
1881 sys_fstatfs64, sys_clock_settime, sys_clock_gettime,
1882 sys_clock_getres, sys_clock_nanosleep, sys_timer_create,
1883 sys_timer_settime, sys_timer_gettime): New declarations.
1884 * linux/sparc64/dummy2.h, linux/sparc64/syscallent2.h,
1885 linux/sparc64/syscall.h, linux/sparc64/errnoent.h,
1886 linux/sparc64/errnoent1.h, linux/sparc64/errnoent2.h,
1887 linux/sparc64/ioctlent.h, linux/sparc64/ioctlent1.h,
1888 linux/sparc64/ioctlent2.h, linux/sparc64/signalent.h,
1889 linux/sparc64/signalent.h, linux/sparc64/signalent.h,
1890 linux/sparc64/signalent1.h, linux/sparc64/signalent2.h,
1891 linux/sparc64/syscall1.h, linux/sparc64/syscallent.h,
1892 linux/sparc64/syscallent1.h: New files.
1893 * defs.h (LINUXSPARC): Define also when SPARC64.
1894 (LINUX && SPARC64): Set SUPPORTED_PERSONALITIES to 3.
1895 Ignore SIGTRAP after execve by defining TCB_WAITEXECVE.
1896 Define possibly missing __NR_exit_group. Declare getrval2.
1897 * configure.ac (sparc64): New architecture case.
1898 * file.c (stat_sparc64): New structure.
1899 (printstat_sparc64): New output routine for that.
1900 (printstat): Call it, if personality is 2.
1901 (printstat64): Likewise.
1902 * util.c: Conditionalize ptrace defines on LINUXSPARC
1903 not LINUX && SPARC.
1904 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1905 to PTRACE_FOOREGS64 so that more sparc code can be shared
1906 between 64-bit and 32-bit.
1907 (_hack_syscall5): Correct trap number when SPARC64.
1908 (PTRACE_WRITE{TEXT,DATA}): Add SPARC64 to ifdef guard.
1909 (getpc): Handle SPARC64 && LINUX.
1910 (printcall): Likewise.
1911 (arg fetching/setting): Use same code for SPARC64 LINUX
1912 as for SPARC.
1913 (setbpt): Handle SPARC64 && LINUX.
1914 (clearbpt): Likewise.
1915 * signal.c: Conditionalize ptrace defines on SPARC and
1916 SPARC64.
1917 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1918 to PTRACE_FOOREGS64 so that more sparc code can be shared
1919 between 64-bit and 32-bit.
1920 (m_siginfo): Use same definition on SPARC64 as SPARC.
1921 (sys_sigreturn): Handle LINUX && SPARC64.
1922 * syscall.c: Conditionalize ptrace defines on SPARC and
1923 SPARC64.
1924 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1925 to PTRACE_FOOREGS64 so that more sparc code can be shared
1926 between 64-bit and 32-bit.
1927 (getscno): Use same static state on SPARC64 as SPARC,
1928 and add SPARC64 handling.
1929 (get_error): Handle LINUX && SPARC64.
1930 (force_result): Likewise.
1931 (syscall_enter): Likewise.
1932 (trace_syscall): Handle sys_socketcall and sys_ipc on SPARC64
1933 just like SPARC.
1934 (getrval2): Handle LINUX && SPARC64.
1935 * process.c: Conditionalize ptrace defines on SPARC and
1936 SPARC64.
1937 (SPARC64 && LINUX): Define r_pc to r_tpc, and PTRACE_FOOREGS
1938 to PTRACE_FOOREGS64 so that more sparc code can be shared
1939 between 64-bit and 32-bit.
1940 (change_syscall): Handle LINUX && SPARC64.
1941 (struct_user_offsets): Ifdef out those which do not exist
1942 on SPARC64.
1943 * net.c (sys_pipe): Handle LINUX && SPARC64.
1944 * ioctl.c: Fix initializer typo for nioctlents2, was
1945 nioctlents1 by accident.
1946
19472004-06-28 Andreas Schwab <schwab@suse.de>
1948
1949 * process.c (internal_exec): Move TCB_WAITEXECVE handling here.
1950 (sys_execve): Remove it here.
1951
19522004-07-12 Roland McGrath <roland@redhat.com>
1953
1954 * Makefile.am (EXTRA_DIST): Add linux/sh64/syscallent.h.
1955
1956 * debian/control (Section): Move to utils, matching Debian override.
1957
Roland McGrath23e86d62004-07-12 07:13:12 +00001958 * net.c (addrfams): Make variable global.
1959 * sock.c (sock_ioctl): Decode the arguments for SIOCGIFNAME,
1960 SIOCGIFINDEX, and SIOCGIFCONF.
1961 From Ulrich Drepper <drepper@redhat.com>.
1962 Fixes RH#126917.
1963
Roland McGrath90a5a942004-07-12 07:04:55 +00001964 * linux/ioctlsort.c: Add some #includes.
1965 [POWERPC]: Kludge out high bits.
1966 * linux/ia64/ioctlent.h: Regenerated using RHEL3 headers.
1967 * linux/powerpc/ioctlent.h: Likewise.
1968
Roland McGrath16110b22004-07-12 05:45:26 +000019692004-07-11 Roland McGrath <roland@redhat.com>
1970
Roland McGrath90a5a942004-07-12 07:04:55 +00001971 * linux/ioctlent.sh: Replace asm with $asm in all places.
1972
Roland McGrath16110b22004-07-12 05:45:26 +00001973 * configure.ac: Add I386 as AM_CONDITIONAL.
1974 * Makefile.am [LINUX]: Add maintainer-mode rules to regenerate
1975 the ioctlent.h file.
1976
Roland McGrath533e52a2004-07-08 19:00:25 +000019772004-07-08 Roland McGrath <roland@redhat.com>
1978
1979 * resource.c (sys_quotactl): Truncate first argument to 32 bits, since
1980 that's what the kernel will do.
1981
19822004-07-07 Roland McGrath <roland@redhat.com>
1983
1984 * linux/ioctlent.sh: Take optional second argument to use as directory
1985 name in place of `asm'.
1986
Roland McGrath2c72f3c2004-06-28 05:24:40 +000019872004-06-27 Roland McGrath <roland@redhat.com>
1988
1989 * configure.ac, NEWS: Version 4.5.5.
1990 * strace.spec, debian/changelog: 4.5.5-1.
1991
Roland McGratha2dec922004-06-23 01:40:57 +000019922004-06-22 Roland McGrath <roland@redhat.com>
1993
1994 * syscall.c (syscall_fixup) [LINUX && X86_64]: For 32-bit process,
1995 sign extend the low 32 bits of RAX to 64 bits.
Roland McGrath7a391df2004-06-23 01:41:30 +00001996 Fixes RH#126547.
Roland McGratha2dec922004-06-23 01:40:57 +00001997
1998 * syscall.c (force_result): [LINUX && X86_64]: Fix RAX*4 -> RAX*8.
1999
Roland McGrath0c542de2004-06-04 02:25:12 +000020002004-06-03 Roland McGrath <roland@redhat.com>
2001
Roland McGrath66a77f12004-06-04 02:36:03 +00002002 * configure.ac, NEWS: Version 4.5.4.
2003 * strace.spec, debian/changelog: 4.5.4-1.
2004
Roland McGrath0c542de2004-06-04 02:25:12 +00002005 * net.c (domains): Add many PF_* values #ifdef PF_*.
2006 (addrfams): Add many AF_* values #ifdef AF_*.
2007 Fixes Debian bug #250506.
2008
Roland McGrath337d3912004-06-04 02:03:15 +000020092004-05-02 Dmitry V. Levin <ldv@altlinux.org>
2010
2011 * linux/ioctlsort.c (compare): When ioctl codes equal, compare
2012 names.
2013 (main): Print a note that program output is generated by
2014 ioctlsort.
2015 * linux/ioctlent.sh: Build the list of ioctls defined in
2016 linux/fb.h (0x46..), linux/kd.h (0x4B..), linux/cdrom.h (0x53..),
2017 asm/ioctls.h (0x54..), linux/vt.h (0x56..), linux/videotext.h
2018 (0x71..), linux/videotext.h (0x72..), asm/sockios.h (0x89..),
2019 linux/sockios.h (0x89..), linux/wireless.h (0x8B..).
2020 * linux/ioctlent.h: Regenerated from linux-2.6.5.
2021 Fixes RH#122257.
2022
Roland McGrath6d52da62004-06-04 01:50:53 +000020232004-06-03 Roland McGrath <roland@redhat.com>
2024
Roland McGrathe01b8ce2004-06-04 02:01:54 +00002025 * debian/control (Architecture): Add amd64.
2026 Fixes Debian bug #246568.
2027
Roland McGrath6d52da62004-06-04 01:50:53 +00002028 * strace.c (main) [LINUX]: Expand TCBTAB as necessary for threads
2029 attached. Attach threads only under -f. Set TCB_FOLLOWFORK in them.
2030 (expand_tcbtab): New function, broken out of ...
2031 * process.c (fork_tcb): ... here, call that.
2032 * defs.h: Declare expand_tcbtab.
2033
Roland McGrath25e82592004-06-04 01:24:12 +000020342004-04-19 Roland McGrath <roland@redhat.com>
2035
2036 * process.c (printstatus): Add a space before | in output.
2037
Roland McGrathea2402e2004-04-16 22:28:48 +000020382004-04-16 Roland McGrath <roland@redhat.com>
2039
2040 * configure.ac: Version 4.5.3.
2041 * strace.spec, debian/changelog: 4.5.3-1.
2042
Roland McGrath025442c2004-04-16 21:59:05 +000020432004-03-18 Dmitry V. Levin <ldv@altlinux.org>
2044
2045 * resource.c (sys_quotactl) [LINUX]: Cast arithmetic shift operand
2046 from long to unsigned long, to fix output of the quotactl command
2047 parser.
Roland McGrathea2402e2004-04-16 22:28:48 +00002048 Fixes RH#118694.
Roland McGrath025442c2004-04-16 21:59:05 +00002049
Roland McGrath8d1bf3c2004-04-16 21:48:43 +000020502004-04-16 Roland McGrath <roland@redhat.com>
2051
Roland McGrath025442c2004-04-16 21:59:05 +00002052 * linux/s390/ioctlent.h, linux/s390x/ioctlent.h: Update DASD ioctls.
2053 From Maxim Shchetynin <maxim@de.ibm.com>.
2054
Roland McGrath8d1bf3c2004-04-16 21:48:43 +00002055 * configure.ac: Check for <mqueue.h>.
2056 * ipc.c (sys_mq_open, printmqattr) [! HAVE_MQUEUE_H]: Don't try to
2057 decode struct mq_attr.
Roland McGrath6508d332004-04-16 21:54:59 +00002058 * NEWS: Mention mq support.
Roland McGrath8d1bf3c2004-04-16 21:48:43 +00002059
2060 * linux/syscall.h: Support new mq_* syscalls on Linux.
2061 * linux/syscallent.h: Likewise.
2062 * linux/dummy.h: Likewise.
2063 * ipc.c: Likewise.
2064 * time.c (printsigevent): Handle SIGEV_THREAD.
2065 From Ulrich Drepper <drepper@redhat.com>.
2066 Fixes RH#120701.
2067
Roland McGrath6421d632004-04-14 02:46:35 +000020682004-04-13 Roland McGrath <roland@redhat.com>
2069
Roland McGrath085bae12004-04-14 02:54:02 +00002070 * net.c (msg_flags): Grok MSG_FIX, MSG_SYN, MSG_RST, MSG_NOSIGNAL,
2071 MSG_MORE.
2072 From Ulrich Drepper <drepper@redhat.com>.
2073 Fixes RH#120541.
2074
Roland McGrath6421d632004-04-14 02:46:35 +00002075 * process.c (printstatus): Mask out bits presented symbolically, and
2076 print "| 0xnnn" if the remaining bits are not all zero.
2077 Fixes Debian bug #240062.
2078
2079 * process.c (print_affinitylist): Rewritten to handle indirect values.
2080 (sys_sched_setaffinity, sys_sched_getaffinity): Update callers.
2081 From Ulrich Drepper <drepper@redhat.com>.
2082 Fixes RH#118685.
2083
2084 * acinclude.m4: Quote first argument to AC_DEFUN in all cases.
2085
Roland McGrath74dcbd82004-04-09 00:25:47 +000020862004-04-08 Roland McGrath <roland@redhat.com>
2087
2088 * strace.c (main) [LINUX]: When attaching for -p, look in
2089 /proc/PID/task for all threads and attach them as presumed
2090 CLONE_THREAD children.
2091 * NEWS: Mention the feature.
Roland McGrath085bae12004-04-14 02:54:02 +00002092 Fixes RH#120462.
Roland McGrath74dcbd82004-04-09 00:25:47 +00002093
Roland McGrath2d1ecca2004-03-02 08:07:20 +000020942004-03-02 Roland McGrath <roland@redhat.com>
2095
Roland McGrath6835f232004-03-02 08:50:47 +00002096 * util.c (setbpt): Fix one missed spot to use new arg0_index macro.
2097 From Michael Holzheu <HOLZHEU@de.ibm.com>.
2098
Roland McGrath2d1ecca2004-03-02 08:07:20 +00002099 * debian/control (Standards-Version): Update to 3.6.1.
2100
Roland McGrath861dc142004-03-01 20:57:16 +000021012004-03-01 Roland McGrath <roland@redhat.com>
2102
Roland McGrath801bf1f2004-03-02 06:38:40 +00002103 * configure.ac, NEWS: Version 4.5.2.
Roland McGrathea2402e2004-04-16 22:28:48 +00002104 * strace.spec, debian/changelog: 4.5.2-1.
Roland McGrath801bf1f2004-03-02 06:38:40 +00002105
Roland McGrath30423402004-03-02 06:54:57 +00002106 * strace.c (main): Avoid potential buffer overruns from ludicrous
2107 arguments or PATH values.
2108 * syscall.c (qual_signal): Bail out for too-long string.
2109
Roland McGrath59aea572004-03-02 06:17:11 +00002110 * mem.c [LINUX]: <asm/mman.h> -> <linux/mman.h>
Roland McGrath5586f9a2004-03-02 06:23:08 +00002111 Fixes Debian bug #223207.
Roland McGrath59aea572004-03-02 06:17:11 +00002112
2113 * linux/sparc/syscall.h: Copy linux/syscall.h decls of sys_sched_*.
Roland McGrath8f30c1d2004-03-02 06:09:35 +00002114
Roland McGrath7da8ff72004-03-01 22:10:58 +00002115 * configure.ac: Check for `struct user_desc' in <asm/ldt.h>.
2116 * process.c [HAVE_STRUCT_USER_DESC]: Use struct user_desc in place of
2117 struct modify_ldt_ldt_s.
2118 * mem.c [HAVE_STRUCT_USER_DESC]: Likewise.
2119
2120 * system.c (sysctl_vm): Conditionalize VM_* macro uses, add some more.
2121 From Tim Yamin <plasmaroo@gentoo.org>.
2122
Roland McGrathce238102004-03-01 22:04:09 +00002123 * process.c (sys_execve): Clear instead of set TCB_WAITEXECVE on
2124 erring syscall.
2125
Roland McGrathe58b8a02004-03-01 21:29:31 +00002126 * configure.ac: Check for `struct pt_all_user_regs'
2127 and `struct ia64_fpreg' in <sys/ptrace.h>.
Roland McGrath4695e942004-03-01 21:31:07 +00002128 * util.c, process.c, syscall.c, signal.c: Work around conflicts between
Roland McGrathe58b8a02004-03-01 21:29:31 +00002129 <sys/ptrace.h> and <linux/ptrace.h> for defining those types.
2130
Roland McGrath4695e942004-03-01 21:31:07 +00002131 * process.c (struct_user_offsets) [LINUX && IA64]: Conditionalize
2132 PT_AR_CSD and PT_AR_SSD uses in case of older kernel headers.
2133
Roland McGrath861dc142004-03-01 20:57:16 +00002134 * util.c [LINUX] (arg0_index, arg1_index): New macros.
2135 [S390 || S390X]: Define them with inverted values.
2136 (setbpt): Use them for u_arg indices.
2137
Roland McGrath24e8d312004-03-01 20:30:51 +000021382004-02-26 Andreas Schwab <schwab@suse.de>
2139
2140 * defs.h [LINUX && IA64]: Declare getrval2 also on IA64.
2141 * net.c (sys_pipe) [LINUX && IA64]: For IA64 use the two return values.
2142 * syscall.c (getrval2) [LINUX && IA64]: Implement for IA64.
2143
Roland McGrath176ac322004-03-01 20:28:19 +000021442004-03-01 Roland McGrath <roland@redhat.com>
2145
2146 * linux/dummy.h (sys_sched_getscheduler, sys_sched_setparam,
2147 sys_sched_getparam, sys_sched_setscheduler, sys_sched_getscheduler,
2148 sys_sched_get_priority_max, sys_sched_get_priority_min): Remove macros.
2149 * process.c [LINUX] (sys_sched_getscheduler, sys_sched_setparam,
2150 sys_sched_getparam, sys_sched_setscheduler, sys_sched_getscheduler,
2151 sys_sched_get_priority_min): New functions.
2152 From Ulrich Drepper <drepper@redhat.com>.
2153 Fixes RH#116990.
2154
Roland McGrath3d3f1c92004-02-20 23:21:34 +000021552004-02-20 Roland McGrath <roland@redhat.com>
2156
2157 * linux/hppa/syscallent.h: Update some syscalls.
2158 From Randolph Chung <tausq@debian.org>.
2159 Fixes Debian bug #231632.
2160
Roland McGrathb233c262004-02-20 22:56:55 +000021612003-12-31 David Mosberger <davidm@hpl.hp.com>
2162
2163 * process.c (internal_exit): For ia64, also recognize IA-32 252
2164 as exit_group().
2165 (change_syscall): For IA64, also support changing IA-32 syscalls.
2166 * syscall.c (internal_syscall): For IA64, also recognize IA-32
2167 syscall 252 (exit_group) as an internal_exit() syscall.
2168 * util.c (SYS_fork): For IA64, define them to the IA-32 syscall
2169 number.
2170 (SYS_vfork): Likewise.
2171 (arg_setup): For IA64 version, also support IA-32 syscalls.
2172 (get_arg0): Likewise.
2173 (get_arg1): Likewise.
2174 (set_arg0): Likewise.
2175 (set_arg1): Likewise.
2176
Roland McGrath13aeab32004-02-20 02:25:42 +000021772004-02-15 Anton Blanchard <anton@samba.org>
2178
2179 * linux/powerpc/syscallent.h: Add rtas call.
2180 Shift multiplexed syscalls to start at 300, we are already about
2181 to hit 256 real syscalls.
2182 * linux/syscall.h: SYS_socket_subcall is now 300 for [POWERPC].
2183
21842004-02-19 Roland McGrath <roland@redhat.com>
2185
2186 * strace.c (main): Use TCP->pid, not PID, in -p message.
2187 Fixes Debian bug #229802.
2188
Roland McGrathec0cf0b2004-01-13 10:18:52 +000021892004-01-13 Roland McGrath <roland@redhat.com>
2190
Roland McGrath13aeab32004-02-20 02:25:42 +00002191 * syscall.c (force_result) [LINUX] [S390 || S390X]: Remove bogus upeek
2192 call.
2193
Roland McGrathec0cf0b2004-01-13 10:18:52 +00002194 * stream.c (internal_stream_ioctl): Fix typo strict -> struct.
2195 Reported by Petter Reinholdtsen <pere@hungry.com>.
2196
Roland McGrath135db892004-01-13 10:14:04 +000021972003-12-31 David Mosberger <davidm@hpl.hp.com>
2198
2199 * process.c (struct_user_offsets) [IA64]: Fix up register name list.
2200
Roland McGrath13aeab32004-02-20 02:25:42 +000022012003-12-14 Anton Blanchard <anton@samba.org>
Roland McGrath135db892004-01-13 10:14:04 +00002202
Roland McGrath75155472004-01-13 10:17:00 +00002203 * file.c (sys_getdents64): Don't cast d_ino and d_off to unsigned long.
2204 Use %llu formats for them.
2205
Roland McGrath135db892004-01-13 10:14:04 +00002206 * file.c [LINUX] (fsmagic): Add SYSFS_MAGIC.
2207
2208 * linux/powerpc/syscallent.h: Update to include recently added
2209 syscalls.
2210
2211 * syscall.c (get_error) [POWERPC]: Cast result to unsigned long for
2212 ppc64, we were misreporting syscalls that really succeeded as having
2213 failed.
2214
Roland McGrath5b7aa682004-01-13 09:52:52 +000022152004-01-13 Roland McGrath <roland@redhat.com>
2216
Roland McGrath8950c692004-01-13 10:00:01 +00002217 * strace.1: Remove comment about vfork on Linux.
2218 Fixes Debian bug #223390.
2219
Roland McGrath5b7aa682004-01-13 09:52:52 +00002220 * file.c (direnttypes): Define under [LINUX] as well. Add DT_UNKNOWN.
2221 (sys_getdents64) [LINUX]: Print d_type field.
2222
Roland McGrath13aeab32004-02-20 02:25:42 +000022232003-12-15 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath8950c692004-01-13 10:00:01 +00002224
2225 * strace.c (trace) [WCOREDUMP]: Show coredump status of the
Roland McGrath135db892004-01-13 10:14:04 +00002226 killed process if available. Fixes RH#112117.
Roland McGrath8950c692004-01-13 10:00:01 +00002227
Roland McGrathcf283032003-11-14 02:57:31 +000022282003-11-13 Roland McGrath <roland@redhat.com>
2229
2230 * configure.ac, NEWS: Version 4.5.1.
2231 * strace.spec, debian/changelog: 4.5.1-1.
2232
Roland McGrath13aeab32004-02-20 02:25:42 +000022332003-09-06 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath0aac8722003-11-14 02:54:09 +00002234
2235 * defs.h (ioctl_lookup): Prototype change.
2236 * ioctl.c (ioctl_next_match): New function.
2237 * defs.h: Declare it.
2238 * io.c (sys_ioctl): Use it, to display all possible ioctl names
2239 when there's more than one match.
2240 * ioctl.c (ioctl_lookup): Likewise.
2241 * stream.c (internal_stream_ioctl): Likewise.
2242 Patch from Solar Designer <solar@openwall.com>.
2243
Roland McGrath09f7a012003-11-13 22:32:32 +000022442003-11-13 Roland McGrath <roland@redhat.com>
2245
2246 * linux/sh/syscallent.h: Use sys_setgroups32, sys_getgroups32.
2247 * linux/sh64/syscallent.h: Likewise.
2248
Roland McGrath13aeab32004-02-20 02:25:42 +000022492003-09-06 Dmitry V. Levin <ldv@altlinux.org>
Roland McGrath09f7a012003-11-13 22:32:32 +00002250
Roland McGrathf25ef392003-11-13 22:33:48 +00002251 Fixes for RH#105359.
Roland McGrath09f7a012003-11-13 22:32:32 +00002252 * util.c (printuid): New function.
2253 * defs.h: Declare it.
2254 * file.c (sys_chown): Use it.
2255 * file.c (sys_fchown): Likewise.
2256 * process.c (sys_setreuid, sys_setregid, sys_setresuid,
2257 sys_setresgid): Likewise.
Roland McGrath09f7a012003-11-13 22:32:32 +00002258 * linux/syscallent.h: Better handle getgid32, geteuid32, getegid32,
2259 setreuid32, setregid32, getgroups32, setgroups32, fchown32,
2260 setresuid32, getresuid32, setresgid32, getresgid32, chown32,
2261 setuid32, setgid32, setfsuid32, setfsgid32.
2262 * process.c [LINUX]: Define GETGROUPS32_T.
2263 * process.c [LINUX] (sys_setgroups32, sys_getgroups32):
2264 New functions.
2265 * linux/syscall.h (sys_setgroups32, sys_getgroups32):
2266 Declare them.
2267
Roland McGrath730e8c02003-11-11 21:24:28 +000022682003-11-11 Roland McGrath <roland@redhat.com>
2269
2270 * strace.c (main): Bail with usage error for missing command before we
2271 open the -o file or fiddle uids.
2272
Roland McGrathe52919b2003-11-06 23:41:33 +000022732003-11-06 Roland McGrath <roland@redhat.com>
2274
Roland McGratha0f32e02003-11-07 02:36:45 +00002275 * strace.c (main): Treat piped output more like file output.
2276 Disallow -ff with piped output. Fixes RH#105366.
2277 Reported by Dmitry V. Levin <ldv@altlinux.org>
2278
Roland McGrathe52919b2003-11-06 23:41:33 +00002279 * strace.c (tprintf): Check result of vfprintf and use perror when it
2280 fails while not writing to stderr itself. Fixes Debian bug #218762.
2281
2282 * net.c (printsock): Fix typo in #ifdef AF_NETLINK.
2283 From Ulrich Drepper <drepper@redhat.com>.
2284
Roland McGrathb67e8e32003-11-01 22:11:29 +000022852003-11-01 Roland McGrath <roland@redhat.com>
2286
2287 * syscall.c (trace_syscall) [LINUX]: Calculate ONE_TICK once using
2288 setitimer rather than hard-coding a value based on HZ.
Roland McGrathd4897f82003-11-01 22:13:35 +00002289 Fixes RH#108012, reported by Florian La Roche <laroche@redhat.com>.
Roland McGrathb67e8e32003-11-01 22:11:29 +00002290
Roland McGratha9f76da2003-10-22 06:11:36 +000022912003-10-21 Roland McGrath <roland@redhat.com>
2292
Roland McGrath7aa6d202003-10-22 06:16:42 +00002293 * strace.1: Fixed a few spelling errors.
Roland McGrathb67e8e32003-11-01 22:11:29 +00002294 Fixes Debian bug #217008.
Roland McGrath7aa6d202003-10-22 06:16:42 +00002295
Roland McGratha9f76da2003-10-22 06:11:36 +00002296 * syscall.c: Revert last change, was broken.
2297
Roland McGrath8c74bd92003-10-01 07:50:34 +000022982003-10-01 Roland McGrath <roland@redhat.com>
2299
Roland McGrathe7da3502003-10-01 21:59:50 +00002300 * process.c (internal_clone): Don't suspend parent when call requested
2301 a specific PID that is not a traced child.
2302
Roland McGrath8c74bd92003-10-01 07:50:34 +00002303 * signal.c [LINUX] (parse_sigset_t): Rewrite to process hex strings
2304 from right to left so we don't have to presume the size.
Roland McGrathe7da3502003-10-01 21:59:50 +00002305 Reported by David Woodhouse <dwmw2@redhat.com>.
Roland McGrath8c74bd92003-10-01 07:50:34 +00002306
Roland McGrath268e9042003-09-25 23:06:12 +000023072003-09-25 Roland McGrath <roland@redhat.com>
2308
2309 * mem.c (mmap_prot) [PROT_SEM, PROT_GROWSDOWN, PROT_GROWSUP]: Include
2310 these in the table if they are defined.
2311
Roland McGrath4f59bab2003-09-24 22:22:49 +000023122003-09-24 Roland McGrath <roland@redhat.com>
2313
2314 * configure.ac, NEWS: Version 4.5.
2315 * strace.spec, debian/changelog: 4.5-1.
2316
2317 * syscall.c (get_scno) [LINUX] [S390 || S390X]: Bail out of
2318 instruction decoding branch if TCB_INSYSCALL is clear.
2319 Reported by <jochen@penguin-breeder.org>.
2320
2321 * linux/ioctlent.h: Swap order of overloaded TC* and SNDCTL_* values.
2322
Roland McGrath7633f1e2003-09-23 22:19:43 +000023232003-09-23 Roland McGrath <roland@redhat.com>
2324
Roland McGrath4f59bab2003-09-24 22:22:49 +00002325 * strace.spec: On ppc64 (maybe others later), create an strace64
2326 package as well containing just /usr/bin/strace64.
2327
Roland McGrath7633f1e2003-09-23 22:19:43 +00002328 * signal.c (sprintsigmask): Print RT_%u for __SIGRTMIN..__SIGRTMAX.
2329 Fixes RH#104365.
2330
Roland McGrath109f3d32003-08-21 10:09:01 +000023312003-08-21 Roland McGrath <roland@redhat.com>
2332
Roland McGrath7633f1e2003-09-23 22:19:43 +00002333 * linux/syscallent.h: Fix mlock argument count. Fixes RH#101499.
Roland McGrath109f3d32003-08-21 10:09:01 +00002334 * linux/x86_64/syscallent.h: Likewise.
2335 * linux/s390/syscallent.h: Likewise.
2336 * linux/s390x/syscallent.h: Likewise.
2337
Roland McGrath5bc53452003-08-21 09:58:08 +000023382003-07-28 Daniel Jacobowitz <drow@mvista.com>
2339
2340 * defs.h (ALIGN64): Define for MIPS.
2341 * io.c (PREAD_OFFSET_ARG): Define.
2342 (sys_pread, sys_pwrite): Use it.
2343 * process.c (struct_user_offsets) [SH]: Check whether REG_XDREG0
2344 is defined.
2345 * linux/sh/syscallent.h (pread, pwrite): Take six arguments.
2346 (truncate64, ftruncate64): Pretty-print.
2347 * linux/mips/syscallent.h (pread, pwrite): Take six arguments.
2348 (truncate64, ftruncate64): Take four arguments.
2349
Roland McGrath4d8130c2003-07-17 09:24:04 +000023502003-07-17 Roland McGrath <roland@redhat.com>
2351
2352 * configure.ac, NEWS: Version 4.4.99.
2353 * strace.spec, debian/changelog: 4.4.99-1.
2354
Roland McGrath25969ce2003-07-17 09:03:22 +000023552003-07-15 Anton Blanchard <anton@samba.org>
2356
2357 * ipc.c: Add SHM_HUGETLB field.
2358 Mask out permission bits in msgget, semget and shmget before
2359 printing resource_flags.
2360 Mask execute permission bits (even though we dont currently
2361 use them).
2362
23632003-07-17 Roland McGrath <roland@redhat.com>
2364
2365 * linux/powerpc/syscallent.h (tgkill): New at 250.
2366
2367 * linux/syscallent.h: truncate64/ftruncate64 need 3 args.
2368 From Ulrich Drepper <drepper@redhat.com>.
2369
2370 * linux/syscallent.h: Handle statfs64, fstatfs64, utimes.
2371 * file.c (printstatfs): Print f_fsid and f_frsize.
2372 [LINUX] (printstatfs64, sys_statfs64, sys_fstatfs64): New functions.
2373 * linux/syscall.h: Add decls.
2374 From Ulrich Drepper <drepper@redhat.com>.
2375
23762003-07-09 Roland McGrath <roland@redhat.com>
2377
2378 * linux/ia64/syscallent.h (tgkill): New at 1235.
2379
Roland McGrath004d88d2003-07-09 09:48:21 +000023802003-07-05 Richard Henderson <rth@twiddle.net>
2381
2382 * process.c (sys_clone): Order arguments for alpha the same as x86_64.
2383 * syscall.c (ERESTART_RESTARTBLOCK): New.
2384 (trace_syscall): Print it.
2385 * linux/alpha/syscallent.h (osf_syscall): Name properly.
2386 (osf_set_program_attributes): Fix typo.
2387 (osf_nfssvc): Likewise.
2388 (osf_sigsendset): Likewise.
2389 (getdents64, gettid, readahead, tkill, setxattr, lsetxattr, fsetxattr,
2390 getxattr, lgetxattr, fgetxattr, listxattr, llistxattr, flistxattr,
2391 removexattr, lremovexattr, fremovexattr, futex, sched_setaffinity,
2392 sched_getaffinity, tuxcall, io_setup, io_destroy, io_getevents,
2393 io_submit, io_cancel, exit_group, lookup_dcookie, epoll_create,
2394 epoll_ctl, epoll_wait, remap_file_pages, set_tid_address,
2395 restart_syscall, fadvise, timer_create, timer_settime, timer_gettime,
2396 timer_getoverrun, timer_delete, clock_settime, clock_gettime,
2397 clock_getres, clock_nanosleep, semtimedop): New.
2398
23992003-07-08 Roland McGrath <roland@redhat.com>
2400
2401 * signal.c (sys_tgkill): New function.
2402 * linux/syscall.h: Declare it.
2403 * linux/syscallent.h: Add tgkill.
2404
Roland McGratha9a86192003-06-27 21:20:14 +000024052003-06-27 Roland McGrath <roland@redhat.com>
2406
2407 * configure.ac: Check for type `struct __old_kernel_stat'.
2408 * file.c (convertoldstat, printoldstat): Define under
2409 [LINUX && HAVE_STRUCT___OLD_KERNEL_STAT] rather than a list of archs.
2410 (sys_oldstat, sys_oldfstat, sys_oldlstat): Likewise.
2411 * linux/dummy.h [! HAVE_STRUCT___OLD_KERNEL_STAT]
2412 (sys_oldstat, sys_oldfstat, sys_oldlstat): #define to printargs.
2413
Roland McGrath9df23f92003-06-26 22:23:32 +000024142003-06-26 Roland McGrath <roland@redhat.com>
2415
Roland McGrath4fe23b52003-06-26 22:41:02 +00002416 * configure.ac: SHMEDIA -> SH64
2417 * defs.h: Likewise.
2418 * mem.c: Likewise.
2419 * process.c: Likewise.
2420 * sock.c: Likewise.
2421 * syscall.c: Likewise.
2422 * util.c: Likewise.
2423 * linux/shmedia/syscallent.h: Moved to ...
2424 * linux/sh64/syscallent.h: ... here.
2425
2426 * config.guess: Update from canonical version, timestamp 2003-06-17.
2427 * config.sub: Likewise.
2428
Roland McGrath8f340e32003-06-26 22:29:38 +00002429 * syscall.c (force_result) [LINUX] [ARM]: Fix variable usage.
2430 From: Joshua Neal <tinara@netpipeline.net>.
2431
Roland McGrathc2aa8ea2003-06-26 22:27:32 +00002432 * process.c [LINUX] (sys_futex): Grok FUTEX_REQUEUE and print 5th arg.
2433 * linux/syscallent.h: sys_futex argument count is now 5, not 4.
2434 * linux/ia64/syscallent.h: Likewise.
2435 * linux/powerpc/syscallent.h: Likewise.
2436 * linux/s390/syscallent.h: Likewise.
2437 * linux/s390x/syscallent.h: Likewise.
2438 * linux/x86_64/syscallent.h: Likewise.
2439 From Jakub Jelinek <jakub@redhat.com>.
2440
Roland McGrath9df23f92003-06-26 22:23:32 +00002441 * syscall.c (get_scno) [S390 || S390X]: Fix old vs new mode detection.
2442 From Michael Holzheu <HOLZHEU@de.ibm.com>.
2443
Roland McGrathee911632003-06-23 23:40:04 +000024442003-06-23 Roland McGrath <roland@redhat.com>
2445
2446 * net.c (sys_socket): Decode protocol for PF_INET6 same as PF_INET.
2447 From Ulrich Drepper <drepper@redhat.com>.
2448
Roland McGrathe84e6272003-06-11 05:38:01 +000024492003-06-10 Roland McGrath <roland@redhat.com>
2450
2451 * configure.ac, NEWS: Version 4.4.98.
2452 * strace.spec, debian/changelog: 4.4.98-1.
2453
Roland McGrath3634c272003-06-10 03:06:05 +000024542003-06-09 Roland McGrath <roland@redhat.com>
2455
Roland McGrath767b4302003-06-10 03:38:03 +00002456 * linux/s390x/syscallent.h: Update many syscalls.
2457 * linux/syscall.h (SYS_socket_subcall): Update [S390X] value.
2458
Roland McGrathc38d46e2003-06-10 03:31:34 +00002459 * linux/s390/syscallent.h: Update many syscalls.
2460 * linux/syscall.h (SYS_socket_subcall): Update [S390] value.
2461
Roland McGratheef1fde2003-06-10 03:07:47 +00002462 * linux/shmedia/syscallent.h: New file.
2463 From Stephen Thomas <stephen.thomas@superh.com>.
2464
Roland McGrath3634c272003-06-10 03:06:05 +00002465 * strace.c (trace): Print a message and newline for a WIFEXITED report
2466 from the process we just printed an unterminated syscall line for.
2467
Roland McGrathcf99f9c2003-06-03 07:18:28 +000024682003-06-03 Roland McGrath <roland@redhat.com>
2469
Roland McGrath2c1d5342003-06-03 23:28:58 +00002470 * util.c (printcall) [LINUX]: Fix typo [IA62] -> [IA64].
2471
2472 Linux/ARM improvements from Russell King <rmk@arm.linux.org.uk>:
2473 * defs.h [LINUX] (TCB_WAITEXECVE): Define for [ARM] too.
2474 * process.c (struct_user_offsets) [LINUX] [ARM]: Add ARM registers.
2475 * signal.c [LINUX] (sys_sigreturn) [ARM]: New case.
2476 * syscall.c (get_scno, syscall_fixup) [LINUX] [ARM]: Case rewritten.
2477 (get_error) [LINUX] [ARM]: Update.
2478 (syscall_enter) [LINUX] [ARM]: New case.
2479 * util.c (printcall) [LINUX] [ARM]: New case.
2480
2481 * debian/control (Standards-Version): Update to 3.5.10.
2482
Roland McGrathcf99f9c2003-06-03 07:18:28 +00002483 * strace.c (main): In PATH search, accept only a regular file with
2484 execute bits set. Fixes Debian bug #137103.
2485
Roland McGratha834fbe2003-06-02 19:37:56 +000024862003-06-02 Roland McGrath <roland@redhat.com>
2487
Roland McGrath454a0242003-06-03 01:35:32 +00002488 * strace.c (main): Set -q when given -o and not -p, and not when not
2489 given -o, to match what the man page always said.
2490 Fixes Debian bug #47113, #153678.
2491
Roland McGratha834fbe2003-06-02 19:37:56 +00002492 * configure.ac, NEWS: Version 4.4.97.
2493 * strace.spec, debian/changelog: 4.4.97-1.
2494
2495 * configure.ac, defs.h, mem.c, process.c, sock.c, syscall.c, util.c:
2496 Merged in SHmedia port from Stephen Thomas <stephen.thomas@superh.com>.
2497
2498 * config.guess: Update from ftp://ftp.gnu.org/pub/gnu/config/,
2499 timestamp 2003-05-22.
2500 * config.sub: Likewise, timestamp 2003-05-24.
2501
Roland McGrath5aae8772003-05-23 00:14:17 +000025022003-05-22 Roland McGrath <roland@redhat.com>
2503
Roland McGrathd0835362003-05-23 02:27:37 +00002504 * defs.h (struct tcb): New member `nzombies'.
2505 * strace.c (alloctcb): Initialize it.
2506 (droptcb): Increment our parent's zombie count.
2507 * process.c (internal_wait): Don't go into TCB_SUSPENDED if the
2508 process has zombies it can reap. On the way out, if we reaped
2509 an untraced process, decrement the zombie count.
2510
Roland McGrath7dfd4ed2003-05-23 01:08:50 +00002511 * process.c (sys_clone): Mask CSIGNAL out of flags and print that
2512 separately using signame.
2513
2514 * process.c (internal_clone) [TCB_CLONE_THREAD]: Use ARG_FLAGS instead
2515 of literal 0 for index. Consult the right flags without clobbering
2516 anything when we reparent the new child to the caller's parent thread.
2517
Roland McGrath031b0d82003-05-23 00:29:11 +00002518 * linux/s390/syscallent.h: Fix sys_clone argument count.
2519 * linux/s390x/syscallent.h: Likewise.
2520 * linux/mips/syscallent.h: Likewise.
2521 * linux/alpha/syscallent.h: Likewise.
2522 * linux/powerpc/syscallent.h: Likewise.
2523 * linux/sh/syscallent.h: Likewise.
2524 * linux/sparc/syscallent.h: Likewise.
2525 * linux/hppa/syscallent.h: Likewise.
2526
2527 * process.c [LINUX] [S390 || S390X] (ARG_CTID, ARG_TLS): Fix swapped
2528 indices. Reported by Jakub Jelinek <jakub@redhat.com>.
2529
2530 * signal.c [LINUX] (SI_SIGIO, SI_TKILL): New macros.
2531 [LINUX || SVR4] (siginfo_codes): Add strings for them.
2532
Roland McGrath5aae8772003-05-23 00:14:17 +00002533 * process.c (print_affinitylist): Fix loop condition.
2534 Reported by Ian Wienand <ianw@gelato.unsw.edu.au>.
2535
Roland McGrath872a4362003-04-10 18:58:33 +000025362003-04-10 Roland McGrath <roland@redhat.com>
2537
2538 * syscall.c (qual_desc): Return zero after parsing number.
2539 From Rob Leslie <rob@mars.org>, fixes Debian bug #188379.
2540
Roland McGrath808a4ba2003-04-08 01:47:02 +000025412003-04-07 Roland McGrath <roland@redhat.com>
2542
2543 * linux/syscallent.h: Handle semtimedop subcall of ipc syscall.
2544 * linux/syscall.h: Likewise.
2545 * ipc.c [LINUX] (sys_semtimedop): New function.
2546 From Ulrich Drepper <drepper@redhat.com>.
2547
2548 * ipc.c (sys_semget): Mask off permission bits for resource_flags.
2549 From Ulrich Drepper <drepper@redhat.com>.
2550
Roland McGrathcf43e902003-04-02 01:10:53 +000025512003-04-01 Philippe De Muyter <phdm@macqel.be>
2552
2553 * sock.c, stream.c: Check #ifdef LINUX, not linux.
2554 * file.c: Always provide sys_*attr, regardless of #ifdef XATTR_CREATE.
2555
Roland McGrath10a56fb2003-03-31 01:21:40 +000025562003-03-30 Roland McGrath <roland@redhat.com>
2557
2558 * configure.ac, NEWS: Version 4.4.96.
2559 * strace.spec, debian/changelog: 4.4.96-1.
2560
Roland McGrath347636f2003-03-31 01:05:16 +000025612003-02-26 Stuart Menefy <stuart.menefy@st.com>
2562
2563 Various fixes for SuperH [SH]:
2564 * mem.c (sys_old_mmap): mmap() parameters passed in registers
2565 * net.c (sys_pipe), syscall.c (getrval2): pipe() results returned
2566 in registers
2567 * process.c (change_syscall): Fixed register which holds system
2568 call number
2569 * util.c (arg0_offset, arg1_offset): provide definition
2570 * Makefile.am: Added new files in linux/sh
2571 * linux/sh/syscallent.h: New file.
2572 * linux/sh/errnoent.h: New file.
2573 * linux/sh/ioctlent.h: New file.
2574 * linux/sh/signalent.h: New file.
2575
2576 * linux/ioctlent.sh: Take an arg for location of header files
2577 * syscallent.sh: Replaced lost $
2578
Roland McGrath5467f262003-03-30 23:52:46 +000025792003-03-30 Roland McGrath <roland@redhat.com>
2580
2581 * time.c [LINUX]: Handle new Linux 2.5 clock/timer syscalls.
2582 * linux/syscall.h, linux/syscallent.h, linux/dummy.h: Likewise.
2583 From Ulrich Drepper <drepper@redhat.com>.
2584
2585 * linux/syscallent.h: Use sys_getrlimit for 191.
2586 Use name "old_getrlimit" for 76.
2587 Reported by Ulrich Drepper <drepper@redhat.com>.
2588
Roland McGrath5755ec52003-03-21 07:33:21 +000025892003-03-18 Roland McGrath <roland@redhat.com>
2590
2591 * process.c [LINUX] (sys_clone): Don't dereference parent_tid argument.
2592
Roland McGrath49bad882003-03-18 07:43:53 +000025932003-03-17 Roland McGrath <roland@redhat.com>
2594
2595 * linux/x86_64/syscallent.h: clone takes 5 args.
2596 * process.c [LINUX] (sys_clone) [X86_64]: Fix argument order.
2597
Roland McGrathf22e0c72003-03-15 21:01:43 +000025982003-03-15 Roland McGrath <roland@redhat.com>
2599
2600 * linux/x86_64/syscallent.h: Add exit_group syscall at 231.
2601
Roland McGrath27cad9a2003-03-14 10:33:06 +000026022003-03-14 Roland McGrath <roland@redhat.com>
2603
2604 * linux/x86_64/syscallent.h: Update and add many 2.5 syscalls.
2605
2606 * linux/ia64/syscallent.h: clone takes 5 arguments.
2607 * process.c [LINUX && IA64] (ARG_*): Update for 2.5 clone calls.
2608
Roland McGrath041900f2003-03-12 08:11:33 +000026092003-03-12 Roland McGrath <roland@redhat.com>
2610
Roland McGrath6fbb4e32003-03-12 09:54:45 +00002611 * linux/ia64/syscallent.h: Fix arg counts for clone and clone2.
2612 Use sys_clone for clone2.
2613 * linux/syscall.h: Don't declare sys_clone2.
2614 * process.c (sys_clone): Rewritten to handle both flavors,
2615 print all extra args depending on flag bits.
2616 (sys_clone2): Function removed.
2617
Roland McGrath041900f2003-03-12 08:11:33 +00002618 * linux/ia64/syscallent.h: Add a bunch of 2.5 syscalls.
2619
Roland McGrathb3f8fd62003-03-05 06:29:11 +000026202003-03-04 Roland McGrath <roland@redhat.com>
2621
2622 * syscall.c (get_scno) [IA64]: Do TCB_WAITEXECVE check only when
2623 TCB_INSYSCALL is clear, like other platforms do.
2624
Roland McGrathd2a6c6b2003-03-05 04:08:07 +000026252003-03-04 Ulrich Drepper <drepper@redhat.com>
2626
2627 * mem.c [LINUX] (sys_remap_file_pages): New function.
2628 * linux/syscall.h: Declare it.
2629 * linux/syscallent.h: Use it.
2630 * linux/powerpc/syscallent.h: Likewise.
2631
2632 * process.c [LINUX] (sys_futex): Omit final if op is not FUTEX_WAIT.
2633
Roland McGratha4187c92003-02-26 20:34:14 +000026342003-02-26 Roland McGrath <roland@redhat.com>
2635
2636 * configure.ac: Fix typo in netinet/in.h check.
2637 Also include <sys/types.h> and <sys/socket.h> before <netinet/in.h>.
2638 Reported by Alex Semenyaka <alexs@snark.rinet.ru>.
2639
Roland McGrath66375f62003-02-24 10:18:11 +000026402003-02-24 Roland McGrath <roland@redhat.com>
2641
Roland McGrath74f905d2003-02-24 10:53:48 +00002642 * configure.ac, NEWS: Version 4.4.95.
2643 * strace.spec, debian/changelog: 4.4.95-1.
2644
Roland McGrath66375f62003-02-24 10:18:11 +00002645 * process.c (sys_getresgid): Fix typos in argument access.
2646
Roland McGrath127f7d22003-02-24 07:13:59 +000026472003-02-23 Roland McGrath <roland@redhat.com>
2648
2649 * process.c (sys_getresuid): Fix typos in argument access.
2650 Reported by Anton Blanchard <anton@samba.org>.
2651
Roland McGrath71522342003-02-20 02:45:34 +000026522003-02-19 Roland McGrath <roland@redhat.com>
2653
Roland McGrath45be9602003-02-20 03:26:58 +00002654 * configure.ac, NEWS: Version 4.4.94.
2655 * strace.spec, debian/changelog: 4.4.94-1.
2656
Roland McGrath44fb0432003-02-20 02:56:50 +00002657 * version.c: Removed.
2658 * Makefile.am (strace_SOURCES): Remove it.
2659 * strace.c: Use PACKAGE_NAME and VERSION macros instead of version var.
2660
Roland McGrath71522342003-02-20 02:45:34 +00002661 FreeBSD rfork support changes from Russ Cox <rsc@plan9.bell-labs.com>:
2662 * syscall.c (internal_syscall): Handle SYS_rfork with internal_fork.
2663 * process.c (internal_fork) [SYS_rfork]: Bail if RFPROC flag not set.
2664
Roland McGrath8d276ff2003-01-24 04:32:36 +000026652003-01-23 Roland McGrath <roland@redhat.com>
2666
Roland McGrathff02c902003-01-30 20:15:35 +00002667 * signal.c: Reorder #ifdefs so HAVE_ASM_SIGCONTEXT_H doesn't matter on
2668 SPARC, which doesn't use the header regardless.
2669
2670 * util.c [LINUX && SPARC]: Do renaming kludges around <asm/reg.h>
2671 like signal.c does.
2672
2673 * linux/sparc/syscall.h: Declare sys_getdents64, sys_llseek.
Roland McGrath6ee7d1f2003-01-24 04:39:50 +00002674
2675 * linux/dummy.h [! SYS_getpmsg] (sys_getpmsg): #define to printargs.
2676 [! SYS_putpmsg] (sys_putpmsg): Likewise.
2677
Roland McGrath8d276ff2003-01-24 04:32:36 +00002678 * process.c: Reorder includes to put sys/reg.h before linux/ptrace.h,
2679 since they can conflict.
2680
Roland McGrath6a39c212003-01-22 02:27:59 +000026812003-01-21 Roland McGrath <roland@redhat.com>
2682
Roland McGrath8d276ff2003-01-24 04:32:36 +00002683 * strace.c (usage): Omit -z, since it has never worked properly.
2684 * NEWS: Likewise.
2685
2686 * strace.c (main): Grok new option `-E var=val' or `-E var' to put
2687 var=val in environ or to remove var, respectively.
2688 (usage): Mention it.
2689 * strace.1, NEWS: Document it.
2690
Roland McGrath6a39c212003-01-22 02:27:59 +00002691 * configure.ac, NEWS: Version 4.4.93.
2692 * strace.spec, debian/changelog: 4.4.93-1.
2693 * strace.spec (Source0): Use strace-VERSION.tar.bz2 now.
2694
Roland McGrath08eee592003-01-20 09:04:42 +000026952003-01-20 Roland McGrath <roland@redhat.com>
2696
Roland McGrathb472e1c2003-01-20 10:23:11 +00002697 * defs.h [LINUX] [S390 || S390X] (TCB_WAITEXECVE): Define it.
2698 * syscall.c (get_scno, syscall_fixup) [LINUX] [S390 || S390X]: Handle
2699 TCB_WAITEXECVE state with special kludges.
2700
Roland McGrath08eee592003-01-20 09:04:42 +00002701 * process.c [LINUX] (sys_clone) [S390 || S390X]: Argument order is
2702 reversed from other architectures.
2703
2704 * process.c (sys_execve) [LINUX]: Make setting TCB_WAITEXECVE flag
2705 conditional on [TCB_WAITEXECVE] instead of list of processors.
2706
2707 * util.c (restore_arg0): Evaluate args in no-op defns.
2708
2709 * util.c [S390 || S390X] (arg0_offset, arg1_offset): Fix definitions
2710 for clone call on S390. From Michael Holzheu <holzheu@de.ibm.com>.
2711
Roland McGrath2b157e72003-01-18 00:19:35 +000027122003-01-17 Anton Blanchard <anton@samba.org>
2713
2714 * util.c [LINUX] (setbpt): Handle SYS_vfork like SYS_fork.
2715
2716 * linux/syscall.h (SYS_socket_subcall): 256 also for POWERPC.
2717
Roland McGrath92999db2003-01-14 09:46:33 +000027182003-01-14 Roland McGrath <roland@redhat.com>
2719
Roland McGrathec4bd132003-01-14 23:41:07 +00002720 * linux/powerpc/errnoent.h: Add missing errnos.
2721 * linux/powerpc/ioctlent.h: Update ioctl values.
2722 From Anton Blanchard <anton@samba.org>.
2723
2724 * io.c [LINUX] (sys_pread, sys_pwrite): Fix last change.
2725 From Anton Blanchard <anton@samba.org>.
2726
2727 * linux/hppa/syscallent.h: Use sys_getdents64, sys_truncate64,
2728 sys_ftruncate64, instead of printargs, for those syscalls.
2729 * linux/mips/syscallent.h: Likewise.
2730 * linux/powerpc/syscallent.h: Likewise.
2731 * linux/s390/syscallent.h: Likewise.
2732 * linux/sparc/syscallent.h: Likewise.
2733
2734 * linux/syscall.h (SYS_socket_subcall): Only 256 for S390, S390X.
2735 All others at the moment use linux/syscallent.h, where it's 300.
2736
2737 * strace.1: Update bug reporting info.
2738
2739 * resource.c [LINUX] (quotacmds): Grok new command encodings.
2740 From Nathan Scott <nathans@debian.org>.
2741
Roland McGrathd7bec502003-01-14 10:10:36 +00002742 * configure.ac, NEWS: Version 4.4.92.
2743 * strace.spec, debian/changelog: 4.4.92-1.
2744
Roland McGrathf775ab32003-01-14 09:59:57 +00002745 * configure.ac: Match powerpc* (includes powerpc64), and don't match
2746 ppc (never comes out of config.sub).
Roland McGrathd7bec502003-01-14 10:10:36 +00002747
Roland McGrathf775ab32003-01-14 09:59:57 +00002748 * process.c (sys_ptrace): Use #lx format for address argument.
2749 [POWERPC]: Use sizeof(unsigned long) in place of 4 for multipliers.
2750 * process.c [POWERPC]: Likewise.
2751 * signal.c (sys_sigreturn) [POWERPC]: Likewise.
2752 * syscall.c (get_scno) [POWERPC]: Likewise.
2753 * util.c [POWERPC]: Likewise.
2754 (printnum): Use long for NUM.
2755 From Anton Blanchard <anton@samba.org>.
2756
Roland McGrath92999db2003-01-14 09:46:33 +00002757 * defs.h (ALIGN64): Fix defn for PPC, same as FreeBSD one.
2758
2759 * util.c [LINUX] (restore_arg0, restore_arg1): New macros, defined
2760 appropriately via set_arg0 or no-ops for each architecture.
2761 (clearbpt): Use those instead of set_arg0 and set_arg1.
2762
2763 * defs.h [_LARGEFILE64_SOURCE] (_LFS64_LARGEFILE): Define it.
2764 * linux/syscallent.h: Use sys_getdents64, sys_truncate64,
2765 sys_ftruncate64, instead of printargs, for those syscalls.
2766
2767 * process.c: Use <linux/ptrace.h> regardless of <sys/reg.h>.
2768 (sys_ptrace): Use printxval.
2769 (ptrace_cmds): Make PTRACE_GETREGS et al conditional on #ifdef PTRACE_*
2770 instead of only #ifdef SUNOS4. Add PTRACE_[GS]ETFPXREGS.
2771
2772 * ipc.c (PRINTCTL): New macro. #ifdef IPC_64, factor out the flag and
2773 print it before using printxval.
2774 (sys_msgctl, sys_semctl, sys_shmctl): Use it.
2775
Roland McGrathda5ad2d2003-01-14 07:53:49 +000027762003-01-13 Roland McGrath <roland@redhat.com>
2777
Roland McGrath4e254592003-01-14 07:58:26 +00002778 * config.guess: Update from ftp://ftp.gnu.org/pub/gnu/config/,
2779 timestamp 2003-01-10.
2780 * config.sub: Likewise, timestamp 2003-01-03.
2781 * install-sh: Update from Automake 1.7.2.
2782
Roland McGrathda5ad2d2003-01-14 07:53:49 +00002783 * linux/powerpc/signalent.h: Add SIGRTMIN.
2784 From Anton Blanchard <anton@samba.org>.
2785
2786 * linux/powerpc/syscallent.h: Add missing system calls.
2787 Decode more system calls, we were just printargs for many things.
2788 Remove some x86-specific system calls.
2789 Remove two syscalls between the socket and ipc syscalls,
2790 it was resulting in all IPC syscalls being off by two.
2791
2792 * ioctl.c (ioctl_decode) [POWERPC]: Decode term ioctls like Alpha.
2793 From Anton Blanchard <anton@samba.org>.
2794
2795 * defs.h [POWERPC] (UESP, EIP, EAX, ORIG_EAX): Remove this cruft.
2796 [LINUX && POWERPC && !__powerpc64__] (ALIGN64): New macro.
2797 * io.c (sys_pread, sys_pwrite): Use ALIGN64.
2798 From Anton Blanchard <anton@samba.org>.
2799
2800 * term.c [LINUX]: Get kernel definition of struct termios.
2801 From Anton Blanchard <anton@samba.org>.
2802
2803 * linux/ioctlent.sh: Look in sound/ directory too.
2804 From Anton Blanchard <anton@samba.org>.
2805
2806 * desc.c (printflock64): Fix ADDR argument type.
2807 From Anton Blanchard <anton@samba.org>.
2808
2809 * strace.c [! HAVE_STRSIGNAL]: Clean up #ifdefs on decls for
2810 sys_siglist and _sys_siglist.
2811 Reported by John Hughes <john@Calva.COM>.
2812
2813 * net.c: HAVE_OPTHDR -> HAVE_STRUCT_OPTHDR
2814 Reported by John Hughes <john@Calva.COM>.
2815
2816 * linux/syscall.h [ARM] (SYS_socket_subcall): Set to 300.
2817
Roland McGrathdcfcaf72003-01-10 10:45:13 +000028182003-01-10 Roland McGrath <roland@redhat.com>
2819
Roland McGrathedcf1b02003-01-10 21:43:33 +00002820 * configure.ac, NEWS: Version 4.4.91.
2821 * strace.spec, debian/changelog: 4.4.91-1
2822
Roland McGrath09b371c2003-01-10 20:51:13 +00002823 * util.c [LINUX && X86_64] (arg0_offset, arg1_offset): Use correct
2824 values for x86-64, conditional on current_personality.
2825
Roland McGrath944d10f2003-01-10 20:14:52 +00002826 * strace.c (droptcb): Clear flags word before calling rebuild_pollv.
2827
Roland McGrath03c5c4d2003-01-10 20:06:01 +00002828 * configure.ac: Check struct T_conn_res for QUEUE_ptr or ACCEPTOR_id.
2829 * stream.c (print_transport_message): Use #ifdefs for those members.
2830
2831 * strace.c (rebuild_pollv): Fix typo: struct poll -> struct pollfd.
2832
Roland McGrath516f3492003-01-10 19:55:42 +00002833 * configure.ac: Fix siginfo_t/sig_atomic_t checks.
2834 Use prerequisite #include <netinet/in.h> for netinet/*.h checks.
2835
2836 * strace.c (pfd2tcb): Fix for new tcbtab type.
2837 (rebuild_pollv): Likewise.
2838 (detach): Put variables used under [LINUX] inside #ifdef.
2839
2840 * process.c (change_syscall) [POWERPC]: Add missing return.
2841 * util.c [POWERPC] (arg0_offset): Set to 4*PT_R3, not 4*PT_ORIG_R3.
2842
Roland McGrathdcfcaf72003-01-10 10:45:13 +00002843 * strace.spec: New file.
2844 * debian/changelog: 4.4.90-1
2845 * debian/rules (binary-arch): Depend on build.
2846 (clean): Don't try to run Makefile.in.
2847 * debian/control (Standards-Version): Now 3.5.8.
2848
2849 * configure.ac: Diddle CFLAGS after AC_PROG_CC, not before.
2850
Roland McGrathea496212003-01-10 07:50:29 +000028512003-01-09 Roland McGrath <roland@redhat.com>
2852
2853 * syscall.c (force_result) [S390 || S390X]: Fix typo.
2854
2855 * debian/control: Update Maintainer: field.
2856
Roland McGrath5694e802003-01-09 06:56:39 +000028572003-01-08 Roland McGrath <roland@redhat.com>
2858
2859 * NEWS: Update for 4.4.90 test release.
2860
2861 Support for new Linux 2.5 thread features.
2862 * defs.h [LINUX]: Define __NR_exit_group if not defined.
2863 (struct tcb): New members nclone_threads, nclone_detached,
2864 and nclone_waiting.
2865 (TCB_CLONE_DETACHED, TCB_CLONE_THREAD, TCB_GROUP_EXITING): New macros.
2866 (waiting_parent): Macro removed.
2867 (pid2tcb): Declare it.
2868 * process.c (internal_clone) [TCB_CLONE_THREAD]: Reparent the new
2869 child to our parent if we are a CLONE_THREAD child ourselves.
2870 Maintain TCB_CLONE_THREAD and TCB_CLONE_DETACHED flags and counts.
2871 (internal_wait) [TCB_CLONE_THREAD]: Factor out detached children when
2872 determining if we have any. If TCB_CLONE_THREAD is set, check
2873 parent's children instead of our own, and bump nclone_waiting count.
2874 (internal_exit) [__NR_exit_group]: Set the TCB_GROUP_EXITING flag if
2875 the syscall was exit_group.
2876 * syscall.c (internal_syscall): Use internal_exit for exit_group.
2877 * strace.c (pid2tcb): No longer static.
2878 (alloctcb) [TCB_CLONE_THREAD]: Initialize new fields.
2879 (droptcb) [TCB_CLONE_THREAD]: Maintain new fields.
2880 If we have thread children, set TCB_EXITING and don't clear the TCB.
2881 (resume) [TCB_CLONE_THREAD]: Decrement parent's nclone_waiting.
2882 (detach) [TCB_CLONE_THREAD]: When calling resume, check all thread
2883 children of our parent that might be waiting for us too.
2884 [TCB_GROUP_EXITING] (handle_group_exit): New function.
2885 (trace) [TCB_GROUP_EXITING]: Use that in place of detach or droptcb.
2886
2887 Revamp -f support for Linux.
2888 * util.c [LINUX] (setbpt, clearbpt): New implementations that tweak
2889 the system call to be clone with CLONE_PTRACE set. Various new static
2890 helper functions.
2891 * process.c (internal_clone): Define also #ifdef SYS_clone2.
2892 Initialize TCPCHILD->parent field.
2893 [CLONE_PTRACE]: Don't do PTRACE_ATTACH here, because it's preattached.
2894 Check in case the new child is in the tcb already.
2895 (internal_fork) [LINUX]: Just call internal_clone.
2896 * strace.c (trace) [LINUX]: Under -f/-F, grok an unknown pid
2897 reporting to wait, put it in the TCB with TCB_ATTACHED|TCB_SUSPENDED.
2898
2899 * linux/x86_64/syscallent1.h (sys_oldlstat): #define as printargs.
2900
2901 * file.c [LINUX]: #undef st_[amc]time in case they are macros.
2902
2903 * Makefile.am (AM_CFLAGS): New variable, define to $(WARNFLAGS).
2904
2905 * Makefile.am (EXTRA_DIST): Remove debian/postinst and debian/prerm.
2906
Wichert Akkerman5a9b0862003-01-08 23:44:36 +000029072003-01-09 Wichert Akkerman <wichert@deephackmode.org>
2908
2909 * debian/postinst, debian/prerm: removed, /usr/doc symlink is no
2910 longer used
2911 * debian/rules: no longer install postinst and prerm
Wichert Akkerman136bbb12003-01-08 23:46:03 +00002912 * debian/control: do not end summary with full stop (lintian)
Wichert Akkerman5a9b0862003-01-08 23:44:36 +00002913
Roland McGratha83c22f2002-12-30 09:13:30 +000029142002-12-30 Roland McGrath <roland@redhat.com>
2915
Roland McGrath2850c7e2002-12-30 10:46:02 +00002916 * Makefile.am (bin_SCRIPTS): New variable, list strace-graph.
2917 (EXTRA_DIST): Add missing files.
2918
2919 * configure.ac: Fix asm/sigcontext.h check to include prerequisite.
2920
2921 * syscall.c (qualify_one): New function.
2922 (qual_options): Replace lookup field with qualify, update initializer.
2923 (qualify): Update caller.
2924 (qual_signal, qual_fault, qual_desc): Rewritten from lookup_*.
2925 (qual_syscall): Rewritten lookup_syscall, match name more than once.
2926 Fixes RH#70579, bites IA64 -efoo when foo exists on IA32.
2927
Roland McGrath692b68a2002-12-30 09:33:32 +00002928 * version.c (version): Make const, bump to 4.4.90.
2929 * strace.c: Update decl.
2930
2931 * Makefile.am [LINUX && X86_64]: Remove cruft.
2932 * linux/x86_64/errnoent1.h: New file.
2933 * linux/x86_64/ioctlent1.h: New file.
2934 * linux/x86_64/signalent1.h: New file.
2935 * linux/x86_64/syscallent1.h: New file.
2936 * linux/x86_64/i386-headers.diff: File removed.
2937 * linux/x86_64/makeheaders.sh: File removed.
2938 * linux/x86_64/Makefile.in: File removed.
2939
Roland McGratha83c22f2002-12-30 09:13:30 +00002940 * linux/syscallent.h [X86_64]: Disable sanity checks, subcall stuff is
2941 already broken for 32-bit personality on x86-64.
2942
Roland McGrath30d47f12002-12-30 00:51:51 +000029432002-12-29 Roland McGrath <roland@redhat.com>
2944
Roland McGratha83c22f2002-12-30 09:13:30 +00002945 * configure.ac, Makefile.am: Punt subdirs, handle everything here.
2946 * linux/Makefile.am: File removed.
2947 * freebsd/Makefile.am: File removed.
2948 * sunos4/Makefile.in: File removed.
2949 * svr4/Makefile.in: File removed.
2950
Roland McGrath30d47f12002-12-30 00:51:51 +00002951 * linux/alpha/Makefile.in: File removed.
2952 * linux/hppa/Makefile.in: File removed.
2953 * linux/ia64/Makefile.in: File removed.
2954 * linux/powerpc/Makefile.in: File removed.
2955 * linux/s390/Makefile.in: File removed.
2956 * linux/s390x/Makefile.in: File removed.
2957
29582002-12-26 Roland McGrath <roland@redhat.com>
2959
2960 * syscallent.sh: Grok three flavors of #define line, uniquify.
2961 * linux/hppa/syscallent.sh: File removed.
2962 * linux/powerpc/syscallent.sh: File removed.
2963
2964 * linux/Makefile.am: New file.
2965 * linux/Makefile.in: File removed.
2966 * freebsd/Makefile.am: New file.
2967 * freebsd/i386/Makefile.am: New file.
2968 * freebsd/i386/Makefile.in: File removed.
2969
29702002-12-22 Roland McGrath <roland@redhat.com>
2971
2972 Update to Autoconf 2.57, and Automakify with version 1.7.
2973 * Makefile.am: New file.
2974 * Makefile.in: File removed.
2975 * configure.in: Moved to ...
2976 * configure.ac: ... here. Update for Autoconf 2.5x and Automake.
2977 * aclocal.m4: Moved to ...
2978 * acinclude.m4: ... here. Update for Autoconf 2.5x.
Roland McGratha83c22f2002-12-30 09:13:30 +00002979 * acconfig.h: File removed.
Roland McGrath30d47f12002-12-30 00:51:51 +00002980 * AUTHORS: New file, makes automake happy.
2981 * autogen.sh: File removed.
2982 * README-CVS: Update to recommend autoreconf instead.
2983 * file.c: HAVE_ST_* -> HAVE_STRUCT_STAT_ST_*.
2984 * net.c: HAVE_SIN6_SCOPE_ID -> HAVE_STRUCT_SOCKADDR_IN6_SIN6_SCOPE_ID,
2985 HAVE_MSG_CONTROL -> HAVE_STRUCT_MSGHDR_MSG_CONTROL.
2986 * strace.c: *_DECLARED -> HAVE_DECL_*
2987 * stream.c: HAVE_* -> HAVE_STRUCT_*
2988
2989 * linux/Makefile.in (ioctldefs.h ioctls.h): Use $(SHELL) instead of
2990 sh, and use $(srcdir) to find the script.
2991 * linux/powerpc/Makefile.in (ioctlent.raw): Find ioctlent.sh in ../.
2992 (ioctlsort.o): Use ../ioctlsort.c, not ../../ioctlsort.c.
2993 * linux/x86_64/Makefile.in (headers): Renamed to all.
2994 * linux/alpha/Makefile.in: Add empty install target.
2995 * linux/x86_64/Makefile.in: Likewise.
2996 * linux/powerpc/Makefile.in: Likewise.
2997 * linux/Makefile.in: Likewise.
2998
Roland McGrath85960152002-12-30 00:26:24 +000029992002-12-26 Roland McGrath <roland@redhat.com>
3000
3001 * defs.h [LINUX && MIPS] (MAX_QUALS): Set to 5000, not 4999.
3002 From Daniel Jacobowitz <drow@false.org>.
3003
Roland McGrathc25a62f2002-12-21 23:25:26 +000030042002-12-21 Roland McGrath <roland@redhat.com>
3005
Roland McGrathdf211902002-12-22 03:34:55 +00003006 * linux/syscallent.h: Add some new 2.5 syscall names.
3007 Now clone takes 5 args.
3008 * process.c [LINUX] (clone_flags): Update with 2.5 flag bits.
3009 [LINUX] (sys_clone): Print new args.
3010 * mem.c (print_ldt_entry): Make global.
3011
3012 * linux/syscall.h [I386 || IA64] (SYS_socket_subcall): Bump to 300 for
3013 safety, since up to 260 are already used in 2.5 kernels.
3014 * linux/syscallent.h: Update the table.
3015 * linux/ia64/syscallent.h: Likewise.
3016
Roland McGrathc25a62f2002-12-21 23:25:26 +00003017 * syscall.c (force_result): New function.
3018 * process.c (internal_wait): Handle ECHILD exit from wait call with
3019 WNOHANG flag set; force the return value to 0 in the inferior when it
3020 has live children we are tracing.
Roland McGrath044c8d22002-12-22 03:36:03 +00003021 * NEWS: Mention the bug fix.
Roland McGrathc25a62f2002-12-21 23:25:26 +00003022
Roland McGrath13f0b432002-12-17 10:48:09 +000030232002-12-17 Roland McGrath <roland@redhat.com>
3024
Roland McGrathf57204d2002-12-18 04:36:59 +00003025 * linux/ia64/syscallent.h: Remove placeholders 275-298 to catch up
3026 with linux/syscallent.h additions.
3027
Roland McGrath29f554f2002-12-18 04:16:31 +00003028 * strace.c (tcbtab): Make this a pointer to pointers, not an array.
3029 (tcbtabsize): New variable.
3030 (main): Initialize them using dynamic allocation.
3031 (alloctcb, main): Use tcbtabsize in place of MAX_PROCS; indirect.
3032 (pid2tcb, cleanup): Likewise.
3033 [USE_PROCFS] (pollv): Make this a pointer, not an array; make static.
3034 (rebuild_pollv): Dynamically allocate the vector.
3035 * defs.h (tcbtab): Update decls.
3036 (MAX_PROCS): Macro removed, no more static limit on this.
3037 * process.c (fork_tcb): New function.
3038 (internal_clone, internal_fork): Use it instead of checking nprocs.
3039
Roland McGrath13f0b432002-12-17 10:48:09 +00003040 * strace.c (detach) [LINUX]: Use __WALL (or a second try with __WCLONE)
3041 in wait after sending SIGSTOP.
3042
Roland McGrath915742f2002-12-17 04:51:02 +000030432002-12-16 Roland McGrath <roland@redhat.com>
3044
Roland McGratha581c512002-12-17 05:10:47 +00003045 * signal.c (sprintsigmask): Increase static buffer size to account for
3046 worst possible case. Reported by Daniel Jacobowitz <drow@false.org>.
3047
Roland McGrath915742f2002-12-17 04:51:02 +00003048 * process.c [LINUX] (wait4_options): Fix __WCLONE value. Add
3049 __WNOTHREAD and __WALL.
3050
3051 * strace.c (trace) [LINUX]: Only check errno if wait4 actually fails,
3052 so we don't repeat a wait and thus drop a status. Fixes RH#62591.
3053
Roland McGrath36d87c22002-12-15 23:59:13 +000030542002-12-15 Roland McGrath <roland@redhat.com>
3055
Roland McGrath32be5972002-12-16 20:41:34 +00003056 * process.c (setarg) [POWERPC]: Support it.
3057
3058 * util.c [POWERPC] (LOOP): Fix value, now 0x48000000 (0: b 0b).
3059 Old value was bogus, not even a proper instruction.
3060 From Guy M. Streeter <streeter@redhat.com>.
3061
3062 * strace.c (main) [! USE_PROCFS]: Always reset SIGCHLD to SIG_DFL.
3063
3064 * configure.in: Don't check for putpmsg.
3065 * stream.c (sys_getpmsg, sys_putpmsg): Make these conditional on
3066 #ifdef SYS_*, rather than on HAVE_PUTPMSG.
3067
Roland McGrath2fe77222002-12-16 09:54:16 +00003068 * aclocal.m4 (AC_STAT64): Include <linux/types.h> before <asm/stat.h>
3069 in test. Test our own #ifdef LINUX rather than predefined `linux'.
3070
Roland McGrath36d87c22002-12-15 23:59:13 +00003071 * linux/powerpc/syscallent.h: Use sys_llseek for _llseek.
3072 * linux/sparc/syscallent.h: Likewise.
3073 * linux/hppa/syscallent.h: Likewise.
3074
3075 * syscall.c (syscall_enter) [LINUX && POWERPC]: Define PT_ORIG_R3 if
3076 not defined, since <asm/ptrace.h> defines it only #ifdef __KERNEL__.
3077 * process.c: Likewise.
3078
3079 * desc.c (sys_osf_select): Add missing return type.
3080
3081 * syscall.c (trace_syscall): Use strerror, not sys_errlist/sys_nerr.
3082
3083 * linux/ia64/syscallent.h: Remove macros for sys_delete_module,
3084 sys_nanosleep, both already in linux/dummy.h.
3085
3086 * syscall.c (get_scno): Move static `currpers' inside #ifdef X86_64.
3087 (trace_syscall): Fix return without value.
3088
3089 * linux/syscallent.h: Update table with names of new syscalls
3090 io_setup, io_destroy, io_getvents, io_submit, io_cancel.
3091 * linux/ia64/syscallent.h: Likewise.
3092 * linux/powerpc/syscallent.h: Likewise.
3093
3094 * signal.c [LINUX && I386]: Provide SA_RESTORER constant if not
3095 defined. If the bit is set, print the sa_restorer field of sigaction.
3096
3097 * mem.c: Add sys_{get,set}_thread_area.
3098 * linux/syscall.h: Declare them.
3099 * linux/syscallent.h: Update the table for these.
3100 * linux/dummy.h (sys_modify_ldt): Define only #ifndef I386.
3101 (sys_get_thread_area, sys_set_thread_area): New macros #ifndef I386.
3102
3103 * configure.in: Check for linux/xattr.h and linux/futex.h headers.
3104 * linux/syscall.h: Add sys_* decls for new syscalls getpmsg, putpmsg,
3105 readahead, sendfile64, setxattr, fsetxattr, getxattr, fgetxattr, int
3106 listxattr, flistxattr, removexattr, fremovexattr, sched_setaffinity,
3107 sched_getaffinity, futex.
3108 * linux/syscallent.h: Update the table.
3109 * io.c: Add sys_sendfile64.
3110 * file.c: Add sys_readahead, sys_*xattr.
3111 * process.c: Add sys_futex, sys_*affinity.
3112
3113 * linux/syscall.h (SYS_socket_subcall): Define to 256 on all machines.
3114 (SYS_ipc_subcall): Always SYS_socket_subcall + SYS_socket_nsubcalls.
3115 * linux/syscallent.h: Update the table for socket and ipc subcalls.
3116
Michal Ludvig882eda82002-11-11 12:50:47 +000031172002-11-09 Heiko Carstens <heiko.carstens@de.ibm.com>
3118
3119 Bugfix for s390/s390x:
3120 * syscall.c: Fixed scno derivation for s390/s390x.
3121
Michal Ludvig17f8fb32002-11-06 13:17:21 +000031222002-11-06 Michal Ludvig <mludvig@suse.cz>
3123
Michal Ludvig39c0e942002-11-06 14:00:12 +00003124 Merged patch from Steven J. Hill <sjhill@realitydiluted.com>
3125 to allow the compilation of a native MIPS strace.
3126
31272002-11-06 Michal Ludvig <mludvig@suse.cz>
3128
Roland McGrath36d87c22002-12-15 23:59:13 +00003129 From Marty Leisner <leisner@rochester.rr.com>,
Michal Ludvig882eda82002-11-11 12:50:47 +00003130 rewritten by mludvig:
Michal Ludvig17f8fb32002-11-06 13:17:21 +00003131 * strace.c (not_failing_only): New.
3132 (usage): Added -z switch description.
3133 (main): Added -z switch parsing to not_failing_only variable.
3134 * syscall.c (trace_syscall): Added not_failing_only handling.
3135
Michal Ludvigeb818f02002-10-09 09:16:22 +000031362002-10-08 Heiko Carstens <heiko.carstens@de.ibm.com>
3137
3138 Missing complete changelog for 2002-10-07 commit:
3139 * Makefile.in: Added linux/s390, linux/s390x to ALL_SUBDIRS.
3140 * acconfig.h: New define for s390x.
3141 * config.sub: Added missing define for s390 and new one for s390x.
3142 * configure.in: Added new define for s390x.
3143 * file.c: Added missing #undef dirent64 and new defines for s390x.
3144 * linux/s390: New directory.
3145 * linux/s390/Makefile.in: New file.
3146 * linux/s390/errnoent.h: New file.
3147 * linux/s390/ioctlent.h: New file.
3148 * linux/s390/signalent.h: New file.
3149 * linux/s390/syscallent.h: New file.
3150 * linux/s390x: New directoy.
3151 * linux/s390x/Makefile.in: New file.
3152 * linux/s390x/errnoent.h: New file.
3153 * linux/s390x/ioctlent.h: New file.
3154 * linux/s390x/signalent.h: New file.
3155 * linux/s390x/syscallent.h: New file.
3156 * linux/syscall.h: Added sys_mincore() prototype and added new
3157 s390x defines.
3158 * process.c: Added s390x defines.
3159 (change_syscall): Changed handling for s390.
3160 (setarg): Added missing s390/s390x code in setarg().
3161 * signal.c: Added s390x define.
3162 (sys_sigreturn): Bugfix in s390/s390x code (wrong number of
3163 arguments to sprintsigmask()).
3164 * stream.c (internal_stream_ioctl): Changed int cast to long cast,
3165 since printstr() expects a long.
3166 * syscall.c (decode_subcall): Changed several variables to be long
3167 instead of int to match 64 bit requirements. Added s390x defines.
3168 (syscall_enter): Changed upeek() call to match s390 and s390x
3169 requirements.
3170 * util.c: Added s390x defines.
3171
Michal Ludvig10a88d02002-10-07 14:31:00 +000031722002-10-07 Michal Ludvig <mludvig@suse.cz>
3173
3174 Merged s390x port by Heiko Carstens <Heiko.Carstens@de.ibm.com>
3175 and bugfixes to s390 by D.J. Barrow.
3176
Michal Ludvig53b320f2002-09-23 13:30:09 +000031772002-09-23 Michal Ludvig <mludvig@suse.cz>
3178
Roland McGrath36d87c22002-12-15 23:59:13 +00003179 Merged x86-64 port by Andi Kleen <ak@suse.de>
Michal Ludvig0e035502002-09-23 15:41:01 +00003180 and Michal Ludvig <mludvig@suse.cz>
3181 * Makefile.in: New target 'headers'. Failure ignored.
3182 * acconfig.h: New defines for x86-64.
3183 * configure.in: Ditto.
3184 * defs.h: Ditto.
3185 * file.c: Ditto.
3186 * signal.c: Ditto.
3187 * process.c: Added support for x86-64.
3188 * util.c: Ditto.
3189 * syscall.c: Ditto + added automatic personality switching.
3190 * linux/syscall.h: Ditto.
3191 * linux/x86_64: New directory.
3192 * linux/x86_64/Makefile.in: New file.
3193 * linux/x86_64/gentab.pl: Ditto.
3194 * linux/x86_64/i386-headers.diff: Ditto.
3195 * linux/x86_64/makeheaders.sh: Ditto.
3196 * linux/x86_64/syscallent.h: Ditto.
3197 * mem.c (print_mmap): Always print arg[4] as int.
3198
31992002-09-23 Michal Ludvig <mludvig@suse.cz>
3200
Michal Ludvig53b320f2002-09-23 13:30:09 +00003201 * configure.in: Fix regular expressions.
Roland McGrath36d87c22002-12-15 23:59:13 +00003202 * linux/syscall.h: Added missing braces in prototype of
Michal Ludvig53b320f2002-09-23 13:30:09 +00003203 sys_getdents64().
3204 * file.c: Use '#ifdef LINUX' instead of '#ifdef linux'.
3205 (struct fileflags): Made extern to inhibit compiation warnings.
3206 (sys_getdents64): Merged LINUX and SVR4 part.
Roland McGrath36d87c22002-12-15 23:59:13 +00003207 * syscall.c (get_scno): Split multiline string into two distinct
Michal Ludvig53b320f2002-09-23 13:30:09 +00003208 strings.
3209
John Hughes2c4e3a82002-05-24 10:19:44 +000032102002-05-24 John Hughes <john@calva.com>
3211
3212 * stream.h, net.h: Avoid possible infinite loop caused by
3213 unsigned arithmetic in preceeding change.
3214
John Hughesb6643082002-05-23 11:02:22 +000032152002-05-23 John Hughes <john@calva.com>
3216
John Hughes38ae88d2002-05-23 11:48:58 +00003217 * acconfig.h: Add HAVE_OPTHDR and HAVE_T_OPTHDR defines.
3218
3219 * aclocal.m4: Add tests for struct opthdr in sys/socket.h and
3220 struct t_opthdr in sys/tiuser.h, define HAVE_OPTHDR and HAVE_T_OPTHDR
3221 if found.
3222
3223 * configure.in: use tests for struct opthdr and struct t_opthdr.
3224
3225 * defs.h: add new function print_sock_optmgmt.
3226
3227 * io.c: add hack that lets ioctl decode functions set auxilliary
3228 string return.
3229
3230 * stream.c: better decoding for timod ioctls.
3231
3232 * net.c: add function print_sock_optmgmt, used by timod ioctl
3233 decoding functions in stream.c.
3234
32352002-05-23 John Hughes <john@calva.com>
3236
John Hughescde80ab2002-05-23 11:19:05 +00003237 * acconfig.h: Make autoheader happy about Linux/SuperH
3238
32392002-05-23 John Hughes <john@calva.com>
3240
John Hughesb6643082002-05-23 11:02:22 +00003241 * strace.c: Get rid of warning if not using POLL_HACK
3242
John Hughes93f7fcc2002-05-22 15:46:49 +000032432002-05-22 John Hughes <john@calva.com>
3244
3245 * net.c: Simplify {get,set}sockopt, decode SO_LINGER, cope with
3246 options that are not just ints, cope with systems that don't
3247 #define SOL_TCP and so on.
3248
John Hughesd870b3c2002-05-21 11:24:18 +000032492002-05-21 John Hughes <john@calva.com>
3250
3251 * strace.c: Fix warning if POLL_HACK is used.
3252
John Hughesc61eb3d2002-05-17 11:37:50 +000032532002-05-17 John Hughes <john@calva.com>
3254
John Hughes5eb78d52002-05-17 14:04:24 +00003255 * svr4/ioctlent.sh: Some defines on UW come with too many spaces.
3256
32572002-05-17 John Hughes <john@calva.com>
3258
John Hughese9224782002-05-17 13:58:24 +00003259 * svr4/ioctlent.sh: Cope with #defines wrapped in #ifdefs.
3260
32612002-05-17 John Hughes <john@calva.com>
3262
John Hughesfd15cb32002-05-17 11:41:35 +00003263 * stream.c: tidy up output a little.
3264
32652002-05-17 John Hughes <john@calva.com>
3266
John Hughesc61eb3d2002-05-17 11:37:50 +00003267 * process.c, svr4/dummy.h, svr4/syscall.h: decode arguments
3268 to procpriv syscall.
3269
Wichert Akkermanccef6372002-05-01 16:39:22 +000032702002-05-01 Wichert Akkerman <wichert@deephackmode.org>
3271
3272 * configure.in, defs.h, process.c, sock.c, syscall.c, util.c: merge
3273 patch from Greg Banks <gbanks@pocketpenguins.com> for Linux/SuperH
3274 support
3275
Wichert Akkermanb0c598f2002-04-01 12:48:06 +000032762002-04-01 Wichert Akkerman <wichert@deephackmode.org>
3277
Wichert Akkermaneb8ebda2002-04-01 17:48:02 +00003278 * strace.c: close tcp->outf in droptcb()
3279
32802002-04-01 Wichert Akkerman <wichert@deephackmode.org>
3281
Wichert Akkermanb0c598f2002-04-01 12:48:06 +00003282 * net.c: decode packet options
3283
Wichert Akkermand321ff92002-03-31 18:45:45 +000032842002-03-31 Wichert Akkerman <wichert@deephackmode.org>
3285
Wichert Akkermaned2c74d2002-03-31 20:16:02 +00003286 * linux/{alpha,hppa,ia64,mips,powerpc,sparc}/syscallent.h: regenerated
3287
32882002-03-31 Wichert Akkerman <wichert@deephackmode.org>
3289
Wichert Akkermand321ff92002-03-31 18:45:45 +00003290 * debian/*: added
Wichert Akkerman7ab47b62002-03-31 19:00:02 +00003291 * linux/syscallent.h: fix typo and add the reserved stream syscalls
3292 * defs.h, file.c, io.c: fix signed/unsigned issues
Wichert Akkerman4527dae2002-03-31 19:03:29 +00003293 * syscall.c: check for negative u_errors
Wichert Akkerman235b0ff2002-03-31 19:08:04 +00003294 * cvsbuild: renamed to autogen.sh
Wichert Akkermand321ff92002-03-31 18:45:45 +00003295
Wichert Akkerman8b8ff7c2001-12-27 22:27:30 +000032962001-12-17 Wichert Akkerman <wakkerma@debian.org>
3297
3298 * net.c: add new TCP socket options
3299
John Hughesfa519572001-10-26 08:05:49 +000033002001-10-26 John Hughes <john@calva.com>
3301
3302 * svr4/ioctlent.sh: Cope with #define lines containing
3303 comments that terminate on subsequent lines. Used to
3304 comment out subsequent ioctls!
3305
Wichert Akkerman9fbd0dd2001-10-26 05:20:37 +000033062001-10-25 Wichert Akkerman <wakkerma@debian.org>
3307
3308 * linux/ioctlent.h: regenerated using current scripts so
3309 term ioctls are included
3310
John Hughes19e49982001-10-19 08:59:12 +000033112001-10-19 John Hughes <john@Calva.COM>
3312
3313 * strace.c(proc_open): On SVR4 only trace the syscalls,
3314 signals and faults we care about.
3315
John Hughes42162082001-10-18 14:48:26 +000033162001-10-18 John Hughes <john@Calva.COM>
3317
John Hughesc0c5ac82001-10-19 07:32:14 +00003318 * acconfig.h: Add HAS_SIGINFO_T.
3319 * aclocal.m4: add check for siginfo_t in signal.h.
3320 * configure.in: use check for siginfo_t.
3321 * defs.h: if HAVE_SIGINFO_T the declare printsiginfo. On SVR4
3322 allow access to siginfo when signal recieved.
3323 * process.c: Remove SVR4 only version of printsiginfo.
3324 * signal.c: merge SVR4 and LINUX versions of printsiginfo.
3325 * strace.c: on SVR4 print siginfo when signal recieved.
3326
33272001-10-18 John Hughes <john@Calva.COM>
3328
John Hughes2d8b2c52001-10-18 14:52:24 +00003329 * system.c(sys_ssisys): handle return values for ssisys
3330
33312001-10-18 John Hughes <john@Calva.COM>
3332
John Hughes42162082001-10-18 14:48:26 +00003333 * signal.c: handle sigwait
3334 * svr4/dummy.c: Move sigwait to done
3335 * svr4/syscall.h: handle sigwait
3336
John Hughes9cecf7f2001-10-16 10:20:22 +000033372001-10-16 John Hughes <john@Calva.COM>
3338
John Hughes0aadba42001-10-16 18:19:52 +00003339 * system.c(sys_ssisys): decode some args for ssisys.
3340
33412001-10-16 John Hughes <john@Calva.COM>
3342
John Hughesaca07f32001-10-16 18:12:27 +00003343 * mem.c: MS_SYNC is zero, so must be first in xlat list.
3344
3345 * svr4/dummy.h: memcntl is much like mctl.
3346
33472001-10-16 John Hughes <john@Calva.COM>
3348
John Hughes9cecf7f2001-10-16 10:20:22 +00003349 * util.c (umovestr): UnixWare (svr4?) returns 0 when trying
3350 to read unmapped page. Make it possible to strace ksh.
3351
Wichert Akkerman7b3346b2001-10-09 23:47:38 +000033522001-10-03 David Mosberger <davidm@hpl.hp.com>
3353
3354 * process.c (internal_clone): Avoid race condition by clearing
3355 breakpoint after attaching to child.
3356
33572001-10-02 David Mosberger <davidm@hpl.hp.com>
3358
3359 * linux/ia64/syscallent.h: Define ia32 syscall numbers (originally
3360 by Don Dugger, with my refinements).
3361
3362 * linux/ia64/ioctlent.h: Regenerate and manually merge conflicting
3363 ioctls (TCGETS & SNDCTL_TMR_TIMEBASE, etc.).
3364
3365 * linux/ia64/Makefile.in (ioctldefs.h ioctls.h): Update for
3366 new ioctlent.h generation scheme.
3367
3368 * linux/syscall.h (sys_clone2): Declare.
3369 [IA64] Define ia32 socket, ipc, and extra syscall numbers.
3370
3371 * linux/ioctlent.sh (regexp): Also handle <asm/ioctls.h> so we
3372 don't miss the tty ioctls (unfortunately, some of the sound timer
3373 ioctls are in conflict with them!).
3374
3375 * util.c (setbpt) [IA64]: Add ia32 support (by Don Dugger).
3376 (clrbpt) [IA64]: Ditto.
3377
3378 * syscall.c (internal_syscall): Handle SYS_clone2, SYS32_wait4,
3379 and SYS32_exit.
3380 (get_scno): Get ia32 syscall number from r1 (orig eax) instead of
3381 r8 (eax). Handle TCB_WAITEXECVE.
3382 (syscall_fixup): Handle ia64.
3383 (syscall_enter): Fix argument fetching for ia64.
3384
3385 * strace.c [IA64 && LINUX]: Include <asm/ptrace_offsets.h>.
3386 (trace) [PT_GETSIGINFO]: Print signal address and pc if possible.
3387
3388 * process.c (tcp): New function.
3389 (change_syscall): Add support for ia64 linux.
3390 (sys_execve): Turn on TCB_WAITEXECVE for ia64 linux.
3391
3392 * desc.c (getlk): Cast l_len to "long long" to avoid warnings when
3393 type is narrower.
3394 * resource.c (sprintrlim64): Ditto.
3395
3396 * defs.h (TCB_WAITEXECVE) [IA64]: Define.
3397 [IA64]: Declare "ia32" variable.
3398
3399 * bjm.c: Do not include <linux/module.h>. It's not safe to include
3400 kernel headers. Declare the necessary constants and structures
3401 directly instead.
3402
34032001-10-01 David Mosberger <davidm@hpl.hp.com>
3404
3405 * signal.c (parse_sigset_t): New function.
3406 (sigishandled): Fix off-by-one bug by using parse_sigset_t() and
3407 avoiding relying on internal layout of sigset_t datastructure.
3408
34092001-04-26 David Mosberger <davidm@hpl.hp.com>
3410
3411 * linux/ia64/syscallent.h: Add getunwind().
3412
34132001-04-11 David Mosberger <davidm@hpl.hp.com>
3414
3415 * syscall.c (syscall_enter): Use PT_RBS_END instead of deprecated
3416 PT_AR_BSP. Pick up arguments starting with out0, which is not
3417 always the same as r32 (e.g., consider inlined syscalls).
3418
John Hughesa2278142001-09-28 16:21:30 +000034192001-09-28 John Hughes <john@Calva.COM>
3420
3421 * process.c: FreeBSD-CURRENT no longer has PT_READ_U, and anyway we
3422 were showing it as PT_WRITE_U! Fix from Maxime Henrion.
3423
John Hughes1fcb1d62001-09-18 15:56:53 +000034242001-09-18 John Hughes <john@Calva.COM>
3425
3426 * net.c: fix display of sockaddr structures, sometimes too many "}",
3427 sometimes too few. Fix suggested by Richard Kettlewell.
3428
Wichert Akkerman67e3e632001-08-19 11:43:17 +000034292001-08-19 Wichert Akkerman <wakkerma@debian.org>
3430
3431 * signal.c: do not include asm/sigcontext.h on IA64 since it gets
3432 the struct from bits/sigcontext.h already which signal.h includes.
3433
Wichert Akkerman7b96b572001-08-03 11:37:07 +000034342001-08-03 Wichert Akkerman <wakkerma@debian.org>
3435
Wichert Akkerman7c707a72001-08-03 21:54:08 +00003436 * linux/ioctlent.sh: change regexps so we catch sound ioctls as well in
3437 Linux
3438 * linux/Makefile.in: fix a few things so the ioctl list is generated
3439 properly
3440 * ioctl.c: remember to shift ioctl masks as well
3441
34422001-08-03 Wichert Akkerman <wakkerma@debian.org>
3443
Wichert Akkermancd6aefc2001-08-03 12:27:54 +00003444 * Linux/**/syscallent.h: synchronize section for fcntl and use sys_fcntl
3445 for sys_fcntl as well
3446
34472001-08-03 Wichert Akkerman <wakkerma@debian.org>
3448
Wichert Akkerman0b1120a2001-08-03 12:20:38 +00003449 * linux/hppa/syscallent.h: updated from Matthew Wilcox
3450
34512001-08-03 Wichert Akkerman <wakkerma@debian.org>
3452
Wichert Akkerman82b162e2001-08-03 11:51:28 +00003453 * process.c: seems Linux/IA64 changed register names on us, switch to
3454 using new names.
3455
34562001-08-03 Wichert Akkerman <wakkerma@debian.org>
3457
Wichert Akkerman54b4f792001-08-03 11:43:35 +00003458 * strace.c: set CLOEXEC flag for outputfile
3459
34602001-08-03 Wichert Akkerman <wakkerma@debian.org>
3461
Wichert Akkerman7b96b572001-08-03 11:37:07 +00003462 * linux/sparc/syscall.h, linux/sparc/syscallent.h: add some LFS calls
3463
Wichert Akkerman4f1bbbe2001-07-23 14:43:07 +000034642001-07-23 Wichert Akkerman <wakkerma@debian.org>
3465
3466 * configure.in: Support cross-compiling between architectures
3467
Wichert Akkerman0dc4fc92001-07-13 22:09:05 +000034682001-07-13 Wichert Akkerman <wakkerma@debian.org>
3469
3470 * configure.in: add S390 to architecture list
3471
John Hughes1d08dcf2001-07-10 13:48:44 +000034722001-07-10 John Hughes <john@Calva.COM>
3473
3474 * TODO, defs.h, io.h, net.c, strace.c, syscall.c, util.c: Merge fixes
3475 from Richard Kettlewell <rkettlewell@zeus.com> which add I/O dumping
3476 of args to readv/writev. Also gets rid of redundant printiovec
3477 routine from net.c (duplicate of tprint_iov in util.c).
3478
Wichert Akkerman688c7fc2001-07-02 16:53:25 +000034792001-07-02 Wichert Akkerman <wakkerma@debian.org>
3480
3481 * config.{guess,sub}: updated
3482
John Hughesaa09c6b2001-05-15 14:53:43 +000034832001-05-15 John Hughes <john@Calva.COM>
3484
John Hughes70c5e7a2001-05-15 15:09:14 +00003485 * signal.c: pass a pointer to sigmask to printsigmask from printcontext,
3486 it was just passing the sigmask (ucp->uc_sigmask).
3487
34882001-05-15 John Hughes <john@Calva.COM>
3489
John Hughesaa09c6b2001-05-15 14:53:43 +00003490 * util.c: Don't run off the end of valid memory in umovestr when
3491 USE_PROCFS. Important for FREEBSD systems (which seem to have an
3492 unmapped page just after the args/env area).
3493
John Hughes4e36a812001-04-18 15:11:51 +000034942001-04-18 John Hughes <john@Calva.COM>
3495
3496 * configure.in: test for sys/nscsys.h, the non-stop clusters includes.
3497 * process.c: handle rfork{1,all} and rexecve calls on non-stop clusters.
3498 * syscall.c: treat rfork{1,all} and fork{1,all} as fork like calls.
3499 Treat rexecve as an exec.
3500 * system.c: decode arguments to ssisys call on nsc systems.
3501 * svr4/dummy.h, svr4/syscall.h: now we handle rfork{1,all}, ssisys and
3502 rexecve calls.
3503
Wichert Akkerman35254402001-04-12 09:11:04 +000035042001-04-12 Wichert Akkerman <wakkerma@debian.org>
3505
3506 * process.c: fix cast for powerpc code
3507 * linux/powerpc/syscallent.h: update syscall list
3508 * README: fix address for the strace mailinglist
3509 * signal.c: switch to using /proc/<pid>/status on Linux so we can get
3510 the realtime signals as well
3511
Wichert Akkerman4ca31092001-04-10 10:28:43 +000035122001-04-10 Wichert Akkerman <wakkerma@debian.org>
3513
3514 * Merge patches from Maciej W. Rozycki:
3515 + util.c: add code to print PC for MIPS
3516 + linux/mips/syscallent.h: updated
3517 + system.c: formating fixes for sys_sysmips
Wichert Akkerman42080d82001-04-10 10:32:26 +00003518 + configure.in: test for yet more headers
3519 + stream.c: use configure-headertests instead of relying on OS hints
Wichert Akkerman4ca31092001-04-10 10:28:43 +00003520
Wichert Akkermand6b92492001-04-07 21:37:12 +000035212001-04-07 Wichert Akkerman <wakkerma@debian.org>
3522
Wichert Akkermane70bbe52001-04-07 21:47:30 +00003523 * NEWS: start 4.3.1 items
3524 * version.c: updated to say 4.3.1 (was still 4.2, oops!)
3525
35262001-04-07 Wichert Akkerman <wakkerma@debian.org>
3527
Wichert Akkermand6b92492001-04-07 21:37:12 +00003528 * configure.in: test for asm/sysmips.h and linux/utsname.h
3529 * linux/syscall.h: fix a typo for sys_sysmips
3530 * system.c: include asm/sysmips.h and linux/utsname.h if they exist,
3531 fix typo
3532
Wichert Akkerman4f043ec2001-03-31 16:25:58 +000035332001-03-31 Wichert Akkerman <wakkerma@debian.org>
3534
3535 * linux/mips/ioctlent.h: updated using new Linux ioctl setup
3536
35372001-03-31 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkerman8aada672001-03-31 16:20:33 +00003538
3539 * linux/ia64/ioctlent.h: regenerated
3540
Wichert Akkerman29f0d052001-03-31 16:14:55 +000035412001-03-31 Wichert Akkerman <wakkerma@debian.org>
3542
Wichert Akkermancf715672001-03-31 16:16:57 +00003543 * linux/{alpha,ia64,powerpc}/ioctlent.sh: removed, all archs use the
3544 general Linux ioctlent.sh
3545
35462001-03-31 Wichert Akkerman <wakkerma@debian.org>
3547
Wichert Akkerman29f0d052001-03-31 16:14:55 +00003548 * linux/ioctlent.sh: add dir variable for location of kernel headers
3549
Wichert Akkermanbbf59e92001-03-29 17:43:19 +000035502001-03-29 Wichert Akkerman <wakkerma@debian.org>
3551
Wichert Akkerman00cd74c2001-03-30 16:20:27 +00003552 * linux/ia64/ioctlent.h: updated using new Linux ioctl setup
3553
35542001-03-29 Wichert Akkerman <wakkerma@debian.org>
3555
Wichert Akkerman10767782001-03-29 19:04:25 +00003556 * linux/powerpc/ioctlent.h: updated using new Linux ioctl setup
3557
35582001-03-29 Wichert Akkerman <wakkerma@debian.org>
3559
Wichert Akkermand7fb2062001-03-29 18:16:07 +00003560 * linux/hppa/ioctlent.h: updated using new Linux ioctl setup
3561
35622001-03-29 Wichert Akkerman <wakkerma@debian.org>
3563
Wichert Akkermanbbf59e92001-03-29 17:43:19 +00003564 * linux/alpha/ioctlent.h: updated using new Linux ioctl setup
3565
Wichert Akkerman2f1d87e2001-03-28 14:40:14 +000035662001-03-28 Wichert Akkerman <wakkerma@debian.org>
3567
Wichert Akkerman00a82ee2001-03-28 20:29:17 +00003568 * configure.in: use sparc* so we can compile on sparc64 as well
3569 * process.c, syscall.c: work around double define of fpq, fq and fpu
3570 structs on Linux/sparc, and use regs instead of pt_regs
3571 * don't use asm/sigcontext.h on Linux/sparc
3572
35732001-03-28 Wichert Akkerman <wakkerma@debian.org>
3574
Wichert Akkermanfe8f65d2001-03-28 15:10:49 +00003575 * linux/sparc/ioctlent.h: updated using new Linux ioctl setup
3576
35772001-03-28 Wichert Akkerman <wakkerma@debian.org>
3578
Wichert Akkerman2f1d87e2001-03-28 14:40:14 +00003579 * strace.c: use __WALL as wait4 flag if it exists so we can properly
3580 trace threaded programs
3581
John Hughes8e075fb2001-03-27 13:57:48 +000035822001-03-27 John Hughes <john@Calva.COM>
3583
John Hughesb8a85a42001-03-28 08:05:27 +00003584 * aclocal.m4: add check for endianness of long long.
3585 * acconfig.h: add #define for LITTLE_ENDIAN_LONG_LONG.
3586 * configure.in: check for endianness of long long.
Wichert Akkerman8ab1a3c2001-03-28 14:27:23 +00003587 * defs.h: change LONG_LONG macro to work with either endianness of
John Hughesb8a85a42001-03-28 08:05:27 +00003588 long long.
3589
35902001-03-27 John Hughes <john@Calva.COM>
3591
John Hughes61563572001-03-27 16:47:36 +00003592 * net.c: Make compilable by SCO UDK compiler (doesn't like empty
3593 initialisation list for array).
3594
35952001-03-27 John Hughes <john@Calva.COM>
3596
John Hughes8e075fb2001-03-27 13:57:48 +00003597 * svr4/syscallent.h: ntp_adjtime entry was duplicated on Solaris
3598 systems - bad merge of Harald Boehme's patch by me.
3599
Wichert Akkerman072ea8a2001-03-27 14:46:05 +000036002001-03-27 Wichert Akkerman <wakkerma@debian.org>
3601
3602 * lots of files: add Linux/hppa support
3603
Wichert Akkerman407be9a2001-03-19 10:56:49 +000036042001-03-19 Wichert Akkerman <wakkerma@debian.org>
3605
3606 * linux/mips/syscallent.h: we can't have -1 nargs, change to 0
Wichert Akkermane3bf56a2001-03-19 11:05:17 +00003607 * linux/syscallent.h: not that syscalls 220 and 221 are used now
Wichert Akkerman6f2bbe22001-03-19 11:00:29 +00003608 * config.guess: updated
Wichert Akkerman407be9a2001-03-19 10:56:49 +00003609
Wichert Akkermana9667852001-03-17 17:26:34 +000036102001-03-17 Wichert Akkerman <wakkerma@debian.org>
3611
3612 * linux/ioclsort.c: new file
3613 * linux/ioctlent.sh: complete rewrite to use a more sane approach to get
3614 the ioctl list that doesn't involve attempting to #include all kernel
3615 headers
3616 * linux/.cvsignore: added ioctdefs.h and ioctls.h which are generated
3617 by the new ioctlent.sh
3618 * ioctl.c: only look at the number and type bits for linux, since
3619 ioctlent.sh no longer supplies the others
3620
John Hughes70623be2001-03-08 13:59:00 +000036212001-03-08 John Hughes <john@Calva.COM>
3622
John Hughescf1de752001-03-08 17:27:20 +00003623 * freebsd/syscalls.pl: On FreeBSD we must cope with COMPATibility syscalls,
3624 pretend they have names ending with "?" so that -e trace=stat (for
3625 example) will work.
3626 * freebsd/i386/syscallent.h: add ? to compatability syscalls.
3627 * freebsd/i386/syscall.h: consistency.
3628
36292001-03-08 John Hughes <john@Calva.COM>
3630
John Hughesc0fc3fd2001-03-08 16:10:40 +00003631 * acconfig.h: add new ST_xxx defines.
3632 * aclocal.m4: macros to check for more fields in struct stat.
3633 * configure.in: use new macros to check for fields in struct stat.
3634 * file.c: use new defines to replace #ifdef FREEBSD by #if HAVE_ST_xxx.
3635
36362001-03-08 John Hughes <john@Calva.COM>
3637
John Hughes0c79e012001-03-08 14:40:06 +00003638 * defs.h: rename wimpy get64 as powerful new LONG_LONG
3639 * file.c: use LONG_LONG
3640 * io.c: use LONG_LONG
3641 * mem.c use LONG_LONG
3642
36432001-03-08 John Hughes <john@Calva.COM>
3644
John Hughes70623be2001-03-08 13:59:00 +00003645 * acconfig.h: new #defines HAVE_LONG_LONG_OFF_T and HAVE_LONG_LONG_RLIM_T.
3646 * aclocal.m4: routines to check for long long off_t and rlim_t.
3647 * configure.in: check for long long off_t and rlim_t.
3648 * desc.c: if HAVE_LONG_LONG_OFF_T treat flock as flock64
3649 * file.c: if HAVE_LONG_LONG_OFF_T treat stat,lstat,fstat and lseek as 64
3650 bit versions.
3651 * io.c: if HAVE_LONG_LONG_OFF_T use 64 bit versions of pread and pwrite.
3652 * mem.c: if HAVE_LONG_LONG_OFF_T use 64 bit version of mmap
3653 * resource.c: if HAVE_LONG_LONG_OFF_T use 64 bit versions of getrlimit
3654 and setrlimit.
3655 * freebsd/syscalls.print: don't explicitly use 64 bit versions of calls,
3656 now done automaticaly for us.
3657 * freebsd/i386/syscall.h: ditto.
3658 * freebsd/i386/syscallent.h ditto.
3659
John Hughes5a826b82001-03-07 13:21:24 +000036602001-03-07 John Hughes <john@Calva.COM>
3661
John Hughesb8c9f772001-03-07 16:53:07 +00003662 * desc.c: On FreeBSD flock structure uses 64 bit offsets.
3663 * file.c: On FreeBSD use stat64 and pals instead of stat.
3664 * freebsd/syscalls.print: use stat64, lstat64 and fstat64.
3665 * freebsd/i386/syscall.h: ditto.
3666 * freebsd/i386/syscallent.h: ditto.
3667
36682001-03-07 John Hughes <john@Calva.COM>
3669
John Hughese2f6d872001-03-07 16:03:20 +00003670 * file.c: merge missing part of Harald Böhme's solaris patches,
3671 was only declaring sys_{stat64,lstat64,fstat64} on linux!
3672
36732001-03-07 John Hughes <john@Calva.COM>
3674
John Hughes9dec06c2001-03-07 14:47:19 +00003675 * svr4/dummy.h: fix multiple define warning on non LFS64 systems.
3676 * svr4/syscallent.h: pread/pwrite are TF calls.
3677
36782001-03-07 John Hughes <john@Calva.COM>
3679
John Hughes5a826b82001-03-07 13:21:24 +00003680 * defs.h: add ALIGN64 macro to cope with FreeBSD's strange insistence
3681 on alignment for off_t (64 bit) arguments. Also simplify get64 so
3682 we don't need to know endianness of long long.
3683 * file.c: FreeBSD now uses 64 bit versions of lseek, truncate,
3684 ftruncate, allows reduction in numvber of horrid #if's
3685 * io.c: FreeBSD now uses 64 bit versions of pread, pwrite.
3686 * mem.c: FreeBSD now uses 64 bit version of mmap.
3687 * freebsd/syscalls.print: use 64 bit versions of various syscalls.
3688 * freebsd/i386/syscall.h: use 64 bit versions of various syscalls.
3689 * freebsd/i386/syscallent.h: use 64 bit versions of various syscalls.
3690
John Hughes95ea9c02001-03-07 10:11:02 +000036912001-03-06 John Hughes <john@Calva.COM>
3692
John Hughes7737c8a2001-03-07 10:41:58 +00003693 * file.c: Implement truncate64 and ftruncate64
3694 * svr4/dummy.h: add dummies for truncate64 and ftruncate64 for non
3695 LFS64 systems.
3696 * svr4/syscall.h: add declarations for truncate64 and ftruncate64.
3697
36982001-03-06 John Hughes <john@Calva.COM>
3699
John Hughesc5249902001-03-07 10:39:06 +00003700 * freebsd/syscalls.pl: fix for FreeBSD 4.1 (new optional field in
3701 syscall master file).
3702
37032001-03-06 John Hughes <john@Calva.COM>
3704
John Hughesbb557232001-03-07 10:37:38 +00003705 * syscall.c: fix for FreeBSD 4.1 (SYS_semconfig has disappeared). Also
3706 zap incorrect syscall subarg range check.
3707
37082001-03-06 John Hughes <john@Calva.COM>
3709
John Hughescb8b69d2001-03-07 10:34:27 +00003710 * configure.in, defs.h, desc.c, file.c, io.c, mem.c, net.c, resource.c,
3711 signal.c, syscall.c, svr4/dummy.h, svr4/syscall.h, svr4/syscallent.h:
3712 merge Harald Böhme's solaris patches (_LFS64_LARGEFILE and kernel aio
3713 mostly).
3714
37152001-03-06 John Hughes <john@Calva.COM>
3716
John Hughesbc4935a2001-03-07 10:28:50 +00003717 * dummy.h: add unimplemented UW sycalls
3718 * syscall.h: we can do settimeofday for UW, whopee!
3719 * syscallent.h: fix unimplemented UW syscalls
3720
37212001-03-06 John Hughes <john@Calva.COM>
3722
John Hughesc8f2e8a2001-03-07 10:26:17 +00003723 * aclocal.m4: look for pr_syscall in pr_lwp if we HAVE_MP_PROCFS
3724 * defs.h: add PR_SYSCALL to allow use of pr_lwp.pr_syscall if it exists.
3725 * syscall.c: use PR_SYSCALL instead of pr_syscall, fix up UnixWare code
3726 so it doesn't try to use pr_sysarg.
3727
37282001-03-06 John Hughes <john@Calva.COM>
3729
John Hughes091fe832001-03-07 10:15:39 +00003730 * aclocal.m4: on systems other than linux look for stat64 in sys/stat.h
3731 * file.c: handle xstat version _STAT64_VER, aka stat64.
3732
37332001-03-06 John Hughes <john@Calva.COM>
3734
John Hughes95ea9c02001-03-07 10:11:02 +00003735 * net.c: make sure SOL_ options are defined before using.
3736 * signal.c: declare sigset variable, only used on linux, inside #ifdef.
3737
Wichert Akkermanfa306182001-02-21 16:42:26 +000037382001-02-21 Wichert Akkerman <wakkerma@debian.org>
3739
3740 * net.c: fix format for printing Unix domain sockets
3741
Wichert Akkerman0cbfb322001-02-19 13:35:53 +000037422001-02-19 Wichert Akkerman <wakkerma@debian.org>
3743
3744 * linux/mips/syscallent.h: use new sys_sysmips
3745 * system.c: add sys_sysmips decoding
3746
Wichert Akkerman8c7122c2001-02-16 19:59:55 +000037472001-02-16 Wichert Akkerman <wakkerma@debian.org>
3748
Wichert Akkermanf1850652001-02-16 20:29:03 +00003749 * CREDITS: add Arkadiusz Miskiewicz <misiek@pld.org.pl> who
3750 submitted the IP6 scope ID updates
3751 * acconfig.h: add HAVE_SIN6_SCOPE_ID and HAVE_SIN6_SCOPE_ID_LINUX
3752 * aclocal.m4: add AC_SIN6_SCOPE_ID to check if sin6_scope_id is
3753 available
3754 * configure.in: check for if_indextoname function and sin6_scope_id
3755 * net.c: teach printsock about IP6 scope ids
3756
37572001-02-16 Wichert Akkerman <wakkerma@debian.org>
3758
Wichert Akkerman8c7122c2001-02-16 19:59:55 +00003759 * configure.in: test for netinet/tcp.h and netinet/udp.h existance
3760 * net.c: include netinet/tcp.h and netinet/udp.h if they exist
Wichert Akkermanedf2dcc2001-02-16 20:14:40 +00003761 * Makefile.in: use @mandir@ and @bindir@
Wichert Akkerman8c7122c2001-02-16 19:59:55 +00003762
Wichert Akkermanefdecac2000-11-26 03:59:21 +000037632000-11-26 Wichert Akkerman <wakkerma@debian.org>
3764
3765 * net.c: fix formating error in sys_setsockopt
3766 * net.c: add list of socketlayers and use that for [gs]etsockopt
3767
Roland McGrath36d87c22002-12-15 23:59:13 +000037682000-10-12 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkermand856b992000-10-13 12:47:12 +00003769
3770 * time.c: use sys/timex.h so things compile with 2.2 kernels
3771 * stream.c: test if MSG_* constants are #defined
3772
Wichert Akkerman9b0c31d2000-09-03 21:56:29 +000037732000-09-03 Wichert Akkerman <wakkerma@debian.org>
3774
Wichert Akkermanefdecac2000-11-26 03:59:21 +00003775 * process.c: perform bpt trick for clone as well so we can get the
3776 pid of the child before it starts doing something
3777 * file.c: rename dirent64 struct to kernel_dirent64 so things compile
3778 again with newer libcs
3779 * test/clone.c: improve our testcase a bit
3780 * Merge another patch from Gäel Roualland with FreeBSD updates
Wichert Akkerman9b0c31d2000-09-03 21:56:29 +00003781
Wichert Akkermanbf79f2e2000-09-01 21:03:06 +000037822000-09-01 Wichert Akkerman <wakkerma@debian.org>
3783
Wichert Akkermanefdecac2000-11-26 03:59:21 +00003784 * lots of files: merge patch from Gaël Roualland to add
3785 support for FreeBSD.
Wichert Akkermanbf79f2e2000-09-01 21:03:06 +00003786
Wichert Akkerman16a03d22000-08-10 02:14:04 +000037872000-08-09 Wichert Akkerman <wakkerma@debian.org>
3788
Wichert Akkermand077c452000-08-10 18:16:15 +00003789 * file.c: update to reflect that st_ino suddenly became a long long
3790 in the in Linux 2.4.0-test6
3791
37922000-08-09 Wichert Akkerman <wakkerma@debian.org>
3793
Wichert Akkerman16a03d22000-08-10 02:14:04 +00003794 * test/clone.c: minor fixup
3795 * Another bunch of patches from John Hughes merged:
3796 * signal.c:
3797 + SVR4 printcontext(): sigset_t != sigset_t*
3798 + getcontext returns a value, so print on exit of syscall
3799 + add UC_FP to ucontext_flags for OS writers that can't spell
3800 + sys_signal(): special case SIG_{ERR,DFL,IGN}
3801 + decode_subcall(): only do subcall range checking when needed
3802 * bunch of UnixWare updates
3803 * aclocal.m4, acconfig.h, configure.in: add test for long long type
3804
Wichert Akkerman7987cdf2000-07-05 16:05:39 +000038052000-07-04 Wichert Akkerman <wakkerma@debian.org>
3806
3807 * net.c: add SOL_PACKET and SOL_RAW socket options, update
3808 SOL_IP and SOL_TCP
3809
Wichert Akkermanbd4125c2000-06-27 17:28:06 +000038102000-06-23 Wichert Akkerman <wakkerma@debian.org>
3811
3812 * strace.c: close outf before we exec a child process
3813
Wichert Akkerman43a74822000-06-27 17:33:32 +000038142000-06-09 Ulrich Drepper <drepper@redhat.com>
3815
3816 * configure.in: Don't link against libnsl on Linux, it's unnecessary.
3817 * defs.h (struct tcb): Make auxstr member const.
3818 * file.c (fsmagic): And many more magic numbers.
3819 * util.c: Don't include <linux/ptrace.h> for glibc 2.1 and up.
3820
Wichert Akkerman5ae21ea2000-05-01 01:53:59 +000038212000-04-26 Wichert Akkerman <wakkerma@debian.org>
3822
3823 * defs.h: balance #if/#endif again
3824 * system.c: fix return statements in sys_capget()
3825 * Merge updates from Topi Miettinen <Topi.Miettinen@nic.fi>:
3826 + file.c: add F_[SG]ETSIG to fcntl flags
3827 + strace.c: don't setre[gu]id if not needed
3828 + system.c: handle sys_reboot for Linux
3829 + term.c: add baudrate constants up to B4000000
3830 + linux/**/syscallent.h: note that munlockall has no arguments
3831
38322000-04-25 David Mosberger <davidm@hpl.hp.com>
3833
3834 * CREDITS: fix email address
3835 * process.c: handle PR_[GS]ET_UNALIGN and PR_[GS]ET_KEEPCAPS
3836 * signal.c: honour offset of sigconfig in sigframe structure for
3837 Linux/ia64
3838 * linux/ia64/syscallent.h: Add perfmonctl, pivotroot, mincore, and
3839 madvise syscalls.
3840 * syscall.c (syscall_enter): With Kevin's latest ptrace patches,
3841 AR_BSP points to the _end_ of the active register frame, so we need
3842 to adjust bsp by moving it back by the size of the active frame
3843 before using it.
3844
38452000-04-24 Wichert Akkerman <wakkerma@debian.org>
3846
3847 * process.c: add sparc support to change_syscall
3848
Wichert Akkerman10dfa562000-04-22 18:26:56 +000038492000-04-22 Wichert Akkerman <wakkerma@debian.org>
3850
3851 * linux/mips/syscallent.h: fix some typos
3852
Wichert Akkerman481e45b2000-04-17 07:42:31 +000038532000-04-14 Wichert Akkerman <wakkerma@debian.org>
3854
3855 * linux/mips/syscallent.h: added names for SVR4, SYSV, BSD4.3 and POSIX
3856 syscalls
3857
Wichert Akkermanfd89ced2000-04-13 17:06:09 +000038582000-04-13 Wichert Akkerman <wakkerma@debian.org>
3859
3860 * defs.h: Linux/MIPS uses syscalls up to >4k, so set MAX_QUALS to
3861 4999
3862
Wichert Akkermanc7926982000-04-10 22:22:31 +000038632000-04-09 Wichert Akkerman <wakkerma@debian.org>
3864
3865 * README-linux: updated to note that strace might not compile
3866 with development kernels
3867 * bjm.c: sys_query_module: check if malloc succeeds
3868 * system.c: sys_cap[gs]et(): check if malloc succeeds, only malloc once
3869 * linux/syscallent.h: updated for 2.3.99pre3
3870 * linux/alpha/syscallent.h: updated for 2.3.99pre3, add all osf syscalls
3871 even though Linux doesn't implement them
3872 * syscall.c: add global variables for MIPS registers as well
3873 * syscall.c: move global variables to before get_scno since that uses them
3874 * util.c: oops, misspelled defined
3875 * process.c: fix ptrace calls in change_syscall
3876 * mem.c: decode sys_madvise
3877 * Merge patch from Topi Miettinen <Topi.Miettinen@nic.fi>
3878 + add support for quotactl, fdatasync, mlock, mlockall, munlockall & acct
3879 + small fix for RLIMIT_* and RUSAGE_BOTH
3880 + enhace support for capget and capset
3881
Wichert Akkermanfaf72222000-02-19 23:59:03 +000038822000-02-19 Wichert Akkerman <wakkerma@debian.org>
3883
3884 * test/vfork.c: new file to test vfork traces
3885 * test/.cvsignore: new file
3886 * defs.h: Up maximum number of traced processed to 64
Roland McGrath36d87c22002-12-15 23:59:13 +00003887 * strace.c: Disable some debugging code from davidm
Wichert Akkermanfaf72222000-02-19 23:59:03 +00003888 * implement setarg for more architectures
3889 * implement change_syscall
3890
Wichert Akkerman2ee6e452000-02-18 15:36:12 +000038911999-12-27 Morten Welinder <terra@diku.dk>
3892
3893 * syscall.c (lookup_signal, lookup_desc): isdigit requires an
3894 _unsigned_ char parameter.
3895
Wichert Akkerman12f75d12000-02-14 16:23:40 +000038962000-02-14 Wichert Akkerman <wakkerma@debian.org>
3897
3898 * S390 updates
3899
Wichert Akkerman8b1b40c2000-02-03 21:58:30 +000039002000-02-03 Wichert Akkerman <wakkerma@debian.org>
3901
Wichert Akkerman5ae21ea2000-05-01 01:53:59 +00003902 * Merge Linux/ia64 patches
Wichert Akkerman8b1b40c2000-02-03 21:58:30 +00003903
Pavel Machek4dc3b142000-02-01 17:58:41 +000039042000-01-02 Pavel Machek <pavel@ucw.cz>
3905
3906 * probe if sys/poll.h exists in configure + minor cleanups
3907
3908 * syscall.c: split trace_syscall into few pieces to make code readable
3909
Wichert Akkerman30160182000-01-21 20:31:34 +000039102000-01-21 Wichert Akkerman <wakkerma@debian.org>
3911
3912 * Release version 4.2 to get the current updates out and so
3913 we can concentrate in finishing the clone support.
3914
Wichert Akkerman3ed6dc22000-01-11 14:41:09 +000039152000-01-11 Wichert Akkerman <wakkerma@debian.org>
3916
3917 * Add 1900 to tm_year in sprinttime
3918
Wichert Akkerman0396bdc1999-12-24 23:11:57 +000039191999-12-24 Wichert Akkerman <wakkerma@debian.org>
3920
3921 * file.c: protect printstat64 with STAT64 instead of linux so we can
3922 compile on Linux architectures that don't have it
Wichert Akkerman9148a3b1999-12-24 23:13:55 +00003923 * util.c: fix LOOP for ARM
Wichert Akkerman0396bdc1999-12-24 23:11:57 +00003924
3925Fri Dec 24 18:05:00 EST 1999
3926
Ulrich Drepperc921cb21999-12-24 08:03:35 +000039271999-12-23 Ulrich Drepper <drepper@cygnus.com>
3928
3929 * file.c: Use ugly libc_stat trick also for stat64.
3930 Implement sys_stat64, sys_fstat64, sys_lstat64, and printstat64.
3931 * process.c (internal_clone): Fix a few typos and add definitions to make
3932 it at least compile.
3933 * linux/syscall.h: Declare sys_stat64, sys_lstat64, and sys_fstat64.
3934 * linux/syscallent.h: Define table entries for sys_stat64, sys_lstat64,
3935 and sys_fstat64.
3936 * aclocal.m4: Define AC_STAT64.
3937 * acconfig.h: Define HAVE_STAT64.
3938 * configure.in: Add AC_STAT64.
3939
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003940Thu Dec 23 15:01:37 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3941
3942 * Merge patch from ftp://oss.software.ibm.com/linux390/ to add
3943 support for Linux on the IBM S/390 architecture
Wichert Akkerman7a0b6491999-12-23 15:08:17 +00003944 * process.c: add internal_clone(), currently only shows the options
3945 * syscall.c: use internal_clone to handle SYS_clone
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003946
3947Mon Dec 20 00:27:50 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3948
3949 * Rewrite mmap-handling to support mmap2 on Linux
3950
Wichert Akkermane5be0de1999-12-14 10:46:18 +00003951Tue Dec 14 11:35:16 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3952
3953 * Note that Linux can handle sys_semop() as well
3954
Wichert Akkerman4dc8a2a1999-12-23 14:20:14 +00003955Tue Nov 30 11:05:26 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3956
3957 * Include linux/in6.h for glibc2.0 and older
3958
Wichert Akkermanea78f0f1999-11-29 15:34:02 +00003959Mon Nov 29 16:33:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3960
3961 * Merge patches from John Hughes to make configure support UnixWare
3962
Wichert Akkerman9123ac81999-11-27 21:58:20 +00003963Sat Nov 27 21:38:17 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3964
3965 * Enhance sys_query_module
3966
Wichert Akkermane4aafd41999-11-26 09:54:08 +00003967Fri Nov 26 10:51:55 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3968
3969 * Patches from John Hughes:
3970 + cosmectic fix in sys_getpmsg
Wichert Akkerman48214be1999-11-26 09:55:42 +00003971 + allow net.c to compile on systems without AF_INET6
3972 + Only use long_to_sigset on Linux systems
Wichert Akkerman46956571999-11-26 10:12:59 +00003973 + UnixWare treats sigmask_t and sigmask_t* as the same thing
Wichert Akkerman9dbf1541999-11-26 13:11:29 +00003974 + Add pollhack
Wichert Akkerman3377df71999-11-26 13:14:41 +00003975 + Parse mount arguments for UnixWare
3976 + ACL fixes for UnixWare
Wichert Akkermane4aafd41999-11-26 09:54:08 +00003977
Wichert Akkerman2a64b431999-11-26 00:29:05 +00003978Fri Nov 26 01:28:09 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3979
3980 * Release 4.1 to get all the changes made out there
3981
Wichert Akkermanf5eeabb1999-11-18 17:09:47 +00003982Thu Nov 18 18:04:04 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3983
3984 * Merge stracefork from Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>
3985 + Socket calls parsed better
3986 + bunch of alpha OSF syscalls added
3987 + Fix alpha 32/64 bit issues
3988
Wichert Akkerman2f473da1999-11-01 19:53:31 +00003989Mon Nov 1 20:52:08 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3990
3991 * Move Linux kernelmodule-functions from system.c to bjm.c and
3992 remove duplicate for sys_create_module
Wichert Akkerman60456d71999-11-01 19:59:33 +00003993 * Linux MIPS updates:
3994 + Play with #ifdef's in net.c to get IPv6 right
3995 + Use printargs for vm86-syscall
Wichert Akkerman2f473da1999-11-01 19:53:31 +00003996
Wichert Akkermanf90da011999-10-31 21:15:38 +00003997Sun Oct 31 22:03:00 CET 1999 Wichert Akkerman <wakkerma@debian.org>
3998
3999 * Merge Linux mips patch from Florian Lohoff <flo@rfc822.org>
4000
Wichert Akkerman50524821999-10-10 22:40:07 +00004001Mon Oct 11 00:36:25 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4002
4003 * Merge patch from Keith Owens <kaos@ocs.com.au> to sys_query_module
4004 and sys_delete_module correctly
4005
Wichert Akkerman15dea971999-10-06 13:06:34 +00004006Wed Oct 6 02:00:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4007
4008 * Update cvsbuild to give a better error if autoconf isn't installed
4009 * Add test for linux/ptrace.h to configure
4010 * Since we define GNU_SOURCE in the Makefile we don't need to define
4011 USE_GNU in file.c anymore
4012
4013Fri Sep 10 04:35:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4014
4015 * #define USE_GNU before including file.c so we get some extra O_* flags
4016
4017Tue Aug 31 16:27:21 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4018
4019 * Add missing } in IPv6 output
4020
Wichert Akkerman7b27ba01999-08-30 23:26:53 +00004021Tue Aug 31 01:23:08 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4022
4023 * Update copyright for strace-graph to BSD to be consistent with
4024 the rest of strace
4025
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00004026Mon Aug 30 00:53:57 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4027
4028 * Merge patch from Daniel Jacobowitz: KERN_JAVA_* and KERN_SECURELVL aren't
4029 defined for all kernelversions
Wichert Akkerman7b27ba01999-08-30 23:26:53 +00004030 * Add strace-graph, written by Richard Braakman <dark@xs4all.nl>
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00004031
4032Thu Aug 19 13:10:15 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
4033
4034 * linux/sparc/syscall.h: Declare create_module/init_module.
4035 * configure.in: Allow compilation in a different directory
4036 than the source one.
4037 * signal.c: Use asm/reg.h and struct regs instead of pt_regs
4038 so that we don't depend on asm/ptrace.h which clashes with
4039 glibc sys/ptrace.h.
4040 * util.c: Likewise.
4041 * syscall.c: Likewise.
4042
Wichert Akkerman5a777661999-08-04 16:03:49 +00004043Wed Aug 4 18:01:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4044
4045 * Syscall 94 on Linux alpha is sys_poll
4046
Wichert Akkerman9ce1a631999-08-29 23:15:07 +00004047Sun Jul 25 14:38:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4048
4049 * Merge in UnixWare patches from John Hughes <john@Calva.COM>
4050
Wichert Akkerman527a8051999-07-15 21:11:37 +00004051Thu Jul 15 23:00:32 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4052
4053 * Merge patch from Maciej W. Rozycki <macro@ds2.pg.gda.pl>:
4054 + Correctly implement fix sys_createmodule (Linux)
4055 + Add limited handlig of sys_initmodule (Linux)
4056
Wichert Akkerman36915a11999-07-13 15:45:02 +00004057Tue Jul 13 17:07:50 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4058
4059 * Add configure-test for sys/reg.h and use that
4060 * Use sys/reg.h instead of asm/ptrace.h
4061
Wichert Akkermanca446991999-07-09 23:48:58 +00004062Sat Jul 10 01:46:10 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4063
4064 * Remove hack in signal.c for arm architecture
4065 * Add hack so we compile correctly on powerpc
4066
Wichert Akkerman5b4d1281999-07-09 00:32:54 +00004067Fri Jul 9 02:28:16 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4068
4069 * Add a corrected patch from Daniel Jacobowitz
4070
Wichert Akkermana6013701999-07-08 14:00:58 +00004071Thu Jul 8 16:00:04 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4072
4073 * Merge patch from Daniel Jacobowitz to allow us to use the kernel types
4074 for the stat structure
4075
4076Thu Jun 24 15:54:18 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkerman2b483ba1999-06-24 13:55:29 +00004077
4078 * Fix test for sys/reg include
4079
Wichert Akkermana6013701999-07-08 14:00:58 +00004080Tue Jun 22 17:26:33 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
Wichert Akkermane6f876c1999-06-22 15:28:30 +00004081
4082 * Fixed some Linux/powerpc sillyness, thanks to Daniel Jacobowitz
4083 * Fixed some SunOS compile problems earlier that I forgot to include
4084 here
4085
Wichert Akkerman789ed351999-06-14 10:45:01 +00004086Mon Jun 14 12:44:25 CEST 1999
4087
4088 * Avoid leakint fd into child when forking, patch from
4089 John Hughes <john@Calva.COM>
4090
Wichert Akkerman8829a551999-06-11 13:18:40 +00004091Fri Jun 11 14:54:47 CEST 1999
4092
4093 * Applied IRIX64 patch from Thomas E. Dickey <dickey@clark.net>
4094 * Applied Solaris and manpage updates from Guy Harris <guy@netapp.com>
4095
Wichert Akkermancc4b8f41999-06-09 12:50:10 +00004096Wed Jun 9 14:48:49 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4097
4098 * Brought syscall list for alpha up to date
4099
Wichert Akkermandacfb6e1999-06-03 14:21:07 +00004100Wed Jun 2 18:30:12 CEST 1999 Jakub Jelinek <jj@ultra.linux.cz>
4101
4102 * system.c: sys_umount2 syscall support.
4103 * linux/sparc/errnoent.h: Update sparc-linux errnos.
4104 * linux/sparc/syscall.h: Update used sparc-linux syscalls.
4105 * linux/sparc/syscallent.h: Match 2.2.9 system calls.
4106 * file.c: sparc-linux asm/stat.h uses dev_t etc. types,
4107 so it needs strace's own copy of the stat structure.
4108 * util.c: Make it compile on sparc-linux.
4109 * strace.c: Fix strace -f and -ff operation on sparc-linux.
4110 * signal.c: rt_sigaction has different arguments on sparc*-linux
4111 and alpha-linux.
4112 * syscall.c: Recognize sparc64-linux binaries.
4113
Ulrich Drepper0d2d3231999-05-29 04:11:48 +00004114Fri May 28 21:09:00 PST Ulrich Drepper <drepper@cygnus.com>
4115
4116 * configure.in: Fix typo (CFLAG -> CFLAGS).
4117
Ulrich Drepper8783c011999-05-29 04:13:58 +00004118 * syscall.c: Don't include linux/ptrace.h explicitly for glibc.
4119
Wichert Akkerman22fe9d21999-05-27 12:00:57 +00004120Thu May 27 13:59:27 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4121
4122 * Add some sysctl support, patch from Ulrich Drepper
4123
Wichert Akkerman9524bb91999-05-25 23:11:18 +00004124Wed May 26 01:04:34 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4125
4126 * Use kernel dirent structure for Linux
4127
Wichert Akkerman2e2553a1999-05-09 00:29:58 +00004128Sun May 9 02:18:30 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4129
4130 * Merge in patches from Andreas Schwab <schwab@issan.cs.uni-dortmund.de>
4131 + some layout and other minor fixes
4132 + add some m68k-specific things to linux/syscallent.h. Note that m68k
4133 is similar enough to i386 to not need it's own subdirectory
4134 + add support for sendfile and mremap syscalls for Linux
4135 * Merge in patches from Sascha Schumann <sascha@schumann.2ns.de>
4136 + ioctls.h vs sys/ioctl.h on Alpha platform
4137 + pointer was casted to an int in stream.c
4138 + strsignal() needs -D_GNU_SOURCE in CFLAGS
4139 + several other casts changed
4140 + correct ARM/POWERPC architecture defines in acconfig.h
4141 * Merge in patches from Morten Welinder <terra@diku.dk>
4142 + add some autoconf-tests for includefiles
4143 + handle solaris version of sigcontext struct (actually I hacked this
4144 up again, but the idea is his :)
4145
Wichert Akkerman7a1f0e91999-04-18 20:23:57 +00004146Sun Apr 18 22:32:42 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4147
4148 * Update syscalls for linux alpha, patch from Bart Warmerdam
Ulrich Drepperc921cb21999-12-24 08:03:35 +00004149 <bartw@debian.org>
Wichert Akkermand4d8e921999-04-18 23:30:29 +00004150 * Update sparc code so it actually compiles
Wichert Akkerman7a1f0e91999-04-18 20:23:57 +00004151
Wichert Akkerman328c5e71999-04-16 00:21:26 +00004152Fri Apr 16 02:18:05 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4153
Wichert Akkerman25d0c4f1999-04-18 19:35:42 +00004154 * Add support for old_*stat functions for Linux. Please note you need
4155 to use reasonably recent kernel headers to compile strace now.
Wichert Akkerman328c5e71999-04-16 00:21:26 +00004156 * Change references to LINUX into linux in file.c
4157 * Fix include for LDT in mem.c
Wichert Akkerman1786d811999-04-15 20:34:14 +00004158
4159Thu Apr 15 22:28:15 CEST 1999 Wichert Akkerman <wakkerma@debian.org>
4160
4161 * Change in strace maintainership, jrs passed the torch to me.
4162 * Use autoconf 2.13
4163 * Incorporate all changes already made in the Debian strace package:
4164 + compiles with more Linux kernels
4165 + added support for more Linux architectures
4166 + add support for a lot of extra syscalls
4167 + fix some problems with hanging children
4168 + check stray syscall after execv
4169 + decode capget and capset arguments
4170 + add more constants to net.c
4171 + detect ROSE networking
4172 + add more protocol families to domains
4173 + add IPIP protocol
4174 + added MSG_PROXY and MSG_CTRUNC to msg_flags
4175 + added SO_BSDCOMPAT and SO_REUSEPORT to sockoptions
4176 + added IP, IPX and TCP-options
4177 + added IP, IPX and TCP support to get-/setsockopt()
4178 + added IPX support
4179 + updated handling of signals
4180
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00004181Sun Oct 27 22:28:00 1996 J. Richard Sladkey <jrs@world.std.com>
4182
4183 * util.c (umovestr) [LINUX]: Handle Linux like SunOS4
4184 instead of SVR4. That is, read a few bytes at a time
4185 to avoid overrunning the end of the stack.
4186
4187Fri May 31 01:48:49 1996 J. Richard Sladkey <jrs@world.std.com>
4188
4189 * version.c: Version 3.1 is released.
4190
4191Thu May 23 01:04:43 1996 J. Richard Sladkey <jrs@world.std.com>
4192
4193 * aclocal.m4 (AC_DECL_SYS_ERRLIST): Try looking in stdio.h
4194 as well since that's where glibc declares it. Go figure.
4195 * signal.c (sys_sigreturn) [ALPHA]: Use sigcontext
4196 instead of sigcontext_struct since glibc v5+ apparently
4197 plays games with the native OS namespace.
4198 From David Mosberger-Tang <davidm@AZStarNet.com>.
4199
4200Mon May 20 23:17:14 1996 J. Richard Sladkey <jrs@world.std.com>
4201
4202 * version.c: Version 3.0.14 is released.
4203
4204 * aclocal.m4 (AC_STRUCT_MSG_CONTROL): New macro.
4205 * configure.in: Add call to AC_STRUCT_MSG_CONTROL.
4206 * net.c (printmsghdr): Handle BSD 4.3 and 4.4 msghdr members
4207 differently.
4208 Reported by Henrik Storner <storner@osiris.ping.dk>.
4209
4210 * configure.in: (AC_CHECK_{HEADERS,FUNCS}): Add checks for
4211 sys/filio.h and sys/stream.h and remove check for poll.
4212 * desc.c (decode_select, sys_select, sys_oldselect) [LINUX]:
4213 Handle old and new styles of argument passing for select on Linux.
4214 * ioctl.c, stream.c: Conditionalize stream code on presence of
4215 sys/stream.h instead of poll because glibc implements poll but
4216 not the rest of the stream interface.
4217 * signal.c [LINUX]: Standardize on the name sigcontext_struct.
4218 (sys_sigprocmask) [ALPHA]: Handle OSF flavor which is more like
4219 sigsetmask.
4220 * term.c (term_ioctl): Use _VMIN, if present, for TC{G,S}ETA*.
4221 * util.c (umoven, umovestr): Move data in long-sized chunks
4222 at a time, instead of hard coding it to be 4.
4223 From David Mosberger-Tang <davidm@AZStarNet.com>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00004224
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00004225Mon May 20 01:19:36 1996 J. Richard Sladkey <jrs@world.std.com>
4226
4227 * version.c: Version 3.0.13 is released.
4228
4229 * configure.in (AC_CHECK_HEADERS): Add check for asm/sigcontext.h.
4230 * signal.c [HAVE_ASM_SIGCONTEXT_H]: Conditionally include
4231 asm/sigcontext.h to define sigcontext_struct and don't define it
4232 locally if the header is present.
4233
4234 * syscall.c (nerrnos{0,2}): Correct size computation.
4235
4236 * Makefile.in: Remove dependencies and rules relating to files
4237 normally found in the os directory. Because of the new scheme we
4238 don't know precisely where they come from. Sigh.
4239 * signalent.sh: Make it work for sunos4, linux, and svr4.
4240 * {sunos4,linux{,/alpha},svr4}/Makefile.in: Make rules correspond
4241 to traditional make syntax. Add signalent.h to files which can
4242 unconditionally be rebuilt. Prevent signalent.h from being
4243 unconditionally being rebuilt since it's customized.
4244 * {sunos4,linux{,/alpha},svr4}/{ioctlent,errnoent,signalent}.h:
4245 Use versions built by {ioctlent,errnoent,signaltent}.sh.
4246 * sunos4/ioctlent.sh: Work around sprintf troubles with SunOS
4247 4.1.4 and gcc 2.7.2.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00004248
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00004249Sun May 19 17:14:09 1996 J. Richard Sladkey <jrs@world.std.com>
4250
4251 * configure.in, Makefile.in: Add OSARCH concept to finish
4252 build support for the alpha.
4253 * Makefile.in, linux/Makefile.in: Rewrite clean, distclean,
4254 and maintainer-clean rules.
4255 * defs.h, ioctlsort.c: Make ioctl code member unsigned.
4256 * ioctl.c, ioctlsort.c (compare): Perform explicit checking
4257 for less, greater, and equal since subtraction on two's
4258 complement numbers isn't an order relation (it isn't transitive)!
4259 * linux/Makefile.in: Add rules for the signalent.h file.
4260 * linux/alpha/Makefile.in: New file.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00004261
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00004262Sun May 19 01:12:28 1996 J. Richard Sladkey <jrs@world.std.com>
4263
4264 * version.c: Version 3.0.12 is released.
4265
4266 * linux{,alpha}/ioctlent.sh: Tweak for recent kernels.
4267 From Michael E Chastain <mec@duracef.shout.net>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00004268
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00004269 * defs.h (SUPPORTED_PERSONALITES, DEFAULT_PERSONALITY): New.
4270 * syscall.c (set_personality): New.
4271 * strace.c (main): Call set_personality.
4272 * defs.h, syscall.c, ioctl.c, signal.c: Make sysent, errnoent,
4273 ioctlent, and signalent indirect pointers and redirect them
4274 based on personality.
4275 * {sunos4,svr4,linux{,/alpha}}/signalent.h: New files.
4276 Suggested by Tom Dyas <tdyas@eden.rutgers.edu>.
4277
4278 * util.c (upeek): Handle case where ptrace returns a long
4279 and sizeof(long) != sizeof(int).
4280 From Richard Henderson <richard@twiddle.tamu.edu>
4281
4282Fri May 17 21:03:36 1996 J. Richard Sladkey <jrs@world.std.com>
4283
4284 * version.c: Version 3.0.11 is released.
4285
4286 * many files: Fix more printf warnings for other platforms.
4287
4288 * ipc.c (sys_msgrcv) [LINUX]: Conditionalize definition of ipc_wrapper.
4289
4290 * linux/dummy.h: Handle missing library support for {send,recv}msg.
4291 Reported by Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
4292
4293 * linux/syscall.h (sys_utimes): Fix a typo in the declaration.
4294 From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
Ulrich Drepperc921cb21999-12-24 08:03:35 +00004295
Wichert Akkerman76baf7c1999-02-19 00:21:36 +00004296Fri May 17 00:50:06 1996 J. Richard Sladkey <jrs@world.std.com>
4297
4298 * version.c: Version 3.0.10 is released.
4299
4300 * Makfile.in: Add os/arch to includes so that a given arch
4301 (like alpha) can override the native arch (like i386).
4302 * configure.in: Check for sendmsg.
4303
4304 * net.c: Make sendmsg and recvmsg dependent on an autoconf
4305 test. Reported by Michael E Chastain <mec@duracef.shout.net>.
4306
4307 * acconfig.h, configure.in: Detect the alpha.
4308 * ioctl.c: Handle the alpha.
4309 * defs.h: Make some members long for the alpha. Define
4310 some register nicknames. Add support for WAITEXECVE.
4311 * file.c [ALPHA]: Support the alpha for statfs. Add
4312 osf_statfs and osf_fstatfs for the alpha. Make damn sure
4313 major and minor results are suitable for passing to printf.
4314 * signal.c, syscall.c: Support the alpha.
4315 * process.c: Add alpha user offsets.
4316 * most files: Use %l? for printf arguments since
4317 most are now longs for the alpha.
4318 * linux/alpha/{errnoent.h,ioctlent.{h,sh},syscallent.h}:
4319 New for the alpha.
4320 From Thomas Bogendoerfer <tsbogend@bigbug.franken.de>.
4321
4322Wed May 15 00:29:37 1996 J. Richard Sladkey <jrs@world.std.com>
4323
4324 * version.c: Version 3.0.9 is released.
4325
4326 * config.in, config.sub, install-sh: Upgrade to autoconf 2.10.
4327
4328 * linux/dummy.h, linux/syscallent.h, linux/syscall.h: Add recent
4329 Linux kernel version system calls.
4330
4331Wed Mar 13 01:03:38 1996 J. Richard Sladkey <jrs@world.std.com>
4332
4333 * ipc.c [SUNOS4]: Add SunOS support for decoding IPC calls.
4334 * syscall.c [SUNOS4]: Compile decode_subcall on SunOS and
4335 decode IPC calls using it.
4336 * sunos4/dummy.h: Alias sys_semop to printargs.
4337 * sunos4/syscall.h: Add new pseudo syscalls for IPC.
4338 * sunos4/syscallent.h: Include new subcalls for IPC.
4339 From Matthias Pfaller <leo@dachau.marco.de>.
4340
4341Tue Feb 13 22:08:25 1996 J. Richard Sladkey <jrs@world.std.com>
4342
4343 * version.c: Version 3.0.8 is released.
4344
4345 * time.c [LINUX]: Explicitly include linux/version.h.
4346
4347 * strace.c (main): Don't let them even *try* to
4348 get strace to attach to itself since some systems
4349 don't handle this case very gracefully.
4350 Reported by David S. Miller <davem@caip.rutgers.edu>.
4351
4352 * Makefile.in (distclean): Fix it for subdirectories.
4353
4354 * sunos4/syscallent.h, svr4/syscallent.h: Fill in the new
4355 sys_flags member for each defined system call.
4356
4357Fri Dec 8 01:17:28 1995 Rick Sladkey <jrs@world.std.com>
4358
4359 * defs.h (TRACE_*): New flags to describe what class
4360 of system call each system call is.
4361 (sysent): Add sys_flags member.
4362 * syscall.c (sysent): Define (and later undef) abbreviations
4363 for the system call class flags.
4364 (lookup_class): New function to translate strings to
4365 system call class flags.
4366 (qualify): Handle new system call class mechanism.
4367 * linux/syscallent.h: Fill in the new sys_flags member
4368 for each defined system call.
4369
4370 * defs.h (print_sock): Remove redundant and non-K&R C
4371 compatible prototype. From Juergen Weigert
4372 <jnweiger@immd4.informatik.uni-erlangen.de>.
4373
4374Thu Dec 7 01:17:40 1995 Rick Sladkey <jrs@world.std.com>
4375
4376 * linux/ioctlent.sh: Tweak to improve ioctl accuracy.
4377 From Michael E Chastain <mec@duracef.shout.net>.
4378
4379 * system.c (includes) [LINUX]: Add linux/nfs.h for recent
4380 kernels. From Michael E Chastain <mec@duracef.shout.net>.
4381
4382Wed Dec 6 21:52:28 1995 Rick Sladkey <jrs@world.std.com>
4383
4384 * file.c (sprintfstype): Enclose string result in double
4385 quotes.
4386
4387 * time.c (sys_adjtimex) [LINUX]: Conditionalize
4388 constantly evolving timex structure.
4389 From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
4390
4391 * defs.h, syscall.c, strace.c: Rename syscall to
4392 trace_syscall and change prototype and all callers
4393 because of broken Linux shared libraries.
4394 From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
4395
4396 * Makefile.in (clean): Check for a file with test -f not
4397 test -d. From Aaron Ucko <UCKO@VAX1.ROCKHURST.EDU>.
4398
4399Tue Sep 26 02:32:31 1995 Rick Sladkey <jrs@world.std.com>
4400
4401 * version.c: Version 3.0.7 is released.
4402
4403 * util.c (string_quote): Fix thinko which caused core
4404 dumps for strings with quotes in them.
4405 Reported by Marty Leisner <leisner@sdsp.mc.xerox.com>.
4406
4407 * linux/Makefile.in (errnoent.h rule): Grab all errno.h
4408 files from /usr/include, not just the linux one.
4409 From Michael E Chastain <mec@duracef.shout.net>.
4410
4411 * linux/errnoent.sh: Total rewrite to handle more ioctls with
4412 fewer false positives on more kernel flavors.
4413 From Michael E Chastain <mec@duracef.shout.net>.
4414
4415Mon Sep 4 01:29:22 1995 Rick Sladkey <jrs@world.std.com>
4416
4417 * version.c: Version 3.0.6 is released.
4418
4419 * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
4420 sys_msync.
4421 * mem.c (mctl_funcs, mctl_lockas, sys_mctl): Conditionalize
4422 on MC_SYNC instead of HAVE_MCTL.
4423 (mctl_sync): Conditionalize on MS_ASYNC instead of HAVE_MCTL.
4424 (sys_msync): New function.
4425
4426Sat Sep 2 12:06:04 1995 Rick Sladkey <jrs@world.std.com>
4427
4428 * linux/dummy.h, linux/syscall.h, linux/syscallent.h: Add
4429 sys_flock and sys_getdents.
4430 * desc.c (flockcmds, sys_flock): Conditionalize on LOCK_SH
4431 not SUNOS4.
4432 * file.c (sys_getdents): Define unconditionally and handle
4433 LINUX case.
4434 * strace.c (main): Disallow username option unless both real
4435 and effective uids are root.
4436
4437Wed Aug 30 01:29:58 1995 Rick Sladkey <jrs@world.std.com>
4438
4439 * strace.c (main): Ensure that run_uid and run_gid are
4440 always set to something meaningful.
4441 (main, newoutf) [!SVR4]: Swap real and effective uids while
4442 opening any output files.
4443 (main) [!SVR4]: Treat effective uid of root as a request
4444 to handle suid binaries correctly using the real uid of
4445 the invoking user.
4446
4447Sat Aug 19 00:06:08 1995 Rick Sladkey <jrs@world.std.com>
4448
4449 * Makefile.in: Add `|| true' to clean rule because
4450 although GNU make 3.74 uses `sh -c' to invoke commands
4451 every other make in the world uses `sh -ec'.
4452
4453 * syscall.c (syscall) [SVR4, MIPS]: The fifth and subsequent
4454 arguments appear to be stored on the stack, not in the
4455 registers following A3 (empirical result).
4456
4457 * defs.h: Add prototype for printsock.
4458 * svr4/dummy.h: Remove generic handling of sys_mount.
4459 * system.c [SVR4, MIPS]: Include several system headers to cleanly
4460 get access to SGI mount information.
4461 (mount_flags, nfs_flags) [SVR4, MIPS]: New objects.
4462 (sys_mount) [SVR4, MIPS]: New function.
4463 (sys_mount) [SVR4, !MIPS]: New function.
4464
4465Tue Jul 4 00:30:34 1995 Rick Sladkey <jrs@world.std.com>
4466
4467 * version.c: Version 3.0.5 is released.
4468
4469 * desc.c, resource.c, strace.c, syscall.c, time.c: Cast tv_sec and
4470 tv_usec members to long when using printf.
4471
4472 * ipc.c: Omit define of __KERNEL__.
4473 ({MSG,SEM,SHM}_{STAT,INFO}): Explicitly define those things we
4474 want which __KERNEL__ used to provide.
4475 (sys_msgrcv): Change reference to ipc_kludge structure to
4476 look-alike ipc_wrapper to avoid dependence on __KERNEL__.
4477
4478 mem.c (mmap_flags) [MAP_{GROWSDOWN,DENYWRITE,EXECUTABLE}]: Add
4479 Linux specific options.
4480
4481 syscall.c: Use SYS_ERRLIST_DECLARED instead of guessing.
4482 [E{RESTART{SYS,NO{INTR,HAND}},NOIOCTLCMD}]: Explicitly define
4483 instead of depending of __KERNEL__.
4484
4485 term.c: Cast c_{i,o,c,l}flag to long when using printf.
4486
4487Tue Jun 6 00:27:48 1995 Rick Sladkey <jrs@world.std.com>
4488
4489 * aclocal.m4 (AC_DECL_SYS_ERRLIST, AC_DECL__SYS_SIGLIST): New.
4490 * configure.in: Call AC_DECL_SYS_ERRLIST, AC_DECL_SYS_SIGLIST,
4491 and AC_DECL__SYS_SIGLIST.
4492 * acconfig.h (SYS_ERRLIST_DECLARED): New.
4493 * strace.c (strerror): Use SYS_ERRLIST_DECLARED.
4494 (strsignal): Use SYS_SIGLIST_DECLARED.
4495
4496 net.c (sys_socket): Omit inadvertent surplus comma when
4497 protocol family isn't PF_INET.
4498
4499 util.c (dumpstr): Fix incorrect printing of one too many
4500 characters when the length is not an even multiple of 16 bytes.
4501 Reported by Juergen Weigert
4502 <jnweiger@immd4.informatik.uni-erlangen.de>.
4503
4504Thu May 4 23:37:47 1995 Rick Sladkey <jrs@world.std.com>
4505
4506 * ioctl.c (compare): Change prototype to match POSIX qsort.
4507 * signal.c (sigishandled) [SVR4]: Omit everything after return.
4508 * strace.c (trace) [SVR4]: Break out of for loop instead of
4509 returning when finished so final return statement is executed.
4510 * syscall.c (internal_syscall): Add more SYS_wait* variations.
4511 (syscall) [LINUX]: Correct typo which commented out the M68K
4512 argument to ifdef.
4513 * util.c (printstr): Cast unsigned char pointer argument
4514 to char pointer in umovestr call.
4515 (dumpstr): Likewise for umoven.
4516
4517Wed May 3 01:10:56 1995 Rick Sladkey <jrs@world.std.com>
4518
4519 * version.c: Version 3.0.4 is released.
4520
4521 * signal.c (sys_sigblock): Move after the definition of
4522 sys_sigsetmask that it calls to avoid an implicit declaration.
4523 * stream.c (transport_user_options, transport_server_options):
4524 Only needed if TI_BIND is defined.
4525 * configure.in: Add -Wno-implicit to WARNFLAGS on SunOS 4.x.
4526
4527 * process.c (internal_fork) [SVR4]: Fix a typo that omitted
4528 the tcp arguement from the call to exiting. Add getrval2
4529 check so no fork processing is done in the child.
4530 (printwaitn): Initialize exited so that its value is defined
4531 for all flows of execution.
4532
4533Tue May 2 22:39:42 1995 Rick Sladkey <jrs@world.std.com>
4534
4535 * linux/dummy.h: Add aliases for sysfs, personality, afs_syscall,
4536 setfsuid, setfsgid, and _llseek syscalls.
4537 * linux/syscall.h: Add prototypes for them.
4538 * linux/syscallent.h: Add them to the syscall entries table.
4539 * system.c (headers) [LINUX]: Include linux/unistd.h to get __NR_*
4540 defines and conditionally include linux/personality.h if
4541 __NR_personality is defined.
4542 (personality_options) [LINUX]: New table.
4543 (sys_personality) [LINUX]: New function.
4544
4545Tue May 2 00:20:39 1995 Rick Sladkey <jrs@world.std.com>
4546
4547 * strace.c (trace) [!SVR4]: Change forever loop to one predicated
4548 on the number of traced processes so that we can have untraced
4549 children (e.g. via popen).
4550
4551 * strace (main) [!SVR4]: Call fake_execve to get the actual
4552 exec and its arguments into the trace.
4553 (environ): Declare it.
4554 * process.c (fake_execve): New function.
4555 (headers): Include sys/syscall.h to get SYS_* defines.
4556
4557 * process.c (sys_execv, sys_execve): Surround argument annotations
4558 with C comment delimiters.
4559 (printargv, printargc): The arg vector is an array of char pointers
4560 not ints.
4561
4562 * strace.c (printleader): Also check for multiple -p arguments
4563 when deciding whether to print the pid field.
4564
4565 * strace.c (strerror) [!HAVE_STRERROR]: New function.
4566 * defs.h (strerror, strsignal): Add these prototypes if we provide
4567 the functions.
4568 * configure.in (AC_CHECK_FUNCS): Add strerror.
4569
4570 * strace.c (main, proc_poller): Add SIGPIPE to the list of caught
4571 and blocked signals.
4572
4573 * strace.c (main): Add username option. Verify they are root before
4574 letting them use it. Look up the ids in the password file. Set
4575 them just before executing the program.
4576 From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
4577
4578Sat Apr 29 00:09:56 1995 Rick Sladkey <jrs@world.std.com>
4579
4580 * version.c: Version 3.0.3 is released.
4581
4582 * system.c (mount_flags) [LINUX]: Omit duplicated MS_NOSUID entry.
4583 From Reuben Sumner <rasumner@undergrad.math.uwaterloo.ca>.
4584
4585 * strace.c (outfname): Initialize to NULL.
4586 (main): Defer output file processing until after arguments.
4587 Allow either a pipe or a bang for command arguments.
4588 Check if outfname is NULL instead of checking outf for stderr.
4589 Reinitialize each startup TCB's outf to fix -p/-o ordering bug.
4590 (droptcb): Reset close TCB's outf to NULL instead of stderr.
4591 (tprintf): Avoid calling vfprintf if outf is NULL.
4592
4593 * strace.c (main): Use popen if -o argument begins with a pipe.
4594 From Marty Leisner <leisner@sdsp.mc.xerox.com>.
4595
4596 * process.c (printstatus): Fix a typo where WIFSIGNALED was meant
4597 but WIFSTOPPED was used.
4598
4599 * Makefile.in: Add an EXTRA_DEFS variable and use it in the .c.o
4600 rule to prevent the comment from being untrue.
4601
4602Fri Apr 28 22:01:56 1995 Rick Sladkey <jrs@world.std.com>
4603
4604 * strace.c (sys_exit): Move follow fork code to internal_exit.
4605 (sys_fork): Move follow fork code to internal_fork.
4606 (sys_execv, sys_execve): Move follow fork code to internal_exec.
4607 (sys_waitpid, sys_wait4): Move follow fork code to internal_wait.
4608 (vforking): Remove this static variable and check scno in
4609 internal_fork instead.
4610 (internal_exit, internal_fork, internal_exec, internal_wait): New
4611 functions.
4612 * defs.h: Add prototypes for the new internal_* functions.
4613 * syscall.c (syscall): Move syscall entering trace qualifier check
4614 and reprint checking after context decoding and precede them with
4615 a call to internal_syscall. Precede syscall exiting trace
4616 qualifier check with a call to internal_syscall.
4617 (internal_syscall): New function.
4618
4619 * defs.h (struct tcb): Make scno signed.
4620 * strace.c (syscall) Make u_error signed.
4621 [LINUX, I386]: Avoid unsigned cast in eax check.
4622 * syscall.c (sys_indir): Make i, scno, and nargs signed.
4623 * desc.c (sys_select): Make cumlen unsigned
4624
4625Mon Apr 24 23:52:47 1995 Rick Sladkey <jrs@world.std.com>
4626
4627 * net.c (socktypes): Add SOCK_PACKET.
4628
4629Sun Apr 2 23:50:39 1995 Rick Sladkey <jrs@world.std.com>
4630
4631 * Makefile (clean): Check explicitly for a Makefile in subdirs
4632 before running make in them.
4633
4634Sun Mar 26 12:37:21 1995 Rick Sladkey <jrs@world.std.com>
4635
4636 * strace.c [MIPS] (proc_open): Conditionalize run on MIPS.
4637 [MIPS] (detach): Initialize error for MIPS case.
4638 (trace): Initialize ioctl_result and ioctl_errno for overly helpful
4639 compilers.
4640 * syscall.c (decode_subcall): Move variable i into conditionals
4641 that use use it.
4642 * system.c (syssgi_options): Conditionalize SGI_RECVLMSG and
4643 SGI_SET_FPDEBUG that SGI decided to drop. I don't have the stomach
4644 to change them all.
4645 * term.c (term_ioctl): Force [c_[iocl]flags members to long before
4646 printing since we don't know what the size of their type is.
4647 * util.c [SVR4, MIPS] (umoven): Prevent MIPS from using pread even
4648 if autoconf detects it since it seems to either not work or do
4649 something else entirely on Irix 5.3.
4650
4651Sun Mar 26 00:01:11 1995 Rick Sladkey <jrs@world.std.com>
4652
4653 * version.c: Version 3.0.2 is released.
4654 * linux/dummy.h: Make sys_fchdir like sys_close instead of printargs
4655 so that the file descriptor arg is decimal.
4656
4657Sat Mar 25 22:50:13 1995 Rick Sladkey <jrs@world.std.com>
4658
4659 * net.c [LINUX] (protocols): Explicitly define all IPPROTO_* entries
4660 because on Linux they are enumerators.
4661
4662 * system.c [LINUX] (mount_flags): Handle renaming of MS_SYNC to
4663 MS_SYNCHRONOUS.
4664
4665 * util.c (printxval): When there is no translation, print the actual
4666 number first and the the default value as a C comment.
4667
4668 * net.c (sys_send, sys_sendto, sys_sendmsg, sys_getsockopt,
4669 sys_setsockopt): Change first argument from unsigned to signed to
4670 cater to the frequent practice of calling system calls with a file
4671 descriptor of -1.
4672 * mem.c (sys_mmap): Likewise.
4673
4674Sun Mar 19 13:53:52 1995 Rick Sladkey <jrs@world.std.com>
4675
4676 * signal.c [LINUX] (signalent): Handle old and new values of SIGIO.
4677
4678Sun Dec 11 22:51:51 1994 Rick Sladkey <jrs@world.std.com>
4679
4680 * version.c: Version 3.0.1 is released.
4681 * Makefile.in, configure.in, aclocal.m4: Changes for autoconf 2.0.
4682 * config.guess, config.guess: Update from the FSF.
4683 * install-sh: New from the FSF.
4684
4685Mon Dec 5 20:51:29 1994 Rick Sladkey <jrs@world.std.com>
4686
4687 * Makefile.in: Add m68k arch.
4688 * acconfig.h (M68K): Add m68k define.
4689 * configure.in: Add detection of arch m68k.
4690 * process.c [M68K] (struct_user_offsets): Support m68k registers and
4691 offsets.
4692 * signal.c [M68K] (sigcontext_struct): Support m68k sigcontext
4693 structure.
4694 [M68K] (sys_sigreturn): Support m68k sigreturn handling.
4695 * syscall.c [M68K] (syscall): Support m68k syscall number register
4696 and errno in d0 instead of eax.
4697 * util.c [M68K] (getpc, printcall, setbpt, clearbpt): Support m68k
4698 program counter in PT_PC instead of EIP.
4699 [M68K] (LOOP): Support m68k loop instruction.
4700 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
4701
4702 * mem.c [MAP_ANONYMOUS] (mmap_flags): Correct inadvertent reference
4703 to MAP_FIXED instead of MAP_ANONYMOUS.
4704 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
4705
4706 * signal.c [LINUX] (signalent): Signal 30 is now SIGPWR.
4707 From Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>.
4708
4709Mon Dec 5 01:05:46 1994 Rick Sladkey <jrs@world.std.com>
4710
4711 * defs.h (tprintf): Fix typo in non-gcc ansi prototype for tprintf.
4712 Reported by Thanh Ma <tma@encore.com>.
4713
4714 * strace.c (cleanup): Send SIGCONT before SIGTERM because Linux
4715 1.1.62 doesn't continue a traced child when the parent exits.
4716 Reported by Matt Day <mday@artisoft.com>.
4717
4718 * system.c [LINUX]: Include netinet/in.h before arpa/inet.h.
4719
4720 * util.c (printstr): Fix longstanding bug in notating string
4721 continuation.
4722
4723 * strace.c [SVR4] (proc_open): Specifically wait for the child the
4724 child to go into the execve syscall to avoid spurious traces.
4725 [LINUX] (detach): Conditionalize the status variable.
4726
4727Sun Dec 4 23:21:42 1994 Rick Sladkey <jrs@world.std.com>
4728
4729 * Makefile.in: Add mips arch.
4730 * acconfig.h (MIPS): Add mips define.
4731 * configure.in: Add detection of opsys irix5 and arch mips. Check
4732 for prctl function.
4733 Check for sys/sysconfig.h header.
4734 * defs.h (MAX_ARGS): Bump maximum syscall arguments from 8 to 32.
4735 * file.c [SVR4]: Include sys/cred.h.
4736 (access_flags): Update access flags for SGI.
4737 (sprinttime): Change type of sprinttime argument from unsigned
4738 long to time_t.
4739 * process.c [HAVE_PRCTL]: Include sys/prctl.h.
4740 [HAVE_PRCTL] (prctl_options, sys_prctl): New for SGI.
4741 (printsiginfo): Conditionally compile SI_TIMER and SI_MESGQ.
4742 Cast si_band member to long before printing.
4743 * signal.c (sigact_flags): Add _SA_BSDCALL for SGI.
4744 (sigprocmaskcmds): Add SIG_SETMASK32 for SGI.
4745 * strace.c [SVR4] [MIPS]:
4746 (foobar): New dummy signal handler.
4747 (main): Install a dummy signal handler in the child before pausing
4748 to work around an SGI bug in PRSABORT.
4749 (proc_open): Send a interrupt to the child instead of aborting the
4750 syscall which doesn't work on Irix5.2.
4751 * svr4/dummy.h: Add new unfinished SGI syscalls
4752 (e.g. sys_sysmp, sys_sginap, etc.). Handle some SGI syscalls like
4753 existing calls (e.g. sys_ksigaction like sys_sigaction).
4754 Printargs does the print thing for sys_sethostid.
4755 * svr4/syscall.h: Declare all new SGI syscalls.
4756 (SGI_KLUDGE): Define syscall table starting index to be 1 for SGI
4757 and add it to all subcall entry points.
4758 (SYS_pgrpsys_subcall, SYS_sigcall_subcall, SYS_context): Don't
4759 decode as subcalls on MIPS. Instead, use the normal syscalls.
4760 * svr4/syscallent.h [MIPS]: Lead syscall table with a dummy entry
4761 since SGI syscall numbers are off by one.
4762 [MIPS] (sys_pgrpsys): Rename to sys_setpgrp on SGI.
4763 [MIPS] (sys_xenix): Rename to sys_syssgi on SGI.
4764 [MIPS] (sys_sysmachine): Rename to sys_sysmips on SGI.
4765 [MIPS]: Conditionalize SVR4 extension into SGI and Solaris classes.
4766 * syscall.c (dumpio): Validate descriptor against MAX_QUALS.
4767 [HAVE_PR_SYSCALL] (syscall): Conditionalize SYS_vfork.
4768 [MIPS] (syscall): Add SGI section for decoding u_error and u_rval.
4769 Add workaround for broken SGI pr_sysarg on syscall entry.
4770 [SVR4] (syscall): Conditionalize subcall decoding for
4771 SYS_ptrpsys_subcall, SYS_sigcall_subcall and SYS_context_subcall.
4772 [SVR4] [MIPS] (getrval2): Handle SGI.
4773 * syscallent.sh: Dork the sed line to be choosier about SYS_ lines.
4774 * system.c [HAVE_SYSCONFIG_H]: Include sys/sysconfig.h.
4775 [MIPS] (syssgi_options, sys_syssgi): New for SGI.