1 /* @(#) $Header: /tcpdump/master/tcpdump/dccp.h,v 1.5 2006-11-02 09:05:23 hannes Exp $ (LBL) */
3 * Copyright (C) Arnaldo Carvalho de Melo 2004
4 * Copyright (C) Ian McDonald 2005 <iam4@cs.waikato.ac.nz>
5 * Copyright (C) Yoshifumi Nishida 2005
7 * This software may be distributed either under the terms of the
8 * BSD-style license that accompanies tcpdump or the GNU GPL version 2
15 * struct dccp_hdr - generic part of DCCP packet header
17 * @dccph_sport - Relevant port on the endpoint that sent this packet
18 * @dccph_dport - Relevant port on the other endpoint
19 * @dccph_doff - Data Offset from the start of the DCCP header, in 32-bit words
20 * @dccph_ccval - Used by the HC-Sender CCID
21 * @dccph_cscov - Parts of the packet that are covered by the Checksum field
22 * @dccph_checksum - Internet checksum, depends on dccph_cscov
23 * @dccph_x - 0 = 24 bit sequence number, 1 = 48
24 * @dccph_type - packet type, see DCCP_PKT_ prefixed macros
25 * @dccph_seq - sequence number high or low order 24 bits, depends on dccph_x
28 u_int16_t dccph_sport
,
31 u_int8_t dccph_ccval_cscov
;
32 u_int16_t dccph_checksum
;
39 #define DCCPH_CCVAL(dh) (((dh)->dccph_ccval_cscov >> 4) & 0xF)
40 #define DCCPH_CSCOV(dh) (((dh)->dccph_ccval_cscov) & 0xF)
42 #define DCCPH_X(dh) ((dh)->dccph_xtrs.dccph_xtr & 1)
43 #define DCCPH_TYPE(dh) (((dh)->dccph_xtrs.dccph_xtr >> 1) & 0xF)
44 #define DCCPH_SEQ(dh) (((dh)->dccph_xtrs.dccph_seq) >> 8)
47 * struct dccp_hdr_ext - the low bits of a 48 bit seq packet
49 * @dccph_seq_low - low 24 bits of a 48 bit seq packet
52 u_int32_t dccph_seq_low
;
56 * struct dccp_hdr_request - Conection initiation request header
58 * @dccph_req_service - Service to which the client app wants to connect
60 struct dccp_hdr_request
{
61 u_int32_t dccph_req_service
;
65 * struct dccp_hdr_ack_bits - acknowledgment bits common to most packets
67 * @dccph_resp_ack_nr_high - 48 bit ack number high order bits, contains GSR
68 * @dccph_resp_ack_nr_low - 48 bit ack number low order bits, contains GSR
70 struct dccp_hdr_ack_bits
{
72 u_int32_t dccph_ack_nr_low
;
75 #define DCCPH_ACK(dh_ack) ((dh_ack)->dccph_ra >> 8)
78 * struct dccp_hdr_response - Conection initiation response header
80 * @dccph_resp_ack_nr_high - 48 bit ack number high order bits, contains GSR
81 * @dccph_resp_ack_nr_low - 48 bit ack number low order bits, contains GSR
82 * @dccph_resp_service - Echoes the Service Code on a received DCCP-Request
84 struct dccp_hdr_response
{
85 struct dccp_hdr_ack_bits dccph_resp_ack
;
86 u_int32_t dccph_resp_service
;
90 static inline struct dccp_hdr_data
*dccp_hdr_data(struct dccp_hdr
*hdrg
)
92 const int ext
= DCCPH_X(hdrg
) ? sizeof(struct dccp_hdr_ext
) : 0;
94 return (struct dccp_hdr_data
*)(((u_char
*)hdrg
) + sizeof(hdrg
) + ext
);
99 * struct dccp_hdr_reset - Unconditionally shut down a connection
101 * @dccph_reset_service - Echoes the Service Code on a received DCCP-Request
103 struct dccp_hdr_reset
{
104 struct dccp_hdr_ack_bits dccph_reset_ack
;
105 u_int8_t dccph_reset_code
,
110 DCCP_PKT_REQUEST
= 0,
123 enum dccp_reset_codes
{
124 DCCP_RESET_CODE_UNSPECIFIED
= 0,
125 DCCP_RESET_CODE_CLOSED
,
126 DCCP_RESET_CODE_ABORTED
,
127 DCCP_RESET_CODE_NO_CONNECTION
,
128 DCCP_RESET_CODE_PACKET_ERROR
,
129 DCCP_RESET_CODE_OPTION_ERROR
,
130 DCCP_RESET_CODE_MANDATORY_ERROR
,
131 DCCP_RESET_CODE_CONNECTION_REFUSED
,
132 DCCP_RESET_CODE_BAD_SERVICE_CODE
,
133 DCCP_RESET_CODE_TOO_BUSY
,
134 DCCP_RESET_CODE_BAD_INIT_COOKIE
,
135 DCCP_RESET_CODE_AGGRESSION_PENALTY
,
136 __DCCP_RESET_CODE_LAST
139 #endif /* __DCCP_HDR__ */