[systemd-commits] src/getty-generator.c
Lennart Poettering
lennart at kemper.freedesktop.org
Tue Aug 30 16:31:03 PDT 2011
src/getty-generator.c | 19 +++++++++++++------
1 file changed, 13 insertions(+), 6 deletions(-)
New commits:
commit a17b785b5fa57fba8cd658fdf710d5987413d9c2
Author: Lennart Poettering <lennart at poettering.net>
Date: Wed Aug 31 01:30:57 2011 +0200
getty-generator: ignore if symlinks already exist
diff --git a/src/getty-generator.c b/src/getty-generator.c
index 7cce76f..14cceb4 100644
--- a/src/getty-generator.c
+++ b/src/getty-generator.c
@@ -44,9 +44,15 @@ static int add_symlink(const char *fservice, const char *tservice) {
mkdir_parents(to, 0755);
- if ((r = symlink(from, to)) < 0) {
- log_error("Failed to create symlink from %s to %s: %m", from, to);
- r = -errno;
+ r = symlink(from, to);
+ if (r < 0) {
+ if (errno == EEXIST)
+ /* In case console=hvc is passed this will very likely result in EEXIST */
+ r = 0;
+ else {
+ log_error("Failed to create symlink from %s to %s: %m", from, to);
+ r = -errno;
+ }
}
finish:
@@ -88,7 +94,8 @@ int main(int argc, char *argv[]) {
if (read_one_line_file("/sys/class/tty/console/active", &active) >= 0) {
const char *tty;
- if ((tty = strrchr(active, ' ')))
+ tty = strrchr(active, ' ');
+ if (tty)
tty ++;
else
tty = active;
@@ -104,8 +111,8 @@ int main(int argc, char *argv[]) {
log_debug("Automatically adding serial getty for /dev/%s.", tty);
- if (!(n = unit_name_replace_instance("serial-getty at .service", tty)) ||
- add_symlink("serial-getty at .service", n) < 0)
+ n = unit_name_replace_instance("serial-getty at .service", tty);
+ if (!n || add_symlink("serial-getty at .service", n) < 0)
r = EXIT_FAILURE;
free(n);
More information about the systemd-commits
mailing list