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

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

?? tcpip.c

?? lpc2368-keil環境下的網絡應用
?? C
?? 第 1 頁 / 共 3 頁
字號:
              }      break;    }    case FRAME_IP :                                        // check for IP-type    {      if ((ReadFrameBE_EMAC() & 0xFF00 ) == IP_VER_IHL)     // IPv4, IHL=5 (20 Bytes Header)      {                                                    // ignore Type Of Service        RecdIPFrameLength = ReadFrameBE_EMAC();             // get IP frame's length        ReadFrameBE_EMAC();                                 // ignore identification        if (!(ReadFrameBE_EMAC() & (IP_FLAG_MOREFRAG | IP_FRAGOFS_MASK)))  // only unfragm. frames        {          ProtocolType = ReadFrameBE_EMAC() & 0xFF;         // get protocol, ignore TTL          ReadFrameBE_EMAC();                               // ignore checksum          CopyFromFrame_EMAC(&RecdFrameIP, 4);              // get source IP          CopyFromFrame_EMAC(&TargetIP, 4);                 // get destination IP          if (!memcmp(&MyIP, &TargetIP, 4))                // is it for us?            switch (ProtocolType) {              case PROT_ICMP : { ProcessICMPFrame(); break; }              case PROT_TCP  : { ProcessTCPFrame(); break; }              case PROT_UDP  : break;                      // not implemented!            }        }            }      break;    }  }}// easyWEB internal function// we've just rec'd an ICMP-frame (Internet Control Message Protocol)// check what to do and branch to the appropriate sub-functionvoid ProcessICMPFrame(void){  unsigned short ICMPTypeAndCode;  ICMPTypeAndCode = ReadFrameBE_EMAC();           // get Message Type and Code  ReadFrameBE_EMAC();                             // ignore ICMP checksum  switch (ICMPTypeAndCode >> 8) {                // check type    case ICMP_ECHO :                             // is echo request?    {      PrepareICMP_ECHO_REPLY();                  // echo as much as we can...      break;    }  }}// easyWEB internal function// we've just rec'd an TCP-frame (Transmission Control Protocol)// this function mainly implements the TCP state machine according to RFC793void ProcessTCPFrame(void){  unsigned short TCPSegSourcePort;               // segment's source port  unsigned short TCPSegDestPort;                 // segment's destination port  unsigned long TCPSegSeq;                       // segment's sequence number  unsigned long TCPSegAck;                       // segment's acknowledge number  unsigned short TCPCode;                        // TCP code and header length  unsigned char TCPHeaderSize;                   // real TCP header length  unsigned short NrOfDataBytes;                  // real number of data      TCPSegSourcePort = ReadFrameBE_EMAC();                    // get ports  TCPSegDestPort = ReadFrameBE_EMAC();  if (TCPSegDestPort != TCPLocalPort) return;              // drop segment if port doesn't match  TCPSegSeq = (unsigned long)ReadFrameBE_EMAC() << 16;      // get segment sequence nr.  TCPSegSeq |= ReadFrameBE_EMAC();  TCPSegAck = (unsigned long)ReadFrameBE_EMAC() << 16;      // get segment acknowledge nr.  TCPSegAck |= ReadFrameBE_EMAC();  TCPCode = ReadFrameBE_EMAC();                             // get control bits, header length...  TCPHeaderSize = (TCPCode & DATA_OFS_MASK) >> 10;         // header length in bytes  NrOfDataBytes = RecdIPFrameLength - IP_HEADER_SIZE - TCPHeaderSize;     // seg. text length  if (NrOfDataBytes > MAX_TCP_RX_DATA_SIZE) return;        // packet too large for us :...-(  if (TCPHeaderSize > TCP_HEADER_SIZE)                     // ignore options if any    DummyReadFrame_EMAC(TCPHeaderSize - TCP_HEADER_SIZE);  switch (TCPStateMachine)                                 // implement the TCP state machine  {    case CLOSED :    {      if (!(TCPCode & TCP_CODE_RST))      {        TCPRemotePort = TCPSegSourcePort;        memcpy(&RemoteMAC, &RecdFrameMAC, 6);              // save opponents MAC and IP        memcpy(&RemoteIP, &RecdFrameIP, 4);                // for later use        if (TCPCode & TCP_CODE_ACK)                        // make the reset sequence        {                                                  // acceptable to the other          TCPSeqNr = TCPSegAck;                            // TCP          PrepareTCP_FRAME(TCP_CODE_RST);        }        else        {          TCPSeqNr = 0;          TCPAckNr = TCPSegSeq + NrOfDataBytes;          if (TCPCode & (TCP_CODE_SYN | TCP_CODE_FIN)) TCPAckNr++;          PrepareTCP_FRAME(TCP_CODE_RST | TCP_CODE_ACK);        }      }      break;    }      case LISTENING :    {      if (!(TCPCode & TCP_CODE_RST))                       // ignore segment containing RST      {        TCPRemotePort = TCPSegSourcePort;        memcpy(&RemoteMAC, &RecdFrameMAC, 6);              // save opponents MAC and IP        memcpy(&RemoteIP, &RecdFrameIP, 4);                // for later use        if (TCPCode & TCP_CODE_ACK)                        // reset a bad        {                                                  // acknowledgement          TCPSeqNr = TCPSegAck;          PrepareTCP_FRAME(TCP_CODE_RST);        }        else if (TCPCode & TCP_CODE_SYN)        {          TCPAckNr = TCPSegSeq + 1;                           // get remote ISN, next byte we expect            TCPSeqNr = ((unsigned long)ISNGenHigh << 16) | (T0TC & 0xFFFF);  // Keil: changed from TAR to T0TC; 
                                                              // set local ISN          TCPUNASeqNr = TCPSeqNr + 1;                         // one byte out -> increase by one          PrepareTCP_FRAME(TCP_CODE_SYN | TCP_CODE_ACK);          LastFrameSent = TCP_SYN_ACK_FRAME;          TCPStartRetryTimer();          TCPStateMachine = SYN_RECD;        }      }      break;    }    case SYN_SENT :    {      if (memcmp(&RemoteIP, &RecdFrameIP, 4)) break;  // drop segment if its IP doesn't belong                                                      // to current session      if (TCPSegSourcePort != TCPRemotePort) break;   // drop segment if port doesn't match            if (TCPCode & TCP_CODE_ACK)                // ACK field significant?        if (TCPSegAck != TCPUNASeqNr)            // is our ISN ACKed?        {          if (!(TCPCode & TCP_CODE_RST))          {            TCPSeqNr = TCPSegAck;            PrepareTCP_FRAME(TCP_CODE_RST);          }          break;                                 // drop segment        }      if (TCPCode & TCP_CODE_RST)                // RST??      {        if (TCPCode & TCP_CODE_ACK)              // if ACK was acceptable, reset        {                                        // connection          TCPStateMachine = CLOSED;          TCPFlags = 0;                          // reset all flags, stop retransmission...          SocketStatus = SOCK_ERR_CONN_RESET;        }        break;                                   // drop segment      }              if (TCPCode & TCP_CODE_SYN)                // SYN??      {        TCPAckNr = TCPSegSeq;                    // get opponents ISN        TCPAckNr++;                              // inc. by one...        if (TCPCode & TCP_CODE_ACK)        {          TCPStopTimer();                        // stop retransmission, other TCP got our SYN          TCPSeqNr = TCPUNASeqNr;                // advance our sequence number          PrepareTCP_FRAME(TCP_CODE_ACK);        // ACK this ISN          TCPStateMachine = ESTABLISHED;          SocketStatus |= SOCK_CONNECTED;          SocketStatus |= SOCK_TX_BUF_RELEASED;  // user may send data now :-)        }        else        {          TCPStopTimer();          PrepareTCP_FRAME(TCP_CODE_SYN | TCP_CODE_ACK);   // our SYN isn't ACKed yet,          LastFrameSent = TCP_SYN_ACK_FRAME;               // now continue with sending          TCPStartRetryTimer();                            // SYN_ACK frames          TCPStateMachine = SYN_RECD;        }      }      break;    }    default :    {      if (memcmp(&RemoteIP, &RecdFrameIP, 4)) break;  // drop segment if IP doesn't belong                                                      // to current session      if (TCPSegSourcePort != TCPRemotePort) break;   // drop segment if port doesn't match      if (TCPSegSeq != TCPAckNr) break;               // drop if it's not the segment we expect                  if (TCPCode & TCP_CODE_RST)                // RST??      {        TCPStateMachine = CLOSED;                // close the state machine        TCPFlags = 0;                            // reset all flags, stop retransmission...        SocketStatus = SOCK_ERR_CONN_RESET;      // indicate an error to user        break;      }      if (TCPCode & TCP_CODE_SYN)                // SYN??      {        PrepareTCP_FRAME(TCP_CODE_RST);          // is NOT allowed here! send a reset,        TCPStateMachine = CLOSED;                // close connection...        TCPFlags = 0;                            // reset all flags, stop retransmission...        SocketStatus = SOCK_ERR_REMOTE;          // fatal error!        break;                                   // ...and drop the frame      }      if (!(TCPCode & TCP_CODE_ACK)) break;      // drop segment if the ACK bit is off      if (TCPSegAck == TCPUNASeqNr)              // is our last data sent ACKed?      {        TCPStopTimer();                          // stop retransmission        TCPSeqNr = TCPUNASeqNr;                  // advance our sequence number        switch (TCPStateMachine)                 // change state if necessary        {          case SYN_RECD :                        // ACK of our SYN?          {            TCPStateMachine = ESTABLISHED;       // user may send data now :-)            SocketStatus |= SOCK_CONNECTED;            break;          }          case FIN_WAIT_1 : { TCPStateMachine = FIN_WAIT_2; break; } // ACK of our FIN?          case CLOSING :    { TCPStateMachine = TIME_WAIT; break; }  // ACK of our FIN?          case LAST_ACK :                                            // ACK of our FIN?          {            TCPStateMachine = CLOSED;            TCPFlags = 0;                        // reset all flags, stop retransmission...            SocketStatus &= SOCK_DATA_AVAILABLE; // clear all flags but data available            break;          }          case TIME_WAIT :          {            PrepareTCP_FRAME(TCP_CODE_ACK);      // ACK a retransmission of remote FIN            TCPRestartTimer();                   // restart TIME_WAIT timeout            break;          }        }                if (TCPStateMachine == ESTABLISHED)      // if true, give the frame buffer back          SocketStatus |= SOCK_TX_BUF_RELEASED;  // to user      }      if ((TCPStateMachine == ESTABLISHED) || (TCPStateMachine == FIN_WAIT_1) || (TCPStateMachine == FIN_WAIT_2))        if (NrOfDataBytes)                                 // data available?          if (!(SocketStatus & SOCK_DATA_AVAILABLE))       // rx data-buffer empty?          {            DummyReadFrame_EMAC(6);                        // ignore window, checksum, urgent pointer            CopyFromFrame_EMAC(RxTCPBuffer, NrOfDataBytes);// fetch data and            TCPRxDataCount = NrOfDataBytes;                // ...tell the user...            SocketStatus |= SOCK_DATA_AVAILABLE;           // indicate the new data to user            TCPAckNr += NrOfDataBytes;            PrepareTCP_FRAME(TCP_CODE_ACK);                // ACK rec'd data          }                    if (TCPCode & TCP_CODE_FIN)                // FIN??      {        switch (TCPStateMachine)        {          case SYN_RECD :          case ESTABLISHED :          {            TCPStateMachine = CLOSE_WAIT;            break;          }          case FIN_WAIT_1 :          {                                      // if our FIN was ACKed, we automatically            TCPStateMachine = CLOSING;           // enter FIN_WAIT_2 (look above) and therefore            SocketStatus &= ~SOCK_CONNECTED;     // TIME_WAIT            break;          }          case FIN_WAIT_2 :          {            TCPStartTimeWaitTimer();            TCPStateMachine = TIME_WAIT;            SocketStatus &= ~SOCK_CONNECTED;                        break;          }          case TIME_WAIT :          {            TCPRestartTimer();            break;          }        }        TCPAckNr++;                              // ACK remote's FIN flag        PrepareTCP_FRAME(TCP_CODE_ACK);      }    }  }}// easyWEB internal function// prepares the TxFrame2-buffer to send an ARP-requestvoid PrepareARP_REQUEST(void){  // Ethernet  memset(&TxFrame2[ETH_DA_OFS], (char)0xFF, 6);                  // we don't know opposites MAC!  memcpy(&TxFrame2[ETH_SA_OFS], &MyMAC, 6);  *(unsigned short *)&TxFrame2[ETH_TYPE_OFS] = SWAPB(FRAME_ARP);  // ARP  *(unsigned short *)&TxFrame2[ARP_HARDW_OFS] = SWAPB(HARDW_ETH10);  *(unsigned short *)&TxFrame2[ARP_PROT_OFS] = SWAPB(FRAME_IP);  *(unsigned short *)&TxFrame2[ARP_HLEN_PLEN_OFS] = SWAPB(IP_HLEN_PLEN);  *(unsigned short *)&TxFrame2[ARP_OPCODE_OFS] = SWAPB(OP_ARP_REQUEST);  memcpy(&TxFrame2[ARP_SENDER_HA_OFS], &MyMAC, 6);  memcpy(&TxFrame2[ARP_SENDER_IP_OFS], &MyIP, 4);  memset(&TxFrame2[ARP_TARGET_HA_OFS], 0x00, 6);           // we don't know opposites MAC!  if (((RemoteIP[0] ^ MyIP[0]) & SubnetMask[0]) || ((RemoteIP[1] ^ MyIP[1]) & SubnetMask[1]))    memcpy(&TxFrame2[ARP_TARGET_IP_OFS], &GatewayIP, 4);   // IP not in subnet, use gateway

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美视频精品在线| 国产亚洲欧美在线| 一区二区三区在线观看国产| 一本色道久久综合亚洲91| 国产精品丝袜黑色高跟| 成人激情黄色小说| 一区二区三区免费网站| 欧美另类一区二区三区| 久久99热国产| 在线一区二区三区做爰视频网站| 最新中文字幕一区二区三区| 欧洲另类一二三四区| 日本sm残虐另类| 久久久久国色av免费看影院| av亚洲精华国产精华| 亚洲无人区一区| 欧美一区二区三区视频免费 | 精品国产凹凸成av人导航| 国产成人免费视频网站 | 制服丝袜中文字幕亚洲| 国产传媒日韩欧美成人| 亚洲一区二区三区自拍| 精品久久久久久无| 色婷婷综合久久久中文字幕| 美日韩一区二区三区| 午夜在线成人av| 国产亚洲短视频| 欧美少妇xxx| 国产专区综合网| 一区二区三区成人| 久久久午夜电影| 911精品国产一区二区在线| 国产精品亚洲第一区在线暖暖韩国| 亚洲影视资源网| 欧美国产一区视频在线观看| 欧美一区二区在线不卡| 色av成人天堂桃色av| 国产在线视视频有精品| 婷婷国产在线综合| 欧美一区二区大片| 高清beeg欧美| 肉丝袜脚交视频一区二区| 国产精品大尺度| 精品成人一区二区| 欧美日韩亚洲综合在线| 一道本成人在线| 高清不卡一区二区| 国精产品一区一区三区mba桃花| 亚洲国产一二三| 亚洲激情男女视频| 国产精品久久久久久一区二区三区| 欧美va亚洲va香蕉在线| 欧美日本在线一区| 欧美性猛片xxxx免费看久爱| 成人黄色在线视频| 国产乱码精品一区二区三区忘忧草| 偷偷要91色婷婷| 亚洲国产欧美在线| 亚洲综合在线五月| 亚洲男帅同性gay1069| 国产精品视频免费| 国产精品久久久久久久久果冻传媒 | 国产成人综合自拍| 激情综合色播激情啊| 蜜臀久久久99精品久久久久久| 亚洲成人一二三| 五月天网站亚洲| 午夜精品在线视频一区| 五月综合激情婷婷六月色窝| 欧美国产精品久久| 日韩你懂的电影在线观看| 67194成人在线观看| 欧美放荡的少妇| 日韩视频在线永久播放| 欧美videos中文字幕| 欧美电视剧在线观看完整版| 欧美xxxx老人做受| 一区二区三区四区在线免费观看| 国产精品欧美极品| 国产精品久久久久久户外露出| 中文字幕制服丝袜一区二区三区| 中文字幕在线视频一区| 亚洲色欲色欲www在线观看| 亚洲色欲色欲www| 亚洲国产wwwccc36天堂| 天天做天天摸天天爽国产一区| 青青草伊人久久| 国产一区二区日韩精品| 大陆成人av片| 欧美中文字幕一二三区视频| 欧美乱妇15p| 久久久亚洲高清| 亚洲视频你懂的| 日韩国产成人精品| 国产一区二区三区四| 成人在线视频一区| 国产欧美日韩中文久久| 久久精品视频在线看| 国产精品国产精品国产专区不片 | 成人久久视频在线观看| 91啪九色porn原创视频在线观看| 欧美伊人久久大香线蕉综合69| 欧美高清视频不卡网| 久久先锋影音av鲁色资源| 国产精品久久久久久妇女6080 | 国产精品色一区二区三区| 亚洲欧美一区二区三区国产精品 | 精品区一区二区| 亚洲色图欧美在线| 青草av.久久免费一区| 国产v综合v亚洲欧| 欧美日韩亚洲综合在线| 久久久三级国产网站| 亚洲午夜精品久久久久久久久| 丁香五精品蜜臀久久久久99网站| 国产一区二区三区四区五区美女| 成人精品一区二区三区四区| 欧美亚日韩国产aⅴ精品中极品| 欧美电视剧在线观看完整版| 亚洲美女淫视频| 91碰在线视频| 久久综合久久综合久久| 亚洲一区免费在线观看| 国产成人一级电影| 91精品国产综合久久久久久久久久 | 中文字幕免费不卡| 日韩av电影免费观看高清完整版在线观看 | 成人aa视频在线观看| 欧美一区二区视频在线观看2022 | 国产丝袜欧美中文另类| 午夜一区二区三区视频| 成人在线视频一区| 精品久久久网站| 丝袜亚洲另类欧美综合| 99精品一区二区| 久久久久九九视频| 蜜臀a∨国产成人精品| 欧美天天综合网| 亚洲欧洲在线观看av| 国产精品一级片在线观看| 91麻豆精品国产自产在线 | 免费成人你懂的| 99久久久久久| 国产视频亚洲色图| 久久国产尿小便嘘嘘尿| 欧美三级日韩在线| 亚洲品质自拍视频网站| 国产91精品露脸国语对白| 精品99一区二区| 琪琪久久久久日韩精品| 欧美日本一区二区在线观看| 亚洲裸体在线观看| 成人国产精品免费| 国产精品午夜春色av| 国产精品2024| 日本一区二区三区在线不卡| 国产一区在线视频| 亚洲免费毛片网站| 99久久婷婷国产综合精品| 欧美激情艳妇裸体舞| 成人开心网精品视频| 中文一区二区在线观看| 成人免费av在线| 国产精品萝li| 91色乱码一区二区三区| 亚洲免费伊人电影| 色老头久久综合| 亚洲综合视频网| 337p亚洲精品色噜噜噜| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩欧美一区二区视频| 看片网站欧美日韩| 久久日韩粉嫩一区二区三区| 黑人巨大精品欧美黑白配亚洲| 亚洲精品一线二线三线| 国产精品 日产精品 欧美精品| 国产日韩欧美精品综合| caoporm超碰国产精品| 一区二区三区四区乱视频| 欧美日韩三级在线| 美女视频网站黄色亚洲| 久久精品夜色噜噜亚洲a∨| bt7086福利一区国产| 亚洲精品免费播放| 欧美理论片在线| 精品午夜久久福利影院| 中文字幕精品—区二区四季| 91在线观看污| 亚洲成人动漫在线免费观看| 欧美哺乳videos| 成人h动漫精品| 性做久久久久久久久| 久久麻豆一区二区| 色综合久久天天| 欧美bbbbb| 中文字幕欧美激情一区| 欧美麻豆精品久久久久久| 国产乱色国产精品免费视频| 亚洲黄色尤物视频| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av |