mirror of
https://git.yoctoproject.org/poky
synced 2026-04-13 23:02:30 +02:00
dhcp: add dhclient.service
Add dhclient.service. This service file mainly comes from meta-systemd, with modifications to take nfs boot into consideration. While using eth0 as the nfsboot interface, we'd like dhclient service to skip it like what ifup and connman do in sysvinit. (From OE-Core rev: faa8d0f5e8db4a99367d42ba8c8de5b2e339d8d2) Signed-off-by: Chen Qi <Qi.Chen@windriver.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
@@ -17,6 +17,8 @@ SRC_URI = "http://ftp.isc.org/isc/dhcp/${PV}/dhcp-${PV}.tar.gz \
|
||||
file://init-relay file://default-relay \
|
||||
file://init-server file://default-server \
|
||||
file://dhclient.conf file://dhcpd.conf \
|
||||
file://dhclient-systemd-wrapper \
|
||||
file://dhclient.service \
|
||||
file://dhcpd.service file://dhcrelay.service \
|
||||
file://dhcpd6.service \
|
||||
file://search-for-libxml2.patch "
|
||||
@@ -29,13 +31,16 @@ inherit autotools systemd useradd update-rc.d
|
||||
USERADD_PACKAGES = "${PN}-server"
|
||||
USERADD_PARAM_${PN}-server = "--system --no-create-home --home-dir /var/run/${PN} --shell /bin/false --user-group ${PN}"
|
||||
|
||||
SYSTEMD_PACKAGES = "${PN}-server ${PN}-relay"
|
||||
SYSTEMD_PACKAGES = "${PN}-server ${PN}-relay ${PN}-client"
|
||||
SYSTEMD_SERVICE_${PN}-server = "dhcpd.service dhcpd6.service"
|
||||
SYSTEMD_AUTO_ENABLE_${PN}-server = "disable"
|
||||
|
||||
SYSTEMD_SERVICE_${PN}-relay = "dhcrelay.service"
|
||||
SYSTEMD_AUTO_ENABLE_${PN}-relay = "disable"
|
||||
|
||||
SYSTEMD_SERVICE_${PN}-client = "dhclient.service"
|
||||
SYSTEMD_AUTO_ENABLE_${PN}-client = "disable"
|
||||
|
||||
INITSCRIPT_PACKAGES = "dhcp-server"
|
||||
INITSCRIPT_NAME_dhcp-server = "dhcp-server"
|
||||
INITSCRIPT_PARAMS_dhcp-server = "defaults"
|
||||
@@ -79,7 +84,13 @@ do_install_append () {
|
||||
sed -i -e 's,@SYSCONFDIR@,${sysconfdir},g' ${D}${systemd_unitdir}/system/dhcpd*.service
|
||||
sed -i -e 's,@base_bindir@,${base_bindir},g' ${D}${systemd_unitdir}/system/dhcpd*.service
|
||||
sed -i -e 's,@localstatedir@,${localstatedir},g' ${D}${systemd_unitdir}/system/dhcpd*.service
|
||||
sed -i -e 's,@SYSCONFDIR@,${sysconfdir},g' ${D}${systemd_unitdir}/system/dhcrelay.service
|
||||
sed -i -e 's,@SYSCONFDIR@,${sysconfdir},g' ${D}${systemd_unitdir}/system/dhcrelay.service
|
||||
|
||||
install -d ${D}${base_sbindir}
|
||||
install -m 0755 ${WORKDIR}/dhclient-systemd-wrapper ${D}${base_sbindir}/dhclient-systemd-wrapper
|
||||
install -m 0644 ${WORKDIR}/dhclient.service ${D}${systemd_unitdir}/system
|
||||
sed -i -e 's,@SYSCONFDIR@,${sysconfdir},g' ${D}${systemd_unitdir}/system/dhclient.service
|
||||
sed -i -e 's,@BASE_SBINDIR@,${base_sbindir},g' ${D}${systemd_unitdir}/system/dhclient.service
|
||||
}
|
||||
|
||||
PACKAGES += "dhcp-libs dhcp-server dhcp-server-config dhcp-client dhcp-relay dhcp-omshell"
|
||||
@@ -97,7 +108,11 @@ FILES_${PN}-server-config = "${sysconfdir}/default/dhcp-server ${sysconfdir}/dhc
|
||||
|
||||
FILES_${PN}-relay = "${sbindir}/dhcrelay ${sysconfdir}/init.d/dhcp-relay ${sysconfdir}/default/dhcp-relay"
|
||||
|
||||
FILES_${PN}-client = "${base_sbindir}/dhclient ${base_sbindir}/dhclient-script ${sysconfdir}/dhcp/dhclient.conf"
|
||||
FILES_${PN}-client = "${base_sbindir}/dhclient \
|
||||
${base_sbindir}/dhclient-script \
|
||||
${sysconfdir}/dhcp/dhclient.conf \
|
||||
${base_sbindir}/dhclient-systemd-wrapper \
|
||||
"
|
||||
|
||||
FILES_${PN}-omshell = "${bindir}/omshell"
|
||||
|
||||
|
||||
@@ -0,0 +1,39 @@
|
||||
#!/bin/sh
|
||||
|
||||
# In case the interface is used for nfs, skip it.
|
||||
nfsroot=0
|
||||
interfaces=""
|
||||
exec 9<&0 < /proc/mounts
|
||||
while read dev mtpt fstype rest; do
|
||||
if test $mtpt = "/" ; then
|
||||
case $fstype in
|
||||
nfs | nfs4)
|
||||
nfsroot=1
|
||||
nfs_addr=`echo $rest | sed -e 's/^.*addr=\([0-9.]*\).*$/\1/'`
|
||||
break
|
||||
;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
done
|
||||
exec 0<&9 9<&-
|
||||
|
||||
if [ $nfsroot -eq 0 ]; then
|
||||
interfaces="$INTERFACES"
|
||||
else
|
||||
if [ -x /bin/ip -o -x /sbin/ip ] ; then
|
||||
nfs_iface=`ip route get $nfs_addr | grep dev | sed -e 's/^.*dev \([-a-z0-9.]*\).*$/\1/'`
|
||||
fi
|
||||
for i in $INTERFACES; do
|
||||
if test "x$i" = "x$nfs_iface"; then
|
||||
echo "dhclient skipping nfsroot interface $i"
|
||||
else
|
||||
interfaces="$interfaces $i"
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
if test "x$interfaces" != "x"; then
|
||||
/sbin/dhclient -d -cf /etc/dhcp/dhclient.conf -q -lf /var/lib/dhcp/dhclient.leases $interfaces
|
||||
fi
|
||||
13
meta/recipes-connectivity/dhcp/files/dhclient.service
Normal file
13
meta/recipes-connectivity/dhcp/files/dhclient.service
Normal file
@@ -0,0 +1,13 @@
|
||||
[Unit]
|
||||
Description=Dynamic Host Configuration Protocol (DHCP)
|
||||
Wants=network.target
|
||||
Before=network.target
|
||||
After=systemd-udevd.service
|
||||
|
||||
[Service]
|
||||
EnvironmentFile=-@SYSCONFDIR@/default/dhcp-client
|
||||
ExecStart=@BASE_SBINDIR@/dhclient-systemd-wrapper
|
||||
RemainAfterExit=yes
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
||||
Reference in New Issue
Block a user