diff options
author | Stefan Metzmacher <metze@samba.org> | 2011-10-24 18:13:09 +0200 |
---|---|---|
committer | Stefan Metzmacher <metze@samba.org> | 2011-10-25 01:47:22 +0200 |
commit | 6fb13f4c1932306e975eb91bcf4830f68139f1e2 (patch) | |
tree | cfcad6e84a8047e88a049e990d50f4c2b0a6f0ec /source3/libsmb | |
parent | 648665a0087a46bce45be872730bf8bed4e1f1c2 (diff) | |
download | samba-6fb13f4c1932306e975eb91bcf4830f68139f1e2.tar.gz samba-6fb13f4c1932306e975eb91bcf4830f68139f1e2.tar.bz2 samba-6fb13f4c1932306e975eb91bcf4830f68139f1e2.zip |
s3:libsmb: use HDR_* defines in cli_state_dispatch_smb1()
metze
Diffstat (limited to 'source3/libsmb')
-rw-r--r-- | source3/libsmb/async_smb.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/source3/libsmb/async_smb.c b/source3/libsmb/async_smb.c index 7213e9848f..587e0e36d8 100644 --- a/source3/libsmb/async_smb.c +++ b/source3/libsmb/async_smb.c @@ -680,9 +680,10 @@ static NTSTATUS cli_state_dispatch_smb1(struct cli_state *cli, int i; uint16_t mid; bool oplock_break; + const uint8_t *inhdr = inbuf + NBT_HDR_SIZE; - if ((IVAL(inbuf, 4) != 0x424d53ff) /* 0xFF"SMB" */ - && (SVAL(inbuf, 4) != 0x45ff)) /* 0xFF"E" */ { + if ((IVAL(inhdr, 0) != SMB_MAGIC) /* 0xFF"SMB" */ + && (SVAL(inhdr, 0) != 0x45ff)) /* 0xFF"E" */ { DEBUG(10, ("Got non-SMB PDU\n")); return NT_STATUS_INVALID_NETWORK_RESPONSE; } @@ -713,7 +714,7 @@ static NTSTATUS cli_state_dispatch_smb1(struct cli_state *cli, } } - mid = SVAL(inbuf, smb_mid); + mid = SVAL(inhdr, HDR_MID); num_pending = talloc_array_length(cli->conn.pending); for (i=0; i<num_pending; i++) { @@ -733,10 +734,10 @@ static NTSTATUS cli_state_dispatch_smb1(struct cli_state *cli, * Paranoia checks that this is really an oplock break request. */ oplock_break = (smb_len_nbt(inbuf) == 51); /* hdr + 8 words */ - oplock_break &= ((CVAL(inbuf, smb_flg) & FLAG_REPLY) == 0); - oplock_break &= (CVAL(inbuf, smb_com) == SMBlockingX); - oplock_break &= (SVAL(inbuf, smb_vwv6) == 0); - oplock_break &= (SVAL(inbuf, smb_vwv7) == 0); + oplock_break &= ((CVAL(inhdr, HDR_FLG) & FLAG_REPLY) == 0); + oplock_break &= (CVAL(inhdr, HDR_COM) == SMBlockingX); + oplock_break &= (SVAL(inhdr, HDR_VWV+VWV(6)) == 0); + oplock_break &= (SVAL(inhdr, HDR_VWV+VWV(7)) == 0); if (!oplock_break) { /* Dump unexpected reply */ |