The file of interest for adding protocols to the ProtoSpec protocol hierarchy is PSpecs.xml. This file is located in a language specific folder (by language ID, for instance the 1033 folder for the English version) in the program's installation folder--the default location is C:\Program Files\WildPackets\[product].
Before opening or modifying these files, it is recommended that you make a backup copy of the PSpecs.xml file, in case your modified copy becomes unusable by your Peek application.
In order to add a protocol to the ProtoSpec hierarchy, you will need to add specifically formatted information to the PSpecs.xml file. This PSpecs.xml file must remain in the language specific folder depending on your system's language settings.
Once you have made a backup copy of the PSpecs.xml file, familiarize yourself with the format of a ProtoSpec item by examining the XML file.
<PSpec Name="IEEE 802.3"> <PSpecID>1</PSpecID> <LName>IEEE 802.3 CSMA/CD Ethernet</LName> <SName>802.3</SName> <Desc>802.3 is a comprehensive standard for Local Area Networks employing the Carrier Sense Multiple Access with Collision Detection (CSMA/CD) access method. Under the International Standards Organization (ISO) the 10 megabits per second transmission speed is specified by ISO/DIS 8802/3. The definition of Ethernet under 802.3 supersedes the previous Ethernet standard known as Ethernet Type 2. In terms of data bytes in the protocol stack, 802.3 uses bytes 13 and 14 as a length field, whereas the earlier standard used these bytes as a protocol definition field.</Desc> <Color>color_1</Color> <CondExp><![CDATA[ MLD16[12] <= 1500 ]]></CondExp> <NextLayer> <Exp><![CDATA[ 14 ]]></Exp> </NextLayer> <Link Name="802.2 LLC"/> </PSpec>
Each PSpec element block is made up of the following items:
Expressions are C style mathematical expressions geared toward analyzing packets. In addition to C style mathematical operators (+, -, <, etc.), there are special operations that examine packet data:
The ProtoSpec tree is generated from the XML by walking the tree from each root element and adding each element, element's children, and the children of any links included in any element. A 32-bit ProtoSpec instance ID is generated for each element in the tree; the lower 16 bits consist of the PSpecID value, and the upper 16 bits are an instance counter, incremented for each time an element is included in the tree. All ProtoSpec IDs passed to plugins are 32 bit instance IDs. Plugins generally examine the lower 16 bits to determine the actual protocol, and list the 16 bit PSpecIDs in the Supported ProtoSpecs array. The 32 bit ID is used for determining the parent protocol list, determining the header and payload locations for each protocol, etc.
WildPackets, Inc.
1340 Treat Blvd., Suite 500
Walnut Creek, CA 94597 USA
(925) 937-3200
http://www.wildpackets.com/
sdkhelp@wildpackets.com
Copyright © 2001-2003 WildPackets, Inc.
All rights reserved.