2014-05-29 04:01:10 +02:00
2014-05-29 03:49:13 +02:00
2014-05-29 02:20:28 +02:00
2014-05-29 02:21:30 +02:00
2014-05-29 04:01:10 +02:00
2014-05-29 02:22:11 +02:00

This is a small portable (and slow?) implementation of AES128 in C.

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

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 --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.

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%