1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
2 | /* RxRPC kernel service interface definitions |
3 | * |
4 | * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved. |
5 | * Written by David Howells (dhowells@redhat.com) |
6 | */ |
7 | |
8 | #ifndef _NET_RXRPC_H |
9 | #define _NET_RXRPC_H |
10 | |
11 | #include <linux/rxrpc.h> |
12 | #include <linux/ktime.h> |
13 | |
14 | struct key; |
15 | struct sock; |
16 | struct socket; |
17 | struct rxrpc_call; |
18 | enum rxrpc_abort_reason; |
19 | |
20 | enum rxrpc_interruptibility { |
21 | RXRPC_INTERRUPTIBLE, /* Call is interruptible */ |
22 | RXRPC_PREINTERRUPTIBLE, /* Call can be cancelled whilst waiting for a slot */ |
23 | RXRPC_UNINTERRUPTIBLE, /* Call should not be interruptible at all */ |
24 | }; |
25 | |
26 | /* |
27 | * Debug ID counter for tracing. |
28 | */ |
29 | extern atomic_t rxrpc_debug_id; |
30 | |
31 | typedef void (*rxrpc_notify_rx_t)(struct sock *, struct rxrpc_call *, |
32 | unsigned long); |
33 | typedef void (*rxrpc_notify_end_tx_t)(struct sock *, struct rxrpc_call *, |
34 | unsigned long); |
35 | typedef void (*rxrpc_notify_new_call_t)(struct sock *, struct rxrpc_call *, |
36 | unsigned long); |
37 | typedef void (*rxrpc_discard_new_call_t)(struct rxrpc_call *, unsigned long); |
38 | typedef void (*rxrpc_user_attach_call_t)(struct rxrpc_call *, unsigned long); |
39 | |
40 | void rxrpc_kernel_new_call_notification(struct socket *, |
41 | rxrpc_notify_new_call_t, |
42 | rxrpc_discard_new_call_t); |
43 | struct rxrpc_call *rxrpc_kernel_begin_call(struct socket *sock, |
44 | struct sockaddr_rxrpc *srx, |
45 | struct key *key, |
46 | unsigned long user_call_ID, |
47 | s64 tx_total_len, |
48 | u32 hard_timeout, |
49 | gfp_t gfp, |
50 | rxrpc_notify_rx_t notify_rx, |
51 | bool upgrade, |
52 | enum rxrpc_interruptibility interruptibility, |
53 | unsigned int debug_id); |
54 | int rxrpc_kernel_send_data(struct socket *, struct rxrpc_call *, |
55 | struct msghdr *, size_t, |
56 | rxrpc_notify_end_tx_t); |
57 | int rxrpc_kernel_recv_data(struct socket *, struct rxrpc_call *, |
58 | struct iov_iter *, size_t *, bool, u32 *, u16 *); |
59 | bool rxrpc_kernel_abort_call(struct socket *, struct rxrpc_call *, |
60 | u32, int, enum rxrpc_abort_reason); |
61 | void rxrpc_kernel_shutdown_call(struct socket *sock, struct rxrpc_call *call); |
62 | void rxrpc_kernel_put_call(struct socket *sock, struct rxrpc_call *call); |
63 | void rxrpc_kernel_get_peer(struct socket *, struct rxrpc_call *, |
64 | struct sockaddr_rxrpc *); |
65 | bool rxrpc_kernel_get_srtt(struct socket *, struct rxrpc_call *, u32 *); |
66 | int rxrpc_kernel_charge_accept(struct socket *, rxrpc_notify_rx_t, |
67 | rxrpc_user_attach_call_t, unsigned long, gfp_t, |
68 | unsigned int); |
69 | void rxrpc_kernel_set_tx_length(struct socket *, struct rxrpc_call *, s64); |
70 | bool rxrpc_kernel_check_life(const struct socket *, const struct rxrpc_call *); |
71 | u32 rxrpc_kernel_get_epoch(struct socket *, struct rxrpc_call *); |
72 | void rxrpc_kernel_set_max_life(struct socket *, struct rxrpc_call *, |
73 | unsigned long); |
74 | |
75 | int rxrpc_sock_set_min_security_level(struct sock *sk, unsigned int val); |
76 | int rxrpc_sock_set_security_keyring(struct sock *, struct key *); |
77 | |
78 | #endif /* _NET_RXRPC_H */ |
79 | |