]> code.ossystems Code Review - openembedded-core.git/commitdiff
systemd: fix systemctl enable script for template units
authorEnrico Jorns <ejo@pengutronix.de>
Tue, 12 Jan 2016 12:55:43 +0000 (13:55 +0100)
committerRichard Purdie <richard.purdie@linuxfoundation.org>
Fri, 29 Jan 2016 18:14:55 +0000 (18:14 +0000)
The systemctl script supports enabling template units by evaluating
"DefaultInstance" parameter. Unfortunately, due to the sed replacement
mechanism, all escaping used in the DefaultInstance string, e.g. for
giving path names with dashes, is expanded too early.

Thus for

  DefaultInstance=-path\x2dwith\x2ddashes

a path unit `foobar@.path` will be installed with a symlink named

  foobar@-path-with-dashed.path

that is interpreted as the path `/path/with/dashes` instead of the
intended path nam `/path-with-dashes`.

To fix this behavior additional escaping of the backslashes in the
`DefaultInstance` string is required so that sed does not expand the
escaped characters.

Signed-off-by: Enrico Jorns <ejo@pengutronix.de>
Signed-off-by: Ross Burton <ross.burton@intel.com>
meta/recipes-core/systemd/systemd-systemctl/systemctl

index 6e163bd5c2632541d6bfb2cbe9b64b475dfdf76c..697fbd59dfd4e65e314285e658443b2ce32992d5 100755 (executable)
@@ -136,7 +136,7 @@ for service in $services; do
                                        continue
                                else
                                        echo "Found DefaultInstance $default_instance, enabling it"
-                                       enable_service=$(echo $service | sed "s/@/@$default_instance/")
+                                       enable_service=$(echo $service | sed "s/@/@$(echo $default_instance | sed 's/\\/\\\\/g')/")
                                fi
                        fi
                        mkdir -p $ROOT/etc/systemd/system/$r.wants