This blog is about Java (advanced Java topics like Reflection, Byte Code transformation, Code Generation), Maven, Web technologies, Raspberry Pi and IT in general.

Freitag, 20. Juli 2012

Truecrypt benchmark for Raspberry Pi

This benchmark was run on raspbian/wheezy. So it's used the armhf architecture. The buffer size was was 5MB. Checkout the truecrypt benchmark with the new turbo overclock setting.

Algorithm Encrypt Decrypt Mean
Twofish 8.9 7.7 8.3
Serpent 6.8 6.9 6.9
AES 4.4 3.7 4.1
Twofish-Serpent 3.9 3.7 3.8
Serpant-AES 2.7 2.4 2.5
AES-Twofish 1.9 2.4 2.1
Serpant-Twofish-AES 2.1 1.8 2.0
AES-Twofish-Serpent 2.0 1.8 1.9

Truecrypt armhf executable for Raspberry Pi (raspbian/wheezy)

Because Truecrypt it's a bit of a work and takes so long to compile I uploaded the compiled binary file

Compile Truecrypt on Raspberry Pi

I wanted to run Truecrypt on my Raspberry Pi. But there is no precompiled package which you could simply install with apt-get. So you have to compile it yourself - which take a few hours. If you just want the truecrypt binary for Raspbian/Wheezy then you can download them here.
The first thing you need to do is to get all needed dependencies. Thereby you have to compile one dependency yourself. We start with this dependency.

How to compile wxWidgets
First download the source code: I used wxAll 2.8.11. Unpack it, go into the directory and execute these commands.
sudo apt-get install libgtk2.0-dev

How to setup PKCS11
Truecrypt needs three header files (pkcs11.h, pkcs11f.h, pkcs11t.h) which you can download from this location:
Put them into a directory and then set the PKCS11_INC variable.
export PKCS11_INC=/home/pi/pkcs11

How to compile Truecrypt
First download the source code: I used 7.1a. Unpack it, go into the unpacked directory and execute these commands.
sudo apt-get install libfuse-dev nasm libwxgtk2.8-dev
make WX_ROOT=/home/pi/wxWidgets/ wxbuild

 There will be this warning
configure: WARNING: libSM not found; disabling session management detection
sadly I couldn't figure out how to fix it. But Truecrypt will work anyway.

If you get this error message
In file included from Keyfile.cpp:10:0:
.../SecurityToken.h:43:21: fatal error: pkcs11.h: No such file or directory
then the  PKCS11_INC variable isn't set correctly or you forgot to put the header files in the directory.

Now you can use Truecrypt. The executable file will be created in Main/truecrypt. To mount a truecrypt volume just use
./truecrypt /path/to/truecrypt-volume /path/to/mount-point
or you can just execute ./truecrypt and use the graphical surface.