2012-06-19 07:34:13 +00:00
|
|
|
/*-
|
2017-11-27 14:52:40 +00:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
|
|
|
|
*
|
2012-06-19 07:34:13 +00:00
|
|
|
* Copyright (c) 2012 Chelsio Communications, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
* Written by: Navdeep Parhar <np@FreeBSD.org>
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. 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.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
|
|
|
|
#include "opt_inet.h"
|
2013-01-15 18:38:51 +00:00
|
|
|
#include "opt_inet6.h"
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
#ifdef TCP_OFFLOAD
|
|
|
|
#include <sys/param.h>
|
2013-10-29 11:17:49 +00:00
|
|
|
#include <sys/systm.h>
|
2012-06-19 07:34:13 +00:00
|
|
|
#include <sys/kernel.h>
|
|
|
|
#include <sys/ktr.h>
|
|
|
|
#include <sys/module.h>
|
|
|
|
#include <sys/protosw.h>
|
|
|
|
#include <sys/domain.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <sys/socketvar.h>
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
#include <sys/sysctl.h>
|
2012-06-19 07:34:13 +00:00
|
|
|
#include <net/ethernet.h>
|
|
|
|
#include <net/if.h>
|
|
|
|
#include <net/if_types.h>
|
|
|
|
#include <net/if_vlan_var.h>
|
|
|
|
#include <net/route.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#include <netinet/in_pcb.h>
|
|
|
|
#include <netinet/ip.h>
|
|
|
|
#define TCPSTATES
|
|
|
|
#include <netinet/tcp_fsm.h>
|
2016-01-27 05:15:53 +00:00
|
|
|
#include <netinet/tcp_var.h>
|
2012-06-19 07:34:13 +00:00
|
|
|
#include <netinet/toecore.h>
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
#include <netinet/cc/cc.h>
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
#include "common/common.h"
|
|
|
|
#include "common/t4_msg.h"
|
|
|
|
#include "common/t4_regs.h"
|
2013-07-04 17:55:52 +00:00
|
|
|
#include "common/t4_regs_values.h"
|
2012-06-19 07:34:13 +00:00
|
|
|
#include "tom/t4_tom_l2t.h"
|
|
|
|
#include "tom/t4_tom.h"
|
|
|
|
|
|
|
|
/*
|
2017-01-07 00:08:55 +00:00
|
|
|
* Active open succeeded.
|
2012-06-19 07:34:13 +00:00
|
|
|
*/
|
|
|
|
static int
|
|
|
|
do_act_establish(struct sge_iq *iq, const struct rss_header *rss,
|
|
|
|
struct mbuf *m)
|
|
|
|
{
|
|
|
|
struct adapter *sc = iq->adapter;
|
|
|
|
const struct cpl_act_establish *cpl = (const void *)(rss + 1);
|
2014-10-07 21:26:22 +00:00
|
|
|
u_int tid = GET_TID(cpl);
|
|
|
|
u_int atid = G_TID_TID(ntohl(cpl->tos_atid));
|
2012-06-19 07:34:13 +00:00
|
|
|
struct toepcb *toep = lookup_atid(sc, atid);
|
|
|
|
struct inpcb *inp = toep->inp;
|
|
|
|
|
|
|
|
KASSERT(m == NULL, ("%s: wasn't expecting payload", __func__));
|
|
|
|
KASSERT(toep->tid == atid, ("%s: toep tid/atid mismatch", __func__));
|
|
|
|
|
|
|
|
CTR3(KTR_CXGBE, "%s: atid %u, tid %u", __func__, atid, tid);
|
|
|
|
free_atid(sc, atid);
|
|
|
|
|
2017-01-11 23:48:17 +00:00
|
|
|
CURVNET_SET(toep->vnet);
|
2012-06-19 07:34:13 +00:00
|
|
|
INP_WLOCK(inp);
|
|
|
|
toep->tid = tid;
|
2017-01-07 20:26:19 +00:00
|
|
|
insert_tid(sc, tid, toep, inp->inp_vflag & INP_IPV6 ? 2 : 1);
|
2012-06-19 07:34:13 +00:00
|
|
|
if (inp->inp_flags & INP_DROPPED) {
|
|
|
|
|
|
|
|
/* socket closed by the kernel before hw told us it connected */
|
|
|
|
|
|
|
|
send_flowc_wr(toep, NULL);
|
|
|
|
send_reset(sc, toep, be32toh(cpl->snd_isn));
|
|
|
|
goto done;
|
|
|
|
}
|
|
|
|
|
|
|
|
make_established(toep, cpl->snd_isn, cpl->rcv_isn, cpl->tcp_opt);
|
Support for TLS offload of TOE connections on T6 adapters.
The TOE engine in Chelsio T6 adapters supports offloading of TLS
encryption and TCP segmentation for offloaded connections. Sockets
using TLS are required to use a set of custom socket options to upload
RX and TX keys to the NIC and to enable RX processing. Currently
these socket options are implemented as TCP options in the vendor
specific range. A patched OpenSSL library will be made available in a
port / package for use with the TLS TOE support.
TOE sockets can either offload both transmit and reception of TLS
records or just transmit. TLS offload (both RX and TX) is enabled by
setting the dev.t6nex.<x>.tls sysctl to 1 and requires TOE to be
enabled on the relevant interface. Transmit offload can be used on
any "normal" or TLS TOE socket by using the custom socket option to
program a transmit key. This permits most TOE sockets to
transparently offload TLS when applications use a patched SSL library
(e.g. using LD_LIBRARY_PATH to request use of a patched OpenSSL
library). Receive offload can only be used with TOE sockets using the
TLS mode. The dev.t6nex.0.toe.tls_rx_ports sysctl can be set to a
list of TCP port numbers. Any connection with either a local or
remote port number in that list will be created as a TLS socket rather
than a plain TOE socket. Note that although this sysctl accepts an
arbitrary list of port numbers, the sysctl(8) tool is only able to set
sysctl nodes to a single value. A TLS socket will hang without
receiving data if used by an application that is not using a patched
SSL library. Thus, the tls_rx_ports node should be used with care.
For a server mostly concerned with offloading TLS transmit, this node
is not needed as plain TOE sockets will fall back to software crypto
when using an unpatched SSL library.
New per-interface statistics nodes are added giving counts of TLS
packets and payload bytes (payload bytes do not include TLS headers or
authentication tags/MACs) offloaded via the TOE engine, e.g.:
dev.cc.0.stats.rx_tls_octets: 149
dev.cc.0.stats.rx_tls_records: 13
dev.cc.0.stats.tx_tls_octets: 26501823
dev.cc.0.stats.tx_tls_records: 1620
TLS transmit work requests are constructed by a new variant of
t4_push_frames() called t4_push_tls_records() in tom/t4_tls.c.
TLS transmit work requests require a buffer containing IVs. If the
IVs are too large to fit into the work request, a separate buffer is
allocated when constructing a work request. This buffer is associated
with the transmit descriptor and freed when the descriptor is ACKed by
the adapter.
Received TLS frames use two new CPL messages. The first message is a
CPL_TLS_DATA containing the decryped payload of a single TLS record.
The handler places the mbuf containing the received payload on an
mbufq in the TOE pcb. The second message is a CPL_RX_TLS_CMP message
which includes a copy of the TLS header and indicates if there were
any errors. The handler for this message places the TLS header into
the socket buffer followed by the saved mbuf with the payload data.
Both of these handlers are contained in tom/t4_tls.c.
A few routines were exposed from t4_cpl_io.c for use by t4_tls.c
including send_rx_credits(), a new send_rx_modulate(), and
t4_close_conn().
TLS keys for both transmit and receive are stored in onboard memory
in the NIC in the "TLS keys" memory region.
In some cases a TLS socket can hang with pending data available in the
NIC that is not delivered to the host. As a workaround, TLS sockets
are more aggressive about sending CPL_RX_DATA_ACK messages anytime that
any data is read from a TLS socket. In addition, a fallback timer will
periodically send CPL_RX_DATA_ACK messages to the NIC for connections
that are still in the handshake phase. Once the connection has
finished the handshake and programmed RX keys via the socket option,
the timer is stopped.
A new function select_ulp_mode() is used to determine what sub-mode a
given TOE socket should use (plain TOE, DDP, or TLS). The existing
set_tcpddp_ulp_mode() function has been renamed to set_ulp_mode() and
handles initialization of TLS-specific state when necessary in
addition to DDP-specific state.
Since TLS sockets do not receive individual TCP segments but always
receive full TLS records, they can receive more data than is available
in the current window (e.g. if a 16k TLS record is received but the
socket buffer is itself 16k). To cope with this, just drop the window
to 0 when this happens, but track the overage and "eat" the overage as
it is read from the socket buffer not opening the window (or adding
rx_credits) for the overage bytes.
Reviewed by: np (earlier version)
Sponsored by: Chelsio Communications
Differential Revision: https://reviews.freebsd.org/D14529
2018-03-13 23:05:51 +00:00
|
|
|
|
|
|
|
if (toep->ulp_mode == ULP_MODE_TLS)
|
|
|
|
tls_establish(toep);
|
|
|
|
|
2012-06-19 07:34:13 +00:00
|
|
|
done:
|
|
|
|
INP_WUNLOCK(inp);
|
2017-01-11 23:48:17 +00:00
|
|
|
CURVNET_RESTORE();
|
2012-06-19 07:34:13 +00:00
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Convert an ACT_OPEN_RPL status to an errno.
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
act_open_rpl_status_to_errno(int status)
|
|
|
|
{
|
|
|
|
|
|
|
|
switch (status) {
|
|
|
|
case CPL_ERR_CONN_RESET:
|
|
|
|
return (ECONNREFUSED);
|
|
|
|
case CPL_ERR_ARP_MISS:
|
|
|
|
return (EHOSTUNREACH);
|
|
|
|
case CPL_ERR_CONN_TIMEDOUT:
|
|
|
|
return (ETIMEDOUT);
|
|
|
|
case CPL_ERR_TCAM_FULL:
|
2012-08-21 18:09:33 +00:00
|
|
|
return (EAGAIN);
|
2012-06-19 07:34:13 +00:00
|
|
|
case CPL_ERR_CONN_EXIST:
|
|
|
|
log(LOG_ERR, "ACTIVE_OPEN_RPL: 4-tuple in use\n");
|
2012-08-21 18:09:33 +00:00
|
|
|
return (EAGAIN);
|
2012-06-19 07:34:13 +00:00
|
|
|
default:
|
|
|
|
return (EIO);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-07 21:26:22 +00:00
|
|
|
void
|
|
|
|
act_open_failure_cleanup(struct adapter *sc, u_int atid, u_int status)
|
|
|
|
{
|
|
|
|
struct toepcb *toep = lookup_atid(sc, atid);
|
|
|
|
struct inpcb *inp = toep->inp;
|
|
|
|
struct toedev *tod = &toep->td->tod;
|
|
|
|
|
|
|
|
free_atid(sc, atid);
|
|
|
|
toep->tid = -1;
|
|
|
|
|
2017-01-11 23:48:17 +00:00
|
|
|
CURVNET_SET(toep->vnet);
|
2014-10-07 21:26:22 +00:00
|
|
|
if (status != EAGAIN)
|
2015-08-03 12:13:54 +00:00
|
|
|
INP_INFO_RLOCK(&V_tcbinfo);
|
2014-10-07 21:26:22 +00:00
|
|
|
INP_WLOCK(inp);
|
|
|
|
toe_connect_failed(tod, inp, status);
|
|
|
|
final_cpl_received(toep); /* unlocks inp */
|
|
|
|
if (status != EAGAIN)
|
2015-08-03 12:13:54 +00:00
|
|
|
INP_INFO_RUNLOCK(&V_tcbinfo);
|
2017-01-11 23:48:17 +00:00
|
|
|
CURVNET_RESTORE();
|
2014-10-07 21:26:22 +00:00
|
|
|
}
|
|
|
|
|
2017-01-07 00:08:55 +00:00
|
|
|
/*
|
|
|
|
* Active open failed.
|
|
|
|
*/
|
2012-06-19 07:34:13 +00:00
|
|
|
static int
|
|
|
|
do_act_open_rpl(struct sge_iq *iq, const struct rss_header *rss,
|
|
|
|
struct mbuf *m)
|
|
|
|
{
|
|
|
|
struct adapter *sc = iq->adapter;
|
|
|
|
const struct cpl_act_open_rpl *cpl = (const void *)(rss + 1);
|
2014-10-07 21:26:22 +00:00
|
|
|
u_int atid = G_TID_TID(G_AOPEN_ATID(be32toh(cpl->atid_status)));
|
|
|
|
u_int status = G_AOPEN_STATUS(be32toh(cpl->atid_status));
|
2012-06-19 07:34:13 +00:00
|
|
|
struct toepcb *toep = lookup_atid(sc, atid);
|
2012-08-21 18:09:33 +00:00
|
|
|
int rc;
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
KASSERT(m == NULL, ("%s: wasn't expecting payload", __func__));
|
|
|
|
KASSERT(toep->tid == atid, ("%s: toep tid/atid mismatch", __func__));
|
|
|
|
|
|
|
|
CTR3(KTR_CXGBE, "%s: atid %u, status %u ", __func__, atid, status);
|
|
|
|
|
|
|
|
/* Ignore negative advice */
|
2013-01-26 03:01:51 +00:00
|
|
|
if (negative_advice(status))
|
2012-06-19 07:34:13 +00:00
|
|
|
return (0);
|
|
|
|
|
|
|
|
if (status && act_open_has_tid(status))
|
|
|
|
release_tid(sc, GET_TID(cpl), toep->ctrlq);
|
|
|
|
|
2012-08-21 18:09:33 +00:00
|
|
|
rc = act_open_rpl_status_to_errno(status);
|
2014-10-07 21:26:22 +00:00
|
|
|
act_open_failure_cleanup(sc, atid, rc);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Options2 for active open.
|
|
|
|
*/
|
|
|
|
static uint32_t
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
calc_opt2a(struct socket *so, struct toepcb *toep,
|
|
|
|
const struct offload_settings *s)
|
2012-06-19 07:34:13 +00:00
|
|
|
{
|
|
|
|
struct tcpcb *tp = so_sototcpcb(so);
|
2015-12-03 00:02:01 +00:00
|
|
|
struct port_info *pi = toep->vi->pi;
|
2012-06-19 07:34:13 +00:00
|
|
|
struct adapter *sc = pi->adapter;
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
uint32_t opt2 = 0;
|
2013-04-11 21:36:01 +00:00
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
/*
|
|
|
|
* rx flow control, rx coalesce, congestion control, and tx pace are all
|
|
|
|
* explicitly set by the driver. On T5+ the ISS is also set by the
|
|
|
|
* driver to the value picked by the kernel.
|
|
|
|
*/
|
|
|
|
if (is_t4(sc)) {
|
|
|
|
opt2 |= F_RX_FC_VALID | F_RX_COALESCE_VALID;
|
|
|
|
opt2 |= F_CONG_CNTRL_VALID | F_PACE_VALID;
|
|
|
|
} else {
|
|
|
|
opt2 |= F_T5_OPT_2_VALID; /* all 4 valid */
|
|
|
|
opt2 |= F_T5_ISS; /* ISS provided in CPL */
|
|
|
|
}
|
2012-06-19 07:34:13 +00:00
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
if (s->sack > 0 || (s->sack < 0 && (tp->t_flags & TF_SACK_PERMIT)))
|
2012-06-19 07:34:13 +00:00
|
|
|
opt2 |= F_SACK_EN;
|
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
if (s->tstamp > 0 || (s->tstamp < 0 && (tp->t_flags & TF_REQ_TSTMP)))
|
2012-06-19 07:34:13 +00:00
|
|
|
opt2 |= F_TSTAMPS_EN;
|
|
|
|
|
|
|
|
if (tp->t_flags & TF_REQ_SCALE)
|
|
|
|
opt2 |= F_WND_SCALE_EN;
|
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
if (s->ecn > 0 || (s->ecn < 0 && V_tcp_do_ecn == 1))
|
2012-06-19 07:34:13 +00:00
|
|
|
opt2 |= F_CCTRL_ECN;
|
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
/* XXX: F_RX_CHANNEL for multiple rx c-chan support goes here. */
|
|
|
|
|
|
|
|
opt2 |= V_TX_QUEUE(sc->params.tp.tx_modq[pi->tx_chan]);
|
|
|
|
|
|
|
|
/* These defaults are subject to ULP specific fixups later. */
|
|
|
|
opt2 |= V_RX_FC_DDP(0) | V_RX_FC_DISABLE(0);
|
|
|
|
|
|
|
|
opt2 |= V_PACE(0);
|
|
|
|
|
|
|
|
if (s->cong_algo >= 0)
|
|
|
|
opt2 |= V_CONG_CNTRL(s->cong_algo);
|
|
|
|
else if (sc->tt.cong_algorithm >= 0)
|
|
|
|
opt2 |= V_CONG_CNTRL(sc->tt.cong_algorithm & M_CONG_CNTRL);
|
2013-07-04 18:41:21 +00:00
|
|
|
else {
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
struct cc_algo *cc = CC_ALGO(tp);
|
|
|
|
|
|
|
|
if (strcasecmp(cc->name, "reno") == 0)
|
|
|
|
opt2 |= V_CONG_CNTRL(CONG_ALG_RENO);
|
|
|
|
else if (strcasecmp(cc->name, "tahoe") == 0)
|
|
|
|
opt2 |= V_CONG_CNTRL(CONG_ALG_TAHOE);
|
|
|
|
if (strcasecmp(cc->name, "newreno") == 0)
|
|
|
|
opt2 |= V_CONG_CNTRL(CONG_ALG_NEWRENO);
|
|
|
|
if (strcasecmp(cc->name, "highspeed") == 0)
|
|
|
|
opt2 |= V_CONG_CNTRL(CONG_ALG_HIGHSPEED);
|
|
|
|
else {
|
|
|
|
/*
|
|
|
|
* Use newreno in case the algorithm selected by the
|
|
|
|
* host stack is not supported by the hardware.
|
|
|
|
*/
|
|
|
|
opt2 |= V_CONG_CNTRL(CONG_ALG_NEWRENO);
|
|
|
|
}
|
2013-07-04 18:41:21 +00:00
|
|
|
}
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
|
|
|
|
if (s->rx_coalesce > 0 || (s->rx_coalesce < 0 && sc->tt.rx_coalesce))
|
2013-07-04 21:19:01 +00:00
|
|
|
opt2 |= V_RX_COALESCE(M_RX_COALESCE);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
/* Note that ofld_rxq is already set according to s->rxq. */
|
|
|
|
opt2 |= F_RSS_QUEUE_VALID;
|
|
|
|
opt2 |= V_RSS_QUEUE(toep->ofld_rxq->iq.abs_id);
|
2017-08-31 20:33:22 +00:00
|
|
|
|
2012-08-17 00:49:29 +00:00
|
|
|
#ifdef USE_DDP_RX_FLOW_CONTROL
|
|
|
|
if (toep->ulp_mode == ULP_MODE_TCPDDP)
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
opt2 |= F_RX_FC_DDP;
|
2012-08-17 00:49:29 +00:00
|
|
|
#endif
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
|
Support for TLS offload of TOE connections on T6 adapters.
The TOE engine in Chelsio T6 adapters supports offloading of TLS
encryption and TCP segmentation for offloaded connections. Sockets
using TLS are required to use a set of custom socket options to upload
RX and TX keys to the NIC and to enable RX processing. Currently
these socket options are implemented as TCP options in the vendor
specific range. A patched OpenSSL library will be made available in a
port / package for use with the TLS TOE support.
TOE sockets can either offload both transmit and reception of TLS
records or just transmit. TLS offload (both RX and TX) is enabled by
setting the dev.t6nex.<x>.tls sysctl to 1 and requires TOE to be
enabled on the relevant interface. Transmit offload can be used on
any "normal" or TLS TOE socket by using the custom socket option to
program a transmit key. This permits most TOE sockets to
transparently offload TLS when applications use a patched SSL library
(e.g. using LD_LIBRARY_PATH to request use of a patched OpenSSL
library). Receive offload can only be used with TOE sockets using the
TLS mode. The dev.t6nex.0.toe.tls_rx_ports sysctl can be set to a
list of TCP port numbers. Any connection with either a local or
remote port number in that list will be created as a TLS socket rather
than a plain TOE socket. Note that although this sysctl accepts an
arbitrary list of port numbers, the sysctl(8) tool is only able to set
sysctl nodes to a single value. A TLS socket will hang without
receiving data if used by an application that is not using a patched
SSL library. Thus, the tls_rx_ports node should be used with care.
For a server mostly concerned with offloading TLS transmit, this node
is not needed as plain TOE sockets will fall back to software crypto
when using an unpatched SSL library.
New per-interface statistics nodes are added giving counts of TLS
packets and payload bytes (payload bytes do not include TLS headers or
authentication tags/MACs) offloaded via the TOE engine, e.g.:
dev.cc.0.stats.rx_tls_octets: 149
dev.cc.0.stats.rx_tls_records: 13
dev.cc.0.stats.tx_tls_octets: 26501823
dev.cc.0.stats.tx_tls_records: 1620
TLS transmit work requests are constructed by a new variant of
t4_push_frames() called t4_push_tls_records() in tom/t4_tls.c.
TLS transmit work requests require a buffer containing IVs. If the
IVs are too large to fit into the work request, a separate buffer is
allocated when constructing a work request. This buffer is associated
with the transmit descriptor and freed when the descriptor is ACKed by
the adapter.
Received TLS frames use two new CPL messages. The first message is a
CPL_TLS_DATA containing the decryped payload of a single TLS record.
The handler places the mbuf containing the received payload on an
mbufq in the TOE pcb. The second message is a CPL_RX_TLS_CMP message
which includes a copy of the TLS header and indicates if there were
any errors. The handler for this message places the TLS header into
the socket buffer followed by the saved mbuf with the payload data.
Both of these handlers are contained in tom/t4_tls.c.
A few routines were exposed from t4_cpl_io.c for use by t4_tls.c
including send_rx_credits(), a new send_rx_modulate(), and
t4_close_conn().
TLS keys for both transmit and receive are stored in onboard memory
in the NIC in the "TLS keys" memory region.
In some cases a TLS socket can hang with pending data available in the
NIC that is not delivered to the host. As a workaround, TLS sockets
are more aggressive about sending CPL_RX_DATA_ACK messages anytime that
any data is read from a TLS socket. In addition, a fallback timer will
periodically send CPL_RX_DATA_ACK messages to the NIC for connections
that are still in the handshake phase. Once the connection has
finished the handshake and programmed RX keys via the socket option,
the timer is stopped.
A new function select_ulp_mode() is used to determine what sub-mode a
given TOE socket should use (plain TOE, DDP, or TLS). The existing
set_tcpddp_ulp_mode() function has been renamed to set_ulp_mode() and
handles initialization of TLS-specific state when necessary in
addition to DDP-specific state.
Since TLS sockets do not receive individual TCP segments but always
receive full TLS records, they can receive more data than is available
in the current window (e.g. if a 16k TLS record is received but the
socket buffer is itself 16k). To cope with this, just drop the window
to 0 when this happens, but track the overage and "eat" the overage as
it is read from the socket buffer not opening the window (or adding
rx_credits) for the overage bytes.
Reviewed by: np (earlier version)
Sponsored by: Chelsio Communications
Differential Revision: https://reviews.freebsd.org/D14529
2018-03-13 23:05:51 +00:00
|
|
|
if (toep->ulp_mode == ULP_MODE_TLS) {
|
|
|
|
opt2 &= ~V_RX_COALESCE(M_RX_COALESCE);
|
|
|
|
opt2 |= F_RX_FC_DISABLE;
|
|
|
|
}
|
2012-08-17 00:49:29 +00:00
|
|
|
|
2012-06-19 07:34:13 +00:00
|
|
|
return (htobe32(opt2));
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2016-07-05 01:29:24 +00:00
|
|
|
t4_init_connect_cpl_handlers(void)
|
2012-06-19 07:34:13 +00:00
|
|
|
{
|
|
|
|
|
2016-07-05 01:29:24 +00:00
|
|
|
t4_register_cpl_handler(CPL_ACT_ESTABLISH, do_act_establish);
|
|
|
|
t4_register_cpl_handler(CPL_ACT_OPEN_RPL, do_act_open_rpl);
|
2012-06-19 07:34:13 +00:00
|
|
|
}
|
|
|
|
|
2017-01-27 23:08:30 +00:00
|
|
|
void
|
|
|
|
t4_uninit_connect_cpl_handlers(void)
|
|
|
|
{
|
|
|
|
|
|
|
|
t4_register_cpl_handler(CPL_ACT_ESTABLISH, NULL);
|
|
|
|
t4_register_cpl_handler(CPL_ACT_OPEN_RPL, NULL);
|
|
|
|
}
|
|
|
|
|
2013-01-15 18:38:51 +00:00
|
|
|
#define DONT_OFFLOAD_ACTIVE_OPEN(x) do { \
|
|
|
|
reason = __LINE__; \
|
|
|
|
rc = (x); \
|
|
|
|
goto failed; \
|
|
|
|
} while (0)
|
|
|
|
|
2013-03-30 02:26:20 +00:00
|
|
|
static inline int
|
|
|
|
act_open_cpl_size(struct adapter *sc, int isipv6)
|
|
|
|
{
|
2016-09-17 23:08:49 +00:00
|
|
|
int idx;
|
|
|
|
static const int sz_table[3][2] = {
|
|
|
|
{
|
|
|
|
sizeof (struct cpl_act_open_req),
|
|
|
|
sizeof (struct cpl_act_open_req6)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
sizeof (struct cpl_t5_act_open_req),
|
|
|
|
sizeof (struct cpl_t5_act_open_req6)
|
|
|
|
},
|
|
|
|
{
|
|
|
|
sizeof (struct cpl_t6_act_open_req),
|
|
|
|
sizeof (struct cpl_t6_act_open_req6)
|
|
|
|
},
|
2013-03-30 02:26:20 +00:00
|
|
|
};
|
|
|
|
|
2016-09-17 23:08:49 +00:00
|
|
|
MPASS(chip_id(sc) >= CHELSIO_T4);
|
|
|
|
idx = min(chip_id(sc) - CHELSIO_T4, 2);
|
|
|
|
|
|
|
|
return (sz_table[idx][!!isipv6]);
|
2013-03-30 02:26:20 +00:00
|
|
|
}
|
|
|
|
|
2012-06-19 07:34:13 +00:00
|
|
|
/*
|
|
|
|
* active open (soconnect).
|
|
|
|
*
|
|
|
|
* State of affairs on entry:
|
|
|
|
* soisconnecting (so_state |= SS_ISCONNECTING)
|
|
|
|
* tcbinfo not locked (This has changed - used to be WLOCKed)
|
|
|
|
* inp WLOCKed
|
|
|
|
* tp->t_state = TCPS_SYN_SENT
|
|
|
|
* rtalloc1, RT_UNLOCK on rt.
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
t4_connect(struct toedev *tod, struct socket *so, struct rtentry *rt,
|
|
|
|
struct sockaddr *nam)
|
|
|
|
{
|
|
|
|
struct adapter *sc = tod->tod_softc;
|
2013-01-15 18:38:51 +00:00
|
|
|
struct tom_data *td = tod_td(tod);
|
2012-06-19 07:34:13 +00:00
|
|
|
struct toepcb *toep = NULL;
|
|
|
|
struct wrqe *wr = NULL;
|
|
|
|
struct ifnet *rt_ifp = rt->rt_ifp;
|
2015-12-03 00:02:01 +00:00
|
|
|
struct vi_info *vi;
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
int mtu_idx, rscale, qid_atid, rc, isipv6, txqid, rxqid;
|
2012-06-19 07:34:13 +00:00
|
|
|
struct inpcb *inp = sotoinpcb(so);
|
|
|
|
struct tcpcb *tp = intotcpcb(inp);
|
2013-01-15 18:38:51 +00:00
|
|
|
int reason;
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
struct offload_settings settings;
|
|
|
|
uint16_t vid = 0xffff;
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
INP_WLOCK_ASSERT(inp);
|
2013-01-15 18:38:51 +00:00
|
|
|
KASSERT(nam->sa_family == AF_INET || nam->sa_family == AF_INET6,
|
|
|
|
("%s: dest addr %p has family %u", __func__, nam, nam->sa_family));
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
if (rt_ifp->if_type == IFT_ETHER)
|
2015-12-03 00:02:01 +00:00
|
|
|
vi = rt_ifp->if_softc;
|
2012-06-19 07:34:13 +00:00
|
|
|
else if (rt_ifp->if_type == IFT_L2VLAN) {
|
|
|
|
struct ifnet *ifp = VLAN_COOKIE(rt_ifp);
|
|
|
|
|
2015-12-03 00:02:01 +00:00
|
|
|
vi = ifp->if_softc;
|
2018-04-19 18:10:44 +00:00
|
|
|
VLAN_TAG(rt_ifp, &vid);
|
2012-06-19 07:34:13 +00:00
|
|
|
} else if (rt_ifp->if_type == IFT_IEEE8023ADLAG)
|
2013-01-15 18:38:51 +00:00
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOSYS); /* XXX: implement lagg+TOE */
|
2012-06-19 07:34:13 +00:00
|
|
|
else
|
2013-01-15 18:38:51 +00:00
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOTSUP);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
rw_rlock(&sc->policy_lock);
|
|
|
|
settings = *lookup_offload_policy(sc, OPEN_TYPE_ACTIVE, NULL, vid, inp);
|
|
|
|
rw_runlock(&sc->policy_lock);
|
|
|
|
if (!settings.offload)
|
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(EPERM);
|
|
|
|
|
|
|
|
if (settings.txq >= 0 && settings.txq < vi->nofldtxq)
|
|
|
|
txqid = settings.txq;
|
|
|
|
else
|
|
|
|
txqid = arc4random() % vi->nofldtxq;
|
|
|
|
txqid += vi->first_ofld_txq;
|
|
|
|
if (settings.rxq >= 0 && settings.rxq < vi->nofldrxq)
|
|
|
|
rxqid = settings.rxq;
|
|
|
|
else
|
|
|
|
rxqid = arc4random() % vi->nofldrxq;
|
|
|
|
rxqid += vi->first_ofld_rxq;
|
|
|
|
|
|
|
|
toep = alloc_toepcb(vi, txqid, rxqid, M_NOWAIT | M_ZERO);
|
2012-06-19 07:34:13 +00:00
|
|
|
if (toep == NULL)
|
2013-01-15 18:38:51 +00:00
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOMEM);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
2013-01-15 18:38:51 +00:00
|
|
|
toep->tid = alloc_atid(sc, toep);
|
|
|
|
if (toep->tid < 0)
|
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOMEM);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
2015-12-03 00:02:01 +00:00
|
|
|
toep->l2te = t4_l2t_get(vi->pi, rt_ifp,
|
2012-06-19 07:34:13 +00:00
|
|
|
rt->rt_flags & RTF_GATEWAY ? rt->rt_gateway : nam);
|
2013-01-15 18:38:51 +00:00
|
|
|
if (toep->l2te == NULL)
|
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOMEM);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
2013-01-15 18:38:51 +00:00
|
|
|
isipv6 = nam->sa_family == AF_INET6;
|
2013-03-30 02:26:20 +00:00
|
|
|
wr = alloc_wrqe(act_open_cpl_size(sc, isipv6), toep->ctrlq);
|
2012-06-19 07:34:13 +00:00
|
|
|
if (wr == NULL)
|
2013-01-15 18:38:51 +00:00
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOMEM);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
2017-01-11 23:48:17 +00:00
|
|
|
toep->vnet = so->so_vnet;
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
set_ulp_mode(toep, select_ulp_mode(so, sc, &settings));
|
2012-06-19 07:34:13 +00:00
|
|
|
SOCKBUF_LOCK(&so->so_rcv);
|
|
|
|
/* opt0 rcv_bufsiz initially, assumes its normal meaning later */
|
|
|
|
toep->rx_credits = min(select_rcv_wnd(so) >> 10, M_RCV_BUFSIZ);
|
|
|
|
SOCKBUF_UNLOCK(&so->so_rcv);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The kernel sets request_r_scale based on sb_max whereas we need to
|
|
|
|
* take hardware's MAX_RCV_WND into account too. This is normally a
|
|
|
|
* no-op as MAX_RCV_WND is much larger than the default sb_max.
|
|
|
|
*/
|
|
|
|
if (tp->t_flags & TF_REQ_SCALE)
|
|
|
|
rscale = tp->request_r_scale = select_rcv_wscale();
|
|
|
|
else
|
|
|
|
rscale = 0;
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
mtu_idx = find_best_mtu_idx(sc, &inp->inp_inc, &settings);
|
2018-04-30 17:33:44 +00:00
|
|
|
qid_atid = V_TID_QID(toep->ofld_rxq->iq.abs_id) | V_TID_TID(toep->tid);
|
2013-01-15 18:38:51 +00:00
|
|
|
|
|
|
|
if (isipv6) {
|
|
|
|
struct cpl_act_open_req6 *cpl = wrtod(wr);
|
2016-09-17 23:08:49 +00:00
|
|
|
struct cpl_t5_act_open_req6 *cpl5 = (void *)cpl;
|
|
|
|
struct cpl_t6_act_open_req6 *cpl6 = (void *)cpl;
|
2013-01-15 18:38:51 +00:00
|
|
|
|
2016-09-17 23:08:49 +00:00
|
|
|
if ((inp->inp_vflag & INP_IPV6) == 0)
|
2013-01-15 18:38:51 +00:00
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOTSUP);
|
|
|
|
|
2017-02-06 17:48:25 +00:00
|
|
|
toep->ce = hold_lip(td, &inp->in6p_laddr, NULL);
|
2013-01-15 18:38:51 +00:00
|
|
|
if (toep->ce == NULL)
|
|
|
|
DONT_OFFLOAD_ACTIVE_OPEN(ENOENT);
|
|
|
|
|
2016-09-17 23:08:49 +00:00
|
|
|
switch (chip_id(sc)) {
|
|
|
|
case CHELSIO_T4:
|
2013-07-04 17:55:52 +00:00
|
|
|
INIT_TP_WR(cpl, 0);
|
2015-12-03 00:02:01 +00:00
|
|
|
cpl->params = select_ntuple(vi, toep->l2te);
|
2016-09-17 23:08:49 +00:00
|
|
|
break;
|
|
|
|
case CHELSIO_T5:
|
|
|
|
INIT_TP_WR(cpl5, 0);
|
|
|
|
cpl5->iss = htobe32(tp->iss);
|
|
|
|
cpl5->params = select_ntuple(vi, toep->l2te);
|
|
|
|
break;
|
|
|
|
case CHELSIO_T6:
|
|
|
|
default:
|
|
|
|
INIT_TP_WR(cpl6, 0);
|
|
|
|
cpl6->iss = htobe32(tp->iss);
|
|
|
|
cpl6->params = select_ntuple(vi, toep->l2te);
|
|
|
|
break;
|
2013-07-04 17:55:52 +00:00
|
|
|
}
|
2013-01-15 18:38:51 +00:00
|
|
|
OPCODE_TID(cpl) = htobe32(MK_OPCODE_TID(CPL_ACT_OPEN_REQ6,
|
|
|
|
qid_atid));
|
|
|
|
cpl->local_port = inp->inp_lport;
|
|
|
|
cpl->local_ip_hi = *(uint64_t *)&inp->in6p_laddr.s6_addr[0];
|
|
|
|
cpl->local_ip_lo = *(uint64_t *)&inp->in6p_laddr.s6_addr[8];
|
|
|
|
cpl->peer_port = inp->inp_fport;
|
|
|
|
cpl->peer_ip_hi = *(uint64_t *)&inp->in6p_faddr.s6_addr[0];
|
|
|
|
cpl->peer_ip_lo = *(uint64_t *)&inp->in6p_faddr.s6_addr[8];
|
2015-12-03 00:02:01 +00:00
|
|
|
cpl->opt0 = calc_opt0(so, vi, toep->l2te, mtu_idx, rscale,
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
toep->rx_credits, toep->ulp_mode, &settings);
|
|
|
|
cpl->opt2 = calc_opt2a(so, toep, &settings);
|
2013-07-04 17:55:52 +00:00
|
|
|
} else {
|
|
|
|
struct cpl_act_open_req *cpl = wrtod(wr);
|
2016-09-17 23:08:49 +00:00
|
|
|
struct cpl_t5_act_open_req *cpl5 = (void *)cpl;
|
|
|
|
struct cpl_t6_act_open_req *cpl6 = (void *)cpl;
|
2013-07-04 17:55:52 +00:00
|
|
|
|
2016-09-17 23:08:49 +00:00
|
|
|
switch (chip_id(sc)) {
|
|
|
|
case CHELSIO_T4:
|
2013-07-04 17:55:52 +00:00
|
|
|
INIT_TP_WR(cpl, 0);
|
2015-12-03 00:02:01 +00:00
|
|
|
cpl->params = select_ntuple(vi, toep->l2te);
|
2016-09-17 23:08:49 +00:00
|
|
|
break;
|
|
|
|
case CHELSIO_T5:
|
|
|
|
INIT_TP_WR(cpl5, 0);
|
|
|
|
cpl5->iss = htobe32(tp->iss);
|
|
|
|
cpl5->params = select_ntuple(vi, toep->l2te);
|
|
|
|
break;
|
|
|
|
case CHELSIO_T6:
|
|
|
|
default:
|
|
|
|
INIT_TP_WR(cpl6, 0);
|
|
|
|
cpl6->iss = htobe32(tp->iss);
|
|
|
|
cpl6->params = select_ntuple(vi, toep->l2te);
|
|
|
|
break;
|
2013-03-30 02:26:20 +00:00
|
|
|
}
|
2013-01-15 18:38:51 +00:00
|
|
|
OPCODE_TID(cpl) = htobe32(MK_OPCODE_TID(CPL_ACT_OPEN_REQ,
|
|
|
|
qid_atid));
|
|
|
|
inp_4tuple_get(inp, &cpl->local_ip, &cpl->local_port,
|
|
|
|
&cpl->peer_ip, &cpl->peer_port);
|
2015-12-03 00:02:01 +00:00
|
|
|
cpl->opt0 = calc_opt0(so, vi, toep->l2te, mtu_idx, rscale,
|
cxgbe(4): Add support for Connection Offload Policy (aka COP).
COP allows fine-grained control on whether to offload a TCP connection
using t4_tom, and what settings to apply to a connection selected for
offload. t4_tom must still be loaded and IFCAP_TOE must still be
enabled for full TCP offload to take place on an interface. The
difference is that IFCAP_TOE used to be the only knob and would enable
TOE for all new connections on the inteface, but now the driver will
also consult the COP, if any, before offloading to the hardware TOE.
A policy is a plain text file with any number of rules, one per line.
Each rule has a "match" part consisting of a socket-type (L = listen,
A = active open, P = passive open, D = don't care) and a pcap-filter(7)
expression, and a "settings" part that specifies whether to offload the
connection or not and the parameters to use if so. The general format
of a rule is: [socket-type] expr => settings
Example. See cxgbetool(8) for more information.
[L] ip && port http => offload
[L] port 443 => !offload
[L] port ssh => offload
[P] src net 192.168/16 && dst port ssh => offload !nagle !timestamp cong newreno
[P] dst port ssh => offload !nagle ecn cong tahoe
[P] dst port http => offload
[A] dst port 443 => offload tls
[A] dst net 192.168/16 => offload !timestamp cong highspeed
The driver processes the rules for each new listen, active open, or
passive open and stops at the first match. There is an implicit rule at
the end of every policy that prohibits offload when no rule in the
policy matches:
[D] all => !offload
This is a reworked and expanded version of a patch submitted by
Krishnamraju Eraparaju @ Chelsio.
Sponsored by: Chelsio Communications
2018-04-14 19:07:56 +00:00
|
|
|
toep->rx_credits, toep->ulp_mode, &settings);
|
|
|
|
cpl->opt2 = calc_opt2a(so, toep, &settings);
|
2013-01-15 18:38:51 +00:00
|
|
|
}
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
CTR5(KTR_CXGBE, "%s: atid %u (%s), toep %p, inp %p", __func__,
|
|
|
|
toep->tid, tcpstates[tp->t_state], toep, inp);
|
|
|
|
|
2013-01-15 18:38:51 +00:00
|
|
|
offload_socket(so, toep);
|
|
|
|
rc = t4_l2t_send(sc, wr, toep->l2te);
|
2012-06-19 07:34:13 +00:00
|
|
|
if (rc == 0) {
|
2012-08-21 18:30:16 +00:00
|
|
|
toep->flags |= TPF_CPL_PENDING;
|
2012-06-19 07:34:13 +00:00
|
|
|
return (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
undo_offload_socket(so);
|
2013-01-15 18:38:51 +00:00
|
|
|
reason = __LINE__;
|
2012-06-19 07:34:13 +00:00
|
|
|
failed:
|
2013-01-15 18:38:51 +00:00
|
|
|
CTR3(KTR_CXGBE, "%s: not offloading (%d), rc %d", __func__, reason, rc);
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
if (wr)
|
|
|
|
free_wrqe(wr);
|
2013-01-15 18:38:51 +00:00
|
|
|
|
|
|
|
if (toep) {
|
|
|
|
if (toep->tid >= 0)
|
|
|
|
free_atid(sc, toep->tid);
|
|
|
|
if (toep->l2te)
|
|
|
|
t4_l2t_release(toep->l2te);
|
|
|
|
if (toep->ce)
|
|
|
|
release_lip(td, toep->ce);
|
2012-06-19 07:34:13 +00:00
|
|
|
free_toepcb(toep);
|
2013-01-15 18:38:51 +00:00
|
|
|
}
|
2012-06-19 07:34:13 +00:00
|
|
|
|
|
|
|
return (rc);
|
|
|
|
}
|
|
|
|
#endif
|