原创 看门狗

2008-4-17 19:43 1898 1 1 分类: MCU/ 嵌入式

看门狗X504电路应用




X5045是一种集看门狗、电压监控和串行EEPROM 三种功能于一身的可编程控制电路.特别适合应用在需要少量存储器,并对电路板空间需求较高场合,<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


X5045具有电压监控功能,可以保护系统免受低电压的影响,当电源电压降到允许范围(4.2V)以下时,系统将复位,直到电源电压返回到稳定值为止。X5045的存储器与CPU 通过串行通信方式接口(SPI),可以存放512个字节数据.可擦写100万次,数据可保存100.


下图是X5045与具有手动复位的8051微控制器的连接



下边是51读写x5045存储器的程序


//x504551的连接方法
sbit CS = P1^0;
sbit SO = P1^3;
sbit SI = P1^1;
sbit SCK = P1^2;
//
定义寄存器指令
#define WREN 0x06 //
写入使能指令(WREN)
#define WRDI 0x04 //
写入禁止指令(WRDI)
#define WRSR 0x01 //
写入状态寄存器指令(WRSR)
#define RDSR 0x05 //
读取状态寄存器指令(RDSR)
#define WRITE 0x02 //
写入存储器指令(WRITE)
#define READ 0x03 //
读取存储器指令(READ)
                      
#define STATUS_REG 0x00 //
要写入到状态寄存器的值
#define MAX_POLL 0x99 //
最在查询次数m number of



void outbyte(unsigned char write_data)
{
     unsigned char i;
      for(i = 0; i < 8; i++)
      {
      SCK = 0;
      SI = (bit)(write_data & 0x80); //
传送一个位到SI
      write_data <<= 1;
     SCK = 1;
      }
      SI = 0;
}
unsigned char inbyte()
{
      unsigned char i;
      unsigned char read_data=0;


for(i = 0; i < 8; i++)
      {
         SCK = 0;
         read_data <<= 1;
         SCK = 1;
         read_data |= (unsigned char)SO;
      }
      return read_data;
}


void wren_cmd()
{

      CS = 0;          
      outbyt(WREN); //
传送写入使能指令
      CS = 1;
}            


void wrdi_cmd()
{
     CS = 0;          
     outbyt(WRDI); //
传送写入禁止指令
     CS = 1;
}


unsigned char rdsr_cmd()
{
       unsigned char status;
       CS = 0;   
       outbyt(RDSR); //
传送状态寄存器读取指令
       status = inbyt(); //
读取状态寄存
       CS = 1;
       return status;
}
void wip_poll()
{
   unsigned char i; //
设置最大的查询次数


//// 如果WIP位为'1'并且未达到最大查询次数, 则继续查询
////
如果WIP位为'0', 则写入周期完成, 返回
   for(i = 0; i < MAX_POLL; i++)
   {
      if(rdsr_cmd() & 0x01) //
读取状态寄存器
      {
        continue;
      }
      return;
    }
}


void wrsr_cmd()
{
      CS = 0;
      outbyt(WRSR); //
传送状态寄存器写入指令
      outbyt(STATUS_REG); //
传送要写入的数据
      CS = 1;
     wip_poll(); //
检测写入进度
}


void byte_write(unsigned int addr,unsigned char dat)
{
      wren_cmd();
     CS = 0;
      if(addr & 0x100)
          outbyt(WRITE | 0x08); //
传送写入指令和地址最高位"1"
      else
           outbyt(WRITE); //
传送写入指令和地址最高位"0"
     outbyt(addr); //
传送地址低字节     
      outbyt(dat); //
传送数据字节  


CS = 1;
       wip_poll(); //
检测写入进度
}
unsigned char byte_read(unsigned int addr)
{
       unsigned char read_data;
        CS = 0;  
       if(addr & 0x100)
            outbyt(READ | 0x08);//
传送读取指令和地址最高位"1"
        else    
          outbyt(READ); //
传送读取指令和地址最高位"0"
       


outbyt(addr); // 传送地址低字节


read_data = inbyt(); // 读取字节
       CS = 1;
        return read_data;
}
void rst_wdog()
{
    CS = 0;
    _nop_();_nop_();
    CS = 1;
}
void init_serialcomm(void)
{   TMOD = 0x21;   //
定时器1工作于8位自动重载模式, 用于产生波特率
          //
定时器0工作于16位模式, 用于定时


TH1 = 0xFD;    // 波特率9600
      TL1 = 0xFD;
       SCON = 0x50;   //
设定串行口工作方式
       PCON &= 0xef;   //
波特率不倍增
       TR1 = 1;    //
启动定时器1
}
void send_char_com(unsigned char ch)
{ //
向串口发送一个字符
   SBUF="ch";
   while(!TI);
   TI="0";
}


void main(void)
{
         unsigned char Temp,tdat;                  


init_serialcomm();
       while(1)
      {
           //
这里演示读出和写入 EEPROM   


   for (Temp=0; Temp<250; Temp++)   byte_write(Temp,Temp);
         delay(200);


   for (Temp=0; Temp<250; Temp++)


{ tdat= byte_read(Temp); send_char_com(tdat);}


 

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
我要评论
0
1
关闭 站长推荐上一条 /4 下一条