2024-04-01 12:25:38 +08:00
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
2023-05-11 12:20:27 +05:30
2023-05-11 18:04:48 +05:30
## Crypto peripherals test
2023-05-11 12:20:27 +05:30
2023-05-11 18:04:48 +05:30
This is a combined crypto peripherals verification application using mostly HAL APIs. This application is intentionally kept simple and does not use any higher layer constructs. This application can help in the early verification of the new SoC.
2023-05-11 12:20:27 +05:30
2023-05-11 18:04:48 +05:30
This contains tests for the following features of the crypto peripherals:
2023-05-11 12:20:27 +05:30
- MPI peripheral
- MPI Modular Multiplication
- MPI Multiplication
- MPI Modular Exponentiation
2023-05-11 15:28:02 +05:30
- ECC peripheral
- ECC Point multiplication for P192 and P256 curve
- ECC Point verification for P192 and P256 curve
- ECC Point verify and multiply for P192 and P256 curve
- ECC Inverse multiplication for P192 and P256
If the hardware supports extended work modes then it also tests:
- ECC Jacobian multiplication for P192 and P256 curve
- ECC Jacobian verification for P192 and P256 curve
- ECC Point verification and Jacobian multiplication for P192 and P256 curve
- ECC Point addition for P192 and P256 curve
- Mod addition
- Mod subtraction
- Mod multiplication
2023-05-11 16:31:00 +05:30
- HMAC periperhal
- HMAC 'downstream' JTAG Enable mode
- HMAC 'downstream' JTAG Disable
- HMAC 'upstream' MAC generation with zeroes
- HMAC 'upstream' MAC generation from data
2023-05-11 18:04:48 +05:30
- DS peripheral
- Digital Signature Parameter Encryption
- Digital Signature wrong HMAC key purpose
- Digital Signature Blocking wrong HMAC key purpose
- Digital Signature Operation
- Digital Signature Blocking Operation
- Digital Signature Invalid Data
2023-05-11 16:31:00 +05:30
2023-05-15 12:20:03 +05:30
- ECDSA peripheral
- ECDSA P192 signature generation
- ECDSA P256 signature generation
- ECDSA P192 signature verification
- ECDSA P256 signature verification
2024-03-28 17:52:53 +05:30
- ECDSA P192 export public key
- ECDSA P256 export public key
- ECDSA P192 deterministic signature generation
- ECDSA P256 deterministic signature generation
2023-05-15 12:20:03 +05:30
2023-08-28 15:44:47 +05:30
- AES peripheral
- Block Mode
- CBC AES-256
- CTR AES-256
- SHA peripheral
- Block Mode
- SHA-1
- SHA-224
- SHA-256
- SHA-384
- SHA-512
- SHA-512/224
- SHA-512/256
- SHA-512/t
2023-05-11 18:04:48 +05:30
> **_NOTE:_** The verification tests for the HMAC and Digital Signature peripherals would get exercised in only in an FPGA environment.
2023-05-11 16:31:00 +05:30
# Burning the HMAC key
The HMAC tests need an HMAC key to be burned in the `BLOCK_KEY3` and `BLOCK_KEY4` of the efuses. As this verification application is independent of the efuse component, the user needs to manually burn the keys and their key purposes using `espefuse.py` .
```bash
2023-05-26 18:15:48 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY3 main/hmac/hmac_key.bin HMAC_DOWN_JTAG
2023-05-11 16:31:00 +05:30
2023-05-26 18:15:48 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY4 main/hmac/hmac_key.bin HMAC_UP
2023-05-11 16:31:00 +05:30
```
2023-05-11 18:04:48 +05:30
# Burning the HMAC keys for Digital Signature tests
2023-08-28 16:51:36 +05:30
The tests needs some HMAC keys to be burned in the `BLOCK_KEY0` , `BLOCK_KEY1` and `BLOCK_KEY2` of the efuses. As this verification application is independent of the efuse component, the user needs to manually burn the keys and their key purposes using `espefuse.py` .
2023-05-11 18:04:48 +05:30
2023-08-02 14:10:24 +05:30
If SOC_DS_SIGNATURE_MAX_BIT_LEN == 3072:
2023-05-11 18:04:48 +05:30
```bash
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY0 main/ds/keys/3072/ds_key1.bin HMAC_DOWN_DIGITAL_SIGNATURE
2023-05-11 18:04:48 +05:30
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY1 main/ds/keys/3072/ds_key2.bin HMAC_DOWN_DIGITAL_SIGNATURE
2023-05-11 18:04:48 +05:30
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY2 main/ds/keys/3072/ds_key3.bin HMAC_DOWN_DIGITAL_SIGNATURE
2023-08-02 14:10:24 +05:30
```
If SOC_DS_SIGNATURE_MAX_BIT_LEN == 4096:
```bash
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY0 main/ds/keys/4096/ds_key1.bin HMAC_DOWN_DIGITAL_SIGNATURE
2023-08-02 14:10:24 +05:30
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY1 main/ds/keys/4096/ds_key2.bin HMAC_DOWN_DIGITAL_SIGNATURE
2023-08-02 14:10:24 +05:30
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY2 main/ds/keys/4096/ds_key3.bin HMAC_DOWN_DIGITAL_SIGNATURE
2023-05-11 18:04:48 +05:30
```
2023-05-15 12:20:03 +05:30
# Burning the ECDSA keys
2023-08-28 16:51:36 +05:30
By default, ECDSA tests are disabled. You can enable it after disabling HMAC tests using `idf.py menuconfig -> Test App Configuration -> Enable ECDSA Peripheral test cases`
The ECDSA tests need some ECDSA keys to be burned in the `BLOCK_KEY4` and `BLOCK_KEY5` of the efuses. As this verification application is independent of the efuse component, the user needs to manually burn the keys and their key purposes using `espefuse.py` .
2023-05-15 12:20:03 +05:30
```bash
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY4 main/ecdsa/ecdsa192_priv_key.pem ECDSA_KEY
2023-05-15 12:20:03 +05:30
2023-08-28 16:51:36 +05:30
espefuse.py -p $ESPPORT burn_key BLOCK_KEY5 main/ecdsa/ecdsa256_priv_key.pem ECDSA_KEY
2023-05-15 12:20:03 +05:30
```
2023-05-11 12:20:27 +05:30
# Building
```bash
idf.py set-target < TARGET >
idf.py build
```
# Running the app manually
```bash
idf.py flash monitor
```
Enter the test that you want to run locally
# Running tests
```bash
pytest --target < TARGET >
```