OpenSSL is popular software library for applications that secure communications over computer networks against eavesdropping or need to identify the party at the other end. It is widely used in internet web servers, serving a majority of all web sites. OpenSSL contains an open-source implementation of the Transport Layer Security (TLS) and Secure Sockets Layer (SSL) protocols, it is a robust, commercial-grade, and full-featured toolkit for the SSL and TLS protocols. OpenSSL is also a general-purpose cryptography library. Its core library, written in the C programming language, implements basic cryptographic functions and provides various utility functions. Wrappers allowing the use of the OpenSSL library in a variety of computer languages are available. More and more embeded systems, like IoT gateway, ePOS, based on i.MX use OpenSSL for their secure communications and cryptographic operations. But it's cryptography library is pure software implementation which need to occupy lots of CPU resouce and the perfermance is very weak than dedicated hardware IP (like CAAM).  
   CAAM is the i.MX's cryptographic acceleration and assurance module, which serves as NXP's latest cryptographic acceleration and offloading hardware. It combines functions previously implemented in separate modules to create a modular and scalable acceleration and assurance engine. It also implements block encryption algorithms, stream cipher algorithms, hashing algorithms, public key algorithms (i.MX6UL/i.MX7D/S), and a hardware random number generator. 
   The official Yocto release (L4.1.15_2.0.0-ga) of the i.MX only enable cryptodev for accelerating symmetric algorithms and hashing algorithms, not support asymmetric algorithms(RSA, ECC). And its engine in OpenSSL(version 1.0.2h) also miss some features which is used to support symmetric algorithms and hashing algorithms, for example, AES ECB, SHA224/256, etc. These patches in the post will close the above gaps for i.MX Linux system. The software environments as the belows: 
 Linux kernel: imx_4.1.15_2.0.0_ga 
 cryptodev: 1.8 
 OpenSSL: 1.0.2h 
 The patches include the following key features: 
 1, Add public key cryptography part in CAAM driver, through protocol commands, to implement a number of public (and private) key functions. These are DSA and ECDSA sign/verify, Diffie-Hellman (DH) and ECDH key agreement, ECC key generation, DLC key generation, RSA encryption/decryption, RSA key-generation finalization. 
 2, Add big number operation and elliptic curve math in CAAM driver to implement addition, subtraction, multiplication, exponentiation, reduction, inversion, greatest common divisor, prime testing and point add, point double, point multiply. 
 3, Add API in cryptodev to support RSA encryption/decryption, DSA/ECDSA sign/verify, DH/ECDH key agreement, ECC & DLC & RSA key generation and big number operation and elliptic curve math. 
 4, Add public key cryptography functions, hardware rng, and missing hash symmetric algorithms in OpenSSL crytodev engine. 
 Note:  
 1, You can refer to ecdhtest.c, ecdsatest.c, dhtest.c, dsatest.c, rsa_test.c for how to use crytodev engine in your applications based on libcryto.so. You can also find their executable programs in folder openssl-1.0.2h/test after compiling. 
 2, If you want to call crytodev API directly to accelerate public key cryptography operations, please refer to asymmetric_cipher.c in cryptodev-linux-1.8/tests. 
 Current Limitation: 
 1, CAAM driver don't support AES GCM/CCM but hardware supporting. I plan to add the feature next version. 
 2, ECDSA sign/verify will fail on some binary curves (sect163r1, sect163r2, sect193r1, sect193r2, sect233r1, sect283r1, sect409r1, sect571r1 and X9.62 binary curves). I will try to find the root cause and fix it. 
   
 ==================================== 
 for  some binary curves (sect163r1, sect163r2, sect193r1, sect193r2, sect233r1, sect283r1, sect409r1, sect571r1 and X9.62 binary curves)  are rarely used, so i will try to find the root cause when i'm free.  
 +++++++++++++++++++++++    updating for Linux-4.14.78-1.1.10 ++++++++++++++++++++++++++++ 
 This updating is for Yocto release of Linux -4.14.78-1.1.10. The new software environments as the belows: 
 Linux kernel: imx_4.14.78_1.1.10 
 cryptodev: 1.9 
 OpenSSL: 1.0.2p 
 HW platform: i.MX6UL, i.MX7D/S, i.MX8M/8M Mini, i.MX8/8X. 
 The patches include the following new features: 
 1, support  RSA key generation but defaultly use openssl build-in function (BN_generate_prime_ex) to create prime p, q for higher security. If need to use CAAM accelerating,  please comment Macro USE_BUILTIN_PRIME_GENERATION, but don't confirm its security. 
 2, Add Manufacturing-protection feature, and you can refer to manufacturing_protection_test function in asymmetric_cipher.c. 
 3, Support AES GCM in cryptodev. 
 4,  git clone https://gitee.com/zxd2021-imx/meta-openssl-caam.git, git checkout Linux-4.14.78-1.1.10  and copy meta-openssl-caam to folder <Yocto 4.14.78-1.1.10 dir>/sources/   
 5, Run DISTRO=fsl-imx-wayland MACHINE=imx6ulevk source fsl-setup-release.sh -b build-imx6ulevk and add BBLAYERS += " ${BSPDIR}/sources/meta-openssl-caam " into /build-imx6ulevk/conf/bblayers.conf 
 6, bitbake fsl-image-validation-imx   
 7, Run the below command on your i.MX6UL EVK board. 
 modprobe cryptodev 
 openssl genrsa -f4 -engine cryptodev 512 -elapsed  openssl speed dsa -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 1024 -elapsed  openssl speed rsa -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 2048 -elapsed  openssl speed ecdsa -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 3072 -elapsed  openssl speed ecdh -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 4096 -elapsed 
 openssl speed -evp sha256 -engine cryptodev -elapsed  openssl speed -evp aes-128-cbc -engine cryptodev -elapsed  openssl speed -evp aes-128-ecb -engine cryptodev -elapsed  openssl speed -evp aes-128-cfb -engine cryptodev -elapsed  openssl speed -evp aes-128-ofb -engine cryptodev -elapsed  openssl speed -evp des-ede3 -engine cryptodev -elapsed  openssl speed -evp des-cbc -engine cryptodev -elapsed  openssl speed -evp des-ede3-cfb -engine cryptodev -elapsed 
 +++++++++++++++++++++++    updating for Linux-4.14.98-2.3.3 ++++++++++++++++++++++++++++ 
 This updating is for Yocto release of Linux -4.14.98-2.3.3. The new software environments as the belows: 
 Linux kernel: imx_4.14.98-2.3.3 
 cryptodev: 1.9 
 OpenSSL: 1.0.2p 
 HW platform: i.MX6UL, i.MX7D/S, i.MX8M/8M Mini/8M Nano, i.MX8/8X. 
 The patches include the following new features: 
 1,  git clone https://gitee.com/zxd2021-imx/meta-openssl-caam.git, git checkout Linux-4.14.98-2.3.3  and copy meta-openssl-caam to folder <Yocto 4.14.98-2.3.3 dir>/sources/   
 2, Run DISTRO=fsl-imx-wayland MACHINE=imx8mmevk source fsl-setup-release.sh -b build-imx8mmevk and add BBLAYERS += " ${BSPDIR}/sources/meta-openssl-caam " into /build-imx8mmevk/conf/bblayers.conf   
 3, bitbake fsl-image-validation-imx   
 4, Run the below command on your i.MX8M Mini EVK board. 
 modprobe cryptodev 
 openssl genrsa -f4 -engine cryptodev 512 -elapsed  openssl speed dsa -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 1024 -elapsed  openssl speed rsa -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 2048 -elapsed  openssl speed ecdsa -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 3072 -elapsed  openssl speed ecdh -engine cryptodev -elapsed  openssl genrsa -f4 -engine cryptodev 4096 -elapsed 
 openssl speed -evp sha256 -engine cryptodev -elapsed  openssl speed -evp aes-128-cbc -engine cryptodev -elapsed  openssl speed -evp aes-128-ecb -engine cryptodev -elapsed  openssl speed -evp aes-128-cfb -engine cryptodev -elapsed  openssl speed -evp aes-128-ofb -engine cryptodev -elapsed  openssl speed -evp des-ede3 -engine cryptodev -elapsed  openssl speed -evp des-cbc -engine cryptodev -elapsed  openssl speed -evp des-ede3-cfb -engine cryptodev -elapsed 
 +++++++++++++++++++++++    updating for Linux-4.19.35-1.1.2 ++++++++++++++++++++++++++++ 
 This updating is for Yocto release of Linux 4.19.35-1.1.2.     
 Software environments as the belows: 
 Linux kernel: imx_4.19.35-1.1.2   
 cryptodev: 1.10 
 OpenSSL: 1.1.1l   
 HW platform: i.MX6UL, i.MX7D/S, i.MX8M/8M Mini/8M Nano, i.MX8/8X. 
 How to build: 
 1, git clone https://gitee.com/zxd2021-imx/meta-openssl-caam.git, git checkout Linux-4.19.35-1.1.2  and copy meta-openssl-caam to folder <Yocto 4.19.35-1.1.2 dir>/sources/ 
 2, Run DISTRO=fsl-imx-wayland MACHINE=imx8mmevk source imx-setup-release.sh -b build-imx8mmevk and add BBLAYERS += " ${BSPDIR}/sources/meta-openssl-caam " into <Yocto 4.19.35-1.1.2 dir>/build-imx8mmevk/conf/bblayers.conf.   
 3, Run bitbake fsl-image-validation-imx. 
 4, Run the below command on your i.MX8M Mini EVK board. 
 modprobe cryptodev 
 openssl speed dsa  openssl speed rsa   openssl speed ecdsa  openssl speed ecdh 
 openssl genrsa -f4 -engine devcrypto 512  openssl genrsa -f4 -engine devcrypto 1024  openssl genrsa -f4 -engine devcrypto 2048  openssl genrsa -f4 -engine devcrypto 3072  openssl genrsa -f4 -engine devcrypto 4096 
 openssl speed -evp sha256 -engine devcrypto -elapsed  openssl speed -evp aes-128-cbc -engine devcrypto -elapsed  openssl speed -evp aes-128-ecb -engine devcrypto -elapsed  openssl speed -evp aes-128-cfb -engine devcrypto -elapsed  openssl speed -evp aes-128-ofb -engine devcrypto -elapsed  openssl speed -evp des-ede3 -engine devcrypto -elapsed  openssl speed -evp des-cbc -engine devcrypto -elapsed  openssl speed -evp des-ede3-cfb -engine devcrypto -elapsed 
 +++++++++++++++++++++++    updating for Linux-5.4.70-2.3.4 ++++++++++++++++++++++++++++ 
 This updating is for Yocto release of Linux 5.4.70_2.3.4.     
 Software environments as the belows: 
 Linux kernel: imx_5.4.70_2.3.4   
 cryptodev: 1.10 
 OpenSSL: 1.1.1l   
 HW platform: i.MX6UL, i.MX7D/S, i.MX8M/8M Mini/8M Nano/8M Plus, i.MX8/8X. 
 How to build: 
 1, git clone https://gitee.com/zxd2021-imx/meta-openssl-caam.git, git checkout Linux-5.4.70-2.3.4  and copy meta-openssl-caam to folder <Yocto 5.4.70_2.3.4 dir>/sources/ 
 2, Run DISTRO=fsl-imx-wayland MACHINE=imx8mmevk source imx-setup-release.sh -b build-imx8mmevk and add BBLAYERS += " ${BSPDIR}/sources/meta-openssl-caam " into <Yocto 5.4.70_2.3.4 dir>/build-imx8mmevk/conf/bblayers.conf.   
 3, Run bitbake imx-image-multimedia. 
 4, Run the below command on your i.MX8M Mini EVK board. 
 modprobe cryptodev 
 openssl speed dsa  openssl speed rsa   openssl speed ecdsa  openssl speed ecdh 
 openssl genrsa -f4 -engine devcrypto 512  openssl genrsa -f4 -engine devcrypto 1024  openssl genrsa -f4 -engine devcrypto 2048  openssl genrsa -f4 -engine devcrypto 3072  openssl genrsa -f4 -engine devcrypto 4096 
 openssl speed -evp sha256 -engine devcrypto -elapsed  openssl speed -evp aes-128-cbc -engine devcrypto -elapsed  openssl speed -evp aes-128-ecb -engine devcrypto -elapsed  openssl speed -evp aes-128-cfb -engine devcrypto -elapsed  openssl speed -evp aes-128-ofb -engine devcrypto -elapsed  openssl speed -evp des-ede3 -engine devcrypto -elapsed  openssl speed -evp des-cbc -engine devcrypto -elapsed  openssl speed -evp des-ede3-cfb -engine devcrypto -elapsed 
   
   
 +++++++++++++++++++++++    updating for Linux-5.10.52-2.1.0 ++++++++++++++++++++++++++++ 
 This updating is for Yocto release of Linux 5.10.52_2.1.0.     
 Software environments as the belows: 
 Linux kernel: lf-5.10.y   
 cryptodev: 1.12 
 OpenSSL: 1.1.1l   
 HW platform: i.MX6UL, i.MX7D/S, i.MX8M/8M Mini/8M Nano/8M Plus, i.MX8/8X. 
 How to build: 
 1, git clone https://gitee.com/zxd2021-imx/meta-openssl-caam.git, git checkout Linux-5.10.52-2.1.0  and copy meta-openssl-caam to folder <Yocto 5.10.52_2.1.0 dir>/sources/ 
 2, Run DISTRO=fsl-imx-xwayland MACHINE=imx8mmevk source imx-setup-release.sh -b build-imx8mmevk and add BBLAYERS += " ${BSPDIR}/sources/meta-openssl-caam " into <Yocto 5.10.52_2.1.0 dir>/build-imx8mmevk/conf/bblayers.conf.   
 3, Run bitbake imx-image-multimedia. 
 4, Run the below command on your i.MX8M Mini EVK board. 
 modprobe cryptodev 
 openssl speed dsa  openssl speed rsa   openssl speed ecdsa  openssl speed ecdh 
 openssl genrsa -f4 -engine devcrypto 512  openssl genrsa -f4 -engine devcrypto 1024  openssl genrsa -f4 -engine devcrypto 2048  openssl genrsa -f4 -engine devcrypto 3072  openssl genrsa -f4 -engine devcrypto 4096 
 openssl speed -evp sha256 -engine devcrypto -elapsed  openssl speed -evp aes-128-cbc -engine devcrypto -elapsed  openssl speed -evp aes-128-ecb -engine devcrypto -elapsed  openssl speed -evp aes-128-cfb -engine devcrypto -elapsed  openssl speed -evp aes-128-ofb -engine devcrypto -elapsed  openssl speed -evp des-ede3 -engine devcrypto -elapsed  openssl speed -evp des-cbc -engine devcrypto -elapsed  openssl speed -evp des-ede3-cfb -engine devcrypto -elapsed 
   
 +++++++++++++++++++++++    updating for Linux-5.15.71-2.2.0 ++++++++++++++++++++++++++++ 
 This updating is for Yocto release of Linux 5.15.71-2.2.0.     
 Software environments as the belows: 
 Linux kernel: lf-5.15.71-2.2.0   
 cryptodev: 1.12 
 OpenSSL: 3.1.0   
 HW platform: i.MX6UL, i.MX7D/S, i.MX8M/8M Mini/8M Nano/8M Plus, i.MX8/8X. 
 How to build: 
 1, git clone https://gitee.com/zxd2021-imx/meta-openssl-caam.git, git checkout Linux-5.15.71-2.2.0 and copy meta-openssl-caam to folder <Yocto 5.15.71_2.2.0 dir>/sources/ 
 2, Run DISTRO=fsl-imx-xwayland MACHINE=imx8mmevk source imx-setup-release.sh -b build-imx8mmevk and add BBLAYERS += " ${BSPDIR}/sources/meta-openssl-caam " into <Yocto 5.15.71_2.2.0 dir>/build-imx8mmevk/conf/bblayers.conf.   
 3, Run bitbake imx-image-multimedia. 
 4, Run the below command on your i.MX8M Mini EVK board. 
 modprobe cryptodev 
 openssl speed sm2  openssl speed dsa  openssl speed rsa  openssl speed ecdsa  openssl speed ecdh 
 openssl genrsa -f4 -engine devcrypto 512  openssl genrsa -f4 -engine devcrypto 1024  openssl genrsa -f4 -engine devcrypto 2048  openssl genrsa -f4 -engine devcrypto 3072  openssl genrsa -f4 -engine devcrypto 4096 
 openssl speed -evp sha256 -engine devcrypto -elapsed  openssl speed -evp aes-128-cbc -engine devcrypto -elapsed  openssl speed -evp aes-128-ecb -engine devcrypto -elapsed  openssl speed -evp aes-128-cfb -engine devcrypto -elapsed  openssl speed -evp aes-128-ofb -engine devcrypto -elapsed  openssl speed -evp des-ede3 -engine devcrypto -elapsed  openssl speed -evp des-cbc -engine devcrypto -elapsed  openssl speed -evp des-ede3-cfb -engine devcrypto -elapsed 
   
   
        
        View full article