Overview
========
The mbdedTLS Benchmark demo application performs cryptographic algorithm benchmarking and prints results to the
terminal.


Toolchain supported
===================
- Keil MDK  5.30
- GCC ARM Embedded  9.2.1
- MCUXpresso  11.2.0
- IAR embedded Workbench  8.50.1

Hardware requirements
=====================
- Mini/micro USB cable
- EVK-MIMXRT1060 board
- Personal Computer

Board settings
==============
No special settings are required.

Note:
This example can't run pass on MCUXpresso IDE v10.2.1, it will be fixed in MCUXpresso IDE v10.3.0.
Prepare the Demo
================
Connect a serial cable from the debug UART port of the target board to the PC. Start TeraTerm (http://ttssh2.osdn.jp)
and make a connection to the virtual serial port.

1. Start TeraTerm.

2. New connection -> Serial.

3. Set the appropriate COMx port (where x is port number) in the port context menu. The number is provided by the operating
   system, and could be different from computer to computer. Select the COM number related to the virtual
   serial port. Confirm the selected port by clicking the "OK" button.

4. Set following connection parameters in menu Setup -> Serial port.
        Baud rate:    115200
        Data:         8
        Parity:       none
        Stop:         1
        Flow control: none

5.  Confirm selected parameters by clicking the "OK" button.

Running the demo
================
When the demo runs successfully, which takes a couple of minutes, the terminal displays similar information like the following:

mbedTLS version 2.12.0
fsys=120000000
Using following implementations:
  SHA: MMCAU HW accelerated
  AES: MMCAU HW accelerated
  AES GCM: MMCAU HW accelerated
  DES: MMCAU HW accelerated
  Asymmetric encryption: Software implementation


  MD5                      :  6505.98 KB/s,   17.62 cycles/byte
  SHA-1                    :  3688.66 KB/s,   31.38 cycles/byte
  SHA-256                  :  2450.96 KB/s,   47.43 cycles/byte
  SHA-512                  :  451.70 KB/s,  259.62 cycles/byte
  3DES                     :  849.94 KB/s,  137.65 cycles/byte
  DES                      :  1740.01 KB/s,   66.99 cycles/byte
  AES-CBC-128              :  2099.88 KB/s,   55.42 cycles/byte
  AES-CBC-192              :  1999.21 KB/s,   58.24 cycles/byte
  AES-CBC-256              :  1917.44 KB/s,   60.74 cycles/byte
  AES-GCM-128              :  518.11 KB/s,  226.22 cycles/byte
  AES-GCM-192              :  511.61 KB/s,  229.08 cycles/byte
  AES-GCM-256              :  505.44 KB/s,  231.92 cycles/byte
  AES-CCM-128              :  699.82 KB/s,  167.29 cycles/byte
  AES-CCM-192              :  676.79 KB/s,  173.01 cycles/byte
  AES-CCM-256              :  655.23 KB/s,  178.73 cycles/byte
  CTR_DRBG (NOPR)          :  2181.05 KB/s,   53.36 cycles/byte
  CTR_DRBG (PR)            :  1484.93 KB/s,   78.58 cycles/byte
  HMAC_DRBG SHA-1 (NOPR)   :  244.85 KB/s,  480.17 cycles/byte
  HMAC_DRBG SHA-1 (PR)     :  226.67 KB/s,  518.88 cycles/byte
  HMAC_DRBG SHA-256 (NOPR) :  268.80 KB/s,  437.21 cycles/byte
  HMAC_DRBG SHA-256 (PR)   :  235.97 KB/s,  498.34 cycles/byte
  RSA-1024                 :   94.00  public/s
  RSA-1024                 :    3.00 private/s
  DHE-2048                 :    0.18 handshake/s
  DH-2048                  :    0.18 handshake/s
  ECDSA-secp384r1          :    1.67 sign/s
  ECDSA-secp256r1          :    2.67 sign/s
  ECDSA-secp224r1          :    4.33 sign/s
  ECDSA-secp192r1          :    5.33 sign/s
  ECDSA-secp384r1          :    1.00 verify/s
  ECDSA-secp256r1          :    1.67 verify/s
  ECDSA-secp224r1          :    2.33 verify/s
  ECDSA-secp192r1          :    3.00 verify/s
  ECDHE-secp384r1          :    1.00 handshake/s
  ECDHE-secp256r1          :    1.67 handshake/s
  ECDHE-secp224r1          :    2.67 handshake/s
  ECDHE-secp192r1          :    3.33 handshake/s
  ECDH-secp384r1           :    2.00 handshake/s
  ECDH-secp256r1           :    3.00 handshake/s
  ECDH-secp224r1           :    4.67 handshake/s
  ECDH-secp192r1           :    6.00 handshake/s
Customization options
=====================

