diff options
author | Andrew Tridgell <tridge@samba.org> | 2005-11-25 05:46:46 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2005-11-25 05:46:46 +0000 |
commit | 990dfbd4ef4377252330b7e5b4bf24d0dfe0c835 (patch) | |
tree | 4ad3f9d8ce53fad7134a97436f81b7c733cc4608 /source/libcli/smb2 | |
parent | 2372b9195e64a5b4f7c64648d5a1c67398a38637 (diff) | |
download | samba-990dfbd4ef4377252330b7e5b4bf24d0dfe0c835.tar.gz samba-990dfbd4ef4377252330b7e5b4bf24d0dfe0c835.tar.xz samba-990dfbd4ef4377252330b7e5b4bf24d0dfe0c835.zip |
r11891: - added pipe_flags field in smb2_trans
- while running dcerpc over SMB2, the server will occasionally send us
a oh-so-useful STATUS_PENDING result meaning "I don't have a result
for you yet, but I'm working on it". These can be discarded :-)
Diffstat (limited to 'source/libcli/smb2')
-rw-r--r-- | source/libcli/smb2/smb2_calls.h | 4 | ||||
-rw-r--r-- | source/libcli/smb2/transport.c | 7 |
2 files changed, 10 insertions, 1 deletions
diff --git a/source/libcli/smb2/smb2_calls.h b/source/libcli/smb2/smb2_calls.h index 07f74ca2293..e0a78937d58 100644 --- a/source/libcli/smb2/smb2_calls.h +++ b/source/libcli/smb2/smb2_calls.h @@ -304,9 +304,11 @@ struct smb2_find { } out; }; +#define SMB2_TRANS_PIPE_FLAGS 0x0011c017 /* what are these? */ + struct smb2_trans { struct { - uint32_t unknown1; + uint32_t pipe_flags; struct smb2_handle handle; uint32_t unknown2; uint32_t max_response_size; diff --git a/source/libcli/smb2/transport.c b/source/libcli/smb2/transport.c index 04767fa6342..02ac587636a 100644 --- a/source/libcli/smb2/transport.c +++ b/source/libcli/smb2/transport.c @@ -185,6 +185,13 @@ static NTSTATUS smb2_transport_finish_recv(void *private, DATA_BLOB blob) req->in.body_size = req->in.size - (SMB2_HDR_BODY+NBT_HDR_SIZE); req->status = NT_STATUS(IVAL(hdr, SMB2_HDR_STATUS)); + if (NT_STATUS_EQUAL(req->status, STATUS_PENDING)) { + /* the server has helpfully told us that this request is still being + processed. how useful :) */ + talloc_free(buffer); + return NT_STATUS_OK; + } + buffer_code = SVAL(req->in.body, 0); req->in.dynamic = NULL; dynamic_size = req->in.body_size - (buffer_code & ~1); |