我正在开发一个在C中实现IRC守护进程的项目。这仍然处于一个非常早期的开发阶段,它现在所做的就是接受主进程上的新连接,并且对于每个新连接,它创建一个线程。来自任何客户端的每条消息都会广播给所有其他连接的客户端。
我正在使用libev的回调机制,以便线程不会阻塞套接字读取。每个线程都使用自己独立的事件循环。这是我main()
函数的一部分:
int main(int argc, char *argv[]) {
int portno = 6667;
/* Libev stuff */
struct ev_loop *loop = EV_DEFAULT;
struct ev_io socket_watcher;
/* Here, I create a socket called mainsock_fd, and then call bind() and listen()
...
*/
/* At this point, we're ready to accept new clients. Set the callback function for new connections */
ev_io_init(&socket_watcher, connection_cb, mainsock_fd, EV_READ);
ev_io_start(loop, &socket_watcher);
/* This is where the problem lies */
ev_loop(loop, 0);
/* ... */
return 0;
}
我不是解放专家。我一直在阅读libev的文档和示例程序。此代码完全按预期工作,但当我通过valgrind运行时,我收到此错误:
==20984== Command: ./yaircd
==20984==
==20984== Invalid read of size 1
==20984== at 0x40638D1: ev_run (in /usr/lib/libev.so.4.0.0)
==20984== by 0x804923F: ev_loop (ev.h:820)
==20984== by 0x8049410: main (yaircd.c:71)
==20984== Address 0xbedf52df is just below the stack ptr. To suppress, use: --workaround-gcc296-bugs=yes
第71行是这条指令:
ev_loop(loop, 0);
启动程序后立即出现错误,没有连接客户端。我调用ev_loop
的事实导致了这个错误。
我不知道如何修复它。到目前为止我编写的代码将成为IRC服务器的核心,我想绝对确定没有错误存在。我想要一个干净的valgrind输出。
有什么建议吗?
UPDATE :我编译并执行了他们的示例程序(http://pod.tst.eu/http://cvs.schmorp.de/libev/ev.pod#EXAMPLE_PROGRAM),valgrind报告了相同的错误。我猜这是libev
中的一些错误,或者示例没有正确编码。我还阅读了关于valgrind的部分 - http://pod.tst.eu/http://cvs.schmorp.de/libev/ev.pod#VALGRIND - 但没有发现它有什么特别之处。我想我会尝试他们的邮件列表。
答案 0 :(得分:2)
之前在libev
的邮件列表中提交了类似的问题(请参阅http://lists.schmorp.de/pipermail/libev/2013q2/002172.html)。
根据开发人员的说法,这是valgrind
中的一个无害的错误,正如本回复中所指出的:http://lists.schmorp.de/pipermail/libev/2013q2/002173.html
不,这只是valgrind中的一个(无害的)错误,显然 无法正确识别锁定前缀,或者某些东西。
它不会影响valgrind内外的正确性。