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.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.0.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.0-py3-none-any.whl (2.6 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: edgeprotecttools-1.6.0.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.0.tar.gz
Algorithm Hash digest
SHA256 8416a3bd12c9ca101dd33e06cb437649d8278ea8c3b13fa8c9b039e2a7fdc6de
MD5 8f0db32e6bfcd05bf2a66b3e29621b88
BLAKE2b-256 5eed5c62108e1a0b8c74f82017b69453704eb167f4698cdac796ca8503957cf6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for edgeprotecttools-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fae83ad433f150b8dd03f5c69be1914bff9019a880514497a707728c4a7730ed
MD5 d995aaffd5db979db539f17286195a05
BLAKE2b-256 79720b9d6f804eb7a6431b624b6774b4509469289c626edf1cbbdb14401d927f

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