8317976096
There are lots of link group termination scenarios. Most of them still allow to inform the peer of the terminating sockets about aborting. This patch tries to call smc_close_abort() for terminating sockets. And the internal TCP socket is reset with tcp_abort(). Signed-off-by: Ursula Braun <ubraun@linux.ibm.com> Signed-off-by: Karsten Graul <kgraul@linux.ibm.com> Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com>
30 lines
708 B
C
30 lines
708 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Shared Memory Communications over RDMA (SMC-R) and RoCE
|
|
*
|
|
* Socket Closing
|
|
*
|
|
* Copyright IBM Corp. 2016
|
|
*
|
|
* Author(s): Ursula Braun <ubraun@linux.vnet.ibm.com>
|
|
*/
|
|
|
|
#ifndef SMC_CLOSE_H
|
|
#define SMC_CLOSE_H
|
|
|
|
#include <linux/workqueue.h>
|
|
|
|
#include "smc.h"
|
|
|
|
#define SMC_MAX_STREAM_WAIT_TIMEOUT (2 * HZ)
|
|
#define SMC_CLOSE_SOCK_PUT_DELAY HZ
|
|
|
|
void smc_close_wake_tx_prepared(struct smc_sock *smc);
|
|
int smc_close_active(struct smc_sock *smc);
|
|
int smc_close_shutdown_write(struct smc_sock *smc);
|
|
void smc_close_init(struct smc_sock *smc);
|
|
void smc_clcsock_release(struct smc_sock *smc);
|
|
int smc_close_abort(struct smc_connection *conn);
|
|
|
|
#endif /* SMC_CLOSE_H */
|