aboutsummaryrefslogtreecommitdiffstats
path: root/fs/cifs/cifs_unicode.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/cifs/cifs_unicode.c')
-rw-r--r--fs/cifs/cifs_unicode.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/fs/cifs/cifs_unicode.c b/fs/cifs/cifs_unicode.c
index 8389f359b03d..614512573c67 100644
--- a/fs/cifs/cifs_unicode.c
+++ b/fs/cifs/cifs_unicode.c
@@ -26,6 +26,37 @@
26#include "cifs_debug.h" 26#include "cifs_debug.h"
27 27
28/* 28/*
29 * cifs_ucs2_bytes - how long will a string be after conversion?
30 * @ucs - pointer to input string
31 * @maxbytes - don't go past this many bytes of input string
32 * @codepage - destination codepage
33 *
34 * Walk a ucs2le string and return the number of bytes that the string will
35 * be after being converted to the given charset, not including any null
36 * termination required. Don't walk past maxbytes in the source buffer.
37 */
38int
39cifs_ucs2_bytes(const __le16 *from, int maxbytes,
40 const struct nls_table *codepage)
41{
42 int i;
43 int charlen, outlen = 0;
44 int maxwords = maxbytes / 2;
45 char tmp[NLS_MAX_CHARSET_SIZE];
46
47 for (i = 0; from[i] && i < maxwords; i++) {
48 charlen = codepage->uni2char(le16_to_cpu(from[i]), tmp,
49 NLS_MAX_CHARSET_SIZE);
50 if (charlen > 0)
51 outlen += charlen;
52 else
53 outlen++;
54 }
55
56 return outlen;
57}
58
59/*
29 * cifs_mapchar - convert a little-endian char to proper char in codepage 60 * cifs_mapchar - convert a little-endian char to proper char in codepage
30 * @target - where converted character should be copied 61 * @target - where converted character should be copied
31 * @src_char - 2 byte little-endian source character 62 * @src_char - 2 byte little-endian source character