136 lines
2.9 KiB
C
136 lines
2.9 KiB
C
|
/****************************************************************************
|
||
|
****************************************************************************
|
||
|
***
|
||
|
*** This header was automatically generated from a Linux kernel header
|
||
|
*** of the same name, to make information necessary for userspace to
|
||
|
*** call into the kernel available to libc. It contains only constants,
|
||
|
*** structures, and macros generated from the original header, and thus,
|
||
|
*** contains no copyrightable information.
|
||
|
***
|
||
|
****************************************************************************
|
||
|
****************************************************************************/
|
||
|
#ifndef _LINUX_DCCP_H
|
||
|
#define _LINUX_DCCP_H
|
||
|
|
||
|
#include <linux/types.h>
|
||
|
#include <asm/byteorder.h>
|
||
|
|
||
|
struct dccp_hdr {
|
||
|
__be16 dccph_sport,
|
||
|
dccph_dport;
|
||
|
__u8 dccph_doff;
|
||
|
#ifdef __LITTLE_ENDIAN_BITFIELD
|
||
|
__u8 dccph_cscov:4,
|
||
|
dccph_ccval:4;
|
||
|
#elif defined(__BIG_ENDIAN_BITFIELD)
|
||
|
__u8 dccph_ccval:4,
|
||
|
dccph_cscov:4;
|
||
|
#else
|
||
|
#error "Adjust your <asm/byteorder.h> defines"
|
||
|
#endif
|
||
|
__u16 dccph_checksum;
|
||
|
#ifdef __LITTLE_ENDIAN_BITFIELD
|
||
|
__u8 dccph_x:1,
|
||
|
dccph_type:4,
|
||
|
dccph_reserved:3;
|
||
|
#elif defined(__BIG_ENDIAN_BITFIELD)
|
||
|
__u8 dccph_reserved:3,
|
||
|
dccph_type:4,
|
||
|
dccph_x:1;
|
||
|
#else
|
||
|
#error "Adjust your <asm/byteorder.h> defines"
|
||
|
#endif
|
||
|
__u8 dccph_seq2;
|
||
|
__be16 dccph_seq;
|
||
|
};
|
||
|
|
||
|
struct dccp_hdr_ext {
|
||
|
__be32 dccph_seq_low;
|
||
|
};
|
||
|
|
||
|
struct dccp_hdr_request {
|
||
|
__be32 dccph_req_service;
|
||
|
};
|
||
|
|
||
|
struct dccp_hdr_ack_bits {
|
||
|
__be16 dccph_reserved1;
|
||
|
__be16 dccph_ack_nr_high;
|
||
|
__be32 dccph_ack_nr_low;
|
||
|
};
|
||
|
|
||
|
struct dccp_hdr_response {
|
||
|
struct dccp_hdr_ack_bits dccph_resp_ack;
|
||
|
__be32 dccph_resp_service;
|
||
|
};
|
||
|
|
||
|
struct dccp_hdr_reset {
|
||
|
struct dccp_hdr_ack_bits dccph_reset_ack;
|
||
|
__u8 dccph_reset_code,
|
||
|
dccph_reset_data[3];
|
||
|
};
|
||
|
|
||
|
enum dccp_pkt_type {
|
||
|
DCCP_PKT_REQUEST = 0,
|
||
|
DCCP_PKT_RESPONSE,
|
||
|
DCCP_PKT_DATA,
|
||
|
DCCP_PKT_ACK,
|
||
|
DCCP_PKT_DATAACK,
|
||
|
DCCP_PKT_CLOSEREQ,
|
||
|
DCCP_PKT_CLOSE,
|
||
|
DCCP_PKT_RESET,
|
||
|
DCCP_PKT_SYNC,
|
||
|
DCCP_PKT_SYNCACK,
|
||
|
DCCP_PKT_INVALID,
|
||
|
};
|
||
|
|
||
|
#define DCCP_NR_PKT_TYPES DCCP_PKT_INVALID
|
||
|
|
||
|
enum {
|
||
|
DCCPO_PADDING = 0,
|
||
|
DCCPO_MANDATORY = 1,
|
||
|
DCCPO_MIN_RESERVED = 3,
|
||
|
DCCPO_MAX_RESERVED = 31,
|
||
|
DCCPO_CHANGE_L = 32,
|
||
|
DCCPO_CONFIRM_L = 33,
|
||
|
DCCPO_CHANGE_R = 34,
|
||
|
DCCPO_CONFIRM_R = 35,
|
||
|
DCCPO_NDP_COUNT = 37,
|
||
|
DCCPO_ACK_VECTOR_0 = 38,
|
||
|
DCCPO_ACK_VECTOR_1 = 39,
|
||
|
DCCPO_TIMESTAMP = 41,
|
||
|
DCCPO_TIMESTAMP_ECHO = 42,
|
||
|
DCCPO_ELAPSED_TIME = 43,
|
||
|
DCCPO_MAX = 45,
|
||
|
DCCPO_MIN_CCID_SPECIFIC = 128,
|
||
|
DCCPO_MAX_CCID_SPECIFIC = 255,
|
||
|
};
|
||
|
|
||
|
enum {
|
||
|
DCCPF_RESERVED = 0,
|
||
|
DCCPF_CCID = 1,
|
||
|
DCCPF_SEQUENCE_WINDOW = 3,
|
||
|
DCCPF_ACK_RATIO = 5,
|
||
|
DCCPF_SEND_ACK_VECTOR = 6,
|
||
|
DCCPF_SEND_NDP_COUNT = 7,
|
||
|
|
||
|
DCCPF_MIN_CCID_SPECIFIC = 128,
|
||
|
DCCPF_MAX_CCID_SPECIFIC = 255,
|
||
|
};
|
||
|
|
||
|
struct dccp_so_feat {
|
||
|
__u8 dccpsf_feat;
|
||
|
__u8 *dccpsf_val;
|
||
|
__u8 dccpsf_len;
|
||
|
};
|
||
|
|
||
|
#define DCCP_SOCKOPT_PACKET_SIZE 1
|
||
|
#define DCCP_SOCKOPT_SERVICE 2
|
||
|
#define DCCP_SOCKOPT_CHANGE_L 3
|
||
|
#define DCCP_SOCKOPT_CHANGE_R 4
|
||
|
#define DCCP_SOCKOPT_CCID_RX_INFO 128
|
||
|
#define DCCP_SOCKOPT_CCID_TX_INFO 192
|
||
|
|
||
|
#define DCCP_SERVICE_LIST_MAX_LEN 32
|
||
|
|
||
|
#endif
|