cifs: Assume passwords are encoded according to iocharset (try #2)
authorShirish Pargaonkar <shirishpargaonkar@gmail.com>
Thu, 20 Oct 2011 18:21:59 +0000 (13:21 -0500)
committerSteve French <smfrench@gmail.com>
Sun, 30 Oct 2011 03:06:54 +0000 (22:06 -0500)
commit9ef5992e442b2b0bf6364bfcc5574e983a983159
treeffd83c890d6d82c525b6030e49b483fee194a8a9
parent5079276066cc421b48a6a63a54a34775979e8506
cifs: Assume passwords are encoded according to iocharset (try #2)

Re-posting a patch originally posted by Oskar Liljeblad after
rebasing on 3.2.

Modify cifs to assume that the supplied password is encoded according
to iocharset.  Before this patch passwords would be treated as
raw 8-bit data, which made authentication with Unicode passwords impossible
(at least passwords with characters > 0xFF).

The previous code would as a side effect accept passwords encoded with
ISO 8859-1, since Unicode < 0x100 basically is ISO 8859-1.  Software which
relies on that will no longer support password chars > 0x7F unless it also
uses iocharset=iso8859-1.  (mount.cifs does not care about the encoding so
it will work as expected.)

Signed-off-by: Oskar Liljeblad <oskar@osk.mine.nu>
Signed-off-by: Shirish Pargaonkar <shirishpargaonkar@gmail.com>
Reviewed-by: Pavel Shilovsky <piastry@etersoft.ru>
Tested-by: A <nimbus1_03087@yahoo.com>
Signed-off-by: Steve French <smfrench@gmail.com>
fs/cifs/cifsencrypt.c
fs/cifs/cifsproto.h
fs/cifs/connect.c
fs/cifs/sess.c
fs/cifs/smbencrypt.c