From fed2fba0a90b8dca3bd4512281d4c53e08e59b5c Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Thu, 5 Jan 2012 11:58:17 +0100 Subject: [PATCH] s3: Move basic SMB checking to a much earlier point --- source3/smbd/process.c | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/source3/smbd/process.c b/source3/smbd/process.c index bf161bbdba3..2f8f88fa2ac 100644 --- a/source3/smbd/process.c +++ b/source3/smbd/process.c @@ -1407,25 +1407,6 @@ static connection_struct *switch_message(uint8 type, struct smb_request *req, in errno = 0; - /* Make sure this is an SMB packet. smb_size contains NetBIOS header - * so subtract 4 from it. */ - if ((size < (smb_size - 4)) || !valid_smb_header(sconn, req->inbuf)) { - DEBUG(2,("Non-SMB packet of length %d. Terminating server\n", - smb_len(req->inbuf))); - - /* special magic for immediate exit */ - if ((size == smb_size) && - (IVAL(req->inbuf, 4) == 0x74697865) && - lp_parm_bool(-1, "smbd", "suicide mode", false)) { - uint8_t exitcode = CVAL(req->inbuf, 8); - DEBUG(1, ("Exiting immediately with code %d\n", - (int)exitcode)); - exit(exitcode); - } - - exit_server_cleanly("Non-SMB packet"); - } - if (smb_messages[type].fn == NULL) { DEBUG(0,("Unknown message type %d!\n",type)); smb_dump("Unknown", 1, (const char *)req->inbuf, size); @@ -1667,6 +1648,25 @@ static void process_smb(struct smbd_server_connection *sconn, } } + /* Make sure this is an SMB packet. smb_size contains NetBIOS header + * so subtract 4 from it. */ + if ((nread < (smb_size - 4)) || !valid_smb_header(sconn, inbuf)) { + DEBUG(2,("Non-SMB packet of length %d. Terminating server\n", + smb_len(inbuf))); + + /* special magic for immediate exit */ + if ((nread == 9) && + (IVAL(inbuf, 4) == 0x74697865) && + lp_parm_bool(-1, "smbd", "suicide mode", false)) { + uint8_t exitcode = CVAL(inbuf, 8); + DEBUG(1, ("Exiting immediately with code %d\n", + (int)exitcode)); + exit(exitcode); + } + + exit_server_cleanly("Non-SMB packet"); + } + show_msg((char *)inbuf); construct_reply(sconn, (char *)inbuf, nread, unread_bytes, seqnum, -- 2.11.4.GIT