Skip to main content

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

Prerequisites

  • Python 3.9 - 3.13 if not using the executable.
  • Installed Infineon OpenOCD
  • Ensure the KitProg3 programming mode is CMSIS-DAP Bulk

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.13 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

Device Documentation
PSOC™ 64 Secure MCU README_PSOC64.md
XMC7000 Industrial MCU README_XMC7XXX.md
AIROC™ CYW20829/CYW89829 README_CYW20829_CYW89829.md
AIROC™ CYW559xx README_CYW559XX.md
PSOC™ Control C3 README_PSOCC3.md
PSOC™ Edge 84 MCU README_PSE8X.md

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

Installation Failure on macOS Big Sur Using pip

Details

During the installation of the package via pip on macOS 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.

Resolution

Upgrade the pip package running the following command from the terminal: python3 -m pip install --upgrade pip.

LibraryNotFoundError During Runtime on Ubuntu 24.04

Details

During the runtime of the package on Ubuntu 24.04, the following exception is raised:

  oscrypto.errors.LibraryNotFoundError: Error detecting the version of libcrypto

Workaround

Consider using an executable file. See Standalone Executable.

Resolution

Upgrade the oscrypto package running the following command from the terminal: pip install --upgrade --force-reinstall git+https://github.com/wbond/oscrypto.git@d5f3437.

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.6.1

Changed

  • Optimized encryption algorithm for faster processing of large images using ECB cipher mode

1.6.0

Added

  • Support for PSOC™ Edge E81, E82, E83, E84 series
  • Support for AIROC™ CYW89829 B1 MCU
  • Signer/Combiner symbol file feature for variable interpolation
  • Intel HEX regions relocation feature

Changed

  • PSOC™ Control C3: "listen_window" value from "1 ms" to "2 ms" in "policy_oem_provisioning.json"
  • CYW559xx: Align the certificate chain address in the OTA image to a 256-byte boundary

1.5.0

Added

  • CYW559xx device erase command
  • CYW559xx custom encryption IV
  • CYW20829 encryption in NORMAL_NO_SECURE LCS

Changed

  • Dropped support for Python 3.8

1.4.0

Added

  • Support for AIROC™ CYW20829 revision B1
  • Application encryption for AIROC™ CYW559xx
  • OTA image generation for AIROC™ CYW559xx

Changed

  • PSOC™ Control C3 integrity exam certificate
  • Replaced lief package with pyelftools

1.3.0

Added

  • X.509 certificates generation and verification
  • Device certificate generation for CYW559xx

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

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

edgeprotecttools-1.6.1.tar.gz (2.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

edgeprotecttools-1.6.1-py3-none-any.whl (2.6 MB view details)

Uploaded Python 3

File details

Details for the file edgeprotecttools-1.6.1.tar.gz.

File metadata

  • Download URL: edgeprotecttools-1.6.1.tar.gz
  • Upload date:
  • Size: 2.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for edgeprotecttools-1.6.1.tar.gz
Algorithm Hash digest
SHA256 073874fdf05969850309086d0bfedff37e539542d476ddd64f103091bb617640
MD5 0ffbe8346e71f149f9aacc668b431486
BLAKE2b-256 7fd0e65e3ac007c06deee258bbb636f65178b6830bc1d4c12212382ce023be7f

See more details on using hashes here.

File details

Details for the file edgeprotecttools-1.6.1-py3-none-any.whl.

File metadata

File hashes

Hashes for edgeprotecttools-1.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e23efd7011c2fcd4a0ea1e5f7f3a56476f687052203fbcc0d7c60670d1239779
MD5 ec471bb17faac41f0f2e7a84eba371b9
BLAKE2b-256 f0862cb9afb1a04f59f30eceb174b27a0b850f8da6f74faf828c05b8af5a9632

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page