element14 Community
element14 Community
    Register Log In
  • Site
  • Search
  • Log In Register
  • Community Hub
    Community Hub
    • What's New on element14
    • Feedback and Support
    • Benefits of Membership
    • Personal Blogs
    • Members Area
    • Achievement Levels
  • Learn
    Learn
    • Ask an Expert
    • eBooks
    • element14 presents
    • Learning Center
    • Tech Spotlight
    • STEM Academy
    • Webinars, Training and Events
    • Learning Groups
  • Technologies
    Technologies
    • 3D Printing
    • FPGA
    • Industrial Automation
    • Internet of Things
    • Power & Energy
    • Sensors
    • Technology Groups
  • Challenges & Projects
    Challenges & Projects
    • Design Challenges
    • element14 presents Projects
    • Project14
    • Arduino Projects
    • Raspberry Pi Projects
    • Project Groups
  • Products
    Products
    • Arduino
    • Avnet Boards Community
    • Dev Tools
    • Manufacturers
    • Multicomp Pro
    • Product Groups
    • Raspberry Pi
    • RoadTests & Reviews
  • Store
    Store
    • Visit Your Store
    • Choose another store...
      • Europe
      •  Austria (German)
      •  Belgium (Dutch, French)
      •  Bulgaria (Bulgarian)
      •  Czech Republic (Czech)
      •  Denmark (Danish)
      •  Estonia (Estonian)
      •  Finland (Finnish)
      •  France (French)
      •  Germany (German)
      •  Hungary (Hungarian)
      •  Ireland
      •  Israel
      •  Italy (Italian)
      •  Latvia (Latvian)
      •  
      •  Lithuania (Lithuanian)
      •  Netherlands (Dutch)
      •  Norway (Norwegian)
      •  Poland (Polish)
      •  Portugal (Portuguese)
      •  Romania (Romanian)
      •  Russia (Russian)
      •  Slovakia (Slovak)
      •  Slovenia (Slovenian)
      •  Spain (Spanish)
      •  Sweden (Swedish)
      •  Switzerland(German, French)
      •  Turkey (Turkish)
      •  United Kingdom
      • Asia Pacific
      •  Australia
      •  China
      •  Hong Kong
      •  India
      •  Korea (Korean)
      •  Malaysia
      •  New Zealand
      •  Philippines
      •  Singapore
      •  Taiwan
      •  Thailand (Thai)
      • Americas
      •  Brazil (Portuguese)
      •  Canada
      •  Mexico (Spanish)
      •  United States
      Can't find the country/region you're looking for? Visit our export site or find a local distributor.
  • Translate
  • Profile
  • Settings
Avnet Boards Forums
  • Products
  • Dev Tools
  • Avnet Boards Community
  • Avnet Boards Forums
  • More
  • Cancel
Avnet Boards Forums
Software Application Development TCP server on zedboard shuts down after some interval
  • Forum
  • Documents
  • Members
  • Mentions
  • Sub-Groups
  • Tags
  • More
  • Cancel
  • New
Join Avnet Boards Forums to participate - click to join for free!
Actions
  • Share
  • More
  • Cancel
Forum Thread Details
  • State Not Answered
  • Replies 3 replies
  • Subscribers 311 subscribers
  • Views 550 views
  • Users 0 members are here
Related

TCP server on zedboard shuts down after some interval

Former Member
Former Member over 8 years ago

Hello,

I have created a LWIP TCP server on the zedboard and a TCP client on MATLAB on the host computer(zedboard and host computer are connected over ethernet). The client requests the connection to the server, SYN, SYNACK and ACK packets are delivered successfully and the connection is established. (Packets are monitored on wireshark on the host computer).

 

Now, If the client keeps sending the data continuously to the server, then server receives the data and process them. BUT the server crashes if I take some time interval in sending the data. For example: If I send data from client to server at time 0, and I take a gap of 60 seconds and then try to send the data from client to server, then by this time the TCP server has crashed and it does not receive data.

If I keep sending data continuously then it does not crash, but if I take some time sending the next data, then TCP crashes.

 

can anyone suggest where I am going wrong 

I have been looking over the Internet to find solutions but any help/suggestions would be appreciated.

Thanks

  • Sign in to reply
  • Cancel
  • Former Member
    0 Former Member over 8 years ago

    Hi

    It is likely you are getting a TCP 'timeout' on the connection.

    I would suggest that if you are going to have extended periods where you are not sending data, make sure that the connection is closed by the client then re-opened when you need to send data again. Or take a close look at your software to see if there is a way that the server can break the connection. The reason for the server 'shut down' will be an if statement, where for example in the FreeRTOS+Lwip application that ships with Xilinx SDK for the Echo server;

    /* break if client closed connection */
    if (n <= 0)
    break;
     
    The above line will break the loop when nothing can be read from the incoming buffer, as 'n' is bytes read. The software assumes the client has closed the connection therefore returns to listening for a new connection. Without seeing your C code it is hard to give a definite answer.
     
    If this is a case, and you need to handle a pause in data, I would suggest that you remove the offending code and replace it with a suitable handle for timeout or closing the connection.
     
    Feel free to post a snippet of C code and I can have a look.
     
    All the best.
    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 8 years ago in reply to Former Member

    Thanks for the help.

    I have 3 functions in this code:

    1. start tcp application.

    2. Connection accept callback

    3. Data receive call back.

     

    Here is the actual C code:

     
    int start_application()
    {
    struct tcp_pcb *pcb;
    err_t err;
    unsigned port = 1004;
     
    /* create new TCP PCB structure */
    pcb = tcp_new();
    if (!pcb) {
    xil_printf("Error creating PCB. Out of Memory\n\r");
    return -1;
    }
     
    /* bind to specified @port */
    err = tcp_bind(pcb, IP_ADDR_ANY, port);
    if (err != ERR_OK) {
    xil_printf("Unable to bind to port %d: err = %d\n\r", port, err);
    return -2;
    }
     
    /* we do not need any arguments to callback functions */
    tcp_arg(pcb, NULL);
     
    /* listen for connections */
    pcb = tcp_listen(pcb);
    if (!pcb) {
    xil_printf("Out of memory while tcp_listen\n\r");
    return -3;
    }
     
    /* specify callback to use for incoming connections */
    tcp_accept(pcb, accept_callback);
     
    xil_printf("TCP echo server started @ port %d\n\r", port);
     
    return 0;
    }
     
     
     
      err_t accept_callback(void *arg, struct tcp_pcb *newpcb, err_t err)
      {
      static int connection = 1;
       
      /* set the receive callback for this connection */
      tcp_recv(newpcb, recv_callback);
       
      /* just use an integer number indicating the connection id as the
        callback argument */
      tcp_arg(newpcb, (void*)connection);
       
      /* increment for subsequent accepted connections */
      connection++;
       
      return ERR_OK;
      }
       
       
       
     
       err_t recv_callback(void *arg, struct tcp_pcb *tpcb,
     
                                      struct pbuf *p, err_t err)
     
       {
     
        
     
       /* do not read the packet if we are not in ESTABLISHED state */
     
       if (!p) {
     
       tcp_close(tpcb);
     
       tcp_recv(tpcb, NULL);
     
       return ERR_OK;
     
       }
     
       // Receiving data in a buffer
     
        
     
       pbuf_free(p);
     
       return ERR_OK;
     
       }

    Although the option you suggested about client closing the connection and reopening again when it wants to send data, sounds good.

    But, my application needs server to push some data to the client when it is connected, so if I close the connection it would not be a very good option.

    It would be great of you if you could suggest something on the connected client. 

    Thanks for the help.

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
  • Former Member
    0 Former Member over 8 years ago

    I can't see anything in your code which would break the connection on the client, unless the recv_callback is used when you are not in the established state, in which case you will be freeing the pbuf, which will likely terminate the connection.

    I have most experience with sockets and RTOS, I would recommend looking into it if your application is going to include more than a couple of network functions, all reasoning here: https://www.xilinx.com/video/soc/networking-with-lwip-focused-free-rtos.html

    As for the TCP Keep Alive, I would read this source to gain the understanding and use a packet sniffer program, such as Wireshark, to see why the connection is closed and by which end. That way you will be able to see where the issue is.

    http://tldp.org/HOWTO/TCP-Keepalive-HOWTO/overview.html

    A potentially easier 'high level' fix could be to make the client send a random packet periodically when no streaming is necessary, this could be used as a 'keep alive' to the TCP connection.

    Please note, I cannot be held responsible for any software installation that may or may not cause damage to the installed location. The installation of software is under discretion of the user and with the IT administrators permission.

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Verify Answer
    • Cancel
element14 Community

element14 is the first online community specifically for engineers. Connect with your peers and get expert answers to your questions.

  • Members
  • Learn
  • Technologies
  • Challenges & Projects
  • Products
  • Store
  • About Us
  • Feedback & Support
  • FAQs
  • Terms of Use
  • Privacy Policy
  • Legal and Copyright Notices
  • Sitemap
  • Cookies

An Avnet Company © 2025 Premier Farnell Limited. All Rights Reserved.

Premier Farnell Ltd, registered in England and Wales (no 00876412), registered office: Farnell House, Forge Lane, Leeds LS12 2NE.

ICP 备案号 10220084.

Follow element14

  • X
  • Facebook
  • linkedin
  • YouTube