#1866 closed task (worksforme)
Pointless warning when running "ifdown" for a manually-configured interface
Reported by: | Owned by: | ||
---|---|---|---|
Priority: | lowest | Milestone: | |
Component: | Book | Version: | SVN |
Severity: | normal | Keywords: | |
Cc: |
Description
For the LiveCD needs, LFS network bootscripts have to be modified for compatibility with the "hibernate" script. The issue is:
- The LiveCD has to run dhcpcd by default on all network interfaces, because it is not known which of possibly more than one network card is connected to a switch. Current syntax of network configuration files doesn't allow this, and the LiveCD has to bypass the existing infrastructure and run dhcpcd from udev rules in order to accomplish the goal.
- Because of that, some interfaces may be up, but without valid configuration files (I refer to such interfaces as manually-configured below, because exactly the same situation arises when one runs the "ip" command manually).
- The "hibernate" script wants to "ifdown" all interfaces, but doing so for interfaces without the configuration file results in a pointless (in this situation) warning. A similar warning appears when resuming, when the "hibernate" script runs "ifup". This warning has to be invisible in this case.
Of course, the LiveCD can create an interface configuration file and run "ifup" instead of running dhcpcd directly, but the bug is still relevant for manually-configured interfaces: not everyone discovers net-setup, and some people configure static IP addresses manually by the "ip" command.
Text of the warning:
/etc/sysconfig/network-devices/ifconfig.eth0 is not a network configuration file or directory.
So the bootscripts should provide some means (environment variable or ifup/ifdown command line switch to be used by the "hibernate" script) to suppress this pointless warning.
Change History (12)
comment:1 by , 18 years ago
comment:2 by , 18 years ago
You missed the point of the ticket.
As of now, there are third-party, not LFS-specific, packages that want to run ifdown. E.g, the "hibernate" script. As of the time when the ticket was submitted, they produced warnings.
Right now, the issue is somewhat worked around in the LiveCD repository by patching the "hibernate" script and generating the ifconfig.ethX files from udev rules. But this solution is still not robust.
comment:3 by , 18 years ago
I thought you might say as much. :) And my above comment would be better placed in the LiveCD list or ticket system. (I'm still curious to hear what you think of that on its own merit, but that discussion can take place elsewhere.)
If we have the ability to alter the way hibernate calls ifdown (I assume so based on your above proposal of adding a switch to ifdown that hibernate can make use of...), what keeps us from just telling hibernate to send errors/output to /dev/null? Am I still missing the point?
comment:4 by , 18 years ago
I don't want to suppress errors other than "ifconfig.eth0 is not a network configuration file or directory", that's why >/dev/null is not a solution. I will patch the script to skip the "ifdown" if the file doesn't exist. I patch it in other places anyway, for unrelated reasons.
comment:5 by , 18 years ago
Priority: | normal → lowest |
---|
As of r1747 in the LiveCD repository, due to added workarounds, there are no warnings from the "hibernate" script even for manually configured interfaces. Thus, lowering the priority.
follow-up: 7 comment:6 by , 18 years ago
For bringing down interfaces, rather than looking at the configuration files, how about the following:
#get a list of available interfaces interfaces=`ip link show | grep ^[[:digit:]].*,UP | cut -f2 -d:` #bring each interface down for iface in interfaces; do ip link set $iface down; done;
I'm not quite sure how to handle bringing interfaces up automatically though. Maybe it's just a case of doing the following for each interface that ip link show
reports:
1) If the interface is blacklisted (I haven't thought of any possible configuration interfaces for this yet), i.e. the user explicitly doesn't want it to be brought up, don't do anything 2) If the interface isn't blacklisted and has an /etc/sysconfig/network-devices/ifconfig.${iface} file, bring it up 3) If the interface isn't blacklisted and doesn't have an /etc/sysconfig/network-devices/ifconfig.${iface} file fallback to a system-wide default configuration, such as DHCP.
follow-up: 8 comment:7 by , 18 years ago
Replying to matthew@linuxfromscratch.org:
#get a list of available interfaces interfaces=
ip link show | grep ^[[:digit:]].*,UP | cut -f2 -d:
I don't think this will always be what we want. On my system, I get:
lo wifi0 ath0
In this case, I don't want to make any direct changes to wifi0, but I do use ath0. This is a characteristic of madwifi cards because both interfaces are for one wireless network card. OTOH, it probably doesn't make any difference for shutdown.
comment:8 by , 18 years ago
Replying to bdubbs@linuxfromscratch.org:
Replying to matthew@linuxfromscratch.org:
#get a list of available interfaces interfaces=
ip link show | grep ^[[:digit:]].*,UP | cut -f2 -d:
I don't think this will always be what we want. On my system, I get:
lo wifi0 ath0In this case, I don't want to make any direct changes to wifi0, but I do use ath0. This is a characteristic of madwifi cards because both interfaces are for one wireless network card. OTOH, it probably doesn't make any difference for shutdown.
Yeah, I get similar interfaces listed for my wifi card - wmaster0 and wlan0. Again, I don't think I should be touching wmaster0 at all, but, like you, I'm not sure that bringing that interface down will do any harm. That said, I can't even bring the interface up at the moment so I can't test this for the time being. I do wonder whether there are similar types of interface (dial-up modems, isdn stuff, etc.) that might end up with more than one interface being listed. The above mechanism for detecting available interfaces might be just too brittle :-(
comment:9 by , 18 years ago
I don't know if this helps much, but maybe we can add a special --all parameter to ifdown. Then it can glob the UP devices and bring them all down. I'm not sure how that would be used since it collides with the stop cases of init.d/network and init.d/localnet.
comment:10 by , 18 years ago
I'm not sure what the point of this ticket is any more. Alexander has a work around for the Live CD. At least the title of the ticket is no longer valid.
What else needs to be fixed?
Or should this ticket just be closed with WORKSFORME?
Instead of running dhcpcd on all devices, why not just run it on the ones where a link is detected? I'm not sure if that information is in any of the kernel fs's, but the test could be done with a small custom C program.