From: Ronnie Sahlberg Date: Mon, 11 Aug 2014 13:15:16 +0000 (-0700) Subject: Merge pull request #97 from rosslagerwall/read-close-crash X-Git-Tag: upstream/1.9.6^2~9 X-Git-Url: https://git.piment-noir.org/?p=deb_libnfs.git;a=commitdiff_plain;h=a8c840e834942b6eb79d06c0bde77aedfda1836a;hp=34e6b2cf94891183d931638e34d15fdfc75a133d Merge pull request #97 from rosslagerwall/read-close-crash libnfs: Don't perform operations on nfsfh after user callback --- diff --git a/lib/libnfs.c b/lib/libnfs.c index 222721c..c213cad 100644 --- a/lib/libnfs.c +++ b/lib/libnfs.c @@ -1808,6 +1808,8 @@ static void nfs_pread_mcb(struct rpc_context *rpc, int status, void *command_dat struct nfs_cb_data *data = mdata->data; struct nfs_context *nfs = data->nfs; READ3res *res; + int cb_err; + void *cb_data; assert(rpc->magic == RPC_CONTEXT_MAGIC); @@ -1906,9 +1908,11 @@ static void nfs_pread_mcb(struct rpc_context *rpc, int status, void *command_dat if (data->max_offset > data->org_offset + data->org_count) { data->max_offset = data->org_offset + data->org_count; } - data->cb(data->max_offset - data->org_offset, nfs, data->buffer + (data->org_offset - data->offset), data->private_data); + cb_err = data->max_offset - data->org_offset; + cb_data = data->buffer + (data->org_offset - data->offset); } else { - data->cb(res->READ3res_u.resok.count, nfs, res->READ3res_u.resok.data.data_val, data->private_data); + cb_err = res->READ3res_u.resok.count; + cb_data = res->READ3res_u.resok.data.data_val; } data->nfsfh->ra.fh_offset = data->max_offset; @@ -1920,6 +1924,8 @@ static void nfs_pread_mcb(struct rpc_context *rpc, int status, void *command_dat data->nfsfh->ra.buf_ts = time(NULL); data->buffer = NULL; } + + data->cb(cb_err, nfs, cb_data, data->private_data); free_nfs_cb_data(data); }