找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2767|回复: 3
收起左侧

单片机IIC总线的验证程序及proteus仿真

[复制链接]
ID:202910 发表于 2017-5-20 17:56 | 显示全部楼层 |阅读模式
这是一个IIC总线的验证程序及proteus仿真。

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载):
key1按下.PNG key2按下.PNG 0.png

单片机源程序如下:
  1. #include<reg51.h>
  2. #include<intrins.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5. #define out P2
  6. sbit scl=P1^1;
  7. sbit sda=P1^0;
  8. sbit key1=P3^2;
  9. sbit key2=P3^3;
  10. uchar data mem[4]_at_ 0x55;
  11. uchar mem[4]={0x41,0x42,0x43,0x00};
  12. uchar data rec_mem[4]_at_ 0x60;
  13. void start(void);
  14. void stop(void);
  15. void sack(void);
  16. bit rack(void);
  17. void ackn(void);
  18. void send_byte(uchar);
  19. uchar rec_byte(void);
  20. void write(void);
  21. void read(void);
  22. void delay4us(void);

  23. void main(void)
  24. {
  25. EA=1;EX0=1;EX1=1;
  26.         while(1);
  27. }
  28. void ext0()interrupt 0
  29. { write();}
  30. void ext1()interrupt 2
  31. { read(); }
  32. void read(void)
  33. {
  34. uchar i;
  35.         bit f;
  36.         start();
  37.         send_byte(0xa0);
  38.         f=rack();
  39.         if(!f)
  40.         {
  41.          start();
  42.          send_byte(0xa0);
  43.          f=rack();
  44.          send_byte(0x00);
  45.          f=rack();
  46.                 if(!f)
  47.                 {
  48.                   start();
  49.               send_byte(0xa1);
  50.                         f=rack();
  51.                         if(!f)
  52.                         {
  53.                          for(i<0;i<3;i++)
  54.                                  {
  55.                                   rec_mem[i]=rec_byte();
  56.                                          sack();
  57.                                  }
  58.                          rec_mem[3]=rec_byte();
  59.                          ackn();
  60.                         }
  61.                 }
  62.         }
  63.         stop();out=rec_mem[3];
  64.         while(!key2);
  65. }
  66. void write(void)
  67. {
  68. uchar i;
  69.         bit f;
  70.         start();
  71.         send_byte(0xa0);
  72.         f=rack();
  73.         if(!f)
  74.         {
  75.          send_byte(0x00);
  76.          f=rack();
  77.                 if(!f)
  78.                 {
  79.                  for(i=0;i<4;i++)
  80.                         {
  81.                          send_byte(mem[3]);
  82.                                 f=rack();
  83.                                 if(f)break;
  84.                         }
  85.                 }
  86.         }
  87.         stop();out=0xc3;while(!key1);
  88. }
  89. void start(void)
  90. {
  91. scl=1;sda=1;delay4us();
  92. sda=0;delay4us();scl=0;
  93. }
  94. void stop(void)
  95. {
  96. scl=0;sda=0;delay4us();
  97. scl=1;delay4us();sda=1;
  98.         delay4us();_nop_();sda=0;
  99. }
  100. bit rack(void)
  101. {
  102. bit flag;scl=1;delay4us();
  103.         flag=sda;scl=0;return(flag);
  104. }
  105. void sack(void)
  106. {
  107. sda=0;delay4us();scl=1;delay4us();
  108. scl=0;delay4us();sda=1;delay4us();
  109. }
  110. void ackn(void)
  111. {
  112. sda=1;delay4us();scl=1;delay4us();
  113. scl=0;delay4us();sda=0;
  114. }
  115. uchar rec_byte(void)
  116. {
  117. uchar i,temp;
  118. for(i=0;i<8;i++)
  119.         {
  120.          temp<<=1;scl=1;delay4us();
  121.          temp|=sda;scl=0;delay4us();
  122.         }
  123.         return(temp);
  124. ……………………

  125. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
IIC.rar (59.38 KB, 下载次数: 52)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:218503 发表于 2017-7-10 14:37 | 显示全部楼层
好赞!
回复

使用道具 举报

ID:218503 发表于 2017-7-10 14:51 | 显示全部楼层
谢谢楼主
回复

使用道具 举报

ID:260548 发表于 2017-12-12 13:32 | 显示全部楼层
Mark一个
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表