打印

实际测量的指令周期和手册上写的不符

[复制链接]
556|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
heweibig|  楼主 | 2015-2-26 22:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
原本想优化一下模拟IIC通讯的时序,使原有延时尽量缩短,但后来发现实际测量的指令周期和手册上写的不符,不知为什么~望高手指点。

我用的芯片型号是MSP430F5438 测试代码如下:
#include <msp430.h>
main()
{
  WDTCTL = WDTPW + WDTHOLD;   
  UCSCTL3 = 0;                              
  UCSCTL0 |= 16 << 8;                     
  UCSCTL1 = DCORSEL_4;                  
  UCSCTL2 = 149;                             
  UCSCTL6 &= ~(XT1DRIVE_3);         
  UCSCTL4 = SELA_0 + SELS_3 + SELM_3;              
                                            
P6DIR = 0xFF;
P6OUT = 0xFF;
P6OUT = 0x00;
P6OUT = 0xFF;
P6OUT = 0x00;

while(1);
}
外部接32768Hz晶振,经过150倍频后,MCLK约为4.9MHz,此时一个指令周期约203ns。
P6OUT = 0xFF;和 P6OUT = 0x00;两句的汇编代码是
mov.b #0xFF, &PCOUT_H 和 clr.b &PCOUT_H
根据手册执行这两句的时间我认为应该是4+4 = 8个时钟周期(约1600ns)。
而示波器上观察输出方波的周期为700ns而我觉得该时间和执行P6OUT = 0xFF; P6OUT = 0x00;两句的时间应该是相同的。

求指点:我的测试哪里出问题了呢~?

相关帖子

沙发
午夜粪车| | 2015-2-26 22:31 | 只看该作者
你的while(1)循环在这里是延时作用    我感觉应该是延时时间不足    或者哪边出现误差

使用特权

评论回复
板凳
heweibig|  楼主 | 2015-2-26 22:33 | 只看该作者
哦,那我看下

使用特权

评论回复
地板
dirtwillfly| | 2015-2-27 08:07 | 只看该作者
时钟配置和手册里的是否一致啊?

使用特权

评论回复
5
mintspring| | 2015-2-27 15:47 | 只看该作者
楼主不要纠结这个,能用就好,我觉得,肯定是你计算有误,或者那个指令换算不对。

使用特权

评论回复
6
cowboy2014| | 2015-2-28 07:50 | 只看该作者
有怀疑精神挺好,但估计是你测试方法不恰当

使用特权

评论回复
7
gaoyang9992006| | 2015-2-28 20:22 | 只看该作者
以测量为准

使用特权

评论回复
8
598330983| | 2015-2-28 20:24 | 只看该作者
肯定测量为准

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

869

主题

13089

帖子

7

粉丝