网站首页
IC库存
IC展台
电子资讯
技术资料
PDF文档
我的博客
IC72论坛
ic72 logo
资料首页最新产品 技术参数 电路图 设计应用 解决方案 代理商查询 IC替换 IC厂商 电子辞典
关键字: 技术文章 PDF资料 IC价格 电路图 代理商查询 IC替换 IC厂商 电子辞典

百度云RSA解密加速服务

软件调用API执行

编译

执行lspci | grep -i Xilinx,输出非空,证实FPGA已被正确透传给虚拟机。

编译驱动,进入rsa-driver目录,执行make。

如提示“No such file or directory”,请修改Makefile中的KERNELDIR变量,使之指向正确的内核编译目录,一般为/usr/src/kernels/$(uname -r)。

如编译时提示符号重定义,请删除源文件中的PDE_DATA、file_inode、kvalloc、kvfree等符号。

加载驱动,执行insmod fpga_drive.ko。

检查/dev/fpga0的权限是否为0666,如过不是,请执行chmod 666 /dev/fpga0。

在openssl系统engine目录创建到rsa-api/output/so/libfpga_rsa_cpp.so的软链接,即执行ln -s /path/to/rsa-api/so/libfpga_rsa_cpp.so /usr/lib64/openssl/engines/libfpga_rsa_cpp.so。

通过openssl标准engine接口使用RSA加速功能,在正确加载并初始化engine后即可通过RSA_private_encrypt、RSA_private_decrypt进行RSA私钥加解密。

FPGA支持密钥长度在2048 bits以下的RSA私钥加解密。如给定密钥长度超出此范围,engine会转交CPU计算,此时性能等同于直接使用CPU处理。

#include ‹openssl/rsa.h›

#include ‹openssl/engine.h›

#include ‹openssl/err.h›

OpenSSL_add_all_algorithms();

ERR_load_crypto_strings();

ENGINE_load_dynamic();

/* load engine */

ENGINE *engine = ENGINE_by_id(fpga_rsa_cpp);

if (engine == NULL) {

LOG(WARNING) ‹‹ Could not Load fpga_rsa_cpp Engine!;

return 1;

}

LOG(INFO) ‹‹ fpga_rsa_cpp Engine successfully loaded;

/* init engine */

int init_ret = ENGINE_init(engine);

int set_ret = ENGINE_set_default_RSA(engine);

LOG(INFO) ‹‹ engine name = ‹‹ ENGINE_get_name(engine);

LOG(INFO) ‹‹ init_ret = ‹‹ init_ret;

LOG(INFO) ‹‹ set_ret = ‹‹ set_ret;

if ((init_ret != 1) || (set_ret != 1)) {

LOG(WARNING) ‹‹ Failed to init engine;

return 1;

}

/* use engine */

RSA_private_decrypt(flen, from, to, rsa, padding);

性能测试

qps

执行openssl speed rsa2048 -engine fpga_rsa_cpp -multi 36,在sign/s一栏中可以看到qps。正常情况应在40000/s以上。

latency

执行openssl speed rsa2048 -engine fpga_rsa_cpp -multi 1,在sign一栏中可以看到latency。正常情况应在700us左右。

RSA私钥解密QPS对比

FPGA解决方案与使用双路Intel Xeon E5-2620 v2服务器(超线程开启,共24核)进行纯CPU计算相比,性能优势十分明显,如下图所示。当RSA密钥长度为512 bits、1024 bits和2048 bits时,前者的私钥解密QPS分别是后者的2.13、4.52和9.36倍,latency仅为后者的89%、50%和27%。

热门搜索:02T0500JF TLP6B TLP808TELTAA RS1215-20 BSV52R 1553DBPCB SBB1602-1 PS120406 ADS1013IDGSR RBC11A 2866569 8300SB2-LF BT151S-800R118 TLP604TEL 01M1001JF SBB1605-1 01T1001JF TLM609GF 2858030 TLP712B TLP404 1301380020 2320296 TLP808TEL BTA12-800TWRG
COPYRIGHT:(1998-2010) IC72 达普IC芯片交易网
客户服务:service@IC72.com 库存上载:IC72@IC72.com
(北京)联系方式: 在线QQ咨询:点击这里给我发消息 联系电话:010-82614113 传真:010-82614123
京ICP备06008810号-21 京公网安备 11010802032910 号 企业资质