2 * Copyright (c) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996,
3 * 1997, 2000, 2011, 2012
4 * The Regents of the University of California. All rights reserved.
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that: (1) source code distributions
8 * retain the above copyright notice and this paragraph in its entirety, (2)
9 * distributions including binary code include the above copyright notice and
10 * this paragraph in its entirety in the documentation or other materials
11 * provided with the distribution, and (3) all advertising materials mentioning
12 * features or use of this software display the following acknowledgement:
13 * ``This product includes software developed by the University of California,
14 * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
15 * the University nor the names of its contributors may be used to endorse
16 * or promote products derived from this software without specific prior
18 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
19 * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
20 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
23 * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved.
26 /* \summary: IP-over-InfiniBand (IPoIB) printer */
32 #include <netdissect-stdinc.h>
37 #include "netdissect.h"
39 #include "addrtoname.h"
42 extern const struct tok ethertype_values
[];
44 #define IPOIB_HDRLEN 44
47 ipoib_hdr_print(netdissect_options
*ndo
, const u_char
*bp
, u_int length
)
51 ether_type
= GET_BE_U_2(bp
+ 40);
52 if (!ndo
->ndo_qflag
) {
53 ND_PRINT(", ethertype %s (0x%04x)",
54 tok2str(ethertype_values
,"Unknown", ether_type
),
57 ND_PRINT(", ethertype %s",
58 tok2str(ethertype_values
,"Unknown", ether_type
));
61 ND_PRINT(", length %u: ", length
);
65 * Print an InfiniBand frame.
66 * This might be encapsulated within another frame; we might be passed
67 * a pointer to a function that can print header information for that
68 * frame's protocol, and an argument to pass to that function.
71 ipoib_print(netdissect_options
*ndo
, const u_char
*p
, u_int length
, u_int caplen
,
72 void (*print_encap_header
)(const u_char
*), const u_char
*encap_header_arg
)
74 const u_char
*orig_hdr
= p
;
78 if (caplen
< IPOIB_HDRLEN
|| length
< IPOIB_HDRLEN
) {
85 if (print_encap_header
!= NULL
)
86 (*print_encap_header
)(encap_header_arg
);
87 ipoib_hdr_print(ndo
, p
, length
);
91 length
-= IPOIB_HDRLEN
;
92 caplen
-= IPOIB_HDRLEN
;
93 ether_type
= GET_BE_U_2(p
+ 40);
96 if (ethertype_print(ndo
, ether_type
, p
, length
, caplen
, NULL
, NULL
) == 0) {
97 /* ether_type not known, print raw packet */
98 if (!ndo
->ndo_eflag
) {
99 if (print_encap_header
!= NULL
)
100 (*print_encap_header
)(encap_header_arg
);
101 ipoib_hdr_print(ndo
, orig_hdr
, orig_length
);
104 if (!ndo
->ndo_suppress_default_print
)
105 ND_DEFAULTPRINT(p
, caplen
);
110 * This is the top level routine of the printer. 'p' points
111 * to the ether header of the packet, 'h->ts' is the timestamp,
112 * 'h->len' is the length of the packet off the wire, and 'h->caplen'
113 * is the number of bytes actually captured.
116 ipoib_if_print(netdissect_options
*ndo
, const struct pcap_pkthdr
*h
, const u_char
*p
)
118 ndo
->ndo_protocol
= "ipoib";
119 ipoib_print(ndo
, p
, h
->len
, h
->caplen
, NULL
, NULL
);
121 return (IPOIB_HDRLEN
);