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

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

?? mainproc.c

?? m68k平臺的Linux多串口實例
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "common.h"#include "PublishCard.c"void ACK(int comPort){ WriteBuffer[0]=0xaa; WriteBuffer[1]=0xdd; WriteToComm(comPort,2);}void NAK(int comPort){ WriteBuffer[0]=0xaa; WriteBuffer[1]=0xee; WriteToComm(comPort,2);}void SetDebug(unsigned char Debug){ DEBUG=Debug;}int GetCommDataLength(int Device_Handle){ int pcbLength; pcbLength=0; ioctl(Device_Handle,FIONREAD,&pcbLength); return pcbLength;}int  AutoDetect(int Device_Handle){ int r,l; r=0; for(;;) {  l=0;  l=GetCommDataLength(Device_Handle);  if(l==0)  {   if(r<50000)r++;   else return 0;  }  else return l; }}//3妙int  ShortBlockDetect(int Device_Handle){ int r,l; r=0; for(;;) {  l=0;  l=GetCommDataLength(Device_Handle);  if(l==0)  {   if(r<25000)r++;   else return 0;  }  else return l; }}void delay(unsigned long dly){ while(dly!=0) {  dly-=1;  dly+=1;  dly-=1;  dly+=1;  dly-=1;  dly+=1;  dly-=1; };}void ListenAllDeviceOnRead_Error(){ int rel; fd_set DeviceRead;   //設備讀準備就緒; fd_set DeviceError; // 設備出現錯誤 int    DeviceMax; for(;;) {  DeviceMax=0;  FD_ZERO(&DeviceRead);  FD_ZERO(&DeviceError); // FD_SET(ListenPort,&DeviceRead);//  FD_SET(HS0,&DeviceRead);  FD_SET(HS1,&DeviceRead);  FD_SET(HS2,&DeviceRead);  FD_SET(HS4,&DeviceRead);  FD_SET(HS5,&DeviceRead);/*  if(SocketConnect.Socket_Handle!=-1)  {   FD_SET(SocketConnect.Socket_Handle,&DeviceRead);   FD_SET(SocketConnect.Socket_Handle,&DeviceError);   DeviceMax=SocketConnect.Socket_Handle;  }  if(DeviceMax<ListenPort)DeviceMax=ListenPort;*/  DeviceMax=HS1;  if(HS1>DeviceMax)DeviceMax=HS1;  if(HS2>DeviceMax)DeviceMax=HS2;  if(HS4>DeviceMax)DeviceMax=HS4;  if(HS5>DeviceMax)DeviceMax=HS5;  rel=select(DeviceMax+1,&DeviceRead,NULL,NULL,NULL);  if(rel<=0)continue;  printf("Listen a Request\n");/*  if(FD_ISSET(ListenPort,&DeviceRead))  {   if(SocketConnect.Socket_Handle==-1)    rel=ListenProcess();  }  if(SocketConnect.Socket_Handle!=-1)  {   if(FD_ISSET(SocketConnect.Socket_Handle,&DeviceRead))   {    rel=recv(SocketConnect.Socket_Handle,&SocketCommand,SocketReadLength,0);    if(rel<=0)     continue;    else     ProcessReceive(SocketConnect.Socket_Handle);   }  }*/  if(FD_ISSET(HS0,&DeviceRead))  {   printf("COM1 Request\n");   mTerminalControl();  }  if(FD_ISSET(HS1,&DeviceRead))  {   printf("COM2 Request\n");  // rel=ReadFromComm(HS1,0);  }  if(FD_ISSET(HS2,&DeviceRead))  {   printf("COM3 Request\n");   rel=ReadFromComm(HS2,0);   if(rel>=0)    ExecMAPCFunc(Command,HS2,rel);  }  if(FD_ISSET(HS4,&DeviceRead))  {   printf("COM5 Request\n");   rel=ReadFromComm(HS4,0);   if(rel>=0)    ExecMAPCFunc(Command,HS4,rel);  }  if(FD_ISSET(HS5,&DeviceRead))  {   printf("COM6 Request\n");//   if(inBusy==0x55aa)continue;   rel=ReadFromComm(HS5,0);   if(rel>=0)    ExecIOCOFunc(Command);  } };}void PrintToNetwork(unsigned char *buff){ int i,l; l=strlen(buff); printf("%s\r",buff);}//---------------------------------------------------------------------------// 初始化并打開設備// 如果設備打開出錯,返回 -1int InitilizeComm(int comPort,int Baud,int DataLength,int StopLength,int Partery){ int fd; struct termios COMOption; //打開設備 //bzero(COMOption sizeof(struct termios)); switch(comPort) {  case 0:HS0=open("/dev/ttyS0",O_RDWR | O_NOCTTY);fd=HS0;break;  case 1:HS1=open("/dev/ttyS1",O_RDWR | O_NOCTTY);fd=HS1;break;  case 2:HS2=open("/dev/ttyS2",O_RDWR | O_NOCTTY);fd=HS2;break;  case 3:HS3=open("/dev/ttyS3",O_RDWR | O_NOCTTY);fd=HS3;break;  case 4:HS4=open("/dev/ttyS4",O_RDWR | O_NOCTTY);fd=HS4;break;  case 5:HS5=open("/dev/ttyS5",O_RDWR | O_NOCTTY);fd=HS5;break; } if(fd<0)return -1; //允許接收,并設為本地模式 COMOption.c_cflag |=(CLOCAL | CREAD); //如果沒有制定奇偶校驗 if(Partery==-1) {  COMOption.c_cflag&=~PARENB;  COMOption.c_cflag&=~PARODD; } else if(Partery/2==0)//如果指定偶校驗 {  COMOption.c_cflag|=PARENB;  COMOption.c_cflag&=~PARODD; } else                        //否則就是奇校驗 {   COMOption.c_cflag&=~PARENB;   COMOption.c_cflag|=PARODD; } COMOption.c_cflag&=~CSTOPB;      // COMOption.c_cflag&=~CSIZE;       // if(DataLength==8)COMOption.c_cflag|=CS8; else if(DataLength==7)COMOption.c_cflag|=CS7; else COMOption.c_cflag|=CS8; switch(Baud) {  case 1200:cfsetispeed(&COMOption,B1200);cfsetospeed(&COMOption,B1200);break;  case 2400:cfsetispeed(&COMOption,B2400);cfsetospeed(&COMOption,B2400);break;  case 4800:cfsetispeed(&COMOption,B4800);cfsetospeed(&COMOption,B4800);break;  case 9600:cfsetispeed(&COMOption,B9600);cfsetospeed(&COMOption,B9600);break;  case 19200:cfsetispeed(&COMOption,B19200);cfsetospeed(&COMOption,B19200);break;  case 38400:cfsetispeed(&COMOption,B38400);cfsetospeed(&COMOption,B38400);break;  case 57600:cfsetispeed(&COMOption,B57600);cfsetospeed(&COMOption,B57600);break;  default:cfsetispeed(&COMOption,B9600);cfsetospeed(&COMOption,B9600);break; } tcflush(fd, TCIFLUSH); tcsetattr(fd,TCSANOW,&COMOption); fcntl(fd,F_SETFL,O_NONBLOCK); CLR_DTR(fd); CLR_RTS(fd); printf("COM%i 初始化完成 波特率 :%i,該設備未發現錯誤\n",comPort,Baud); return 0;}int ReadFromComm(int comPort,int Length){ int pcbRead,i,rel,p; unsigned char buf[256],cht; cht=0; RDataLength=0; i=0; p=0; rel=0; for(;;) {  //delay(1000);  pcbRead=read(comPort,&buf,GetCommDataLength(comPort));  if(pcbRead<=0)  {   if(p<200)   {    p++;    continue;   }   else    break;  }   else if(buf[pcbRead-3]==0xaa && buf[pcbRead-2]==0xcc)  {   for(i=0;i<pcbRead;i++)    ReadBuffer[RDataLength++]=buf[i];   break;  }  else if(buf[pcbRead-2]==0xaa && buf[pcbRead-1]==0xdd)  {   for(i=0;i<pcbRead;i++)    ReadBuffer[RDataLength++]=buf[i];   break;  }  else if(buf[pcbRead-2]==0xaa && buf[pcbRead-1]==0xee)  {   for(i=0;i<pcbRead;i++)    ReadBuffer[RDataLength++]=buf[i];   break;  }  else  {   for(i=0;i<pcbRead;i++)    ReadBuffer[RDataLength++]=buf[i];  } } //tcflush(comPort, TCIFLUSH); //讀回數據后,判斷設備類型  Result=CanverBSYNToContent(comPort); if(Result==0xaadd)return -1; else if(Result==0xccee)return -3; if(comPort!=HS5) {  if(GET_RTS(comPort)==1)return 0;  else return 1; } else {  cht=*(unsigned char*)COM5_MCR;  cht=cht<<6;  if((cht & 0xc0)==0xc0) //串口5設備A   return 0;  else if((cht & 0xc0)==0x40)   return 1;  else if((cht & 0xc0)==0x80)   return 2;  else if((cht & 0xc0)==0x00)   return 3; }}int ReadFromComm6003(int comPort,int Length){ int pcbRead,i,rel; unsigned char buf[256]; RDataLength=0; i=0; for(;;) {  pcbRead=read(comPort,&buf,256);  if(pcbRead<=0)  {   if(i<200)   {    i++;    continue;   }   return -1;  }  for(i=0;i<pcbRead;i++)   ReadBuffer[RDataLength++]=buf[i];  if(RDataLength+pcbRead-3>=ReadBuffer[1])   break; } tcflush(comPort, TCIFLUSH); if(GET_RTS(comPort)==1) {  Canver6003ToContent(HS3);  } else                   //串口3設備B {  Canver6003ToContent(HS3); }}int WriteToComm(int comPort,int Length){  return write(comPort,WriteBuffer,Length);}//-----------------------------------------------------------------------------// 將數據轉換成BSYN格式的數據,準備向串口發送int CanverContentToBSYN(int comPort){ int i,p; unsigned char ch,chk; p=0; chk=0xaa^0xbb^Command; WriteBuffer[p++]=0xaa; WriteBuffer[p++]=0xbb; WriteBuffer[p++]=Command; for(i=0;i<DataLength;i++) {  ch=DataBuffer[i];  chk=chk^ch;  if(ch==0xaa)  {   WriteBuffer[p++]=ch;   WriteBuffer[p++]=ch;   chk=chk^ch;   continue;  }  else WriteBuffer[p++]=ch; } WriteBuffer[p++]=0xaa; WriteBuffer[p++]=0xcc; chk=chk^0xaa^0xcc; WriteBuffer[p++]=chk; WDataLength=p;#ifdef __DEBUG__ printf("Send To Comm:\n"); for(i=0;i<WDataLength;i++)  printf("%x ",WriteBuffer[i]); printf("\nSend END\n");#endif}//----------------------------------------------------------------------------// 將數據轉換成6003格式的數據,準備向串口發送int CanverContentTo6003(int comPort){ unsigned char CheckCode; int i; WDataLength=0; WriteBuffer[WDataLength++]=P6003H; WriteBuffer[WDataLength++]=DataLength+1; WriteBuffer[WDataLength++]=Command; CheckCode=WriteBuffer[0]^WriteBuffer[1]^WriteBuffer[2]; if(DataLength>1) {  for(i=0;i<DataLength;i++)  {   WriteBuffer[WDataLength++]=DataBuffer[i];   CheckCode=CheckCode^WriteBuffer[i+3];  } } WriteBuffer[WDataLength++]=CheckCode; WriteBuffer[WDataLength++]=P6003E;#ifdef __DEBUG__ printf("Send To 6003 Content\n"); for(i=0;i<WDataLength;i++)  printf("%x ",WriteBuffer[i]); printf("\n");#endif}//-----------------------------------------------------------------------// 將接收到的BSYN格式的數據轉換成普通數據格式// 函數執行正確,返回0 將接收的數據存放在DataBuffer中// 如果包頭錯誤  反回 0xaadd 這是一條正應答// 如果包尾錯誤  返回 0xaaee 這是一條負應答// 如果校驗值錯誤返回 0xccee 收到的數據校驗和錯誤,但數據已經放在DataBuffer中

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产v综合v亚洲欧| 国产剧情在线观看一区二区| 国产色产综合产在线视频| 欧美一区二区三区视频免费播放| 欧美日韩一区二区三区高清| 日本久久电影网| 日本道免费精品一区二区三区| 91蜜桃传媒精品久久久一区二区| 91小视频免费看| 91国内精品野花午夜精品| 欧美色综合网站| 91.com视频| 26uuu精品一区二区在线观看| 精品久久国产字幕高潮| 国产日韩三级在线| 亚洲日本免费电影| 亚洲亚洲人成综合网络| 中文字幕在线观看一区二区| 亚洲桃色在线一区| 天堂在线亚洲视频| 久久精品国产**网站演员| 国产精一品亚洲二区在线视频| 国产成人啪免费观看软件| aaa国产一区| 制服丝袜亚洲精品中文字幕| 久久色成人在线| 亚洲男人电影天堂| 麻豆成人91精品二区三区| 国产成人自拍网| 欧美日韩一区二区三区视频| 久久久美女艺术照精彩视频福利播放| 国产精品久久久久久久久果冻传媒 | 国产精品久久三| 亚洲你懂的在线视频| 人妖欧美一区二区| jvid福利写真一区二区三区| 制服丝袜中文字幕一区| 国产精品网站一区| 亚洲不卡av一区二区三区| 国产精品自产自拍| 欧美日韩大陆在线| 国产精品麻豆99久久久久久| 日韩国产成人精品| 色婷婷av一区二区| 久久久精品影视| 午夜欧美2019年伦理 | 亚洲日本欧美天堂| 精品无码三级在线观看视频| 欧美亚洲日本国产| 亚洲欧洲国产日韩| 韩国午夜理伦三级不卡影院| 欧美日韩亚州综合| 成人免费在线播放视频| 国产一区二区不卡| 日韩午夜精品电影| 亚洲午夜免费视频| 91一区在线观看| 国产视频一区二区在线| 日本欧美久久久久免费播放网| 国产精品综合二区| 欧美精选午夜久久久乱码6080| 国产精品青草综合久久久久99| 美女一区二区三区在线观看| 欧美日韩1234| 亚洲国产你懂的| 欧美偷拍一区二区| 亚洲精品国产一区二区精华液| 国产精品亚洲专一区二区三区 | 26uuu久久综合| 午夜私人影院久久久久| 在线观看亚洲一区| 亚洲免费视频中文字幕| 91在线视频免费观看| 国产精品午夜久久| 国产在线视频不卡二| 国产日韩欧美在线一区| 免费观看在线综合| 欧美色图激情小说| 一区二区三区四区激情| 欧洲亚洲国产日韩| 亚洲综合色婷婷| 欧美亚洲国产一区二区三区| 亚洲影视在线观看| 欧美精品亚洲一区二区在线播放| 午夜精品福利一区二区三区av | 久久这里只有精品6| 久久激情五月婷婷| 久久久三级国产网站| 精品一区二区在线视频| 久久日一线二线三线suv| 国产精品一二二区| 国产精品久久看| 在线亚洲高清视频| 亚洲人成网站影音先锋播放| 国产欧美一区二区精品婷婷 | 全部av―极品视觉盛宴亚洲| 欧美精品国产精品| 日本不卡的三区四区五区| 精品免费99久久| eeuss鲁一区二区三区| 成人欧美一区二区三区黑人麻豆 | 综合电影一区二区三区| 成人高清视频免费观看| 1024成人网| 欧美精品久久久久久久多人混战| 精品系列免费在线观看| 亚洲欧美日韩人成在线播放| 在线电影欧美成精品| 国产裸体歌舞团一区二区| 一区二区三区国产豹纹内裤在线| 91麻豆精品国产91久久久久久| 韩国女主播成人在线观看| 亚洲男人的天堂网| 精品国产免费久久| 色国产综合视频| 国产剧情一区二区三区| 亚洲一区二区av电影| 日韩中文字幕不卡| 久久亚洲春色中文字幕久久久| 97久久超碰国产精品| 国产夫妻精品视频| 五月激情综合婷婷| 国产精品福利在线播放| 日韩欧美一级精品久久| 91免费在线看| 国产在线麻豆精品观看| 视频一区二区三区入口| 一区在线中文字幕| 久久新电视剧免费观看| 欧美色网站导航| 91亚洲男人天堂| 粉嫩一区二区三区性色av| 免费观看久久久4p| 亚洲国产精品视频| 国产精品久久午夜| 久久久久国产一区二区三区四区| 欧美色图免费看| 色哟哟在线观看一区二区三区| 国产美女在线精品| 国产主播一区二区| 免费高清不卡av| 视频一区二区中文字幕| 亚洲国产精品一区二区尤物区| 亚洲色图丝袜美腿| 亚洲视频一二三| 国产精品久久久久三级| 欧美国产精品一区二区三区| 久久综合色之久久综合| 日韩一本二本av| 欧美成人一区二区三区在线观看| 欧美精品九九99久久| 欧美一区二区三区在线观看| 91麻豆精品国产自产在线观看一区 | 欧美本精品男人aⅴ天堂| 欧美日韩精品一区视频| 欧美性生活一区| 欧美性生活久久| 91精品国产91热久久久做人人| 欧美视频在线一区二区三区 | 亚洲日本丝袜连裤袜办公室| 国产欧美一区二区精品性色 | a亚洲天堂av| 色综合天天综合在线视频| av在线不卡电影| 色综合久久中文综合久久97| 色哟哟欧美精品| 欧美日韩亚洲综合一区| 日韩欧美国产电影| 久久久五月婷婷| 亚洲免费在线视频一区 二区| 亚洲激情一二三区| 三级一区在线视频先锋| 久久国产精品99久久久久久老狼| 麻豆精品蜜桃视频网站| 成人在线综合网站| 99亚偷拍自图区亚洲| 91精彩视频在线| 日韩欧美中文字幕公布| 久久久99精品免费观看| 综合在线观看色| 日韩成人一级片| 国产99久久久国产精品免费看 | 国产亚洲成年网址在线观看| 中文字幕一区三区| 五月天视频一区| 国产乱子轮精品视频| 色婷婷综合视频在线观看| 91精品国产色综合久久| 国产拍揄自揄精品视频麻豆| 亚洲成av人影院| 国产成人在线观看免费网站| 欧洲色大大久久| 久久人人超碰精品| 亚洲电影在线免费观看| 国产精品中文欧美| 欧美优质美女网站| 国产欧美精品一区二区色综合 | 91福利视频网站| 国产女人18水真多18精品一级做| 亚洲成人一区在线|