summaryrefslogtreecommitdiff
path: root/source3/smbd/smb2_close.c
diff options
context:
space:
mode:
authorVolker Lendecke <vl@samba.org>2019-06-15 15:23:50 -0700
committerJeremy Allison <jra@samba.org>2019-06-20 17:18:19 +0000
commitb091c19cb2045e72b3a9a0b364f110ad88debe53 (patch)
tree6c2d7880be56cc07455da398bee59158f41378c5 /source3/smbd/smb2_close.c
parent6f204de778490c7bffdc367de21d80fb410b227f (diff)
downloadsamba-b091c19cb2045e72b3a9a0b364f110ad88debe53.tar.gz
smbd: Base smb2_lock.c on tevent_req
smb2 locking is a lot more regular than reply_lockingX. So this is a much smaller change. Signed-off-by: Volker Lendecke <vl@samba.org> Reviewed-by: Jeremy Allison <jra@samba.org>
Diffstat (limited to 'source3/smbd/smb2_close.c')
-rw-r--r--source3/smbd/smb2_close.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/source3/smbd/smb2_close.c b/source3/smbd/smb2_close.c
index dea9512dfc6..93539d48845 100644
--- a/source3/smbd/smb2_close.c
+++ b/source3/smbd/smb2_close.c
@@ -313,6 +313,7 @@ static struct tevent_req *smbd_smb2_close_send(TALLOC_CTX *mem_ctx,
{
struct tevent_req *req;
struct smbd_smb2_close_state *state;
+ unsigned i;
NTSTATUS status;
req = tevent_req_create(mem_ctx, &state,
@@ -324,6 +325,17 @@ static struct tevent_req *smbd_smb2_close_send(TALLOC_CTX *mem_ctx,
state->in_fsp = in_fsp;
state->in_flags = in_flags;
+ in_fsp->closing = true;
+
+ i = 0;
+ while (i < in_fsp->num_aio_requests) {
+ bool ok = tevent_req_cancel(in_fsp->aio_requests[i]);
+ if (ok) {
+ continue;
+ }
+ i += 1;
+ }
+
if (in_fsp->num_aio_requests != 0) {
in_fsp->deferred_close = tevent_wait_send(in_fsp, ev);
if (tevent_req_nomem(in_fsp->deferred_close, req)) {