Experimental PENCIL tools repository Tools ----- * PENCIL cross-component optimizer * PENCIL linker Coding Style ----------- C - please follow linux kernel coding style [https://www.kernel.org/doc/Documentation/CodingStyle] Scala - please follow Scala Style Guide [http://docs.scala-lang.org/style] Documentation ------------- Generated SCALA docs are available here: * PENCIL IR: http://carpproject.github.io/pencil/index.html * Optimizations: http://carpproject.github.io/optimizations/index.html Repository Contents ------------------- * grammar/ ANTLR3 Grammar for PENCIL * res/ Resources * src/ Scala source code: * .../apps/ Tool-specific source code * .../frontends/ PENCIL frontend code * .../pencil/ PENCIL class definitions * testsuite/ Test files: * code/ Unit tests * lib/ Testing infrastructure files Building process ---------------- Summary: autoconf ./configure --with-scala=$SCALA_HOME --with-antlr3=$ANTLR_HOME [--with-filecheck=$FILECHECK_HOME] [--prefix=$PREFIX] make For more information on what $SCALA_HOME and $ANTLR_HOME should point to, refer to 'Build requirements' below. Build requirements ------------------ * Antlr3 is installed and ANTLR_HOME is set: % ANTLR_HOME=/opt/antlr # Or any other % mkdir -p $ANTLR_HOME % wget http://www.antlr3.org/download/antlr-3.5.2-complete-no-st3.jar -O $ANTLR_HOME/antlr3.jar % wget http://www.antlr3.org/share/1169924912745/antlr3-task.zip -O /tmp/antlr3-task.zip % unzip /tmp/antlr3-task.zip -d /tmp/antlr3-task % cp /tmp/antlr3-task/antlr3-task/ant-antlr3.jar $ANTLR_HOME/ant-antlr3.jar % rm -rf /tmp/antlr3-task /tmp/antlr3-task.zip % ls $ANTLR_HOME ant-antlr3.jar antlr3.jar * Scala tools are installed and SCALA_HOME is set: % SCALA_HOME=/opt/scala # Or any other % mkdir -p $SCALA_HOME % wget http://www.scala-lang.org/files/archive/scala-2.10.4.tgz % tar xf scala-2.10.4.tgz --strip-component=1 -C $SCALA_HOME % rm scala-2.10.4.tgz % ls $SCALA_HOME/lib -1 akka-actors.jar jline.jar scala-actors.jar scala-actors-migration.jar scala-compiler.jar scala-library.jar scala-partest.jar scalap.jar scala-reflect.jar scala-swing.jar typesafe-config.jar * Antlr3 tools are accessible via CLASSPATH: % export CLASSPATH=$ANTLR_HOME/ant-antlr3.jar:$ANTLR_HOME/antlr3.jar * [Optional] FileCheck tool from LLVM testsuite: % ls $FILECHECK_HOME/FileCheck FileCheck If present this tool will be used to perform more accurate testing of the PENCIL tools. * pencil-util submodule: % git submodule init % git submodule update This build has been tested on the following configuration: % scalac -version Scala compiler version 2.10.4 -- Copyright 2002-2013, LAMP/EPFL % ant -version Apache Ant version 1.7.1 compiled on September 8 2010 % java -jar $ANTLR_HOME/antlr3.jar -version ANTLR Parser Generator Version 3.5.2 Running tools ------------- Linker: linker <files> Optimizer: optimizer <file> Each tool supports -h for help Creating the binary packages ---------------------------- The following binary packages can be created: * Debian package (deb) * Red Hat package (rpm) The following programs must be available: * dpkg-deb * fakeroot * alien The packages are created as follows: % autoconf % ./configure [--prefix=$target_prefix] % make % make packages Variables: * TAREGT_PREFIX - prefix for file installation (/usr/local/ by default). When installed the package will use the system scala compiler and antlr jars from the system CLASSPATH. After the package is built it can be installed as follows: % sudo dpkg -i pencil-tools.deb # for deb package After the package is installed the following commands should be available: % pencil-optimizer % pencil-linker