From: "Yu, Mingli" <mingli.yu@windriver.com>
To: <openembedded-core@lists.openembedded.org>
Subject: [PATCH 1/2] dhclient: not always skip the nfsroot interface
Date: Thu, 2 Apr 2020 14:26:08 +0800 [thread overview]
Message-ID: <1585808769-176932-1-git-send-email-mingli.yu@windriver.com> (raw)
From: Mingli Yu <mingli.yu@windriver.com>
Don't skip the nfsroot interface when use dhcp
to get the address for nfsroot interface as the
nfsroot interface may need dhclient to renew
the lease.
Signed-off-by: Mingli Yu <mingli.yu@windriver.com>
---
.../dhcp/files/dhclient-systemd-wrapper | 26 +++++++++++++++++++++-
1 file changed, 25 insertions(+), 1 deletion(-)
diff --git a/meta/recipes-connectivity/dhcp/files/dhclient-systemd-wrapper b/meta/recipes-connectivity/dhcp/files/dhclient-systemd-wrapper
index 7d0e224..87c60fa 100644
--- a/meta/recipes-connectivity/dhcp/files/dhclient-systemd-wrapper
+++ b/meta/recipes-connectivity/dhcp/files/dhclient-systemd-wrapper
@@ -1,5 +1,19 @@
#!/bin/sh
+# Add an initial /var/lib/dhcp/dhclient.leases to make
+# sure the IP which dhclient try to renew is the same
+# with the IP which kernel got from dhcp server during
+# boot
+update_dhclient_leases()
+{
+ local addr=$1
+ local interface=$2
+ echo "lease {" >> /var/lib/dhcp/dhclient.leases
+ echo " interface \"${addr}\";" >> /var/lib/dhcp/dhclient.leases
+ echo " fixed-address ${interface:0:-3};" >> /var/lib/dhcp/dhclient.leases
+ echo "}" >> /var/lib/dhcp/dhclient.leases
+}
+
# In case the interface is used for nfs, skip it.
nfsroot=0
interfaces=""
@@ -19,6 +33,7 @@ while read dev mtpt fstype rest; do
done
exec 0<&9 9<&-
+
if [ $nfsroot -eq 0 ]; then
interfaces="$INTERFACES"
else
@@ -27,7 +42,16 @@ else
fi
for i in $INTERFACES; do
if test "x$i" = "x$nfs_iface"; then
- echo "dhclient skipping nfsroot interface $i"
+ interface_addr=`ip -4 address show $nfs_iface | grep 'inet '|sed 's/.*inet \(\S\+\).*/\1/'`
+ if [ "x$interface_addr" != "x" ] && cat /proc/cmdline | grep "ip=dhcp" > /dev/null ; then
+ # use to renew lease if needed
+ interfaces="$interfaces $i"
+ # use to update /var/lib/dhcp/dhclient.leases if needed
+ # when the ip got by kernel, we need use dhclient to renew the ip
+ update_dhclient_leases $nfs_iface $interface_addr
+ else
+ echo "dhclient skipping nfsroot interface $i"
+ fi
else
interfaces="$interfaces $i"
fi
--
2.7.4
next reply other threads:[~2020-04-02 6:26 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-04-02 6:26 Yu, Mingli [this message]
2020-04-02 6:26 ` [PATCH 2/2] dhcp: add RDEPENDS for dhcp-client Yu, Mingli
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1585808769-176932-1-git-send-email-mingli.yu@windriver.com \
--to=mingli.yu@windriver.com \
--cc=openembedded-core@lists.openembedded.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox