cheerp 交叉编译aes库

简介: 这个文章主要演示了一个cheerp交叉编译的简单的例子对比测试。这个例子中我们把一个c文件的算法交叉到js侧。先行准备我们分别使用js的一个aes库,和交叉过去的一个c实现的库分别分别在node和浏览器端做性能比较。

这个文章主要演示了一个cheerp交叉编译的简单的例子对比测试。这个例子中我们把一个c文件的算法交叉到js侧。

先行准备

我们分别使用js的一个aes库,和交叉过去的一个c实现的库分别分别在node和浏览器端做性能比较。

先把c算法库交叉到一个bc(clang 的byte code)备用, 验证好执行正确结果。

clang -c -w $(CHEERP_FLAG) $(WASMFLAGS) -O3 -o ./build/aes.bc aes.c

clang++ -w $(CHEERP_FLAG) $(WASMFLAGS) $(WASM_LOADER) -D_MACRO_WASM_INIT -cheerp-no-math-imul -O3 -o ./build/test.wasm main.cpp ./build/aes.bc

cheerp -wasm 执行结果

node开启 --wasm-opt 运行
wasm 执行 1000000次结果 397-459ms
chorme
1000000次结果 400-576ms

js + aes.js 执行结果

node 缓存开启 运行
执行 1000000次结果 2585ms-5600ms
chorme
执行 1000000次结果 3156ms-3500ms

js代码

var aesjs = this.aesjs;
var zero = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]

var key = zero;
//var key = [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 ];

// The initialization vector (must be 16 bytes)
var iv = zero;//[ 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34,35, 36 ];

// Convert text to bytes (text must be a multiple of 16 bytes)
var text = '1234567892312710';
var textBytes = aesjs.utils.utf8.toBytes(text);
var aesCbc = new aesjs.ModeOfOperation.cbc(key, iv);
console.time("time_t node");
for(var i = 0; i< 1000000; i++) {
    
    var encryptedBytes = aesCbc.encrypt(textBytes);
}
console.timeEnd("time_t node");

c++代码

void test_for_aes_en() {
    aes_context  ctx ;
    uint8 Key[16] ={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
    uint8 Indata[16]  ={1,2,3,4,5,6,7,8,9,2,3,1,2,7,1};
    uint8 Outdata[16] ={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};

    memset(&ctx,0,sizeof(ctx));
    aes_set_key(&ctx, Key, 16*8);
    aes_encrypt(&ctx, Indata, Outdata);
}

void m007 () {
    long int size_w = 1000000;
    for( long int i = 0 ; i < size_w; i++ ) {
        test_for_aes_en();
    }
}

可以看到,经过LLVM优化过的WASM代码执行的效率在V8引擎和Node引之上, V8和Node经过jit已经很快了(其他浏览器速度更慢,firefox执行了 7852ms),wasm 性能在这几个平台移植保持出色和稳定(300-500ms);

相关文章
|
编解码 监控 API
|
前端开发 UED 容器
在 CSS 中使用 Flex 布局实现页面自适应时需要注意什么?
【10月更文挑战第22天】在使用 Flex 布局实现页面自适应时,需要对其基本原理和特性有深入的理解,同时结合具体的布局需求和场景,进行细致的调整和优化。通过合理的设置和注意事项的把握,才能实现理想的自适应效果,提升用户体验。还可以根据实际情况进行更深入的探索和实践,以不断提升 Flex 布局的应用能力。
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
259 19
|
消息中间件 开发者
【RabbitMQ深度解析】Topic交换器与模式匹配:掌握消息路由的艺术!
【8月更文挑战第24天】在消息队列(MQ)体系中,交换器作为核心组件之一负责消息路由。特别是`topic`类型的交换器,它通过模式匹配实现消息的精准分发,适用于发布-订阅模式。不同于直接交换器和扇形交换器,`topic`交换器支持更复杂的路由策略,通过带有通配符(如 * 和 #)的模式字符串来定义队列与交换器间的绑定关系。
352 2
|
XML 存储 JSON
在 Python 中应用 protobuf
在 Python 中应用 protobuf
353 0
|
机器学习/深度学习 存储 算法
使用深度强化学习预测股票:DQN 、Double DQN和Dueling Double DQN对比和代码示例
深度强化学习可以将深度学习与强化学习相结合:深度学习擅长从原始数据中学习复杂的表示,强化学习则使代理能够通过反复试验在给定环境中学习最佳动作。通过DRL,研究人员和投资者可以开发能够分析历史数据的模型,理解复杂的市场动态,并对股票购买、销售或持有做出明智的决策。
390 4
|
机器学习/深度学习 算法 计算机视觉
蔚来感知算法岗面经
蔚来感知算法岗面经
315 0
|
Java Maven
Maven配置阿里云镜像与JDK编译版本
Maven配置阿里云镜像与JDK编译版本
7640 0
Maven配置阿里云镜像与JDK编译版本
|
网络协议 安全 机器人
互联网的发展简史—web
前言:互联网是我现在生活所离不开的一个东西,但是你知道互联网的前世今生吗?本文将讲解互联网的发展史,以及很火的元宇宙概念。
2697 1
 互联网的发展简史—web
|
云安全 存储 运维
想考阿里云ACE认证该怎么办?难不难考?
作为云计算行业的TOP级企业,阿里云认证在业界内有很高的知名度和认可度,而阿里云ACE是其中等级最高、难度最大的一个,想考这个需要做不少准备。
1742 1
想考阿里云ACE认证该怎么办?难不难考?