2004-04-10 18:53:55 +00:00
|
|
|
.TH MACH 3
|
|
|
|
.SH NAME
|
2004-04-11 03:42:27 +00:00
|
|
|
machbytype, machbyname \- machine-independent access to executables and programs
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH SYNOPSIS
|
|
|
|
.B #include <u.h>
|
|
|
|
.br
|
|
|
|
.B #include <libc.h>
|
|
|
|
.br
|
|
|
|
.B #include <mach.h>
|
|
|
|
.PP
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void machbytype(int type)
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
int machbyname(char *name)
|
|
|
|
.PP
|
|
|
|
.B
|
2004-04-11 03:42:27 +00:00
|
|
|
extern Mach *mach;
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH DESCRIPTION
|
2004-04-11 03:42:27 +00:00
|
|
|
.I Libmach
|
|
|
|
provides an interface for accessing
|
|
|
|
the executable files and executing images of various architectures
|
|
|
|
and operating systems.
|
|
|
|
The interface is machine-independent, meaning that, for example,
|
|
|
|
Mac OS X core dumps may be inspected using an x86 Linux machine
|
|
|
|
and vice versa.
|
|
|
|
In its current form,
|
|
|
|
the library is mainly useful for writing debuggers
|
|
|
|
of one sort or another.
|
|
|
|
.PP
|
|
|
|
An architecture is described primarily by a
|
2004-04-10 18:53:55 +00:00
|
|
|
.B Mach
|
2004-04-11 03:42:27 +00:00
|
|
|
structure, which contains
|
|
|
|
data structures and parameters describing the
|
|
|
|
particular architecture.
|
|
|
|
Most library functions assume that the global variable
|
2004-04-10 18:53:55 +00:00
|
|
|
.I mach
|
2004-04-11 03:42:27 +00:00
|
|
|
points at the structure for the architecture being debugged.
|
|
|
|
It is set implicitly by
|
|
|
|
.I crackhdr
|
|
|
|
(see
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR mach-file (3) )
|
2004-04-11 03:42:27 +00:00
|
|
|
and can be set explicitly by calling
|
|
|
|
.I machbyname
|
|
|
|
or
|
|
|
|
.IR machbytype .
|
|
|
|
.PP
|
|
|
|
There is no operating system-specific structure akin to
|
|
|
|
.IR mach .
|
|
|
|
Typically the choice of operating system on a particular
|
|
|
|
architecture affects only the executable and core dump formats;
|
|
|
|
the various file parsers deduce the operating system from
|
|
|
|
information in the binary files themselves and adjust
|
|
|
|
accordingly.
|
|
|
|
.PP
|
2005-01-03 06:40:20 +00:00
|
|
|
The supported architectures are
|
|
|
|
.B 386
|
|
|
|
(Intel 32-bit x86)
|
|
|
|
386 and later)
|
|
|
|
and
|
|
|
|
.B power
|
|
|
|
(IBM PowerPC, typically running
|
|
|
|
Mac OS X).
|
|
|
|
.PP
|
2004-04-11 03:42:27 +00:00
|
|
|
Other manual pages
|
|
|
|
describe the library functions in detail.
|
|
|
|
.PP
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR Mach-cmd (3)
|
2005-01-03 06:40:20 +00:00
|
|
|
describes some convenience routines for attaching to
|
|
|
|
processes and core files.
|
|
|
|
.PP
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR Mach-file (3)
|
2004-04-11 03:42:27 +00:00
|
|
|
describes the manipulation of binary files.
|
|
|
|
.PP
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR Mach-map (3)
|
2004-04-11 03:42:27 +00:00
|
|
|
describes the interface to address spaces and register sets
|
|
|
|
in executable files and executing programs.
|
|
|
|
.PP
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR Mach-stack (3)
|
2004-04-11 03:42:27 +00:00
|
|
|
describes support for unwinding the stack.
|
|
|
|
.PP
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR Mach-swap (3)
|
2004-04-11 03:42:27 +00:00
|
|
|
describes helper functions for accessing data
|
|
|
|
in a particular byte order.
|
|
|
|
.PP
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR Mach-symbol (3)
|
2004-04-11 03:42:27 +00:00
|
|
|
describes the interface to debugging symbol information.
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH SOURCE
|
2005-01-11 17:37:33 +00:00
|
|
|
.B \*9/src/libmach
|
2004-04-11 03:42:27 +00:00
|
|
|
.SH "SEE ALSO
|
2020-08-16 00:07:38 +00:00
|
|
|
.MR mach-file (3) ,
|
|
|
|
.MR mach-map (3) ,
|
|
|
|
.MR mach-stack (3) ,
|
|
|
|
.MR mach-swap (3) ,
|
|
|
|
.MR mach-symbol (3)
|