xref: /freebsd/contrib/file/magic/Magdir/sniffer (revision da759cfa320d5076b075d15ff3f00ab3ba5634fd)
1
2#------------------------------------------------------------------------------
3# $File: sniffer,v 1.27 2019/12/08 18:22:24 christos Exp $
4# sniffer:  file(1) magic for packet capture files
5#
6# From: guy@alum.mit.edu (Guy Harris)
7#
8
9#
10# Microsoft Network Monitor 1.x capture files.
11#
120	string		RTSS		NetMon capture file
13>5	byte		x		- version %d
14>4	byte		x		\b.%d
15>6	leshort		0		(Unknown)
16>6	leshort		1		(Ethernet)
17>6	leshort		2		(Token Ring)
18>6	leshort		3		(FDDI)
19>6	leshort		4		(ATM)
20>6	leshort		>4		(type %d)
21
22#
23# Microsoft Network Monitor 2.x capture files.
24#
250	string		GMBU		NetMon capture file
26>5	byte		x		- version %d
27>4	byte		x		\b.%d
28>6	leshort		0		(Unknown)
29>6	leshort		1		(Ethernet)
30>6	leshort		2		(Token Ring)
31>6	leshort		3		(FDDI)
32>6	leshort		4		(ATM)
33>6	leshort		5		(IP-over-IEEE 1394)
34>6	leshort		6		(802.11)
35>6	leshort		7		(Raw IP)
36>6	leshort		8		(Raw IP)
37>6	leshort		9		(Raw IP)
38>6	leshort		>9		(type %d)
39
40#
41# Network General Sniffer capture files.
42# Sorry, make that "Network Associates Sniffer capture files."
43# Sorry, make that "Network General old DOS Sniffer capture files."
44#
450	string		TRSNIFF\040data\040\040\040\040\032	Sniffer capture file
46>33	byte		2		(compressed)
47>23	leshort		x		- version %d
48>25	leshort		x		\b.%d
49>32	byte		0		(Token Ring)
50>32	byte		1		(Ethernet)
51>32	byte		2		(ARCNET)
52>32	byte		3		(StarLAN)
53>32	byte		4		(PC Network broadband)
54>32	byte		5		(LocalTalk)
55>32	byte		6		(Znet)
56>32	byte		7		(Internetwork Analyzer)
57>32	byte		9		(FDDI)
58>32	byte		10		(ATM)
59
60#
61# Cinco Networks NetXRay capture files.
62# Sorry, make that "Network General Sniffer Basic capture files."
63# Sorry, make that "Network Associates Sniffer Basic capture files."
64# Sorry, make that "Network Associates Sniffer Basic, and Windows
65# Sniffer Pro", capture files."
66# Sorry, make that "Network General Sniffer capture files."
67# Sorry, make that "NetScout Sniffer capture files."
68#
690	string		XCP\0		NetXRay capture file
70>4	string		>\0		- version %s
71>44	leshort		0		(Ethernet)
72>44	leshort		1		(Token Ring)
73>44	leshort		2		(FDDI)
74>44	leshort		3		(WAN)
75>44	leshort		8		(ATM)
76>44	leshort		9		(802.11)
77
78#
79# "libpcap" capture files.
80# https://www.tcpdump.org/manpages/pcap-savefile.5.html
81# (We call them "tcpdump capture file(s)" for now, as "tcpdump" is
82# the main program that uses that format, but there are other programs
83# that use "libpcap", or that use the same capture file format.)
84#
850	name		pcap-be
86>4	beshort		x		- version %d
87>6	beshort		x		\b.%d
88# clear that continuation level match
89>20	clear		x
90>20	belong		0		(No link-layer encapsulation
91>20	belong		1		(Ethernet
92>20	belong		2		(3Mb Ethernet
93>20	belong		3		(AX.25
94>20	belong		4		(ProNET
95>20	belong		5		(CHAOS
96>20	belong		6		(Token Ring
97>20	belong		7		(BSD ARCNET
98>20	belong		8		(SLIP
99>20	belong		9		(PPP
100>20	belong		10		(FDDI
101>20	belong		11		(RFC 1483 ATM
102>20	belong		12		(Raw IP
103>20	belong		13		(BSD/OS SLIP
104>20	belong		14		(BSD/OS PPP
105>20	belong		19		(Linux ATM Classical IP
106>20	belong		50		(PPP or Cisco HDLC
107>20	belong		51		(PPP-over-Ethernet
108>20	belong		99		(Symantec Enterprise Firewall
109>20	belong		100		(RFC 1483 ATM
110>20	belong		101		(Raw IP
111>20	belong		102		(BSD/OS SLIP
112>20	belong		103		(BSD/OS PPP
113>20	belong		104		(BSD/OS Cisco HDLC
114>20	belong		105		(802.11
115>20	belong		106		(Linux Classical IP over ATM
116>20	belong		107		(Frame Relay
117>20	belong		108		(OpenBSD loopback
118>20	belong		109		(OpenBSD IPsec encrypted
119>20	belong		112		(Cisco HDLC
120>20	belong		113		(Linux cooked v1
121>20	belong		114		(LocalTalk
122>20	belong		117		(OpenBSD PFLOG
123>20	belong		119		(802.11 with Prism header
124>20	belong		122		(RFC 2625 IP over Fibre Channel
125>20	belong		123		(SunATM
126>20	belong		127		(802.11 with radiotap header
127>20	belong		129		(Linux ARCNET
128>20	belong		130		(Juniper Multi-Link PPP
129>20	belong		131		(Juniper Multi-Link Frame Relay
130>20	belong		132		(Juniper Encryption Services PIC
131>20	belong		133		(Juniper GGSN PIC
132>20	belong		134		(Juniper FRF.16 Frame Relay
133>20	belong		135		(Juniper ATM2 PIC
134>20	belong		136		(Juniper Advanced Services PIC
135>20	belong		137		(Juniper ATM1 PIC
136>20	belong		138		(Apple IP over IEEE 1394
137>20	belong		139		(SS7 MTP2 with pseudo-header
138>20	belong		140		(SS7 MTP2
139>20	belong		141		(SS7 MTP3
140>20	belong		142		(SS7 SCCP
141>20	belong		143		(DOCSIS
142>20	belong		144		(Linux IrDA
143>20	belong		147		(Private use 0
144>20	belong		148		(Private use 1
145>20	belong		149		(Private use 2
146>20	belong		150		(Private use 3
147>20	belong		151		(Private use 4
148>20	belong		152		(Private use 5
149>20	belong		153		(Private use 6
150>20	belong		154		(Private use 7
151>20	belong		155		(Private use 8
152>20	belong		156		(Private use 9
153>20	belong		157		(Private use 10
154>20	belong		158		(Private use 11
155>20	belong		159		(Private use 12
156>20	belong		160		(Private use 13
157>20	belong		161		(Private use 14
158>20	belong		162		(Private use 15
159>20	belong		163		(802.11 with AVS header
160>20	belong		164		(Juniper Passive Monitor PIC
161>20	belong		165		(BACnet MS/TP
162>20	belong		166		(PPPD
163>20	belong		167		(Juniper PPPoE
164>20	belong		168		(Juniper PPPoE/ATM
165>20	belong		169		(GPRS LLC
166>20	belong		170		(GPF-T
167>20	belong		171		(GPF-F
168>20	belong		174		(Juniper PIC Peer
169>20	belong		175		(Ethernet with Endace ERF header
170>20	belong		176		(Packet-over-SONET with Endace ERF header
171>20	belong		177		(Linux LAPD
172>20	belong		178		(Juniper Ethernet
173>20	belong		179		(Juniper PPP
174>20	belong		180		(Juniper Frame Relay
175>20	belong		181		(Juniper C-HDLC
176>20	belong		182		(FRF.16 Frame Relay
177>20	belong		183		(Juniper Voice PIC
178>20	belong		184		(Arinc 429
179>20	belong		185		(Arinc 653 Interpartition Communication
180>20	belong		186		(USB with FreeBSD header
181>20	belong		187		(Bluetooth HCI H4
182>20	belong		188		(802.16 MAC Common Part Sublayer
183>20	belong		189		(Linux USB
184>20	belong		190		(Controller Area Network (CAN) v. 2.0B
185>20	belong		191		(802.15.4 with Linux padding
186>20	belong		192		(PPI
187>20	belong		193		(802.16 MAC Common Part Sublayer plus radiotap header
188>20	belong		194		(Juniper Integrated Service Module
189>20	belong		195		(802.15.4 with FCS
190>20	belong		196		(SITA
191>20	belong		197		(Endace ERF
192>20	belong		198		(Ethernet with u10 Networks pseudo-header
193>20	belong		199		(IPMB
194>20	belong		200		(Juniper Secure Tunnel
195>20	belong		201		(Bluetooth HCI H4 with pseudo-header
196>20	belong		202		(AX.25 with KISS header
197>20	belong		203		(LAPD
198>20	belong		204		(PPP with direction pseudo-header
199>20	belong		205		(Cisco HDLC with direction pseudo-header
200>20	belong		206		(Frame Relay with direction pseudo-header
201>20	belong		209		(Linux IPMB
202>20	belong		215		(802.15.4 with non-ASK PHY header
203>20	belong		216		(Linux evdev events
204>20	belong		219		(MPLS with label as link-layer header
205>20	belong		220		(Memory-mapped Linux USB
206>20	belong		221		(DECT
207>20	belong		222		(AOS Space Data Link protocol
208>20	belong		223		(Wireless HART
209>20	belong		224		(Fibre Channel FC-2
210>20	belong		225		(Fibre Channel FC-2 with frame delimiters
211>20	belong		226		(Solaris IPNET
212>20	belong		227		(SocketCAN
213>20	belong		228		(Raw IPv4
214>20	belong		229		(Raw IPv6
215>20	belong		230		(802.15.4 without FCS
216>20	belong		231		(D-Bus messages
217>20	belong		232		(Juniper Virtual Server
218>20	belong		233		(Juniper SRX E2E
219>20	belong		234		(Juniper Fibre Channel
220>20	belong		235		(DVB-CI
221>20	belong		236		(MUX27010
222>20	belong		237		(STANAG 5066 D_PDUs
223>20	belong		238		(Juniper ATM CEMIC
224>20	belong		239		(Linux netfilter log messages
225>20	belong		240		(Hilscher netAnalyzer
226>20	belong		241		(Hilscher netAnalyzer with delimiters
227>20	belong		242		(IP-over-Infiniband
228>20	belong		243		(MPEG-2 Transport Stream packets
229>20	belong		244		(ng4t ng40
230>20	belong		245		(NFC LLCP
231>20	belong		246		(Packet filter state syncing
232>20	belong		247		(InfiniBand
233>20	belong		248		(SCTP
234>20	belong		249		(USB with USBPcap header
235>20	belong		250		(Schweitzer Engineering Laboratories RTAC packets
236>20	belong		251		(Bluetooth Low Energy air interface
237>20	belong		252		(Wireshark Upper PDU export
238>20	belong		253		(Linux netlink
239>20	belong		254		(Bluetooth Linux Monitor
240>20	belong		255		(Bluetooth Basic Rate/Enhanced Data Rate baseband packets
241>20	belong		256		(Bluetooth Low Energy air interface with pseudo-header
242>20	belong		257		(PROFIBUS data link layer
243>20	belong		258		(Apple DLT_PKTAP
244>20	belong		259		(Ethernet with 802.3 Clause 65 EPON preamble
245>20	belong		260		(IPMI trace packets
246>20	belong		261		(Z-Wave RF profile R1 and R2 packets
247>20	belong		262		(Z-Wave RF profile R3 packets
248>20	belong		263		(WattStopper Digital Lighting Mngmt/Legrand Nitoo Open Proto
249>20	belong		264		(ISO 14443 messages
250>20	belong		265		(IEC 62106 Radio Data System groups
251>20	belong		266		(USB with Darwin header
252>20	belong		267		(OpenBSD DLT_OPENFLOW
253>20	belong		268		(IBM SDLC frames
254>20	belong		269		(TI LLN sniffer frames
255>20	belong		271		(Linux vsock
256>20	belong		272		(Nordic Semiconductor Bluetooth LE sniffer frames
257>20	belong		273		(Excentis XRA-31 DOCSIS 3.1 RF sniffer frames
258>20	belong		274		(802.3br mPackets
259>20	belong		275		(DisplayPort AUX channel monitoring data
260>20	belong		276		(Linux cooked v2
261>20	belong		278		(OpenVizsla USB
262>20	belong		279		(Elektrobit High Speed Capture and Replay (EBHSCR)
263>20	belong		281		(Broadcom tag
264>20	belong		282		(Broadcom tag (prepended)
265>20	belong		284		(Marvell DSA
266>20	belong		285		(Marvell EDSA
267# print default match
268>20	default		x
269>>20	belong		x		(linktype#%u
270>16	belong		x		\b, capture length %u)
271
272# packets time stamps in seconds and microseconds.
2730	ubelong		0xa1b2c3d4	pcap capture file, microseconds ts (big-endian)
274!:mime	application/vnd.tcpdump.pcap
275>0	use	pcap-be
2760	ulelong		0xa1b2c3d4	pcap capture file, microsecond ts (little-endian)
277!:mime	application/vnd.tcpdump.pcap
278>0	use	\^pcap-be
279
280# packets time stamps in seconds and nanoseconds.
2810	ubelong		0xa1b23c4d	pcap capture file, nanosecond ts (big-endian)
282!:mime	application/vnd.tcpdump.pcap
283>0	use	pcap-be
2840	ulelong		0xa1b23c4d	pcap capture file, nanosecond ts (little-endian)
285!:mime	application/vnd.tcpdump.pcap
286>0	use	\^pcap-be
287
288#
289# "libpcap"-with-Alexey-Kuznetsov's-patches capture files.
290#
2910	ubelong		0xa1b2cd34	pcap capture file, microsecond ts, extensions (big-endian)
292>0	use	pcap-be
2930	ulelong		0xa1b2cd34	pcap capture file, microsecond ts, extensions (little-endian)
294>0	use	\^pcap-be
295
296#
297# "pcapng" capture files.
298# https://github.com/pcapng/pcapng
299# Pcapng files can contain multiple sections. Printing the endianness,
300# snaplen, or other information from the first SHB may be misleading.
301#
3020	ubelong		0x0a0d0d0a
303>8	ubelong		0x1a2b3c4d	pcapng capture file
304>>12	beshort		x		- version %d
305>>14	beshort		x		\b.%d
3060	ulelong		0x0a0d0d0a
307>8	ulelong		0x1a2b3c4d	pcapng capture file
308>>12	leshort		x		- version %d
309>>14	leshort		x		\b.%d
310
311#
312# AIX "iptrace" capture files.
313#
3140	string		iptrace\0401.0	AIX iptrace capture file
3150	string		iptrace\0402.0	AIX iptrace capture file
316
317#
318# Novell LANalyzer capture files.
319#
3200	leshort		0x1001		Novell LANalyzer capture file
3210	leshort		0x1007		Novell LANalyzer capture file
322
323#
324# HP-UX "nettl" capture files.
325#
3260	string		\x54\x52\x00\x64\x00	HP/UX nettl capture file
327
328#
329# RADCOM WAN/LAN Analyzer capture files.
330#
3310	string		\x42\xd2\x00\x34\x12\x66\x22\x88	RADCOM WAN/LAN Analyzer capture file
332
333#
334# NetStumbler log files.  Not really packets, per se, but about as
335# close as you can get.  These are log files from NetStumbler, a
336# Windows program, that scans for 802.11b networks.
337#
3380	string		NetS		NetStumbler log file
339>8	lelong		x		\b, %d stations found
340
341#
342# *Peek tagged capture files.
343#
3440	string		\177ver		EtherPeek/AiroPeek/OmniPeek capture file
345
346#
347# Visual Networks traffic capture files.
348#
3490	string		\x05VNF		Visual Networks traffic capture file
350
351#
352# Network Instruments Observer capture files.
353#
3540	string		ObserverPktBuffe	Network Instruments Observer capture file
355
356#
357# Files from Accellent Group's 5View products.
358#
3590	string		\xaa\xaa\xaa\xaa	5View capture file
360