Wiki Roadmap Timeline Tickets New Ticket Source Search Help / Guide About Trac Login

LLVM D Compiler

LDC is a compiler for the D programming Language. It is based on the latest DMD frontend and uses LLVM 2.4 as backend. LLVM provides a fast and modern backend for high quality code generation. LDC is released under a BSD license with exceptions for the DMD frontend and code from GDC.

The development takes place mostly on x86-32 Linux and that is where LDC works best. Support for other platforms and architectures is under development, but we are still looking for people to help test and adjust LDC for those platforms!

LDC already compiles a lot of D code, but should still be considered beta quality. Take a look at the tickets to get a better impression on what still needs to be implemented.

We have two sets of tests living in the tests directory. The mini testsuite in mini/ and minicomplex/ contains a few tests that are supposed to compile or run and is mostly used when fixing a bug. There is also the larger DStress based test suite comparing LDC revisions among themselves and to DMD.

Project Status

  • The first release is near.
  • x86 Linux: Tango compiles and all its unittests pass. MiniD compiles. DWT still has issues.
  • Help is welcome for getting LDC to work on other platforms!
  • D2 support is highly experimental!

See the tickets for more details.

Communication

Feedback is much appreciated, you can contact us via IRC in the #ldc channel on FreeNode or the mailing list at ldc-dev@googlegroups.com.

The dsource forum is hardly ever looked at by the developers, please use the mailing list instead. If you've found a bug, feel free to report it directly.

D binding for LLVM

While not part of the LDC compiler, a llvm binding to LLVM for D can be found in the old SVN repository. The binding is a wrapper around the LLVM C interface with a few extensions. See the source/samples for more information.

Documentation

Documentation is still sparse, but there is a little on the versions and pragmas. There is also the beginnings of a hackers guide.

How To Compile

Dependencies:

Download, Compile and install LLVM 2.4

wget http://llvm.org/releases/2.4/llvm-2.4.tar.gz
tar -xvzf llvm-2.4.tar.gz
mv llvm-2.4 llvm-2.4-src
mkdir llvm-2.4-obj
cd llvm-2.4-obj
../llvm-2.4-src/configure --enable-optimized
make
su -c 'make install'
cd ..

Grab LDC from the Mercurial repository:

hg clone http://hg.dsource.org/projects/ldc ldc

Generate the LDC makefiles and

cd ldc
ccmake ./

enter D_VERSION "1" or "2", press 'c', press 'g'.

Compile ldc and include in your path

make
export PATH=`pwd`/bin:${PATH}

Fetch, patch and compile the tango runtime for dmd1:

svn co http://svn.dsource.org/projects/tango/trunk tango
make patch
make runtime

or

Fetch, patch and compile the druntime for dmd2:

svn co http://svn.dsource.org/projects/druntime/trunk druntime
make patch
make runtime

Help! Assertion `i < NumOperands && getOperand() out of range!' failed.

Your object.d has not been patched to work with LDC. Look at the instructions above regarding how to patch druntime or tango to work with LDC.

Using Tango

While LDC does use the Tango runtime per default, you still need to compile the Tango user library to build most applications. Otherwise you'll get linking errors when calling into tango code.

To build the Tango user library, go to the tango/lib directory and run sh build-tango.sh ldc. Copy the resulting libtango-user-ldc.a to LDC's lib directory and adjust your bin/ldc.conf to include -L-ltango-user-ldc.

Alternatively you can use Rebuild ...

Using Rebuild

Rebuild has some advantages to using a static Tango library (as described above). It compiles and links only to the modules you actually need, and changing the compiler options, for all the modules your application needs, is easy.

If you want to use DSSS or Rebuild with LDC, install the ldc-tango Rebuild profile from the root dir:

mkdir -p $HOME/.rebuild
ln -s `pwd`/ldc-tango $HOME/.rebuild

After you made sure that LDC is in PATH, you can use Rebuild from anywhere.

export PATH=$PATH:`pwd`/bin
rebuild -dc=ldc-tango test.d

Submitting Patches

Clone the Mercurial repository, make your changes, then use hg export and send the output to either lindquist or ChristianK:

hg export <revision> > blah-blah.patch
Copyright © 2008, LLVMDC Development Team.