@@ -3,7 +3,9 @@
void flockfile(FILE *f)
{
- pthread_self();
- libc.lockfile = __lockfile;
+ if (!libc.lockfile) {
+ pthread_self();
+ libc.lockfile = __lockfile;
+ }
__lockfile(f);
}
@@ -3,7 +3,7 @@
int ftrylockfile(FILE *f)
+ if (!libc.lockfile) libc.lockfile = __lockfile;
if (f->owner && f->owner == pthread_self()->tid) {
if (f->lockcount == INT_MAX)
return -1;