File: README

package info (click to toggle)
ifplugd 0.28-19
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd, wheezy
  • size: 1,152 kB
  • ctags: 772
  • sloc: sh: 2,535; ansic: 2,023; makefile: 176
file content (390 lines) | stat: -rw-r--r-- 16,379 bytes parent folder | download | duplicates (16)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390

                                 ifplugd 0.28

   Copyright 2002-2005 Lennart Poettering <mzvscyhtq (at) 0pointer (dot)
   de>
     * [1]License
     * [2]News
     * [3]Overview
     * [4]Current Status
     * [5]Documentation
     * [6]Requirements
     * [7]Installation
     * [8]Acknowledgements
     * [9]Download

License

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or (at
   your option) any later version.

   This program is distributed in the hope that it will be useful, but
   WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
   General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

News

   Sat Jun 4 2005:

   [10]Version 0.28 released, changes include: build fixes from Stefan
   Seyfried.

   Wed Mar 30 2005:

   [11]Version 0.27 released, changes include: new option --no-startup.

   Sun Dec 19 2004:

   [12]Version 0.26 released, changes include: changed MII code for
   better compatibility with some 3COM Boomerang cards.

   Mon May 10 2004:

   [13]Version 0.25 released, changes include: Revert to more classic
   link checking support. The new checking order is: ETHTOOL, MII, WLAN,
   IFF. The obsolete API "PRIV" is no longer checked by the automatic API
   detection code. However, you may enable it forcibly by passing -m priv
   on the command line.

   Mon Apr 12 2004:

   [14]Version 0.24 released, changes include: add IFF_RUNNING link check
   support and make it the default. This might break some setups. You may
   workaround this by passing -m to the daemon for selecting a different
   API. Please report breakages!

   Wed Apr 7 2004:

   [15]Version 0.23 released, changes include: don't make /dev/tty1 the
   controlling TTY when beeping

   Tue Feb 10 2004:

   [16]Version 0.22 released, changes include: rename ifstatus to
   ifplugstatus due to namespace collision, minor fixes

   Mon Jan 26 2004:

   [17]Version 0.21b released, added missing file.

   Mon Jan 26 2004:

   [18]Version 0.21 released, changes include: better compatibility with
   wireless devices, compatibility with newer kernels

   Sun Nov 9 2003:

   [19]Version 0.20 released, changes include: fix wrong message, build
   fix

   Mon Oct 20 2003:

   [20]Version 0.19 released, changes include: New option
   --wait-for-kill, this requires [21]libdaemon 0.3

   Fri Oct 17 2003:

   [22]Version 0.18 released, changes include: Some bugs fixed

   Fri Sep 13 2003:

   [23]Version 0.17b released, changes include: typo and date fix

   Fri Sep 13 2003:

   [24]Version 0.17 released, changes include: documentation update,
   better support for multiple interfaces, gcc 2.95 build fix

   Thu Aug 13 2003:

   [25]Version 0.16 released, changes include: RPM spec file added, build
   fixes, WLAN improvements (including compatibility with the upcoming
   waproamd, a WLAN roaming daemon), monitor mode for use in conjunction
   with PCMCIA devices, better support for multiple interface setups,
   SUPPORTED_DRIVERS returns

   Thu July 10 2003:

   [26]Version 0.15 released, changes include: bad umask fix,
   documentation update

   Mon July 7 2003:

   [27]Version 0.14 released, changes include: autoconf usage, new
   dependency [28]libdaemon, wireless LAN support, support for
   suspending/resuming, many fixes

Overview

   ifplugd is a Linux daemon which will automatically configure your
   ethernet device when a cable is plugged in and automatically
   unconfigure it if the cable is pulled. This is useful on laptops with
   onboard network adapters, since it will only configure the interface
   when a cable is really connected.

   ifplugd ifplugd interfaces with your distribution's native network
   configuration utilities.

   Some features:
     * Uses your distribution's native ifup/ifdown programs.
     * May beep when the cable is unplugged, plugged, the interface
       configuration succeeded or failed.
     * Supports the Linux SIOCETHTOOL (newer, aka ethtool API),
       SIOCGMIIREG (older, aka mii-diag/mii-tool API) and SIOCDEVPRIVATE
       (oldest, aka mii-tool API) ioctl()s for getting link status.
       Release 0.24 introduces support for link detection with the
       IFF_RUNNING interface flag.
     * Syslog support
     * Small program - the binary is just 25 KB (plus 16 KB for
       libdaemon).
     * Multiple ethernet interface support
     * Can be configured to ignore short "unplugged" periods (-d option)
       or short "plugged" periods(-u option)
     * Support for wireless networking. Whenever an association to an AP
       is detected the network is configured. Have a look on [29]waproamd
       if you need a facility to configure WEP keys before AP
       associations succeed.
     * Compatibility mode for network devices which do not support cable
       detection (-F option)

Current Status

   Version 0.28 is stable and has all the sensible features its users
   could think of.

Documentation

   Have a look on the man pages [30]ifplugd(8), [31]ifplugstatus(8),
   [32]ifplugd.conf(5). (An XSLT capable browser is required)

  Configuration

   Edit /etc/ifplugd/ifplugd.conf for configuration changes. This file is
   a bourne shell script sourced by the init script and used to start
   ifplugd with appropriate arguments. You may specify more than one
   ethernet interface in INTERFACES. For each interface a seperate
   instance of ifplugd is spawned. The arguments specified in ARGS are
   append to ifplugd's command line. Have a look on ifplugd -h or man
   ifplugd for further information about the available options.

   The network interface which is controlled by ifplugd should not be
   configured automatically by your distribution's network subsystem,
   since ifplugd will do this for you if needed.

   On Debian systems, any interfaces named in ifplugd's INTERFACES
   environment variable should not also be listed in an "auto" stanza in
   /etc/network/interfaces.

  Troubleshooting

   When you are using the hotplug subsystem (Debian package hotplug) you
   may notice that the network device is configured even when it is not
   listed on an auto line in /etc/network/interface. This may be due to
   hotplug being configured to ifup the network interface when it becomes
   available. This was the default behavior in the Debian hotplug package
   prior to release 0.0.20030117-1, for example. To prevent this you
   should either upgrade your hotplug package or comment out the ifup
   call in /etc/hotplug/net.agent.

   When using ifplugd together with APM (and probably ACPI) suspends,
   strange things may happen: some network devices fail to detect the
   network cable for a short period of time before and after the suspend.
   When using the -f switch, this will be treated as "no link beat", thus
   the network is shutdown after a timeout. During this timeout the
   machine changes to suspended state. When it is resumed again, the
   timeout period will have expired and so the network is deconfigured,
   however, as the next cable detection succeeds, the network is
   configured again immediately. To fix this problem, ifplugd should be
   disabled before the APM suspend and enabled back after the suspend.
   This may be done by using apmd and adding a script to
   /etc/apm/{suspend,resume}.d which simply calls /etc/init.d/ifplugd
   suspend, resp. /etc/init.d/ifplugd resume. It might even be a good
   idea to shut down the network completely during suspend, this may be
   achieved by calling /etc/init.d/ifplugd stop and /etc/init.d/ifplugd
   start in the appropriate places. I strongly urge the packagers of this
   software for the Linux distributions to add such scripts to their
   packages.

  FAQ

    1. Q: I want to use ifplugd with my PCMCIA device, but ifplugd quits
       when it doesn't find eth0, when I have not inserted the card. What
       can I do?
       A: Use the -f switch. This is not very clean however, since
       modprobe is called on each cable detection query of ifplugd to
       load a module for the network device. This is suboptimal. You
       should probably run ifplugd only when the card is really inserted.
    2. Q: I am using the -f switch, but the kernel logs are getting
       filled with messages like "modprobe: modprobe: Can't locate module
       eth0". What can I do?
       A: Make sure you have a line like alias eth0 off in your
       /etc/modules.conf
    3. Q: When the cable is unplugged and the interface shut down it is
       still available with ifconfig and markes as UP. Why this?
       A: ifplugd cannot detect the link beat with a shut down interface
       on certain (most as of kernel 2.4.19) network drivers. Thus
       ifplugd enables the interface before querying the link status.
       This may be switched off with -a flag. You might want to use it if
       you have a sane network driver (e.g. eepro100). The subdirectory
       patches/ in the ifplugd distribution includes a patch for the
       8139too 0.9.26 driver, which makes the driver compatible with -a.
       Don't ask me how to apply this patch. If you don't know, you won't
       need it.
    4. Q: Does it work with anything else than plain ethernet or wireless
       LAN?
       A: Certainly not, since the MII and ETHTOOL ioctl()s and the
       wireless extension don't exist on other network device types.
    5. Q: I have a Realtek 8139 based network card. Everytime ifplugd
       starts on bootup my machine freezes. What can I do?
       A: This is a bug in the 8139too driver 0.9.25 (at least) shipped
       with Linux 2.4.19, please upgrade to 8139too 0.9.26 (Linux 2.4.20
       or seperately at
       [33]http://www.sourceforge.net/projects/gkernel/).
    6. Q: There are already laptop-net's ifd and miid, why did you write
       your own daemon?
       A: laptop-net was too integrated with its profile system and
       didn't work on my hardware when I had a look on it. It seemed
       easier to me to write a simple but feature complete replacement
       than using laptop-net without most of the special features
       disabled. I didn't know about miid when I wrote ifplugd, but in
       any case ifplugd is much better than miid. For a comparison of
       miid and ifplugd, have a look on
       [34]http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=162763&repeat
       merged=yes
    7. Q: I have two interfaces (e.g. WLAN and copper ethernet), both
       controlled by ifplugd, and want to force the network traffic to go
       over the faster one of them, in case both are available at the
       same time. How can I do this?
       A: A tool I wrote called [35]ifmetric might be exactly what you're
       looking for.

Requirements

   A newer Linux Kernel (I think 2.2 is good enough, alltough I tested it
   only with 2.4) with a compatible device driver and ethernet card. Most
   modern cards and drivers are compatible, like mine which works with
   the 8139too driver.

   ifplugd was developed and tested on Debian GNU/Linux "testing" from
   July 2003, it should work on most other Linux distributions (and maybe
   Unix versions) since it uses GNU autoconf and GNU libtool for source
   code configuration and shared library management.

   The machine used was a Medion 9580-F laptop with a Realtek 8139
   network card and a PRISM1 PCMCIA wireless LAN card.

   ifplugd needs [36]libdaemon.

Installation

   As this package is made with the GNU autotools you should run
   ./configure inside the distribution directory for configuring the
   source tree. After that you should run make for compilation and make
   install (as root) for installation of ifplugd.

   The installation scripts create an init script in
   ${sysconfdir}/init.d/ifplugd, however no /etc/rc?.d/ links are created
   for it.

   Extensive installation instructions for installation of ifplugd on
   Fedora Core 1 are available at [37]Geoff Ericksson's web site.

Acknowledgements

   For the developers of mii-diag, ethtool and laptop-net, since I looked
   on their source codes for learning how to use the link beat ioctls.

   Oliver Kurth for packaging ifplugd for Debian and ifplugd's manpage

   Stefan Seyfried, Thomas Hood, Asgeir Nilsen, Sean Reifschneider, R.
   Steve McKown, David Mitchell, Norbert Preining, Herbert Graeber for
   patches

   Frederic Lepied for integrating ifplugd into Mandrake Linux

Download

   The newest release is always available from
   [38]http://0pointer.de/lennart/projects/ifplugd/

   The current release is [39]0.28

   Get ifplugd's development sources from the [40]Subversion
   [41]repository ([42]viewcvs):
svn checkout svn://seth.intheinter.net/ifplugd/trunk ifplugd

   You may find an up to date Debian package of ifplugd on the [43]Debian
   package repository.

   ifplugd is nowadays included in many popular distributions (Mandrake,
   Gentoo, Suse, Debian, Ubuntu); [44]Conectiva packages are available
   courtesy of Gonzalo Nemmi. Fedora Core packages are available from
   [45]Dag Wieers.

   If you want to be notified whenever I release a new version of this
   software use the subscription feature of [46]Freshmeat.

   New! There is a joint ifplugd and waproamd [47]mailing list available.
     _________________________________________________________________


    Lennart Poettering <mzvscyhtq (at) 0pointer (dot) de>, June 2005

   $Id: README.html.in 124 2005-06-04 19:22:59Z lennart $

References

   1. README#license
   2. README#news
   3. README#overview
   4. README#status
   5. README#documentation
   6. README#requirements
   7. README#installation
   8. README#acks
   9. README#download
  10. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.27.tar.gz
  11. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.27.tar.gz
  12. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.26.tar.gz
  13. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.25.tar.gz
  14. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.24.tar.gz
  15. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.23.tar.gz
  16. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.22.tar.gz
  17. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.21b.tar.gz
  18. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.21.tar.gz
  19. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.20.tar.gz
  20. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.19.tar.gz
  21. http://0pointer.de/lennart/projects/libdaemon/
  22. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.18.tar.gz
  23. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.17b.tar.gz
  24. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.17.tar.gz
  25. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.16.tar.gz
  26. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.15.tar.gz
  27. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.14.tar.gz
  28. http://0pointer.de/lennart/projects/libdaemon/
  29. http://0pointer.de/lennart/projects/waproamd/
  30. http://0pointer.de/lennart/projects/ifplugd/ifplugd.8.xml
  31. http://0pointer.de/lennart/projects/ifplugd/ifplugstatus.8.xml
  32. http://0pointer.de/lennart/projects/ifplugd/ifplugd.conf.5.xml
  33. http://www.sourceforge.net/projects/gkernel/
  34. http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=162763&repeatmerged=yes
  35. http://0pointer.de/lennart/projects/ifmetric/
  36. http://0pointer.de/lennart/projects/libdaemon/
  37. http://www.acmc.uq.edu.au/~gbe/linux/installation_of_ifplugd.html
  38. http://0pointer.de/lennart/projects/ifplugd/
  39. http://0pointer.de/lennart/projects/ifplugd/ifplugd-0.28.tar.gz
  40. http://subversion.tigris.org/
  41. svn://seth.intheinter.net/ifplugd
  42. http://0pointer.de/cgi-bin/viewcvs.cgi/?root=ifplugd
  43. http://packages.debian.org/ifplugd
  44. http://www.linuxdicas.com.ar/caleb/rpm
  45. http://dag.wieers.com/packages/ifplugd/
  46. http://freshmeat.net/projects/ifplugd/
  47. https://seth.intheinter.net/mailman/listinfo/ifplugd-discuss