工作频率可动态调整的单片机系统设计

摘要:介绍一种采用可编程cmos频率合成器ds1077设计的单片机系统,使单片机能根据环境需要动态调整系统的工作频率,既能满足系统要求的实时处理能力,又尽可能地降低系统的耗电量及引起的电磁干扰。同时还讨论了系统改变工作频率后对rs232串行通讯的影响以及解决办法确保该系统在不同的工作频率下仍能正常进行rs232串行通信。这种单片机系统的变频设计提高了系统的适用范围和兼容性,使系统设计更加灵活。

  关键词:可编程cmos频率合成器 串行通讯 动态编程 ds1077

  在单片机系统中,总希望单片机能够工作于最大频率,以提高系统的实时处理能力。但单片机系统工作频率越高,其耗电量及引起的电磁干扰也就越大,并且单片机工作频率的选择直接影响到rs232串行通讯。特别是在51单片机系统中,rs232串行通讯的使用往往决定了系统时钟选用,这使得在设计单片机系统时的灵活性大大降低。在很多情况下,希望设计出一个工作频率可根据任务的轻得实时改变,并且能够在各种工作频率下进行rs232串行通讯的单片机系统,它既能满足单片机的实时处理要求,又有利于降低系统的耗电量和电磁干扰。采用可编程cmos频率合成器ds1077后,设计这种系统变得简单了。

  1 可编程cmos频率合成器ds1077

  1.1 ds1077的引脚及其功能

  ds1077是一个具有两种同步输出的单片机固定频率合成器。它不需要外接任何元件即可工作,允许通过二线串行接口频率合成器进行动态编程。ds1077的输出频率范围宽(8khz~133mhz),且在整个温度和电压变化范围内输出频率偏差小于1%。ds1077既可作为由控制器编程的两路同步频率合成器使用,也可以当作固定频率振荡器使用。控制器可通过编程片上的两个预标定器和一个除法器来调整两路同步输出频率。工作模式和输出频率的设定值存储于片上eeprom中。每次上电时,存储于eeprom中的值自动弹出到各个寄存器中,使ds1077工作于以前设定的初始状态。

  引脚功能:

  scl:串行时钟输入线(用于编程);

  sda:串行数据输入、输出线(用于编程);

  ctr1:控制out1输出允许或芯片掉电模式的多功能引脚;

  crt0:控制out0输出允许、芯片掉电模式或mux选择的多功能引脚;

  out1:参考频率输出引脚;

  out0:主振荡频率输出引脚。

  1.2 ds1077内部框图及工作原理

  ds1077内部框图如图1所示。主要由内部主振荡器、2个预定标器、1个可编程除法器和3个控制寄存器四大部分组成。主振荡器产生的时钟信号mclk既可直接输出到out0,也可以经过p0预定标器分频后输出out0。另外时钟信号mclk经过p1预定标器分频后要么直接输出到out1,要么再经可编程除法器n分频后输出到out1。

  主时钟信号mclk经过p0预定标器进行1、2、4或8分频后送入mux选择器。同时,主时钟信号mclk经过p1预定标器进行1、2、4或8分频后既可直接输出到out1引脚,又可输出到可编程除法器n进行2~1025之间的任一分频后送到out1引脚。

  通过对控制寄存器进行编程,可决定ds1077输出频率和工作模式。控制寄存器的值存于片内的eeprom中,因此只有改变输出频率和工作模式时才需要对ds1077重新编程。

  1.3 ds1077的控制寄存器

  ds1077的控制包括mux寄存器、div寄存器和bus寄存器共3个寄存器。mux寄存器用于设置频率合成器的工作模式,div寄存器用于设置工作频率,bus寄存器用于设置总线控制方式。它们的设置方式如下:

  mux寄存器(16位):

  • 工作频率可动态调整的单片机系统设计已关闭评论
    A+
发布日期:2019年07月02日  所属分类:参考设计