1.指令结构
CairoCPU原生支持的word是一个域元素,而这个域是特征值大于P?>2^63。每个指令会占用1到2个word,如果指令后面跟着立即值(="12345678")则该指令占用2个word,并且值存在第二个word里。每个指令的第一个word由以下元素组成:
2.状态转换
状态转换函数代表了一个通用的状态转换单元,而一个计算通常会分解成多个连续执行的指令,因此我们需要:
a.?确保指令的内容,以及指令执行前后的状态的有效性
b.确保执行的指令是一个有效的指令
2.1转换逻辑
如果指令执行前后的状态是一致的,那么其状态的更新一定是按照以下逻辑执行:
Beosin:jimbos protocol 项目疑似遭受攻击,累计损失约750万美元:金色财经报道,据区块链安全审计公司Beosin旗下Beosin?EagleEye安全风险监控、预警与阻断平台监测显示,2023年5月28日,jimbos protocol项目疑似遭受攻击,目前被盗资金已经通过跨链协议转移到以太坊上的0x5f3开头的地址,到目前该笔资金仍存放在该地址上。[2023/5/28 9:46:42]
2.2指令校验
如图1所示,?个指令由以下元素组成:
Algorand基金会任命Harpal Singh为首席财务官:10月13日消息,Algorand基金会任命Harpal Singh为首席财务官,Singh将监督Algorand基金会的财务事务,并与高级管理层密切合作,以确保有效实施业务战略,鼓励整个Algorand生态系统的发展,以解决现实世界的问题。(PR News Wire)[2022/10/13 14:26:37]
3.指令示例
3.1断言相等
断言相等指令可以用下述语法表示:
<left_handle_op>=<right_handle_op>
它确保了公式两边是相等的,否则程序的执行将会被返回。
Note2:除法和减法可以分别表示为具有不同操作数顺序的乘法和加法。?
assert指令可以被认为是一条赋值指令,其中?边是已知的,另一边是未知的。例如=4可以被认为是断言的??值为4,或者根据上下文将赋值为4。
图4给出了断言相等指令的一些示例,以及每个指令对应的标志值:
法国食品零售商Groupe Casino推出欧元稳定币:金色财经报道,法国一家主要的食品零售商Groupe Casino推出了由Tezos区块链支持的欧元稳定币“Lugh”,将用于店内付款。该稳定币未来会由零售商组成的联盟用于店内支付和忠诚度积分。该稳定币的储备已经由普华永道法国子公司审计。此外,该稳定币将首先在法国加密货币交易所Coinhouse上市。[2021/3/18 18:54:44]
解释?指令=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?
?等式左边=>dst_reg(dst)=1?
?等式左边=>off_dst=1?
?op0_reg/off_op0=>initalvalue(1/-1)//因为这个指令用不到这些flags,所以填充默认值
声音 | Fox Business主持人:华尔街可能最终也会和千禧一代一样喜欢加密货币:随着比特币今年飙升逾50%,主流媒体纷纷改变对比特币的态度。Fox Business主持人Charles Payne最近认为,华尔街的大佬们,而不仅仅是精通科技的千禧一代,最终将有可能会喜欢加密货币。他表示,“千禧一代喜欢加密货币,而且我怀疑有一天华尔街也会喜欢。” 年轻人在投资选择上往往比老一辈人聪明得多。他比较了Bed Bath & Beyond和Shopify的股票。美国零售巨头Bed Bath & Beyond的股价在过去三年里遭受重创(跌幅超过70%),但其加拿大电商竞争对手Shopify的股价却上涨近900%。冒险投资者也将大笔资金押在特斯拉身上,特斯拉在1月份再次成为华尔街做空最多的股票。根据Bankrate的一项调查,千禧一代购买BTC的可能性是X世代的三倍。与此同时,持有约68万亿美元的婴儿潮一代被认为是最不喜欢加密货币的人群。早在去年12月,灰度投资董事总经理Michael Sonnenshein就认为,在未来25年的代际财富转移中,比特币可能是最大的赢家。(U.Today)[2020/2/13]
3.2条件和非条件跳转?
jmp指令允许更改程序计数器pc的值。?
Cairo支持相对跳转和绝对跳转-分别用关键字rel和abs表示;jmp指令或许是有条件的,比如当某个内存单元的值不为0时,触发jmp指令。
动态 | Alive Play Casino将提供区块链VR在线体验:9月12日消息,一家名为Alive Casino的公司将为玩家提供使用VR技术进行的区块链平台。[2018/9/12]
指令的语法如下所示:?
#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,所以填充默认值
参考
SpecificationforCairo:https://arxiv.org/pdf/2109.14534.pdf
关于我们
Sin7y成立于2021年,由顶尖的区块链开发者和密码学工程师组成。我们既是项目孵化器也是区块链技术研究团队,探索EVM、Layer2、跨链、隐私计算、自主支付解决方案等最重要和最前沿的技术。
微信公众号:Sin7y
GitHub:Sin7y
Twitter:@Sin7y_Labs
Medium:Sin7y
Mirror:Sin7y
HackMD:Sin7y
HackerNoon:Sin7y
Email:contact@sin7y.org
来源:金色财经
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。