mirror of
https://github.com/samba-team/samba.git
synced 2025-01-07 17:18:11 +03:00
s3: smbd: named pipe reads are async. Use the same logic as for named pipe transacts to avoid crashes on shutdown.
Noticed by Metze.
BUG: https://bugzilla.samba.org/show_bug.cgi?id=15423
Signed-off-by: Jeremy Allison <jra@samba.org>
Reviewed-by: Ralph Boehme <slow@samba.org>
(cherry picked from commit 3f32bf887d
)
This commit is contained in:
parent
4baff9de6b
commit
b3a881f89a
@ -494,6 +494,7 @@ static struct tevent_req *smbd_smb2_read_send(TALLOC_CTX *mem_ctx,
|
||||
|
||||
if (IS_IPC(smbreq->conn)) {
|
||||
struct tevent_req *subreq = NULL;
|
||||
bool ok;
|
||||
|
||||
state->out_data = data_blob_talloc(state, NULL, in_length);
|
||||
if (in_length > 0 && tevent_req_nomem(state->out_data.data, req)) {
|
||||
@ -515,6 +516,18 @@ static struct tevent_req *smbd_smb2_read_send(TALLOC_CTX *mem_ctx,
|
||||
tevent_req_set_callback(subreq,
|
||||
smbd_smb2_read_pipe_done,
|
||||
req);
|
||||
|
||||
/*
|
||||
* Make sure we mark the fsp as having outstanding async
|
||||
* activity so we don't crash on shutdown close.
|
||||
*/
|
||||
|
||||
ok = aio_add_req_to_fsp(fsp, req);
|
||||
if (!ok) {
|
||||
tevent_req_nterror(req, NT_STATUS_NO_MEMORY);
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
||||
return req;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user