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

[复制链接]
796|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 | 显示全部楼层
时钟配置和手册里的是否一致啊?
mintspring 发表于 2015-2-27 15:47 | 显示全部楼层
楼主不要纠结这个,能用就好,我觉得,肯定是你计算有误,或者那个指令换算不对。
cowboy2014 发表于 2015-2-28 07:50 | 显示全部楼层
有怀疑精神挺好,但估计是你测试方法不恰当
gaoyang9992006 发表于 2015-2-28 20:22 来自手机 | 显示全部楼层
以测量为准
598330983 发表于 2015-2-28 20:24 来自手机 | 显示全部楼层
肯定测量为准
您需要登录后才可以回帖 登录 | 注册

本版积分规则

869

主题

13089

帖子

7

粉丝
快速回复 在线客服 返回列表 返回顶部