2015-08-19 20:33:27 +02:00
# SHA-256 Hash Example
2015-07-28 14:17:48 +02:00
This 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.
## Pre-requisites
2015-08-27 16:56:44 +02:00
To build and run this example you must have:
2015-07-28 14:17:48 +02:00
* A computer with the following software installed:
* [CMake ](http://www.cmake.org/download/ ).
* [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 ).
* [Python ](https://www.python.org/downloads/ ).
2015-08-27 16:56:44 +02:00
* [The ARM GCC toolchain ](https://launchpad.net/gcc-arm-embedded ).
* A serial terminal emulator (Like screen, pySerial and cu).
2015-08-19 20:33:27 +02:00
* 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).
2015-07-28 14:17:48 +02:00
* A micro-USB cable.
* If your OS is Windows, please follow the installation instructions [for the serial port driver ](https://developer.mbed.org/handbook/Windows-serial-configuration ).
## Getting started
2015-08-19 20:33:27 +02:00
1. Connect the FRDM-K64F to the computer with the micro-USB cable, being careful to use the "OpenSDA" connector on the target board.
2015-07-28 14:17:48 +02:00
2. Navigate to the mbedtls directory supplied with your release and open a terminal.
3. Set the yotta target:
```
yotta target frdm-k64f-gcc
```
2015-08-19 21:29:31 +02:00
4. Build mbedtls and the examples. This may take a long time if this is your first compilation:
2015-07-28 14:17:48 +02:00
```
2015-08-19 20:33:27 +02:00
$ yotta build
2015-07-28 14:17:48 +02:00
```
2015-08-18 19:52:57 +02:00
5. 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.
2015-07-28 14:17:48 +02:00
2015-08-27 16:56:44 +02:00
6. Start the serial terminal emulator and connect to the virtual serial port presented by FRDM-K64F.
2015-07-28 14:17:48 +02:00
2018-03-13 16:22:58 +01:00
Use the following settings:
2015-08-27 16:56:44 +02:00
2018-03-13 16:22:58 +01:00
* 115200 baud (not 9600).
* 8N1.
* No flow control.
2015-08-27 16:56:44 +02:00
7. Press the Reset button on the board.
2015-07-28 14:17:48 +02:00
2015-08-18 19:52:57 +02:00
8. The output in the terminal window should look like:
2015-07-28 14:17:48 +02:00
```
{{timeout;10}}
{{host_test_name;default}}
{{description;mbed TLS example on hashing}}
{{test_id;MBEDTLS_EX_HASHING}}
{{start}}
Method 1: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
Method 2: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
Method 3: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
Method 4: 315f5bdb76d078c43b8ac0064e4a0164612b1fce77c869345bfc94c75894edd3
DONE
{{success}}
{{end}}
```