aboutsummaryrefslogtreecommitdiffstats
path: root/recipes
diff options
context:
space:
mode:
authorAnatoly Shipitsin <norguhtar@gmail.com>2010-08-30 06:47:58 +0000
committerKhem Raj <raj.khem@gmail.com>2010-10-20 18:30:26 -0700
commit2deeb9722f41c167503c242943a0df28349b77aa (patch)
tree0280df1b8aa69b4ecf352cfb9d9e523bd0c847b2 /recipes
parente685bea03a3321b830d4422727df821699eede93 (diff)
downloadopenembedded-2deeb9722f41c167503c242943a0df28349b77aa.tar.gz
update upstart.inc for fix upstart-sysvcompat
* change upstart-sysvtools to upstart-sysvcompat for right package build * move all sysvcompat tools to upstart-sysvcompat * add to upstart-sysvinit need for sysvcompat services from example-jobs * add inherit update-alternatives for right set and switch between inits * move base directory from /usr to /. This need for update-alternatives work right, see sysvinit recipe * add generation native tty services, similary as in sysvinit recipe * add update alternatives in upstart-sysvcompat and upstart packages Signed-off-by: Anatoly Shipitsin <norguhtar@gmail.com> Signed-off-by: Khem Raj <raj.khem@gmail.com>
Diffstat (limited to 'recipes')
-rw-r--r--recipes/upstart/upstart.inc111
1 files changed, 107 insertions, 4 deletions
diff --git a/recipes/upstart/upstart.inc b/recipes/upstart/upstart.inc
index e67774a21b..7512133a22 100644
--- a/recipes/upstart/upstart.inc
+++ b/recipes/upstart/upstart.inc
@@ -4,7 +4,7 @@ DEPENDS = ""
DESCRIPTION = "Event driven system init"
LICENSE = "GPL"
-inherit autotools pkgconfig
+inherit autotools pkgconfig update-alternatives
# --enable-compat builds halt, reboot, shutdown tools
EXTRA_OECONF += "--enable-compat"
@@ -17,6 +17,109 @@ FILES_libupstart-dev += "${libdir}/libupstart.* ${includedir}/upstart/"
# upstart-sysvcompat provides Sys V Init compatible tools: halt, reboot,
# shutdown, telinit. These might be needed by other scripts.
-PACKAGES =+ "upstart-sysvcompat upstart-sysvtools-doc"
-FILES_upstart-sysvcompat += "${sbindir}/reboot ${sbindir}/halt ${sbindir}/shutdown ${sbindir}/telinit"
-FILES_upstart-sysvcompat-doc += "${mandir}/*/reboot.* ${mandir}/*/halt.* ${mandir}/*/shutdown.* ${mandir}/*/telinit.*"
+PACKAGES =+ "upstart-sysvcompat upstart-sysvcompat-doc"
+FILES_upstart-sysvcompat += " \
+ ${base_sbindir}/reboot.* ${base_sbindir}/halt.* ${base_sbindir}/poweroff.* \
+ ${base_sbindir}/shutdown.* ${base_sbindir}/telinit ${base_sbindir}/runlevel \
+ ${sysconfdir}/event.d/control-alt-delete \
+ ${sysconfdir}/event.d/rc* \
+ ${sysconfdir}/event.d/sulogin \
+ ${sysconfdir}/init.d \
+ ${sysconfdir}/default/rcS \
+"
+FILES_upstart-sysvcompat-doc += " \
+ ${mandir}/*/reboot.* ${mandir}/*/halt.* ${mandir}/*/poweroff.* \
+ ${mandir}/*/shutdown.* ${mandir}/*/telinit.* ${mandir}/*/runlevel.* \
+"
+
+ALTERNATIVE_NAME = "init"
+ALTERNATIVE_LINK = "${base_sbindir}/init"
+ALTERNATIVE_PATH = "${base_sbindir}/init.${PN}"
+ALTERNATIVE_PRIORITY = "60"
+
+EXTRA_OEMAKE += "'bindir=${base_bindir}' \
+ 'sbindir=${base_sbindir}' \
+ 'usrbindir=${bindir}' \
+ 'usrsbindir=${sbindir}' \
+ 'includedir=${includedir}' \
+ 'mandir=${mandir}'"
+
+do_install () {
+ oe_runmake 'DESTDIR=${D}' install
+ install -d ${D}${sysconfdir}
+ install -d ${D}${sysconfdir}/default
+ install -d ${D}${sysconfdir}/init.d
+
+ install -m 0644 ${WORKDIR}/init/rcS-default ${D}${sysconfdir}/default/rcS
+ install -m 0755 ${WORKDIR}/init/rc ${D}${sysconfdir}/init.d
+ install -m 0755 ${WORKDIR}/init/rcS ${D}${sysconfdir}/init.d
+ install -m 0644 ${WORKDIR}/rc* ${D}${sysconfdir}/event.d
+ install -m 0644 ${WORKDIR}/control-alt-delete ${D}${sysconfdir}/event.d
+ install -m 0644 ${WORKDIR}/sulogin ${D}${sysconfdir}/event.d
+
+ if [ ! -z "${SERIAL_CONSOLE}" ]; then
+ cat <<EOF >> ${D}${sysconfdir}/event.d/tty-serial
+# tty-serial - getty
+#
+# This service maintains a getty on tty-serial from the point the system is
+# started until it is shut down again.
+
+start on runlevel 2
+start on runlevel 3
+start on runlevel 4
+start on runlevel 5
+
+stop on runlevel 0
+stop on runlevel 1
+stop on runlevel 6
+
+respawn
+exec ${base_sbindir}/getty ${SERIAL_CONSOLE}
+EOF
+ fi
+ if [ "${USE_VT}" = "1" ]; then
+ for n in ${SYSVINIT_ENABLED_GETTYS}
+ do
+ cat <<EOF >> ${D}${sysconfdir}/event.d/tty$n
+# tty$n - getty
+#
+# This service maintains a getty on tty$n from the point the system is
+# started until it is shut down again.
+
+start on runlevel 2
+start on runlevel 3
+start on runlevel 4
+start on runlevel 5
+
+stop on runlevel 0
+stop on runlevel 1
+stop on runlevel 6
+
+respawn
+exec ${base_sbindir}/getty 38400 tty$n
+EOF
+ done
+ fi
+
+ mv ${D}${base_sbindir}/init ${D}${base_sbindir}/init.${PN}
+ mv ${D}${base_sbindir}/halt ${D}${base_sbindir}/halt.${PN}
+ mv ${D}${base_sbindir}/reboot ${D}${base_sbindir}/reboot.${PN}
+ mv ${D}${base_sbindir}/shutdown ${D}${base_sbindir}/shutdown.${PN}
+ mv ${D}${base_sbindir}/poweroff ${D}${base_sbindir}/poweroff.${PN}
+}
+
+pkg_postinst_${PN}-sysvcompat () {
+#!/bin/sh
+update-alternatives --install ${base_sbindir}/reboot reboot reboot.${PN} 200
+update-alternatives --install ${base_sbindir}/halt halt halt.${PN} 200
+update-alternatives --install ${base_sbindir}/poweroff poweroff poweroff.${PN} 200
+update-alternatives --install ${base_sbindir}/shutdown shutdown shutdown.${PN} 200
+}
+
+pkg_prerm_${PN}-sysvcompat () {
+#!/bin/sh
+update-alternatives --remove reboot reboot.${PN}
+update-alternatives --remove halt halt.${PN}
+update-alternatives --remove poweroff reboot.${PN}
+update-alternatives --remove shutdown shutdown.${PN}
+}