2014-05-31 00:42:28 +02:00
2014-05-30 14:59:40 +02:00
2014-05-29 02:20:28 +02:00
2014-05-29 02:21:30 +02:00
2014-05-31 00:42:28 +02:00
2014-05-29 02:22:11 +02:00

Tiny AES128 in C

This is a small portable implementation of AES128 in C. This is the smallest implementation in C I've seen yet, but if you find something smaller (or have improvements for the code in this project) please contact me or fork the project.

The code is tested on Intel 64bit, 32bit ARM Cortex-M3 and 8 bit Atmel Mega16.

The module uses just a bit more than 200 bytes of RAM and 1K ROM when compiled for ARM. YMMV depending on target platform and optimization skills of your compiler.

GCC size output when compiled for ARM:

$ arm-none-eabi-gcc -Os -c aes.c -o aes.o
$ size aes.o
   text    data     bss     dec     hex filename
   1079       0     204    1283     503 aes.o
$ arm-none-eabi-gcc -O2 -c aes.c -o aes.o
$ size aes.o
   text    data     bss     dec     hex filename
   1024       0     204    1228     4cc aes.o

Somehow, -O2 is a bit smaller than -Os with this compiler. I am using Mentor Graphics ARM toolchain:

$ arm-none-eabi-gcc --version
arm-none-eabi-gcc (GNU Tools for ARM Embedded Processors) 4.8.3 20131129 (release) [ARM/embedded-4_8-branch revision 205641]
Copyright (C) 2013 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

The implementation is verified against the data in: National Institute of Standards and Technology Special Publication 800-38A 2001 ED Appendix F: Example Vectors for Modes of Operation of the AES.

Note: AES128 ECB is symmetric, so you use the same function for encrypting and decrypting.

Description
Small portable AES128/192/256 in C
Readme 434 KiB
Languages
C 89.1%
Python 5.9%
Makefile 2.9%
CMake 1.6%
C++ 0.5%