summaryrefslogtreecommitdiffstats
path: root/abs/core-testing/wlan-ng26-utils/tmp/trunk/FAQ
blob: 83358fdedcba80a2e1d5a9c66175c5c1cc6c0754 (plain)
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
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
********************** Linux-wlan-ng FAQ **************************
For additions, corrections, and clarifications, send mail to
solomon@linux-wlan.com with FAQ in the subject.
*******************************************************************

Q: When will linux-wlan-ng be merged into the mainline kernel?

	Short answer:  Never.

	First, the linux-netdev people will soundly reject this driver.  
	I don't begrudge them for this; indeed in their position I'd do 
	exactly the same.  It's a sound engineering decision.

	linux-wlan-ng is obselete, and effort spent fixing it is better 
	spent elsewhere.  You can't even buy the hardware any longer.

	The original design for linux-wlan-ng was to separate the 802.11 
	stack from the actual hardware driver.  This added a lot of 
	complexity, but would greatly ease the pain of supporitng 
	multiple hardware types.  Unfortunately, the implementation was 
	turned out to be somewhat flawed, and hardware manufaturers went 
	away from the thick-mac model, leaving linux-wlan-ng overly 
	complex for what it did.  

	(Ironically, the linux kernel is adopting a similar 
	 separation model, but it is a long way off from being ready)

	So why not rewrite linux-wlan-ng to be more suitable, the 
	enterprising reader may ask?

	The kernel already has two drivers for prism2 (cs/pci/plx) 
	hardware -- hostap and orinoco. linux-wlan-ng basically 
	has three features not present in kernel drivers:
	
		1) USB support
		2) nearly complete implemettion of the 802.11 MIB/MLME
		3) Firmware-based AP support
	
	(3) requires an expensive license that isn't even available any 
	longer, as the hostap mode works far better -- and is already 
	supported by in-kernel drivers.

	(2) would need to be removed or completely rewritten in order to 
	be merged, as it does not fit within existing kernel APIs, and 
	it would be effectively merging new kernel APIs.

	(1) Is the only truly unique thing that linux-wlan-ng does that 
	is generally needed any more.

	To merge it into the kernel, we'd need to strip out (2), which 
	would necessitate a complete rewrite -- to the point where 
	writing a new driver from scratch is easier.  

	Basically, it would take far less effort to add USB 
	support to the in-kernel drivers than it would to make 
	linux-wlan-ng acceptable to be merged. 

	In other words, the short answer is:  Never.

Q: It doesn't work/compile/sing/dance!

	First, make sure you're using the latest linux-wlan-ng release
	from http://www.linux-wlan-ng.org.  New releases are infrequent,
	but tthey happen for a reason.

	If you are using the latest release, you may want to obtain the 
	latest development sources via subversion:

		svn co svn://svn.shaftnet.org/linux-wlan-ng/trunk

	Questions and problems with the developement code should be sent 
	to the development mailing list, at:

		linux-wlan-devel@lists.linux-wlan.com

Q: What devices does the linux-wlan-ng driver support?

	Currently, the linux-wlan-ng driver supports the Intersil
	Prism2/2.5/3 chipsets.  These chipsets are used in a wide
	variety of PCMCIA, PCI, and USB products.  If it has a Prism
	chip in it, linux-wlan-ng should support it.

Q: Will linux-wlan-ng support some feature or funkiness in
   the <pick one> Linux distribution?
 
	Our development target always consists of stock kernels from
	kernel.org and stock pcmcia_cs.  If a given distribution
	chooses to do something funky, we rely on users of that
	distribution to contribute patches to deal with their
	funkiness.

	The quickest way to get some action on this kind of item is to
	communicate with any users of the same distribution that you
	can find on the linux-wlan-[devel|user] lists about working up
	a patch.  If it's reasonably sane and doesn't break things for
	our development environment or for other distributions, we'll
	be more than happy to roll that patch into the next release.  

Q: What does "resultcode=implementation_failure" mean?

	Complicated Answer: 
	Each command that can be issued with wlanctl-ng returns a status
	called "resultcode".  Resultcode is something that we picked up
	from the 802.11 MLME definition.  In the standard, resultcode
	is an enumeration with a fixed set of values.  To be able to
	report failures that a driver detects that are outside the
	context of the 802.11 standard set of resultcode values, we 
	invented the "implementation_failure" value.

	Simple Answer:
	Go look in your kernel log for more detailed error information.

Q: I'm trying to use the HostAP/orinoco/aironet/wvlan driver and it
   won't work!

	That has nothing to do with the linux-wlan-ng driver.  Go ask
	those responsible for those drivers.

Q: Can I get Debian packages of linux-wlan-ng?
 
A: Packages of linux-wlan-ng are now available in the Debian stable
   tree.

Q: Where do I find some RPMS for linux-wlan-ng? The ones on
    the ftp are dreadfully out of date!

	http://prism2.unixguru.raleigh.nc.us/

	(Maintained by Tim Miller)

Q: I installed the RPMs/compiled the driver and installed it and it
   won't work when I try to run 'ifup wlan0' or whatnot.

	First, ensure you're running the most up-to-date version of
	the driver.  Many problems have been fixed in newer releases.

	802.11 wireless networks are much more complex than wired
	ethernet networks.  They require much more configuration than
        an ip address.   If you are using pcmcia, edit the file 
        /etc/pcmcia/wlan-ng.opts to set the network parameters.  For
        PCI, PLX, or USB adapters, you need to edit /etc/wlan.conf.
	
	You also need to make sure you have the correct settings in
	/etc/modules.conf (alias wlan0 prism2_usb). 

	Might we suggest you read the README file?

Q: When I try to load the driver, I get a whole bunch of errors about
   unresolved symbols.

	The running kernel does not match the kernel the driver was
	compiled for.  If you downloaded a RPM, make sure you
        downloaded the correct version for your kernel.  This should not
        happen if you compiled the driver from source -- if it does, the
        kernel configuration you compiled against does not match the
        running kernel.  Probably a screwed-up distro kernel.

Q: I have a DWL-520 and it won't work!

	The DWL-520 claims to require a PCI 2.2 compliant motherboard.
        Only fairly new machines support this.  Yes, the box lies.  :)
        Check the documentation for your system and/or motherboard to see if 
	it is PCI 2.2 compliant.  

	NOTE:  We have some reports of the DWL-520 working on PCI 2.1
	motherboards; your mileage may vary.  See the following URL:

		http://www.personaltelco.net/index.cgi/DlinkDwl520

        NOTE:  The Linksys WMP11 v2.7 is NOT prism-based, and
	thus not supported by this driver.  The Actiontec PCI board is
	still known to be prism based; you may want to try that instead.

Q: All I see is "Tx attempt prior to association, frame dropped"

	You are not associated with an access point.  Double-check the
        settings in /etc/wlan.conf (USB, PCI, PLX) or /etc/pcmcia/wlan-ng.opts
        (for PCMCIA users).    If all of these settings are correct (you
        did check with your admin, right?) make sure the access point
        doesn't have a MAC filter installed or has different WEP settings.

	If all of this is verified correct, and are using a PCMCIA
	card, try setting the "irq_mode=0" option.  See the
	documentaiton in the pcmcia-cs sources.

Q: I installed the modules, performed a 'wlanctl-ng wlan0 lnxreq_autojoin'
   command, and it still won't work!

	You did read the README, didn't you?  You need to perform a 
	"wlanctl-ng wlan0 lnxreq_ifstate ifstate=enable" in order to
        torn on the radio.  The pcmcia scripts and the /etc/init.d/wlan
        script do this for you.

Q: I have a XXX USB 802.11b device, will it work with this driver?

	Most 802.11b USB devices use the ATMEL AT76C503A chipset, which
        is not supported by the linux-wlan-ng project.  However, there
	are some prism2.5-based USB adapters, most notably the Linksys
	WUSB v2.5.  The other versions (1.0, 2.6, 3.0) are based on
        ATMEL chipsets.  Another supported USB device is the Actiontec
	802UI3.

Q: My prism2.5-based USB adapter won't work!

	An excellent guide can be found at:

	http://www.fuw.edu.pl/~pliszka/hints/prism2.html
	
Q: My prism2.5-based USB adapter won't come up if it's plugged in at boot! 

	Thanks to buggy firmware, it is often necessary to perform a
        device reset on initialization.  You can perform this by adding
        "options prism2_usb prism2_doreset=1" in your /etc/modules.conf

	Intersil has released Primary firmware 1.1.2, which seems to
	have resolved this problem, at least on our test machines.

Q: My PC crashes when the USB device is plugged in!

	This is a result of the port reset necessitated by buggy firmware.

	You are probably using the 'usb-uhci' driver with an intel
        chipset.  Unfortunately, the crashes happen deep within the USB
        core, so there's nothing the linux-wlan-ng driver can do.

	In the mean time, try using the 'uhci' host controller driver
        instead ("alias usb-controller uhci" in /etc/modules.conf), or
        plug the USB device into a hub.

	Linux kernel 2.4.19 is known to improve the situation somewhat,
	but the right way to fix it is to turn off the port reset
	(options prism2_usb prism2_doreset=0).  The current firmware
	from Intersil alleviates the need to perform the reset.

	UPDATE:  if you're using linux-wlan-ng 0.2.1-pre6 or newer and 
        kernel < 2.4.22-pre, the 'uhci' driver will NOT work without a 
        kernel patch! See:

	http://lists.linux-wlan.com/pipermail/linux-wlan-devel/2003-May/002369.html

Q: How come I can't transmit when in monitor mode?

	You can't.  It's a fundamental "feature" of the hardware.

Q: How come the /proc/net/wireless info isn't updated when in monitor mode?

	The definition of "signal quality" refers to the quality of the
	link to the associated access point.  When you're in monitor
	mode, you're not associated, so this information is by defintion 
	irrelevant.

	And regardless, the hardware doesn't update the registers we poll to
	obtain this information while in monitor mode.

Q: What do the various monitor mode options do?

	enable=[true/false]           Turn it on and off.  required.
	channel=[1-14]                Sniff channel.  required.
	prismheader=[true/false]      Optionally preppend a special
                                      radio header on the packet.
				      Defaults to off.
	keepwepflags=[true/false]     If you had WEP configured correctly
				      the card will perform WEP decoding.
				      Defaults to off.
	stripfcs=[true/false]         When true, the 802.11 FCS is not
				      stripped from incoming packets.
				      Defaults off.
	truncate=[number]             Truncates the captured frame.  

Q: How come iwconfig/iwspy/[random other wireless tool] doesn't work?
	
	linux-wlan-ng only supports a subset of the wireless
	extensions; generally read-only things.  However, you won't
	need any of those tools as wlan-ng comes with its own set of
	tools that closely mirror the 802.11 spec.  Have a look
	through the documentation and supplied scripts.

	That said, if more complete (ie read/write) wireless extension
	support is really important to you, you're more than welcome to
	implement it and submit a patch.  

	As of 0.1.16-pre1, the wireless extension plumbing has been
	re-written, and further support is much easier now.  And many
	more bits are hooked up now than before.

Q: How do I know exactly what prism variant is on my card?

	When you load the driver, you see a line which reads like:

		ident: nic h/w id=0x8008 1.0.0
                                         
	1.0.0 is the hardware revision.  Below is a (partial) list of IDs.

		0x8003, 0x8008 :  Prism2 PCMCIA

		0x800b, 0x800c :  Prism2.5 PCMCIA
		0x8012, 0x8013 :  Prism2.5 PCI
		0x801a, 0x801b :  Prism3 PCMCIA
		0x8021, 0x8022 :  Prism3 PCI
		
		0x800f, 0x8010 :  Prism2.5 USB  (3863)
		0x801e, 0x801f :  Prism2.5 USB  (3861B)
		0x8025, 0x8026 :  Prism3 USB

Q: How do I know what firmware my card has?

	After the driver is loaded and brought into ifstate=enable, you
	will see the following lines in the kernel log: (eg dmesg |grep ident)

	ident: pri f/w: id=0x15 0.3.0
	ident: sta f/w: id=0x1f 1.7.1

	In this case, the card has primary firmware 0.3.0 and secondary
	firmware 1.7.1.  
	
	Or, if you are using 0.2.1-pre17 or newer:
	'cat /proc/net/p80211/wlan0/nsd' with the card running.

Q: How can I update my firmware under Linux?

	Use the 'prism2dl' utility.  While it does its utmost to ensure 
	you don't fry your card, use it at your own risk.  Even the 
	Intersil-supplied tools fail occasionally.

Q: Where can I download updated firmware for my Prism2/2.5/3-based card?

	As of linux-wlan-ng 0.2.1-pre21, the ram download firmware for 
	all supported card types is bundled with the driver.  These 
	images cannot be flashed.

	A general FAQ on firmware updating is here:
		http://linux.junsun.net/intersil-prism

	It includes links to some sites with firmware images.

	We strongly recommend against flashing a new image, instead one 
	should use the ram-download images that are loaded when the
	driver starts, much like the Windows drivers do.

	See the instructions below for getting this to work.

Q: What's this about "ram downloading"?

	This means the driver loads up a firmware images directly into
	card RAM, instead of using the firmware stored in the card's 
	flash ROM.  This lets us ensure we are using the lastest available
	code without risking ruining the hardware due to a bad flashing.

	linux-wlan-ng will automatically perform a RAM download if you have
	the necessary firmware images.

Q: Okay, I have new ram download firmware images, where do I put them?

	copy the *hex files into linux-wlan-ng-XXXX/src/prism2/
	then build and install the driver per usual.

Q: Can I use my 802.11b card as an AP under Linux?

	Yes, and in the true free software fashion, there are several
	ways:

	a) linux-wlan-ng supports AP operation by using special tertiary
	   firmware on prism devices.  This firmware is not generally
	   available, however.   Contact Intersil for licensing terms.

	b) The Prism2 HostAP driver uses the special HostAP mode of the
           prism chipsets.            http://people.ssh.com/jkm/Prism2/

Q: I have a PCI adapter, and upon resuming from a suspend, the device is not
   responsive.  

	Much like you need to run some commands to bring the card to life 
	when the PC is first booted, you also need to perform similar 
	steps when the card comes out of suspend.   Run '/etc/init.d/wlan start'
	and all should be well.

	You'll need to be running 0.1.15-pre3 or newer for this to work
        properly.

	The prism2.5/3 chipsets do not support PCI power management, so
	this is the best we can realistically do.

Q: I have a Linksys WMP11, and under moderate to heavy traffic, I get
   errors like "unknown port number" and "invalid frame type"

	Make sure you're using the latest firmware avaliable from
	Linksys's web site.  According to the firmware release notes:
	
	 "Changes were made to prevent erroneous data from being 
          transferred over the PCI bus"

	Note that this problem has also beeen confirmed on the D-Link
	DWL-520.  You will need firmware 1.3.5 or newer to resolve this.

Q:  I have a D-Link DWL-650/650+/520+ card, why doesn't it work with
    this driver?

	The DWL-650 comes in at least three flavors; older ones have grey
	antennae, with no revision number on the back.  
	Second-generation  has a black antenna and the back reads 
	"H/W J3 F/W 1.x.x". Both of these will work.  The third-
	generation, with a grey antenna, has "H/W A1, F/W x.x", and
	will NOT work;  It has the same hardware as the "plus" series
	of cards.

	The "plus" series of cards from D-Link use the Texas Instruments 
	ACX100/TNETW1100 chipset.  TI has not been forthcoming with 
	programming information.  Politely ask TI and D-Link for Linux
	drivers and/or docs.

	We've been told that TI will be releasing binary-only Linux
	drivers sometime in December.  In the mean time, return the
	card and buy one that works with Linux.
	
Q: I have a Linksys WMP11 v2.7 card; why doesn't it work with this driver?

	Linksys, in their grand tradition, likes to introduce completely
	new cards but re-use the model number.  The WMP11 v2.7 utilizes the
	Broadcomm chipset, and is not supported by linux-wlan-ng.  Politely
	ask Linksys and/or Broadcomm for Linux drivers and/or docs.

Q: What other resources are there for Wireless LANs under Linux?

	http://www.fuw.edu.pl/~pliszka/hints/wireless.html

	http://www.hpl.hp.com/personal/Jean_Tourrilhes/Linux/Linux.Wireless.drivers.html

Q: I'm using RedHat 8.x+ (or Fedora Core), and I get this error when 
   trying to ifup wlan0:

	Error for wireless request "Set Encode" (8B2A) :
	    SET failed on device wlan0 ; Function not implemented.
	Error for wireless request "Set ESSID" (8B1A) :
	    SET failed on device wlan0 ; Function not implemented.

	
	You can safely ignore this; it is there because linux-wlan-ng
	does not currently use the wireless extension commands for
	configuration.

Q: When the prism2_cs module loads, I see the message "RequestIRQ:
   Resource in use" and the load fails! What's going on?

   Is your card a 16-bit PCMCIA card? If it is, you may need to
   recompile your kernel with ISA bus support enabled (CONFIG_ISA=y).
   The PCMCIA core uses ISA bus support to help determine what IRQs
   are available for the card. Without it, the PCMCIA core may not be
   able to select an IRQ.

Q: After installing linux-wlan-ng on my RedHat 9 system, pcmcia no 
   longer works!

	This is due to a bug in the RedHat 9 pcmcia startup scripts.
	On or about line 105 in /etc/init.d/pcmcia, remove all of the
	'.o' suffixes on the modprobe command lines.  It should read 
	something like this:

            if [ -d $PC ] ; then
                echo -n " modules"
                /sbin/modprobe pcmcia_core $CORE_OPTS
                /sbin/modprobe $PCIC $PCIC_OPTS
                /sbin/modprobe ds
            elif [ -d $KD ] ; then
                /sbin/modprobe pcmcia_core
                /sbin/modprobe $PCIC
                /sbin/modprobe ds
            else