微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

两个线程在一个内核上工作正常,但在两个单独的内核上出错

如何解决两个线程在一个内核上工作正常,但在两个单独的内核上出错

我正在通过将 lwIP 与 DPDK 集成来创建应用程序。我正在使用套接字级 API。从接口接收数据包和处理,有两个线程。

Thread-1:从接口接收数据包,调用pbuf_alloc将数据包数据转入pbuf(lwIP buffer struct),然后调用netif->input(将数据包传递给IP栈的函数)。

Thread-2:lwIP 核心线程:tcpip_thread(所有 TCPIP 堆栈处理都在此线程中)。

如果我在一个内核上运行两个线程,它们就可以正常工作。但是,如果我使用 pthread_setaffinity_np() 在单独的内核上运行两者,它会在大约 5 分钟后出现错误错误是:

断言“memp sanity”在 ../lwip/contrib/../src/core/memp.c 中的第 389 行失败

我试图在 google 上找到问题,但只找到了一个 relevant article,但他们没有解决这个问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。