This file is indexed.

/usr/share/wireshark/help/faq.txt is in libwireshark-data 1.8.2-5wheezy18.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

   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
 469
 470
 471
 472
 473
 474
 475
 476
 477
 478
 479
 480
 481
 482
 483
 484
 485
 486
 487
 488
 489
 490
 491
 492
 493
 494
 495
 496
 497
 498
 499
 500
 501
 502
 503
 504
 505
 506
 507
 508
 509
 510
 511
 512
 513
 514
 515
 516
 517
 518
 519
 520
 521
 522
 523
 524
 525
 526
 527
 528
 529
 530
 531
 532
 533
 534
 535
 536
 537
 538
 539
 540
 541
 542
 543
 544
 545
 546
 547
 548
 549
 550
 551
 552
 553
 554
 555
 556
 557
 558
 559
 560
 561
 562
 563
 564
 565
 566
 567
 568
 569
 570
 571
 572
 573
 574
 575
 576
 577
 578
 579
 580
 581
 582
 583
 584
 585
 586
 587
 588
 589
 590
 591
 592
 593
 594
 595
 596
 597
 598
 599
 600
 601
 602
 603
 604
 605
 606
 607
 608
 609
 610
 611
 612
 613
 614
 615
 616
 617
 618
 619
 620
 621
 622
 623
 624
 625
 626
 627
 628
 629
 630
 631
 632
 633
 634
 635
 636
 637
 638
 639
 640
 641
 642
 643
 644
 645
 646
 647
 648
 649
 650
 651
 652
 653
 654
 655
 656
 657
 658
 659
 660
 661
 662
 663
 664
 665
 666
 667
 668
 669
 670
 671
 672
 673
 674
 675
 676
 677
 678
 679
 680
 681
 682
 683
 684
 685
 686
 687
 688
 689
 690
 691
 692
 693
 694
 695
 696
 697
 698
 699
 700
 701
 702
 703
 704
 705
 706
 707
 708
 709
 710
 711
 712
 713
 714
 715
 716
 717
 718
 719
 720
 721
 722
 723
 724
 725
 726
 727
 728
 729
 730
 731
 732
 733
 734
 735
 736
 737
 738
 739
 740
 741
 742
 743
 744
 745
 746
 747
 748
 749
 750
 751
 752
 753
 754
 755
 756
 757
 758
 759
 760
 761
 762
 763
 764
 765
 766
 767
 768
 769
 770
 771
 772
 773
 774
 775
 776
 777
 778
 779
 780
 781
 782
 783
 784
 785
 786
 787
 788
 789
 790
 791
 792
 793
 794
 795
 796
 797
 798
 799
 800
 801
 802
 803
 804
 805
 806
 807
 808
 809
 810
 811
 812
 813
 814
 815
 816
 817
 818
 819
 820
 821
 822
 823
 824
 825
 826
 827
 828
 829
 830
 831
 832
 833
 834
 835
 836
 837
 838
 839
 840
 841
 842
 843
 844
 845
 846
 847
 848
 849
 850
 851
 852
 853
 854
 855
 856
 857
 858
 859
 860
 861
 862
 863
 864
 865
 866
 867
 868
 869
 870
 871
 872
 873
 874
 875
 876
 877
 878
 879
 880
 881
 882
 883
 884
 885
 886
 887
 888
 889
 890
 891
 892
 893
 894
 895
 896
 897
 898
 899
 900
 901
 902
 903
 904
 905
 906
 907
 908
 909
 910
 911
 912
 913
 914
 915
 916
 917
 918
 919
 920
 921
 922
 923
 924
 925
 926
 927
 928
 929
 930
 931
 932
 933
 934
 935
 936
 937
 938
 939
 940
 941
 942
 943
 944
 945
 946
 947
 948
 949
 950
 951
 952
 953
 954
 955
 956
 957
 958
 959
 960
 961
 962
 963
 964
 965
 966
 967
 968
 969
 970
 971
 972
 973
 974
 975
 976
 977
 978
 979
 980
 981
 982
 983
 984
 985
 986
 987
 988
 989
 990
 991
 992
 993
 994
 995
 996
 997
 998
 999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
# Index

### 1. General Questions:

1.1 What is Wireshark?

1.2 What's up with the name change? Is Wireshark a fork?

1.3 Where can I get help?

1.4 What kind of shark is Wireshark?

1.5 How is Wireshark pronounced, spelled and capitalized?

1.6 How much does Wireshark cost?

1.7 But I just paid someone on eBay for a copy of Wireshark! Did I get
ripped off?

1.8 Can I use Wireshark commercially?

1.9 Can I use Wireshark as part of my commercial product?

1.10 What protocols are currently supported?

1.11 Are there any plans to support {your favorite protocol}?

1.12 Can Wireshark read capture files from {your favorite network
analyzer}?

1.13 What devices can Wireshark use to capture packets?

1.14 Does Wireshark work on Windows Vista or Windows Server 2008?

### 2. Downloading Wireshark:

2.1 Why do I get an error when I try to run the Win32 installer?

### 3. Installing Wireshark:

3.1 I installed the Wireshark RPM (or other package); why did it install
TShark but not Wireshark?

### 4. Building Wireshark:

4.1 I have libpcap installed; why did the configure script not find
pcap.h or bpf.h?

4.2 Why do I get the error

> dftest_DEPENDENCIES was already defined in condition TRUE, which
implies condition HAVE_PLUGINS_TRUE

when I try to build Wireshark from SVN or a SVN snapshot?

4.3 Why does the linker fail with a number of "Output line too long."
messages followed by linker errors when I try to build Wireshark?

4.4 When I try to build Wireshark on Solaris, why does the link fail
complaining that plugin_list is undefined?

4.5 When I try to build Wireshark on Windows, why does the build fail
because of conflicts between winsock.h and winsock2.h?

### 5. Starting Wireshark:

5.1 Why does Wireshark crash with a Bus Error when I try to run it on
Solaris 8?

5.2 When I run Wireshark on Windows NT, why does it die with a Dr.
Watson error, reporting an "Integer division by zero" exception, when I
start it?

5.3 When I try to run Wireshark, why does it complain about
sprint_realloc_objid being undefined?

5.4 I've installed Wireshark from Fink on Mac OS X; why is it very slow
to start up?

### 6. Crashes and other fatal errors:

6.1 I have an XXX network card on my machine; if I try to capture on it,
why does my machine crash or reset itself?

6.2 Why does my machine crash or reset itself when I select "Start" from
the "Capture" menu or select "Preferences" from the "Edit" menu?

### 7. Capturing packets:

7.1 When I use Wireshark to capture packets, why do I see only packets
to and from my machine, or not see all the traffic I'm expecting to see
from or to the machine I'm trying to monitor?

7.2 When I capture with Wireshark, why can't I see any TCP packets other
than packets to and from my machine, even though another analyzer on the
network sees those packets?

7.3 Why am I only seeing ARP packets when I try to capture traffic?

7.4 Why am I not seeing any traffic when I try to capture traffic?

7.5 Can Wireshark capture on (my T1/E1 line, SS7 links, etc.)?

7.6 How do I put an interface into promiscuous mode?

7.7 I can set a display filter just fine; why don't capture filters
work?

7.8 I'm entering valid capture filters; why do I still get "parse error"
errors?

7.9 How can I capture packets with CRC errors?

7.10 How can I capture entire frames, including the FCS?

7.11 I'm capturing packets on a machine on a VLAN; why don't the packets
I'm capturing have VLAN tags?

7.12 Why does Wireshark hang after I stop a capture?

### 8. Capturing packets on Windows:

8.1 I'm running Wireshark on Windows; why does some network interface on
my machine not show up in the list of interfaces in the "Interface:"
field in the dialog box popped up by "Capture->Start", and/or why does
Wireshark give me an error if I try to capture on that interface?

8.2 I'm running Wireshark on Windows; why do no network interfaces show
up in the list of interfaces in the "Interface:" field in the dialog box
popped up by "Capture->Start"?

8.3 I'm running Wireshark on Windows; why doesn't my serial port/ADSL
modem/ISDN modem show up in the list of interfaces in the "Interface:"
field in the dialog box popped up by "Capture->Start"?

8.4 I'm running Wireshark on Windows NT 4.0/Windows 2000/Windows
XP/Windows Server 2003; my machine has a PPP (dial-up POTS, ISDN, etc.)
interface, and it shows up in the "Interface" item in the "Capture
Options" dialog box. Why can no packets be sent on or received from that
network while I'm trying to capture traffic on that interface?

8.5 I'm running Wireshark on Windows; why am I not seeing any traffic
being sent by the machine running Wireshark?

8.6 When I capture on Windows in promiscuous mode, I can see packets
other than those sent to or from my machine; however, those packets show
up with a "Short Frame" indication, unlike packets to or from my
machine. What should I do to arrange that I see those packets in their
entirety?

8.7 I'm trying to capture 802.11 traffic on Windows; why am I not seeing
any packets?

8.8 I'm trying to capture 802.11 traffic on Windows; why am I seeing
packets received by the machine on which I'm capturing traffic, but not
packets sent by that machine?

8.9 I'm trying to capture Ethernet VLAN traffic on Windows, and I'm
capturing on a "raw" Ethernet device rather than a "VLAN interface", so
that I can see the VLAN headers; why am I seeing packets received by the
machine on which I'm capturing traffic, but not packets sent by that
machine?

### 9. Capturing packets on UN*Xes:

9.1 I'm running Wireshark on a UNIX-flavored OS; why does some network
interface on my machine not show up in the list of interfaces in the
"Interface:" field in the dialog box popped up by "Capture->Start",
and/or why does Wireshark give me an error if I try to capture on that
interface?

9.2 I'm running Wireshark on a UNIX-flavored OS; why do no network
interfaces show up in the list of interfaces in the "Interface:" field
in the dialog box popped up by "Capture->Start"?

9.3 I'm capturing packets on Linux; why do the time stamps have only
100ms resolution, rather than 1us resolution?

### 10. Capturing packets on wireless LANs:

10.1 How can I capture raw 802.11 frames, including non-data
(management, beacon) frames?

10.2 How do I capture on an 802.11 device in monitor mode?

### 11. Viewing traffic:

11.1 Why am I seeing lots of packets with incorrect TCP checksums?

11.2 I've just installed Wireshark, and the traffic on my local LAN is
boring. Where can I find more interesting captures?

11.3 Why doesn't Wireshark correctly identify RTP packets? It shows them
only as UDP.

11.4 Why doesn't Wireshark show Yahoo Messenger packets in captures that
contain Yahoo Messenger traffic?

### 12. Filtering traffic:

12.1 I saved a filter and tried to use its name to filter the display;
why do I get an "Unexpected end of filter string" error?

12.2 How can I search for, or filter, packets that have a particular
string anywhere in them?

12.3 How do I filter a capture to see traffic for virus XXX?

### 1. General Questions

Q 1.1: What is Wireshark?

A: Wireshark® is a network protocol analyzer. It lets you capture and
interactively browse the traffic running on a computer network. It has a
rich and powerful feature set and is world's most popular tool of its
kind. It runs on most computing platforms including Windows, OS X,
Linux, and UNIX. Network professionals, security experts, developers,
and educators around the world use it regularly. It is freely available
as open source, and is released under the GNU General Public License
version 2.

It is developed and maintained by a global team of protocol experts, and
it is an example of a disruptive technology.

Wireshark used to be known as Ethereal®. See the next question for
details about the name change. If you're still using Ethereal, it is
strongly recommended that you upgrade to Wireshark.

For more information, please see the About Wireshark page.

Q 1.2: What's up with the name change? Is Wireshark a fork?

A: In May of 2006, Gerald Combs (the original author of Ethereal) went
to work for CACE Technologies (best known for WinPcap). Unfortunately,
he had to leave the Ethereal trademarks behind.

This left the project in an awkward position. The only reasonable way to
ensure the continued success of the project was to change the name. This
is how Wireshark was born.

Wireshark is almost (but not quite) a fork. Normally a "fork" of an open
source project results in two names, web sites, development teams,
support infrastructures, etc. This is the case with Wireshark except for
one notable exception -- every member of the core development team is
now working on Wireshark. There has been no active development on
Ethereal since the name change. Several parts of the Ethereal web site
(such as the mailing lists, source code repository, and build farm) have
gone offline.

More information on the name change can be found here:

  *   *   * Many other articles in

Q 1.3: Where can I get help?

A: Community support is available on the Q&A site and on the wireshark-
users mailing list. Subscription information and archives for all of
Wireshark's mailing lists can be found at
https://www.wireshark.org/mailman/listinfo. An IRC channel dedicated to
Wireshark can be found at irc://irc.freenode.net/wireshark.

Self-paced and instructor-led training is available at Wireshark
University. Wireshark University also offers certification via the
Wireshark Certified Network Analyst program.

Q 1.4: What kind of shark is Wireshark?

A: _carcharodon photoshopia_.

Q 1.5: How is Wireshark pronounced, spelled and capitalized?

A: Wireshark is pronounced as the word _wire_ followed immediately by
the word _shark_. Exact pronunciation and emphasis may vary depending on
your locale (e.g. Arkansas).

It's spelled with a capital _W_, followed by a lower-case _ireshark_. It
is not a CamelCase word, i.e., _WireShark_ is incorrect.

Q 1.6: How much does Wireshark cost?

A: Wireshark is "free software"; you can download it without paying any
license fee. The version of Wireshark you download isn't a "demo"
version, with limitations not present in a "full" version; it _is_ the
full version.

The license under which Wireshark is issued is the GNU General Public
License version 2. See the GNU GPL FAQ for some more information.

Q 1.7: But I just paid someone on eBay for a copy of Wireshark! Did I
get ripped off?

A: That depends. Did they provide any sort of value-added product or
service, such as installation support, installation media, training,
trace file analysis, or funky-colored shark-themed socks? Probably not.

Wireshark is available for anyone to download, absolutely free, at any
time. Paying for a copy implies that you should get something for your
money.

Q 1.8: Can I use Wireshark commercially?

A: Yes, if, for example, you mean "I work for a commercial organization;
can I use Wireshark to capture and analyze network traffic in our
company's networks or in our customer's networks?"

If you mean "Can I use Wireshark as part of my commercial product?", see
the next entry in the FAQ.

Q 1.9: Can I use Wireshark as part of my commercial product?

A: As noted, Wireshark is licensed under the GNU General Public License.
The GPL imposes conditions on your use of GPL'ed code in your own
products; you cannot, for example, make a "derived work" from Wireshark,
by making modifications to it, and then sell the resulting derived work
and not allow recipients to give away the resulting work. You must also
make the changes you've made to the Wireshark source available to all
recipients of your modified version; those changes must also be licensed
under the terms of the GPL. See the GPL FAQ for more details; in
particular, note the answer to the question about modifying a GPLed
program and selling it commercially, and the question about linking
GPLed code with other code to make a proprietary program.

You can combine a GPLed program such as Wireshark and a commercial
program as long as they communicate "at arm's length", as per this item
in the GPL FAQ.

We recommend keeping Wireshark and your product completely separate,
communicating over sockets or pipes. If you're loading any part of
Wireshark as a DLL, you're probably doing it wrong.

Q 1.10: What protocols are currently supported?

A: There are currently hundreds of supported protocols and media.
Details can be found in the wireshark(1) man page.

Q 1.11: Are there any plans to support {your favorite protocol}?

A: Support for particular protocols is added to Wireshark as a result of
people contributing that support; no formal plans for adding support for
particular protocols in particular future releases exist.

Q 1.12: Can Wireshark read capture files from {your favorite network
analyzer}?

A: Support for particular protocols is added to Wireshark as a result of
people contributing that support; no formal plans for adding support for
particular protocols in particular future releases exist.

If a network analyzer writes out files in a format already supported by
Wireshark (e.g., in libpcap format), Wireshark may already be able to
read them, unless the analyzer has added its own proprietary extensions
to that format.

If a network analyzer writes out files in its own format, or has added
proprietary extensions to another format, in order to make Wireshark
read captures from that network analyzer, we would either have to have a
specification for the file format, or the extensions, sufficient to give
us enough information to read the parts of the file relevant to
Wireshark, or would need at least one capture file in that format
**AND** a detailed textual analysis of the packets in that capture file
(showing packet time stamps, packet lengths, and the top-level packet
header) in order to reverse-engineer the file format.

Note that there is no guarantee that we will be able to reverse-engineer
a capture file format.

Q 1.13: What devices can Wireshark use to capture packets?

A: Wireshark can read live data from Ethernet, Token-Ring, FDDI, serial
(PPP and SLIP) (if the OS on which it's running allows Wireshark to do
so), 802.11 wireless LAN (if the OS on which it's running allows
Wireshark to do so), ATM connections (if the OS on which it's running
allows Wireshark to do so), and the "any" device supported on Linux by
recent versions of libpcap.

See the list of supported capture media on various OSes for details
(several items in there say "Unknown", which doesn't mean "Wireshark
can't capture on them", it means "we don't know whether it can capture
on them"; we expect that it will be able to capture on many of them, but
we haven't tried it ourselves - if you try one of those types and it
works, please update the wiki page accordingly.

It can also read a variety of capture file formats, including:

  * AG Group/WildPackets EtherPeek/TokenPeek/AiroPeek/EtherHelp/Packet
Grabber captures

  * AIX's iptrace captures

  * Accellent's 5Views LAN agent output

  * Cinco Networks NetXRay captures

  * Cisco Secure Intrusion Detection System IPLog output

  * CoSine L2 debug output

  * DBS Etherwatch VMS text output

  * Endace Measurement Systems' ERF format captures

  * EyeSDN USB S0 traces

  * HP-UX nettl captures

  * ISDN4BSD project i4btrace captures

  * Linux Bluez Bluetooth stack hcidump -w traces

  * Lucent/Ascend router debug output

  * Microsoft Network Monitor captures

  * Network Associates Windows-based Sniffer captures

  * Network General/Network Associates DOS-based Sniffer (compressed or
uncompressed) captures

  * Network Instruments Observer version 9 captures

  * Novell LANalyzer captures

  * RADCOM's WAN/LAN analyzer captures

  * Shomiti/Finisar Surveyor captures

  * Toshiba's ISDN routers dump output

  * VMS TCPIPtrace/TCPtrace/UCX$TRACE output

  * Visual Networks' Visual UpTime traffic capture

  * libpcap, tcpdump and various other tools using tcpdump's capture
format

  * snoop and atmsnoop output

so that it can read traces from various network types, as captured by
other applications or equipment, even if it cannot itself capture on
those network types.

Q 1.14: Does Wireshark work on Windows Vista or Windows Server 2008?

A: Yes, but if you want to capture packets as a normal user, you must
make sure npf.sys is loaded. Wireshark's installer enables this by
default. This is not a concern if you run Wireshark as Administrator,
but this is discouraged. See the CapturePrivileges page on the wiki for
more details.

### 2. Downloading Wireshark

Q 2.1: Why do I get an error when I try to run the Win32 installer?

A: The program you used to download it may have downloaded it
incorrectly. Web browsers and download accelerators sometimes may do
this.

Try downloading it with, for example:

  * Wget, for which Windows binaries are available from Christopher
Lewis or wGetGUI, which offers a GUI interface that uses wget;

  * WS_FTP from Ipswitch,

  * the ftp command that comes with Windows.

If you use the ftp command, make sure you do the transfer in binary mode
rather than ASCII mode, by using the binary command before transferring
the file.

### 3. Installing Wireshark

Q 3.1: I installed the Wireshark RPM (or other package); why did it
install TShark but not Wireshark?

A: Many distributions have separate Wireshark packages, one for non-GUI
components such as TShark, editcap, dumpcap, etc. and one for the GUI.
If this is the case on your system, there's probably a separate package
named wireshark-gnome or wireshark-gtk+. Find it and install it.

### 4. Building Wireshark

Q 4.1: I have libpcap installed; why did the configure script not find
pcap.h or bpf.h?

A: Are you sure pcap.h and bpf.h are installed? The official
distribution of libpcap only installs the libpcap.a library file when
"make install" is run. To install pcap.h and bpf.h, you must run "make
install-incl". If you're running Debian or Redhat, make sure you have
the "libpcap-dev" or "libpcap-devel" packages installed.

It's also possible that pcap.h and bpf.h have been installed in a
strange location. If this is the case, you may have to tweak aclocal.m4.

Q 4.2: Why do I get the error

> dftest_DEPENDENCIES was already defined in condition TRUE, which
implies condition HAVE_PLUGINS_TRUE

when I try to build Wireshark from SVN or a SVN snapshot?

A: You probably have automake 1.5 installed on your machine (the command
automake --version will report the version of automake on your machine).
There is a bug in that version of automake that causes this problem;
upgrade to a later version of automake (1.6 or later).

Q 4.3: Why does the linker fail with a number of "Output line too long."
messages followed by linker errors when I try to build Wireshark?

A: The version of the sed command on your system is incapable of
handling very long lines. On Solaris, for example, /usr/bin/sed has a
line length limit too low to allow libtool to work; /usr/xpg4/bin/sed
can handle it, as can GNU sed if you have it installed.

On Solaris, changing your command search path to search /usr/xpg4/bin
before /usr/bin should make the problem go away; on any platform on
which you have this problem, installing GNU sed and changing your
command path to search the directory in which it is installed before
searching the directory with the version of sed that came with the OS
should make the problem go away.

Q 4.4: When I try to build Wireshark on Solaris, why does the link fail
complaining that plugin_list is undefined?

A: This appears to be due to a problem with some versions of the GTK+
and GLib packages from www.sunfreeware.org; un-install those packages,
and try getting the 1.2.10 versions from that site, or the versions from
The Written Word, or the versions from Sun's GNOME distribution, or the
versions from the supplemental software CD that comes with the Solaris
media kit, or build them from source from the GTK Web site. Then re-run
the configuration script, and try rebuilding Wireshark. (If you get the
1.2.10 versions from www.sunfreeware.org, and the problem persists, un-
install them and try installing one of the other versions mentioned.)

Q 4.5: When I try to build Wireshark on Windows, why does the build fail
because of conflicts between winsock.h and winsock2.h?

A: As of Wireshark 0.9.5, you must install WinPcap 2.3 or later, and the
corresponding version of the developer's pack, in order to be able to
compile Wireshark; it will not compile with older versions of the
developer's pack. The symptoms of this failure are conflicts between
definitions in winsock.h and in winsock2.h; Wireshark uses winsock2.h,
but pre-2.3 versions of the WinPcap developer's packet use winsock.h.
(2.3 uses winsock2.h, so if Wireshark were to use winsock.h, it would
not be able to build with current versions of the WinPcap developer's
pack.)

Note that the installed version of the developer's pack should be the
same version as the version of WinPcap you have installed.

### 5. Starting Wireshark

Q 5.1: Why does Wireshark crash with a Bus Error when I try to run it on
Solaris 8?

A: Some versions of the GTK+ library from www.sunfreeware.org appear to
be buggy, causing Wireshark to drop core with a Bus Error. Un-install
those packages, and try getting the 1.2.10 version from that site, or
the version from The Written Word, or the version from Sun's GNOME
distribution, or the version from the supplemental software CD that
comes with the Solaris media kit, or build it from source from the GTK
Web site. Update the GLib library to the 1.2.10 version, from the same
source, as well. (If you get the 1.2.10 versions from
www.sunfreeware.org, and the problem persists, un-install them and try
installing one of the other versions mentioned.)

Similar problems may exist with older versions of GTK+ for earlier
versions of Solaris.

Q 5.2: When I run Wireshark on Windows NT, why does it die with a Dr.
Watson error, reporting an "Integer division by zero" exception, when I
start it?

A: In at least some case, this appears to be due to using the default
VGA driver; if that's not the correct driver for your video card, try
running the correct driver for your video card.

Q 5.3: When I try to run Wireshark, why does it complain about
sprint_realloc_objid being undefined?

A: Wireshark can only be linked with version 4.2.2 or later of UCD SNMP.
Your version of Wireshark was dynamically linked with such a version of
UCD SNMP; however, you have an older version of UCD SNMP installed,
which means that when Wireshark is run, it tries to link to the older
version, and fails. You will have to replace that version of UCD SNMP
with version 4.2.2 or a later version.

Q 5.4: I've installed Wireshark from Fink on Mac OS X; why is it very
slow to start up?

A: When an application is installed on OS X, prior to 10.4, it is
usually "prebound" to speed up launching the application. (That's what
the "Optimizing" phase of installation is.)

Fink normally performs prebinding automatically when you install a
package. However, in some rare cases, for whatever reason the prebinding
caches get corrupt, and then not only does prebinding fail, but startup
actually becomes much slower, because the system tries in vain to
perform prebinding "on the fly" as you launch the application. This
fails, causing sometimes huge delays.

To fix the prebinding caches, run the command



        sudo /sw/var/lib/fink/prebound/update-package-prebinding.pl -f


### 6. Crashes and other fatal errors

Q 6.1: I have an XXX network card on my machine; if I try to capture on
it, why does my machine crash or reset itself?

A: This is almost certainly a problem with one or more of:

  * the operating system you're using;

  * the device driver for the interface you're using;

  * the libpcap/WinPcap library and, if this is Windows, the WinPcap
device driver;

so:

  * if you are using Windows, see the WinPcap support page - check the
"Submitting bugs" section;

  * if you are using some Linux distribution, some version of BSD, or
some other UNIX-flavored OS, you should report the problem to the
company or organization that produces the OS (in the case of a Linux
distribution, report the problem to whoever produces the distribution).

Q 6.2: Why does my machine crash or reset itself when I select "Start"
from the "Capture" menu or select "Preferences" from the "Edit" menu?

A: Both of those operations cause Wireshark to try to build a list of
the interfaces that it can open; it does so by getting a list of
interfaces and trying to open them. There is probably an OS, driver, or,
for Windows, WinPcap bug that causes the system to crash when this
happens; see the previous question.

### 7. Capturing packets

Q 7.1: When I use Wireshark to capture packets, why do I see only
packets to and from my machine, or not see all the traffic I'm expecting
to see from or to the machine I'm trying to monitor?

A: This might be because the interface on which you're capturing is
plugged into an Ethernet or Token Ring switch; on a switched network,
unicast traffic between two ports will not necessarily appear on other
ports - only broadcast and multicast traffic will be sent to all ports.

Note that even if your machine is plugged into a hub, the "hub" may be a
switched hub, in which case you're still on a switched network.

Note also that on the Linksys Web site, they say that their auto-sensing
hubs "broadcast the 10Mb packets to the port that operate at 10Mb only
and broadcast the 100Mb packets to the ports that operate at 100Mb
only", which would indicate that if you sniff on a 10Mb port, you will
not see traffic coming sent to a 100Mb port, and _vice versa_. This
problem has also been reported for Netgear dual-speed hubs, and may
exist for other "auto-sensing" or "dual-speed" hubs.

Some switches have the ability to replicate all traffic on all ports to
a single port so that you can plug your analyzer into that single port
to sniff all traffic. You would have to check the documentation for the
switch to see if this is possible and, if so, to see how to do this. See
the switch reference page on the Wireshark Wiki for information on some
switches. (Note that it's a Wiki, so you can update or fix that
information, or add additional information on those switches or
information on new switches, yourself.)

Note also that many firewall/NAT boxes have a switch built into them;
this includes many of the "cable/DSL router" boxes. If you have a box of
that sort, that has a switch with some number of Ethernet ports into
which you plug machines on your network, and another Ethernet port used
to connect to a cable or DSL modem, you can, at least, sniff traffic
between the machines on your network and the Internet by plugging the
Ethernet port on the router going to the modem, the Ethernet port on the
modem, and the machine on which you're running Wireshark into a hub
(make sure it's not a switching hub, and that, if it's a dual-speed hub,
all three of those ports are running at the same speed.

If your machine is _not_ plugged into a switched network or a dual-speed
hub, or it is plugged into a switched network but the port is set up to
have all traffic replicated to it, the problem might be that the network
interface on which you're capturing doesn't support "promiscuous" mode,
or because your OS can't put the interface into promiscuous mode.
Normally, network interfaces supply to the host only:

  * packets sent to one of that host's link-layer addresses;

  * broadcast packets;

  * multicast packets sent to a multicast address that the host has
configured the interface to accept.

Most network interfaces can also be put in "promiscuous" mode, in which
they supply to the host all network packets they see. Wireshark will try
to put the interface on which it's capturing into promiscuous mode
unless the "Capture packets in promiscuous mode" option is turned off in
the "Capture Options" dialog box, and TShark will try to put the
interface on which it's capturing into promiscuous mode unless the -p
option was specified. However, some network interfaces don't support
promiscuous mode, and some OSes might not allow interfaces to be put
into promiscuous mode.

If the interface is not running in promiscuous mode, it won't see any
traffic that isn't intended to be seen by your machine. It **will** see
broadcast packets, and multicast packets sent to a multicast MAC address
the interface is set up to receive.

You should ask the vendor of your network interface whether it supports
promiscuous mode. If it does, you should ask whoever supplied the driver
for the interface (the vendor, or the supplier of the OS you're running
on your machine) whether it supports promiscuous mode with that network
interface.

In the case of token ring interfaces, the drivers for some of them, on
Windows, may require you to enable promiscuous mode in order to capture
in promiscuous mode. See the Wireshark Wiki item on Token Ring capturing
for details.

In the case of wireless LAN interfaces, it appears that, when those
interfaces are promiscuously sniffing, they're running in a
significantly different mode from the mode that they run in when they're
just acting as network interfaces (to the extent that it would be a
significant effort for those drivers to support for promiscuously
sniffing _and_ acting as regular network interfaces at the same time),
so it may be that Windows drivers for those interfaces don't support
promiscuous mode.

Q 7.2: When I capture with Wireshark, why can't I see any TCP packets
other than packets to and from my machine, even though another analyzer
on the network sees those packets?

A: You're probably not seeing _any_ packets other than unicast packets
to or from your machine, and broadcast and multicast packets; a switch
will normally send to a port only unicast traffic sent to the MAC
address for the interface on that port, and broadcast and multicast
traffic - it won't send to that port unicast traffic sent to a MAC
address for some other interface - and a network interface not in
promiscuous mode will receive only unicast traffic sent to the MAC
address for that interface, broadcast traffic, and multicast traffic
sent to a multicast MAC address the interface is set up to receive.

TCP doesn't use broadcast or multicast, so you will only see your own
TCP traffic, but UDP services may use broadcast or multicast so you'll
see some UDP traffic - however, this is not a problem with TCP traffic,
it's a problem with unicast traffic, as you also won't see all UDP
traffic between other machines.

I.e., this is probably the same question as this earlier one; see the
response to that question.

Q 7.3: Why am I only seeing ARP packets when I try to capture traffic?

A: You're probably on a switched network, and running Wireshark on a
machine that's not sending traffic to the switch and not being sent any
traffic from other machines on the switch. ARP packets are often
broadcast packets, which are sent to all switch ports.

I.e., this is probably the same question as this earlier one; see the
response to that question.

Q 7.4: Why am I not seeing any traffic when I try to capture traffic?

A: Is the machine running Wireshark sending out any traffic on the
network interface on which you're capturing, or receiving any traffic on
that network, or is there any broadcast traffic on the network or
multicast traffic to a multicast group to which the machine running
Wireshark belongs?

If not, this may just be a problem with promiscuous sniffing, either due
to running on a switched network or a dual-speed hub, or due to problems
with the interface not supporting promiscuous mode; see the response to
this earlier question.

Otherwise, on Windows, see the response to this question and, on a UNIX-
flavored OS, see the response to this question.

Q 7.5: Can Wireshark capture on (my T1/E1 line, SS7 links, etc.)?

A: Wireshark can only capture on devices supported by libpcap/WinPcap.
On most OSes, only devices that can act as network interfaces of the
type that support IP are supported as capture devices for
libpcap/WinPcap, although the device doesn't necessarily have to be
running as an IP interface in order to support traffic capture.

On Linux and FreeBSD, libpcap 0.8 and later support the API for Endace
Measurement Systems' DAG cards, so that a system with one of those
cards, and its driver and libraries, installed can capture traffic with
those cards with libpcap-based applications. You would either have to
have a version of Wireshark built with that version of libpcap, or a
dynamically-linked version of Wireshark and a shared libpcap library
with DAG support, in order to do so with Wireshark. You should ask
Endace whether that could be used to capture traffic on, for example,
your T1/E1 link.

See the SS7 capture setup page on the Wireshark Wiki for current
information on capturing SS7 traffic on TDM links.

Q 7.6: How do I put an interface into promiscuous mode?

A: By not disabling promiscuous mode when running Wireshark or TShark.

Note, however, that:

  * the form of promiscuous mode that libpcap (the library that programs
such as tcpdump, Wireshark, etc. use to do packet capture) turns on will
**not** necessarily be shown if you run ifconfig on the interface on a
UNIX system;

  * some network interfaces might not support promiscuous mode, and some
drivers might not allow promiscuous mode to be turned on - see this
earlier question for more information on that;

  * the fact that you're not seeing any traffic, or are only seeing
broadcast traffic, or aren't seeing any non-broadcast traffic other than
traffic to or from the machine running Wireshark, does not mean that
promiscuous mode isn't on - see this earlier question for more
information on that.

I.e., this is probably the same question as this earlier one; see the
response to that question.

Q 7.7: I can set a display filter just fine; why don't capture filters
work?

A: Capture filters currently use a different syntax than display
filters. Here's the corresponding section from the wireshark(1) man
page:

"Display filters in Wireshark are very powerful; more fields are
filterable in Wireshark than in other protocol analyzers, and the syntax
you can use to create your filters is richer. As Wireshark progresses,
expect more and more protocol fields to be allowed in display filters.

Packet capturing is performed with the pcap library. The capture filter
syntax follows the rules of the pcap library. This syntax is different
from the display filter syntax."

The capture filter syntax used by libpcap can be found in the tcpdump(8)
man page.

Q 7.8: I'm entering valid capture filters; why do I still get "parse
error" errors?

A: There is a bug in some versions of libpcap/WinPcap that cause it to
report parse errors even for valid expressions if a previous filter
expression was invalid and got a parse error.

Try exiting and restarting Wireshark; if you are using a version of
libpcap/WinPcap with this bug, this will "erase" its memory of the
previous parse error. If the capture filter that got the "parse error"
now works, the earlier error with that filter was probably due to this
bug.

The bug was fixed in libpcap 0.6; 0.4[.x] and 0.5[.x] versions of
libpcap have this bug, but 0.6[.x] and later versions don't.

Versions of WinPcap prior to 2.3 are based on pre-0.6 versions of
libpcap, and have this bug; WinPcap 2.3 is based on libpcap 0.6.2, and
doesn't have this bug.

If you are running Wireshark on a UNIX-flavored platform, run "wireshark
-v", or select "About Wireshark..." from the "Help" menu in Wireshark,
to see what version of libpcap it's using. If it's not 0.6 or later, you
will need either to upgrade your OS to get a later version of libpcap,
or will need to build and install a later version of libpcap from the
tcpdump.org Web site and then recompile Wireshark from source with that
later version of libpcap.

If you are running Wireshark on Windows with a pre-2.3 version of
WinPcap, you will need to un-install WinPcap and then download and
install WinPcap 2.3.

Q 7.9: How can I capture packets with CRC errors?

A: Wireshark can capture only the packets that the packet capture
library - libpcap on UNIX-flavored OSes, and the WinPcap port to Windows
of libpcap on Windows - can capture, and libpcap/WinPcap can capture
only the packets that the OS's raw packet capture mechanism (or the
WinPcap driver, and the underlying OS networking code and network
interface drivers, on Windows) will allow it to capture.

Unless the OS always supplies packets with errors such as invalid CRCs
to the raw packet capture mechanism, or can be configured to do so,
invalid CRCs to the raw packet capture mechanism, Wireshark - and other
programs that capture raw packets, such as tcpdump - cannot capture
those packets. You will have to determine whether your OS needs to be so
configured and, if so, can be so configured, configure it if necessary
and possible, and make whatever changes to libpcap and the packet
capture program you're using are necessary, if any, to support capturing
those packets.

Most OSes probably do **not** support capturing packets with invalid
CRCs on Ethernet, and probably do not support it on most other link-
layer types. Some drivers on some OSes do support it, such as some
Ethernet drivers on FreeBSD; in those OSes, you might always get those
packets, or you might only get them if you capture in promiscuous mode
(you'd have to determine which is the case).

Note that libpcap does not currently supply to programs that use it an
indication of whether the packet's CRC was invalid (because the drivers
themselves do not supply that information to the raw packet capture
mechanism); therefore, Wireshark will not indicate which packets had CRC
errors unless the FCS was captured (see the next question) and you're
using Wireshark 0.9.15 and later, in which case Wireshark will check the
CRC and indicate whether it's correct or not.

Q 7.10: How can I capture entire frames, including the FCS?

A: Wireshark can only capture data that the packet capture library -
libpcap on UNIX-flavored OSes, and the WinPcap port to Windows of
libpcap on Windows - can capture, and libpcap/WinPcap can capture only
the data that the OS's raw packet capture mechanism (or the WinPcap
driver, and the underlying OS networking code and network interface
drivers, on Windows) will allow it to capture.

For any particular link-layer network type, unless the OS supplies the
FCS of a frame as part of the frame, or can be configured to do so,
Wireshark - and other programs that capture raw packets, such as tcpdump
- cannot capture the FCS of a frame. You will have to determine whether
your OS needs to be so configured and, if so, can be so configured,
configure it if necessary and possible, and make whatever changes to
libpcap and the packet capture program you're using are necessary, if
any, to support capturing the FCS of a frame.

Most OSes do **not** support capturing the FCS of a frame on Ethernet,
and probably do not support it on most other link-layer types. Some
drivres on some OSes do support it, such as some (all?) Ethernet drivers
on NetBSD and possibly the driver for Apple's gigabit Ethernet interface
in Mac OS X; in those OSes, you might always get the FCS, or you might
only get the FCS if you capture in promiscuous mode (you'd have to
determine which is the case).

Versions of Wireshark prior to 0.9.15 will not treat an Ethernet FCS in
a captured packet as an FCS. 0.9.15 and later will attempt to determine
whether there's an FCS at the end of the frame and, if it thinks there
is, will display it as such, and will check whether it's the correct
CRC-32 value or not.

Q 7.11: I'm capturing packets on a machine on a VLAN; why don't the
packets I'm capturing have VLAN tags?

A: You might be capturing on what might be called a "VLAN interface" -
the way a particular OS makes VLANs plug into the networking stack
might, for example, be to have a network device object for the physical
interface, which takes VLAN packets, strips off the VLAN header and
constructs an Ethernet header, and passes that packet to an internal
network device object for the VLAN, which then passes the packets onto
various higher-level protocol implementations.

In order to see the raw Ethernet packets, rather than "de-VLANized"
packets, you would have to capture not on the virtual interface for the
VLAN, but on the interface corresponding to the physical network device,
if possible. See the Wireshark Wiki item on VLAN capturing for details.

Q 7.12: Why does Wireshark hang after I stop a capture?

A: The most likely reason for this is that Wireshark is trying to look
up an IP address in the capture to convert it to a name (so that, for
example, it can display the name in the source address or destination
address columns), and that lookup process is taking a very long time.

Wireshark calls a routine in the OS of the machine on which it's running
to convert of IP addresses to the corresponding names. That routine
probably does one or more of:

  * a search of a system file listing IP addresses and names;

  * a lookup using DNS;

  * on UNIX systems, a lookup using NIS;

  * on Windows systems, a NetBIOS-over-TCP query.

If a DNS server that's used in an address lookup is not responding, the
lookup will fail, but will only fail after a timeout while the system
routine waits for a reply.

In addition, on Windows systems, if the DNS lookup of the address fails,
either because the server isn't responding or because there are no
records in the DNS that could be used to map the address to a name, a
NetBIOS-over-TCP query will be made. That query involves sending a
message to the NetBIOS-over-TCP name service on that machine, asking for
the name and other information about the machine. If the machine isn't
running software that responds to those queries - for example, many non-
Windows machines wouldn't be running that software - the lookup will
only fail after a timeout. Those timeouts can cause the lookup to take a
long time.

If you disable network address-to-name translation - for example, by
turning off the "Enable network name resolution" option in the "Capture
Options" dialog box for starting a network capture - the lookups of the
address won't be done, which may speed up the process of reading the
capture file after the capture is stopped. You can make that setting the
default by selecting "Preferences" from the "Edit" menu, turning off the
"Enable network name resolution" option in the "Name resolution" options
in the preferences disalog box, and using the "Save" button in that
dialog box; note that this will save _all_ your current preference
settings.

If Wireshark hangs when reading a capture even with network name
resolution turned off, there might, for example, be a bug in one of
Wireshark's dissectors for a protocol causing it to loop infinitely. If
you're not running the most recent release of Wireshark, you should
first upgrade to that release, as, if there's a bug of that sort, it
might've been fixed in a release after the one you're running. If the
hang occurs in the most recent release of Wireshark, the bug should be
reported to the Wireshark developers' mailing list at wireshark-
dev@wireshark.org.

On UNIX-flavored OSes, please try to force Wireshark to dump core, by
sending it a SIGABRT signal (usually signal 6) with the kill command,
and then get a stack trace if you have a debugger installed. A stack
trace can be obtained by using your debugger (gdb in this example), the
Wireshark binary, and the resulting core file. Here's an example of how
to use the gdb command backtrace to do so.



            $ gdb wireshark core

            (gdb) backtrace

            ..... prints the stack trace

            (gdb) quit

            $


The core dump file may be named "wireshark.core" rather than "core" on
some platforms (e.g., BSD systems).

Also, if at all possible, please send a copy of the capture file that
caused the problem. When capturing packets, Wireshark normally writes
captured packets to a temporary file, which will probably be in /tmp or
/var/tmp on UNIX-flavored OSes, \TEMP on the main system disk (normally
C:) on Windows 9x/Me/NT 4.0, \Documents and Settings\your login name
\Local Settings\Temp on the main system disk on Windows 2000/Windows
XP/Windows Server 2003, and \Users\your login name\AppData\Local\Temp on
the main system disk on Windows 7, so the capture file will probably be
there. If you are capturing on a single interface, it will have a name
of the form, wireshark_iface_YYYYmmddHHMMSS_XXXXXX; otherwise, if you
are capturing on multiple interfaces, it will have a name of the form,
wireshark_<N>_interfaces_YYYYmmddHHMMSS_XXXXXX, where <N> is the number
of simultaneous interfaces you are capturing on. Please don't send a
trace file greater than 1 MB when compressed; instead, make it available
via FTP or HTTP, or say it's available but leave it up to a developer to
ask for it. If the trace file contains sensitive information (e.g.,
passwords), then please do not send it.

### 8. Capturing packets on Windows

Q 8.1: I'm running Wireshark on Windows; why does some network interface
on my machine not show up in the list of interfaces in the "Interface:"
field in the dialog box popped up by "Capture->Start", and/or why does
Wireshark give me an error if I try to capture on that interface?

A: If you are running Wireshark on Windows NT 4.0, Windows 2000, Windows
XP, or Windows Server 2003, and this is the first time you have run a
WinPcap-based program (such as Wireshark, or TShark, or WinDump, or
Analyzer, or...) since the machine was rebooted, you need to run that
program from an account with administrator privileges; once you have run
such a program, you will not need administrator privileges to run any
such programs until you reboot.

If you are running on Windows Windows 2000/Windows XP/Windows Server
2003 and have administrator privileges or a WinPcap-based program has
been run with those privileges since the machine rebooted, this problem
_might_ clear up if you completely un-install WinPcap and then re-
install it.

If that doesn't work, then note that Wireshark relies on the WinPcap
library, on the WinPcap device driver, and on the facilities that come
with the OS on which it's running in order to do captures.

Therefore, if the OS, the WinPcap library, or the WinPcap driver don't
support capturing on a particular network interface device, Wireshark
won't be able to capture on that device.

Note that:

  1. 2.02 and earlier versions of the WinPcap driver and library that
Wireshark uses for packet capture didn't support Token Ring interfaces;
versions 2.1 and later support Token Ring, and the current version of
Wireshark works with (and, in fact, requires) WinPcap 2.1 or later.

If you are having problems capturing on Token Ring interfaces, and you
have WinPcap 2.02 or an earlier version of WinPcap installed, you should
uninstall WinPcap, download and install the current version of WinPcap,
and then install the latest version of Wireshark.

  2. WinPcap 2.3 has problems supporting PPP WAN interfaces on Windows
NT 4.0, Windows 2000, Windows XP, and Windows Server 2003, and, to avoid
those problems, support for PPP WAN interfaces on those versions of
Windows has been disabled in WinPcap 3.0. Regular dial-up lines, ISDN
lines, ADSL connections using PPPoE or PPPoA, and various other lines
such as T1/E1 lines are all PPP interfaces, so those interfaces might
not show up on the list of interfaces in the "Capture Options" dialog on
those OSes.

On Windows 2000, Windows XP, and Windows Server 2003, but **not**
Windows NT 4.0 or Windows Vista Beta 1, you should be able to capture on
the "GenericDialupAdapter" with WinPcap 3.1. (3.1 beta releases called
it the "NdisWanAdapter"; if you're using a 3.1 beta release, you should
un-install it and install the final 3.1 release.) See the Wireshark Wiki
item on PPP capturing for details.

  3. WinPcap prior to 3.0 does not support multiprocessor machines (note
that machines with a single multi-threaded processor, such as Intel's
new multi-threaded x86 processors, are multiprocessor machines as far as
the OS and WinPcap are concerned), and recent 2.x versions of WinPcap
refuse to operate if they detect that they're running on a
multiprocessor machine, which means that they may not show any network
interfaces. You will need to use WinPcap 3.0 to capture on a
multiprocessor machine.


If an interface doesn't show up in the list of interfaces in the
"Interface:" field, and you know the name of the interface, try entering
that name in the "Interface:" field and capturing on that device.

If the attempt to capture on it succeeds, the interface is somehow not
being reported by the mechanism Wireshark uses to get a list of
interfaces. Try listing the interfaces with WinDump; see the WinDump Web
site for information on using WinDump.

You would run WinDump with the -D flag; if it lists the interface,
please report this to wireshark-dev@wireshark.org giving full details of
the problem, including

  * the operating system you're using, and the version of that operating
system;

  * the type of network device you're using;

  * the output of WinDump.

If WinDump does _not_ list the interface, this is almost certainly a
problem with one or more of:

  * the operating system you're using;

  * the device driver for the interface you're using;

  * the WinPcap library and/or the WinPcap device driver;

so first check the WinPcap FAQ or  the Wiretapped.net mirror of that
FAQ, to see if your problem is mentioned there. If not, then see the
WinPcap support page - check the "Submitting bugs" section.

If you are having trouble capturing on a particular network interface,
first try capturing on that device with WinDump; see the WinDump Web
site for information on using WinDump.

If you can capture on the interface with WinDump, send mail to
wireshark-users@wireshark.org giving full details of the problem,
including

  * the operating system you're using, and the version of that operating
system;

  * the type of network device you're using;

  * the error message you get from Wireshark.

If you _cannot_ capture on the interface with WinDump, this is almost
certainly a problem with one or more of:

  * the operating system you're using;

  * the device driver for the interface you're using;

  * the WinPcap library and/or the WinPcap device driver;

so first check the WinPcap FAQ or  the Wiretapped.net mirror of that
FAQ, to see if your problem is mentioned there. If not, then see the
WinPcap support page - check the "Submitting bugs" section.

You may also want to ask the wireshark-users@wireshark.org and the
winpcap-users@winpcap.org mailing lists to see if anybody happens to
know about the problem and know a workaround or fix for the problem.
(Note that you will have to subscribe to that list in order to be
allowed to mail to it; see the WinPcap support page for information on
the mailing list.) In your mail, please give full details of the
problem, as described above, and also indicate that the problem occurs
with WinDump, not just with Wireshark.

Q 8.2: I'm running Wireshark on Windows; why do no network interfaces
show up in the list of interfaces in the "Interface:" field in the
dialog box popped up by "Capture->Start"?

A: This is really the same question as a previous one; see the response
to that question.

Q 8.3: I'm running Wireshark on Windows; why doesn't my serial port/ADSL
modem/ISDN modem show up in the list of interfaces in the "Interface:"
field in the dialog box popped up by "Capture->Start"?

A: Internet access on those devices is often done with the Point-to-
Point (PPP) protocol; WinPcap 2.3 has problems supporting PPP WAN
interfaces on Windows NT 4.0, Windows 2000, Windows XP, and Windows
Server 2003, and, to avoid those problems, support for PPP WAN
interfaces on those versions of Windows has been disabled in WinPcap
3.0.

On Windows 2000, Windows XP, and Windows Server 2003, but **not**
Windows NT 4.0 or Windows Vista Beta 1, you should be able to capture on
the "GenericDialupAdapter" with WinPcap 3.1. (3.1 beta releases called
it the "NdisWanAdapter"; if you're using a 3.1 beta release, you should
un-install it and install the final 3.1 release.) See the Wireshark Wiki
item on PPP capturing for details.

Q 8.4: I'm running Wireshark on Windows NT 4.0/Windows 2000/Windows
XP/Windows Server 2003; my machine has a PPP (dial-up POTS, ISDN, etc.)
interface, and it shows up in the "Interface" item in the "Capture
Options" dialog box. Why can no packets be sent on or received from that
network while I'm trying to capture traffic on that interface?

A: Some versions of WinPcap have problems with PPP WAN interfaces on
Windows NT 4.0, Windows 2000, Windows XP, and Windows Server 2003; one
symptom that may be seen is that attempts to capture in promiscuous mode
on the interface cause the interface to be incapable of sending or
receiving packets. You can disable promiscuous mode using the -p
command-line flag or the item in the "Capture Preferences" dialog box,
but this may mean that outgoing packets, or incoming packets, won't be
seen in the capture.

On Windows 2000, Windows XP, and Windows Server 2003, but **not**
Windows NT 4.0 or Windows Vista Beta 1, you should be able to capture on
the "GenericDialupAdapter" with WinPcap 3.1. (3.1 beta releases called
it the "NdisWanAdapter"; if you're using a 3.1 beta release, you should
un-install it and install the final 3.1 release.) See the Wireshark Wiki
item on PPP capturing for details.

Q 8.5: I'm running Wireshark on Windows; why am I not seeing any traffic
being sent by the machine running Wireshark?

A: If you are running some form of VPN client software, it might be
causing this problem; people have seen this problem when they have Check
Point's VPN software installed on their machine. If that's the cause of
the problem, you will have to remove the VPN software in order to have
Wireshark (or any other application using WinPcap) see outgoing packets;
unfortunately, neither we nor the WinPcap developers know any way to
make WinPcap and the VPN software work well together.

Also, some drivers for Windows (especially some wireless network
interface drivers) apparently do not, when running in promiscuous mode,
arrange that outgoing packets are delivered to the software that
requested that the interface run promiscuously; try turning promiscuous
mode off.

Q 8.6: When I capture on Windows in promiscuous mode, I can see packets
other than those sent to or from my machine; however, those packets show
up with a "Short Frame" indication, unlike packets to or from my
machine. What should I do to arrange that I see those packets in their
entirety?

A: In at least some cases, this appears to be the result of PGPnet
running on the network interface on which you're capturing; turn it off
on that interface.

Q 8.7: I'm trying to capture 802.11 traffic on Windows; why am I not
seeing any packets?

A: At least some 802.11 card drivers on Windows appear not to see any
packets if they're running in promiscuous mode. Try turning promiscuous
mode off; you'll only be able to see packets sent by and received by
your machine, not third-party traffic, and it'll look like Ethernet
traffic and won't include any management or control frames, but that's a
limitation of the card drivers.

See MicroLogix's list of cards supported with WinPcap for information on
support of various adapters and drivers with WinPcap.

Q 8.8: I'm trying to capture 802.11 traffic on Windows; why am I seeing
packets received by the machine on which I'm capturing traffic, but not
packets sent by that machine?

A: This appears to be another problem with promiscuous mode; try turning
it off.

Q 8.9: I'm trying to capture Ethernet VLAN traffic on Windows, and I'm
capturing on a "raw" Ethernet device rather than a "VLAN interface", so
that I can see the VLAN headers; why am I seeing packets received by the
machine on which I'm capturing traffic, but not packets sent by that
machine?

A: The way the Windows networking code works probably means that packets
are sent on a "VLAN interface" rather than the "raw" device, so packets
sent by the machine will only be seen when you capture on the "VLAN
interface". If so, you will be unable to see outgoing packets when
capturing on the "raw" device, so you are stuck with a choice between
seeing VLAN headers and seeing outgoing packets.

### 9. Capturing packets on UN*Xes

Q 9.1: I'm running Wireshark on a UNIX-flavored OS; why does some
network interface on my machine not show up in the list of interfaces in
the "Interface:" field in the dialog box popped up by "Capture->Start",
and/or why does Wireshark give me an error if I try to capture on that
interface?

A: You may need to run Wireshark from an account with sufficient
privileges to capture packets, such as the super-user account, or may
need to give your account sufficient privileges to capture packets. Only
those interfaces that Wireshark can open for capturing show up in that
list; if you don't have sufficient privileges to capture on any
interfaces, no interfaces will show up in the list. See the Wireshark
Wiki item on capture privileges for details on how to give a particular
account or account group capture privileges on platforms where that can
be done.

If you are running Wireshark from an account with sufficient privileges,
then note that Wireshark relies on the libpcap library, and on the
facilities that come with the OS on which it's running in order to do
captures. On some OSes, those facilities aren't present by default; see
the Wireshark Wiki item on adding capture support for details.

And, even if you're running with an account that has sufficient
privileges to capture, and capture support is present in your OS, if the
OS or the libpcap library don't support capturing on a particular
network interface device or particular types of devices, Wireshark won't
be able to capture on that device.

On Solaris, note that libpcap 0.6.2 and earlier didn't support Token
Ring interfaces; the current version, 0.7.2, does support Token Ring,
and the current version of Wireshark works with libpcap 0.7.2 and later.

If an interface doesn't show up in the list of interfaces in the
"Interface:" field, and you know the name of the interface, try entering
that name in the "Interface:" field and capturing on that device.

If the attempt to capture on it succeeds, the interface is somehow not
being reported by the mechanism Wireshark uses to get a list of
interfaces; please report this to wireshark-dev@wireshark.org giving
full details of the problem, including

  * the operating system you're using, and the version of that operating
system (for Linux, give both the version number of the kernel and the
name and version number of the distribution you're using);

  * the type of network device you're using.

If you are having trouble capturing on a particular network interface,
and you've made sure that (on platforms that require it) you've arranged
that packet capture support is present, as per the above, first try
capturing on that device with tcpdump.

If you can capture on the interface with tcpdump, send mail to
wireshark-users@wireshark.org giving full details of the problem,
including

  * the operating system you're using, and the version of that operating
system (for Linux, give both the version number of the kernel and the
name and version number of the distribution you're using);

  * the type of network device you're using;

  * the error message you get from Wireshark.

If you _cannot_ capture on the interface with tcpdump, this is almost
certainly a problem with one or more of:

  * the operating system you're using;

  * the device driver for the interface you're using;

  * the libpcap library;

so you should report the problem to the company or organization that
produces the OS (in the case of a Linux distribution, report the problem
to whoever produces the distribution).

You may also want to ask the wireshark-users@wireshark.org and the
tcpdump-workers@lists.tcpdump.org mailing lists to see if anybody
happens to know about the problem and know a workaround or fix for the
problem. In your mail, please give full details of the problem, as
described above, and also indicate that the problem occurs with tcpdump
not just with Wireshark.

Q 9.2: I'm running Wireshark on a UNIX-flavored OS; why do no network
interfaces show up in the list of interfaces in the "Interface:" field
in the dialog box popped up by "Capture->Start"?

A: This is really the same question as the previous one; see the
response to that question.

Q 9.3: I'm capturing packets on Linux; why do the time stamps have only
100ms resolution, rather than 1us resolution?

A: Wireshark gets time stamps from libpcap/WinPcap, and libpcap/WinPcap
get them from the OS kernel, so Wireshark - and any other program using
libpcap, such as tcpdump - is at the mercy of the time stamping code in
the OS for time stamps.

At least on x86-based machines, Linux can get high-resolution time
stamps on newer processors with the Time Stamp Counter (TSC) register;
for example, Intel x86 processors, starting with the Pentium Pro, and
including all x86 processors since then, have had a TSC, and other
vendors probably added the TSC at some point to their families of x86
processors. The Linux kernel must be configured with the CONFIG_X86_TSC
option enabled in order to use the TSC. Make sure this option is enabled
in your kernel.

In addition, some Linux distributions may have bugs in their versions of
the kernel that cause packets not to be given high-resolution time
stamps even if the TSC is enabled. See, for example, bug 61111 for Red
Hat Linux 7.2. If your distribution has a bug such as this, you may have
to run a standard kernel from kernel.org in order to get high-resolution
time stamps.

### 10. Capturing packets on wireless LANs

Q 10.1: How can I capture raw 802.11 frames, including non-data
(management, beacon) frames?

A: That depends on the operating system on which you're running, and on
the 802.11 interface on which you're capturing.

This would probably require that you capture in promiscuous mode or in
the mode called "monitor mode" or "RFMON mode". On some platforms, or
with some cards, this might require that you capture in monitor mode -
promiscuous mode might not be sufficient. If you want to capture traffic
on networks other than the one with which you're associated, you will
have to capture in monitor mode.

Not all operating systems support capturing non-data packets and, even
on operating systems that do support it, not all drivers, and thus not
all interfaces, support it. Even on those that do, monitor mode might
not be supported by the operating system or by the drivers for all
interfaces.

**NOTE:** an interface running in monitor mode will, on most if not all
platforms, not be able to act as a regular network interface; putting it
into monitor mode will, in effect, take your machine off of whatever
network it's on as long as the interface is in monitor mode, allowing it
only to passively capture packets.

This means that you should disable name resolution when capturing in
monitor mode; otherwise, when Wireshark (or TShark, or tcpdump) tries to
display IP addresses as host names, it will probably block for a long
time trying to resolve the name because it will not be able to
communicate with any DNS or NIS servers.

See the Wireshark Wiki item on 802.11 capturing for details.

Q 10.2: How do I capture on an 802.11 device in monitor mode?

A: Whether you will be able to capture in monitor mode depends on the
operating system, adapter, and driver you're using. See the previous
question for information on monitor mode, including a link to the
Wireshark Wiki page that gives details on 802.11 capturing.

### 11. Viewing traffic

Q 11.1: Why am I seeing lots of packets with incorrect TCP checksums?

A: If the packets that have incorrect TCP checksums are all being sent
by the machine on which Wireshark is running, this is probably because
the network interface on which you're capturing does TCP checksum
offloading. That means that the TCP checksum is added to the packet by
the network interface, not by the OS's TCP/IP stack; when capturing on
an interface, packets being sent by the host on which you're capturing
are directly handed to the capture interface by the OS, which means that
they are handed to the capture interface without a TCP checksum being
added to them.

The only way to prevent this from happening would be to disable TCP
checksum offloading, but

  1. that might not even be possible on some OSes;

  2. that could reduce networking performance significantly.

However, you can disable the check that Wireshark does of the TCP
checksum, so that it won't report any packets as having TCP checksum
errors, and so that it won't refuse to do TCP reassembly due to a packet
having an incorrect TCP checksum. That can be set as an Wireshark
preference by selecting "Preferences" from the "Edit" menu, opening up
the "Protocols" list in the left-hand pane of the "Preferences" dialog
box, selecting "TCP", from that list, turning off the "Check the
validity of the TCP checksum when possible" option, clicking "Save" if
you want to save that setting in your preference file, and clicking
"OK".

It can also be set on the Wireshark or TShark command line with a -o
tcp.check_checksum:false command-line flag, or manually set in your
preferences file by adding a tcp.check_checksum:false line.

Q 11.2: I've just installed Wireshark, and the traffic on my local LAN
is boring. Where can I find more interesting captures?

A: We have a collection of strange and exotic sample capture files at
http://wiki.wireshark.org/SampleCaptures

Q 11.3: Why doesn't Wireshark correctly identify RTP packets? It shows
them only as UDP.

A: Wireshark can identify a UDP datagram as containing a packet of a
particular protocol running atop UDP only if

  1. The protocol in question has a particular standard port number, and
the UDP source or destination port number is that port

  2. Packets of that protocol can be identified by looking for a
"signature" of some type in the packet - i.e., some data that, if
Wireshark finds it in some particular part of a packet, means that the
packet is almost certainly a packet of that type.

  3. Some _other_ traffic earlier in the capture indicated that, for
example, UDP traffic between two particular addresses and ports will be
RTP traffic.

RTP doesn't have a standard port number, so 1) doesn't work; it doesn't,
as far as I know, have any "signature", so 2) doesn't work.

That leaves 3). If there's RTSP traffic that sets up an RTP session,
then, at least in some cases, the RTSP dissector will set things up so
that subsequent RTP traffic will be identified. Currently, that's the
only place we do that; there may be other places.

However, there will always be places where Wireshark is simply
**incapable** of deducing that a given UDP flow is RTP; a mechanism
would be needed to allow the user to specify that a given conversation
should be treated as RTP. As of Wireshark 0.8.16, such a mechanism
exists; if you select a UDP or TCP packet, the right mouse button menu
will have a "Decode As..." menu item, which will pop up a dialog box
letting you specify that the source port, the destination port, or both
the source and destination ports of the packet should be dissected as
some particular protocol.

Q 11.4: Why doesn't Wireshark show Yahoo Messenger packets in captures
that contain Yahoo Messenger traffic?

A: Wireshark only recognizes as Yahoo Messenger traffic packets to or
from TCP port 3050 that begin with "YPNS", "YHOO", or "YMSG". TCP
segments that start with the middle of a Yahoo Messenger packet that
takes more than one TCP segment will not be recognized as Yahoo
Messenger packets (even if the TCP segment also contains the beginning
of another Yahoo Messenger packet).

### 12. Filtering traffic

Q 12.1: I saved a filter and tried to use its name to filter the
display; why do I get an "Unexpected end of filter string" error?

A: You cannot use the name of a saved display filter as a filter. To
filter the display, you can enter a display filter expression - **not**
the name of a saved display filter - in the "Filter:" box at the bottom
of the display, and type the  key or press the "Apply" button (that does
not require you to have a saved filter), or, if you want to use a saved
filter, you can press the "Filter:" button, select the filter in the
dialog box that pops up, and press the "OK" button.

Q 12.2: How can I search for, or filter, packets that have a particular
string anywhere in them?

A: If you want to do this when capturing, you can't. That's a feature
that would be hard to implement in capture filters without changes to
the capture filter code, which, on many platforms, is in the OS kernel
and, on other platforms, is in the libpcap library.

After capture, you can search for text by selecting _Edit->Find
Packet..._ and making sure _String_ is selected. Alternately, you can
use the "contains" display filter operator or "matches" operator if it's
supported on your system.

Q 12.3: How do I filter a capture to see traffic for virus XXX?

A: For some viruses/worms there might be a capture filter to recognize
the virus traffic. Check the CaptureFilters page on the Wireshark Wiki
to see if anybody's added such a filter.

Note that Wireshark was not designed to be an intrusion detection
system; you might be able to use it as an IDS, but in most cases
software designed to be an IDS, such as Snort or Prelude, will probably
work better.

The Bleeding Edge of Snort has a collection of signatures for Snort to
detect various viruses, worms, and the like.