summaryrefslogtreecommitdiffstats
path: root/usr.bin/truss
Commit message (Collapse)AuthorAgeFilesLines
* Use cat(1) instead of cp(1) so as not to break -DNOCLEAN buildsmarcel2003-06-061-2/+2
| | | | when the file permissions of source files don't allow writing.
* Revamp of the syscall path, exception and context handling. Themarcel2003-05-161-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | prime objectives are: o Implement a syscall path based on the epc inststruction (see sys/ia64/ia64/syscall.s). o Revisit the places were we need to save and restore registers and define those contexts in terms of the register sets (see sys/ia64/include/_regset.h). Secundairy objectives: o Remove the requirement to use contigmalloc for kernel stacks. o Better handling of the high FP registers for SMP systems. o Switch to the new cpu_switch() and cpu_throw() semantics. o Add a good unwinder to reconstruct contexts for the rare cases we need to (see sys/contrib/ia64/libuwx) Many files are affected by this change. Functionally it boils down to: o The EPC syscall doesn't preserve registers it does not need to preserve and places the arguments differently on the stack. This affects libc and truss. o The address of the kernel page directory (kptdir) had to be unstaticized for use by the nested TLB fault handler. The name has been changed to ia64_kptdir to avoid conflicts. The renaming affects libkvm. o The trapframe only contains the special registers and the scratch registers. For syscalls using the EPC syscall path no scratch registers are saved. This affects all places where the trapframe is accessed. Most notably the unaligned access handler, the signal delivery code and the debugger. o Context switching only partly saves the special registers and the preserved registers. This affects cpu_switch() and triggered the move to the new semantics, which additionally affects cpu_throw(). o The high FP registers are either in the PCB or on some CPU. context switching for them is done lazily. This affects trap(). o The mcontext has room for all registers, but not all of them have to be defined in all cases. This mostly affects signal delivery code now. The *context syscalls are as of yet still unimplemented. Many details went into the removal of the requirement to use contigmalloc for kernel stacks. The details are mostly CPU specific and limited to exception_save() and exception_restore(). The few places where we create, destroy or switch stacks were mostly simplified by not having to construct physical addresses and additionally saving the virtual addresses for later use. Besides more efficient context saving and restoring, which of course yields a noticable speedup, this also fixes the dreaded SMP bootup problem as a side-effect. The details of which are still not fully understood. This change includes all the necessary backward compatibility code to have it handle older userland binaries that use the break instruction for syscalls. Support for break-based syscalls has been pessimized in favor of a clean implementation. Due to the overall better performance of the kernel, this will still be notived as an improvement if it's noticed at all. Approved by: re@ (jhb)
* Decode a few more syscalls.mdodd2003-04-151-1/+24
|
* Removed extra parentheses.ru2003-02-201-1/+1
|
* Fixed comment.ru2003-02-203-3/+3
|
* mdoc(7) police: markup polishing.ru2002-11-261-4/+10
| | | | Approved by: re
* Port to ia64. It builds, but usability is very limited.marcel2002-11-103-0/+349
|
* Various cleanups of truss:dwmalone2002-11-096-97/+121
| | | | | | | | | | | 1) Missing include. 2) Constness. 3) ANSIfication. 4) Avoid some shadowing. 5) Add/clarify some error messages. 6) Some int functions were using return without a value. 7) Mark some parameters as unused. 8) Cast a value we know is non-negative to a size_t before comparing.
* Check if name is NULL before we strcmp the syscall name. This wasdwmalone2002-11-091-1/+1
| | | | | sometimes triggered if you began trussing a process while it was in a syscall, as the name is filled in when the syscall is made.
* Don't depend on <signal.h> to include <sys/time.h>, instead includemike2002-10-062-0/+2
| | | | | <sys/time.h> directly. This is mostly bogus since CLOCK_REALTIME should be defined in <time.h>, which these files already include.
* Remove an unnecessary cast.mdodd2002-08-071-2/+2
|
* - Use time.h not sys/time.h.mdodd2002-08-069-13/+13
| | | | | | - Fix printf format errors. Submitted by: bde
* Remove extra space in output.mdodd2002-08-051-1/+1
|
* Diff reduction.mdodd2002-08-056-140/+244
|
* Use timespec not timeval.mdodd2002-08-053-15/+24
|
* Ported to sparc64.jake2002-08-044-5/+372
|
* Include <sys/time.h> for the declaration of struct timeval. Do notbde2002-08-047-0/+7
| | | | | | depend on namespace pollution in <signal.h>. (truss shouldn't be using timevals anyway, since it was implemented long after timevals were obsoleted by timespecs.)
* Add options to print the argument and environment string parameters tomdodd2002-08-0410-6/+146
| | | | | | | | | execve(). This could be done in a more general manner but it still wouldn't be very pretty. MFC after: 3 weeks
* Add a "FreeBSD ELF32" entry to ex_types[].mdodd2002-08-041-0/+1
|
* Terminate the output line when a non-returning syscall is printed.mdodd2002-08-045-0/+5
|
* Add options to print absolute and relative timestamps.mdodd2002-08-044-5/+46
| | | | | PR: bin/25587 (in part) MFC after: 3 weeks
* Allow tracking fork()ed children.mdodd2002-08-0411-10/+80
| | | | | PR: bin/25587 (in part) MFC after: 3 weeks
* Parameterize globals.mdodd2002-08-0411-143/+196
| | | | | PR: bin/25587 (in part) MFC after: 3 weeks
* s/inline/__inline/markm2002-07-196-6/+6
|
* OOPS! rev 1.16 accidently changed the default outfile from stderr topeter2002-05-161-1/+1
| | | | | | | | stdout. Unfortunately, DES mfc'ed this change in 1.15.2.1 (this part probably should not have been) so it is broken there too. truss is documented to use stderr, and other implementations use stderr. Submitted by: Arne Dag Fidjestøl <adf@idi.ntnu.no>
* Do not bother with #include <machine/psl.h> since it is just a stub filepeter2002-05-011-1/+0
| | | | that says something like "/* Not used on Alpha */".
* Use fseeko and uintptr_t to make sure that we get a sensible offsetdwmalone2002-04-211-2/+2
| | | | | | | | when trying to read from the stack. PR: 37104 Submitted by: Thomas Quinot <thomas@cuivre.fr.eu.org> MFC after: 3 weeks
* Use `The .Nm utility'charnier2002-04-201-2/+3
|
* I now don't seem to be able to reproduce the -DNOCLEAN buildworldru2002-04-111-5/+1
| | | | | | | | | | breakage with ioctl.c. The .depend file should track dependencies just fine, and the worst we can have is to miss new ioctls. But I still think it's a good idea to have -DNOCLEAN build produce the same ioctl.c as it would without -DNOCLEAN. Prodded for a long time by: bde
* Remove NO_WERRORs and WARNS=n's. To be revisited after GCC3.markm2002-02-081-3/+0
|
* Fix the code that selects the default binary type if the actual type can'tdes2002-02-081-3/+3
| | | | | | | | be determined. PR: bin/34698 Submitted by: (in part) Stefan Farfeleder <e0026813@stud3.tuwien.ac.at> MFC after: 1 weeks
* Print open(2) flags in hex instread of decimal for clarity.alfred2001-12-301-2/+2
|
* Partial WARNS=1 fizes with NO_WERROR set to prevent world breakage.markm2001-12-118-38/+78
| | | | Use __FBSDID().
* Print the correct return code for successful Linux syscalls.des2001-11-172-2/+4
| | | | | | Submitted by: Vitezslav Novy <vita@fio.cz> PR: 32036 MFC after: 1 week
* Add missing include for <ctype.h>green2001-11-061-27/+47
| | | | | | | Make sockaddr printing code unbad. Always copy in sizeof(sockaddr_un) bytes for an AF_UNIX sockaddr, despite what the length may be.
* Back out part of previous commit: remove #include <sys/proc.h>.des2001-10-222-2/+0
|
* #include <sys/proc.h> where needed (for the stop event definitions) anddes2001-10-227-29/+49
| | | | reorder includes everywhere to conform to style(9).
* Teach truss(1) to display sockaddrs. It currently knows about AF_INET,des2001-10-212-3/+82
| | | | | | | | | AF_INET6 and AF_UNIX sockaddrs, and will recognize accept(), bind(), connect(), getpeername() and getsockname() as syscalls taking sockaddr arguments. Some enterprising soul might want to add (and test) support for the send() / recv() family of syscalls as well. MFC after: 1 week
* In get_string(), 0-terminate the contents of buf ``just in case'';joerg2001-08-281-0/+1
| | | | | | | otherwise, if the very first fgetc() already yielded EOF, the returned string won't get terminated at all. MFC after: 1 day
* Initialize outfile in main()peter2001-08-131-1/+2
|
* Remove whitespace at EOL.dd2001-07-151-1/+1
|
* mdoc(7) police: removed HISTORY info from the .Os call.ru2001-07-101-1/+1
|
* Prepare for mdoc(7)NG.ru2000-12-191-0/+1
|
* mdoc(7) police: use canonical form of .Dd macro.ru2000-12-111-1/+1
|
* mdoc(7) police: use the new features of the Nm macro.ru2000-11-201-2/+2
|
* cc -O -pipe -I/usr/src/usr.bin/kdump/../ktrace ↵jkh2000-09-141-2/+6
| | | | | | -I/usr/src/usr.bin/kdump/../.. Fix ioctl.c creation to deal with the depend case more properly. Submitted by: Ruslan Ermilov <ru@sunbay.com>
* remove .PHONY to avoid gratuitous rebuild of ioctl.c each time.jkh2000-09-141-1/+1
| | | | Approved by: sef
* Make auto-generated ioctl.c to be always considered out of dateru2000-08-011-1/+1
| | | | | | since it could potentially depend on any ${DESTDIR}/usr/include preprocessor file. This fixes the broken -DNOCLEAN world build I experienced yesterday.
* Change the output of truss to more closely resemble SysV's. (Yes, itsef2000-03-187-31/+24
| | | | | | really is much nicer looking.) Submitted by: "Matthew N. Dodd" <winter@jurai.net>
* Fix a leak. (Thanks Bruce, this was a bonehead mistake on my part :).)sef2000-02-151-3/+8
| | | | Submitted by: Bruce Evans
OpenPOWER on IntegriCloud