专注电子技术学习与研究
当前位置:单片机教程网 >> MCU设计实例 >> 浏览文章

msp430驱动74hc595(程序+电路)I2C串行通信

作者:未知   来源:不详   点击数:  更新时间:2014年08月31日   【字体:
#include "msp430G2553.h"
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
          0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
//毫秒延迟函数
void delay(int ms)
{
  int i;
  while(ms--)
   for(i=0;i<120;i++);
}
//纳米延迟函数
void delayns(int ns)
{
  while(ns--);
}
void display(temp)//现实位置P2.0=SH;P2.1=ST;P2,2=DS
{
  int k,temp1,temp2;
   for(k=7;k>=0;k--)
     {
       temp1=1<<k;
       temp2=temp & temp1;
       if(temp2==temp1)
           {
             P2OUT |=BIT2;
           } 
       else 
           {
             P2OUT &=~BIT2;
           }
       P2OUT &=~BIT0;
       delayns(10);
       P2OUT |=BIT0;
     }
   P2OUT &=~BIT1;
   delayns(10);
   P2OUT |=BIT1;   
}
int main( void )
{
  // Stop watchdog timer to prevent time out reset
  WDTCTL = WDTPW + WDTHOLD;
  P2DIR |=0x07;
  int m,time,temp;
    while(1)
     {
       m=P1IN;
       //显示
       temp=tab[(2*m)%10];//个位
       display(temp);
       temp=tab[(2*m)/10];//十位
       display(temp);
       //脉宽
       if(m<=9) time +=10;
       if(m>15) time -=30;  
       P2OUT |=BIT3;
       delay(time);
       P2OUT &=~BIT3;
       delay(20);  
     }
  

#include"reg51.h"
 
sbit DS_595= P1^0;
 
sbit CT_595= P1^1;
 
sbit CH_595= P1^2;
 
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
 
          0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
 
int temp;
 
void delay(int ms)
 
{
 
  int i;
 
  while(ms--)
 
   for(i=0;i<120;i++);
 
}
 
 
void delayns(int ns)
 
{
 
  
  while(ns--);
 
 
}
 
 
void WR_595(void)
 
{
 
  int k,temp1,temp2;
 
   for(k=7;k>=0;k--)
 
     {
 
       temp1=1<<k;
 
       temp2=temp & temp1;
 
       if(temp2==temp1)
 
           {
 
             DS_595=1;
 
           } 
 
       else 
 
           {
 
             DS_595=0;
 
           }
 
       CH_595=0;
 
       delayns(10);
 
       CH_595=1;
 
     }    
 
}
 
void main()
 
 
         int m;
    for(m=0;m<10000;m++)
 
      {
 
         temp=tab[m/1000];
 
WR_595();
 
CT_595=0;
 
delayns(10);
 
CT_595=1;
 
 
         temp=tab[(m%1000)/100];
 
WR_595();
 
CT_595=0;
 
delayns(10);
 
CT_595=1;
 
         temp=tab[((m%1000)%100)/10];
 
WR_595();
 
CT_595=0;
 
delayns(10);
 
CT_595=1;
 
        temp=tab[((m%1000)%100)%10];
 
WR_595();
 
CT_595=0;
 
delayns(10);
 
CT_595=1;
        
         delay(200);
 
     }
 



串行通信时钟程序
#include"reg51.h"

sbit DS_595= P1^0;

sbit CT_595= P1^1;

sbit CH_595= P1^2;

sbit POT  =P1^3;

int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,

          0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};

int temp;

void delay(int ms)

{

  int i;

  while(ms--)

   for(i=0;i<120;i++);

}


void delayns(int ns)

{

  
  while(ns--);


}


void WR_595(void)

{

  int k,temp1,temp2;

   for(k=7;k>=0;k--)

     {

       temp1=1<<k;

       temp2=temp & temp1;

       if(temp2==temp1)

           {

             DS_595=1;

           } 

       else 

           {

             DS_595=0;

           }

       CH_595=0;

       delayns(10);

       CH_595=1;

     }    

}

void main()


    int hour,min,sec;
    while(1)
   
      {
         sec++;
         if(sec==60)
           {
             sec=0;
             min++;
           
            if(min==60)
               {
                min=0;hour++;                        
                if(hour==24)hour=0;
                
               }
            }
        
         temp=tab[hour/10];
 
         WR_595();
 
         CT_595=0;
 
         delayns(2);
 
         CT_595=1;


         temp=tab[hour%10];//245959
 
           WR_595();
 
           CT_595=0;
 
           delayns(2);
 
           CT_595=1;         
        

         temp=tab[min/10];//5900
 
        WR_595();
 
        CT_595=0;
 
        delayns(2);
 
        CT_595=1;


         temp=tab[min%10];
 
         WR_595();
 
         CT_595=0;
 
         delayns(2);
 
         CT_595=1;

         temp=tab[sec/10];
         
 
         WR_595();
 
         CT_595=0;
 
         delayns(2);
 
         CT_595=1;
 
        temp=tab[sec%10];
       
         WR_595();
 
         CT_595=0;
 
         delayns(2);
 
         CT_595=1;
        
         delay(300);
         POT=~POT;
         delay(300);
          POT=~POT;
     }
 
74HC595芯片是一种串入并出的芯片,在电子显示屏制作当中有广泛的应用
74HC595是8位串行输入/输出或者并行输出移位寄存器,具有高阻、关、断状态。
三态。特点 8位串行输入 8位串行或并行输出 存储状态寄存器,三种状态 输出寄存器可以直接清除 100MHz的移位频率 输出能力 并行输出,总线驱动 串行输出;
标准 中等规模集成电路应用 串行到并行的数据转换 Remote control holding register. 描述 595是告诉的硅结构的CMOS器件, 兼容低电压TTL电路,遵守JEDEC标准。
 595是具有8位移位寄存器和一个存储器,三态输出功能。 移位寄存器和存储器是分别的时钟。数据在SCHcp的上升沿输入,在STcp的上升沿进入的存储寄存器中去。如果两个时钟连在一起,则移位寄存器总是比存储寄存器早一个脉冲。 移位寄存器有一个串行移位输入(Ds),和一个串行输出(Q7’),和一个异步的低电平复位,存储寄存器有一个并行8位的,具备三态的总线输出,当使能OE时(为低电平),存储寄存器的数据输出到总线。
 CPD决定动态的能耗, PD=CPD×VCC×f1+∑(CL×VCC2×f0) F1=输入频率,CL=输出电容 f0=输出频率(MHz) Vcc=电源电压 引脚说明符号引脚描述
内部结构
结合引脚说明就能很快理解 595的工作情况
74HC595引脚图,管脚图
     ______________________
QB--|1                   16|--Vcc
QC--|2                   15|--QA
QD--|3                   14|--SI(DS)
QE--|4                   13|--/G(/OE)
QF--|5                   12|--RCK(ST_CP)
QG--|6                   11|--SRCK(SH_CP)
QH--|7                   10|--/SRCLR(/MR)
GND- |8                   9|--QH'
    ________________________
74595的数据端:
QA--QH: 八位并行输出端,可以直接控制数码管的8个段。
QH': 级联输出端。我将它接下一个595的SI端。
SI: 串行数据输入端。
74595的控制端说明:
/SRCLR(10脚): 低点平时将移位寄存器的数据清零。通常我将它接Vcc。
SRCK(11脚):上升沿时数据寄存器的数据移位。QA-->QB-->QC-->...-->QH;下降沿移位寄存器数据不变。(脉冲宽度:5V时,大于几十纳秒就行了。我通常都选微秒级)
RCK(12脚):上升沿时移位寄存器的数据进入数据存储寄存器,下降沿时存储寄存器数据不变。(通常我将RCK置为低电平,) 当移位结束后,在RCK端产生一个正脉冲(5V时,大于几十纳秒就行了。我通常都选微秒级),更新显示数据。
/G(13脚): 高电平时禁止输出(高阻态)。如果单片机的引脚不紧张,用一个引脚控制它,可以方便地产生闪烁和熄灭效果。比通过数据端移位控制要省时省力。
注:
1)74164和74595功能相仿,都是8位串行输入转并行输出移位寄存器。74164的驱动电流(25mA)比74595(35mA)的要小,14脚封装,体积也小一些。
2)74595的主要优点是具有数据存储寄存器,在移位的过程中,输出端的数据可以保持不变。这在串行速度慢的场合很有用处,数码管没有闪烁感。
与164只有数据清零端相比,595还多有输出端时能/禁止控制端,可以使输出为高阻态。
3)595是串入并出带有锁存功能移位寄存器,它的使用方法很简单,在正常使用时SCLR为高电平, G为低电平。从SER每输入一位数据,串行输595是串入并出带有锁存功能移位寄存器,它的使用方法很简单,如下面的真值表,在正常使用时SCLR为高电平, G为低电平。从SER每输入一位数据,串行输入时钟SCK上升沿有效一次,直到八位数据输入完毕,输出时钟上升沿有效一次,此时,输入的数据就被送到了输出端。入时钟SCK上升沿有效一次,直到八位数据输入完毕,输出时钟上升沿有效一次,此时,输入的数据就被送到了输出端。
    其实,看了这么多595的资料,觉得没什么难的,关键是看懂其时序图,说到底,就是下面三步(引用):
   第一步:目的:将要准备输入的位数据移入74HC595数据输入端上。
           方法:送位数据到 P1.0。
   第二步:目的:将位数据逐位移入74HC595,即数据串入
           方法:P1.2产生一上升沿,将P1.0上的数据移入74HC595中.从低到高。
   第三步:目的:并行输出数据。即数据并出
           方法:P1.1产生一上升沿,将由P1.0上已移入数据寄存器中的数据
                 送入到输出锁存器。
    说明: 从上可分析:从P1.2产生一上升沿(移入数据)和P1.1产生一上升沿
          (输出数据)是二个独立过程,实际应用时互不干扰。即可输出数据的
           同时移入数据。
   而具体编程方法为
      如:R0中存放3FH,LED数码管显示“0”
      ;*****接口定义:
      DS_595 EQU P1.0      ;串行数据输入(595-14)
      CH_595 EQU P1.2      ;移位时钟脉冲(595-11)
      CT_595 EQU P1.1      ;输出锁存器控制脉冲(595-12)
     ;*****将移位寄存器内的数据锁存到输出寄存器并显示
OUT_595:
      CALL WR_595          ;调用移位寄存器接收一个字节数据子程序 
      CLR CT_595           ;拉低锁存器控制脉冲
      NOP
      NOP
      SETB CT_595          ;上升沿将数据送到输出锁存器,LED数码管显示“0”
      NOP
      NOP
      CLR CT_595
      RET
      ;*****移位寄存器接收一个字节(如3FH)数据子程序   
WR_595: 
      MOV R4,#08H               ;一个字节数据(8位)      
      MOV A,R0                  ;R0中存放要送入的数据3FH       
LOOP: 
      ;第一步:准备移入74HC595数据
      RLC A                     ;数据移位
      MOV DS_595,C              ;送数据到串行数据输入端上(P1.0)
      ;第二步:产生一上升沿将数据移入74HC595
      CLR CH_595                ;拉低移位时钟 
      NOP                       
      NOP
      setb CH_595                ;上升沿发生移位(移入一数据)
      DJNZ R4,LOOP              ;一个字节数据没移完继续
      RET
   而其级联的应用
         74HC595主要应用于点阵屏,以16*16点阵为例:传送一行共二个字节(16位)
     如:发送的是06H和3FH。其方法是:
     1.先送数据3FH,后送06H。
     2.通过级联串行输入后,3FH在IC2内,06H在IC1内。应用如图二 
     3.接着送锁存时钟,数据被锁存并出现在IC1和IC2的并行输出口上显示。                                                       

     编程方法:
     数据在30H和31H中
     ;MOV 30H,#3FH
     ;MOV 31H,#06H
      ;*****接口定义:
      DS_595 EQU P1.0      ;串行数据输入(595-14)
      CH_595 EQU P1.2      ;移位时钟脉冲(595-11)
      CT_595 EQU P1.1      ;输出锁存器控制脉冲(595-12)
      ;*****串行输入16位数据
      MOV R0,30H
      CALL WR_595          ;串行输入3FH
      nop
      NOP 
      MOV R0,31H
      CALL WR_595          ;串行输入06H
      NOP
      NOP
      SETB CT_595          ;上升沿将数据送到输出锁存器,显示
      NOP
      NOP
      CLR CT_595
      RET
MC74HC595A包括一个8位移位寄存器和一个8D型锁存器和三态并行输出。移位寄存器接受串行数据并提供串行输出。移位寄存器也提供并行数据输出和8位锁存器。移位寄存器和锁存器都有独立的时钟输入。这个IC还具有异步复位的功能。
HC595A可以直接和CMOS MPU的和MCUSPI接口进行连接。
 
#include"reg51.h"
sbit DS_595= P1^0;
sbit CT_595= P1^1;
sbit CH_595= P1^2;
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
          0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
void delay(int ms)
{
  int i;
  while(ms--)
   for(i=0;i<120;i++);
}
void WR_595(void)
{
  int k,temp1,temp2;
   for(k=7;k>=0;k--)
     {
       temp1=1<<k;
       temp2=temp & temp1;
       if(temp2==temp1)
           {
             DS_595=1;
           } 
       else 
           {
             DS_595=0;
           }
       CH_595=0;
       delay(2);
       CH_595=1;
     }    
}
void main()
  int m;
  for(m=0;m<16;m++)
    {
      temp=tab[m];
 WR_595();
 CT_595=0;
 delay(2);
 CT_595=1;
 delay(2);
 CT_595=0;
      delay(500);
    } 

 
#include"reg51.h"
sbit DS_595= P1^0;
sbit CT_595= P1^1;
sbit CH_595= P1^2;
sbit AA=P1^3;
sbit BB=P1^4;
 
int yu[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
          0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp,court,gg,ss,m,n,j;
void delay(int ms)
{
  int i;
  while(ms--)
   for(i=0;i<120;i++);
}
 
void WR_595(void)
{
  int k,temp1,temp2;  
   for(k=7;k>=0;k--)
     {
       temp1=1<<k;
       temp2=temp & temp1;
       if(temp2==temp1)
           {
             DS_595=1;
           } 
       else 
           {
             DS_595=0;
           }
       CH_595=0;
       delay(2);
       CH_595=1;
     }     
}
 
void display(m)
{
 
      temp=yu[m];
 WR_595();
 CT_595=0;
 delay(1);
 CT_595=1;
      delay(1); 
}
 
void main()
 for(m=0;m<1000;m++)
  {
   n=m/1000;
   BB=1;AA=1;
   P2=0x80;   
   display(n);   
 
   n=(m%1000)/100;
   BB=1;AA=0;   P2=0x40;
   display(n);
 
   n=((m%1000)%100)/10;
   BB=0;AA=1; P2=0x20;
   display(n);
  
   n=m%10;
   AA=0;BB=0; P2=0x01;
   display(n);
  
 
   delay(600);
  } 
}  
关闭窗口