Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 25 Jun 2016 21:25:48 +0300
From:      Ivan Klymenko <fidaj@ukr.net>
To:        Konstantin Belousov <kostikbel@gmail.com>
Cc:        svn-src-head@freebsd.org, svn-src-all@freebsd.org, src-committers@freebsd.org
Subject:   Re: svn commit: r302194 - head/lib/libthr/thread
Message-ID:  <20160625212548.14057aa1@nonamehost.local>
In-Reply-To: <20160625180657.GG38613@kib.kiev.ua>
References:  <20160625170406.77c79b2e@nonamehost.local> <20160625140529.GW38613@kib.kiev.ua> <20160625171800.50a43746@nonamehost.local> <20160625142915.GX38613@kib.kiev.ua> <20160625175503.7c57d42b@nonamehost.local> <20160625152006.GA38613@kib.kiev.ua> <20160625190346.19a1ef0d@nonamehost.local> <20160625161615.GD38613@kib.kiev.ua> <20160625204317.0aae5c98@nonamehost.local> <20160625180543.GF38613@kib.kiev.ua> <20160625180657.GG38613@kib.kiev.ua>

next in thread | previous in thread | raw e-mail | index | archive | help

On Sat, 25 Jun 2016 21:06:57 +0300
Konstantin Belousov <kostikbel@gmail.com> wrote:

> On Sat, Jun 25, 2016 at 09:05:43PM +0300, Konstantin Belousov wrote:
> > On Sat, Jun 25, 2016 at 08:43:17PM +0300, Ivan Klymenko wrote:  
> > > ./thr_mutex_test
> > > thr_mutex_test: mutex_trylock 2: No error: 0  
> > 
> > Ok, there is a bug in my test, it must use errc(3) and not err(3).
> > Please retest wth the updated code below.  But I am sure that you
> > would see EDEADLK (Resource deadlock avoided) error, which means
> > that you have wrong, i.e. unpatched libthr, installed.
> > 
> > For me, the output is 
> > sandy% ./pthread_errrecurse
> > sandy% echo $?
> > 0
> >   
> Err, the updated test.
> 
> /* $Id: pthread_errrecurse.c,v 1.2 2016/06/25 18:02:54 kostik Exp
> kostik $ */
> 
> #include <err.h>
> #include <errno.h>
> #include <pthread.h>
> 
> int
> main(void)
> {
> 	pthread_mutex_t m;
> 	pthread_mutexattr_t ma;
> 	int error;
> 
> 	error = pthread_mutexattr_init(&ma);
> 	if (error != 0)
> 		errc(1, error, "mutexattr_init");
> 	error = pthread_mutexattr_settype(&ma,
> PTHREAD_MUTEX_ADAPTIVE_NP); if (error != 0)
> 		errc(1, error, "mutexattr_settype");
> 	error = pthread_mutex_init(&m, &ma);
> 	if (error != 0)
> 		errc(1, error, "mutex_init");
> 	error = pthread_mutex_trylock(&m);
> 	if (error != 0)
> 		errc(1, error, "mutex_trylock 1");
> 	error = pthread_mutex_trylock(&m);
> 	if (error != EBUSY)
> 		errc(1, error, "mutex_trylock 2");
> 	else if (error == 0)
> 		errx(1, "mutex_trylock 2 succeeded");
> 	return (0);
> }

1. Patched & installed libthr r302195
2. test for other soft:
mousepad 
GLib (gthread-posix.c): Unexpected error from C library during
'pthread_mutex_trylock': Уникнуто взаємне блокування ресурсів.
Aborting. Аварійне завершення(записано core)
3.test new ./thr_mutex_test 
thr_mutex_test: mutex_trylock 2: No error: 0
4. restore patch & install original libthr r302195
5. test for other soft:
mousepad
GLib (gthread-posix.c): Unexpected error from C library during
'pthread_mutex_trylock': Уникнуто взаємне блокування ресурсів.
Aborting. Аварійне завершення(записано core)
6. test new ./thr_mutex_test 
thr_mutex_test: mutex_trylock 2: No error: 0
7. restore & install libthr r302191
8. test for other soft:
mousepad - complete run
9. test new ./thr_mutex_test 
thr_mutex_test: mutex_trylock 2: No error: 0



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20160625212548.14057aa1>