From: Jeremy Allison Date: Fri, 28 Feb 2020 23:59:16 +0000 (-0800) Subject: s3: VFS: vfs_glusterfs. Pass in struct vfs_gluster_fsync_state as the callback data... X-Git-Tag: ldb-2.2.0~1494 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=cdde55a69d0dacd2f9939c2f00cd356c0186f791;p=thirdparty%2Fsamba.git s3: VFS: vfs_glusterfs. Pass in struct vfs_gluster_fsync_state as the callback data to the subreq. Find the req we're finishing off by looking inside vfs_gluster_fsync_state. In a shutdown close the caller calls talloc_free(req), so we can't access it directly as callback data. The next commit will NULL out the vfs_gluster_fsync_state->req pointer when a caller calls talloc_free(req), and the request is still in flight. BUG: https://bugzilla.samba.org/show_bug.cgi?id=14301 Signed-off-by: Jeremy Allison Reviewed-by: Volker Lendecke --- diff --git a/source3/modules/vfs_glusterfs.c b/source3/modules/vfs_glusterfs.c index d5d402d72ab..4706e6f9189 100644 --- a/source3/modules/vfs_glusterfs.c +++ b/source3/modules/vfs_glusterfs.c @@ -1158,7 +1158,7 @@ static struct tevent_req *vfs_gluster_fsync_send(struct vfs_handle_struct if (tevent_req_nomem(subreq, req)) { return tevent_req_post(req, ev); } - tevent_req_set_callback(subreq, vfs_gluster_fsync_done, req); + tevent_req_set_callback(subreq, vfs_gluster_fsync_done, state); talloc_set_destructor(state, vfs_gluster_fsync_state_destructor); @@ -1202,10 +1202,9 @@ static int vfs_gluster_fsync_state_destructor(struct vfs_gluster_fsync_state *st static void vfs_gluster_fsync_done(struct tevent_req *subreq) { - struct tevent_req *req = tevent_req_callback_data( - subreq, struct tevent_req); - struct vfs_gluster_fsync_state *state = tevent_req_data( - req, struct vfs_gluster_fsync_state); + struct vfs_gluster_fsync_state *state = tevent_req_callback_data( + subreq, struct vfs_gluster_fsync_state); + struct tevent_req *req = state->req; int ret; ret = pthreadpool_tevent_job_recv(subreq);