net.lo: sleep *after* carrier check

For devices that are always connected (e.g. ethernet cards), the current
carrier always wastes time by sleeping for 1 second.  This is because the
code sleeps first, then checks for carrier.  Invert the order so that we
return quickly for devices already active.  For devices which are not yet
up, there shouldn't be any real difference.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
This commit is contained in:
Mike Frysinger 2012-12-18 00:20:23 -05:00
parent 2c60282ba9
commit 7557d62870

View File

@ -116,12 +116,12 @@ _wait_for_carrier()
yesno ${RC_PARALLEL} && efunc=einfo yesno ${RC_PARALLEL} && efunc=einfo
${efunc} "Waiting for carrier (${timeout} seconds) " ${efunc} "Waiting for carrier (${timeout} seconds) "
while [ ${timeout} -gt 0 ]; do while [ ${timeout} -gt 0 ]; do
sleep 1
if _has_carrier; then if _has_carrier; then
[ "${efunc}" = "einfon" ] && echo [ "${efunc}" = "einfon" ] && echo
eend 0 eend 0
return 0 return 0
fi fi
sleep 1
: $(( timeout -= 1 )) : $(( timeout -= 1 ))
[ "${efunc}" = "einfon" ] && printf "." [ "${efunc}" = "einfon" ] && printf "."
done done