shithub: riscv

ref: ffb48be969338833a69e576e7d62353bbd831226
dir: /sys/man/1/vi/

View raw version
.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.