Skip to content

david-broman/ktc

 
 

Repository files navigation

KTC : A Source-To-Source Compiler For TIMED-C

##Introduction


KTC is a source-to-source compiler for the timed-C programming language. It takes timed-C code as input, performs source-to-source transformation (depending on the specified target platform), spits out a C code which can then be compiled using a target specific compiler. The current version of KTC supports translation of timed-c to real-time POSIX standard. The KTC compiler is currently being tested to compile and run timed-C applications on Raspberry Pi and Intel x86 processor running Linux based operating systems.

##Building and Installing KTC


A. Installing Dependencies

####1. MAC OSX The following steps have been tested on OSX El Capitan.

(a) OCaml Dependencies

Install the following packages using MacPorts. Some of these packages are needed to install and run C Intermediate Language(CIL).

sudo port install ocaml opam ocaml-findlib lablgtk2 	mercurial ocaml-ocamlgraph

(b) CIL Dependencies

Follow instructions at https://github.com/cil-project/cil to install and build CIL.

(c) A C compiler that supports RT-POSIX standards

Mac OSX does not support RT-POSIX standard, hence inorder to translate timed-C to POSIX download the Linux cross compiler for Mac OSX from http://crossgcc.rts-software.org/doku.php

####2.Linux based OS The following steps have been tested on ubuntu 14.04LTS.

(a) OCaml Dependencies

Install the following packages using apt-get. Some of these packages are needed to install and run C Intermediate Language(CIL).

sudo apt-get install ocaml opam ocaml-findlib 	lablgtk2 mercurial ocaml-ocamlgraph

(b) CIL Dependencies

Follow instructions at https://github.com/cil-project/cil to install and build CIL.

B. KTC Installation

(a) Clone or download the source code from https://github.com/timed-c/ktc.git

(b) Run make from the root directory (in this case, the ktc directory)

C. Executing KTC

(a) Go to the bin directory

(b) To view the various options, run ktc with the help command.

./ktc --help

(c) In Linux OS, to run and test KTC use the following command

./ktc --enable-ext0 ../test/demo1.c

(d) In Mac OSX, to run and test KTC use the following command

./ktc --enable-ext0 --gcc=x86_64-pc-linux-gcc ../	 test/demo1.c

If you have not exported the path for the cross compiler, you will have to use the complete path in the --gcc option as below.

./ktc --enable-ext0 --gcc=/usr/local/gcc-4.5.2-for-	linux64/bin/i586-pc-linux-gcc ../test/demo1.c

##KTC For Raspberry Pi


A. Setting up the Raspberry Pi

(a) Follow the instructions at https://www.raspberrypi.org/help/quick-start-guide/ to install Raspbian OS on the raspberry pi. For a hassle free setup, make sure you have all the required components as mentioned in the link before you start. Use the official noobs installer to install raspbian. The instructions are avaialable at https://www.raspberrypi.org/help/noobs-setup/

(b)This is an optional step, one can download and install the Linux RT Prempt patch over the Raspbian OS. The Linux RT Prempt patch guarantees better real-time performance.Follow the instructions for installing the pre-compiled (RT patch Linux) given at http://www.frank-durr.de/?p=203

(c) For MAC OSX, install the cross compiler for raspberry pi by following the instructions at http://www.welzels.de/blog/en/arm-cross-compiling-with-mac-os-x/comment-page-1/.

(d) For Linux OS, install the cross compiler for raspberry pi by following the instructions at https://www.raspberrypi.org/documentation/linux/kernel/building.md

C. Compiling to Raspberry Pi Using KTC

(a) Go to the bin directory

(b) To cross compile timed-C file to run on raspberry pi run use the following command

./ktc --enable-ext0 --rasp --gcc=arm-linux-gnueabihf-gcc ../test/demo1.c

If you have not exported the path for the cross compiler, you will have to use the complete path in the --gcc option as below.

./ktc --enable-ext0 --rasp --gcc=/usr/local/linaro/arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf-gcc ../test/demo1.c -w

KTC for PIC32 Microcontroller using FreeRTOS.


####A. Setting up FreeRTOS on PIC32

(a) Download the MPLAB XC Compiler from http://www.microchip.com/mplab/compilers.

(b) Download Microchip's Integrated Development Environment, MPLAB X IDE, from http://www.microchip.com/mplab/mplab-x-ide. Inorder to program your PIC32 microcontroller board using MPLAB you will also need either microchips's chipKIT PGM or PICkit 3 Programmer/Debugger.

(c)FreeRTOS is downloaded as a part of the KTC environment from the github which contains the FreeRTOS code from https://sourceforge.net/projects/freertos/files/latest/download?source=file

(d)In the ktc home directory, open the RTOSDEMO.X project (distributed by FreeRTOS) using MPLAB from within the FreeRTOS/Demo directory depending on your microcontroller. Connect your PIC32 board and chipKIT PGM or PICkit 3 Programmer/Debugger to the computer and execute the demo application from MPLAB X IDE. The function of the Demo applications are explained in the source files.

(c)KTC can preform source-to-source transformation to support FreeRTOS APIs. For this write your code in a .c file, compile it using the below command and then add the .cil.c file to your project in MPLAB.

./ktc --enable-ext1 --freertos --save-temps --gcc=/Applications/microchip/xc32/v1.42/bin/xc32-gcc <NAME-OF-C-FILE> -w 

(d) The file freertos_main.c is a TIMED-C version of the FreeRTOS demo application. In order to run this application on the PIC32 board execute the below commands from ktc/bin directory, followed by building the RTOSDEMO.X project on MPLAB.

First perform the source-to-source transformation

./ktc --enable-ext1 --freertos --save-temps --gcc=/Applications/microchip/xc32/v1.42/bin/xc32-gcc freertos_main.c -w

Now copy the .cil.c file to the MPLAB project.

cp freertos_main.cil.c ../FreeRTOS/Demo/PIC32MX_MPLAB/main_blinky.c

About

KTH's Timed C compiler

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 77.1%
  • C++ 16.1%
  • Makefile 2.5%
  • Assembly 2.4%
  • Objective-C 0.9%
  • OCaml 0.6%
  • Other 0.4%