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"
36 #include "netdissect.h"
38 #include "addrtoname.h"
41 extern const struct tok ethertype_values
[];
43 #define IPOIB_HDRLEN 44
46 ipoib_hdr_print(netdissect_options
*ndo
, const u_char
*bp
, u_int length
)
50 ether_type
= GET_BE_U_2(bp
+ 40);
51 if (!ndo
->ndo_qflag
) {
52 ND_PRINT(", ethertype %s (0x%04x)",
53 tok2str(ethertype_values
,"Unknown", ether_type
),
56 ND_PRINT(", ethertype %s",
57 tok2str(ethertype_values
,"Unknown", ether_type
));
60 ND_PRINT(", length %u: ", length
);
64 * Print an InfiniBand frame.
65 * This might be encapsulated within another frame; we might be passed
66 * a pointer to a function that can print header information for that
67 * frame's protocol, and an argument to pass to that function.
70 ipoib_print(netdissect_options
*ndo
, const u_char
*p
, u_int length
, u_int caplen
,
71 void (*print_encap_header
)(const u_char
*), const u_char
*encap_header_arg
)
73 const u_char
*orig_hdr
= p
;
77 if (caplen
< IPOIB_HDRLEN
) {
79 ndo
->ndo_ll_hdr_len
+= caplen
;
83 if (length
< IPOIB_HDRLEN
) {
85 ndo
->ndo_ll_hdr_len
+= length
;
90 nd_print_protocol_caps(ndo
);
91 if (print_encap_header
!= NULL
)
92 (*print_encap_header
)(encap_header_arg
);
93 ipoib_hdr_print(ndo
, p
, length
);
97 ndo
->ndo_ll_hdr_len
+= IPOIB_HDRLEN
;
98 length
-= IPOIB_HDRLEN
;
99 caplen
-= IPOIB_HDRLEN
;
100 ether_type
= GET_BE_U_2(p
+ 40);
103 if (ethertype_print(ndo
, ether_type
, p
, length
, caplen
, NULL
, NULL
) == 0) {
104 /* ether_type not known, print raw packet */
105 if (!ndo
->ndo_eflag
) {
106 if (print_encap_header
!= NULL
)
107 (*print_encap_header
)(encap_header_arg
);
108 ipoib_hdr_print(ndo
, orig_hdr
, orig_length
);
111 if (!ndo
->ndo_suppress_default_print
)
112 ND_DEFAULTPRINT(p
, caplen
);
117 * This is the top level routine of the printer. 'p' points
118 * to the ether header of the packet, 'h->ts' is the timestamp,
119 * 'h->len' is the length of the packet off the wire, and 'h->caplen'
120 * is the number of bytes actually captured.
123 ipoib_if_print(netdissect_options
*ndo
, const struct pcap_pkthdr
*h
, const u_char
*p
)
125 ndo
->ndo_protocol
= "ipoib";
126 ipoib_print(ndo
, p
, h
->len
, h
->caplen
, NULL
, NULL
);