171 lines
2.8 KiB
Text
171 lines
2.8 KiB
Text
|
.TH VI 1
|
||
|
.SH NAME
|
||
|
5i, ki, vi, qi \- instruction simulators
|
||
|
.SH SYNOPSIS
|
||
|
.B vi
|
||
|
[
|
||
|
.I textfile
|
||
|
]
|
||
|
.br
|
||
|
.B vi
|
||
|
.I pid
|
||
|
.br
|
||
|
.B 5i
|
||
|
[
|
||
|
.I textfile
|
||
|
]
|
||
|
.br
|
||
|
.B 5i
|
||
|
.I pid
|
||
|
.br
|
||
|
.B ki
|
||
|
[
|
||
|
.I textfile
|
||
|
]
|
||
|
.br
|
||
|
.B ki
|
||
|
.I pid
|
||
|
.br
|
||
|
.B qi
|
||
|
[
|
||
|
.I textfile
|
||
|
]
|
||
|
.br
|
||
|
.B qi
|
||
|
.I pid
|
||
|
.SH DESCRIPTION
|
||
|
.I Vi
|
||
|
simulates the execution of a MIPS binary in
|
||
|
a Plan 9 environment.
|
||
|
It has two main uses: as
|
||
|
a debugger and as a statistics gatherer.
|
||
|
Programs running under
|
||
|
.I vi
|
||
|
execute about two hundred times
|
||
|
slower than normal\(embut faster than
|
||
|
single stepping under
|
||
|
.IR db .
|
||
|
.IR 5i ,
|
||
|
.IR ki ,
|
||
|
and
|
||
|
.IR qi
|
||
|
are similar to
|
||
|
.I vi
|
||
|
but interpret ARM, SPARC, and PowerPC binaries.
|
||
|
The following discussion refers to
|
||
|
.I vi
|
||
|
but applies to the others
|
||
|
as well.
|
||
|
.PP
|
||
|
.I Vi
|
||
|
will simulate the execution of a named
|
||
|
.IR textfile .
|
||
|
It will also make a copy of an existing process with process id
|
||
|
.I pid
|
||
|
and simulate its continuation.
|
||
|
.PP
|
||
|
As a debugger
|
||
|
.I vi
|
||
|
offers more complete information
|
||
|
than
|
||
|
.IR db (1).
|
||
|
Tracing can be performed at the level of instructions,
|
||
|
system calls, or function calls.
|
||
|
.I Vi
|
||
|
allows breakpoints to be triggered when specified addresses
|
||
|
in memory are accessed.
|
||
|
A report of instruction counts,
|
||
|
load delay fills and distribution is produced for
|
||
|
each run.
|
||
|
.I Vi
|
||
|
simulates the CPU's caches and MMU
|
||
|
to assist the optimization of compilers and programs.
|
||
|
.PP
|
||
|
The command interface mirrors the interface to
|
||
|
.IR db ;
|
||
|
see
|
||
|
.IR db (1)
|
||
|
for a detailed description.
|
||
|
Data formats and addressing are compatible with
|
||
|
.I db
|
||
|
except
|
||
|
for disassembly:
|
||
|
.I vi
|
||
|
offers only MIPS
|
||
|
.RB ( db
|
||
|
.BR -mmipsco )
|
||
|
mnemonics for
|
||
|
machine instructions.
|
||
|
.I Ki
|
||
|
offers both Plan 9 and Sun SPARC formats.
|
||
|
.PP
|
||
|
Several extra commands allow
|
||
|
extended tracing and printing of statistics:
|
||
|
.TP
|
||
|
.BR $t [ 0ics ]
|
||
|
The
|
||
|
.I t
|
||
|
command controls tracing. Zero cancels all tracing
|
||
|
options.
|
||
|
.RS
|
||
|
.TP
|
||
|
.B i
|
||
|
Enable instruction tracing
|
||
|
.TP
|
||
|
.B c
|
||
|
Enable call tracing
|
||
|
.TP
|
||
|
.B s
|
||
|
Enable system call tracing
|
||
|
.RE
|
||
|
.TP
|
||
|
.BR $i [ itsp ]
|
||
|
The
|
||
|
.B i
|
||
|
command prints statistics accumulated by
|
||
|
all code run in this session.
|
||
|
.RS
|
||
|
.TP
|
||
|
.B i
|
||
|
Print instruction counts and frequency.
|
||
|
.TP
|
||
|
.B p
|
||
|
Print cycle profile.
|
||
|
.TP
|
||
|
.B t
|
||
|
.RI ( Vi
|
||
|
only) Print TLB and cache statistics.
|
||
|
.TP
|
||
|
.B s
|
||
|
Print memory reference, working set and size statistics.
|
||
|
.RE
|
||
|
.TP
|
||
|
.BR :b [ arwe ]
|
||
|
.I Vi
|
||
|
allows breakpoints to be set on any memory location.
|
||
|
These breakpoints monitor when a location is
|
||
|
accessed, read, written, or equals a certain value.
|
||
|
For equality the compared value is the
|
||
|
.I count
|
||
|
(see
|
||
|
.IR db (1))
|
||
|
supplied to the command.
|
||
|
.SH SOURCE
|
||
|
.B /sys/src/cmd/vi
|
||
|
etc.
|
||
|
.SH "SEE ALSO"
|
||
|
.IR nm (1),
|
||
|
.IR db (1)
|
||
|
.SH BUGS
|
||
|
The code generated by
|
||
|
the compilers
|
||
|
is well supported, but some unusual instructions are unimplemented.
|
||
|
Some Plan 9 system calls such as
|
||
|
.I rfork
|
||
|
cause simulated traps.
|
||
|
The floating point simulation makes assumptions about the interpreting
|
||
|
machine's floating point support. The floating point conversions performed
|
||
|
by
|
||
|
.I vi
|
||
|
may cause a loss of precision.
|