1998-09-17 02:01:50 +00:00
|
|
|
/* packet-osi.c
|
|
|
|
* Routines for ISO/OSI network and transport protocol packet disassembly
|
2000-04-15 22:11:26 +00:00
|
|
|
* Main entrance point and common functions
|
1998-09-17 02:01:50 +00:00
|
|
|
*
|
2001-03-29 08:05:07 +00:00
|
|
|
* $Id: packet-osi.c,v 1.40 2001/03/29 08:05:06 guy Exp $
|
1998-09-17 02:01:50 +00:00
|
|
|
* Laurent Deniel <deniel@worldnet.fr>
|
2000-04-15 22:11:26 +00:00
|
|
|
* Ralf Schneider <Ralf.Schneider@t-online.de>
|
1998-09-17 02:01:50 +00:00
|
|
|
*
|
|
|
|
* Ethereal - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@zing.org>
|
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
# include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
|
1999-03-23 03:14:46 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
2000-03-02 07:27:05 +00:00
|
|
|
#include <ctype.h>
|
1999-03-23 03:14:46 +00:00
|
|
|
#include <glib.h>
|
1998-09-17 02:01:50 +00:00
|
|
|
#include "packet.h"
|
2000-04-17 00:32:43 +00:00
|
|
|
#include "llcsaps.h"
|
2000-11-17 06:02:21 +00:00
|
|
|
#include "aftypes.h"
|
2000-01-13 00:41:11 +00:00
|
|
|
#include "nlpid.h"
|
2000-04-15 22:11:26 +00:00
|
|
|
#include "packet-osi.h"
|
|
|
|
#include "packet-isis.h"
|
|
|
|
#include "packet-esis.h"
|
1998-09-17 02:01:50 +00:00
|
|
|
|
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
gchar *print_system_id( const u_char *buffer, int length ) {
|
|
|
|
int tmp;
|
|
|
|
u_char *cur;
|
|
|
|
static gchar str[MAX_SYSTEMID_LEN * 3 + 5]; /* Don't trust exact matching */
|
|
|
|
|
|
|
|
if ( ( length <= 0 ) || ( length > MAX_SYSTEMID_LEN ) ) {
|
|
|
|
sprintf( str, "<Invalid length of SYSTEM ID>");
|
|
|
|
return( str );
|
|
|
|
}
|
|
|
|
|
|
|
|
cur = str;
|
|
|
|
if ( ( 6 == length ) || ( 7 == length ) ) { /* Special case, print as MAC */
|
|
|
|
cur += sprintf(str, "[%02x:%02x:%02x_%02x:%02x:%02x]", buffer[0], buffer[1],
|
|
|
|
buffer[2], buffer[3], buffer[4], buffer[5] );
|
|
|
|
if ( 7 == length ) {
|
|
|
|
sprintf( cur, "-%02x", buffer[6] );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
}
|
2000-03-02 07:27:05 +00:00
|
|
|
else {
|
2000-04-15 22:11:26 +00:00
|
|
|
tmp = 0;
|
|
|
|
while ( tmp < length / 4 ) { /* 16 / 4 == 4 > four Octets left to print */
|
|
|
|
cur += sprintf( str, "%02x%02x%02x%02x.", buffer[tmp++], buffer[tmp++],
|
|
|
|
buffer[tmp++], buffer[tmp++] );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
if ( 1 == tmp ) { /* Special case for Designated IS */
|
|
|
|
sprintf( --cur, "-%02x", buffer[tmp] );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
else {
|
|
|
|
for ( ; tmp < length; ) { /* print the rest without dot */
|
|
|
|
cur += sprintf( cur, "%02x", buffer[tmp++] );
|
2000-03-02 07:27:05 +00:00
|
|
|
}
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
return( str );
|
|
|
|
}
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
gchar *print_area(const u_char *buffer, int length)
|
1998-09-17 02:01:50 +00:00
|
|
|
{
|
2000-04-15 22:11:26 +00:00
|
|
|
/* to do : all real area decoding now: NET is assumed if id len is 1 more byte
|
|
|
|
* and take away all these stupid resource consuming local statics
|
|
|
|
*/
|
|
|
|
|
|
|
|
static gchar str[MAX_AREA_LEN * 3 + 20]; /* reserve space for nice layout */
|
|
|
|
gchar *cur;
|
|
|
|
u_int tmp = 0;
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
cur = str;
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
if (length <= 0 || length > MAX_AREA_LEN) {
|
|
|
|
sprintf( str, "<Invalid length of AREA>");
|
|
|
|
return( str );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
|
|
|
|
if ( ( ( NSAP_IDI_ISODCC == *buffer )
|
|
|
|
|| ( NSAP_IDI_GOSIP2 == *buffer )
|
|
|
|
)
|
|
|
|
&&
|
|
|
|
( ( RFC1237_FULLAREA_LEN == length )
|
|
|
|
|| ( RFC1237_FULLAREA_LEN + 1 == length )
|
|
|
|
)
|
|
|
|
) { /* AFI is good and length is long enough */
|
|
|
|
|
|
|
|
if ( length > RFC1237_FULLAREA_LEN + 1 ) { /* Special Case Designated IS */
|
|
|
|
sprintf( str, "<Invalid length of AREA for DCC / GOSIP AFI>");
|
|
|
|
return( str );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
|
|
|
|
cur += sprintf( cur, "[%02x|%02x:%02x][%02x|%02x:%02x:%02x|%02x:%02x]",
|
|
|
|
buffer[0], buffer[1], buffer[2], buffer[3], buffer[4],
|
|
|
|
buffer[5], buffer[6], buffer[7], buffer[8] );
|
|
|
|
cur += sprintf( cur, "[%02x:%02x|%02x:%02x]",
|
|
|
|
buffer[9], buffer[10], buffer[11], buffer[12] );
|
|
|
|
if ( RFC1237_FULLAREA_LEN + 1 == length ) {
|
|
|
|
sprintf( cur, "-[%02x]", buffer[20] );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
return str;
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
else { /* print standard format */
|
|
|
|
if ( 4 < length ) {
|
|
|
|
while ( tmp < length / 4 ) { /* 16/4==4 four Octets left to print */
|
|
|
|
cur += sprintf( str, "%02x%02x%02x%02x.", buffer[tmp++], buffer[tmp++],
|
|
|
|
buffer[tmp++], buffer[tmp++] );
|
|
|
|
}
|
|
|
|
if ( 1 == tmp ) { /* Special case for Designated IS */
|
|
|
|
sprintf( --cur, "-%02x", buffer[tmp] );
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
for ( ; tmp < length; ) { /* print the rest without dot */
|
|
|
|
cur += sprintf( cur, "%02x", buffer[tmp++] );
|
|
|
|
}
|
|
|
|
}
|
2000-04-15 06:47:43 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
return( str );
|
2000-04-15 06:47:43 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
} /* print_area */
|
2000-03-02 07:27:05 +00:00
|
|
|
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
gchar *print_nsap_net( const u_char *buffer, int length)
|
1998-09-17 02:01:50 +00:00
|
|
|
{
|
2000-04-15 22:11:26 +00:00
|
|
|
/* to do : NSAP / NET decoding */
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
static gchar str[MAX_NSAP_LEN * 3 + 50]; /* reserve space for nice layout */
|
|
|
|
gchar *cur;
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
cur = str;
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
if ( (length <= 0 ) || ( length > MAX_NSAP_LEN ) ) {
|
|
|
|
sprintf( str, "<Invalid length of NSAP>");
|
|
|
|
return( str );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
if ( ( length == RFC1237_NSAP_LEN ) || ( length == RFC1237_NSAP_LEN + 1 ) ) {
|
|
|
|
cur += sprintf( cur, "%s", print_area( buffer, RFC1237_FULLAREA_LEN ) );
|
|
|
|
cur += sprintf( cur, "%s", print_system_id( buffer + RFC1237_FULLAREA_LEN,
|
|
|
|
RFC1237_SYSTEMID_LEN ) );
|
|
|
|
cur += sprintf( cur, "[%02x]",
|
|
|
|
buffer[ RFC1237_FULLAREA_LEN + RFC1237_SYSTEMID_LEN ] );
|
|
|
|
if ( length == RFC1237_NSAP_LEN + 1 ) {
|
|
|
|
cur += sprintf( cur, "-%02x", buffer[ length -1 ] );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
return ( str );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
else { /* probably format as standard */
|
|
|
|
return( print_area( buffer, length ) );
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
} /* print_nsap */
|
1998-09-17 02:01:50 +00:00
|
|
|
|
|
|
|
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
gchar *calc_checksum( tvbuff_t *tvb, int offset, u_int len, u_int checksum) {
|
2000-04-15 22:11:26 +00:00
|
|
|
u_int calc_sum = 0;
|
|
|
|
u_int count = 0;
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
const gchar *buffer;
|
|
|
|
guint available_len;
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
if ( 0 == checksum )
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
return( "Not Used" );
|
1998-09-17 02:01:50 +00:00
|
|
|
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
available_len = tvb_length_remaining( tvb, offset );
|
|
|
|
if ( available_len < len )
|
|
|
|
return( "Not checkable - not all of packet was captured" );
|
|
|
|
|
|
|
|
buffer = tvb_get_ptr( tvb, offset, len );
|
2000-04-15 22:11:26 +00:00
|
|
|
for ( count = 0; count < len; count++ ) {
|
|
|
|
calc_sum += (u_int) buffer[count];
|
1998-09-17 02:01:50 +00:00
|
|
|
}
|
2000-04-15 22:11:26 +00:00
|
|
|
calc_sum %= 255; /* modulo 255 divison */
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
if ( 0 == calc_sum )
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
return( "Is good" );
|
2000-04-15 22:11:26 +00:00
|
|
|
else
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
return( "Is wrong" ); /* XXX - what should the checksum be? */
|
2000-04-15 22:11:26 +00:00
|
|
|
}
|
1998-09-17 02:01:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* main entry point */
|
|
|
|
|
2000-01-13 00:41:11 +00:00
|
|
|
const value_string nlpid_vals[] = {
|
|
|
|
{ NLPID_NULL, "NULL" },
|
2000-01-30 05:50:02 +00:00
|
|
|
{ NLPID_T_70, "T.70" },
|
|
|
|
{ NLPID_X_633, "X.633" },
|
|
|
|
{ NLPID_Q_931, "Q.931" },
|
|
|
|
{ NLPID_Q_2931, "Q.2931" },
|
|
|
|
{ NLPID_Q_2119, "Q.2119" },
|
2000-01-13 00:41:11 +00:00
|
|
|
{ NLPID_SNAP, "SNAP" },
|
|
|
|
{ NLPID_ISO8473_CLNP, "CLNP" },
|
|
|
|
{ NLPID_ISO9542_ESIS, "ESIS" },
|
|
|
|
{ NLPID_ISO10589_ISIS, "ISIS" },
|
2000-04-15 22:11:26 +00:00
|
|
|
{ NLPID_ISO10747_IDRP, "IDRP" },
|
2000-01-13 00:41:11 +00:00
|
|
|
{ NLPID_ISO9542X25_ESIS, "ESIS (X.25)" },
|
2000-01-30 05:50:02 +00:00
|
|
|
{ NLPID_ISO10030, "ISO 10030" },
|
|
|
|
{ NLPID_ISO11577, "ISO 11577" },
|
2001-03-29 08:05:07 +00:00
|
|
|
{ NLPID_COMPRESSED, "Data compression protocol" },
|
2000-01-13 00:41:11 +00:00
|
|
|
{ NLPID_IP, "IP" },
|
2000-01-13 05:41:24 +00:00
|
|
|
{ NLPID_PPP, "PPP" },
|
2000-01-13 00:41:11 +00:00
|
|
|
{ 0, NULL },
|
|
|
|
};
|
|
|
|
|
2000-04-17 01:36:31 +00:00
|
|
|
static dissector_table_t subdissector_table;
|
|
|
|
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
void dissect_osi(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
|
1998-09-17 02:01:50 +00:00
|
|
|
{
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
guint8 nlpid;
|
|
|
|
|
|
|
|
pinfo->current_proto = "OSI";
|
|
|
|
|
|
|
|
nlpid = tvb_get_guint8(tvb, 0);
|
|
|
|
|
2000-04-17 01:36:31 +00:00
|
|
|
/* do lookup with the subdissector table */
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
if (dissector_try_port(subdissector_table, nlpid, tvb, pinfo, tree))
|
2000-04-17 01:36:31 +00:00
|
|
|
return;
|
|
|
|
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
switch (nlpid) {
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-04-15 22:11:26 +00:00
|
|
|
/* ESIS (X.25) is not currently decoded */
|
1998-09-17 02:01:50 +00:00
|
|
|
|
2000-01-13 00:41:11 +00:00
|
|
|
case NLPID_ISO9542X25_ESIS:
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
if (check_col(pinfo->fd, COL_PROTOCOL)) {
|
2000-11-19 08:54:37 +00:00
|
|
|
col_set_str(pinfo->fd, COL_PROTOCOL, "ESIS (X.25)");
|
1999-09-18 15:51:31 +00:00
|
|
|
}
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
dissect_data(tvb, 0, pinfo, tree);
|
1998-09-17 02:01:50 +00:00
|
|
|
break;
|
2000-04-15 22:11:26 +00:00
|
|
|
case NLPID_ISO10747_IDRP:
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
if (check_col(pinfo->fd, COL_PROTOCOL)) {
|
2000-11-19 08:54:37 +00:00
|
|
|
col_set_str(pinfo->fd, COL_PROTOCOL, "IDRP");
|
2000-04-15 22:11:26 +00:00
|
|
|
}
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
dissect_data(tvb, 0, pinfo, tree);
|
2000-04-15 22:11:26 +00:00
|
|
|
break;
|
1998-09-17 02:01:50 +00:00
|
|
|
default:
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
if (check_col(pinfo->fd, COL_PROTOCOL)) {
|
2000-11-19 08:54:37 +00:00
|
|
|
col_set_str(pinfo->fd, COL_PROTOCOL, "ISO");
|
1999-09-18 15:51:31 +00:00
|
|
|
}
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
if (check_col(pinfo->fd, COL_INFO)) {
|
|
|
|
col_add_fstr(pinfo->fd, COL_INFO, "Unknown ISO protocol (%02x)", nlpid);
|
1999-09-18 15:51:31 +00:00
|
|
|
}
|
Tvbuffify the IP, ICMP, TCP, UDP, OSI CLNP, OSI COTP, OSI CLTP, and OSI
ESIS dissectors.
Register the IP dissector and have dissectors that call it directly
(rather than through a port table) call it through a handle.
Add a routine "tvb_set_reported_length()" which a dissector can use if
it was handed a tvbuff that contains more data than is actually in its
part of the packet - for example, handing a padded Ethernet frame to IP;
the routine sets the reported length of the tvbuff (and also adjusts the
actual length, as appropriate). Then use it in IP.
Given that, "ethertype()" can determine how much of the Ethernet frame
was actually part of an IP datagram (and can do the same for other
protocols under Ethernet that use "tvb_set_reported_length()"; have it
return the actual length, and have "dissect_eth()" and "dissect_vlan()"
use that to mark trailer data in Ethernet II frames as well as in 802.3
frames.
svn path=/trunk/; revision=2658
2000-11-18 10:38:33 +00:00
|
|
|
dissect_data(tvb, 0, pinfo, tree);
|
1998-09-17 02:01:50 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
} /* dissect_osi */
|
2000-04-17 00:32:43 +00:00
|
|
|
|
2000-04-17 01:36:31 +00:00
|
|
|
void
|
|
|
|
proto_register_osi(void)
|
|
|
|
{
|
|
|
|
/* There's no "OSI" protocol *per se*, but we do register a
|
|
|
|
dissector table so various protocols running at the
|
|
|
|
network layer can register themselves. */
|
|
|
|
subdissector_table = register_dissector_table("osinl");
|
|
|
|
}
|
|
|
|
|
2000-04-17 00:32:43 +00:00
|
|
|
void
|
|
|
|
proto_reg_handoff_osi(void)
|
|
|
|
{
|
2001-01-09 06:32:10 +00:00
|
|
|
dissector_add("llc.dsap", SAP_OSINL, dissect_osi, -1);
|
|
|
|
dissector_add("null.type", BSD_AF_ISO, dissect_osi, -1);
|
2000-04-17 00:32:43 +00:00
|
|
|
}
|