1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-16 06:32:44 +01:00
RIOT/pkg/micro-ecc
Sebastian Meiling ba7cbd024e
Merge pull request #8227 from gebart/pr/micro-ecc-feature-periph
pkg/micro-ecc: Update FEATURE_PERIPH_HWRNG -> MODULE_PERIPH_HWRNG
2018-01-17 20:16:38 +01:00
..
patches pkg/micro-ecc: rename deprecated FEATURE_PERIPH_x 2017-12-13 11:01:46 +01:00
doc.txt fixup! pkg: enhance doxygen packages documentation 2017-07-03 11:18:47 +02:00
Makefile pkg/*: put $(MAKE) in quotes in all packages 2017-12-18 14:53:54 +01:00
Makefile.include make: pkg: make use of PKGDIRBASE 2017-03-10 14:18:44 +01:00
README.md pkg/micro-ecc: support boards without hwrng feature 2017-01-04 02:32:40 -08:00

Micro-ECC for RIOT

This port of Micro-ECC to RIOT is based on the Micro-ECC upstream and adds hwrng_read (provided by RIOT) as the default RNG function if it is available on the target platform. This port also fixes a minor issue with unused variables in the upstream code.

Usage

Build

Add

USEPKG += micro-ecc

to your Makefile.

Choosing the right API

Before using the Micro-ECC library, you need to check the Makefile.features of your target board to see if periph_hwrng is provided.

If it is provided, you may safely use uECC_make_key to generate ECDSA key pairs and call uECC_sign/uECC_verify to sign/verify the ECDSA signatures.

If not, you cannot use uECC_make_key or uECC_sign APIs anymore. The ECDSA keys have to be generated on a platform with HWRNG support (e.g., native) and transferred to your target device. You need to use uECC_sign_deterministic to perform ECDSA deterministic signing (standardized by RFC 6979). You can still use uECC_verify to verify the signatures from both signing APIs.

WARNING Calling uECC_make_key and uECC_sign APIs on platforms without HWRNG support will lead to compile failure.

Examples of using these uECC APIs can be found in the test folder of the Micro-ECC upstream.