diff options
Diffstat (limited to 'fs/cifs/connect.c')
-rw-r--r-- | fs/cifs/connect.c | 38 |
1 files changed, 25 insertions, 13 deletions
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index 196976049c00..e27e5ad8b591 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c | |||
@@ -303,12 +303,12 @@ static int coalesce_t2(struct smb_hdr * psecond, struct smb_hdr *pTargetSMB) | |||
303 | byte_count += total_in_buf2; | 303 | byte_count += total_in_buf2; |
304 | BCC_LE(pTargetSMB) = cpu_to_le16(byte_count); | 304 | BCC_LE(pTargetSMB) = cpu_to_le16(byte_count); |
305 | 305 | ||
306 | byte_count = be32_to_cpu(pTargetSMB->smb_buf_length); | 306 | byte_count = pTargetSMB->smb_buf_length; |
307 | byte_count += total_in_buf2; | 307 | byte_count += total_in_buf2; |
308 | 308 | ||
309 | /* BB also add check that we are not beyond maximum buffer size */ | 309 | /* BB also add check that we are not beyond maximum buffer size */ |
310 | 310 | ||
311 | pTargetSMB->smb_buf_length = cpu_to_be32(byte_count); | 311 | pTargetSMB->smb_buf_length = byte_count; |
312 | 312 | ||
313 | if(remaining == total_in_buf2) { | 313 | if(remaining == total_in_buf2) { |
314 | cFYI(1,("found the last secondary response")); | 314 | cFYI(1,("found the last secondary response")); |
@@ -333,7 +333,7 @@ cifs_demultiplex_thread(struct TCP_Server_Info *server) | |||
333 | struct cifsSesInfo *ses; | 333 | struct cifsSesInfo *ses; |
334 | struct task_struct *task_to_wake = NULL; | 334 | struct task_struct *task_to_wake = NULL; |
335 | struct mid_q_entry *mid_entry; | 335 | struct mid_q_entry *mid_entry; |
336 | char *temp; | 336 | char temp; |
337 | int isLargeBuf = FALSE; | 337 | int isLargeBuf = FALSE; |
338 | int isMultiRsp; | 338 | int isMultiRsp; |
339 | int reconnect; | 339 | int reconnect; |
@@ -435,22 +435,32 @@ cifs_demultiplex_thread(struct TCP_Server_Info *server) | |||
435 | continue; | 435 | continue; |
436 | } | 436 | } |
437 | 437 | ||
438 | /* the right amount was read from socket - 4 bytes */ | 438 | /* The right amount was read from socket - 4 bytes */ |
439 | /* so we can now interpret the length field */ | ||
439 | 440 | ||
441 | /* the first byte big endian of the length field, | ||
442 | is actually not part of the length but the type | ||
443 | with the most common, zero, as regular data */ | ||
444 | temp = *((char *) smb_buffer); | ||
445 | |||
446 | /* Note that FC 1001 length is big endian on the wire, | ||
447 | but we convert it here so it is always manipulated | ||
448 | as host byte order */ | ||
440 | pdu_length = ntohl(smb_buffer->smb_buf_length); | 449 | pdu_length = ntohl(smb_buffer->smb_buf_length); |
441 | cFYI(1,("rfc1002 length(big endian)0x%x)", pdu_length+4)); | 450 | smb_buffer->smb_buf_length = pdu_length; |
451 | |||
452 | cFYI(1,("rfc1002 length 0x%x)", pdu_length+4)); | ||
442 | 453 | ||
443 | temp = (char *) smb_buffer; | 454 | if (temp == (char) RFC1002_SESSION_KEEP_ALIVE) { |
444 | if (temp[0] == (char) RFC1002_SESSION_KEEP_ALIVE) { | ||
445 | continue; | 455 | continue; |
446 | } else if (temp[0] == (char)RFC1002_POSITIVE_SESSION_RESPONSE) { | 456 | } else if (temp == (char)RFC1002_POSITIVE_SESSION_RESPONSE) { |
447 | cFYI(1,("Good RFC 1002 session rsp")); | 457 | cFYI(1,("Good RFC 1002 session rsp")); |
448 | continue; | 458 | continue; |
449 | } else if (temp[0] == (char)RFC1002_NEGATIVE_SESSION_RESPONSE) { | 459 | } else if (temp == (char)RFC1002_NEGATIVE_SESSION_RESPONSE) { |
450 | /* we get this from Windows 98 instead of | 460 | /* we get this from Windows 98 instead of |
451 | an error on SMB negprot response */ | 461 | an error on SMB negprot response */ |
452 | cFYI(1,("Negative RFC1002 Session Response Error 0x%x)", | 462 | cFYI(1,("Negative RFC1002 Session Response Error 0x%x)", |
453 | temp[4])); | 463 | pdu_length)); |
454 | if(server->tcpStatus == CifsNew) { | 464 | if(server->tcpStatus == CifsNew) { |
455 | /* if nack on negprot (rather than | 465 | /* if nack on negprot (rather than |
456 | ret of smb negprot error) reconnecting | 466 | ret of smb negprot error) reconnecting |
@@ -472,9 +482,10 @@ cifs_demultiplex_thread(struct TCP_Server_Info *server) | |||
472 | wake_up(&server->response_q); | 482 | wake_up(&server->response_q); |
473 | continue; | 483 | continue; |
474 | } | 484 | } |
475 | } else if (temp[0] != (char) 0) { | 485 | } else if (temp != (char) 0) { |
476 | cERROR(1,("Unknown RFC 1002 frame")); | 486 | cERROR(1,("Unknown RFC 1002 frame")); |
477 | cifs_dump_mem(" Received Data: ", temp, length); | 487 | cifs_dump_mem(" Received Data: ", (char *)smb_buffer, |
488 | length); | ||
478 | cifs_reconnect(server); | 489 | cifs_reconnect(server); |
479 | csocket = server->ssocket; | 490 | csocket = server->ssocket; |
480 | continue; | 491 | continue; |
@@ -609,7 +620,8 @@ multi_t2_fnd: | |||
609 | } else if ((is_valid_oplock_break(smb_buffer) == FALSE) | 620 | } else if ((is_valid_oplock_break(smb_buffer) == FALSE) |
610 | && (isMultiRsp == FALSE)) { | 621 | && (isMultiRsp == FALSE)) { |
611 | cERROR(1, ("No task to wake, unknown frame rcvd!")); | 622 | cERROR(1, ("No task to wake, unknown frame rcvd!")); |
612 | cifs_dump_mem("Received Data is: ",temp,sizeof(struct smb_hdr)); | 623 | cifs_dump_mem("Received Data is: ",(char *)smb_buffer, |
624 | sizeof(struct smb_hdr)); | ||
613 | } | 625 | } |
614 | } /* end while !EXITING */ | 626 | } /* end while !EXITING */ |
615 | 627 | ||