aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Xavier Ruppen <xruppen@gmail.com>2019-03-04 20:25:47 +0100
committerGravatar Peter Korsgaard <peter@korsgaard.com>2019-03-17 23:14:14 +0100
commit66681350b412aefae5a08dc82f72bd41daa8b9cd (patch)
tree49eb300b29ca3fe769b0f88a2403b325180952e7
parent4bce0718f25413838c393ac2a24ac2b20e8bc160 (diff)
downloadbuildroot-66681350b412aefae5a08dc82f72bd41daa8b9cd.tar.gz
buildroot-66681350b412aefae5a08dc82f72bd41daa8b9cd.tar.bz2
package/systemd: fix "Timed out waiting for device /dev/console."
Buildroot built with systemd fails to open a login prompt on the serial port when /dev/console is specified as BR2_TARGET_GENERIC_GETTY_PORT (which is its default value): systemd[1]: dev-console.device: Job dev-console.device/start timed out. systemd[1]: Timed out waiting for device /dev/console. systemd[1]: Dependency failed for Serial Getty on console. systemd[1]: serial-getty@console.service: Job serial-getty@console.service/start failed with result 'dependency'. systemd[1]: dev-console.device: Job dev-console.device/start failed with result 'timeout'. systemd[1]: Reached target Login Prompts. systemd[1]: Reached target Multi-User System. According to this issue on Github [1], serial-getty@.service should not be instantiated on /dev/console, console-getty@.service should be used instead. This stems from the fact that there should be no dependency on /dev/console. [1] https://github.com/systemd/systemd/issues/10914 Signed-off-by: Xavier Ruppen <xruppen@gmail.com> Reviewed-by: "Yann E. MORIN" <yann.morin.1998@free.fr> [Peter: drop SERVICE variable as suggested by Yann] Signed-off-by: Peter Korsgaard <peter@korsgaard.com> (cherry picked from commit 940e7deab09e34585a5b70dd6ce1c9afd22fd8f3) Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
-rw-r--r--package/systemd/systemd.mk19
1 files changed, 13 insertions, 6 deletions
diff --git a/package/systemd/systemd.mk b/package/systemd/systemd.mk
index 4dea7d340d..d636fb5536 100644
--- a/package/systemd/systemd.mk
+++ b/package/systemd/systemd.mk
@@ -366,19 +366,26 @@ endef
ifneq ($(call qstrip,$(BR2_TARGET_GENERIC_GETTY_PORT)),)
# systemd needs getty.service for VTs and serial-getty.service for serial ttys
+# note that console-getty.service should be used on /dev/console as it should not have dependencies
# also patch the file to use the correct baud-rate, the default baudrate is 115200 so look for that
define SYSTEMD_INSTALL_SERVICE_TTY
- if echo $(BR2_TARGET_GENERIC_GETTY_PORT) | egrep -q 'tty[0-9]*$$'; \
+ if [ $(BR2_TARGET_GENERIC_GETTY_PORT) = "console" ]; \
then \
- SERVICE="getty"; \
+ TARGET="console-getty.service"; \
+ LINK_NAME="console-getty.service"; \
+ elif echo $(BR2_TARGET_GENERIC_GETTY_PORT) | egrep -q 'tty[0-9]*$$'; \
+ then \
+ TARGET="getty@.service"; \
+ LINK_NAME="getty@$(call qstrip,$(BR2_TARGET_GENERIC_GETTY_PORT)).service"; \
else \
- SERVICE="serial-getty"; \
+ TARGET="serial-getty@.service"; \
+ LINK_NAME="serial-getty@$(call qstrip,$(BR2_TARGET_GENERIC_GETTY_PORT)).service"; \
fi; \
- ln -fs ../../../../lib/systemd/system/$${SERVICE}@.service \
- $(TARGET_DIR)/etc/systemd/system/getty.target.wants/$${SERVICE}@$(BR2_TARGET_GENERIC_GETTY_PORT).service; \
+ ln -fs ../../../../lib/systemd/system/$${TARGET} \
+ $(TARGET_DIR)/etc/systemd/system/getty.target.wants/$${LINK_NAME}; \
if [ $(call qstrip,$(BR2_TARGET_GENERIC_GETTY_BAUDRATE)) -gt 0 ] ; \
then \
- $(SED) 's,115200,$(BR2_TARGET_GENERIC_GETTY_BAUDRATE),' $(TARGET_DIR)/lib/systemd/system/$${SERVICE}@.service; \
+ $(SED) 's,115200,$(BR2_TARGET_GENERIC_GETTY_BAUDRATE),' $(TARGET_DIR)/lib/systemd/system/$${TARGET}; \
fi
endef
endif