From: Michael Olbrich <m.olbrich@pengutronix.de>
To: ptxdist@pengutronix.de
Cc: Roland Hieber <rhi@pengutronix.de>
Subject: Re: [ptxdist] [APPLIED] busybox: update udhcp config files
Date: Tue, 29 Jun 2021 07:09:26 +0200 [thread overview]
Message-ID: <20210629050926.2524480-1-m.olbrich@pengutronix.de> (raw)
In-Reply-To: <20210620173954.5608-1-rhi@pengutronix.de>
Thanks, applied as 320816c70b01e6376ddf450fa55028ef2ff6fb06.
Michael
[sent from post-receive hook]
On Tue, 29 Jun 2021 07:09:26 +0200, Roland Hieber <rhi@pengutronix.de> wrote:
> Copy the following files from busybox 1.33:
>
> * examples/udhcp/simple.script
> * examples/udhcp/udhcpd.conf
>
> This teaches the DHCP client to use iproute2 tools instead of the
> outdated iputils.
>
> Signed-off-by: Roland Hieber <rhi@pengutronix.de>
> Message-Id: <20210620173954.5608-1-rhi@pengutronix.de>
> Signed-off-by: Michael Olbrich <m.olbrich@pengutronix.de>
>
> diff --git a/projectroot/etc/udhcpc.script b/projectroot/etc/udhcpc.script
> index 130c37e0ce6a..f079ec8b849f 100644
> --- a/projectroot/etc/udhcpc.script
> +++ b/projectroot/etc/udhcpc.script
> @@ -1,38 +1,74 @@
> #!/bin/sh
> +# udhcpc script edited by Tim Riker <Tim@Rikers.org>
>
> -# $Id$
> +RESOLV_CONF="/etc/resolv.conf"
>
> -[ -z "$1" ] && echo "Error: should be called from udhcpc" && exit 1
> +[ -n "$1" ] || { echo "Error: should be called from udhcpc"; exit 1; }
>
> -RESOLV_CONF="/etc/resolv.conf"
> +NETMASK=""
> +if command -v ip >/dev/null; then
> + [ -n "$subnet" ] && NETMASK="/$subnet"
> +else
> + [ -n "$subnet" ] && NETMASK="netmask $subnet"
> +fi
> +BROADCAST="broadcast +"
> [ -n "$broadcast" ] && BROADCAST="broadcast $broadcast"
> -[ -n "$subnet" ] && NETMASK="netmask $subnet"
>
> case "$1" in
> deconfig)
> - /sbin/ifconfig $interface 0.0.0.0
> + echo "Clearing IP addresses on $interface, upping it"
> + if command -v ip >/dev/null; then
> + ip -4 addr flush dev $interface
> + ip link set dev $interface up
> + else
> + ifconfig $interface 0.0.0.0
> + fi
> ;;
>
> renew|bound)
> - /sbin/ifconfig $interface $ip $BROADCAST $NETMASK
> + echo "Setting IP address $ip on $interface"
> + if command -v ip >/dev/null; then
> + ip addr add $ip$NETMASK $BROADCAST dev $interface
> + else
> + ifconfig $interface $ip $NETMASK $BROADCAST
> + fi
>
> if [ -n "$router" ] ; then
> - echo "deleting routers"
> + echo "Deleting routers"
> while route del default gw 0.0.0.0 dev $interface ; do
> :
> done
>
> + metric=0
> for i in $router ; do
> - route add default gw $i dev $interface
> + echo "Adding router $i"
> + if [ "$subnet" = "255.255.255.255" ]; then
> + # special case for /32 subnets:
> + # /32 instructs kernel to always use routing for all outgoing packets
> + # (they can never be sent to local subnet - there is no local subnet for /32).
> + # Used in datacenters, avoids the need for private ip-addresses between two hops.
> + ip route add $i dev $interface
> + fi
> + route add default gw $i dev $interface metric $((metric++))
> done
> fi
>
> - echo -n > $RESOLV_CONF
> - [ -n "$domain" ] && echo search $domain >> $RESOLV_CONF
> + # If the file is a symlink somewhere (like /etc/resolv.conf
> + # pointing to /run/resolv.conf), make sure things work.
> + if test -L "$RESOLV_CONF"; then
> + # If it's a dangling symlink, try to create the target.
> + test -e "$RESOLV_CONF" || touch "$RESOLV_CONF"
> + fi
> + realconf=$(readlink -f "$RESOLV_CONF" 2>/dev/null || echo "$RESOLV_CONF")
> + echo "Recreating $realconf"
> + tmpfile="$realconf-$$"
> + > "$tmpfile"
> + [ -n "$domain" ] && echo "search $domain" >> "$tmpfile"
> for i in $dns ; do
> - echo adding dns $i
> - echo nameserver $i >> $RESOLV_CONF
> + echo " Adding DNS server $i"
> + echo "nameserver $i" >> "$tmpfile"
> done
> + mv "$tmpfile" "$realconf"
> ;;
> esac
>
> diff --git a/projectroot/etc/udhcpd.conf b/projectroot/etc/udhcpd.conf
> index eca44c0ab41e..6eb10852e2e6 100644
> --- a/projectroot/etc/udhcpd.conf
> +++ b/projectroot/etc/udhcpd.conf
> @@ -44,7 +44,7 @@ interface eth0
> #notify_file # default: no script
> #notify_file dumpleases # useful for debugging
>
> -# The following are bootp specific options
> +# The following are BOOTP specific options
> # next server to use in bootstrap
> #siaddr 192.168.0.22 # default: 0.0.0.0 (none)
> # tftp server name
> @@ -52,9 +52,14 @@ interface eth0
> # tftp file to download (e.g. kernel image)
> #boot_file /var/nfs_root # default: none
>
> +# NOTE: "boot_file FILE" and "opt bootfile FILE" are conceptually the same,
> +# but "boot_file" goes into BOOTP-defined fixed-size field in the packet,
> +# whereas "opt bootfile" goes into DHCP option 0x43.
> +# Same for "sname HOST" and "opt tftp HOST".
> +
> # Static leases map
> #static_lease 00:60:08:11:CE:4E 192.168.0.54
> -#static_lease 00:60:08:11:CE:3E 192.168.0.44
> +#static_lease 00:60:08:11:CE:3E 192.168.0.44 optional_hostname
>
> # The remainder of options are DHCP options and can be specified with the
> # keyword 'opt' or 'option'. If an option can take multiple items, such
> @@ -70,46 +75,56 @@ option domain local
> option lease 864000 # default: 10 days
> option msstaticroutes 10.0.0.0/8 10.127.0.1 # single static route
> option staticroutes 10.0.0.0/8 10.127.0.1, 10.11.12.0/24 10.11.12.1
> -# Arbitrary option in hex form:
> +# Arbitrary option in hex or string form:
> option 0x08 01020304 # option 8: "cookie server IP addr: 1.2.3.4"
> +option 14 "dumpfile"
>
> -# Currently supported options (for more info, see options.c):
> -#opt lease NUM
> -#opt subnet IP
> -#opt broadcast IP
> -#opt router IP_LIST
> -#opt ipttl NUM
> -#opt mtu NUM
> -#opt hostname STRING # client's hostname
> -#opt domain STRING # client's domain suffix
> -#opt search STRING_LIST # search domains
> -#opt nisdomain STRING
> -#opt timezone NUM # (localtime - UTC_time) in seconds. signed
> -#opt tftp STRING # tftp server name
> -#opt bootfile STRING # tftp file to download (e.g. kernel image)
> -#opt bootsize NUM # size of that file
> -#opt rootpath STRING # (NFS) path to mount as root fs
> -#opt wpad STRING
> -#opt serverid IP # default: server's IP
> -#opt message STRING # error message (udhcpd sends it on success too)
> -#opt vlanid NUM # 802.1P VLAN ID
> -#opt vlanpriority NUM # 802.1Q VLAN priority
> +# Currently supported options [hex option value] (for more info, see common.c):
> +#opt lease NUM # [0x33]
> +#opt subnet IP # [0x01]
> +#opt broadcast IP # [0x1c]
> +#opt router IP_LIST # [0x03]
> +#opt ipttl NUM # [0x17]
> +#opt mtu NUM # [0x1a]
> +#opt hostname STRING # [0x0c] client's hostname
> +#opt domain STRING # [0x0f] client's domain suffix
> +#opt search STRING_LIST # [0x77] search domains
> +#opt nisdomain STRING # [0x28]
> +#opt timezone NUM # [0x02] (localtime - UTC_time) in seconds. signed
> +#opt tzstr STRING # [0x64] RFC 4833. IEEE 1003.1 TZ string
> +#opt tzdbstr STRING # [0x65] RFC 4833. Reference to the TZ database string
> +#opt tftp STRING # [0x42] tftp server name
> +#opt bootfile STRING # [0x43] tftp file to download (e.g. kernel image)
> +#opt bootsize NUM # [0x0d] size of that file
> +#opt rootpath STRING # [0x11] (NFS) path to mount as root fs
> +#opt wpad STRING # [0xfc] Web Proxy Auto Discovery Protocol
> +#opt serverid IP # [0x36] default: server's IP
> +#opt message STRING # [0x38] error message (if set, udhcpd would send it on success too)
> +#opt vlanid NUM # [0x84] 802.1P VLAN ID
> +#opt vlanpriority NUM # [0x85] 802.1Q VLAN priority
> +#opt vendor STRING # [0x3c] client's vendor string, not intended to be sent by DHCP servers
> +# RFC 5071: PXELINUX Options
> +#opt 0xd0 F100747E # [0xd0] magic needed for other options to be recognized by clients
> +#opt pxeconffile STRING # [0xd1]
> +#opt pxepathprefix STRING # [0xd2]
> +#opt reboottime NUM # [0xd3] bootstrap timeout
> # Options specifying server(s)
> -#opt dns IP_LIST
> -#opt wins IP_LIST
> -#opt nissrv IP_LIST
> -#opt ntpsrv IP_LIST
> -#opt lprsrv IP_LIST
> -#opt swapsrv IP
> +#opt dns IP_LIST # [0x06]
> +#opt wins IP_LIST # [0x2c]
> +#opt nissrv IP_LIST # [0x29]
> +#opt ntpsrv IP_LIST # [0x2a]
> +#opt lprsrv IP_LIST # [0x09]
> +#opt swapsrv IP # [0x10]
> # Options specifying routes
> -#opt routes IP_PAIR_LIST
> -#opt staticroutes STATIC_ROUTES # RFC 3442 classless static route option
> -#opt msstaticroutes STATIC_ROUTES # same, using MS option number
> +#opt routes IP_PAIR_LIST # [0x21]
> +#opt staticroutes STATIC_ROUTES # [0x79] RFC 3442 classless static route option
> +#opt msstaticroutes STATIC_ROUTES # [0xf9] same, using MS option number
> # Obsolete options, no longer supported
> -#opt logsrv IP_LIST # 704/UDP log server (not syslog!)
> -#opt namesrv IP_LIST # IEN 116 name server, obsolete (August 1979!!!)
> -#opt cookiesrv IP_LIST # RFC 865 "quote of the day" server, rarely (never?) used
> -#opt timesrv IP_LIST # RFC 868 time server, rarely (never?) used
> +#opt logsrv IP_LIST # [0x07] 704/UDP log server (not syslog!)
> +#opt namesrv IP_LIST # [0x05] IEN 116 name server, obsolete (August 1979!!!)
> +#opt cookiesrv IP_LIST # [0x08] RFC 865 "quote of the day" server, rarely (never?) used
> +#opt timesrv IP_LIST # [0x04] RFC 868 time server, rarely (never?) used
> # TODO: in development
> -#opt userclass STRING # RFC 3004. set of LASCII strings. "I am a printer" etc
> -#opt sipserv STRING LIST # RFC 3361. flag byte, then: 0: domain names, 1: IP addrs
> +#opt userclass STRING # [0x4d] RFC 3004. set of LASCII strings. "I am a printer" etc
> +#opt sipsrv STRING LIST # [0x78] RFC 3361. flag byte, then: 0: domain names, 1: IP addrs
> +#opt ip6rd .... # [0xd4] IPv6 rapid deployment
_______________________________________________
ptxdist mailing list
ptxdist@pengutronix.de
To unsubscribe, send a mail with subject "unsubscribe" to ptxdist-request@pengutronix.de
prev parent reply other threads:[~2021-06-29 5:12 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-06-20 17:39 [ptxdist] [PATCH] " Roland Hieber
2021-06-29 5:09 ` Michael Olbrich [this message]
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=20210629050926.2524480-1-m.olbrich@pengutronix.de \
--to=m.olbrich@pengutronix.de \
--cc=ptxdist@pengutronix.de \
--cc=rhi@pengutronix.de \
/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