2004-06-27  Ulrich Drepper  <drepper@redhat.com>

	* Makefile: Add rules to build tst-rwlock14.
	* tst-rwlock14.c: New file.

2004-06-24  Boris Hu  <boris.hu@intel.com>

	* sysdeps/pthread/pthread_rwlock_timedrdlock.c: Add timeout validation
	check.
	* sysdeps/pthread/pthread_rwlock_timedwrlock.c: Likewise.
This commit is contained in:
Ulrich Drepper 2004-06-27 19:32:01 +00:00
parent 17fb9c535b
commit 46f4c5787a
5 changed files with 159 additions and 3 deletions

View File

@ -1,3 +1,14 @@
2004-06-27 Ulrich Drepper <drepper@redhat.com>
* Makefile: Add rules to build tst-rwlock14.
* tst-rwlock14.c: New file.
2004-06-24 Boris Hu <boris.hu@intel.com>
* sysdeps/pthread/pthread_rwlock_timedrdlock.c: Add timeout validation
check.
* sysdeps/pthread/pthread_rwlock_timedwrlock.c: Likewise.
2004-06-19 Andreas Jaeger <aj@suse.de>
* sysdeps/unix/sysv/linux/x86_64/pthread_cond_timedwait.S: Fix

View File

@ -197,7 +197,7 @@ tests = tst-attr1 tst-attr2 tst-attr3 \
tst-cond14 tst-cond15 tst-cond16 tst-cond17 tst-cond18 tst-cond19 \
tst-rwlock1 tst-rwlock2 tst-rwlock3 tst-rwlock4 tst-rwlock5 \
tst-rwlock6 tst-rwlock7 tst-rwlock8 tst-rwlock9 tst-rwlock10 \
tst-rwlock11 tst-rwlock12 tst-rwlock13 \
tst-rwlock11 tst-rwlock12 tst-rwlock13 tst-rwlock14 \
tst-once1 tst-once2 tst-once3 tst-once4 \
tst-key1 tst-key2 tst-key3 tst-key4 \
tst-sem1 tst-sem2 tst-sem3 tst-sem4 tst-sem5 tst-sem6 tst-sem7 \
@ -460,6 +460,7 @@ $(objpfx)tst-cancelx17: $(common-objpfx)rt/librt.so
$(objpfx)tst-cancel18: $(common-objpfx)rt/librt.so
$(objpfx)tst-cancelx18: $(common-objpfx)rt/librt.so
$(objpfx)tst-clock2: $(common-objpfx)rt/librt.so
$(objpfx)tst-rwlock14: $(common-objpfx)rt/librt.so
$(objpfx)tst-_res1mod2.so: $(objpfx)tst-_res1mod1.so
LDFLAGS-tst-_res1mod1.so = -Wl,-soname,tst-_res1mod1.so
LDFLAGS-tst-_res1mod2.so = -Wl,-soname,tst-_res1mod2.so
@ -472,6 +473,7 @@ $(objpfx)tst-cancelx17: $(common-objpfx)rt/librt.a
$(objpfx)tst-cancel18: $(common-objpfx)rt/librt.a
$(objpfx)tst-cancelx18: $(common-objpfx)rt/librt.a
$(objpfx)tst-clock2: $(common-objpfx)rt/librt.a
$(objpfx)tst-rwlock14: $(common-objpfx)rt/librt.a
endif
extra-B-pthread.so = -B$(common-objpfx)nptl/

View File

@ -70,7 +70,8 @@ pthread_rwlock_timedrdlock (rwlock, abstime)
performed if we would not block at all simply moving the test
to the front is no option. Replicating all the code is
costly while this test is not. */
if (__builtin_expect (abstime->tv_nsec >= 1000000000, 0))
if (__builtin_expect (abstime->tv_nsec >= 1000000000
|| abstime->tv_sec < 0, 0))
{
result = EINVAL;
break;

View File

@ -61,7 +61,8 @@ pthread_rwlock_timedwrlock (rwlock, abstime)
performed if we would not block at all simply moving the test
to the front is no option. Replicating all the code is
costly while this test is not. */
if (abstime->tv_nsec >= 1000000000)
if (__builtin_expect (abstime->tv_nsec >= 1000000000
|| abstime->tv_sec < 0, 0))
{
result = EINVAL;
break;

141
nptl/tst-rwlock14.c Normal file
View File

@ -0,0 +1,141 @@
/* Copyright (C) 2004 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@redhat.com>, 2004.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, write to the Free
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */
#include <errno.h>
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
static pthread_barrier_t b;
static pthread_rwlock_t r = PTHREAD_RWLOCK_INITIALIZER;
static void *
tf (void *arg)
{
/* Lock the read-write lock. */
if (pthread_rwlock_wrlock (&r) != 0)
{
puts ("tf: cannot lock rwlock");
exit (EXIT_FAILURE);
}
pthread_barrier_wait (&b);
pthread_t *mtp = (pthread_t *) arg;
/* This call will never return. */
pthread_join (*mtp, NULL);
return NULL;
}
static int
do_test (void)
{
int result = 0;
struct timespec ts;
if (clock_gettime (CLOCK_REALTIME, &ts) != 0)
{
puts ("clock_gettime failed");
return 1;
}
if (pthread_barrier_init (&b, NULL, 2) != 0)
{
puts ("barrier_init failed");
return 1;
}
pthread_t me = pthread_self ();
pthread_t th;
if (pthread_create (&th, NULL, tf, &me) != 0)
{
puts ("create failed");
return 1;
}
/* Wait until the rwlock is locked. */
pthread_barrier_wait (&b);
ts.tv_nsec = -1;
int e = pthread_rwlock_timedrdlock (&r, &ts);
if (e == 0)
{
puts ("first rwlock_timedrdlock did not fail");
result = 1;
}
else if (e != EINVAL)
{
puts ("first rwlock_timedrdlock did not return EINVAL");
result = 1;
}
e = pthread_rwlock_timedwrlock (&r, &ts);
if (e == 0)
{
puts ("first rwlock_timedwrlock did not fail");
result = 1;
}
else if (e != EINVAL)
{
puts ("first rwlock_timedwrlock did not return EINVAL");
result = 1;
}
ts.tv_nsec = 2000000000;
e = pthread_rwlock_timedrdlock (&r, &ts);
if (e == 0)
{
puts ("second rwlock_timedrdlock did not fail");
result = 1;
}
else if (e != EINVAL)
{
puts ("second rwlock_timedrdlock did not return EINVAL");
result = 1;
}
e = pthread_rwlock_timedrdlock (&r, &ts);
if (e == 0)
{
puts ("second rwlock_timedrdlock did not fail");
result = 1;
}
else if (e != EINVAL)
{
puts ("second rwlock_timedrdlock did not return EINVAL");
result = 1;
}
if (result == 0)
puts ("no bugs");
return result;
}
#define TEST_FUNCTION do_test ()
#include "../test-skeleton.c"