diff --git a/[refs] b/[refs] index 5bfe5154aceb..053699ab564b 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: cbb7fe129bb2b836083ebcc256c43faff4b48cc2 +refs/heads/master: d37dc42ab6f040b8f0f2962ab219c5b2accf748d diff --git a/trunk/include/linux/nls.h b/trunk/include/linux/nls.h index 6a882208301a..52b1a76c1b43 100644 --- a/trunk/include/linux/nls.h +++ b/trunk/include/linux/nls.h @@ -58,6 +58,25 @@ static inline int nls_strnicmp(struct nls_table *t, const unsigned char *s1, return 0; } +/* + * nls_nullsize - return length of null character for codepage + * @codepage - codepage for which to return length of NULL terminator + * + * Since we can't guarantee that the null terminator will be a particular + * length, we have to check against the codepage. If there's a problem + * determining it, assume a single-byte NULL terminator. + */ +static inline int +nls_nullsize(const struct nls_table *codepage) +{ + int charlen; + char tmp[NLS_MAX_CHARSET_SIZE]; + + charlen = codepage->uni2char(0, tmp, NLS_MAX_CHARSET_SIZE); + + return charlen > 0 ? charlen : 1; +} + #define MODULE_ALIAS_NLS(name) MODULE_ALIAS("nls_" __stringify(name)) #endif /* _LINUX_NLS_H */