Skip to main content
Version: 0.1.23

Introduction

NoxTLS is designed to secure membedded devices quickly and easily. A C library you can integrate into your system to provide cryptographic operations and TLS (Transport Layer Security) functionality for embedded applications. It's been created with low memory footprint an efficiency

Features

  • Encryption: AES, ARIA, Camellia, ChaCha20/Poly1305
  • Message digests: SHA-1, SHA-256, SHA-512, SHA-3, MD4, MD5, RIPEMD-160, BLAKE2
  • Public key crypto: RSA, DSA, ECC, ECDSA, ECDH, Ed25519, X25519
  • TLS: TLS 1.0–1.3 and DTLS support — see TLS component for usage and TLS API for the API
  • X.509 / certificates: Parsing and verification

Supported elliptic curves

NoxTLS supports the following curves for ECDH, ECDSA, and TLS key exchange:

CurveOID / nameUse
NIST P-256secp256r1, prime256v1ECDSA, ECDH, TLS (e.g. ECDHE with AES-128)
NIST P-384secp384r1ECDSA, ECDH, TLS (e.g. ECDHE with AES-256)
NIST P-521secp521r1ECDSA, ECDH
Curve25519X25519Key agreement (ECDH), TLS 1.3 key share
Ed25519Ed25519 (RFC 8032)Digital signatures, X.509 subject public keys
  • Weierstrass (NIST): P-256, P-384, and P-521 are used for ECDSA signing/verification and ECDH key agreement, and for TLS 1.2/1.3 ECDHE cipher suites.
  • X25519: Montgomery curve used for key agreement; supported in TLS key exchange.
  • Ed25519: Twisted Edwards curve used for signatures; supported for X.509 and general signing.

Build modes

NoxTLS can be built in two ways:

  1. Standalone (host) – For unit tests and desktop tooling. Build from the repository with CMake.
  2. With Zephyr (embedded) – Add the library to your Zephyr application via add_subdirectory and link to the noxtls targets.

See Getting Started for build instructions, TLS component for TLS/DTLS usage, and Crypto API for the C API.