Skip to content

A Hardware Security Module that supports Encryption, Decryption, Hashing, Random Number Generation of various sizes and Secure Key Management.

Notifications You must be signed in to change notification settings

mbedsyst/HardwareSecurityModule

Repository files navigation

Hardware Security Module over USB-CDC Class Device

A Hardware Security Module (HSM) that supports AES, RSA, and ECC encryption and decryption, along with hashing using SHA-224, SHA-256, SHA-384, and SHA-512 algorithms. It includes HMAC verification using SHA-224 or SHA-256 and features secure random number generation of various sizes. Secure key management is implemented by storing keys in internal flash memory in an encrypted format, derived from the processor’s Hardware Unique Key (HUK), with an encrypted backup copy stored externally on flash memory.

To ensure persistent configuration storage across resets, a serial EEPROM is incorporated. Hardware security measures include readout protection for internal flash memory and restricted access to the Secure World from Non-Secure code using the GTZC feature of the STM32. Tamper protection is also implemented, monitoring both internal tamper signals and a predefined external GPIO pin for enclosure breaches, triggering erasure protocols for both internal and external flash memory if necessary.

Currently, the PCB is being designed with the STM32H573RIV6 MCU at the core, featuring a USB-C receptacle as the sole interface. SWD pins are exposed for potential future flashing and debugging needs, and UART terminal pins are included for use as a serial data logger during debugging.

PCB Design (Work in Progress)

🧷 2D Views

Top View:

2D Top View

Bottom View:

2D Bottom View

🧷 3D Views

Top View:

Gerber Top View

Right View:

Gerber Right View

🧷 Routed Views

Top Routed View:

2D Top Routed View

Bottom Routed View:

2D Bottom Routed View

About

A Hardware Security Module that supports Encryption, Decryption, Hashing, Random Number Generation of various sizes and Secure Key Management.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages