mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
string_helpers: Escape double quotes in escape_special
From an abstract point of view, escape_special's counterpart, unescape_special, already handles the unescaping of blackslashed double quote sequences. As a more practical example, printk indexing is an example case where this is already practically useful. Compare an example with `ESCAPE_SPECIAL | ESCAPE_SPACE`, with quotes not escaped: [root@ktst ~]# grep drivers/pci/pci-stub.c:69 /sys/kernel/debug/printk/index/vmlinux <4> drivers/pci/pci-stub.c:69 pci_stub_init "pci-stub: invalid ID string "%s"\n" ...and the same after this patch: [root@ktst ~]# grep drivers/pci/pci-stub.c:69 /sys/kernel/debug/printk/index/vmlinux <4> drivers/pci/pci-stub.c:69 pci_stub_init "pci-stub: invalid ID string \"%s\"\n" One can of course, alternatively, use ESCAPE_APPEND with a quote in @only, but without this patch quotes are coerced into hex or octal which can hurt readability quite significantly. I've checked uses of ESCAPE_SPECIAL and %pE across the codebase, and I'm pretty confident that this shouldn't affect any stable interfaces. Signed-off-by: Chris Down <chris@chrisdown.name> Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Reviewed-by: Petr Mladek <pmladek@suse.com> Cc: Rasmus Villemoes <linux@rasmusvillemoes.dk> Acked-by: Andy Shevchenko <andy.shevchenko@gmail.com> Signed-off-by: Petr Mladek <pmladek@suse.com> Link: https://lore.kernel.org/r/af144c5b75e41ce417386253ba2694456bc04118.1623775748.git.chris@chrisdown.name
This commit is contained in:
parent
e73f0f0ee7
commit
91027d0a7a
@ -361,6 +361,9 @@ static bool escape_special(unsigned char c, char **dst, char *end)
|
|||||||
case '\e':
|
case '\e':
|
||||||
to = 'e';
|
to = 'e';
|
||||||
break;
|
break;
|
||||||
|
case '"':
|
||||||
|
to = '"';
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -474,6 +477,7 @@ static bool escape_hex(unsigned char c, char **dst, char *end)
|
|||||||
* '\t' - horizontal tab
|
* '\t' - horizontal tab
|
||||||
* '\v' - vertical tab
|
* '\v' - vertical tab
|
||||||
* %ESCAPE_SPECIAL:
|
* %ESCAPE_SPECIAL:
|
||||||
|
* '\"' - double quote
|
||||||
* '\\' - backslash
|
* '\\' - backslash
|
||||||
* '\a' - alert (BEL)
|
* '\a' - alert (BEL)
|
||||||
* '\e' - escape
|
* '\e' - escape
|
||||||
|
@ -140,13 +140,13 @@ static const struct test_string_2 escape0[] __initconst = {{
|
|||||||
},{
|
},{
|
||||||
.in = "\\h\\\"\a\e\\",
|
.in = "\\h\\\"\a\e\\",
|
||||||
.s1 = {{
|
.s1 = {{
|
||||||
.out = "\\\\h\\\\\"\\a\\e\\\\",
|
.out = "\\\\h\\\\\\\"\\a\\e\\\\",
|
||||||
.flags = ESCAPE_SPECIAL,
|
.flags = ESCAPE_SPECIAL,
|
||||||
},{
|
},{
|
||||||
.out = "\\\\\\150\\\\\\042\\a\\e\\\\",
|
.out = "\\\\\\150\\\\\\\"\\a\\e\\\\",
|
||||||
.flags = ESCAPE_SPECIAL | ESCAPE_OCTAL,
|
.flags = ESCAPE_SPECIAL | ESCAPE_OCTAL,
|
||||||
},{
|
},{
|
||||||
.out = "\\\\\\x68\\\\\\x22\\a\\e\\\\",
|
.out = "\\\\\\x68\\\\\\\"\\a\\e\\\\",
|
||||||
.flags = ESCAPE_SPECIAL | ESCAPE_HEX,
|
.flags = ESCAPE_SPECIAL | ESCAPE_HEX,
|
||||||
},{
|
},{
|
||||||
/* terminator */
|
/* terminator */
|
||||||
@ -157,10 +157,10 @@ static const struct test_string_2 escape0[] __initconst = {{
|
|||||||
.out = "\eb \\C\007\"\x90\\r]",
|
.out = "\eb \\C\007\"\x90\\r]",
|
||||||
.flags = ESCAPE_SPACE,
|
.flags = ESCAPE_SPACE,
|
||||||
},{
|
},{
|
||||||
.out = "\\eb \\\\C\\a\"\x90\r]",
|
.out = "\\eb \\\\C\\a\\\"\x90\r]",
|
||||||
.flags = ESCAPE_SPECIAL,
|
.flags = ESCAPE_SPECIAL,
|
||||||
},{
|
},{
|
||||||
.out = "\\eb \\\\C\\a\"\x90\\r]",
|
.out = "\\eb \\\\C\\a\\\"\x90\\r]",
|
||||||
.flags = ESCAPE_SPACE | ESCAPE_SPECIAL,
|
.flags = ESCAPE_SPACE | ESCAPE_SPECIAL,
|
||||||
},{
|
},{
|
||||||
.out = "\\033\\142\\040\\134\\103\\007\\042\\220\\015\\135",
|
.out = "\\033\\142\\040\\134\\103\\007\\042\\220\\015\\135",
|
||||||
@ -169,10 +169,10 @@ static const struct test_string_2 escape0[] __initconst = {{
|
|||||||
.out = "\\033\\142\\040\\134\\103\\007\\042\\220\\r\\135",
|
.out = "\\033\\142\\040\\134\\103\\007\\042\\220\\r\\135",
|
||||||
.flags = ESCAPE_SPACE | ESCAPE_OCTAL,
|
.flags = ESCAPE_SPACE | ESCAPE_OCTAL,
|
||||||
},{
|
},{
|
||||||
.out = "\\e\\142\\040\\\\\\103\\a\\042\\220\\015\\135",
|
.out = "\\e\\142\\040\\\\\\103\\a\\\"\\220\\015\\135",
|
||||||
.flags = ESCAPE_SPECIAL | ESCAPE_OCTAL,
|
.flags = ESCAPE_SPECIAL | ESCAPE_OCTAL,
|
||||||
},{
|
},{
|
||||||
.out = "\\e\\142\\040\\\\\\103\\a\\042\\220\\r\\135",
|
.out = "\\e\\142\\040\\\\\\103\\a\\\"\\220\\r\\135",
|
||||||
.flags = ESCAPE_SPACE | ESCAPE_SPECIAL | ESCAPE_OCTAL,
|
.flags = ESCAPE_SPACE | ESCAPE_SPECIAL | ESCAPE_OCTAL,
|
||||||
},{
|
},{
|
||||||
.out = "\eb \\C\007\"\x90\r]",
|
.out = "\eb \\C\007\"\x90\r]",
|
||||||
|
Loading…
Reference in New Issue
Block a user