[linux-cifs-client] [PATCH 01/12] nls: add a nls_nullsize inline
Suresh Jayaraman
sjayaraman at suse.de
Thu Apr 30 08:20:11 GMT 2009
Jeff Layton wrote:
> It's possible for character sets to require a multi-byte null
> string terminator. Add a helper function that determines the size
> of the null terminator at runtime.
>
> Signed-off-by: Jeff Layton <jlayton at redhat.com>
> ---
> include/linux/nls.h | 19 +++++++++++++++++++
> 1 files changed, 19 insertions(+), 0 deletions(-)
>
> diff --git a/include/linux/nls.h b/include/linux/nls.h
> index 6a88220..52b1a76 100644
> --- a/include/linux/nls.h
> +++ b/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 */
Though any of the supported charsets does seem to use multi-byte null
termination, it makes more sense to have forward-compatible code with
negligible overhead.
Acked-by: Suresh Jayaraman <sjayaraman at suse.de>
More information about the linux-cifs-client
mailing list