/* * Copyright (c) 2006, 2017 Oracle and/or its affiliates. All rights reserved. * * This software is available to you under a choice of one of two * licenses. You may choose to be licensed under the terms of the GNU * General Public License (GPL) Version 2, available from the file * COPYING in the main directory of this source tree, or the * OpenIB.org BSD license below: * * Redistribution and use in source and binary forms, with or * without modification, are permitted provided that the following * conditions are met: * * - Redistributions of source code must retain the above * copyright notice, this list of conditions and the following * disclaimer. * * - Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials * provided with the distribution. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. * */ #include <linux/kernel.h> #include <linux/slab.h> #include <net/tcp.h> #include <trace/events/sock.h> #include "rds.h" #include "tcp.h" static struct kmem_cache *rds_tcp_incoming_slab; static void rds_tcp_inc_purge(struct rds_incoming *inc) { … } void rds_tcp_inc_free(struct rds_incoming *inc) { … } /* * this is pretty lame, but, whatever. */ int rds_tcp_inc_copy_to_user(struct rds_incoming *inc, struct iov_iter *to) { … } /* * We have a series of skbs that have fragmented pieces of the congestion * bitmap. They must add up to the exact size of the congestion bitmap. We * use the skb helpers to copy those into the pages that make up the in-memory * congestion bitmap for the remote address of this connection. We then tell * the congestion core that the bitmap has been changed so that it can wake up * sleepers. * * This is racing with sending paths which are using test_bit to see if the * bitmap indicates that their recipient is congested. */ static void rds_tcp_cong_recv(struct rds_connection *conn, struct rds_tcp_incoming *tinc) { … } struct rds_tcp_desc_arg { … }; static int rds_tcp_data_recv(read_descriptor_t *desc, struct sk_buff *skb, unsigned int offset, size_t len) { … } /* the caller has to hold the sock lock */ static int rds_tcp_read_sock(struct rds_conn_path *cp, gfp_t gfp) { … } /* * We hold the sock lock to serialize our rds_tcp_recv->tcp_read_sock from * data_ready. * * if we fail to allocate we're in trouble.. blindly wait some time before * trying again to see if the VM can free up something for us. */ int rds_tcp_recv_path(struct rds_conn_path *cp) { … } void rds_tcp_data_ready(struct sock *sk) { … } int rds_tcp_recv_init(void) { … } void rds_tcp_recv_exit(void) { … }