211 lines
7.6 KiB
Markdown
211 lines
7.6 KiB
Markdown
wolfSSL for Renesas RA Evaluation Kit (EK-RA6M3)
|
|
=================================================
|
|
|
|
## Description
|
|
|
|
This directory contains e2studio projects targeted at the Renesas RA 32-bit MCUs.\
|
|
The example projects include a wolfSSL TLS client and server.\
|
|
They also include benchmark and cryptography tests for the wolfCrypt library.
|
|
|
|
The wolfssl project contains both the wolfSSL and wolfCrypt libraries.\
|
|
It is built as a `Renesas RA C Library Project` and contains the Renesas RA\
|
|
configuration.
|
|
|
|
The other projects (benchmark, client, server and test) are built as a\
|
|
`Renesas RA C Project Using RA Library`, where the RA library is the wolfssl project.\
|
|
The wolfssl Project Summary is listed below and is relevant for every project.
|
|
|
|
### Project Summary
|
|
|Item|Name/Version|
|
|
|:--|:--|
|
|
|Board|EK-RA6M3|
|
|
|Device|R7FA6M3AH3CFC|
|
|
|Toolchain|GCC ARM Embedded|
|
|
|FSP Version|3.5.0|
|
|
|
|
#### Selected software components
|
|
|
|
|Components|Version|
|
|
|:--|:--|
|
|
|Board Support Package Common Files|v3.5.0|
|
|
|Arm CMSIS Version 5 - Core (M)|v5.8.0+renesas.0.fsp.3.5.0|
|
|
|FreeRTOS|v10.4.3-LTS.Patch.2+fsp.3.5.0|
|
|
|RA6M3-EK Board Support Files|v3.5.0|
|
|
|Board support package for R7FA6M3AH3CFC|v3.5.0|
|
|
|Board support package for RA6M3|v3.5.0|
|
|
|Board support package for RA6M3 - FSP Data|v3.5.0|
|
|
|FreeRTOS - Memory Management - Heap 4|v10.4.3-LTS.Patch.2+fsp.3.5.0|
|
|
|r_ether to FreeRTOS+TCP Wrapper|v3.5.0|
|
|
|Ethernet|v3.5.0|
|
|
|Ethernet PHY|v3.5.0|
|
|
|FreeRTOS+TCP|v2.3.2-LTS.Patch.1+fsp.3.5.0|
|
|
|FreeRTOS - Buffer Allocation 2|v2.3.2-LTS.Patch.1+fsp.3.5.0|
|
|
|
|
|
|
## Setup Steps
|
|
|
|
The project directories are missing files necessary to build the project.\
|
|
These files can be generated when creating a new Renesas RA Project.\
|
|
The following steps explain how to generate the missing files and where to place them.
|
|
|
|
1.) Create a 'dummy' Renesas RA C Library Project.
|
|
|
|
+ Click File->New->`RA C/C++ Project`
|
|
+ Click `Renesas RA C Library Project`. Click Next
|
|
+ Enter `dummy_library` as the project name. Click Next.
|
|
+ Under `Board: Custom User Board`, select `EK-RA6M3`.
|
|
+ Under `RTOS: No RTOS`, select `FreeRTOS`.
|
|
+ Click Next. Select `FreeRTOS - Minimal - Static Allocation`
|
|
+ Click Finish.
|
|
+ Open Smart Configurator by clicking configuration.xml in the project
|
|
+ Go to `BSP` tab and increase Heap Size under `RA Common` on Properties page, e.g. 0x1000
|
|
+ Go to `Stacks` tab
|
|
+ Add New thead and set properties
|
|
|
|
|Property|Value|
|
|
|:--|:--|
|
|
|Thread Symbol|wolfssl_tst_thread|
|
|
|Thread Name|wolf_tst_thread|
|
|
|Thread Stack size|increase depending on your environment<br> e.g. 0xA000|
|
|
|Thread MemoryAllocation|Dyamic|
|
|
|Common General Use Mutexes|Enabled|
|
|
|Common General Enable Backward Compatibility|Enabled|
|
|
|Common Memory Allocation Support Dynamic Allocation|Enabled|
|
|
|Common Memory Allocation Total Heap Size|increase depending on your environment<br> e.g. 0x20000|
|
|
|
|
+ Add `Heap 4` stack to sce_tst_thread from `New Stack` -> `RTOS` -> `FreeRTOS Heap 4`
|
|
+ Add `FreeRTOS + TCP` stack to sce_tst_thread from `New Stack` -> `Networking` -> `FreeRTOS+TCP` and set properties
|
|
|
|
|Property|Value|
|
|
|:--|:--|
|
|
|Network Events call vApplicationIPNetworkEventHook|Disable|
|
|
|Use DHCP|Disable|
|
|
|
|
2.) Create a 'dummy' Renesas RA C Project Using RA Library.
|
|
|
|
+ Click File->New->`RA C/C++ Project`
|
|
+ Click `Renesas RA C Project Using RA Library`. Click Next
|
|
+ Enter `dummy_app` as the project name. Click Next.
|
|
+ Under `Executable Using an RA Static library`
|
|
+ Enter `dummy_app` as the project name. Click Next
|
|
+ Select `dummy_library` from Select Renesas RA library project.
|
|
+ Click Finish.
|
|
|
|
3.) Import all the wolfSSL Projects into e2studio workspace.
|
|
|
|
+ Click File->`Open Projects from File System`
|
|
+ Click `Directory...` to the right of Import source
|
|
+ Select the RA6M3 folder location that contains the projects\
|
|
example path: wolfssl/IDE/Renesas/e2studio/RA6M3
|
|
+ Deselect the Non-Eclipse project, RA6M3, by clicking the checkbox\
|
|
Only the folders with 'Eclipse project' under 'Import as' need to be selected.
|
|
+ Click Finish.
|
|
|
|
4.) Copy files from `dummy_library` into `wolfSSL_RA6M3`
|
|
|
|
+ Expand the dummy_library and wolfSSL_RA6M3 projects\
|
|
(Click the drop-down arrow to the left of the project name.)
|
|
+ Select and Copy the following folders/files inside dummy_library\
|
|
|
|
`ra/`\
|
|
`ra_gen/`\
|
|
`ra_cfg/`\
|
|
`script/`\
|
|
`R7FA6M3AH3CFC.pincfg`\
|
|
`configuration.xml`
|
|
|
|
+ Paste the copied folders/files into wolfSSL_RA6M3
|
|
+ The `dummy_library` project can now be deleted.
|
|
+ Generate Project Content.
|
|
+ Click `Open RA Configuration` in the top bar (Grey Settings Cog)
|
|
+ Click `Generate Project Content` at top right (Green Icon)
|
|
+ Build wolfSSL_RA6M3.
|
|
|
|
5.) Copy files from `dummy_app` into each executable projects\
|
|
+ Select and Copy the following folder inside dummy_app\
|
|
|
|
`script/`
|
|
|
|
+ Paste the copied folders into each executable projects which are Crypt test, benchmark, client and server projects\
|
|
+ The `dummy_app` project can now be deleted.
|
|
|
|
6.) Setup Network Environment
|
|
|
|
The client and server projects have defines inside their wolfssl_thread_entry.h.
|
|
These defines (ucIPAddress ... ucDNSServerAddress) may need to be changed
|
|
based on your internal network environment. The g_ether0_mac_address is the default
|
|
mac address found inside the RA configuration inside the wolfssl project.
|
|
The client wolfssl_thread_entry.h has defines (SERVER_IP and DEFAULT_PORT) that
|
|
will need to be changed based on the server you're trying to connect to over
|
|
the ethernet connection.
|
|
|
|
## Build and Run
|
|
|
|
### Build Each Project
|
|
Right-Click each Project and select Build.
|
|
|
|
### Run wolfCrypt Test and Benchmark
|
|
|
|
1.) Right-Click the Project name.\
|
|
2.) Select `Debug As` -> `Renesas GDB Hardware Debugging`\
|
|
3.) Select J-Link ARM. Click OK.\
|
|
4.) Select R7FA6M3AH. Click OK.
|
|
|
|
### Run the wolfSSL TLS Server Example.
|
|
|
|
1.) Right-Click the Project name.\
|
|
2.) Select `Debug As` -> `Renesas GDB Hardware Debugging`\
|
|
3.) Select J-Link ARM. Click OK.\
|
|
4.) Select R7FA6M3AH. Click OK.\
|
|
5.) Run the following wolfSSL example client command inside the base of the wolfssl directory.
|
|
|
|
```
|
|
./examples/client/client -v 4 -h "ucIPAddress" -p 11111 -A ./certs/1024/ca-cert.pem
|
|
```
|
|
|
|
**NOTE:** "ucIPAddress" is "192.168.1.241" by default. (See wolfssl_thread_entry.h)
|
|
|
|
### Run the wolfSSL TLS Client Example.
|
|
|
|
1.) Run the following wolfSSL example server command inside the base of the wolfssl directory.
|
|
|
|
```
|
|
./examples/server/server -v 4 -b -d -p 11111 -c ./certs/1024/server-cert.pem -k ./certs/1024/server-key.pem
|
|
```
|
|
|
|
**NOTE:** The port 11111 is the DEFAULT_PORT inside wolfssl_thread_entry.h.\
|
|
|
|
2.) Right-Click the Project name.\
|
|
3.) Select `Debug As` -> `Renesas GDB Hardware Debugging`\
|
|
4.) Select J-Link ARM. Click OK.\
|
|
5.) Select R7FA6M3AH. Click OK.
|
|
|
|
## Troubleshooting
|
|
|
|
+ The commands for the example client/server assumes it is being run from the
|
|
base directory of wolfssl.
|
|
|
|
+ Enter "#define DEBUG_WOLFSSL" inside user_settings.h or wolfssl_thread_entry.c\
|
|
to enable wolfssl debug messages to the Renesas Virtual Debug Console.
|
|
|
|
+ Some linking errors can be caused by the e2studio project files needing to be rebuilt and freshened.
|
|
Right-Click a project, select Index, click Rebuild and then click Freshen Files. Repeat for each project.
|
|
|
|
[Support Forum](https://www.wolfssl.com/forums/)
|
|
|
|
Support Email: support@wolfssl.com
|
|
|
|
|
|
## Resources
|
|
|
|
[wolfSSL Website](https://www.wolfssl.com/)
|
|
|
|
[wolfSSL Wiki](https://github.com/wolfSSL/wolfssl/wiki)
|
|
|
|
[wolfSSL Manual](https://wolfssl.com/wolfSSL/Docs-wolfssl-manual-toc.html)
|
|
|
|
[wolfSSL API Reference](https://wolfssl.com/wolfSSL/Docs-wolfssl-manual-17-wolfssl-api-reference.html)
|
|
|
|
[wolfCrypt API Reference](https://wolfssl.com/wolfSSL/Docs-wolfssl-manual-18-wolfcrypt-api-reference.html)
|
|
|
|
[TLS 1.3](https://www.wolfssl.com/docs/tls13/)
|