久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4872|回復: 0
打印 上一主題 下一主題
收起左側

2440 I2C存儲卡讀寫實驗 AT24c08a

[復制鏈接]
跳轉到指定樓層
樓主

本實驗為IIC總線通信協議,以友善之臂mini2440為實驗平臺,對其開發板上的AT24c08a指定位置寫入字符串“hello”,并指定位置讀出該位置的內容。

    初始工作,首先需要配置GPE14、15管腳分別為IICSLC、IICSDA,并禁止上拉功能。然后設置IIC時鐘頻率,使能應答信號,并使IIC中斷使能,禁止IIC中斷屏蔽寄存器。

應答中斷處理函數為清除中斷標志位,清除中斷標記flag。

    指定內存寫函數的實現為:首先設置主設備發送模式,寫入從設備地址,清除中斷標記,然后等待應答,寫入設備內存地址,等待到應答后開始連續發送數據,存入指定空間。發送結束發出停止命令,結束本次通訊,讓IIC狀態改為開始狀態,準備下一次讀寫操作。

    指定內存讀函數,首先配置設備為發送模式,寫入要讀的設備地址,寫入要讀的設備內存,設置為主機接收模式,發送接收設備地址,此后從設備會返回一個要讀的內存地址,讀取該地址拋棄后,連續讀取指定內存數據,讀到最后一個數據不再產生應答,停止接收,改為準備狀態。

    AT24C08 的地址格式為: 1 0 1 0 A2 P1 P0 W/R

    A2為設備地址位、P1,P0為片內頁尋址  LSB=0 寫    LSB=1 讀

其中mini2440讀寫位為自動標記無需配置。



  1. /*51實驗24: I2C存儲卡讀寫實驗*/

  2. #include <reg51.h>
  3. #include <ABSACC.H>
  4. #define cp8155 XBYTE[0xff20]
  5. #define pa8155 XBYTE[0xff21]
  6. #define pb8155 XBYTE[0xff22]
  7. #define pc8155 XBYTE[0xff23]
  8. #define dataadr 0x4000


  9. //*********************************************
  10. //MON51必須用到的
  11. code unsigned char stop[3] _at_ 0x3b;

  12. unsigned char code DISPB[]={0x0C0,0x0F9,0x0A4,0x0B0,0x99,0x92,0x82,0x0F8,0x80,0x90,
  13.                             0x088,0x83,0x0C6,0x0A1,0x86,0x8E,0xFF,0x0C,0xDE,0x0F3,0x08F};
  14. unsigned char ledbuf[6];
  15. sbit SCL=P3^0;
  16. sbit SDA=P3^1;
  17. sbit INS=P1^0;
  18. sbit WRS=P1^1;
  19. sbit RDS=P1^2;
  20. bit ack;                             //是否應答
  21. void disp(void);
  22. void delay(unsigned char dl);
  23. void Start_I2c(void);
  24. void Stop_I2c(void);
  25. void SendByte(unsigned char c);
  26. unsigned char  RcvByte();
  27. bit ISendByte(unsigned char sla,unsigned char c);
  28. bit IRcvByte(unsigned char sla,unsigned char *c);

  29. void main(void)
  30. {
  31.     unsigned char tmp1,tmp2;
  32.     bit wrok,wrst;                  //讀寫正常,讀寫狀態
  33.     //SP=0x60;
  34.         SP=0x53;
  35.     tmp2=0x50;
  36.     wrok=1;  wrst=0;
  37.         cp8155=0x43;
  38.     while(1)
  39.     {
  40.        while(INS);
  41.        delay(1);
  42.        if (INS==0) break;
  43.     }
  44.     while(1)
  45.     {
  46.        if (wrst==0)
  47.        {//寫數據到卡
  48.           for (tmp1=0;tmp1<0x80;tmp1++)
  49.           {
  50.              WRS=!WRS;
  51.              if (ISendByte(tmp1,tmp2)==0) {wrok=0; break;}
  52.              tmp2++;
  53.           }
  54.           Stop_I2c();
  55.        }
  56.        else
  57.        {//從卡讀數據
  58.           for (tmp1=0;tmp1<0x80;tmp1++)
  59.           {
  60.              RDS=!RDS;
  61.              if (IRcvByte(tmp1,&tmp2)==0) {wrok=0; break;}
  62.              XBYTE[dataadr+tmp1]=tmp2;               //讀取數據
  63.           }
  64.           Stop_I2c();
  65.        }
  66.        if (wrok==0)
  67.        {//讀寫錯誤
  68.           ledbuf[0]=0x01;  ledbuf[1]=0x0c;  ledbuf[2]=0x10;
  69.           ledbuf[3]=0x0E;  ledbuf[4]=0x14;  ledbuf[5]=0x14;//IC-ERR
  70.           while(1) disp();
  71.        }
  72.        if (wrst==0) wrst=1; //向卡寫數據完成后,讀取數據
  73.        else
  74.        {//IC卡讀寫正確
  75.           ledbuf[0]=0x01;  ledbuf[1]=0x0c;  ledbuf[2]=0x09;
  76.           ledbuf[3]=0x00;  ledbuf[4]=0x00;  ledbuf[5]=0x0d;//ICgood
  77.           while(1) disp();
  78.        }
  79.     }
  80. }

  81. void disp(void)
  82. {
  83.     unsigned char i;
  84.     unsigned int ledwz=0x20;
  85.     for (i=0;i<6;i++)
  86.     {
  87.        pb8155=DISPB[ledbuf[i]];
  88.        pa8155=~(ledwz>>i);
  89.        delay(8);
  90.     }
  91. }

  92. void delay(unsigned char dl)
  93. {
  94.    unsigned char ii1,ii2;
  95.    for (ii1=0;ii1<dl;ii1++)
  96.     // for (ii2=0;ii2<0xA;ii2++);
  97.      for (ii2=0;ii2<0x0f;ii2++);
  98. }

  99. //發送開始
  100. void Start_I2c(void)
  101. {
  102.    SDA=1;  delay(1);
  103.    SCL=1;  delay(1);
  104.    SDA=0;  delay(1);
  105.    SCL=0;  delay(1);
  106. }
  107. //發送停止
  108. void Stop_I2c(void)
  109. {
  110.    SCL=0;  delay(1);
  111.    SDA=0;  delay(1);
  112.    SCL=1;  delay(1);
  113.    SDA=1;  delay(1);
  114. }

  115. //發送數據C可以是地址,也可以是數據,發完后等待應答,并置狀態位ack=1(ok)
  116. void  SendByte(unsigned char c)
  117. {
  118.    unsigned char BitCnt;
  119.    for(BitCnt=0;BitCnt<8;BitCnt++)  //要傳送的數據長度為8位
  120.    {
  121.       SCL=0;
  122.       if((c<<BitCnt)&0x80) SDA=1;   //判斷發送位
  123.       else  SDA=0;
  124.       delay(1);
  125.       SCL=1;  delay(1);            //置時鐘線為高,通知被控器開始接收數據位
  126.    }
  127.    SCL=0;    delay(1);
  128.    SCL=1;    delay(1);
  129.    if(SDA==1) ack=0;
  130.    else ack=1;                    //*判斷是否接收到應答信號
  131. }

  132. //發送字節數據函數
  133. bit ISendByte(unsigned char sla,unsigned char c)
  134. {
  135.     Stop_I2c();  delay(1);               //結束總線
  136.     Start_I2c();                //啟動總線
  137.     SendByte(0xA0);             //WR2401
  138.     if(ack==0) return(0);
  139.     SendByte(sla);              //地址
  140.     SCL=0;    delay(1);
  141.     if(ack==0) return(0);
  142.     SendByte(c);         //寫數據
  143.     if (ack==0) return(0);
  144.     Stop_I2c(); delay(3);
  145.     return(1);
  146. }

  147. //讀字節數據函數從器件地址sla,返回值在c. 返回1(OK)
  148. bit IRcvByte(unsigned char sla,unsigned char *c)
  149. {
  150.     Stop_I2c();  delay(1);       //結束總線
  151.     Start_I2c();                //啟動總線
  152.     SendByte(0xA0);             //WR2401
  153.     if(ack==0) return(0);
  154.     SendByte(sla);             //地址
  155.     SCL=0;    delay(1);
  156.     if(ack==0) return(0);
  157.     Start_I2c();                //啟動總線
  158.     SendByte(0xA1);             //設備地址00
  159.     if(ack==0) return(0);
  160.     *c=RcvByte();               //讀取數據
  161.     if (ack==0) return(0);
  162.     Stop_I2c();
  163.     return(1);
  164. }

  165. //接收從器件傳來的數據,并判斷總線錯誤(不發應答信號),
  166. unsigned char  RcvByte()
  167. {
  168.    unsigned char retc;
  169.    unsigned char BitCnt;
  170.    retc=0;
  171.    for(BitCnt=0;BitCnt<8;BitCnt++)
  172.    {
  173.         SCL=0;   delay(1);    //置時鐘線為低,準備接收數據位
  174.         SCL=1;   delay(1);    //置時鐘線為高使數據線上數據有效
  175.         retc=retc<<1;
  176.         if(SDA==1)retc=retc+1; //讀數據位,接收的數據位放入retc中
  177.         delay(1);
  178.    }

  179. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

完整資料下載:
12實驗十二 I2C存儲卡讀寫實驗a.zip (22.94 KB, 下載次數: 22)


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产一区二区视频免费在线观看 | av黄色免费 | 精品视频一二区 | 91色视频在线观看 | 亚洲国产成人精品久久久国产成人一区 | 久久精品天堂 | 亚洲成人黄色 | 日韩欧美精品一区 | 日本在线中文 | a在线视频 | 亚洲欧美一区二区在线观看 | 亚洲精品国产成人 | 91在线免费视频 | 日韩免费高清视频 | 一区二区三区四区电影视频在线观看 | 久久久久91| 精品国产一区二区在线 | 麻豆av片| 国产精品免费一区二区 | 国产精品国产a级 | 久久久视频在线 | 日韩欧美一区二区三区在线播放 | 亚洲一区视频在线 | 成人午夜影院 | 中文字幕一区二区三区在线视频 | 狠狠爱视频 | 亚洲永久精品国产 | 91久久精品国产免费一区 | 久久久天天 | 久久综合久 | 欧美中文字幕一区二区三区 | 久久精品国产a三级三级三级 | 亚洲成av人影片在线观看 | 综合久久综合久久 | 天天久久 | 久久久久久久久久久蜜桃 | 亚洲国产免费 | 国产视频中文字幕在线观看 | 国产一区二区三区免费观看视频 | 国产一区二区三区免费观看在线 | 91精品国产综合久久婷婷香蕉 |