开源LLVM打碎控制流图和字符串加密

栏目: 软件资讯 · 发布时间: 6年前

内容简介:字符串加密效果见:下面介绍打碎控制流。

字符串加密效果见: https://bbs.pediy.com/thread-251631.htm

下面介绍打碎控制流。

> > > >

原理

将llvm中的条件br指令替换成一个 call indirectbr 。这个 call 返回的是跳转的目的地址。

处理前:

%7 = icmp eq i32 %6, 2
 br i1 %7, label %8, label %13

处理后:

%8 = icmp eq i32 %7, 2
 %9 = call i8* @brkcfg(i1 %8, i32 0)
 
indirectbr i8* %9, [label %15, label %10]

> > > >

用法:

-mllvm -brkcfg 使能打碎控制流

-mllvm -encstr 使能加密字符串

代码中使用以下注解来对指定函数开关打碎控制流:

__attribute__((annotate("loveida")))

__attribute__((annotate("hateida")))

真值表:

hateida     loveida     default

default Y              N              N

brkcfg  Y              N              Y

在目前的实现中,打碎控制流中的call并没有加密跳转表,因此对抗脚本分析效果不怎么好。等那天闲着无聊再弄吧。

代码较为简短,所以就直接发代码了。本来想发binary的,但是编译一次release太久太占硬盘,就不弄了。感兴趣的自己编译吧。使用的llvm版本是release/8.x。

> > > >

效果:

开源LLVM打碎控制流图和字符串加密 开源LLVM打碎控制流图和字符串加密 开源LLVM打碎控制流图和字符串加密 开源LLVM打碎控制流图和字符串加密

- End -

开源LLVM打碎控制流图和字符串加密

看雪ID: malokch

https://bbs.pediy.com/user-453009.htm   

本文由看雪论坛  malokch  原创

转载请注明来自看雪社区

:warning: 注意

2019 看雪安全开发者峰会门票正在热售中!

长按识别下方 二维码 即可享受  2.5折  优惠!

开源LLVM打碎控制流图和字符串加密

开源LLVM打碎控制流图和字符串加密

公众号ID:ikanxue

官方微博:看雪安全

商务合作:wsc@kanxue.com

点击下方“阅读原文”,查看更多干货


以上所述就是小编给大家介绍的《开源LLVM打碎控制流图和字符串加密》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

移动风暴

移动风暴

[美]弗雷德·沃格尔斯坦 / 朱邦芊 / 中信出版社 / 2014-1-1 / 39

也许,除了伟大的乔布斯,每一位奋力改变世界的硅谷英雄,都值得我们肃然起敬。苹果与谷歌十年博弈,关于这场移动平台战争的报道早已铺天盖地,而这是第一次,我们能听到幕后工程师的真实声音。两大科技巨人用智能手机和平板电脑颠覆了电脑产业。它们位处变革的中心,凭借各自的经营哲学、魅力领袖和商业敏感度,把竞争变成了残酷对决。商业记者沃格尔斯坦报道这场对抗已逾十载,在《移动风暴》中,他带领我们来到一间间办公室和会......一起来看看 《移动风暴》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

随机密码生成器
随机密码生成器

多种字符组合密码

MD5 加密
MD5 加密

MD5 加密工具