1
2
3
4
5
6
7
8
9
10
11
12#ifndef _NET_RXRPC_H
13#define _NET_RXRPC_H
14
15#include <linux/rxrpc.h>
16
17struct rxrpc_call;
18
19
20
21
22enum {
23 RXRPC_SKB_MARK_DATA,
24 RXRPC_SKB_MARK_FINAL_ACK,
25 RXRPC_SKB_MARK_BUSY,
26 RXRPC_SKB_MARK_REMOTE_ABORT,
27 RXRPC_SKB_MARK_NET_ERROR,
28 RXRPC_SKB_MARK_LOCAL_ERROR,
29 RXRPC_SKB_MARK_NEW_CALL,
30};
31
32typedef void (*rxrpc_interceptor_t)(struct sock *, unsigned long,
33 struct sk_buff *);
34void rxrpc_kernel_intercept_rx_messages(struct socket *, rxrpc_interceptor_t);
35struct rxrpc_call *rxrpc_kernel_begin_call(struct socket *,
36 struct sockaddr_rxrpc *,
37 struct key *,
38 unsigned long,
39 gfp_t);
40int rxrpc_kernel_send_data(struct rxrpc_call *, struct msghdr *, size_t);
41void rxrpc_kernel_abort_call(struct rxrpc_call *, u32);
42void rxrpc_kernel_end_call(struct rxrpc_call *);
43bool rxrpc_kernel_is_data_last(struct sk_buff *);
44u32 rxrpc_kernel_get_abort_code(struct sk_buff *);
45int rxrpc_kernel_get_error_number(struct sk_buff *);
46void rxrpc_kernel_data_delivered(struct sk_buff *);
47void rxrpc_kernel_free_skb(struct sk_buff *);
48struct rxrpc_call *rxrpc_kernel_accept_call(struct socket *, unsigned long);
49int rxrpc_kernel_reject_call(struct socket *);
50
51#endif
52