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 README_CYW20829.md
AIROC™ CYW559xx README_CYW559XX.md
PSOC™ Control C3 README_PSOCC3.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.5.0

Changed

  • Dropped support for Python 3.8

Added

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

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.5.0.tar.gz (1.4 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.5.0-py3-none-any.whl (1.7 MB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for edgeprotecttools-1.5.0.tar.gz
Algorithm Hash digest
SHA256 d3f954996a2a020bc08518b7155c9218c7e8ef1cdb6f3633cb2c166d25d85c3c
MD5 a25d39019eb3dbefa639f14e58889f0a
BLAKE2b-256 b968d6a3ed274ab8ccfb88b3b71f0d390f15bed1aeb710142b73d60b7a626788

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for edgeprotecttools-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b4e725c2990b2889e29fc1420eb9419d29af047eea09ad115138385f437a8d3e
MD5 cab0b8e59e58fa9cb63026aaedbc68bf
BLAKE2b-256 cd4fb60a2c527d0f7c607da8db6fcfd4dfead19db94d206e5b2fe48666fc10af

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