完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
最近在看十速芯片资料,碰到“SUBWF f [,d] ”这样的指令,资料中给出的例子有点迷惑
请高手释疑! 资料上这样描述的: 指令描述:寄存器‘f’ 的值减去W寄存器中的值(2的补码运算),运算结果存于目标寄存器。 举例: SUBWF REG1 , 1 执行前:REG1=3,W=2,C=?, Z=? 执行后:REG1=1,W=2,C=1, Z=0 SUBWF REG1 , 1 执行前:REG1=2,W=2,C=?, Z=? 执行后:REG1=0,W=2,C=1, Z=1 SUBWF REG1 , 1 执行前:REG1=1, W=2, C=?,Z=? 执行后:REG1=FFh,W=2,C=0,Z=0 我是这么理解的:如果REG1>=W,说明够减,执行结果存放在REG1中,如果REG1 这样理解对吗?还有那个标志位‘C’的值怎么理解?跟51的不一样,费解啊! |
|
相关推荐
3个回答
|
|
计算机的所有减法都是做加法,也就是加上补码。
SUBWF REG1 , 1 执行前:REG1=3,W=2,C=?, Z=? 执行后:REG1=1,W=2,C=1, Z=0 (解释:计算机的二进制值分别是REG1=00000011,W=11111110(这是补码), 相加后00000001,有进位,C=1,奇,Z=0) 第二个自己算,也就进位,偶。 第三个,REG1=00000001,W=11111110,相加后11111111,没有进位,C=0,偶,Z=0。 就是这样。。。。 C标志位是和51一样的意义。 |
|
|
|
|
|
|
|
欢迎到易德电子咨询
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
811 浏览 0 评论
525 浏览 0 评论
嵌入式学习-搭建自己的ubuntu系统之ubuntu网络设置
646 浏览 0 评论
龙芯中科胡伟武:3B6600 八核桌面 CPU 性能将达到英特尔中高端酷睿 12~13 代水平
710 浏览 0 评论
树莓派Pico 2发布,搭载RP2350双核RISC-V和Arm Cortex-M33微控制器!
670 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
10719 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-8-17 19:46 , Processed in 0.550173 second(s), Total 77, Slave 59 queries .
Powered by 电子发烧友网
© 2015 www.ws-dc.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号