David Howells | 651350d | 2007-04-26 15:50:17 -0700 | [diff] [blame] | 1 | /* RxRPC kernel service interface definitions |
David Howells | 17926a7 | 2007-04-26 15:48:28 -0700 | [diff] [blame] | 2 | * |
David Howells | 651350d | 2007-04-26 15:50:17 -0700 | [diff] [blame] | 3 | * Copyright (C) 2007 Red Hat, Inc. All Rights Reserved. |
David Howells | 17926a7 | 2007-04-26 15:48:28 -0700 | [diff] [blame] | 4 | * Written by David Howells (dhowells@redhat.com) |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or |
| 7 | * modify it under the terms of the GNU General Public License |
| 8 | * as published by the Free Software Foundation; either version |
| 9 | * 2 of the License, or (at your option) any later version. |
| 10 | */ |
| 11 | |
| 12 | #ifndef _NET_RXRPC_H |
| 13 | #define _NET_RXRPC_H |
| 14 | |
David Howells | 8e688d9 | 2016-04-07 17:23:16 +0100 | [diff] [blame] | 15 | #include <linux/skbuff.h> |
David Howells | 17926a7 | 2007-04-26 15:48:28 -0700 | [diff] [blame] | 16 | #include <linux/rxrpc.h> |
| 17 | |
David Howells | 651350d | 2007-04-26 15:50:17 -0700 | [diff] [blame] | 18 | struct rxrpc_call; |
| 19 | |
| 20 | /* |
| 21 | * the mark applied to socket buffers that may be intercepted |
| 22 | */ |
David Howells | dc44b3a | 2016-04-07 17:23:30 +0100 | [diff] [blame] | 23 | enum rxrpc_skb_mark { |
David Howells | 651350d | 2007-04-26 15:50:17 -0700 | [diff] [blame] | 24 | RXRPC_SKB_MARK_DATA, /* data message */ |
| 25 | RXRPC_SKB_MARK_FINAL_ACK, /* final ACK received message */ |
| 26 | RXRPC_SKB_MARK_BUSY, /* server busy message */ |
| 27 | RXRPC_SKB_MARK_REMOTE_ABORT, /* remote abort message */ |
David Howells | dc44b3a | 2016-04-07 17:23:30 +0100 | [diff] [blame] | 28 | RXRPC_SKB_MARK_LOCAL_ABORT, /* local abort message */ |
David Howells | 651350d | 2007-04-26 15:50:17 -0700 | [diff] [blame] | 29 | RXRPC_SKB_MARK_NET_ERROR, /* network error message */ |
| 30 | RXRPC_SKB_MARK_LOCAL_ERROR, /* local error message */ |
| 31 | RXRPC_SKB_MARK_NEW_CALL, /* local error message */ |
| 32 | }; |
| 33 | |
| 34 | typedef void (*rxrpc_interceptor_t)(struct sock *, unsigned long, |
| 35 | struct sk_buff *); |
Joe Perches | cd2cf63 | 2013-07-31 17:31:34 -0700 | [diff] [blame] | 36 | void rxrpc_kernel_intercept_rx_messages(struct socket *, rxrpc_interceptor_t); |
| 37 | struct rxrpc_call *rxrpc_kernel_begin_call(struct socket *, |
| 38 | struct sockaddr_rxrpc *, |
| 39 | struct key *, |
| 40 | unsigned long, |
| 41 | gfp_t); |
| 42 | int rxrpc_kernel_send_data(struct rxrpc_call *, struct msghdr *, size_t); |
David Howells | 372ee16 | 2016-08-03 14:11:40 +0100 | [diff] [blame] | 43 | void rxrpc_kernel_data_consumed(struct rxrpc_call *, struct sk_buff *); |
Joe Perches | cd2cf63 | 2013-07-31 17:31:34 -0700 | [diff] [blame] | 44 | void rxrpc_kernel_abort_call(struct rxrpc_call *, u32); |
| 45 | void rxrpc_kernel_end_call(struct rxrpc_call *); |
| 46 | bool rxrpc_kernel_is_data_last(struct sk_buff *); |
| 47 | u32 rxrpc_kernel_get_abort_code(struct sk_buff *); |
| 48 | int rxrpc_kernel_get_error_number(struct sk_buff *); |
Joe Perches | cd2cf63 | 2013-07-31 17:31:34 -0700 | [diff] [blame] | 49 | void rxrpc_kernel_free_skb(struct sk_buff *); |
| 50 | struct rxrpc_call *rxrpc_kernel_accept_call(struct socket *, unsigned long); |
| 51 | int rxrpc_kernel_reject_call(struct socket *); |
David Howells | 8324f0b | 2016-08-30 09:49:29 +0100 | [diff] [blame^] | 52 | void rxrpc_kernel_get_peer(struct socket *, struct rxrpc_call *, |
| 53 | struct sockaddr_rxrpc *); |
David Howells | 651350d | 2007-04-26 15:50:17 -0700 | [diff] [blame] | 54 | |
David Howells | 17926a7 | 2007-04-26 15:48:28 -0700 | [diff] [blame] | 55 | #endif /* _NET_RXRPC_H */ |