Thread changes from Boost 1.38 to 1.45
data:image/s3,"s3://crabby-images/31d7a/31d7ab3b3a6f6f35c6ca55c9eaba9db24382ce60" alt=""
Hi, We upgraded our project from using Boost 1.38 to Boost 1.45 but now seem to be having some thread issues. The error doesn't happen for every run, but occasionally the wait method in condition_variable_any fails. At other times the program seems to run into an infinite loop, presumably waiting for a lock that's never released. I looked at the changes in http://www.boost.org/doc/libs/1_45_0/doc/html/thread/changes.html but don't see what could be causing the error to occur only after upgrading to Boost 1.45. Has anyone else experienced their code breaking when upgrading to the latest version of Boost? Thanks, Ven
data:image/s3,"s3://crabby-images/2d876/2d8761f822017f8aa245a528aea60188ebc194c6" alt=""
Ven Tadipatri
Hi, We upgraded our project from using Boost 1.38 to Boost 1.45 but now seem to be having some thread issues. The error doesn't happen for every run, but occasionally the wait method in condition_variable_any fails. At other times the program seems to run into an infinite loop, presumably waiting for a lock that's never released. I looked at the changes in http://www.boost.org/doc/libs/1_45_0/doc/html/thread/changes.html but don't see what could be causing the error to occur only after upgrading to Boost 1.45. Has anyone else experienced their code breaking when upgrading to the latest version of Boost?
This seems similar to the problems people have experience with boost::this_thread::sleep (which I cannot reproduce), which relies on condition_variable::timed_wait. I don't think anything significant has changed in that area, so it surprises me that you are experiencing problems only after upgrading. Can you give more information about the problem? A small sample application that demonstrates it would be nice. Anthony -- Author of C++ Concurrency in Action http://www.stdthread.co.uk/book/ just::thread C++0x thread library http://www.stdthread.co.uk Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk 15 Carrallack Mews, St Just, Cornwall, TR19 7UL, UK. Company No. 5478976
data:image/s3,"s3://crabby-images/31d7a/31d7ab3b3a6f6f35c6ca55c9eaba9db24382ce60" alt=""
Our application is quite large and it's hard to determine what exactly
is triggering the error. But the exception itself happens in the wait
method in condition_variable_any.
Actually, I do seem some calls to timed_wait so I think I might be
running into similar errors. Could you point me to how others have
resolved the problem?
The error message that's displayed is:
terminate called after throwing an instance of
'boost::exception_detail::clone_impl
' what(): boost::lock_error And I've confirmed that the error only exists when using Boost 1.45, not Boost 1.38.
Here is what the wait method looks like in Boost 1.45:
template<typename lock_type>
void wait(lock_type& m)
{
int res=0;
{
thread_cv_detail::lock_on_exit
Ven Tadipatri
writes: Hi, We upgraded our project from using Boost 1.38 to Boost 1.45 but now seem to be having some thread issues. The error doesn't happen for every run, but occasionally the wait method in condition_variable_any fails. At other times the program seems to run into an infinite loop, presumably waiting for a lock that's never released. I looked at the changes in http://www.boost.org/doc/libs/1_45_0/doc/html/thread/changes.html but don't see what could be causing the error to occur only after upgrading to Boost 1.45. Has anyone else experienced their code breaking when upgrading to the latest version of Boost? This seems similar to the problems people have experience with boost::this_thread::sleep (which I cannot reproduce), which relies on condition_variable::timed_wait.
I don't think anything significant has changed in that area, so it surprises me that you are experiencing problems only after upgrading.
Can you give more information about the problem? A small sample application that demonstrates it would be nice.
Anthony
data:image/s3,"s3://crabby-images/c7ddd/c7dddabaaaa3e7a7b8dd49a44a27b796590d9516" alt=""
On 1:59 PM, Anthony Williams wrote:
Ven Tadipatri
writes: Hi, We upgraded our project from using Boost 1.38 to Boost 1.45 but now seem to be having some thread issues. [...] Has anyone else experienced their code breaking when upgrading to the latest version of Boost? This seems similar to the problems people have experience with boost::this_thread::sleep (which I cannot reproduce), which relies on condition_variable::timed_wait.
Ven: What platform (operating system and compiler) are you using?
data:image/s3,"s3://crabby-images/31d7a/31d7ab3b3a6f6f35c6ca55c9eaba9db24382ce60" alt=""
I'm using CentOs 5.4 and gcc 4.1.2. Any idea what changes to Boost were
done that could affect it?
I did have to make code changes to get it to compile, but they were
related to virtualization. Would code like this have any impact on the
way boost's thread locking mechanism works?
//this had to be added for various header files otherwise "no unique
final overrider" errors would be thrown
//but it wasn't needed for Boost 1.38
namespace boost{
template<>
struct is_virtual_base_of
On 1:59 PM, Anthony Williams wrote:
Ven Tadipatri
writes: Hi, We upgraded our project from using Boost 1.38 to Boost 1.45 but now seem to be having some thread issues. [...] Has anyone else experienced their code breaking when upgrading to the latest version of Boost? This seems similar to the problems people have experience with boost::this_thread::sleep (which I cannot reproduce), which relies on condition_variable::timed_wait. Ven: What platform (operating system and compiler) are you using?
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/6fce8/6fce82352e3055d630a1f630b992a5cf22bb3066" alt=""
We have code which checks to see if a thread is joinable. If so, it's interrupted. I suspect that behavior may have changed with the later versions of Boost. boost::thread is quite simple component, just start your code in debugger and see where it fails. What's the point to guess if you don't provide details
-- Slava
data:image/s3,"s3://crabby-images/e13c8/e13c81d52afdf95a8409872ba39f90ad43222c69" alt=""
On 2/2/2011 2:33 AM, Viatcheslav.Sysoltsev@h-d-gmbh.de wrote:
boost::thread is quite simple component, just start your code in debugger and see where it fails. What's the point to guess if you don't provide details
Yeah, nothing like adding in a debugger to change the race conditions and hide your bugs. If there's one word I would *not* use in reference to anything multi-threaded, it's "simple".
data:image/s3,"s3://crabby-images/6fce8/6fce82352e3055d630a1f630b992a5cf22bb3066" alt=""
boost::thread is quite simple component, just start your code in debugger and see where it fails. What's the point to guess if you don't provide details
Yeah, nothing like adding in a debugger to change the race conditions and hide your bugs.
c'mon, you're overreacting. The man have either exception or deadlock, try it few times in debugger to maybe catch the exception; in case of deadlock is more simple, start it as is, when it frezes, attach the debugger and dissect. Run through valgrind if the bug is soooooo elusive. Anyway you should have some data on hand, it's act of desperation to ask what might have changed in boost::thread during few last *years*.
If there's one word I would *not* use in reference to anything multi-threaded, it's "simple".
Not going to dispute about it, but I meant 'simple' in regard to the fact, that boost::thread is a little wrapper around pthread functionality (in pthread case). The source code is not as hard to comprehend as in some other boost parts ;) -- Slava
data:image/s3,"s3://crabby-images/31d7a/31d7ab3b3a6f6f35c6ca55c9eaba9db24382ce60" alt=""
It appears the problem has to do with the thread being interrupted. For some reason in Boost 1.45, when a thread is given the interrupt command, it's either ignored, or something is prevented from checking for the interrupt. The only change I can see in the interrupt method is the acquisition of an internal lock (line 414 in thread.cpp in Boost 1.45): boost::pthread::pthread_mutex_scoped_lock internal_lock(local_thread_info->cond_mutex); This line isn't present in Boost 1.38. As a sort of hack I was able to call interrupt on the thread, then call sleep on that thread for 20 milliseconds (some arbitrary time). The documentation states there are interruption points, so the thread only interrupts when it reaches one of those points: http://www.boost.org/doc/libs/1_45_0/doc/html/thread/thread_management.html#... Was this behavior changed so that now when interrupt is called on a thread it doesn't actually get interrupted until one of these other methods are called? Previously, when interrupt was called on a thread it would get interrupted immediately, so what's going on? Thanks, Ven On 02/02/2011 08:12 AM, Eric J. Holtman wrote:
On 2/2/2011 2:33 AM, Viatcheslav.Sysoltsev@h-d-gmbh.de wrote:
boost::thread is quite simple component, just start your code in debugger and see where it fails. What's the point to guess if you don't provide details
Yeah, nothing like adding in a debugger to change the race conditions and hide your bugs.
If there's one word I would *not* use in reference to anything multi-threaded, it's "simple". _______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/6fce8/6fce82352e3055d630a1f630b992a5cf22bb3066" alt=""
It appears the problem has to do with the thread being interrupted. For some reason in Boost 1.45, when a thread is given the interrupt command, it's either ignored, or something is prevented from checking for the interrupt. The only change I can see in the interrupt method is the acquisition of an internal lock (line 414 in thread.cpp in Boost 1.45): boost::pthread::pthread_mutex_scoped_lock internal_lock(local_thread_info->cond_mutex); This line isn't present in Boost 1.38. As a sort of hack I was able to call interrupt on the thread, then call sleep on that thread for 20 milliseconds (some arbitrary time). The documentation states there are interruption points, so the thread only interrupts when it reaches one of those points:
Umm, not sure if I got you correctly: you mean one of your thread waits in condition_variable_any::timed_wait() and second tries to interrupt it, which just does not seem to make any effect? Can you write a small test case demonstrating your problem?
http://www.boost.org/doc/libs/1_45_0/doc/html/thread/thread_management.html#... Was this behavior changed so that now when interrupt is called on a thread it doesn't actually get interrupted until one of these other methods are called? Previously, when interrupt was called on a thread it would get interrupted immediately, so what's going on?
The behavior was always such, the interrupt works only for predefined points. No signal black magick here ;) -- Slava
data:image/s3,"s3://crabby-images/6fce8/6fce82352e3055d630a1f630b992a5cf22bb3066" alt=""
Umm, not sure if I got you correctly: you mean one of your thread waits in condition_variable_any::timed_wait() and second tries to interrupt it, which just does not seem to make any effect? Can you write a small test case demonstrating your problem?
The following works as expected with boost 1.45:
#include <string>
#include
participants (5)
-
Anthony Williams
-
Eric J. Holtman
-
Jim Bell
-
Ven Tadipatri
-
Viatcheslav.Sysoltsev@h-d-gmbh.de