blob: 74f12a0f6a4b9a6e021898743ec2ebf115a94a7a [file] [log] [blame] [view]
Simon Butcherdf819242015-08-19 19:33:27 +01001# SHA-256 Hash Example
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +02002
3This application performs hashing of a buffer with SHA-256 using various APIs. It serves as a tutorial for the basic hashing APIs of mbed TLS.
4
5## Pre-requisites
6
Simon Butcherdf819242015-08-19 19:33:27 +01007To build and run this example the following requirements are necessary:
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +02008
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).
Simon Butcherdf819242015-08-19 19:33:27 +010015* An [FRDM-K64F](http://developer.mbed.org/platforms/FRDM-K64F/) development board, or another board supported by mbed OS (in which case you'll have to substitute frdm-k64f-gcc with the appropriate target in the instructions below).
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +020016* 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
Simon Butcherdf819242015-08-19 19:33:27 +0100211. Connect the FRDM-K64F to the computer with the micro-USB cable, being careful to use the "OpenSDA" connector on the target board.
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +020022
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 ```
Simon Butcherdf819242015-08-19 19:33:27 +010034 $ yotta ls
35
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +020036 ```
37
Simon Butcherdf819242015-08-19 19:33:27 +010038 If there are missing dependencies, yotta will list them in the terminal. Please install these before proceeding.
39
405. Build mbedtls and the examples. This may take a long time if this is your first compilation:
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +020041
42 ```
Simon Butcherdf819242015-08-19 19:33:27 +010043 $ yotta build
Manuel Pégourié-Gonnard63e7eba2015-07-28 14:17:48 +020044 ```
45
466. Copy `build/frdm-k64f-gcc/test/mbedtls-test-example-hashing.bin` to your mbed board and wait until the LED next to the USB port stops blinking.
47
Manuel Pégourié-Gonnardbd5bbec2015-08-06 18:10:17 +0200487. 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 +020049
508. Press the reset button on the board.
51
529. The output in the terminal window should look like:
53
54 ```
55 {{timeout;10}}
56 {{host_test_name;default}}
57 {{description;mbed TLS example on hashing}}
58 {{test_id;MBEDTLS_EX_HASHING}}
59 {{start}}
60
61
62 Method 1: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
63 Method 2: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
64 Method 3: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
65 Method 4: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
66
67 DONE
68 {{success}}
69 {{end}}
70 ```