blob: 55186d19d217075226a627162932eaa3627fbe76 [file] [log] [blame] [view]
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +02001# Authenticated encryption example
2
3This application performs authenticated encryption and authenticated decryption of a buffer. It serves as a tutorial for the basic authenticated encryption functions of mbed TLS.
4
5## Pre-requisites
6
7To build and run this example the requirements below are necessary:
8
9* A computer with the following software installed:
10 * [CMake](http://www.cmake.org/download/).
11 * [yotta](https://github.com/ARMmbed/yotta). Please note that **yotta has its own set of dependencies**, listed in the [installation instructions](http://armmbed.github.io/yotta/#installing-on-windows).
12 * [Python](https://www.python.org/downloads/).
13 * [ARM GCC toolchain](https://launchpad.net/gcc-arm-embedded).
14 * A serial terminal emulator (e.g. screen, pySerial, cu).
15* An [FRDM-K64F](http://developer.mbed.org/platforms/FRDM-K64F/) development board, or another board supported by mbed OS (in that case you'll have to substitute frdm-k64f-gcc with the appropriate target below).
16* A micro-USB cable.
17* If your OS is Windows, please follow the installation instructions [for the serial port driver](https://developer.mbed.org/handbook/Windows-serial-configuration).
18
19## Getting started
20
211. Connect the FRDM-K64F to the computer with the micro-USB cable, being careful to use the micro-usb port labeled "OpenSDA".
22
232. Navigate to the mbedtls directory supplied with your release and open a terminal.
24
253. Set the yotta target:
26
27 ```
28 yotta target frdm-k64f-gcc
29 ```
30
314. Check that there are no missing dependencies:
32
33 ```
34 $ yt ls
35 ```
36
37 If there are, yotta will list them in the terminal. Please install them before proceeding.
38
395. Build mbedtls and the examples. This will take a long time if it is the first time:
40
41 ```
42 $ yt build
43 ```
44
456. Copy `build/frdm-k64f-gcc/test/mbedtls-test-example-authcrypt.bin` to your mbed board and wait until the LED next to the USB port stops blinking.
46
Manuel Pégourié-Gonnardbd5bbec2015-08-06 18:10:17 +0200477. Start the serial terminal emulator and connect to the virtual serial port presented by FRDM-K64F. For settings, use 115200 baud, 8N1, no flow control. **Warning:** for this example, the baud rate is not the default 9600, it is 115200.
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +020048
498. Press the reset button on the board.
50
519. The output in the terminal window should look like:
52
53 ```
54 {{timeout;10}}
55 {{host_test_name;default}}
56 {{description;mbed TLS example authcrypt}}
57 {{test_id;MBEDTLS_EX_AUTHCRYPT}}
58 {{start}}
59
60
61 plaintext message: 536f6d65207468696e67732061726520626574746572206c65667420756e7265616400
62 ciphertext: c57f7afb94f14c7977d785d08682a2596bd62ee9dcf216b8cccd997afee9b402f5de1739e8e6467aa363749ef39392e5c66622b01c7203ec0a3d14
63 decrypted: 536f6d65207468696e67732061726520626574746572206c65667420756e7265616400
64
65 DONE
66 {{success}}
67 {{end}}
68 ```
69
70The actual output for the ciphertext line will vary on each run due to the use of a random nonce in the encryption process.