Subject: [Boost-bugs] [Boost C++ Libraries] #12298: epool_wait hang
From: Boost C++ Libraries (noreply_at_[hidden])
Date: 2016-06-23 10:22:34
#12298: epool_wait hang
----------------------------------+----------------------------
Reporter: baibin <406455861@â¦> | Owner: chris_kohlhoff
Type: Bugs | Status: new
Milestone: To Be Determined | Component: asio
Version: Boost 1.53.0 | Severity: Problem
Keywords: epool_wait |
----------------------------------+----------------------------
We use sofarpc (https://github.com/baidu/sofa-pbrpc ) which uses boost
asio as network lib.
code like
boost::asio::io_service io_ser;
auto work = new boost::asio::io_service::work(io_ser);
after I delete work, io_ser still in run function and never stop.
so i print io_ser class member as below
(gdb) p *(boost::asio::detail::task_io_service * const) 0x22738e0
$26 =
{<boost::asio::detail::service_base<boost::asio::detail::task_io_service>>
= {<boost::asio::io_service::service> =
{<boost::noncopyable_::noncopyable> = {<No data fields>},
_vptr.service = 0xa24a90 <vtable for
boost::asio::detail::task_io_service+16>, key_ = {type_info_ = 0xa245a0
<typeinfo for
boost::asio::detail::typeid_wrapper<boost::asio::detail::task_io_service>>,
id_ = 0x0}, owner_ = @0x228f6d0, next_ = 0x0}, static id =
{<boost::asio::io_service::id> = {<boost::noncopyable_::noncopyable> =
{<No data fields>}, <No data fields>}, <No data fields>}},
one_thread_ = false, mutex_ = {<boost::noncopyable_::noncopyable> = {<No
data fields>}, mutex_ = {__data = {__lock = 0, __count = 0, __owner = 0,
__nusers = 7, __kind = 0, __spins = 0, __list = {
__prev = 0x0, __next = 0x0}}, __size = '\000' <repeats 12
times>, "\a", '\000' <repeats 26 times>, __align = 0}}, task_ = 0x2266e10,
task_operation_ = {<boost::asio::detail::task_io_service_operation> =
{next_ = 0x0, func_ = 0x0, task_result_ = 0}, <No data fields>},
task_interrupted_ = false, outstanding_work_ = {value_ = 3},
op_queue_ = {<boost::noncopyable_::noncopyable> = {<No data fields>},
front_ = 0x0, back_ = 0x0}, stopped_ = false, shutdown_ = false,
first_idle_thread_ = 0x7f182991fce0}
and I found one of the thread stack as belows
Thread 6 (Thread 0x7f182a321700 (LWP 30142)):
#0 0x00007f1833fb2163 in epoll_wait () from /lib64/libc.so.6
#1 0x000000000061f888 in boost::asio::detail::epoll_reactor::run
(this=0x2266e10, block=<optimized out>, ops=...) at
/usr/local/include/boost/asio/detail/impl/epoll_reactor.ipp:392
#2 0x0000000000624671 in boost::asio::detail::task_io_service::do_run_one
(ec=..., this_thread=..., lock=..., this=0x22738e0) at
/usr/local/include/boost/asio/detail/impl/task_io_service.ipp:396
#3 boost::asio::detail::task_io_service::run (this=0x22738e0, ec=...) at
/usr/local/include/boost/asio/detail/impl/task_io_service.ipp:153
#4 0x000000000062521e in boost::asio::io_service::run (this=0x228f6d0) at
/usr/local/include/boost/asio/impl/io_service.ipp:59
#5 sofa::pbrpc::ThreadGroupImpl::thread_run (param=0x22bf100) at
src/sofa/pbrpc/thread_group_impl.h:263
#6 0x00007f1834e7a9d1 in start_thread () from /lib64/libpthread.so.0
#7 0x00007f1833fb1b6d in clone () from /lib64/libc.so.6
because of its hanging, i want see if i see time_out parameter of
epoll_wait function is -1.
so i print epoll_reactor::timer_fd_
(gdb) p timer_fd_
$6 = 515
so we don't use time_out a normal value .
so why epoll_wait never has a return ??
-- Ticket URL: <https://svn.boost.org/trac/boost/ticket/12298> Boost C++ Libraries <http://www.boost.org/> Boost provides free peer-reviewed portable C++ source libraries.
This archive was generated by hypermail 2.1.7 : 2017-02-16 18:50:20 UTC