mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-10 07:50:04 +00:00
4de48af663
Pass struct socket * to more rxrpc kernel interface functions. They should be starting from this rather than the socket pointer in the rxrpc_call struct if they need to access the socket. I have left: rxrpc_kernel_is_data_last() rxrpc_kernel_get_abort_code() rxrpc_kernel_get_error_number() rxrpc_kernel_free_skb() rxrpc_kernel_data_consumed() unmodified as they're all about to be removed (and, in any case, don't touch the socket). Signed-off-by: David Howells <dhowells@redhat.com>
60 lines
2.1 KiB
C
60 lines
2.1 KiB
C
/* RxRPC kernel service interface definitions
|
|
*
|
|
* Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
|
|
* Written by David Howells (dhowells@redhat.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _NET_RXRPC_H
|
|
#define _NET_RXRPC_H
|
|
|
|
#include <linux/skbuff.h>
|
|
#include <linux/rxrpc.h>
|
|
|
|
struct key;
|
|
struct sock;
|
|
struct socket;
|
|
struct rxrpc_call;
|
|
|
|
/*
|
|
* the mark applied to socket buffers that may be intercepted
|
|
*/
|
|
enum rxrpc_skb_mark {
|
|
RXRPC_SKB_MARK_DATA, /* data message */
|
|
RXRPC_SKB_MARK_FINAL_ACK, /* final ACK received message */
|
|
RXRPC_SKB_MARK_BUSY, /* server busy message */
|
|
RXRPC_SKB_MARK_REMOTE_ABORT, /* remote abort message */
|
|
RXRPC_SKB_MARK_LOCAL_ABORT, /* local abort message */
|
|
RXRPC_SKB_MARK_NET_ERROR, /* network error message */
|
|
RXRPC_SKB_MARK_LOCAL_ERROR, /* local error message */
|
|
RXRPC_SKB_MARK_NEW_CALL, /* local error message */
|
|
};
|
|
|
|
typedef void (*rxrpc_interceptor_t)(struct sock *, unsigned long,
|
|
struct sk_buff *);
|
|
void rxrpc_kernel_intercept_rx_messages(struct socket *, rxrpc_interceptor_t);
|
|
struct rxrpc_call *rxrpc_kernel_begin_call(struct socket *,
|
|
struct sockaddr_rxrpc *,
|
|
struct key *,
|
|
unsigned long,
|
|
gfp_t);
|
|
int rxrpc_kernel_send_data(struct socket *, struct rxrpc_call *,
|
|
struct msghdr *, size_t);
|
|
void rxrpc_kernel_data_consumed(struct rxrpc_call *, struct sk_buff *);
|
|
void rxrpc_kernel_abort_call(struct socket *, struct rxrpc_call *, u32);
|
|
void rxrpc_kernel_end_call(struct socket *, struct rxrpc_call *);
|
|
bool rxrpc_kernel_is_data_last(struct sk_buff *);
|
|
u32 rxrpc_kernel_get_abort_code(struct sk_buff *);
|
|
int rxrpc_kernel_get_error_number(struct sk_buff *);
|
|
void rxrpc_kernel_free_skb(struct sk_buff *);
|
|
struct rxrpc_call *rxrpc_kernel_accept_call(struct socket *, unsigned long);
|
|
int rxrpc_kernel_reject_call(struct socket *);
|
|
void rxrpc_kernel_get_peer(struct socket *, struct rxrpc_call *,
|
|
struct sockaddr_rxrpc *);
|
|
|
|
#endif /* _NET_RXRPC_H */
|