1.指令结构
CairoCPU原生支持的word是一个域元素,而这个域是特征值大于P>2^63。每个指令会占用1到2个word,如果指令后面跟着立即值(="12345678")则该指令占用2个word,并且值存在第二个word里。每个指令的第一个word由以下元素组成:
2.状态转换
状态转换函数代表了一个通用的状态转换单元,而一个计算通常会分解成多个连续执行的指令,因此我们需要:
a.确保指令的内容,以及指令执行前后的状态的有效性
Argo Blockchain Q1收入1140万美元,较上一季度增长15%:金色财经报道,加密矿业公司Argo Blockchain第一季度收入为1140万美元,比上一季度增长15%。本季度,Argo开采了491枚BTC。矿业利润率为49%,而上一季度为35%。截至3月31日,该公司的资产负债表上有1420万美元现金和85枚BTC的加密货币储备。[2023/6/6 21:19:31]
b.确保执行的指令是一个有效的指令
2.1转换逻辑
如果指令执行前后的状态是一致的,那么其状态的更新一定是按照以下逻辑执行:
巴林电信运营商子公司Stec Bahrain接受加密货币支付:金色财经报道,巴林电信运营商Stc Group子公司Stec Bahrain近日宣布与支付服务提供商Eazy Financial Services达成合作,将通过EazyPay和Binance Pay接受加密货币支付。这一合作关系允许Stec Bahrain客户使用Binance钱包结算账单。(Bitcoin.com)[2022/12/18 21:52:34]
2.2指令校验
如图1所示,?个指令由以下元素组成:
Espresso Systems旗下隐私资产配置协议CAPE上线Arbitrum测试网:12月9日消息,Web3应用扩展和隐私系统Espresso Systems宣布在Arbitrum测试网上线隐私资产配置协议CAPE(Configurable Asset Privacy for Ethereum)。据悉,该协议可使数字资产创建者能够配置其所创建的资产的保管和转移数据的查看权限。用户可以创建新的代币并包装现有的以太坊代币,以赋予他们所需的隐私属性。[2022/12/9 21:33:36]
3.指令示例
3.1断言相等
断言相等指令可以用下述语法表示:
<left_handle_op>=<right_handle_op>
它确保了公式两边是相等的,否则程序的执行将会被返回。
Note2:除法和减法可以分别表示为具有不同操作数顺序的乘法和加法。
assert指令可以被认为是一条赋值指令,其中?边是已知的,另一边是未知的。例如=4可以被认为是断言的值为4,或者根据上下文将赋值为4。
图4给出了断言相等指令的一些示例,以及每个指令对应的标志值:
加拿大帝国商业银行:加息100个基点可能还不在美联储计划之中:9月21日消息,在8月通胀数据超预期之后,9月美联储至少可以再加息75个基点,并承诺未来还会有更多加息。加息100个基点也很容易找到理由。FOMC中没有人认为利率不会在某个时候达到3.5%,美联储可以通过解释加息100个基点只是为了尽快将利率提高到所需水平来消除此举所带来的冲击,就像加拿大央行在加息100个基点后所做的那样。不过,美联储在利率水平低得多的时候否认加息100个基点的事实表明,加息100个基点可能还不在计划之中。[2022/9/21 7:11:39]
解释指令=5:
?为assert指令=>opcode=4
?next_ap=ap=>ap_update=00=0
?next_pc=pc+instruction_size=>pc_update=000=0
?op0和op1没有addormul=>res_logic(res)=00=0
?存在立即数=>op1_src(op1)=001=1
?立即数地址指令地址相邻=>off_op1=1
PGA高尔夫巡回赛将支持加密支付:金色财经报道,PGA高尔夫巡回赛将首次接受加密货币支付,该赛事宣布将在7月14日至17日的Barracuda锦标赛中允许观众使用加密货币购买门票,球迷可以使用300多种加密货币支付门票,包括比特币、以太坊和狗狗币等,而本次比赛的独家VIP体验服务仅支持使用加密货币购买。(Sport Techie)[2022/6/1 3:54:18]
?等式左边=>dst_reg(dst)=1
?等式左边=>off_dst=1
?op0_reg/off_op0=>initalvalue(1/-1)//因为这个指令用不到这些flags,所以填充默认值
3.2条件和非条件跳转
jmp指令允许更改程序计数器pc的值。
Cairo支持相对跳转和绝对跳转-分别用关键字rel和abs表示;jmp指令或许是有条件的,比如当某个内存单元的值不为0时,触发jmp指令。
指令的语法如下所示:
#Unconditionaljumps.
jmpabs<adress>
jmprel<offset>
#Conditionaljumps.
jmprel<offset>if<op>!
图5给出了jmp指令的一些示例,以及每个指令对应的标志值:
解释指令jmprel+:
?为jmp指令=>opcode=0
?next_ap=ap=>ap_update=b00=0
?next_pc=pc+res=>pc_update=b010=2
?res=op0+op1=>res_logic(res)=b01=1
?op1:=>op1_src(op1)=b010=2
?op1:=>off_op1=-7
?op0:=>op0_src(op0)=0
?op0:=>off_op0=1
?dst_reg/off_dst=>initalvalue(1/-1)///因为这个指令用不到这些flags,所以填充默认值
3.3call和ret
call和ret指令允许实现函数堆栈。call指令更新程序计数器(pc)和帧指针(fp)寄存器。程序计数器的更新类似于jmp指令。之前fp的值被写入,以允许ret指令将fp的值重置为调用之前的值;类似地,返回的pc(调用指令后面指令的地址)被写到,以允许ret指令跳回并继续执行调用指令后面的代码的执行。由于写入了两个存储单元,ap向前进了2,fp被设置为新的ap。
指令的语法如下:
callret<adress>
callrel<offset>
ret
图6给出了call和ret指令的一些示例,以及每个指令对应的标志值:
解释指令callabs:
?为call指令=>opcode=0
?next_ap=ap=>ap_update=b00=0
?next_pc=res=>pc_update=b001=1
?res=op1=>res_logic(res)=b00=0
?op1:=>op1_src(op1)=b010=2
?op1:=>off_op1=4
?op0_reg/off_op0=>initalvalue(0/1)///因为这个指令用不到这些flags,所以填充默认值
?dst_reg/off_dst=>initalvalue(0/0)///因为这个指令用不到这些flags,所以填充默认值
3.4高级ap
指令ap+=<op>通过给定的操作数增加ap的值。
图7给出了高级ap指令的一些示,以及每个指令对应的标志:
解释指令ap+=123:
?为advancingap指令=>opcode=0
?next_ap=ap+res=>ap_update=b01=1
?next_pc=pc+instruction_size=>pc_update=b000=0
?res=op1=>res_logic(res)=b00=0
?op1=123=>op1_src(op1)=b001=1
?op1=123=>off_op1=1
?op0_reg/off_op0=>initalvalue(1/-1)///因为这个指令用不到这些flags,所以填充默认值
?dst_reg/off_dst=>initalvalue(1/-1)///因为这个指令用不到这些flags,所以填充默认值
关于我们
Sin7y成立于2021年,由顶尖的区块链开发者组成。我们既是项目孵化器也是区块链技术研究团队,探索EVM、Layer2、跨链、隐私计算、自主支付解决方案等最重要和最前沿的技术。
微信公众号:Sin7Y
GitHub|Twitter|Telegram|Medium|Mirror|HackMD|HackerNoon
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。