IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 区块链 -> Polygon zkEVM zkASM 与 以太坊虚拟机opcode 对应集合 -> 正文阅读

[区块链]Polygon zkEVM zkASM 与 以太坊虚拟机opcode 对应集合

1. 引言

结合:

2. 0x01 ADD opcode

在这里插入图片描述
其中:

  • δ \delta δ为从stack中pop出来的value数,因ADD是对stack的top 2 values求和(除非明确说明,否则是对 2 256 2^{256} 2256取模)。
  • α \alpha α为向stack push进去的value数。ADD操作会将二值求和结果再push进stack中。

在这里插入图片描述
根据上图可知,0x01 ADD opcode所需最小gas为3。

在Polygon zkEVM中,以太坊虚拟机的0x01 ADD opcode对应的zkASM表示为:

opADD:
	; 检查当前stack中确实有至少2个元素,否则跳转到stackUnderflow。
    SP - 2          :JMPN(stackUnderflow)
    ; 将stack pointer值减一
    SP - 1 => SP
    ; 将stack pointer值加载到A寄存器中;再将stack pointer值减一
    $ => A          :MLOAD(SP--)
    ; 将stack pointer值加载到C寄存器中
    $ => C          :MLOAD(SP)

    ; Add operation with Arith
    ; 将A寄存器的值存储在Memory状态机中的`arithA`变量中
    A               :MSTORE(arithA)
    ; 将C寄存器的值存储在Memory状态机中的`arithB`变量中
    C               :MSTORE(arithB)
    ; 调用`addARITH`子程序,负责执行加法运算
                    :CALL(addARITH)
    ; 从Memory状态机中的`arithRes1`变量中读取加法运算结果 存入在 E寄存器中
    $ => E          :MLOAD(arithRes1)
    ; 将E寄存器的值存储在stack pointer位置,将stack pointer值加一
    E               :MSTORE(SP++)
    ; stack空间为1024,若当前stack pointer值大于1024,则跳转到stackOverflow
    1024 - SP       :JMPN(stackOverflow)
    ; ADD opcode所需最低gas为3,若执行为ADD操作后GAS为负数,则跳转到outOfGas
    GAS-3 => GAS    :JMPN(outOfGas)
    ; 最后但同样重要的是,以下表示继续处理下一指令。
                    :JMP(readCode)

其中addARITH子程序负责执行加法运算,具体实现见:

  • zkEVM Rom项目中的utils.zkasm
    ; 其中tmpZkPC、storeTmp、arithA、arithB、arithRes1、loadTmp均为全局变量。
    addARITH:
    	; 将调用addARITH子程序之前的RR值存入tmpZkPC临时全局变量中。
        RR              :MSTORE(tmpZkPC)
        zkPC+1 => RR    :JMP(storeTmp) ; 等效为 CALL(storeTmp)
    
        $ => A          :MLOAD(arithA)
        $ => B          :MLOAD(arithB)
        $ => E          :ADD
    
        E               :MSTORE(arithRes1)
    
        zkPC+1 => RR    :JMP(loadTmp) ; 等效为 CALL(loadTmp)
        ; 重置RR值 为 调用addARITH子程序之前的RR值(从tmpZkPC临时全局变量中取出)
        $ => RR         :MLOAD(tmpZkPC)
                        :JMP(RR)
    
    其中storeTmp子程序为将A/B/C/D/E寄存器的值存储在临时全局变量tmpVarA/B/C/D/E中,而loadTmp为将临时全局变量tmpVarA/B/C/D/E中的值加载到A/B/C/D/E寄存器中:
    storeTmp:
        A                   :MSTORE(tmpVarA)
        B                   :MSTORE(tmpVarB)
        C                   :MSTORE(tmpVarC)
        D                   :MSTORE(tmpVarD)
        E                   :MSTORE(tmpVarE)
                            :JMP(RR) ; 等效为 RETURN
    loadTmp:
        $ => A                  :MLOAD(tmpVarA)
        $ => B                  :MLOAD(tmpVarB)
        $ => C                  :MLOAD(tmpVarC)
        $ => D                  :MLOAD(tmpVarD)
        $ => E                  :MLOAD(tmpVarE)
                                :JMP(RR) ; 等效为 RETURN
    

参考资料

[1] zkASM示例
[2] 以太坊黄皮书 https://ethereum.github.io/yellowpaper/paper.pdf
[3] 理解以太坊黄皮书
[3] EVM.Codes

附录:Polygon Hermez 2.0 zkEVM系列博客

  区块链 最新文章
盘点具备盈利潜力的几大加密板块,以及潜在
阅读笔记|让区块空间成为商品,打造Web3云
区块链1.0-比特币的数据结构
Team Finance被黑分析|黑客自建Token“瞒天
区块链≠绿色?波卡或成 Web3“生态环保”标
期货从入门到高深之手动交易系列D1课
以太坊基础---区块验证
进入以太坊合并的五个数字
经典同态加密算法Paillier解读 - 原理、实现
IPFS/Filecoin学习知识科普(四)
上一篇文章      下一篇文章      查看所有文章
加:2022-09-21 00:33:53  更:2022-09-21 00:35:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 21:45:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码