The Amsterdam Compiler Kit
davidgiven Merge pull request #133 from davidgiven/dtrg-mips
Allow constants >INT_MAX in mcg
Latest commit 1b60af4 Sep 22, 2018
Failed to load latest commit information.
bin Distributions are a pain --- let's not bother any more. Instead, we j… Sep 2, 2016
doc Distributions are a pain --- let's not bother any more. Instead, we j… Sep 2, 2016
emtest Distributions are a pain --- let's not bother any more. Instead, we j… Sep 2, 2016
etc After finding the em_table documentation, move it somewhere where oth… Jun 13, 2018
examples Build a smaller startrek for CP/M. May 4, 2018
fast Remove UNSIGNED_ARITH from a few more files. Oct 29, 2017
fcc Distributions are a pain --- let's not bother any more. Instead, we j… Sep 2, 2016
first Don't crash and burn if there are no tests to run. Jun 23, 2018
h Ansify. Sep 10, 2018
include/_tail_mon Distributions are a pain --- let's not bother any more. Instead, we j… Sep 2, 2016
lang Create correctly sized csa descriptors in the Basic compiler. Sep 19, 2018
lib Disable the built-in preprocessor in cemcom.ansi; the external prepro… Sep 2, 2018
mach When parsing constants which don't fit into an arith, handle overflow… Sep 22, 2018
man Add the .dataf4 and .dataf8 directives to the assembler --- manually … Sep 10, 2018
modules Convert CRLF into LF on read; this should avoid problems with parsing… Sep 2, 2018
plat Updated READMEs with the MIPS platform. Sep 18, 2018
tests/plat Array descriptor ranges are inclusive; adjust aar and the tests to ch… Sep 17, 2018
util Add the OPTIONS clause to the mcgg grammar; add an optional pass whic… Sep 22, 2018
.clang-format Warning-fixed and ansified the Modula-2 library. Jun 25, 2018
.distr Updated distr files. Jun 21, 2013
.drone.yml Disable the msys32 build because it doesn't work (due to brk issues). Sep 1, 2018
.hgignore Add hgignore file. Jun 12, 2016
.travis.yml Try and *actually* use clang for the clang build. Jun 2, 2018
Action Modified to no longer build LLgen, as it is now distributed seperately. Jul 18, 2006
CHANGES Updated. Sep 3, 2016
Copyright new copyright notice in repository May 26, 2005
Makefile The default installation location should be /usr/local. Sep 1, 2018
NEW Added some new readmes at the top level. Jun 24, 2005
README Updated READMEs with the MIPS platform. Sep 18, 2018
TODO Added some new readmes at the top level. Jun 24, 2005
build.lua Add huge numbers of failing tests. Sep 10, 2018


                     THE AMSTERDAM COMPILER KIT V6.1pre1

                  © 1987-2005 Vrije Universiteit, Amsterdam


The Amsterdam Compiler Kit is a complete compiler toolchain consisting of
front end compilers for a number of different languages, code generators,
support libraries, and all the tools necessary to go from source code to
executable on any of the platforms it supports.

This is an early prerelease of the apocryphal version 6.1 release. Not a
lot is supported, the build mechanism needs work, and a lot of things are
probably broken. However, what's there should be sufficient to get things
done and to evaluate how the full 6.1 release should work. 



ANSI C, B, Pascal, Modula 2, Basic. K&R is supported via the ANSI C compiler.


pc86          produces bootable floppy disk images for 8086 PCs
linux386      produces ELF executables for PC Linux systems
linux68k      produces ELF executables for m68020 Linux systems
linuxppc      produces ELF executables for PowerPC Linux systems
linuxmips     produces ELF executables for little-endian MIPS32r2 Linux systems
cpm           produces i80 CP/M .COM files
rpi           produces Raspberry Pi GPU binaries
pdpv7         produces PDP/11 V7 Unix binaries


The version 5.0 build mechanism has been completely rewritten. Installation
ought to be fairly straightforward.


- an ANSI C compiler. This defaults to gcc. You can change this by setting
  the CC make variable.

- flex and yacc.

- GNU make.

- (optionally) ninja; if you've got this, this will be autodetected and give
  you faster builds.

- (optionally) the qemu suite: if you have this installed, the build system
  will detect it automatically and run the test suites for the supported
  architectures. Get both the qemu-system-* platform emulators and the qemu-*
  userland emulators (only works on Linux).

- about 115MB free in /tmp (or some other temporary directory).

- about 15MB in the target directory.


- edit the Makefile. There's a small section at the top where you can change
  the configuration. Probably the only one you may want to edit is PREFIX,
  which changes where the ACK installs to.

- Run:


  ...from the command line. This will do the build.

  The make system is fully parallelisable. If you have a multicore system,
  install ninja and it'll use all your cores. If you don't have ninja, you
  can still use make for parallel builds with:

    make -r -j8   # or however many cores you have

  ...but frankly, I recommend ninja.

- Run:

    sudo make install

  ...from the command line. This will install the ACK in your PREFIX
  directory (by default, /usr/local).

The ACK should now be ready to use.


Currently I haven't sorted out all the documentation --- it's supplied in the
distribution, but not all of it gets installed yet --- so here is a quickstart

The main command to use is 'ack'. This invokes the compiler and the linker.
Some useful options include:

  -m<platform>     build for the specified platform
  -o <file>        specifies the output file
  -c               produce a .o file
  -c.s             produce a .s assembly file
  -O               enable optimisation (optimisation levels go up to 6)
  -ansi            compile ANSI C (when using the C compiler)
  -v               be more verbose (repeatable)
  <file>           build file

ack figures out which language to use from the file extension:

  .c               C (ANSI or K&R)
  .b               the PDP-11 dialect of B
  .bas             Basic
  .mod             Modula-2
  .ocm             Occam 1
  .p               Pascal
  .o               object files
  .s               assembly files
  .e               ACK intermediate code assembly files

For further information, see the man page (which actually does get
installed, but is rather out of date).

There are some (known working) example programs in the 'examples' directory.
A sample command line is:

ack -mlinux386 -O examples/paranoia.c


There are some things you should be aware of.

- Look at plat/<PLATFORMNAME>/README for information about the supported
- The library support is fairly limited; for C, it's at roughly the ANSI C
  level, and for the other languages it's similar.
- When compiling languages other than C, the ACK will usually look at the
  first character of the file. If it's a #, then the file will be run through
  the C preprocessor anyway.

- BSD systems may need to up the number of file descriptors (e.g.
  'ulimit -n 200') before the ACK will compile.
- The ACK uses its own .o format. You won't be able to mix the ACK's object
  files and another compiler's.

- When compiling together multiple B source files, you need to do some extra
  work to initialise them properly otherwise your program will crash on
  startup; see the ack(1) and abmodules(1) man pages.

- The distribution contains *everything*, including the weird, ancient,
  archaic stuff that doesn't work any more and never will, such as the int EM
  interpreter and the assembler-linkers. Only some of it builds. Look for
  build.lua files.


The ACK is mature, well-tested software, but the environment in which it was
developed for and tested under is rather different from that available on
today's machines. There will probably be little in the way of logical bugs,
but there may be many compilation and API bugs.

If you wish to use the ACK, *please* join the mailing list. We are interested
in any reports of success and particularly, failure. If it does fail for you,
we would love to know why, in as much detail as possible. Bug fixes are even
more welcome.

The ACK is licensed under a BSD-like license. Please see the 'Copyright' file
for the full text.

You can find the mailing list on the project's web site:
Please enjoy.

David Given (davidgiven on Github)