KAE1.0源码包中包含内核驱动、用户态驱动、基于OpenSSL的KAE引擎和zlib库四个模块,其中内核驱动与用户态驱动为必选项,KAE引擎与zlib库按实际需求选择安装。本文选择基于OpenSSL的KAE引擎进行安装,过程中需要使用命令先进行编译,安装,最后检查是否安装成功。
1 | export OPENSSL_ENGINES=/usr/local/lib/engines-1.1 |
在KAEdriver源码目录下,进入“kae_driver”目录后开始安装内核驱动。
1 2 3 | cd kae_driver make make install |
由于SUSE及CentOS内核目录为“/lib/modules/`uname -r`/”,驱动安装的目录为“/lib/modules/`uname -r`/extra”(`uname -r`命令获取当前运行内核信息)。如果其他操作系统不是该目录,需要修改Makefile文件中install指定的内核路径。
install:
$(shell mkdir -p /lib/modules/`uname -r`/extra)修改为$(shell mkdir -p内核路径/extra)
1 2 3 4 5 | cd warpdrive sh autogen.sh ./configure make make install |
其中,执行编译命令./configure时可以加--prefix选项用于指定加速器用户态驱动需要安装的位置,用户态驱动动态库文件为libwd.so。Warpdrive默认安装路径为“/usr/local”,动态库文件在“/usr/local/lib”下。
KAE引擎需要使用到OpenSSL的动态库与Warpdrive的动态库。Warpdrive源码安装路径选择需要与OpenSSL安装路径保持一致,使得KAE加速引擎可以通过LD_LIBRARY_PATH能够同时找到这两个动态库。
1 | lsmod | grep uacce |
1 | modprobe uacce
|
1 | modprobe hisi_sec2
|
1 | modprobe hisi_hpre
|
1 | modprobe hisi_rde
|
1 | lsmod | grep uacce |
1 | uacce 36864 3 hisi_sec2,hisi_qm,hisi_hpre,hisi_rde |
1 2 3 4 5 | cd kae_engine chmod +x configure ./configure make clean && make make install |
其中,执行编译命令./configure时可以加--prefix选项用于指定KAE引擎的安装路径,KAE引擎动态库文件为libkae.so。
推荐通过默认方式安装KAE引擎。默认安装路径为“/usr/local”,动态库文件在“/usr/local/lib/engines-1.1”下。
如果libwd和OpenSSL安装方式不是按默认进行安装,则可以通过以下命令指定OpenSSL和libwd的安装路径:
1 | ./configure --openssl_path=/usr/local/openssl –wd_path=/usr/local/libwd |
其中,“/usr/local/openssl”和“/usr/local/libwd”是OpenSSL和libwd的一个示例安装路径。
1 | ls -al /usr/local/lib/ | grep libwd |
1 2 3 | lrwxrwxrwx. 1 root root 14 Jun 25 11:16 libwd.so -> libwd.so.1.0.1 lrwxrwxrwx. 1 root root 14 Jun 25 11:16 libwd.so.0 -> libwd.so.1.0.1 -rwxr-xr-x. 1 root root 137280 Jun 24 11:37 libwd.so.1.0.1 |
1 | ls -al /usr/local/lib/engines-1.1/ |
1 2 3 | lrwxrwxrwx. 1 root root 48 Jun 25 11:21 kae.so -> /usr/local/openssl/lib/engines-1.1/kae.so.1.0.1 lrwxrwxrwx. 1 root root 48 Jun 25 11:21 kae.so.0 -> /usr/local/openssl/lib/engines-1.1/kae.so.1.0.1 -rwxr-xr-x. 1 root root 212192 Jun 24 11:37 kae.so.1.0.1 |
1 | ls -al /sys/class/uacce/ |
1 2 3 4 5 6 7 | total 0 lrwxrwxrwx. 1 root root 0 Nov 14 03:45 hisi_hpre-2 -> ../../devices/pci0000:78/0000:78:00.0/0000:79:00.0/uacce/hisi_hpre-2 lrwxrwxrwx. 1 root root 0 Nov 14 03:45 hisi_hpre-3 -> ../../devices/pci0000:b8/0000:b8:00.0/0000:b9:00.0/uacce/hisi_hpre-3 lrwxrwxrwx. 1 root root 0 Nov 17 22:09 hisi_rde-4 -> ../../devices/pci0000:78/0000:78:01.0/uacce/hisi_rde-4 lrwxrwxrwx. 1 root root 0 Nov 17 22:09 hisi_rde-5 -> ../../devices/pci0000:b8/0000:b8:01.0/uacce/hisi_rde-5 lrwxrwxrwx. 1 root root 0 Nov 14 08:39 hisi_sec-0 -> ../../devices/pci0000:74/0000:74:01.0/0000:76:00.0/uacce/hisi_sec-0 lrwxrwxrwx. 1 root root 0 Nov 14 08:39 hisi_sec-1 -> ../../devices/pci0000:b4/0000:b4:01.0/0000:b6:00.0/uacce/hisi_sec-1 |
以验证RSA性能为例,验证步骤请参见测试同步RSA性能,通过RSA性能命令可以看到指定KAE引擎之后,RSA的性能得到明显提升。
另外,除上述方法,在执行RSA性能命令过程中,可以在新的终端上同时查看hisi_hpre设备的硬件队列资源情况如下,相同地,SM3/SM4算法可以查看hisi_sec2的硬件队列消耗情况。
1 | cat /sys/class/uacce/hisi_hpre-*/attrs/available_instances
|
1 | watch -n 0.1 cat /sys/class/uacce/hisi_hpre-*/attrs/available_instances |
显示结果从256变为255,说明RSA算法消耗了HPRE加速器一个硬件单元队列,说明KAEOpensslEngine加速引擎已生效。