Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
LLVM backend for dcpu-16 processor
C++ Objective-C Assembly Shell C OCaml Other
branch: dcpu16

Merge pull request #194 from Blei/fix-register-size

Register sizes are in bits. Divide
latest commit ae6b01fecd
@Blei Blei authored
Failed to load latest commit information.
autoconf Merge branch 'master' into dcpu16
bindings [python] Add negative MemoryBuffer testcase
cmake Merge branch 'master' into dcpu16
docs Document the llvm.fabs intrinsic.
examples Move llvm/Support/IRBuilder.h -> llvm/IRBuilder.h
include Merge branch 'master' into dcpu16
lib Register sizes are in bits. Divide by 8.
projects Remove 'check-dg', a wrapper around 'check-local-dg' which was just
runtime Free the allocated filename. Found by clang static analyzer.
test Fix test failures. Currently, test/CodeGen/X86/early-ifcvt.ll fails, …
tools Merge branch 'master' into dcpu16
unittests Merge branch 'master' into dcpu16
utils Merge branch 'master' into dcpu16
.gitignore Merge with LLVM upstream (build is broken now)
CMakeLists.txt Merge branch 'master' into dcpu16
CREDITS.TXT Alphabetize.
LICENSE.TXT Add YAML parser to Support.
LLVMBuild.txt LLVMBuild: Introduce a common section which currently has a list of the
Makefile Do not install llvm-config-host for cross-builds of clang. rdar://113…
Makefile.common [docs] Remove unsupported references to ExtraSource variable.
Makefile.config.in Remove autoconf support for runtest and tclsh, some of the last vestigal
Makefile.rules Remove 'check-dg', a wrapper around 'check-local-dg' which was just
README.md DCPU16: Fixed small typo in the README.md
README.txt Testing commit access
configure Merge branch 'master' into dcpu16
llvm.spec.in Tidy up. s/Low Level Virtual Machine/LLVM/.

README.md

LLVM backend for DCPU-16

DCPU-16 is the processor from Mojang's new game 0x10c. This project has a goal to make a full-featured LLVM backend for DCPU-16 and port Clang to support this architecture.

Currently llvm backend and Clang support are nearly fully implemented.

Simple C SDK

You can download a simple C SDK, which includes clang with the binutils port for dcpu16. It is Makefile based and contains a very simple C test program to demonstrate how you can develop your own program.

Download

You can find different precompiled packages for linux here.

There is also a very simple build script, which will assemble all needed parts for building the SDK yourself.

Please, let us know, if it does not work for you.

Building

First, of all, you need to install prerequisites:

sudo apt-get install gcc g++ git subversion git-svn make\
 perl gawk expect tcl texinfo bison autoconf automake cmake

Note, that when your python executable points to python3 (you can check that by running python --version) you have to replace "cmake .." with "cmake -DPYTHON_EXECUTABLE=/path/to/python2 .." in the following steps (path is /usr/bin/python2 in most cases)

Next, get the sources and build it:

git clone git://github.com/llvm-dcpu16/llvm-dcpu16.git # Checkout LLVM
cd llvm-dcpu16/tools
git clone git://github.com/llvm-dcpu16/clang.git # Checkout Clang
mkdir ../cbuild
cd ../cbuild
cmake ..
make -j4

Using LLVM-DCPU16

Consider the following C file:

fib.c:

int fib(int n) {
  int cur = 1;
  int prev = 1;
  for (int i = 0; i < n; i++) {
    int next = cur+prev;
    prev = cur;
    cur = next;
  }
  return cur;
}

int main(void) {
  return fib(5);
}

Now, let's translate C to DCPU16 assembly:

bin/clang -ccc-host-triple dcpu16 -S fib.c -o fib.s

We generate DCPU16 v1.7 ASM with GAS compatible syntax. Most online assemblers won't work. Please use the binutils port for DCPU16 to assemble and link your program and then use an DCPU16 v1.7 compatible emulator to test your program.

Enjoy and, please, report bugs!

Something went wrong with that request. Please try again.