summaryrefslogtreecommitdiff
path: root/src/core/mount.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/mount.c')
-rw-r--r--src/core/mount.c35
1 files changed, 29 insertions, 6 deletions
diff --git a/src/core/mount.c b/src/core/mount.c
index 549d7dbf98..b87b57b7ad 100644
--- a/src/core/mount.c
+++ b/src/core/mount.c
@@ -34,6 +34,7 @@
#include "strv.h"
#include "unit-name.h"
#include "unit.h"
+#include "utf8.h"
#define RETRY_UMOUNT_MAX 32
@@ -274,13 +275,35 @@ static int update_parameters_proc_self_mountinfo(
p = &m->parameters_proc_self_mountinfo;
- r = free_and_strdup(&p->what, what);
- if (r < 0)
- return r;
+ if (what && !utf8_is_valid(what)) {
+ _cleanup_free_ char *what_escaped = NULL;
- q = free_and_strdup(&p->options, options);
- if (q < 0)
- return q;
+ what_escaped = utf8_escape_invalid(what);
+ if (!what_escaped)
+ return -ENOMEM;
+
+ r = !streq_ptr(p->what, what_escaped);
+ free_and_replace(p->what, what_escaped);
+ } else {
+ r = free_and_strdup(&p->what, what);
+ if (r < 0)
+ return r;
+ }
+
+ if (options && !utf8_is_valid(options)) {
+ _cleanup_free_ char *options_escaped = NULL;
+
+ options_escaped = utf8_escape_invalid(options);
+ if (!options_escaped)
+ return -ENOMEM;
+
+ q = !streq_ptr(p->options, options_escaped);
+ free_and_replace(p->options, options_escaped);
+ } else {
+ q = free_and_strdup(&p->options, options);
+ if (q < 0)
+ return q;
+ }
w = free_and_strdup(&p->fstype, fstype);
if (w < 0)