public inbox for pthreads-win32@sourceware.org
 help / color / mirror / Atom feed
From: Ross Johnson <rpj@ise.canberra.edu.au>
To: Alexander Terekhov <TEREKHOV@de.ibm.com>
Cc: pthreads-win32@sources.redhat.com
Subject: Re: pthread_mutex_timedlock problem
Date: Tue, 04 Mar 2003 00:56:00 -0000	[thread overview]
Message-ID: <3E63FA44.4020302@ise.canberra.edu.au> (raw)
In-Reply-To: <OF08F67B50.6E3D5A44-ONC1256CDE.005B2A90-C1256CDE.005B86B4@de.ibm.com>

Alexander Terekhov wrote:

>It seem to me that the "/*******/"-if-below shall be added to the 
>pthread_mutex_timedlock.c (after line 307).
>
>           LeaveCriticalSection(&mx->wait_cs);
>/*******/  if (!result) {
>/*******/     mx->recursive_count = 1;
>/*******/     mx->ownerThread = (mx->kind != PTHREAD_MUTEX_FAST_NP
>/*******/             ? pthread_self()
>/*******/             : (pthread_t) PTW32_MUTEX_OWNER_ANONYMOUS);
>/*******/  }
>           break;
>   }
>   case 2: /* abstime passed before we started to wait. */
>   {
>
>Or am I just missing and/or misunderstanding something?
>  
>
I was looking at it last night and also noticed this. I can't think of, 
or recall, any reason this would have been deliberately left out (the 
intention is explained in the comments in the code). My mistake.

The fix will be in CVS probably by the time you see this message, but it 
may not have been tested yet. Thanks Robert and Alexander.

Question:
As explained in the code comments, pthread_mutex_timedlock() is 
attempting a second grab at the lock [immediately] AFTER the timeout 
abstime. This is actually to simplify the code and reduce the overhead 
in managing the mutex's state. The way mutex state is being managed here 
results in the possibility of the lock being acquired as a natural 
consequence. The choice is then whether to keep the lock or give it up 
immediately. It is assumed that it's acceptible to keep the lock only 
because most applications assume/allow that absolute timeouts are a 
little fuzzy anyway. I think this would be true in nearly all cases. Is 
this reasonable and correct?

Ross

>regards,
>alexander.
>
>Sent by:        pthreads-win32-owner@sources.redhat.com
>To:     pthreads-win32@sources.redhat.com
>cc:      
>Subject:        pthread_mutex_timedlock problem
>
>
>Hello All,
>I'm working on an rw-mutex and found something like a dead lock when 
>testing timed lock functions.
>To be sure, I wrote a simple test program, which hangs up, too.
>after ~4 loops it's dead (on 1GHz P3, Win2k)
>Here it is:
>
>#include <windows.h>
>#include <sys/timeb.h>
>#include "lib/pthreads/pthread.h"
>#define DELAY                   200
>#define _log(what)              OutputDebugString( what )
>
>pthread_mutex_t mut;
>
>void * thread_proc_w( void * );
>
>int APIENTRY WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR 
>lpCmdLine, int nCmdShow )
>{
>        int i;
>        pthread_t th_w[2];
>        pthread_mutexattr_t m;
>        pthread_mutexattr_init( &m );
>        pthread_mutexattr_settype( &m, PTHREAD_MUTEX_NORMAL ); 
>//PTHREAD_MUTEX_RECURSIVE
>        pthread_mutex_init( &mut, &m );
>        pthread_mutexattr_destroy( &m );
>        for( i=0; i<2; i++ )
>                pthread_create( &th_w[i], NULL, thread_proc_w, (void *) i 
>);
>        while( 1 )
>                Sleep( 1000 );
>        return 0;
>}
>
>void * thread_proc_w( void * param )
>{
>        timespec ts;
>        _timeb tb;
>        while( 1 ) {
>                Sleep( 100 );
>                while( 1 ) {
>                        _ftime( &tb );
>                        ts.tv_sec = DELAY/1000 + tb.time;
>                        ts.tv_nsec = (DELAY%1000 + tb.millitm) * 1000000;
>
>                        int ret = pthread_mutex_timedlock( &mut, &ts ); 
>// this makes problems
>                        if( ret == 0 )
>                                break;
>                }
>                _log( param ? "\r\nL0" : "\r\nL1" );    //I'm alive
>                Sleep( 500 );
>                _log( param ? "u0" : "u1" );            //unlocking ...
>                pthread_mutex_unlock( &mut );
>        }
>        pthread_exit( 0 );
>        return 0;
>}
>
>-------------------------------
>
>(values in Sleep() do matter - some values work fine)
>After a few loops, the mutex 'mut' cannot be locked no more.
>Does anyone have any idea what's wrong ?
>
>Thanks,
>
>Robo
>  
>


      reply	other threads:[~2003-03-04  0:56 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2003-03-03 10:02 Robert Strycek
2003-03-03 16:39 ` Alexander Terekhov
2003-03-04  0:56   ` Ross Johnson [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=3E63FA44.4020302@ise.canberra.edu.au \
    --to=rpj@ise.canberra.edu.au \
    --cc=TEREKHOV@de.ibm.com \
    --cc=pthreads-win32@sources.redhat.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).