国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

W6100-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六)

這篇具有很好參考價值的文章主要介紹了W6100-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報違法"按鈕提交疑問。

前言

????????上一章我們用W6100-EVB-PICO開發(fā)板做TCP 客戶端連接服務(wù)器進(jìn)行數(shù)據(jù)回環(huán)測試,那么本章將用開發(fā)板做TCP服務(wù)器來進(jìn)行數(shù)據(jù)回環(huán)測試。

TCP是什么?什么是TCP Server?能干什么?

????????TCP (Transmission Control Protocol) 是一種面向連接的、可靠的、基于字節(jié)流的傳輸協(xié)議,用于在計算機(jī)網(wǎng)絡(luò)上傳輸數(shù)據(jù)。TCP Server是指TCP網(wǎng)絡(luò)服務(wù)的服務(wù)器端連接,用于接收客戶端的連接請求并建立連接,實現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)的交互。
????????TCP Server的主要作用是監(jiān)聽客戶端的連接請求,并建立與管理連接,實現(xiàn)數(shù)據(jù)的可靠傳輸。通過TCPServer,多個客戶端可以同時與服務(wù)器建立連接,實現(xiàn)數(shù)據(jù)的多點(diǎn)傳輸。
????????在TCP Server中,服務(wù)器程序需要指定監(jiān)聽的端口號,并使用TCP協(xié)議與客戶端建立連接。一旦有客戶端連接進(jìn)來,服務(wù)器程序就會為每個客戶端建立一個單獨(dú)的連接,并通過數(shù)據(jù)流對象 (NetworkStream) 與客廣端進(jìn)行數(shù)據(jù)交互。
????????因此,TCP Server可以幫助設(shè)備實現(xiàn)多點(diǎn)數(shù)據(jù)交互,是設(shè)備聯(lián)網(wǎng)通信的重要方式之一。在工業(yè)自動化、物聯(lián)網(wǎng)、智能家居等應(yīng)用中,TCP Server被廣泛使用。

連接方式

使開發(fā)板和我們的電腦處于同一網(wǎng)段:

  • 開發(fā)板(設(shè)備)通過交叉線直連主機(jī)(PC)
  • ?開發(fā)板和主機(jī)都接在路由器LAN口

測試工具

  • 網(wǎng)絡(luò)調(diào)試工具(任意)
  • wireshark抓包工具

回環(huán)測試

1.相關(guān)代碼

如下所示,tcp服務(wù)端的回環(huán)測試函數(shù)需要我們傳入三個參數(shù):socket端口號、收發(fā)數(shù)據(jù)的緩存和端口,與做tcp客戶端實現(xiàn)思路一樣(可參考上一章內(nèi)容),即通過Switch狀態(tài)機(jī)輪詢socket狀態(tài)進(jìn)行相應(yīng)處理,不同的是在初始化socket端口后不再是連接服務(wù)器,而是開啟端口監(jiān)聽。

因為W6100這款以太網(wǎng)芯片支持IPv6,因此在回環(huán)模式上有著不同選擇,相應(yīng)地處理上也會根據(jù)模式分別進(jìn)行處理,這里選擇IPv4模式進(jìn)行回環(huán)測試。

int32_t loopback_tcps(uint8_t sn, uint8_t* buf, uint16_t port, uint8_t loopback_mode)
{
    int32_t ret;
    datasize_t sentsize=0;
    int8_t status,inter;
    uint8_t tmp = 0;
    datasize_t received_size;
    uint8_t arg_tmp8;
    uint8_t* mode_msg;
    uint8_t dip[16];
    uint16_t dport;
    if(loopback_mode == AS_IPV4)
    {
       mode_msg = msg_v4;
    }else if(loopback_mode == AS_IPV6)
    {
       mode_msg = msg_v6;
    }else
    {
       mode_msg = msg_dual;
    }
    #ifdef _LOOPBACK_DEBUG_
        uint8_t dst_ip[16], ext_status;
        uint16_t dst_port;
    #endif
        getsockopt(sn, SO_STATUS, &status);
        switch(status)
        {
        case SOCK_ESTABLISHED :
            ctlsocket(sn,CS_GET_INTERRUPT,&inter);
            if(inter & Sn_IR_CON)
            {
            #ifdef _LOOPBACK_DEBUG_
                getsockopt(sn,SO_DESTIP,dst_ip);
                getsockopt(sn,SO_EXTSTATUS, &ext_status);
                if(ext_status & TCPSOCK_MODE){
                    //IPv6
                    printf("%d:Peer IP : %04X:%04X", sn, ((uint16_t)dst_ip[0] << 8) | ((uint16_t)dst_ip[1]),
                            ((uint16_t)dst_ip[2] << 8) | ((uint16_t)dst_ip[3]));
                    printf(":%04X:%04X", ((uint16_t)dst_ip[4] << 8) | ((uint16_t)dst_ip[5]),
                            ((uint16_t)dst_ip[6] << 8) | ((uint16_t)dst_ip[7]));
                    printf(":%04X:%04X", ((uint16_t)dst_ip[8] << 8) | ((uint16_t)dst_ip[9]),
                            ((uint16_t)dst_ip[10] << 8) | ((uint16_t)dst_ip[11]));
                    printf(":%04X:%04X, ", ((uint16_t)dst_ip[12] << 8) | ((uint16_t)dst_ip[13]),
                            ((uint16_t)dst_ip[14] << 8) | ((uint16_t)dst_ip[15]));
                }else
                {
                    //IPv4
                    //getSn_DIPR(sn,dst_ip);
                    printf("%d:Peer IP : %.3d.%.3d.%.3d.%.3d, ",
                            sn, dst_ip[0], dst_ip[1], dst_ip[2], dst_ip[3]);
                }
                getsockopt(sn,SO_DESTPORT,&dst_port);
                printf("Peer Port : %d\r\n", dst_port);
            #endif
                arg_tmp8 = Sn_IR_CON;
                ctlsocket(sn,CS_CLR_INTERRUPT,&arg_tmp8);
            }
            getsockopt(sn,SO_RECVBUF,&received_size);

            if(received_size > 0){
                if(received_size > DATA_BUF_SIZE) received_size = DATA_BUF_SIZE;
                ret = recv(sn, buf, received_size);
                getsockopt(sn,SO_DESTIP,dip);
                getsockopt(sn,SO_DESTPORT,&dport);
                printf("from the client with ip [%d.%d.%d.%d] - port [%d].\n",dip[0],dip[1],dip[2],dip[3],dport);
                printf("recv: %s",buf);
                if(ret <= 0) return ret;      // check SOCKERR_BUSY & SOCKERR_XXX. For showing the occurrence of SOCKERR_BUSY.
                received_size = (uint16_t) ret;
                sentsize = 0;

                while(received_size != sentsize)
                {
                    ret = send(sn, buf+sentsize, received_size-sentsize);
                    if(ret < 0)
                    {
                        close(sn);
                        return ret;
                    }
                    sentsize += ret; // Don't care SOCKERR_BUSY, because it is zero.
                }
            }
            break;
        case SOCK_CLOSE_WAIT :
            #ifdef _LOOPBACK_DEBUG_
                printf("%d:CloseWait\r\n",sn);
            #endif
            getsockopt(sn, SO_RECVBUF, &received_size);
            if(received_size > 0) // Don't need to check SOCKERR_BUSY because it doesn't not occur.
            {
                if(received_size > DATA_BUF_SIZE) received_size = DATA_BUF_SIZE;
                ret = recv(sn, buf, received_size);

                if(ret <= 0) return ret;      // check SOCKERR_BUSY & SOCKERR_XXX. For showing the occurrence of SOCKERR_BUSY.
                received_size = (uint16_t) ret;
                sentsize = 0;

                while(received_size != sentsize)
                {
                    ret = send(sn, buf+sentsize, received_size-sentsize);
                    if(ret < 0)
                    {
                        close(sn);
                        return ret;
                    }
                    sentsize += ret; // Don't care SOCKERR_BUSY, because it is zero.
                }
            }

            if((ret = disconnect(sn)) != SOCK_OK) return ret;
                #ifdef _LOOPBACK_DEBUG_
                    printf("%d:Socket Closed\r\n", sn);
                #endif
            break;
        case SOCK_INIT :
            if( (ret = listen(sn)) != SOCK_OK) return ret;
                #ifdef _LOOPBACK_DEBUG_
                    printf("%d:Listen, TCP server loopback, port [%d] as %s\r\n", sn, port, mode_msg);
                #endif
                    printf("%d:Listen, TCP server loopback, port [%d] as %s\r\n", sn, port, mode_msg);
            break;
        case SOCK_CLOSED:
            #ifdef _LOOPBACK_DEBUG_
                printf("%d:TCP server loopback start\r\n",sn);
            #endif
                switch(loopback_mode)
                {
                case AS_IPV4:
                    tmp = socket(sn, Sn_MR_TCP4, port, SOCK_IO_NONBLOCK);
                    break;
                case AS_IPV6:
                    tmp = socket(sn, Sn_MR_TCP6, port, SOCK_IO_NONBLOCK);
                    break;
                case AS_IPDUAL:
                    tmp = socket(sn, Sn_MR_TCPD, port, SOCK_IO_NONBLOCK);
                    break;
                default:
                    break;
                }
                if(tmp != sn)    /* reinitialize the socket */
                {
                    #ifdef _LOOPBACK_DEBUG_
                        printf("%d : Fail to create socket.\r\n",sn);
                    #endif
                    return SOCKERR_SOCKNUM;
                }
            #ifdef _LOOPBACK_DEBUG_
                printf("%d:Socket opened[%d]\r\n",sn, getSn_SR(sn));
                sock_state[sn] = 1;
            #endif
            break;
        default:
            break;
        }
    return 1;
}

主函數(shù)就比較簡單,在此之前我們先聲明socket端口號和所用最大的緩存大小,不做分片處理默認(rèn)為2KB;然后初始化網(wǎng)絡(luò)信息、目標(biāo)IP地址和目標(biāo)端口,最后在while循環(huán)里調(diào)用loopback_tcps并傳入相應(yīng)參數(shù)即可。

注意:這里的本地端口選擇盡量避免使用特殊端口,這里使用8080;如下所示。

#define SOCKET_ID 0
#define ETHERNET_BUF_MAX_SIZE (1024 * 2)

void network_init(void);

wiz_NetInfo net_info = {
    .mac = {0x00, 0x08, 0xdc, 0x16, 0xed, 0x2e},
    .ip = {192, 168, 1, 10},
    .sn = {255, 255, 255, 0},
    .gw = {192, 168, 1, 1},
    .dns = {8, 8, 8, 8},
    .ipmode = NETINFO_STATIC_V4};
wiz_NetInfo get_info;
static uint8_t ethernet_buf[ETHERNET_BUF_MAX_SIZE] = {0,};
static uint16_t local_port = 8080;

int main()                                                          
{   
    stdio_init_all();
    sleep_ms(2000);
    network_init();

    while(true)
    {
        loopback_tcps(SOCKET_ID, ethernet_buf, local_port, AS_IPV4);
        sleep_ms(500);
    }
    

}

void network_init(void)
{
    uint8_t temp;
    wizchip_initialize();
     printf("W6100 tcp server example.\r\n");
    sleep_ms(2000);
     /* Determine the network lock register status */
    if(!ctlwizchip(SYS_NET_LOCK, &temp))
    {   
        printf("unlock.\n");
        NETUNLOCK();
    }
    wizchip_setnetinfo(&net_info);
    print_net_info(&get_info);
    sleep_ms(2000);   
}

2.測試現(xiàn)象

我們編譯燒錄后,打開串行監(jiān)視器,可以看到我們開發(fā)板通過串口回顯的網(wǎng)絡(luò)配置信息,然后我們打開網(wǎng)絡(luò)調(diào)試工具,配置為TCP Client模式;遠(yuǎn)程IP地址和遠(yuǎn)程端口為我們開發(fā)板的本地IP和端口,然后點(diǎn)擊連接,并發(fā)送數(shù)據(jù)測試;可以看到串口打印的信息,我們電腦作為客戶端成功連接并收到開發(fā)板回傳的數(shù)據(jù)。

W6100-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六),WIZnet W6100-EVB-Pico  C/C++教程,W6100以太網(wǎng)芯片,樹莓派pico,C SDK,嵌入式設(shè)備入網(wǎng)教程,wiznet

我們也可以在打開wireshark抓包工具,輸入命令<ip.addr == 192.168.1.10 and tcp>過濾數(shù)據(jù)包(IP地址改成自己電腦的IP或者開發(fā)板的IP地址即可);我這里先關(guān)閉網(wǎng)絡(luò)調(diào)試助手,然后又打開,接著發(fā)送0~9十個阿拉伯?dāng)?shù)字,可以通過抓包工具十分清楚明了的看到具體交互過程,如下圖所示。W6100-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六),WIZnet W6100-EVB-Pico  C/C++教程,W6100以太網(wǎng)芯片,樹莓派pico,C SDK,嵌入式設(shè)備入網(wǎng)教程,wiznet

?相關(guān)鏈接:

本章相關(guān)例程鏈接https://gitee.com/wiznet-hk/example-of-w6100-evb-pico.gitwireshark抓包工具下載鏈接https://www.wireshark.org/download.html文章來源地址http://www.zghlxwxcb.cn/news/detail-639352.html

到了這里,關(guān)于W6100-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點(diǎn)擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • W5500-EVB-PICO 做UDP Server進(jìn)行數(shù)據(jù)回環(huán)測試(七)

    W5500-EVB-PICO 做UDP Server進(jìn)行數(shù)據(jù)回環(huán)測試(七)

    ????????前面我們用W5500-EVB-PICO 開發(fā)板在TCP Client和TCP Server模式下,分別進(jìn)行數(shù)據(jù)回環(huán)測試,本章我們將用開發(fā)板在UDP Server模式下進(jìn)行數(shù)據(jù)回環(huán)測試。 ????????UDP (User Dataqram Protocol) 是一種無連接的、不可靠的傳輸協(xié)議,用于在計算機(jī)網(wǎng)絡(luò)上傳輸數(shù)據(jù)UDP Server是指UDP網(wǎng)絡(luò)

    2024年02月12日
    瀏覽(15)
  • W5500-EVB-PICO作為TCP Client 進(jìn)行數(shù)據(jù)回環(huán)測試(五)

    W5500-EVB-PICO作為TCP Client 進(jìn)行數(shù)據(jù)回環(huán)測試(五)

    ????????上一章我們用W5500-EVB-PICO開發(fā)板通過DNS解析www.baidu.com(百度域名)成功得到其IP地址,那么本章我們將用我們的開發(fā)板作為客戶端去連接服務(wù)器,并做數(shù)據(jù)回環(huán)測試:收到服務(wù)器發(fā)送的數(shù)據(jù),并回傳給服務(wù)器。 ????????TCP (Transmission Control Protocol) 是一種面向連

    2024年02月13日
    瀏覽(17)
  • W5500-EVB-PICO進(jìn)行UDP組播數(shù)據(jù)回環(huán)測試(九)

    W5500-EVB-PICO進(jìn)行UDP組播數(shù)據(jù)回環(huán)測試(九)

    ????????上一章我們用我們的開發(fā)板作為UDP客戶端連接服務(wù)器進(jìn)行數(shù)據(jù)回環(huán)測試,那么本章我們進(jìn)行UDP組播數(shù)據(jù)回環(huán)測試。 ????????組播是主機(jī)間一對多的通訊模式, 組播是一種允許一個或多個組播源發(fā)送同一報文到多個接收者的技術(shù)。組播源將一份報文發(fā)送到特定的

    2024年02月11日
    瀏覽(16)
  • W5500-EVB-PICO做UDP Client進(jìn)行數(shù)據(jù)回環(huán)測試(八)

    W5500-EVB-PICO做UDP Client進(jìn)行數(shù)據(jù)回環(huán)測試(八)

    ? ? ? ? 上一章我們用開發(fā)板作為UDP Server進(jìn)行數(shù)據(jù)回環(huán)測試,本章我們讓我們的開發(fā)板作為UDP Client進(jìn)行數(shù)據(jù)回環(huán)測試。 使開發(fā)板和我們的電腦處于同一網(wǎng)段: 開發(fā)板通過交叉線直連主機(jī) 開發(fā)板和主機(jī)都接在路由器LAN口 網(wǎng)路調(diào)試工具(任意) wireshark抓包工具 我們打開例程

    2024年02月12日
    瀏覽(21)
  • W5100S-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六)

    W5100S-EVB-PICO 做TCP Server進(jìn)行回環(huán)測試(六)

    ????????上一章我們用W5100S-EVB-PICO開發(fā)板做TCP 客戶端連接服務(wù)器進(jìn)行數(shù)據(jù)回環(huán)測試,那么本章將用開發(fā)板做TCP服務(wù)器來進(jìn)行數(shù)據(jù)回環(huán)測試。 ????????TCP (Transmission Control Protocol) 是一種面向連接的、可靠的、基于字節(jié)流的傳輸協(xié)議,用于在計算機(jī)網(wǎng)絡(luò)上傳輸數(shù)據(jù)。TCP S

    2024年02月13日
    瀏覽(21)
  • WIZnet W5500-EVB-Pico DHCP 配置教程(三)

    WIZnet W5500-EVB-Pico DHCP 配置教程(三)

    ????????動態(tài)主機(jī)配置協(xié)議DHCP(Dynamic Host Configuration Protocol)是一種網(wǎng)絡(luò)管理協(xié)議,用于集中對用戶IP地址進(jìn)行動態(tài)管理和配置。 ????????DHCP于1993年10月成為標(biāo)準(zhǔn)協(xié)議,其前身是BOOTP協(xié)議。DHCP協(xié)議由RFC 2131定義,采用客戶端/服務(wù)器通信模式,由客戶端(DHCP Client)向服

    2024年02月15日
    瀏覽(25)
  • W5100S-EVB-PICO 做UDP Server進(jìn)行數(shù)據(jù)回環(huán)測試(七)

    W5100S-EVB-PICO 做UDP Server進(jìn)行數(shù)據(jù)回環(huán)測試(七)

    ????????前面我們用W5100S-EVB-PICO 開發(fā)板在TCP Client和TCP Server模式下,分別進(jìn)行數(shù)據(jù)回環(huán)測試,本章我們將用開發(fā)板在UDP Server模式下進(jìn)行數(shù)據(jù)回環(huán)測試。 ????????UDP (User Dataqram Protocol) 是一種無連接的、不可靠的傳輸協(xié)議,用于在計算機(jī)網(wǎng)絡(luò)上傳輸數(shù)據(jù)UDP Server是指UDP網(wǎng)絡(luò)

    2024年02月13日
    瀏覽(15)
  • W5100S-EVB-PICO作為TCP Client 進(jìn)行數(shù)據(jù)回環(huán)測試(五)

    W5100S-EVB-PICO作為TCP Client 進(jìn)行數(shù)據(jù)回環(huán)測試(五)

    ????????上一章我們用W5100S-EVB-PICO開發(fā)板通過DNS解析www.baidu.com(百度域名)成功得到其IP地址,那么本章我們將用我們的開發(fā)板作為客戶端去連接服務(wù)器,并做數(shù)據(jù)回環(huán)測試:收到服務(wù)器發(fā)送的數(shù)據(jù),并回傳給服務(wù)器。 ????????TCP (Transmission Control Protocol) 是一種面向連

    2024年02月13日
    瀏覽(17)
  • W5100S-EVB-PICO進(jìn)行UDP組播數(shù)據(jù)回環(huán)測試(九)

    W5100S-EVB-PICO進(jìn)行UDP組播數(shù)據(jù)回環(huán)測試(九)

    ????????上一章我們用我們的開發(fā)板作為UDP客戶端連接服務(wù)器進(jìn)行數(shù)據(jù)回環(huán)測試,那么本章我們進(jìn)行UDP組播數(shù)據(jù)回環(huán)測試。 ????????組播是主機(jī)間一對多的通訊模式, 組播是一種允許一個或多個組播源發(fā)送同一報文到多個接收者的技術(shù)。組播源將一份報文發(fā)送到特定的

    2024年02月10日
    瀏覽(25)
  • WIZnet W51000S-EVB-PICO 入門教程(一)

    WIZnet W51000S-EVB-PICO 入門教程(一)

    W5100S-EVB-Pico 是基于樹莓派RP2040和全硬件TCP/IP協(xié)議??刂破鱓5100S的微控制器開發(fā)板-基本上與樹莓派Pico板相同,但通過W5100S芯片增加了以太網(wǎng)功能。 RP2040 規(guī)格參數(shù) ? ? ?? 雙核Arm Cortex-M0 + @133MHz 264KB 高速SRAM和2MB板載內(nèi)存 通過專用QSPI總線最高支持16MB的片外閃存 ?DMA控制器 30

    2024年02月15日
    瀏覽(26)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包