mirror of
https://github.com/samba-team/samba.git
synced 2025-01-21 18:04:06 +03:00
libcli/smb: pass max_dyn_len to smb2cli_req_send()
This way we can calculate the correct credit charge for requests with large output buffers. Signed-off-by: Stefan Metzmacher <metze@samba.org> Reviewed-by: Jeremy Allison <jra@samba.org>
This commit is contained in:
parent
4a3352020d
commit
44b53937d5
@ -60,7 +60,8 @@ struct tevent_req *smb2cli_close_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
NULL, 0);
|
||||
NULL, 0, /* dyn* */
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -62,6 +62,7 @@ struct tevent_req *smb2cli_create_send(
|
||||
size_t blobs_offset;
|
||||
uint8_t *dyn;
|
||||
size_t dyn_len;
|
||||
size_t max_dyn_len;
|
||||
|
||||
req = tevent_req_create(mem_ctx, &state,
|
||||
struct smb2cli_create_state);
|
||||
@ -129,13 +130,23 @@ struct tevent_req *smb2cli_create_send(
|
||||
data_blob_free(&blob);
|
||||
}
|
||||
|
||||
/*
|
||||
* We use max_dyn_len = 0
|
||||
* as we don't explicitly ask for any output length.
|
||||
*
|
||||
* But it's still possible for the server to return
|
||||
* large create blobs.
|
||||
*/
|
||||
max_dyn_len = 0;
|
||||
|
||||
subreq = smb2cli_req_send(state, ev, conn, SMB2_OP_CREATE,
|
||||
0, 0, /* flags */
|
||||
timeout_msec,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
max_dyn_len);
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -53,7 +53,8 @@ struct tevent_req *smb2cli_echo_send(TALLOC_CTX *mem_ctx,
|
||||
NULL, /* tcon */
|
||||
NULL, /* session */
|
||||
state->fixed, sizeof(state->fixed),
|
||||
NULL, 0);
|
||||
NULL, 0, /* dyn* */
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -58,7 +58,8 @@ struct tevent_req *smb2cli_flush_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
NULL, 0);
|
||||
NULL, 0, /* dyn* */
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -61,6 +61,8 @@ struct tevent_req *smb2cli_ioctl_send(TALLOC_CTX *mem_ctx,
|
||||
uint32_t output_buffer_offset = 0;
|
||||
uint32_t output_buffer_length = 0;
|
||||
uint32_t pad_length = 0;
|
||||
uint64_t tmp64;
|
||||
uint32_t max_dyn_len = 0;
|
||||
|
||||
req = tevent_req_create(mem_ctx, &state,
|
||||
struct smb2cli_ioctl_state);
|
||||
@ -70,6 +72,14 @@ struct tevent_req *smb2cli_ioctl_send(TALLOC_CTX *mem_ctx,
|
||||
state->max_input_length = in_max_input_length;
|
||||
state->max_output_length = in_max_output_length;
|
||||
|
||||
tmp64 = in_max_input_length;
|
||||
tmp64 += in_max_output_length;
|
||||
if (tmp64 > UINT32_MAX) {
|
||||
max_dyn_len = UINT32_MAX;
|
||||
} else {
|
||||
max_dyn_len = tmp64;
|
||||
}
|
||||
|
||||
if (in_input_buffer) {
|
||||
input_buffer_offset = SMB2_HDR_BODY+0x38;
|
||||
input_buffer_length = in_input_buffer->length;
|
||||
@ -139,7 +149,8 @@ struct tevent_req *smb2cli_ioctl_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
max_dyn_len);
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -93,7 +93,8 @@ struct tevent_req *smb2cli_query_directory_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
outbuf_len); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -96,7 +96,8 @@ struct tevent_req *smb2cli_query_info_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
in_max_output_length); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -72,7 +72,8 @@ struct tevent_req *smb2cli_read_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
state->dyn_pad, sizeof(state->dyn_pad));
|
||||
state->dyn_pad, sizeof(state->dyn_pad),
|
||||
length); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -102,7 +102,8 @@ struct tevent_req *smb2cli_session_setup_send(TALLOC_CTX *mem_ctx,
|
||||
NULL, /* tcon */
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
UINT16_MAX); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
@ -258,7 +259,8 @@ struct tevent_req *smb2cli_logoff_send(TALLOC_CTX *mem_ctx,
|
||||
NULL, /* tcon */
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
NULL, 0);
|
||||
NULL, 0, /* dyn* */
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -88,7 +88,8 @@ struct tevent_req *smb2cli_set_info_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -82,7 +82,8 @@ struct tevent_req *smb2cli_write_send(TALLOC_CTX *mem_ctx,
|
||||
tcon,
|
||||
session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -2984,11 +2984,11 @@ struct tevent_req *smb2cli_req_send(TALLOC_CTX *mem_ctx,
|
||||
const uint8_t *fixed,
|
||||
uint16_t fixed_len,
|
||||
const uint8_t *dyn,
|
||||
uint32_t dyn_len)
|
||||
uint32_t dyn_len,
|
||||
uint32_t max_dyn_len)
|
||||
{
|
||||
struct tevent_req *req;
|
||||
NTSTATUS status;
|
||||
uint32_t max_dyn_len = 0;
|
||||
|
||||
req = smb2cli_req_create(mem_ctx, ev, conn, cmd,
|
||||
additional_flags, clear_flags,
|
||||
@ -4260,7 +4260,8 @@ static struct tevent_req *smbXcli_negprot_smb2_subreq(struct smbXcli_negprot_sta
|
||||
state->timeout_msec,
|
||||
NULL, NULL, /* tcon, session */
|
||||
state->smb2.fixed, sizeof(state->smb2.fixed),
|
||||
state->smb2.dyn, dialect_count*2);
|
||||
state->smb2.dyn, dialect_count*2,
|
||||
UINT16_MAX); /* max_dyn_len */
|
||||
}
|
||||
|
||||
static void smbXcli_negprot_smb2_done(struct tevent_req *subreq)
|
||||
|
@ -242,7 +242,8 @@ struct tevent_req *smb2cli_req_send(TALLOC_CTX *mem_ctx,
|
||||
const uint8_t *fixed,
|
||||
uint16_t fixed_len,
|
||||
const uint8_t *dyn,
|
||||
uint32_t dyn_len);
|
||||
uint32_t dyn_len,
|
||||
uint32_t max_dyn_len);
|
||||
NTSTATUS smb2cli_req_recv(struct tevent_req *req, TALLOC_CTX *mem_ctx,
|
||||
struct iovec **piov,
|
||||
const struct smb2cli_req_expected_response *expected,
|
||||
|
@ -85,7 +85,8 @@ struct tevent_req *smb2cli_tcon_send(TALLOC_CTX *mem_ctx,
|
||||
NULL, /* tcon */
|
||||
cli->smb2.session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
dyn, dyn_len);
|
||||
dyn, dyn_len,
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
@ -211,7 +212,8 @@ struct tevent_req *smb2cli_tdis_send(TALLOC_CTX *mem_ctx,
|
||||
cli->smb2.tcon,
|
||||
cli->smb2.session,
|
||||
state->fixed, sizeof(state->fixed),
|
||||
NULL, 0);
|
||||
NULL, 0, /* dyn* */
|
||||
0); /* max_dyn_len */
|
||||
if (tevent_req_nomem(subreq, req)) {
|
||||
return tevent_req_post(req, ev);
|
||||
}
|
||||
|
@ -151,7 +151,8 @@ void smb2_transport_send(struct smb2_request *req)
|
||||
NULL, /* body */
|
||||
0, /* body_fixed */
|
||||
NULL, /* dyn */
|
||||
0); /* dyn_len */
|
||||
0, /* dyn_len */
|
||||
0); /* max_dyn_len */
|
||||
if (subreq != NULL) {
|
||||
smbXcli_req_set_pending(subreq);
|
||||
tevent_req_set_callback(subreq,
|
||||
@ -190,7 +191,8 @@ void smb2_transport_send(struct smb2_request *req)
|
||||
tcon,
|
||||
session,
|
||||
body.data, body.length,
|
||||
dyn.data, dyn.length);
|
||||
dyn.data, dyn.length,
|
||||
0); /* max_dyn_len */
|
||||
if (req->subreq == NULL) {
|
||||
req->state = SMB2_REQUEST_ERROR;
|
||||
req->status = NT_STATUS_NO_MEMORY;
|
||||
@ -347,7 +349,8 @@ static void smb2_transport_break_handler(struct tevent_req *subreq)
|
||||
NULL, /* body */
|
||||
0, /* body_fixed */
|
||||
NULL, /* dyn */
|
||||
0); /* dyn_len */
|
||||
0, /* dyn_len */
|
||||
0); /* max_dyn_len */
|
||||
if (subreq != NULL) {
|
||||
smbXcli_req_set_pending(subreq);
|
||||
tevent_req_set_callback(subreq,
|
||||
|
Loading…
x
Reference in New Issue
Block a user