LWIP TCP客户端传输由于“ MEM PBUF_POOL”达到最大值而停止

时间:2020-08-25 08:57:14

标签: lwip

我正在使用LwIPstack(和FreeRtos)为STM32F7系统制作一个TCP客户端程序,并且可以很好地连接到服务器,但是我只能传输8条消息。似乎是因为“ MEM PBUF_POOL”达到了最大值。似乎在发送消息并关闭连接后,PBUF永远不会释放。

由于我不是自己分配PBUF,而是使用高级LwIP TCP函数,所以我没有PBUF指针,所以无法释放它。

有人知道释放PBUF需要什么吗?。

打印LwIP统计信息时,我可以看到所有的“ MEM PBUF_POOL”都已使用(如下所示):

MEM PBUF_POOL
avail: 8
used: 8
max: 8
err: 126

供参考,我的代码如下所示:

static uint32_t tcp_send_packet(struct tcp_pcb *pcb)
{
    static auto cnt = 0;
    string string = "Hej Med Dig:" + std::to_string(cnt++);
    const uint32_t len = string.length();

    err_t error = tcp_write(pcb, &string.c_str()[0], len, TCP_WRITE_FLAG_COPY);
    if (error) {
        TRACE("tcp", T_E,  "tcp_write - Code: %d\n", error);
        return error;
    }

    error = tcp_output(pcb);
    if (error) {
        TRACE("tcp", T_E,  "tcp_output - Code:%d\n", error);
    }
    return error;
}

err_t connectCallback(void *arg, struct tcp_pcb *tpcb, err_t err)
{
    TRACE("tcp", T_E, "Connection Established.\n");
    return ERR_OK;
}

err_t tcpRecvCallback(void *arg, struct tcp_pcb *tpcb, struct pbuf *p, err_t err)
{
    TRACE("tcp", T_E,"Data recieved.\n");
    if (p == NULL) {
        TRACE("tcp", T_E, "The remote host closed the connection.\n");
        //tcp_close_con();
        return ERR_ABRT;
    } else {
        TRACE("tcp", T_E,"pbufs %d - pbuf %s\n", pbuf_clen(p), (char *)p->payload);
    }
    return ERR_OK;
}

static void tcpErrorHandler(void *arg, const  err_t err) {
    TRACE("tcp", T_E,"Err:%d\n", err);
}

static void client_close(struct tcp_pcb *pcb)
{
   tcp_arg(pcb, NULL);
   tcp_sent(pcb, NULL);
   tcp_close(pcb);
}

err_t tcpSendCallback(void *arg, struct tcp_pcb *tpcb, u16_t len) {
    TRACE("tcp", T_E,"Data sent.\n");
    return ERR_OK;
}

void msgClientTask(void *arg) {
    vTaskDelay(1000);
    struct ip4_addr ip;
    while (1) {
        IP4_ADDR(&ip, 192,168, 10 ,100);    //IP of my server
        tcp_pcb *pcb = tcp_new();
        tcp_err(pcb, tcpErrorHandler);
        tcp_recv(pcb, tcpRecvCallback);
        tcp_sent(pcb, tcpSendCallback);
        tcp_connect(pcb, &ip, 4002, connectCallback);
        tcp_send_packet(pcb);
        vTaskDelay(100);
        client_close(pcb);
        vTaskDelay(100);
    }
}
  

1 个答案:

答案 0 :(得分:0)

我认为您需要在使用数据后调用tcp_recved并使用pbuf_free中的tcpRecvCallback释放传递的pbuf

err_t tcpRecvCallback(void *arg, struct tcp_pcb *tpcb, struct pbuf *p, err_t err)
{
    if (p == NULL) {
        tcp_close_con();
        return ERR_ABRT;
    } else {
        // use data in pbuf p here            

        // Acknowledge received data and free pbuf
        tcp_recved(tpcb, p->len);
        pbuf_free(p);
    }
    return ERR_OK;
}