专栏名称: 看雪学苑
致力于移动与安全研究的开发者社区,看雪学院(kanxue.com)官方微信公众帐号。
目录
相关文章推荐
计算机与网络安全  ·  信息通信行业技术标准体系建设指南(2025- ... ·  13 小时前  
吾爱破解论坛  ·  分享图片 ·  2 天前  
吾爱破解论坛  ·  分享图片 ·  2 天前  
计算机与网络安全  ·  渗透测试工程师(高级)证书,终身有效(免维持费) ·  昨天  
新华网汽车  ·  中汽协发声,反对“价格战” ·  2 天前  
新华网汽车  ·  中汽协发声,反对“价格战” ·  2 天前  
51好读  ›  专栏  ›  看雪学苑

虚拟机保护技术浅谈

看雪学苑  · 公众号  · 互联网安全  · 2017-07-28 18:16

正文

请到「今天看啥」查看全文


现在的CPU都有大量的寄存器,堆栈一般只是在函数传递参数时使用(譬如PC机用的x86系列CPU)。但也有一些CPU只操作内存,没有堆栈,也没有寄存器。使用这种CPU的机器称之为3地址机器。

基于堆栈的CPU或虚拟机没有临时变量、寄存器的概念,所有的东西都放入堆栈。由于指令中不需要指定操作数,所以其指令相对基于寄存器的要短。也因此相对简单,在嵌入式系统中运用较多。用于保护代码,我们也选择这种。

举例,譬如指令add,基于堆栈的CPU首先从堆栈里Pop两个数,然后将两数相加,再把和Push到堆栈。Add指令只占用1个字节。而基于寄存器的CPU对应指令为 add Reg1,Reg2,需要3个字节。请仔细想象一下没有寄存器的CPU,它的指令是怎样的,该会是多么简洁。当然,指令简洁带来的缺点就是效率低下。

我们这里谈的虚拟机保护技术,就是把基于寄存器的CPU代码,改造成基于堆栈的CPU的伪代码。然后再由基于堆栈的虚拟机(CPU)对伪代码解释执行。


指令系统


关键在于设计一个虚拟的基于堆栈的虚拟机(CPU)的指令系统。这个指令系统越简洁,复用性越高越好。

还是以add 指令为例。X86系列CPU的add指令有许多格式,譬如:add reg,imm 、add reg,reg、add reg,mem、add mem,reg等等。而基于堆栈的虚拟机CPU则没有这么多花样,就一个单单的add指令,参数和返回都是在堆栈里。

我们需要为我们的虚拟机CPU模拟实现这样的add命令:







请到「今天看啥」查看全文


推荐文章
计算机与网络安全  ·  信息通信行业技术标准体系建设指南(2025-2027)
13 小时前
吾爱破解论坛  ·  分享图片
2 天前
吾爱破解论坛  ·  分享图片
2 天前
新华网汽车  ·  中汽协发声,反对“价格战”
2 天前
新华网汽车  ·  中汽协发声,反对“价格战”
2 天前
冷丫  ·  冷丫专栏:这个角度正好
8 年前
丁香医生  ·  把痰吞进肚子里,要紧吗?
8 年前
真叫卢俊的地产观  ·  关于白百合事件,我更想聊聊狗仔队
8 年前