1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
23c9f3681SJames Bottomley #ifndef _LINUX_STRING_HELPERS_H_
33c9f3681SJames Bottomley #define _LINUX_STRING_HELPERS_H_
43c9f3681SJames Bottomley 
5994b6970SAndy Shevchenko #include <linux/bits.h>
658eeba0bSVadim Pasternak #include <linux/ctype.h>
7fca76071SAndy Shevchenko #include <linux/string_choices.h>
8bfb3ba32SLucas De Marchi #include <linux/string.h>
93c9f3681SJames Bottomley #include <linux/types.h>
103c9f3681SJames Bottomley 
11acdb89b6SAndy Shevchenko struct device;
1221985319SKees Cook struct file;
13c6d24c32SAndy Shevchenko struct task_struct;
1421985319SKees Cook 
string_is_terminated(const char * s,int len)15f1db99c0SAndy Shevchenko static inline bool string_is_terminated(const char *s, int len)
16f1db99c0SAndy Shevchenko {
17f1db99c0SAndy Shevchenko 	return memchr(s, '\0', len) ? true : false;
18f1db99c0SAndy Shevchenko }
19f1db99c0SAndy Shevchenko 
203c9f3681SJames Bottomley /* Descriptions of the types of units to
213c9f3681SJames Bottomley  * print in */
223c9f3681SJames Bottomley enum string_size_units {
233c9f3681SJames Bottomley 	STRING_UNITS_10,	/* use powers of 10^3 (standard SI) */
243c9f3681SJames Bottomley 	STRING_UNITS_2,		/* use binary powers of 2^10 */
253c9f3681SJames Bottomley };
263c9f3681SJames Bottomley 
27b9f28d86SJames Bottomley void string_get_size(u64 size, u64 blk_size, enum string_size_units units,
283c9f3681SJames Bottomley 		     char *buf, int len);
293c9f3681SJames Bottomley 
30f0b93323SCezary Rojewski int parse_int_array_user(const char __user *from, size_t count, int **array);
31f0b93323SCezary Rojewski 
32994b6970SAndy Shevchenko #define UNESCAPE_SPACE		BIT(0)
33994b6970SAndy Shevchenko #define UNESCAPE_OCTAL		BIT(1)
34994b6970SAndy Shevchenko #define UNESCAPE_HEX		BIT(2)
35994b6970SAndy Shevchenko #define UNESCAPE_SPECIAL	BIT(3)
3616c7fa05SAndy Shevchenko #define UNESCAPE_ANY		\
3716c7fa05SAndy Shevchenko 	(UNESCAPE_SPACE | UNESCAPE_OCTAL | UNESCAPE_HEX | UNESCAPE_SPECIAL)
3816c7fa05SAndy Shevchenko 
39259fa5d7SAndy Shevchenko #define UNESCAPE_ALL_MASK	GENMASK(3, 0)
40259fa5d7SAndy Shevchenko 
4116c7fa05SAndy Shevchenko int string_unescape(char *src, char *dst, size_t size, unsigned int flags);
4216c7fa05SAndy Shevchenko 
string_unescape_inplace(char * buf,unsigned int flags)4316c7fa05SAndy Shevchenko static inline int string_unescape_inplace(char *buf, unsigned int flags)
4416c7fa05SAndy Shevchenko {
4516c7fa05SAndy Shevchenko 	return string_unescape(buf, buf, 0, flags);
4616c7fa05SAndy Shevchenko }
4716c7fa05SAndy Shevchenko 
string_unescape_any(char * src,char * dst,size_t size)4816c7fa05SAndy Shevchenko static inline int string_unescape_any(char *src, char *dst, size_t size)
4916c7fa05SAndy Shevchenko {
5016c7fa05SAndy Shevchenko 	return string_unescape(src, dst, size, UNESCAPE_ANY);
5116c7fa05SAndy Shevchenko }
5216c7fa05SAndy Shevchenko 
string_unescape_any_inplace(char * buf)5316c7fa05SAndy Shevchenko static inline int string_unescape_any_inplace(char *buf)
5416c7fa05SAndy Shevchenko {
5516c7fa05SAndy Shevchenko 	return string_unescape_any(buf, buf, 0);
5616c7fa05SAndy Shevchenko }
5716c7fa05SAndy Shevchenko 
58994b6970SAndy Shevchenko #define ESCAPE_SPACE		BIT(0)
59994b6970SAndy Shevchenko #define ESCAPE_SPECIAL		BIT(1)
60994b6970SAndy Shevchenko #define ESCAPE_NULL		BIT(2)
61994b6970SAndy Shevchenko #define ESCAPE_OCTAL		BIT(3)
62c8250381SAndy Shevchenko #define ESCAPE_ANY		\
63c8250381SAndy Shevchenko 	(ESCAPE_SPACE | ESCAPE_OCTAL | ESCAPE_SPECIAL | ESCAPE_NULL)
64994b6970SAndy Shevchenko #define ESCAPE_NP		BIT(4)
65c8250381SAndy Shevchenko #define ESCAPE_ANY_NP		(ESCAPE_ANY | ESCAPE_NP)
66994b6970SAndy Shevchenko #define ESCAPE_HEX		BIT(5)
67a0809783SAndy Shevchenko #define ESCAPE_NA		BIT(6)
680362c27fSAndy Shevchenko #define ESCAPE_NAP		BIT(7)
69aec0d096SAndy Shevchenko #define ESCAPE_APPEND		BIT(8)
70c8250381SAndy Shevchenko 
71259fa5d7SAndy Shevchenko #define ESCAPE_ALL_MASK		GENMASK(8, 0)
72259fa5d7SAndy Shevchenko 
7341416f23SRasmus Villemoes int string_escape_mem(const char *src, size_t isz, char *dst, size_t osz,
74b40bdb7fSKees Cook 		unsigned int flags, const char *only);
75c8250381SAndy Shevchenko 
string_escape_mem_any_np(const char * src,size_t isz,char * dst,size_t osz,const char * only)76c8250381SAndy Shevchenko static inline int string_escape_mem_any_np(const char *src, size_t isz,
77b40bdb7fSKees Cook 		char *dst, size_t osz, const char *only)
78c8250381SAndy Shevchenko {
79b40bdb7fSKees Cook 	return string_escape_mem(src, isz, dst, osz, ESCAPE_ANY_NP, only);
80c8250381SAndy Shevchenko }
81c8250381SAndy Shevchenko 
string_escape_str(const char * src,char * dst,size_t sz,unsigned int flags,const char * only)8241416f23SRasmus Villemoes static inline int string_escape_str(const char *src, char *dst, size_t sz,
83b40bdb7fSKees Cook 		unsigned int flags, const char *only)
84c8250381SAndy Shevchenko {
85b40bdb7fSKees Cook 	return string_escape_mem(src, strlen(src), dst, sz, flags, only);
86c8250381SAndy Shevchenko }
87c8250381SAndy Shevchenko 
string_escape_str_any_np(const char * src,char * dst,size_t sz,const char * only)8841416f23SRasmus Villemoes static inline int string_escape_str_any_np(const char *src, char *dst,
89b40bdb7fSKees Cook 		size_t sz, const char *only)
90c8250381SAndy Shevchenko {
91b40bdb7fSKees Cook 	return string_escape_str(src, dst, sz, ESCAPE_ANY_NP, only);
92c8250381SAndy Shevchenko }
93c8250381SAndy Shevchenko 
string_upper(char * dst,const char * src)9458eeba0bSVadim Pasternak static inline void string_upper(char *dst, const char *src)
9558eeba0bSVadim Pasternak {
9658eeba0bSVadim Pasternak 	do {
9758eeba0bSVadim Pasternak 		*dst++ = toupper(*src);
9858eeba0bSVadim Pasternak 	} while (*src++);
9958eeba0bSVadim Pasternak }
10058eeba0bSVadim Pasternak 
string_lower(char * dst,const char * src)10158eeba0bSVadim Pasternak static inline void string_lower(char *dst, const char *src)
10258eeba0bSVadim Pasternak {
10358eeba0bSVadim Pasternak 	do {
10458eeba0bSVadim Pasternak 		*dst++ = tolower(*src);
10558eeba0bSVadim Pasternak 	} while (*src++);
10658eeba0bSVadim Pasternak }
10758eeba0bSVadim Pasternak 
108b53f27e4SKees Cook char *kstrdup_quotable(const char *src, gfp_t gfp);
1090d044328SKees Cook char *kstrdup_quotable_cmdline(struct task_struct *task, gfp_t gfp);
11021985319SKees Cook char *kstrdup_quotable_file(struct file *file, gfp_t gfp);
111b53f27e4SKees Cook 
112*045ad464SAndy Shevchenko char *kstrdup_and_replace(const char *src, char old, char new, gfp_t gfp);
113*045ad464SAndy Shevchenko 
114418e0a35SAndy Shevchenko char **kasprintf_strarray(gfp_t gfp, const char *prefix, size_t n);
1150fd16012SBartosz Golaszewski void kfree_strarray(char **array, size_t n);
1160fd16012SBartosz Golaszewski 
117acdb89b6SAndy Shevchenko char **devm_kasprintf_strarray(struct device *dev, const char *prefix, size_t n);
118acdb89b6SAndy Shevchenko 
1193c9f3681SJames Bottomley #endif
120