diff options
author | Steve French <smfrench@us.ibm.com> | 2013-06-25 14:03:16 -0500 |
---|---|---|
committer | Steve French <smfrench@gmail.com> | 2013-06-26 17:31:45 -0500 |
commit | fdf96a907c1fbb93c633e2b7ede3b8df26d6a4c0 (patch) | |
tree | c6941390435b58b2cb117fd1537d4d60bc6c5f47 /fs/cifs/cifs_unicode.h | |
parent | 2a2c41c07c710f2c1afe3748bdde40db9ea9d9e6 (diff) | |
download | linux-fdf96a907c1fbb93c633e2b7ede3b8df26d6a4c0.tar.gz linux-fdf96a907c1fbb93c633e2b7ede3b8df26d6a4c0.tar.bz2 linux-fdf96a907c1fbb93c633e2b7ede3b8df26d6a4c0.zip |
Handle big endianness in NTLM (ntlmv2) authentication
This is RH bug 970891
Uppercasing of username during calculation of ntlmv2 hash fails
because UniStrupr function does not handle big endian wchars.
Also fix a comment in the same code to reflect its correct usage.
[To make it easier for stable (rather than require 2nd patch) fixed
this patch of Shirish's to remove endian warning generated
by sparse -- steve f.]
Reported-by: steve <sanpatr1@in.ibm.com>
Signed-off-by: Shirish Pargaonkar <shirishpargaonkar@gmail.com>
Cc: <stable@kernel.org>
Reviewed-by: Jeff Layton <jlayton@redhat.com>
Signed-off-by: Steve French <smfrench@gmail.com>
Diffstat (limited to 'fs/cifs/cifs_unicode.h')
-rw-r--r-- | fs/cifs/cifs_unicode.h | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/fs/cifs/cifs_unicode.h b/fs/cifs/cifs_unicode.h index 4fb097468e21..fe8d6276410a 100644 --- a/fs/cifs/cifs_unicode.h +++ b/fs/cifs/cifs_unicode.h @@ -327,14 +327,14 @@ UniToupper(register wchar_t uc) /* * UniStrupr: Upper case a unicode string */ -static inline wchar_t * -UniStrupr(register wchar_t *upin) +static inline __le16 * +UniStrupr(register __le16 *upin) { - register wchar_t *up; + register __le16 *up; up = upin; while (*up) { /* For all characters */ - *up = UniToupper(*up); + *up = cpu_to_le16(UniToupper(le16_to_cpu(*up))); up++; } return upin; /* Return input pointer */ |