diff options
author | Stefan Metzmacher <metze@samba.org> | 2011-09-13 18:09:42 +0200 |
---|---|---|
committer | Stefan Metzmacher <metze@samba.org> | 2011-09-15 12:12:25 +0200 |
commit | abca5f17c38f5ced2d03d66f99f91f895bf00851 (patch) | |
tree | 9de49a65fbdac433da58d2154fde1b12642c1b74 /source3 | |
parent | 14e8ef14a0cf44476160d3c0a12d0166002987a0 (diff) | |
download | samba-abca5f17c38f5ced2d03d66f99f91f895bf00851.tar.gz samba-abca5f17c38f5ced2d03d66f99f91f895bf00851.tar.bz2 samba-abca5f17c38f5ced2d03d66f99f91f895bf00851.zip |
s3:libsmb: detect lock_read and write_unlock support
metze
Diffstat (limited to 'source3')
-rw-r--r-- | source3/include/client.h | 2 | ||||
-rw-r--r-- | source3/libsmb/cliconnect.c | 15 |
2 files changed, 17 insertions, 0 deletions
diff --git a/source3/include/client.h b/source3/include/client.h index e51d72789c..09893a2e01 100644 --- a/source3/include/client.h +++ b/source3/include/client.h @@ -135,6 +135,8 @@ struct cli_state { uint16_t security_mode; bool readbraw; bool writebraw; + bool lockread; + bool writeunlock; } server; uint32_t capabilities; diff --git a/source3/libsmb/cliconnect.c b/source3/libsmb/cliconnect.c index e2d0a2b8bd..91e613affb 100644 --- a/source3/libsmb/cliconnect.c +++ b/source3/libsmb/cliconnect.c @@ -2600,6 +2600,7 @@ static void cli_negprot_done(struct tevent_req *subreq) struct cli_negprot_state *state = tevent_req_data( req, struct cli_negprot_state); struct cli_state *cli = state->cli; + uint8_t flags; uint8_t wct; uint16_t *vwv; uint32_t num_bytes; @@ -2618,6 +2619,8 @@ static void cli_negprot_done(struct tevent_req *subreq) uint16_t server_security_mode = 0; bool server_readbraw = false; bool server_writebraw = false; + bool server_lockread = false; + bool server_writeunlock = false; enum protocol_types protocol; status = cli_smb_recv(subreq, state, &inbuf, 1, &wct, &vwv, @@ -2628,6 +2631,8 @@ static void cli_negprot_done(struct tevent_req *subreq) return; } + flags = CVAL(inbuf, smb_flg); + protnum = SVAL(vwv, 0); if ((protnum >= ARRAY_SIZE(prots)) @@ -2645,6 +2650,11 @@ static void cli_negprot_done(struct tevent_req *subreq) return; } + if (flags & FLAG_SUPPORT_LOCKREAD) { + server_lockread = true; + server_writeunlock = true; + } + if (protocol >= PROTOCOL_NT1) { struct timespec ts; const char *client_signing = NULL; @@ -2674,6 +2684,9 @@ static void cli_negprot_done(struct tevent_req *subreq) server_readbraw = true; server_writebraw = true; } + if (server_capabilities & CAP_LOCK_AND_READ) { + server_lockread = true; + } /* work out if they sent us a workgroup */ if (!(server_capabilities & CAP_EXTENDED_SECURITY) && smb_buflen(inbuf) > 8) { @@ -2779,6 +2792,8 @@ static void cli_negprot_done(struct tevent_req *subreq) cli->conn.smb1.server.readbraw = server_readbraw; cli->conn.smb1.server.writebraw = server_writebraw; + cli->conn.smb1.server.lockread = server_lockread; + cli->conn.smb1.server.writeunlock = server_writeunlock; tevent_req_done(req); } |