Question

pthread_join on Linux crashes on segmentation fault

Asked by: optimaltest

Hi,

I'm getting a segmentation fault when trying to run pthread_join on Linux.
On my program, the main function calls several threads that do all the work.
to prevent the main function from exiting prematurely, the main uses pthread_join.
When waiting for the first thread in line, there is a segmentation fault.

thread creation
 
//
// Call Unix / Linux native API to create thread
//
OT_THREAD_HANDLE OT_CreateThread(	
	void *(*start_routine)(void *), // thread function  
	void *arg,						// argument to thread function						 	
	OT_THREAD_HANDLE *CreatedThreadHandle		// not in use in windows code
)
{
	pthread_create(
			CreatedThreadHandle,
			NULL,
			start_routine,
			arg);
 
	//TODO: print thread details
 
	return CreatedThreadHandle;
}
 
pthread_join
//
// Waits until one or all of the specified objects are in the signaled state or the time-out interval elapses
//
OT_DWORD OT_WaitForThreads(
  OT_DWORD nCount,				
  OT_THREAD_HANDLE *pHandles,	
  OT_BOOL bWaitAll,			
  OT_DWORD dwMilliseconds		
)
{
	void *threadResult;
	int res,i;
 
	res = 0 ;
	for(i = 0 ; i < nCount ; i++)
	{
		res = pthread_join( pHandles[i] , &threadResult );
		if(res != 0) //error
		{
			break;
		}
	}
 
	return (OT_DWORD)res;
}

                                  
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:

Select allOpen in new window

This Question has been solved and asker verified All Experts Exchange premium technology solutions are available to subscription members.

Subscribe now for full access to Experts Exchange and get

Instant Access to this Solution

  • Plus...
  • 30 Day FREE access, no risk, no obligation
  • Collaborate with the world's top tech experts
  • Unlimited access to our exclusive solution database
  • Never be left without tech help again

Subscribe Now

Asked On
2009-04-07 at 00:22:42ID24300959
Tags

pthread_join

,

C

,

threads

,

Linux

Topic

C Programming Language

Participating Experts
3
Points
500
Comments
20

Trusted by hundreds of thousands everyday for fast, accurate and reliable tech support.

  • "The time we save is the biggest benefit of Experts Exchange to Warner Bros. What could take multiple guys 2 hours or more each to find is accessed in around 15 minutes on Experts Exchange." Mike Kapnisakis, Warner Bros.
  • "Our team likes having a resource that is more secure than just using Google and most experts using this service really know their stuff. It's nice to look here first versus using Google." Dayna Sellner, Lockheed Martin
  • "Anytime that I've been stumped with a problem, 9 out of 10 times Experts Exchange has either the accepted solution or an open discussion of the potential solution to the problem." Kenny Red, eBay Inc.

See what Experts Exchange can do for you.

Got a question?

We've got the answer.

Experts Exchange has been collecting answers to technology questions since 1996…3 million and counting! If you have a question, chances are we already have your answer.

Screenshot of Experts Exchange Knowledgebase

Need individual assistance?

Our experts are ready to help.

If you can't find the exact answer you're looking for, ask our exclusive community of 50,000 experts. You’ll get a personalized answer from a trusted professional.

Screenshot of Experts Exchange Knowledgebase

Want to learn from the best?

Read articles from industry experts.

Thousands of free tech tips, tricks, how-to’s and tutorials are available in our peer reviewed articles section. See for yourself how smart our experts are, no login required.

Screenshot of an Article

Working on a long term project?

Store your work and research.

Save solutions to your questions, answers you’ve discovered through searching plus helpful articles in your personal knowledgebase for easy future access.

Screenshot of Experts Exchange Knowledgebase

Access the answers to your technology questions today.

Subscribe Now

30-day free trial. Register in 60 seconds.

What Makes Experts Exchange Unique?

Members of the expert community talk about why the experience at Experts Exchange is different than what you will find anywhere else.

Trusted by the world's most respected brands.

image of each brand's logo

Faithfully serving IT professionals since 1996.

Experts Exchange Logo

Try it out and discover for yourself.

Subscribe Now

30-day free trial. Register in 60 seconds.

Related Solutions

  1. pipe possible between pthreads? (seg fault)
    I try to create a pipe to exchange data between different threads of the pthread library, but on the write statement to the pipe I get a segmentation fault. Find the code below. You may ask why I want to do this, the answer is that later I want to connect the read end to a fu...
  2. Pthreads
    Hi ! I am trying to use pthreads on Solaris. I can create a thread that runs sucessfully and from the calling function I issue a pthread_join which returns a success. The problem I have is that while monitoring the memory usage of the process using the top program when the ...
  3. pthreads
    i was trying to use a function pthreads_setconcurrency() defined in pthread.h it says undefined function the other functions work fine (pthread_create etc) I wanted to start more than one thread simultaneously any help ??
  4. segmentation fault when pthread_mutex_lock is called
    Dear Experts, I declared a linked-list structure as shown below: #define <pthread.h> ... struct InputQueueNode { struct RawPktBuff *pktinfo; struct InputQueueNode *InputQueueNextPtr; pthread_mutex_t lock; }; When the program ran until the foll...
  5. pthreads and signals
    I have a c++ code that creates two threads. The program is running constantly, so I wanted to stop is by ctr+c (as opposed to kill, because I wanted to save some files and other logging stuff). I also wanted to be notified of segmentation faults. What I did was something lik...
  6. Pthread scheduling RR and FIFO problem
    Here is what I understood from the manual pages about setting the schedule priority and policy: In a given priority level, if FIFO scheduling is used, a process runs unless a thread that has higher priority is active, that is threads run first in first out in a given priorit...

Free Tech Articles

  1. WARNING: 5 Reasons why you should NEVER fix a computer for free.
    It is in our nature to love the puzzle. We are obsessed. The lot of us. We love puzzles. We love the challenge. We thrive on finding the answer. We hate disarray. It bothers us deep in our soul. W...
  2. SCCM OSD Basic troubleshooting
    SCCM 2007 OSD is a fantastic way to deploy operating systems, however, like most things SCCM issues can sometimes be difficult to resolve due to the sheer volume of logs to sift through and the dispe...
  3. Migrate Small Business Server 2003 to Exchange 2010 and Windows 2008 R2
    This guide is intended to provide step by step instructions on how to migrate from Small Business Server 2003 to Windows 2008 R2 with Exchange 2010. For this migration to work you will need the fo...
  4. Create a Win7 Gadget
    This article shows you how to create a simple "Gadget" -- a sort of mini-application supported by Windows 7 and Vista. Gadgets can be dropped anywhere on the desktop to provide instant information, ...
  5. Outlook continually prompting for username and password
    There have been a lot of questions recently regarding Outlook prompting for a username and password whilst using Exchange 2007. There are a few reasons why this would happen and I will try to cover t...
  6. Backup Exchange 2010 Information Store using Windows Backup
    There seems to be quite a lot of confusion around the ability to backup Exchange 2010 using the built in Windows Backup feature. This stems from the omission of this feature prior to Exchange 2007 s...

Cloud Class Webinars

  1. Avoiding Bugs in Microsoft Access
    Alison Balter takes and in-depth look at avoiding bugs in Access. In this webinar you will learn about using the immediate window to debug your applications, invoking the debugger, using breakpoints to troubleshoot, stepping through code, setting the next statement to execute, ...
  2. Top 10 Best New Features in Visio 2010
    Scott Helmers gives live demonstrations of the top 10 new features in Visio 2010. This webinar will teach you how to create compelling diagrams by adding shapes to the page with a single click, linking the shapes in a diagram to data in Excel (or SQL Server, or SharePoint), ...
  3. IT Consultant Business Secrets Revealed
    Michael Munger, Experts Exchange tech pro and IT consultant, pulls back the curtain on his very successful businesses and answers question on every IT consultant and business owner should know about. He shares secrets on what he did to solve the 5 most common problems in IT, ...
  4. Disaster Recovery and Business Continuity
    Quest CTO, Mike Billon, gives an overview of the steps involved in building a dunamic disaster recovery plan. Through case studies and an examination of software/hardware tooles for monitoring and testing, you'll gain a better understandin of where you are, where you want ...
  5. Organize Your Visio Diagrams with Containers and Lists
    Scott Helmers uses cross functional flowcharts, wireframe diagrams, data graphic legends and seating charts to teach you: how to ustilize all three new structured diagram components in Visio 2010, the best practices for organizeing shapes in previous version of Visio, how to organize ...
  6. How to Us Objects, Properties, Events and Methods in Microsoft Access
    Alison Dalter gives an in-depbth look at objects, properties, events and methods in Microsoft Access. In this webinar you will learn about using the object browser, referring to objects, working with properties and methods, working with object variables, understanding the ...

Join the Community

Give a Little. Get a Lot.

Join the community of experts here and help other tech pros by answering question in your area of expertise. You can earn FREE access to all Experts Exchange's premium features and resources.

Join the Community

Answers

 

by: Infinity08Posted on 2009-04-07 at 01:14:11ID: 24084867

(a) How is OT_THREAD_HANDLE defined ? It should be pthread_t.

(b) You don't check the return value of pthread_create ... How will you know if it failed ?

(c) Did you verify that pHandles actually contains nCount valid pthread_t's referring to existing threads ? Can you show the code that actually calls these functions.

 

by: murugesandinsPosted on 2009-04-07 at 04:38:53ID: 24086064

use the following command:
               ulimit -c unlimited
The core file will be created.
let us know the output of the following command:
               gdb binaryName coreFileName

 

by: murugesandinsPosted on 2009-04-07 at 04:42:56ID: 24086098

gdb binaryFileName coreFileName
gdb) where

 

by: optimaltestPosted on 2009-04-07 at 04:50:49ID: 24086158

Answer to Genius:
typedef pthread_t OT_THREAD_HANDLE;

 

by: Infinity08Posted on 2009-04-07 at 04:57:30ID: 24086194

How about (b) and (c) ?

Generating the core file like murugesandins suggested will allow you to see the exact location of the segmentation fault, so that's a good idea too.

 

by: optimaltestPosted on 2009-04-07 at 05:57:48ID: 24086745

Core dump file is not created. The where command output is as follow:

Program received signal SIGSEGV, Segmentation fault.
0x007c777b in __deallocate_stack () from /lib/tls/libpthread.so.0
(gdb) where
#0  0x007c777b in __deallocate_stack () from /lib/tls/libpthread.so.0
#1  0x007c7d2b in __free_tcb () from /lib/tls/libpthread.so.0
#2  0x007c8d9f in pthread_join () from /lib/tls/libpthread.so.0
#3  0x0804b73a in OT_WaitForThreads (nCount=4, pHandles=0x81efef8, bWaitAll=1, dwMilliseconds=0) at OTThread.c:80
#4  0x0804a89e in EngineCleanUp () at Engine.c:106
#5  0x0804a962 in main () at Engine.c:138
(gdb)

 

by: Infinity08Posted on 2009-04-07 at 06:00:13ID: 24086775

That seems to indicate that your heap got corrupted. That could have happened anywhere and anytime. Check whether you can spot any obvious buffer overflows, or other write operations to unallocated (or simply wrong) memory. If you can't spot it immediately, I suggest using a memory debugger to find the problem for you.

 

by: Infinity08Posted on 2009-04-07 at 06:01:38ID: 24086793

That is, assuming you've already eliminated (b) and (c) I've mentioned earlier ... (you still haven't replied to that)

 

by: optimaltestPosted on 2009-04-07 at 06:33:24ID: 24087119

Answer for b:

There is no return value. The application crashes within the function.

Answer for c:

I derify that ThreadArray holds the number of the threads expected. the code you asked for is attached.

BTW - Since the general code in the application is crosspatform and since in Windows i seo problem with this application i'm pretty sure this is pure Linux / Unix pthread_join related issue.

 

by: Infinity08Posted on 2009-04-07 at 06:40:25ID: 24087187

>> There is no return value. The application crashes within the function.

Of course there is a return value ... It returns int.
The crash you mentioned was not in pthread_create, but in pthread_join. pthread_create happens before pthread_join (or at least it should), and my remark was about pthread_create's return value not being checked. As long as you don't do so, you can't know whether the creation of the thread failed or not (which could cause problems later, including the crash you experience).


>> I derify that ThreadArray holds the number of the threads expected.

And are all entries in the array valid ?


>> the code you asked for is attached.

You must have forgotten it, as I can't see it ;)


>> i'm pretty sure this is pure Linux / Unix pthread_join related issue.

I'm not ... There's a LOT of differences between a Windows and a Linux platform, so just because the problem occurs on one platform and not on the other, does not mean that you can immediately point to one function as the problem.

 

by: optimaltestPosted on 2009-04-07 at 07:01:45ID: 24087425

Hre is the code:
for(i = 0 ; i < MAX_THREAD ; i++)
      {
            if(ThreadArray[i] == NULL)
            {
                  waitForAllThreads = 0;
                  break;
            }
      }

      if(      0 != waitForAllThreads)
      {
            // DON'T wait for the listen thread it is block by the read command
            // Make sure Listen thread is always the last one on the handle array
            OT_WaitForThreads(MAX_THREAD-1, ThreadArray, 1 /*TRUE*/, INFINITE);
      }      

 

by: Infinity08Posted on 2009-04-07 at 07:10:19ID: 24087506

You're comparing a pthread_t with NULL here ... :

>>             if(ThreadArray[i] == NULL)

pthread_t is not a pointer.

The code you posted also doesn't show how ThreadArray is constructed and filled.

 

by: optimaltestPosted on 2009-04-07 at 07:18:46ID: 24087593

LoggerAddMessage( PROXY_LOG_LEVEL_ANALYSIS , FLUSH_TO_DISK,"EngineInit - Start ...\n" ) ;
      QueueInit(&messageQ);
      QueueInit(&writeQ);
      QueueInit(&transmitQ);
      
      strcpy(messageQ.qName , "MessageQ");
      messageQ.hMutex = OT_CreateMutex(messageQ.qName);

      strcpy(writeQ.qName , "WriteQ");
      writeQ.hMutex = OT_CreateMutex(writeQ.qName);

      strcpy(transmitQ.qName , "TransmitQ");
      transmitQ.hMutex = OT_CreateMutex(transmitQ.qName);

      ThreadArray[WORKER_THREAD] = OT_CreateThread( MessageQWorkerThread,            // thread function
                                                        &messageQ,                                          // argument to thread function                                     
                                                        &ThreadArray[WORKER_THREAD]);                  // The pointer that will store the thread handle - in use only in non windows systems

      ThreadArray[WRITER_THREAD] = OT_CreateThread(      MessageQWriterThread,      // thread function
                                                            &writeQ,                                          // argument to thread function
                                                            &ThreadArray[WRITER_THREAD]);            // The pointer that will store the thread handle - in use only in non windows systems

      ThreadArray[TRANSMIT_THREAD] = OT_CreateThread(      MessageQTransmitThread,      // thread function
                                                            &transmitQ,                                          // argument to thread function
                                                            &ThreadArray[TRANSMIT_THREAD]);            // The pointer that will store the thread handle - in use only in non windows systems

      ThreadArray[CMT_THREAD] = OT_CreateThread(      CMTThread,                              // thread function
                                                                        &messageQ,                                          // argument to thread function
                                                                        &ThreadArray[TRANSMIT_THREAD]);            // The pointer that will store the thread handle - in use only in non windows systems

      
      // Make sure Listen thread is always the last one on the handle array - refer to the comment in the EngineCleanup
      ThreadArray[LISTEN_THREAD] = OT_CreateThread(      ListeningThread,            // thread function
                                                                              &messageQ,                                          // argument to thread function
                                                                              &ThreadArray[LISTEN_THREAD]);            // The pointer that will store the thread handle - in use only in non windows systems

 

by: Infinity08Posted on 2009-04-07 at 07:35:52ID: 24087765

I assume that MAX_THREAD is equal to 5, and that WORKER_THREAD, WRITER_THREAD, TRANSMIT_THREAD, CMT_THREAD and LISTEN_THREAD are 0, 1, 2, 3 and 4 resp. ?

Ok.

I can see a typo here though :

>>       ThreadArray[CMT_THREAD] = OT_CreateThread(      CMTThread,                              // thread function
>>                                                                         &messageQ,                                          // argument to thread function
>>                                                                         &ThreadArray[TRANSMIT_THREAD]);            // The pointer that will store the thread handle - in use only in non windows systems

which should be :

      ThreadArray[CMT_THREAD] = OT_CreateThread(      CMTThread,                              // thread function
                                                                        &messageQ,                                          // argument to thread function
                                                                        &ThreadArray[CMT_THREAD]);            // The pointer that will store the thread handle - in use only in non windows systems


If the problem still persists after that, then do not forget to check the return value of each pthread_create, and to fix this :

>>             if(ThreadArray[i] == NULL)

as I remarked earlier.


If all of that doesn't get you closer to the solution, then it's time to bring out the memory debugger :)

 

by: itsmeandnobodyelsePosted on 2009-04-07 at 07:44:55ID: 24087861

Just in case some one is interested in a formatted code snippet ...

   LoggerAddMessage( PROXY_LOG_LEVEL_ANALYSIS , FLUSH_TO_DISK,"EngineInit - Start ...\n" ) ;
   QueueInit(&messageQ);
 
   QueueInit(&writeQ);
   QueueInit(&transmitQ);
 
   strcpy(messageQ.qName , "MessageQ");
   messageQ.hMutex = OT_CreateMutex(messageQ.qName);
 
   strcpy(writeQ.qName , "WriteQ");
   writeQ.hMutex = OT_CreateMutex(writeQ.qName);
 
   strcpy(transmitQ.qName , "TransmitQ");
   transmitQ.hMutex = OT_CreateMutex(transmitQ.qName);
 
   ThreadArray[WORKER_THREAD] = 
      OT_CreateThread( MessageQWorkerThread,          
                      &messageQ,                      
                      &ThreadArray[WORKER_THREAD]);    
 
   ThreadArray[WRITER_THREAD] = 
      OT_CreateThread(MessageQWriterThread,           
                      &writeQ,                        
                      &ThreadArray[WRITER_THREAD]);    
 
   ThreadArray[TRANSMIT_THREAD] = 
      OT_CreateThread(MessageQTransmitThread,         
                      &transmitQ,                     
                      &ThreadArray[TRANSMIT_THREAD]);  
 
   ThreadArray[CMT_THREAD] = 
      OT_CreateThread(CMTThread,                      
                      &messageQ,                      
                      &ThreadArray[TRANSMIT_THREAD]);  
 
 
   ThreadArray[LISTEN_THREAD] = 
      OT_CreateThread(ListeningThread,                
                      &messageQ,                      
                      &ThreadArray[LISTEN_THREAD]);    
                                              
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:

Select allOpen in new window

 

by: itsmeandnobodyelsePosted on 2009-04-07 at 07:48:59ID: 24087908

>>>> I can see a typo here though :

Good catch, Infinity  ;-)

Should be possible that

         ThreadArray[TRANSMIT_THREAD]);  

has the wrong handles and

         ThreadArray[CMT_THREAD]

is uninitialized.

Could be enough to make the system crash.

 

by: optimaltestPosted on 2009-04-07 at 09:00:40ID: 24088756

Good catch with the typo. I'm sure it solved some future problem, but It didn't help this issue.

I've added a line "res = pthread_create(...)" to see the result. They all get 0.
I can also see that ThreadArray has 5 consequtive values

I'll start working with a memory debugger then

// Number of threads in the application 
#define MAX_THREAD			5
// Assign ID's to the applicaion threads
#define WORKER_THREAD		0
#define WRITER_THREAD		1
#define TRANSMIT_THREAD		2
#define CMT_THREAD			3
#define	LISTEN_THREAD		4

                                              
1:
2:
3:
4:
5:
6:
7:
8:

Select allOpen in new window

 

by: Infinity08Posted on 2009-04-07 at 09:52:18ID: 24089362

>> I'll start working with a memory debugger then

Likely candidates to look for are buffer overflows.

 

by: optimaltestPosted on 2009-04-07 at 10:13:01ID: 24089616

I've run valgrind memory check, and it helped me see that the CreatedThreadHandle thread is actually lost (and used redundantly).
I fixed it and it stop falling on segmentation.

 

by: Infinity08Posted on 2009-04-07 at 10:23:46ID: 24089742

Great :) Glad you found it !

20120131-EE-VQP-002

3 Ways to Join

30-Day Free Trial

The Experts

98% positive feedback on 31,087 answers since March 2000. angeliii is a Microsoft Most Valuable Professional for his work with MS SQL Server & Develoment.

He has also proven his knowledge of Visual Basic Programming, PHP Scripting and Oracle Databases.

The Experts

97% positive feedback on 10,752 answers since July 2000. lrmoore has more than 18 years experience in the networking industry.

The six-time Mircosoft MVPs specialties include firewalls, virtual private networking, and network management.

Testimonials

"...and excellent source for support... Kind of like having your very own IT dept." Electriciansnet

Testimonials

"I was apprehensive at signing up at first. However... it has already made my life as an IT administrator much easier." JaCrews

Testimonials

"WOW! You guys have great, active, and knowledgeable people on here." moore50

Business Clients

Business Clients

In the Press

"If you’ve got a question... Experts Exchange can supply an answer.”

In the Press

"...an invaluable aid for both IT professionals and those who require tech support."

In the Press

"where IT professionals provide quick answers on just about any topic"

Business Account Plans

Loading Advertisement...