From 1e3d0e5e869d6a920987d20cc6ed7a67f5c426bd Mon Sep 17 00:00:00 2001 From: dimitri staessens Date: Thu, 21 Sep 2017 11:22:49 +0200 Subject: lib: Pass the fuse struct to the handling thread This avoids potential data races on rib.fuse. --- src/lib/rib.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) (limited to 'src/lib/rib.c') diff --git a/src/lib/rib.c b/src/lib/rib.c index 579d9aac..dc78696b 100644 --- a/src/lib/rib.c +++ b/src/lib/rib.c @@ -227,9 +227,7 @@ static struct fuse_operations r_ops = { static void * fuse_thr(void * o) { - (void) o; - - if (fuse_loop(rib.fuse) < 0) + if (fuse_loop((struct fuse *) o) < 0) return (void *) -1; return (void *) 0; @@ -276,7 +274,7 @@ int rib_init(const char * prefix) if (pthread_rwlock_init(&rib.lock, NULL)) goto fail_rwlock_init; - if (pthread_create(&rib.fuse_thr, NULL, fuse_thr, NULL)) + if (pthread_create(&rib.fuse_thr, NULL, fuse_thr, rib.fuse)) goto fail_fuse_thr; fuse_opt_free_args(&args); -- cgit v1.2.3