亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? serial.lst

?? 基于單片機C8051F020與以太網進行通信程序
?? LST
字號:
C51 COMPILER V7.06   SERIAL                                                                03/05/2005 08:11:34 PAGE 1   


C51 COMPILER V7.06, COMPILATION OF MODULE SERIAL
OBJECT MODULE PLACED IN Serial.OBJ
COMPILER INVOKED BY: c:\KEIL\C51\BIN\C51.exe Serial.c DB OE

stmt level    source

   1          //-----------------------------------------------------------------------------
   2          // Copyright (c) 2002 Jim Brady
   3          // Do not use commercially without author's permission
   4          // Last revised August 2002
   5          // Net SERIAL.C
   6          //
   7          // This module handles RS-232 messages and associated tasks
   8          //-----------------------------------------------------------------------------
   9          #include "C8051f.h"
  10          #include "intrins.h"
  11          #include "net.h"
  12          #include "serial.h"
  13          
  14          bit CommRecDataOverflowFlag,FlagRecComm,SendItComm;
  15          
  16          unsigned char CommSendBufferHead, CommSendBufferTail;
  17          unsigned char CommRecBufferHead, CommRecBufferTail;
  18          
  19          unsigned char xdata CommSendBuffer[DB_SENDMAXSIZE] _at_ 0 ; //串行口緩沖區定位在內部4K XRAM中
  20          unsigned char xdata CommRecBuffer[DB_RECMAXSIZE] _at_ DB_SENDMAXSIZE; 
  21           
  22          void ClearCommRecBuffer(void)
  23          {
  24   1              unsigned char i;
  25   1              CommRecBufferHead=CommRecBufferTail=0;
  26   1              CommSendBufferHead=CommSendBufferTail=0;
  27   1              FlagRecComm=0;
  28   1              for (i=0;i<DB_SENDMAXSIZE;i++)
  29   1              {
  30   2                      CommSendBuffer[i]=0;
  31   2              }
  32   1              for (i=0;i<DB_RECMAXSIZE;i++)
  33   1              {
  34   2                      CommRecBuffer[i]=0;
  35   2              }
  36   1      }
  37          
  38          void init_serial(void)
  39          {
  40   1              ClearCommRecBuffer();
  41   1              OpenComm();
  42   1      }
  43          
  44          void OpenComm(void) 
  45          {
  46   1              PCON |= 0x80;           // SMOD=1 (HW_UART uses Timer 1 overflow with no divide down).
  47   1              TMOD |= 0x20;           // Configure Timer 1 for use by UART0
  48   1              CKCON |= 0x10;          // Timer 1 derived from SYSCLK
  49   1      
  50   1              RCAP2H=(65536-(SYSCLK/BAUDRATE0/32))/256;
  51   1              RCAP2L=(65536-(SYSCLK/BAUDRATE0/32))%256;
  52   1              TH2=RCAP2H;TL2=RCAP2L;
  53   1              CT2=0;                          //T2:timer mode 
  54   1              TR2=1;
  55   1              TCLK=1;RCLK=1;          //說明:52,對于SIO0,可選擇T1(TCLK=0,RCLK=0)或T2(TCLK=1,RCLK=1)作為波特率發生器
C51 COMPILER V7.06   SERIAL                                                                03/05/2005 08:11:34 PAGE 2   

  56   1                                                  //            SIO1只能用T1作為波特率發生器
  57   1                                                  //baud=OSC/(32*(65536-[RCAP2H,RCAP2L])
  58   1              CommSendBufferHead=CommSendBufferTail=0; // set the head and tail to the base of the ring buffer
  59   1              CommRecBufferHead=CommRecBufferTail=0;
  60   1              FlagRecComm=0;
  61   1              RI0=0;                                  // Clear HW_UART receive and transmit
  62   1              TI0=0;                                  // complete indicators.
  63   1              SCON0 = 0x50;                   // Configure UART0 for mode 1, receiver enabled.
  64   1              ES0=1;                                  // allow the serial interrupt
  65   1              SendItComm=1;
  66   1      }
  67          /*
  68          void SendCommChar(char ch)
  69          {
  70                  CommSendBuffer[CommSendBufferTail]=ch; 
  71                  CommSendBufferTail++;
  72                  if (CommSendBufferTail==DB_SENDMAXSIZE)
  73                  {       
  74                          CommSendBufferTail=0;
  75                  }
  76                  if (SendItComm)
  77                  {        
  78                          SendItComm=0;
  79                          SBUF0=CommSendBuffer[CommSendBufferHead]; 
  80                  }
  81                  while (CommSendBufferHead!=CommSendBufferTail);
  82                  return ;
  83          }
  84          
  85          code unsigned char hex[]="0123456789ABCDEF";
  86          void SendCommHex(unsigned char senddata)//往串口發送hex碼 表示的一個字符 例如senddata=0x3A那么將向串口發送
             -兩個字符'3','A'hex[]為轉換表,在前面有定義
  87          {
  88                  unsigned char ch;
  89                  ch=senddata>>4;
  90                  SendCommChar(hex[ch]);
  91                  ch=senddata&0x0F;
  92                  SendCommChar(hex[ch]);
  93          }
  94          void SendCommWord(unsigned int asciiword)
  95          //向串口發送一個int型的 hex碼表示的字符 例如:asciiword=0x124D 將向串口發送4個字符:'1','2','4','D'
  96          {
  97                  unsigned char ascii;
  98                  ascii=asciiword>>8;
  99                  SendCommHex(ascii);
 100                  ascii=asciiword&0xff;
 101                  SendCommHex(ascii);
 102          }
 103          
 104          void SendCommLong(unsigned long asciilong)
 105          {
 106                  SendCommWord(asciilong>>16);
 107                  SendCommWord(asciilong&0xffff);
 108          }
 109          */
 110          void serial_send(unsigned char *base)
 111          {
 112   1              SendCommString(base);
 113   1      }
 114          
 115          void SendCommString(unsigned char *base) 
 116          {
C51 COMPILER V7.06   SERIAL                                                                03/05/2005 08:11:34 PAGE 3   

 117   1      unsigned char i=0;
 118   1              if (base[0]==0) return;
 119   1              for (;;)
 120   1              {       
 121   2                      if (base[i]==0) break;
 122   2                      CommSendBuffer[CommSendBufferTail]=base[i]; 
 123   2                      CommSendBufferTail++; 
 124   2                      if (CommSendBufferTail==DB_SENDMAXSIZE)
 125   2                      {                                               
 126   3                              CommSendBufferTail=0;
 127   3                      }
 128   2                      i++;
 129   2              }
 130   1              if (SendItComm)
 131   1              {                                                       
 132   2                      SendItComm=0;
 133   2                      SBUF0=CommSendBuffer[CommSendBufferHead];
 134   2              }
 135   1              while (CommSendBufferHead!=CommSendBufferTail);
 136   1      }
 137          /*
 138          void SendCommBuffer(unsigned char *base, unsigned char size) 
 139          {
 140          unsigned char i=0;
 141                  if (!size) { return; }  
 142                  while (i<size) 
 143                  {        
 144                          CommSendBuffer[CommSendBufferTail]=base[i]; 
 145                          i++;
 146                          CommSendBufferTail++; 
 147                          if (CommSendBufferTail==DB_SENDMAXSIZE)
 148                          { 
 149                                  CommSendBufferTail=0;
 150                          }
 151                  }
 152                  if (SendItComm)
 153                  {        
 154                          SendItComm=0;
 155                          SBUF0=CommSendBuffer[CommSendBufferHead]; 
 156                  }
 157          }
 158          */
 159          void CommISR(void) interrupt 4
 160          {
 161   1              if (_testbit_(TI0))
 162   1              {
 163   2                      TI0=0;
 164   2                      CommSendBufferHead++;   
 165   2                      if (CommSendBufferHead==DB_SENDMAXSIZE)
 166   2                      {        
 167   3                              CommSendBufferHead=0;
 168   3                      }
 169   2                      if (CommSendBufferHead!=CommSendBufferTail)
 170   2                      {        
 171   3                              SBUF0=CommSendBuffer[CommSendBufferHead]; // send the next byte
 172   3                              SendItComm=0;
 173   3                      }
 174   2                      else
 175   2                      {
 176   3                              SendItComm=1;
 177   3                      }
 178   2              }
C51 COMPILER V7.06   SERIAL                                                                03/05/2005 08:11:34 PAGE 4   

 179   1              if (_testbit_(RI0))     
 180   1              {        
 181   2                      RI0=0;
 182   2                      if (CommRecBufferTail==CommRecBufferHead)
 183   2                      {
 184   3                              CommRecDataOverflowFlag=1;                              //接收緩沖區溢出
 185   3                      }
 186   2                      CommRecBuffer[CommRecBufferTail]=SBUF0;     //receive data           
 187   2                  CommRecBufferTail++;
 188   2                  if (CommRecBufferTail==DB_RECMAXSIZE)
 189   2                  {
 190   3                      CommRecBufferTail=0;
 191   3                  }
 192   2                      FlagRecComm=1;
 193   2              }
 194   1      }
 195          
 196          //從接收緩沖區讀數據 ,無數據返回0,有數據返回1
 197          bit GetCommChar(unsigned char idata *ch)      
 198          { 
 199   1              if (CommRecBufferTail==CommRecBufferHead) return 0;     
 200   1              *ch=CommRecBuffer[CommRecBufferHead];
 201   1              CommRecBufferHead++;
 202   1              if (CommRecBufferHead==DB_RECMAXSIZE)
 203   1              {
 204   2                      CommRecBufferHead=0;
 205   2              }
 206   1              if (CommRecBufferTail==CommRecBufferHead) FlagRecComm=0;
 207   1              return 1;
 208   1      }
 209          /*
 210          //在T(0-255)毫秒內從接收緩沖區讀數據 ,無數據返回0,有數據返回1
 211          bit GetCommCharWait(unsigned char idata *ch,unsigned char T)  //T ms    
 212          { 
 213                  Count1ms=T;*ch=0;
 214                  while (Count1ms)
 215                  {
 216                          if (CommRecBufferTail!=CommRecBufferHead) break;
 217                  }
 218                  if (Count1ms==0) return 0;
 219                  *ch=CommRecBuffer[CommRecBufferHead];
 220                  CommRecBufferHead++;
 221                  if (CommRecBufferHead==DB_RECMAXSIZE)
 222                  {
 223                          CommRecBufferHead=0;
 224                  }
 225                  return 1;
 226          }
 227          */
 228          
 229          //------------------------------------------------------------------------
 230          // This function converts an integer to an ASCII string.  It is a 
 231          // normally provided as a standard library function but the Keil
 232          // libraries do not include it.  Caution: The string passed to this
 233          // must be at least 12 bytes long
 234          //------------------------------------------------------------------------
 235          /*char * itoa(UINT value, char * buf, UCHAR radix)
 236          {
 237                  UINT i;
 238              
 239                  char * ptr;
 240                  char * temphold;
C51 COMPILER V7.06   SERIAL                                                                03/05/2005 08:11:34 PAGE 5   

 241          
 242                  temphold = buf;
 243                  ptr = buf + 12;
 244                  *--ptr = 0;             // Insert NULL char
 245                  
 246                  do
 247                  {
 248                     // First create string in reverse order
 249                     i = (value % radix) + 0x30;
 250                          if(i > 0x39) i += 7;
 251                          *--ptr = i;
 252                value = value / radix;
 253                  } while(value != 0);
 254          
 255                  // Next, move the string 6 places to the left
 256                  // Include NULL character
 257                  for( ; (*buf++ = *ptr++); );    
 258                  return(temphold);
 259          }*/
 260          
 261          char * itoa(UINT value, char * buf, UCHAR radix)
 262          {
 263   1              UINT i,t1;
 264   1              char * ptr;
 265   1              char * temphold;
 266   1      
 267   1              temphold = buf;
 268   1              ptr = buf + 12;
 269   1              *--ptr = 0;             // Insert NULL char
 270   1           t1=0;
 271   1      if(radix==10)
 272   1      {
 273   2              do
 274   2              {
 275   3                 // First create string in reverse order
 276   3                 i = (value % radix) + 0x30;
 277   3                      if(i > 0x39) i += 7;
 278   3                      *--ptr = i;
 279   3            value = value / radix;
 280   3            t1++;
 281   3              } while(value != 0);
 282   2      }
 283   1      
 284   1              // Next, move the string 6 places to the left
 285   1              // Include NULL character
 286   1        
 287   1      else
 288   1      {
 289   2         radix=radix-1;
 290   2              do
 291   2              {
 292   3                 // First create string in reverse order
 293   3                 i = (value % radix) + 0x30;
 294   3                      if(i > 0x39) i += 7;
 295   3                      *--ptr = i;
 296   3            value = value / radix;
 297   3            t1++;
 298   3              } while(value != 0);    
 299   2        if(!(t1==2))
 300   2              { t1=2-t1;
 301   3               for(i=0;i<t1;i++)
 302   3                 *--ptr=0x30;
C51 COMPILER V7.06   SERIAL                                                                03/05/2005 08:11:34 PAGE 6   

 303   3                         }
 304   2         }
 305   1              for( ; (*buf++ = *ptr++); );    
 306   1              return(temphold);
 307   1      }
 308          
 309          


MODULE INFORMATION:   STATIC OVERLAYABLE
   CODE SIZE        =    673    ----
   CONSTANT SIZE    =   ----    ----
   XDATA SIZE       =   ----    ----
   PDATA SIZE       =   ----    ----
   DATA SIZE        =      4      19
   IDATA SIZE       =   ----    ----
   BIT SIZE         =      3    ----
END OF MODULE INFORMATION.


C51 COMPILATION COMPLETE.  0 WARNING(S),  0 ERROR(S)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美激情一区二区三区四区| 亚洲一二三四在线观看| 成人手机电影网| 日本一二三四高清不卡| 粉嫩av一区二区三区在线播放 | 亚洲va欧美va人人爽| 欧美日韩国产色站一区二区三区| 天堂一区二区在线| 欧美一个色资源| 国产精品99久久不卡二区| 国产欧美va欧美不卡在线| 99久久久久久| 亚洲主播在线播放| 日韩视频一区二区三区在线播放 | 免费黄网站欧美| 久久婷婷国产综合国色天香| 岛国一区二区在线观看| 亚洲啪啪综合av一区二区三区| 欧美吻胸吃奶大尺度电影| 日韩精品成人一区二区在线| 精品国产sm最大网站免费看| 国产成人丝袜美腿| 亚洲精品第1页| 日韩你懂的在线观看| 国产99久久久国产精品免费看 | 国产一区二区三区在线观看免费 | 亚洲情趣在线观看| 在线不卡中文字幕| 国产一区二区免费视频| 亚洲免费观看高清完整版在线观看| 欧美日韩国产高清一区二区三区| 久久国产人妖系列| 亚洲视频精选在线| 日韩欧美国产综合在线一区二区三区| 高清不卡一区二区在线| 亚洲国产美女搞黄色| 2021中文字幕一区亚洲| 91小视频免费观看| 美女网站色91| 国产精品伦理在线| 在线播放中文一区| 成人精品亚洲人成在线| 香蕉乱码成人久久天堂爱免费| 欧美精品一区在线观看| 91论坛在线播放| 久久精品国产一区二区三| 综合久久久久综合| 精品国产乱子伦一区| 在线亚洲+欧美+日本专区| 久久99久久久欧美国产| 亚洲品质自拍视频| 久久欧美中文字幕| 色吧成人激情小说| 国产伦精品一区二区三区在线观看| 伊人夜夜躁av伊人久久| 精品国产乱码久久久久久久 | 99精品欧美一区二区三区小说| 日韩二区三区在线观看| 日韩美女啊v在线免费观看| 日韩区在线观看| 日本精品一区二区三区四区的功能| 久久精品理论片| 亚洲午夜精品一区二区三区他趣| 国产视频911| 欧美一区二区三区在线看| 91丝袜呻吟高潮美腿白嫩在线观看| 美美哒免费高清在线观看视频一区二区 | 国产精品日韩精品欧美在线| 欧美顶级少妇做爰| 日本乱人伦aⅴ精品| 国产成人啪午夜精品网站男同| 亚洲国产综合色| 国产精品久久久久久久久免费桃花| 精品久久国产字幕高潮| 欧美在线你懂得| 99热99精品| 国产乱妇无码大片在线观看| 青青草97国产精品免费观看 | 久久精品av麻豆的观看方式| 亚洲视频每日更新| 国产欧美一二三区| 精品国产精品网麻豆系列| 欧美日韩国产123区| av电影一区二区| 国产精品99久久久久久宅男| 蜜臀av亚洲一区中文字幕| 亚洲国产日日夜夜| 亚洲精品ww久久久久久p站| 中文字幕不卡在线| xf在线a精品一区二区视频网站| 欧美日韩国产小视频| 日本韩国精品一区二区在线观看| 成av人片一区二区| 成人动漫av在线| 国产**成人网毛片九色| 美女爽到高潮91| 蜜臀av性久久久久蜜臀aⅴ| 亚洲不卡一区二区三区| 亚洲成人免费视频| 亚洲一区二区三区精品在线| 一区二区三区国产精品| 亚洲免费观看在线视频| 中文字幕一区二区三区蜜月 | 性做久久久久久免费观看欧美| 亚洲一二三区在线观看| 色婷婷综合久色| av不卡在线观看| www.66久久| 99re8在线精品视频免费播放| 成人久久18免费网站麻豆 | 91免费看`日韩一区二区| aaa国产一区| 91小视频免费观看| 色婷婷精品久久二区二区蜜臂av| 色综合中文综合网| 久久av老司机精品网站导航| 久久精品国产一区二区三区免费看| 老司机精品视频导航| 麻豆国产欧美一区二区三区| 免费欧美日韩国产三级电影| 毛片av一区二区三区| 久久99国内精品| 国产精品亚洲第一| 成人免费三级在线| 99在线精品观看| 色琪琪一区二区三区亚洲区| 欧美日韩在线播放三区四区| 欧美高清www午色夜在线视频| 欧美成人在线直播| 久久久亚洲精华液精华液精华液| 国产日韩欧美精品一区| 国产精品私房写真福利视频| 亚洲人成7777| 天堂一区二区在线| 韩国一区二区视频| 成人自拍视频在线| 在线视频你懂得一区二区三区| 欧美日韩国产高清一区二区 | 亚洲日本成人在线观看| 一区二区三区四区视频精品免费 | 免费高清在线一区| 国内精品免费在线观看| 成人av片在线观看| 91行情网站电视在线观看高清版| 欧美日韩国产区一| 精品国产乱码久久久久久蜜臀| 国产精品网站在线播放| 一区二区三区四区精品在线视频| 香蕉av福利精品导航| 国产一区二区三区日韩| 色中色一区二区| 欧美一区二区久久久| 久久久91精品国产一区二区精品| 亚洲欧洲99久久| 婷婷国产在线综合| 国内久久婷婷综合| 91丨九色丨蝌蚪丨老版| 欧美日本在线一区| 国产欧美日韩麻豆91| 一区二区激情视频| 久久精品国产精品亚洲综合| 95精品视频在线| 欧美一区二区网站| 国产精品美女久久久久久久久| 亚洲成人午夜影院| 国产成人免费视频网站| 欧美亚男人的天堂| 久久精品一区蜜桃臀影院| 一区二区三区产品免费精品久久75| 日韩—二三区免费观看av| 成人午夜精品一区二区三区| 欧美日韩国产小视频在线观看| 国产日韩欧美激情| 天使萌一区二区三区免费观看| 高清不卡一区二区在线| 欧美日韩高清在线播放| 国产精品美女久久久久久久久| 日本网站在线观看一区二区三区| 成人免费视频免费观看| 91精品国产一区二区三区| 国产精品乱码一区二区三区软件| 日韩国产欧美在线观看| heyzo一本久久综合| 日韩一区二区三区视频| 一区二区在线观看视频在线观看| 精品夜夜嗨av一区二区三区| 在线精品视频一区二区三四| 久久久噜噜噜久久人人看| 亚洲高清不卡在线| 成人av影视在线观看| 日韩午夜精品视频| 一区二区三区精品| 成人黄色免费短视频| 欧美成人在线直播| 性欧美大战久久久久久久久| 97久久人人超碰| 久久午夜免费电影| 日本不卡视频一二三区| 一本久道久久综合中文字幕 | 久久综合色婷婷|