完善资料让更多小伙伴认识你,还能领取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一样的意义。 |
|
|
|
|
|
|
|
欢迎到易德电子咨询
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
使用Keil建立完整的工程,并使用外部中断0触发数码管显示903
418 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-使用AHT20进行环境监测之AHT20传感器介绍
1083 浏览 0 评论
846 浏览 0 评论
886 浏览 1 评论
基于瑞萨FPB-RA4E2智能床头灯项目——1编译环境搭建与点亮驱动ws2812全彩LED
882 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11834 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-1 03:08 , Processed in 0.586285 second(s), Total 46, Slave 37 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号