aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiklos Szeredi <miklos@szeredi.hu>2005-10-07 12:39:58 +0000
committerMiklos Szeredi <miklos@szeredi.hu>2005-10-07 12:39:58 +0000
commit4f5df5eb96153534fb1592dec920f4a8e1c806f4 (patch)
tree45d6275aed9da36514775c696653e6158feba713
parentf2491129cf48e1d7d4ec8906157870a527f2eed0 (diff)
downloadlibfuse-4f5df5eb96153534fb1592dec920f4a8e1c806f4.tar.gz
fix
-rw-r--r--ChangeLog5
-rw-r--r--lib/fuse.c9
2 files changed, 14 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index e2038c1..76e66e8 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2005-10-07 Miklos Szeredi <miklos@szeredi.hu>
+
+ * highlevel-lib: init() and destroy() methods didn't have an
+ initialized fuse_context. Bug reported by Tim Stoakes
+
2005-10-04 Miklos Szeredi <miklos@szeredi.hu>
* Released 2.4.0
diff --git a/lib/fuse.c b/lib/fuse.c
index c81fcf7..f2593fe 100644
--- a/lib/fuse.c
+++ b/lib/fuse.c
@@ -564,6 +564,10 @@ static void reply_entry(fuse_req_t req, const struct fuse_entry_param *e,
static void fuse_data_init(void *data)
{
struct fuse *f = (struct fuse *) data;
+ struct fuse_context *c = fuse_get_context();
+
+ memset(c, 0, sizeof(*c));
+ c->fuse = f;
if (f->op.init)
f->user_data = f->op.init();
@@ -572,6 +576,11 @@ static void fuse_data_init(void *data)
static void fuse_data_destroy(void *data)
{
struct fuse *f = (struct fuse *) data;
+ struct fuse_context *c = fuse_get_context();
+
+ memset(c, 0, sizeof(*c));
+ c->fuse = f;
+ c->private_data = f->user_data;
if (f->op.destroy)
f->op.destroy(f->user_data);