Python tools for provisioning Cypress/Infineon MCUs
Project description
This package contains security tools for creating keys, creating certificates, signing user applications, and provisioning Cypress/Infineon MCUs.
Table of Contents
- HW/SW compatibility
- Prerequisites
- Documentation
- Standalone Executable
- Installing From Sources
- Supported Devices
- Interface and Usage
- Logging
- Known Issues
- Error Handling
- License and Contributions
HW/SW compatibility
PSoC 64
| Target/Kit | Silicon ID, Silicon Rev., Family ID | Secure FlashBoot Version | CyBootloader Version | ||
| 512K | |||||
|
cyb06xx5 cy8cproto‑064b0s3 |
0xE70D, 0x12, 0x105 | 4.0.2.1842 | 2.0.1.6441 | ||
| 2M | |||||
|
cyb06xxa cy8ckit‑064b0s2‑4343w |
0xE470, 0x12, 0x102 | 4.0.3.2319 | 2.0.2.8102 | ||
|
cys06xxa cy8ckit‑064s0s2‑4343w |
0xE4A0, 0x12, 0x02 | 4.0.3.2319 | 2.0.2.8102 | ||
| 1M | |||||
|
cyb06xx7 cy8cproto‑064s1‑sb cy8cproto‑064b0s1‑ble cy8cproto‑064b0s1‑ssa |
0xE262, 0x24, 0x100 0xE261, 0x24, 0x100 | 4.0.2.1842 | 2.0.0.4041 | ||
CYW20829 / CYW89829
| Target/Kit | Silicon ID, Silicon Rev., Family ID | ROM Boot Version | RAM Applications Version |
| cyw20829 | 0xEB43, 0x21, 0x110 | 1.2.0.8334 | 1.2.0.3073 |
| cyw89829 | 0xEB47, 0x21, 0x110 | 1.2.0.8334 | 1.2.0.3073 |
Prerequisites
- Python 3.8 - 3.12
- Installed Infineon OpenOCD
- Ensure the KitProg3 programming mode is CMSIS-DAP Bulk
Documentation
Standalone Executable
Edge Protect Tools can be used as a standalone application. The executable can be found in the tools/edgeprotecttools/bin directory of the Edge Protect Security Suite or Early Access Pack installation.
Installing From Sources
Alternatively Edge Protect Tools can be installed from the sources as a Python package. The source code is located in the tools/edgeprotecttools/src directory of the Edge Protect Security Suite or Early Access Pack installation.
Install Python 3.12 on your computer. You can download it from https://www.python.org/downloads/. Set up the appropriate environment variable(s) for your operating system.
Installing Package
Make sure that you have the latest version of pip installed, use the following command.
$ python -m pip install --upgrade pip
Run the following command, from the Early Access Pack or Edge Protect Security Suite directory.
$ python -m pip install tools/edgeprotecttools/src
Updating Package
To update the already installed package, run the following command from the Early Access Pack or Edge Protect Security Suite directory.
$ python -m pip install --upgrade --force-reinstall tools/edgeprotecttools/src
Note: There may be some pip dependency resolver errors. In most cases, these can be safely ignored.
Note: You can use the following command to show the path to the installed package
$ python -m pip show edgeprotecttools.
Supported Devices
Use device-list command for output of the supported devices list.
$ edgeprotecttools device-list
Interface and Usage
For instructions how to use common commands, see README_GENERAL.md.
For instructions how to use target-specific commands, see the corresponding readme file in the docs directory.
Logging
Every time the tool is invoked, a new log file is created in the logs directory of the project. By default, the console output has INFO logging severity. The log file contains the DEBUG logging severity.
Known Issues
- Using the policy from CySecureTools 4.0.0 in projects created by CySecureTools 4.1.0 causes the CY_FB_INVALID_IMG_JWT_SIGNATURE error during re-provisioning on PSoC64-2M devices:
...
ERROR : SFB status: CY_FB_INVALID_IMG_JWT_SIGNATURE: Invalid image certificate signature. Check the log for details
Workaround:
- Open the policy file.
- Navigate to section 1 of the
boot_upgrade/firmware. - Set
boot_authandbootloader_keysas follows:
"boot_auth": [
3
],
"bootloader_keys": [
{
"kid": 3,
"key": "../keys/cy_pub_key.json"
}
]
- During the installation of the package via pip on Mac OS Big Sur, the following exception is raised:
...
distutils.errors.DistutilsError: Setup script exited with error: SandboxViolation:
mkdir('/private/var/root/Library/Caches/com.apple.python/private/tmp/easy_install-y8c1npmz', 511) {}
The package setup script has attempted to modify files on your system
that are not within the EasyInstall build area, and has been aborted.
This package cannot be safely installed by EasyInstall, and may not
support alternate installation locations even if you run its setup
script by hand. Please inform the package's author and the EasyInstall
maintainers to find out if a fix or workaround is available.
Solution: Upgrade the pip package running the following command from the terminal: python3 -m pip install --upgrade pip.
Error Handling
Refer to the guidelines on how to resolve errors.
License and Contributions
The software is provided under the Apache-2.0 license. Contributions to this project are accepted under the same license. This project contains code from other projects. The original license text is included in those source files.
Changelog
All notable changes to this project will be documented in this file.
1.2.0
Added
- Support for PSOC C3 device
- Reading device CSR from CYW559xx
1.1.0
Added
- Support for CYW559xx device
1.0.0
Added
- Backward compatibility with the CySecureTools 6.1.0 package
- Combiner/Signer tool
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file edgeprotecttools-1.2.0.tar.gz.
File metadata
- Download URL: edgeprotecttools-1.2.0.tar.gz
- Upload date:
- Size: 1.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
20ef316e5ed0ff5cb3329a23ce1c27af5007ac8ecac27b4e1e4a6966533fbc10
|
|
| MD5 |
9cfecf67e1ed25617aa5cebac47c264d
|
|
| BLAKE2b-256 |
349dfcd727c8e1cce7402c12cac17bd1c8cc0307ab05b82051cbca6a37fef502
|
File details
Details for the file edgeprotecttools-1.2.0-py3-none-any.whl.
File metadata
- Download URL: edgeprotecttools-1.2.0-py3-none-any.whl
- Upload date:
- Size: 1.6 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
963297af78c899ecc110ba88939e80159684f95aaf5b210fa68b3f979481d36a
|
|
| MD5 |
4e9fa4c277a1750f09da5b58703e2860
|
|
| BLAKE2b-256 |
052db785d4a7cacf8d45565ed110ce54a303d87caa2330ab22e5319bbdc7f335
|