搜索
bottom↓
回复: 6

弱问:PIC16的指令周期?

[复制链接]

出0入0汤圆

发表于 2015-8-17 14:59:04 | 显示全部楼层 |阅读模式
例如        :
0x47: MOVLP 0x1
0x48: CALL 0x1B1
0x49: MOVLP 0x0

其中"0x49: MOVLP 0x0"
执行这么一步需要多少个时钟上升沿?

入门级都算不上的问题,让大家见笑了.

出0入0汤圆

发表于 2015-8-17 15:01:33 | 显示全部楼层
你里面一个CALL 都不知道运行多长程序了。

出0入0汤圆

 楼主| 发表于 2015-8-17 15:17:52 | 显示全部楼层
waterghost 发表于 2015-8-17 15:01
你里面一个CALL 都不知道运行多长程序了。

明白了,就是说这些指令执行是不固定的,要具体情况具体分析,对吧?

出0入0汤圆

发表于 2015-8-17 15:44:11 | 显示全部楼层
JYX2015 发表于 2015-8-17 15:17
明白了,就是说这些指令执行是不固定的,要具体情况具体分析,对吧?

>> 这些指令执行是不固定的,

绝对不是。

楼主先要分清时钟周期及指令周期。

在PIC16,一个指令周期要占用四个时钟周期,而AVR则一个指令周期等同一个时钟周期。

对PIC16而言,除了跳转指令要用二个指令周期外,其它的都是单指令周期。

例:Call + Return = 4 指令周期(即16个时钟周期);
      MOVWF,MOVF、、、等都是单指令周期(即4个时钟周期)

出0入0汤圆

 楼主| 发表于 2015-8-17 15:47:17 | 显示全部楼层
alias 发表于 2015-8-17 15:44
>> 这些指令执行是不固定的,

绝对不是。

对不起,我表述错误,我想说的是不同的指令占用时钟周期是不同的。

现在看来也不完全是这样。PIC的大部分指令都占用4个时钟周期,也就是说执行大部分指令,
需要4个外部晶振的上升沿(虽然是正弦波),但也有个别的指令并非如此。

不知道我的理解是否有误,请进一步指点。

出0入0汤圆

发表于 2015-8-17 15:56:26 | 显示全部楼层
个别 测试/跳转 指令像BTFSS, BTFSC, INCFSZ及DECFSZ,不跳转时需要4个外部晶振的上升沿,但跳转却需要8个晶振的上升沿。

出0入0汤圆

 楼主| 发表于 2015-8-17 17:34:03 | 显示全部楼层
alias 发表于 2015-8-17 15:56
个别 测试/跳转 指令像BTFSS, BTFSC, INCFSZ及DECFSZ,不跳转时需要4个外部晶振的上升沿,但跳转却需要8个 ...

非常感谢你详尽的回答
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-29 11:39

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表