69 lines
1.7 KiB
Groff
69 lines
1.7 KiB
Groff
|
.TH EM_B 6
|
||
|
.ad
|
||
|
|
||
|
|
||
|
.SH NAME
|
||
|
em_b \- ACK B compiler
|
||
|
|
||
|
|
||
|
.SH SYNOPSIS
|
||
|
.B ~em/lib/ack/em_b
|
||
|
.RI [ options ]
|
||
|
|
||
|
|
||
|
.SH DESCRIPTION
|
||
|
.I em_b
|
||
|
is a port of the ABC B compiler to the ACK. Interested parties will be
|
||
|
interested in the upstream distribution here:
|
||
|
|
||
|
.nf
|
||
|
.sp
|
||
|
https://github.com/aap/abc
|
||
|
.fi
|
||
|
|
||
|
However, the version here has been heavily modified --- bug reports should be
|
||
|
filed with the ACK, not with the upstream compiler.
|
||
|
|
||
|
.PP
|
||
|
Since B was designed for machines with word addressing, some hacking is
|
||
|
required to make it work on modern, byte addressed machines. The generated
|
||
|
code expects B variables to contain word addresses, and then generates
|
||
|
code to transform these into native addresses before use (which,
|
||
|
unfortunately, impacts performance). However, the ACK's linker doesn't know
|
||
|
how to emit word addresses into the program's data sections, and so a
|
||
|
separate fixup stage has to happen at runtime, just before \fBmain()\fP,
|
||
|
to convert the byte addresses into word addresses.
|
||
|
|
||
|
.PP
|
||
|
The end result is that using multiple source files with B is somewhat
|
||
|
unwieldy, requiring each module to be explicitly named and then an extra
|
||
|
stage to generate the fixup code. See the \fBack\fP(1) and \fBabmodules\fP(1)
|
||
|
for details.
|
||
|
|
||
|
|
||
|
.SH OPTIONS
|
||
|
|
||
|
.I em_b
|
||
|
accepts the following flags:
|
||
|
|
||
|
.IP \-w\ \fIsize\fP
|
||
|
Sets the word size, used for scaling addresses. Usually either 2 or 4.
|
||
|
|
||
|
.IP \-B\ \fIname\fP
|
||
|
Sets the name of the module currently being compiled (used to generate the
|
||
|
fixup table symbol name). Defaults to \fImain\fP if not specified.
|
||
|
|
||
|
.IP \-i\ \fIfilename\fP
|
||
|
The source B file.
|
||
|
|
||
|
.IP \-o\ \fIfilename\fP
|
||
|
The output compact EM bytecode file.
|
||
|
|
||
|
|
||
|
|
||
|
.SH SEE ALSO
|
||
|
\fIack\fR(1), \fIabmodules\fR(1)
|
||
|
|
||
|
.SH REMARKS
|
||
|
It is very unlikely the \fIem_b\fP will ever be useful for anything.
|