summaryrefslogtreecommitdiffstats
path: root/lib/libc/stdio/ftell.c
diff options
context:
space:
mode:
authorjb <jb@FreeBSD.org>1998-04-11 07:40:47 +0000
committerjb <jb@FreeBSD.org>1998-04-11 07:40:47 +0000
commit0ff63017b40dda207b2aadc9881e0c93e7fd2753 (patch)
tree4819eff8a5c9bc5ae04aaf772d0d5b4f7bfaaebc /lib/libc/stdio/ftell.c
parent525c97c21dbcb3fd61a8a530a3f8df5e901bf1ab (diff)
downloadFreeBSD-src-0ff63017b40dda207b2aadc9881e0c93e7fd2753.zip
FreeBSD-src-0ff63017b40dda207b2aadc9881e0c93e7fd2753.tar.gz
Add FILE locking stubs for libc.
Change the FILE locking to support kernel threads when linked with libpthread (which you haven't see yet). This requires that libc become thread-safe and thread-aware, testing __isthreaded before attempting to do lock/unlock calls. The impact on non-threaded programs is minor. This change works with libc_r, so it's the best compromise.
Diffstat (limited to 'lib/libc/stdio/ftell.c')
-rw-r--r--lib/libc/stdio/ftell.c19
1 files changed, 5 insertions, 14 deletions
diff --git a/lib/libc/stdio/ftell.c b/lib/libc/stdio/ftell.c
index 9b85ee0..34da271 100644
--- a/lib/libc/stdio/ftell.c
+++ b/lib/libc/stdio/ftell.c
@@ -39,16 +39,13 @@
static char sccsid[] = "@(#)ftell.c 8.2 (Berkeley) 5/4/95";
#endif
static const char rcsid[] =
- "$Id: ftell.c,v 1.7 1997/02/22 15:02:07 peter Exp $";
+ "$Id: ftell.c,v 1.8 1997/03/11 11:40:40 peter Exp $";
#endif /* LIBC_SCCS and not lint */
#include <stdio.h>
#include <errno.h>
#include "local.h"
-#ifdef _THREAD_SAFE
-#include <pthread.h>
-#include "pthread_private.h"
-#endif
+#include "libc_private.h"
/*
* ftell: return current offset.
@@ -64,9 +61,7 @@ ftell(fp)
return (-1L);
}
-#ifdef _THREAD_SAFE
- _thread_flockfile(fp, __FILE__, __LINE__);
-#endif
+ FLOCKFILE(fp);
/*
* Find offset of underlying I/O object, then
* adjust for buffered bytes.
@@ -76,9 +71,7 @@ ftell(fp)
else {
pos = (*fp->_seek)(fp->_cookie, (fpos_t)0, SEEK_CUR);
if (pos == -1) {
-#ifdef _THREAD_SAFE
- _thread_funlockfile(fp);
-#endif
+ FUNLOCKFILE(fp);
return (pos);
}
}
@@ -99,8 +92,6 @@ ftell(fp)
*/
pos += fp->_p - fp->_bf._base;
}
-#ifdef _THREAD_SAFE
- _thread_funlockfile(fp);
-#endif
+ FUNLOCKFILE(fp);
return (pos);
}
OpenPOWER on IntegriCloud