diff --git a/include/linux/string.h b/include/linux/string.h index 20b0829..62d743e 100644 --- a/include/linux/string.h +++ b/include/linux/string.h @@ -38,6 +38,9 @@ #ifndef __HAVE_ARCH_STRNCPY extern char * strncpy(char *,const char *, __kernel_size_t); #endif +#ifndef __HAVE_ARCH_STRLCPY +size_t strlcpy(char *, const char *, size_t); +#endif #ifndef __HAVE_ARCH_STRCAT extern char * strcat(char *, const char *); #endif diff --git a/include/stdio.h b/include/stdio.h index d591b6a..8bc45fa 100644 --- a/include/stdio.h +++ b/include/stdio.h @@ -36,6 +36,7 @@ char *asprintf(const char *fmt, ...); char *vasprintf(const char *fmt, va_list ap); int vsnprintf(char *buf, size_t size, const char *fmt, va_list args); +int vscnprintf(char *buf, size_t size, const char *fmt, va_list args); /* stderr */ #define eputc(c) console_putc(CONSOLE_STDERR, c) diff --git a/lib/string.c b/lib/string.c index cbb13d3..77435aa 100644 --- a/lib/string.c +++ b/lib/string.c @@ -62,6 +62,32 @@ #endif EXPORT_SYMBOL(strncpy); +#ifndef __HAVE_ARCH_STRLCPY +/** + * strlcpy - Copy a %NUL terminated string into a sized buffer + * @dest: Where to copy the string to + * @src: Where to copy the string from + * @size: size of destination buffer + * + * Compatible with *BSD: the result is always a valid + * NUL-terminated string that fits in the buffer (unless, + * of course, the buffer size is zero). It does not pad + * out the result like strncpy() does. + */ +size_t strlcpy(char *dest, const char *src, size_t size) +{ + size_t ret = strlen(src); + + if (size) { + size_t len = (ret >= size) ? size - 1 : ret; + memcpy(dest, src, len); + dest[len] = '\0'; + } + return ret; +} +EXPORT_SYMBOL(strlcpy); +#endif + #ifndef __HAVE_ARCH_STRCAT /** * strcat - Append one %NUL-terminated string to another