1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (c) 2018 Chelsio Communications, Inc.
5 * Written by: Atul Gupta (atul.gupta@chelsio.com)
8 #include <linux/module.h>
9 #include <linux/list.h>
10 #include <linux/workqueue.h>
11 #include <linux/skbuff.h>
12 #include <linux/timer.h>
13 #include <linux/notifier.h>
14 #include <linux/inetdevice.h>
16 #include <linux/tcp.h>
17 #include <linux/sched/signal.h>
19 #include <net/busy_poll.h>
20 #include <crypto/aes.h>
25 static bool is_tls_tx(struct chtls_sock *csk)
27 return csk->tlshws.txkey >= 0;
30 static bool is_tls_rx(struct chtls_sock *csk)
32 return csk->tlshws.rxkey >= 0;
35 static int data_sgl_len(const struct sk_buff *skb)
39 cnt = skb_shinfo(skb)->nr_frags;
40 return sgl_len(cnt) * 8;
43 static int nos_ivs(struct sock *sk, unsigned int size)
45 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
47 return DIV_ROUND_UP(size, csk->tlshws.mfs);
50 static int set_ivs_imm(struct sock *sk, const struct sk_buff *skb)
52 int ivs_size = nos_ivs(sk, skb->len) * CIPHER_BLOCK_SIZE;
53 int hlen = TLS_WR_CPL_LEN + data_sgl_len(skb);
55 if ((hlen + KEY_ON_MEM_SZ + ivs_size) <
56 MAX_IMM_OFLD_TX_DATA_WR_LEN) {
57 ULP_SKB_CB(skb)->ulp.tls.iv = 1;
60 ULP_SKB_CB(skb)->ulp.tls.iv = 0;
64 static int max_ivs_size(struct sock *sk, int size)
66 return nos_ivs(sk, size) * CIPHER_BLOCK_SIZE;
69 static int ivs_size(struct sock *sk, const struct sk_buff *skb)
71 return set_ivs_imm(sk, skb) ? (nos_ivs(sk, skb->len) *
72 CIPHER_BLOCK_SIZE) : 0;
75 static int flowc_wr_credits(int nparams, int *flowclenp)
77 int flowclen16, flowclen;
79 flowclen = offsetof(struct fw_flowc_wr, mnemval[nparams]);
80 flowclen16 = DIV_ROUND_UP(flowclen, 16);
81 flowclen = flowclen16 * 16;
84 *flowclenp = flowclen;
89 static struct sk_buff *create_flowc_wr_skb(struct sock *sk,
90 struct fw_flowc_wr *flowc,
93 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
96 skb = alloc_skb(flowclen, GFP_ATOMIC);
100 __skb_put_data(skb, flowc, flowclen);
101 skb_set_queue_mapping(skb, (csk->txq_idx << 1) | CPL_PRIORITY_DATA);
106 static int send_flowc_wr(struct sock *sk, struct fw_flowc_wr *flowc,
109 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
110 struct tcp_sock *tp = tcp_sk(sk);
115 flowclen16 = flowclen / 16;
117 if (csk_flag(sk, CSK_TX_DATA_SENT)) {
118 skb = create_flowc_wr_skb(sk, flowc, flowclen);
123 ULPCB_FLAG_NO_HDR | ULPCB_FLAG_NO_APPEND);
127 ret = cxgb4_immdata_send(csk->egress_dev,
132 skb = create_flowc_wr_skb(sk, flowc, flowclen);
135 send_or_defer(sk, tp, skb, 0);
139 static u8 tcp_state_to_flowc_state(u8 state)
142 case TCP_ESTABLISHED:
143 return FW_FLOWC_MNEM_TCPSTATE_ESTABLISHED;
145 return FW_FLOWC_MNEM_TCPSTATE_CLOSEWAIT;
147 return FW_FLOWC_MNEM_TCPSTATE_FINWAIT1;
149 return FW_FLOWC_MNEM_TCPSTATE_CLOSING;
151 return FW_FLOWC_MNEM_TCPSTATE_LASTACK;
153 return FW_FLOWC_MNEM_TCPSTATE_FINWAIT2;
156 return FW_FLOWC_MNEM_TCPSTATE_ESTABLISHED;
159 int send_tx_flowc_wr(struct sock *sk, int compl,
160 u32 snd_nxt, u32 rcv_nxt)
162 struct flowc_packed {
163 struct fw_flowc_wr fc;
164 struct fw_flowc_mnemval mnemval[FW_FLOWC_MNEM_MAX];
166 int nparams, paramidx, flowclen16, flowclen;
167 struct fw_flowc_wr *flowc;
168 struct chtls_sock *csk;
171 csk = rcu_dereference_sk_user_data(sk);
173 memset(&sflowc, 0, sizeof(sflowc));
176 #define FLOWC_PARAM(__m, __v) \
178 flowc->mnemval[paramidx].mnemonic = FW_FLOWC_MNEM_##__m; \
179 flowc->mnemval[paramidx].val = cpu_to_be32(__v); \
185 FLOWC_PARAM(PFNVFN, FW_PFVF_CMD_PFN_V(csk->cdev->lldi->pf));
186 FLOWC_PARAM(CH, csk->tx_chan);
187 FLOWC_PARAM(PORT, csk->tx_chan);
188 FLOWC_PARAM(IQID, csk->rss_qid);
189 FLOWC_PARAM(SNDNXT, tp->snd_nxt);
190 FLOWC_PARAM(RCVNXT, tp->rcv_nxt);
191 FLOWC_PARAM(SNDBUF, csk->sndbuf);
192 FLOWC_PARAM(MSS, tp->mss_cache);
193 FLOWC_PARAM(TCPSTATE, tcp_state_to_flowc_state(sk->sk_state));
196 FLOWC_PARAM(RCV_SCALE, SND_WSCALE(tp));
198 if (csk->ulp_mode == ULP_MODE_TLS)
199 FLOWC_PARAM(ULD_MODE, ULP_MODE_TLS);
201 if (csk->tlshws.fcplenmax)
202 FLOWC_PARAM(TXDATAPLEN_MAX, csk->tlshws.fcplenmax);
207 flowclen16 = flowc_wr_credits(nparams, &flowclen);
208 flowc->op_to_nparams =
209 cpu_to_be32(FW_WR_OP_V(FW_FLOWC_WR) |
210 FW_WR_COMPL_V(compl) |
211 FW_FLOWC_WR_NPARAMS_V(nparams));
212 flowc->flowid_len16 = cpu_to_be32(FW_WR_LEN16_V(flowclen16) |
213 FW_WR_FLOWID_V(csk->tid));
215 return send_flowc_wr(sk, flowc, flowclen);
219 static int tls_copy_ivs(struct sock *sk, struct sk_buff *skb)
222 struct chtls_sock *csk;
223 unsigned char *iv_loc;
224 struct chtls_hws *hws;
230 csk = rcu_dereference_sk_user_data(sk);
232 number_of_ivs = nos_ivs(sk, skb->len);
234 if (number_of_ivs > MAX_IVS_PAGE) {
235 pr_warn("MAX IVs in PAGE exceeded %d\n", number_of_ivs);
239 /* generate the IVs */
240 ivs = kmalloc_array(CIPHER_BLOCK_SIZE, number_of_ivs, GFP_ATOMIC);
243 get_random_bytes(ivs, number_of_ivs * CIPHER_BLOCK_SIZE);
245 if (skb_ulp_tls_iv_imm(skb)) {
246 /* send the IVs as immediate data in the WR */
247 iv_loc = (unsigned char *)__skb_push(skb, number_of_ivs *
250 memcpy(iv_loc, ivs, number_of_ivs * CIPHER_BLOCK_SIZE);
252 hws->ivsize = number_of_ivs * CIPHER_BLOCK_SIZE;
254 /* Send the IVs as sgls */
255 /* Already accounted IV DSGL for credits */
256 skb_shinfo(skb)->nr_frags--;
257 page = alloc_pages(sk->sk_allocation | __GFP_COMP, 0);
259 pr_info("%s : Page allocation for IVs failed\n",
264 memcpy(page_address(page), ivs, number_of_ivs *
266 skb_fill_page_desc(skb, skb_shinfo(skb)->nr_frags, page, 0,
267 number_of_ivs * CIPHER_BLOCK_SIZE);
276 static void tls_copy_tx_key(struct sock *sk, struct sk_buff *skb)
278 struct ulptx_sc_memrd *sc_memrd;
279 struct chtls_sock *csk;
280 struct chtls_dev *cdev;
281 struct ulptx_idata *sc;
282 struct chtls_hws *hws;
286 csk = rcu_dereference_sk_user_data(sk);
290 immdlen = sizeof(*sc) + sizeof(*sc_memrd);
291 kaddr = keyid_to_addr(cdev->kmap.start, hws->txkey);
292 sc = (struct ulptx_idata *)__skb_push(skb, immdlen);
294 sc->cmd_more = htonl(ULPTX_CMD_V(ULP_TX_SC_NOOP));
296 sc_memrd = (struct ulptx_sc_memrd *)(sc + 1);
297 sc_memrd->cmd_to_len =
298 htonl(ULPTX_CMD_V(ULP_TX_SC_MEMRD) |
299 ULP_TX_SC_MORE_V(1) |
300 ULPTX_LEN16_V(hws->keylen >> 4));
301 sc_memrd->addr = htonl(kaddr);
305 static u64 tlstx_incr_seqnum(struct chtls_hws *hws)
307 return hws->tx_seq_no++;
310 static bool is_sg_request(const struct sk_buff *skb)
312 return skb->peeked ||
313 (skb->len > MAX_IMM_ULPTX_WR_LEN);
317 * Returns true if an sk_buff carries urgent data.
319 static bool skb_urgent(struct sk_buff *skb)
321 return ULP_SKB_CB(skb)->flags & ULPCB_FLAG_URG;
324 /* TLS content type for CPL SFO */
325 static unsigned char tls_content_type(unsigned char content_type)
327 switch (content_type) {
328 case TLS_HDR_TYPE_CCS:
329 return CPL_TX_TLS_SFO_TYPE_CCS;
330 case TLS_HDR_TYPE_ALERT:
331 return CPL_TX_TLS_SFO_TYPE_ALERT;
332 case TLS_HDR_TYPE_HANDSHAKE:
333 return CPL_TX_TLS_SFO_TYPE_HANDSHAKE;
334 case TLS_HDR_TYPE_HEARTBEAT:
335 return CPL_TX_TLS_SFO_TYPE_HEARTBEAT;
337 return CPL_TX_TLS_SFO_TYPE_DATA;
340 static void tls_tx_data_wr(struct sock *sk, struct sk_buff *skb,
341 int dlen, int tls_immd, u32 credits,
344 struct fw_tlstx_data_wr *req_wr;
345 struct cpl_tx_tls_sfo *req_cpl;
346 unsigned int wr_ulp_mode_force;
347 struct tls_scmd *updated_scmd;
348 unsigned char data_type;
349 struct chtls_sock *csk;
350 struct net_device *dev;
351 struct chtls_hws *hws;
352 struct tls_scmd *scmd;
353 struct adapter *adap;
359 csk = rcu_dereference_sk_user_data(sk);
360 iv_imm = skb_ulp_tls_iv_imm(skb);
361 dev = csk->egress_dev;
362 adap = netdev2adap(dev);
367 dlen = (dlen < hws->mfs) ? dlen : hws->mfs;
368 atomic_inc(&adap->chcr_stats.tls_pdu_tx);
371 updated_scmd->seqno_numivs &= 0xffffff80;
372 updated_scmd->seqno_numivs |= SCMD_NUM_IVS_V(pdus);
373 hws->scmd = *updated_scmd;
375 req = (unsigned char *)__skb_push(skb, sizeof(struct cpl_tx_tls_sfo));
376 req_cpl = (struct cpl_tx_tls_sfo *)req;
377 req = (unsigned char *)__skb_push(skb, (sizeof(struct
380 req_wr = (struct fw_tlstx_data_wr *)req;
381 immd_len = (tls_immd ? dlen : 0);
382 req_wr->op_to_immdlen =
383 htonl(FW_WR_OP_V(FW_TLSTX_DATA_WR) |
384 FW_TLSTX_DATA_WR_COMPL_V(1) |
385 FW_TLSTX_DATA_WR_IMMDLEN_V(immd_len));
386 req_wr->flowid_len16 = htonl(FW_TLSTX_DATA_WR_FLOWID_V(csk->tid) |
387 FW_TLSTX_DATA_WR_LEN16_V(credits));
388 wr_ulp_mode_force = TX_ULP_MODE_V(ULP_MODE_TLS);
390 if (is_sg_request(skb))
391 wr_ulp_mode_force |= FW_OFLD_TX_DATA_WR_ALIGNPLD_F |
392 ((tcp_sk(sk)->nonagle & TCP_NAGLE_OFF) ? 0 :
393 FW_OFLD_TX_DATA_WR_SHOVE_F);
395 req_wr->lsodisable_to_flags =
396 htonl(TX_ULP_MODE_V(ULP_MODE_TLS) |
397 TX_URG_V(skb_urgent(skb)) |
398 T6_TX_FORCE_F | wr_ulp_mode_force |
399 TX_SHOVE_V((!csk_flag(sk, CSK_TX_MORE_DATA)) &&
400 skb_queue_empty(&csk->txq)));
402 req_wr->ctxloc_to_exp =
403 htonl(FW_TLSTX_DATA_WR_NUMIVS_V(pdus) |
404 FW_TLSTX_DATA_WR_EXP_V(expn) |
405 FW_TLSTX_DATA_WR_CTXLOC_V(CHTLS_KEY_CONTEXT_DDR) |
406 FW_TLSTX_DATA_WR_IVDSGL_V(!iv_imm) |
407 FW_TLSTX_DATA_WR_KEYSIZE_V(hws->keylen >> 4));
409 /* Fill in the length */
410 req_wr->plen = htonl(len);
411 req_wr->mfs = htons(hws->mfs);
412 req_wr->adjustedplen_pkd =
413 htons(FW_TLSTX_DATA_WR_ADJUSTEDPLEN_V(hws->adjustlen));
414 req_wr->expinplenmax_pkd =
415 htons(FW_TLSTX_DATA_WR_EXPINPLENMAX_V(hws->expansion));
416 req_wr->pdusinplenmax_pkd =
417 FW_TLSTX_DATA_WR_PDUSINPLENMAX_V(hws->pdus);
420 data_type = tls_content_type(ULP_SKB_CB(skb)->ulp.tls.type);
421 req_cpl->op_to_seg_len = htonl(CPL_TX_TLS_SFO_OPCODE_V(CPL_TX_TLS_SFO) |
422 CPL_TX_TLS_SFO_DATA_TYPE_V(data_type) |
423 CPL_TX_TLS_SFO_CPL_LEN_V(2) |
424 CPL_TX_TLS_SFO_SEG_LEN_V(dlen));
425 req_cpl->pld_len = htonl(len - expn);
427 req_cpl->type_protover = htonl(CPL_TX_TLS_SFO_TYPE_V
428 ((data_type == CPL_TX_TLS_SFO_TYPE_HEARTBEAT) ?
429 TLS_HDR_TYPE_HEARTBEAT : 0) |
430 CPL_TX_TLS_SFO_PROTOVER_V(0));
432 /* create the s-command */
434 req_cpl->seqno_numivs = cpu_to_be32(hws->scmd.seqno_numivs);
435 req_cpl->ivgen_hdrlen = cpu_to_be32(hws->scmd.ivgen_hdrlen);
436 req_cpl->scmd1 = cpu_to_be64(tlstx_incr_seqnum(hws));
440 * Calculate the TLS data expansion size
442 static int chtls_expansion_size(struct sock *sk, int data_len,
444 unsigned short *pducnt)
446 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
447 struct chtls_hws *hws = &csk->tlshws;
448 struct tls_scmd *scmd = &hws->scmd;
449 int fragsize = hws->mfs;
455 if (SCMD_CIPH_MODE_G(scmd->seqno_numivs) ==
456 SCMD_CIPH_MODE_AES_GCM) {
457 expppdu = GCM_TAG_SIZE + AEAD_EXPLICIT_DATA_SIZE +
461 *pducnt = data_len / (expppdu + fragsize);
466 expnsize = (*pducnt) * expppdu;
469 fragcnt = (data_len / fragsize);
470 expnsize = fragcnt * expppdu;
471 fragleft = data_len % fragsize;
478 /* WR with IV, KEY and CPL SFO added */
479 static void make_tlstx_data_wr(struct sock *sk, struct sk_buff *skb,
480 int tls_tx_imm, int tls_len, u32 credits)
482 unsigned short pdus_per_ulp = 0;
483 struct chtls_sock *csk;
484 struct chtls_hws *hws;
488 csk = rcu_dereference_sk_user_data(sk);
490 pdus = DIV_ROUND_UP(tls_len, hws->mfs);
491 expn_sz = chtls_expansion_size(sk, tls_len, 0, NULL);
493 hws->expansion = chtls_expansion_size(sk,
496 hws->pdus = pdus_per_ulp;
497 hws->adjustlen = hws->pdus *
498 ((hws->expansion / hws->pdus) + hws->mfs);
501 if (tls_copy_ivs(sk, skb))
503 tls_copy_tx_key(sk, skb);
504 tls_tx_data_wr(sk, skb, tls_len, tls_tx_imm, credits, expn_sz, pdus);
505 hws->tx_seq_no += (pdus - 1);
508 static void make_tx_data_wr(struct sock *sk, struct sk_buff *skb,
509 unsigned int immdlen, int len,
510 u32 credits, u32 compl)
512 struct fw_ofld_tx_data_wr *req;
513 unsigned int wr_ulp_mode_force;
514 struct chtls_sock *csk;
517 csk = rcu_dereference_sk_user_data(sk);
518 opcode = FW_OFLD_TX_DATA_WR;
520 req = (struct fw_ofld_tx_data_wr *)__skb_push(skb, sizeof(*req));
521 req->op_to_immdlen = htonl(WR_OP_V(opcode) |
522 FW_WR_COMPL_V(compl) |
523 FW_WR_IMMDLEN_V(immdlen));
524 req->flowid_len16 = htonl(FW_WR_FLOWID_V(csk->tid) |
525 FW_WR_LEN16_V(credits));
527 wr_ulp_mode_force = TX_ULP_MODE_V(csk->ulp_mode);
528 if (is_sg_request(skb))
529 wr_ulp_mode_force |= FW_OFLD_TX_DATA_WR_ALIGNPLD_F |
530 ((tcp_sk(sk)->nonagle & TCP_NAGLE_OFF) ? 0 :
531 FW_OFLD_TX_DATA_WR_SHOVE_F);
533 req->tunnel_to_proxy = htonl(wr_ulp_mode_force |
534 TX_URG_V(skb_urgent(skb)) |
535 TX_SHOVE_V((!csk_flag(sk, CSK_TX_MORE_DATA)) &&
536 skb_queue_empty(&csk->txq)));
537 req->plen = htonl(len);
540 static int chtls_wr_size(struct chtls_sock *csk, const struct sk_buff *skb,
545 wr_size = TLS_WR_CPL_LEN;
546 wr_size += KEY_ON_MEM_SZ;
547 wr_size += ivs_size(csk->sk, skb);
552 /* frags counted for IV dsgl */
553 if (!skb_ulp_tls_iv_imm(skb))
554 skb_shinfo(skb)->nr_frags++;
559 static bool is_ofld_imm(struct chtls_sock *csk, const struct sk_buff *skb)
561 int length = skb->len;
563 if (skb->peeked || skb->len > MAX_IMM_ULPTX_WR_LEN)
566 if (likely(ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NEED_HDR)) {
567 /* Check TLS header len for Immediate */
568 if (csk->ulp_mode == ULP_MODE_TLS &&
569 skb_ulp_tls_inline(skb))
570 length += chtls_wr_size(csk, skb, true);
572 length += sizeof(struct fw_ofld_tx_data_wr);
574 return length <= MAX_IMM_OFLD_TX_DATA_WR_LEN;
579 static unsigned int calc_tx_flits(const struct sk_buff *skb,
580 unsigned int immdlen)
582 unsigned int flits, cnt;
584 flits = immdlen / 8; /* headers */
585 cnt = skb_shinfo(skb)->nr_frags;
586 if (skb_tail_pointer(skb) != skb_transport_header(skb))
588 return flits + sgl_len(cnt);
591 static void arp_failure_discard(void *handle, struct sk_buff *skb)
596 int chtls_push_frames(struct chtls_sock *csk, int comp)
598 struct chtls_hws *hws = &csk->tlshws;
605 wr_size = sizeof(struct fw_ofld_tx_data_wr);
609 if (unlikely(sk_in_state(sk, TCPF_SYN_SENT | TCPF_CLOSE)))
612 if (unlikely(csk_flag(sk, CSK_ABORT_SHUTDOWN)))
615 while (csk->wr_credits && (skb = skb_peek(&csk->txq)) &&
616 (!(ULP_SKB_CB(skb)->flags & ULPCB_FLAG_HOLD) ||
617 skb_queue_len(&csk->txq) > 1)) {
618 unsigned int credit_len = skb->len;
619 unsigned int credits_needed;
620 unsigned int completion = 0;
621 int tls_len = skb->len;/* TLS data len before IV/key */
622 unsigned int immdlen;
623 int len = skb->len; /* length [ulp bytes] inserted by hw */
628 if (!is_ofld_imm(csk, skb)) {
629 immdlen = skb_transport_offset(skb);
630 if (skb_ulp_tls_inline(skb))
631 wr_size = chtls_wr_size(csk, skb, false);
632 credit_len = 8 * calc_tx_flits(skb, immdlen);
634 if (skb_ulp_tls_inline(skb)) {
635 wr_size = chtls_wr_size(csk, skb, false);
639 if (likely(ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NEED_HDR))
640 credit_len += wr_size;
641 credits_needed = DIV_ROUND_UP(credit_len, 16);
642 if (!csk_flag_nochk(csk, CSK_TX_DATA_SENT)) {
643 flowclen16 = send_tx_flowc_wr(sk, 1, tp->snd_nxt,
647 csk->wr_credits -= flowclen16;
648 csk->wr_unacked += flowclen16;
649 csk->wr_nondata += flowclen16;
650 csk_set_flag(csk, CSK_TX_DATA_SENT);
653 if (csk->wr_credits < credits_needed) {
654 if (skb_ulp_tls_inline(skb) &&
655 !skb_ulp_tls_iv_imm(skb))
656 skb_shinfo(skb)->nr_frags--;
660 __skb_unlink(skb, &csk->txq);
661 skb_set_queue_mapping(skb, (csk->txq_idx << 1) |
664 hws->txqid = (skb->queue_mapping >> 1);
665 skb->csum = (__force __wsum)(credits_needed + csk->wr_nondata);
666 csk->wr_credits -= credits_needed;
667 csk->wr_unacked += credits_needed;
669 enqueue_wr(csk, skb);
671 if (likely(ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NEED_HDR)) {
672 if ((comp && csk->wr_unacked == credits_needed) ||
673 (ULP_SKB_CB(skb)->flags & ULPCB_FLAG_COMPL) ||
674 csk->wr_unacked >= csk->wr_max_credits / 2) {
678 if (skb_ulp_tls_inline(skb))
679 make_tlstx_data_wr(sk, skb, tls_tx_imm,
680 tls_len, credits_needed);
682 make_tx_data_wr(sk, skb, immdlen, len,
683 credits_needed, completion);
685 tp->lsndtime = tcp_jiffies32;
687 ULP_SKB_CB(skb)->flags &= ~ULPCB_FLAG_NEED_HDR;
689 struct cpl_close_con_req *req = cplhdr(skb);
690 unsigned int cmd = CPL_OPCODE_G(ntohl
693 if (cmd == CPL_CLOSE_CON_REQ)
695 CSK_CLOSE_CON_REQUESTED);
697 if ((ULP_SKB_CB(skb)->flags & ULPCB_FLAG_COMPL) &&
698 (csk->wr_unacked >= csk->wr_max_credits / 2)) {
699 req->wr.wr_hi |= htonl(FW_WR_COMPL_F);
703 total_size += skb->truesize;
704 if (ULP_SKB_CB(skb)->flags & ULPCB_FLAG_BARRIER)
705 csk_set_flag(csk, CSK_TX_WAIT_IDLE);
706 t4_set_arp_err_handler(skb, NULL, arp_failure_discard);
707 cxgb4_l2t_send(csk->egress_dev, skb, csk->l2t_entry);
709 sk->sk_wmem_queued -= total_size;
713 static void mark_urg(struct tcp_sock *tp, int flags,
716 if (unlikely(flags & MSG_OOB)) {
717 tp->snd_up = tp->write_seq;
718 ULP_SKB_CB(skb)->flags = ULPCB_FLAG_URG |
720 ULPCB_FLAG_NO_APPEND |
726 * Returns true if a connection should send more data to TCP engine
728 static bool should_push(struct sock *sk)
730 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
731 struct chtls_dev *cdev = csk->cdev;
732 struct tcp_sock *tp = tcp_sk(sk);
735 * If we've released our offload resources there's nothing to do ...
741 * If there aren't any work requests in flight, or there isn't enough
742 * data in flight, or Nagle is off then send the current TX_DATA
743 * otherwise hold it and wait to accumulate more data.
745 return csk->wr_credits == csk->wr_max_credits ||
746 (tp->nonagle & TCP_NAGLE_OFF);
750 * Returns true if a TCP socket is corked.
752 static bool corked(const struct tcp_sock *tp, int flags)
754 return (flags & MSG_MORE) || (tp->nonagle & TCP_NAGLE_CORK);
758 * Returns true if a send should try to push new data.
760 static bool send_should_push(struct sock *sk, int flags)
762 return should_push(sk) && !corked(tcp_sk(sk), flags);
765 void chtls_tcp_push(struct sock *sk, int flags)
767 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
768 int qlen = skb_queue_len(&csk->txq);
771 struct sk_buff *skb = skb_peek_tail(&csk->txq);
772 struct tcp_sock *tp = tcp_sk(sk);
774 mark_urg(tp, flags, skb);
776 if (!(ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NO_APPEND) &&
778 ULP_SKB_CB(skb)->flags |= ULPCB_FLAG_HOLD;
782 ULP_SKB_CB(skb)->flags &= ~ULPCB_FLAG_HOLD;
784 ((ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NO_APPEND) ||
786 chtls_push_frames(csk, 1);
791 * Calculate the size for a new send sk_buff. It's maximum size so we can
792 * pack lots of data into it, unless we plan to send it immediately, in which
793 * case we size it more tightly.
795 * Note: we don't bother compensating for MSS < PAGE_SIZE because it doesn't
796 * arise in normal cases and when it does we are just wasting memory.
798 static int select_size(struct sock *sk, int io_len, int flags, int len)
800 const int pgbreak = SKB_MAX_HEAD(len);
803 * If the data wouldn't fit in the main body anyway, put only the
804 * header in the main body so it can use immediate data and place all
805 * the payload in page fragments.
807 if (io_len > pgbreak)
811 * If we will be accumulating payload get a large main body.
813 if (!send_should_push(sk, flags))
819 void skb_entail(struct sock *sk, struct sk_buff *skb, int flags)
821 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
822 struct tcp_sock *tp = tcp_sk(sk);
824 ULP_SKB_CB(skb)->seq = tp->write_seq;
825 ULP_SKB_CB(skb)->flags = flags;
826 __skb_queue_tail(&csk->txq, skb);
827 sk->sk_wmem_queued += skb->truesize;
829 if (TCP_PAGE(sk) && TCP_OFF(sk)) {
830 put_page(TCP_PAGE(sk));
836 static struct sk_buff *get_tx_skb(struct sock *sk, int size)
840 skb = alloc_skb(size + TX_HEADER_LEN, sk->sk_allocation);
842 skb_reserve(skb, TX_HEADER_LEN);
843 skb_entail(sk, skb, ULPCB_FLAG_NEED_HDR);
844 skb_reset_transport_header(skb);
849 static struct sk_buff *get_record_skb(struct sock *sk, int size, bool zcopy)
851 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
854 skb = alloc_skb(((zcopy ? 0 : size) + TX_TLSHDR_LEN +
855 KEY_ON_MEM_SZ + max_ivs_size(sk, size)),
858 skb_reserve(skb, (TX_TLSHDR_LEN +
859 KEY_ON_MEM_SZ + max_ivs_size(sk, size)));
860 skb_entail(sk, skb, ULPCB_FLAG_NEED_HDR);
861 skb_reset_transport_header(skb);
862 ULP_SKB_CB(skb)->ulp.tls.ofld = 1;
863 ULP_SKB_CB(skb)->ulp.tls.type = csk->tlshws.type;
868 static void tx_skb_finalize(struct sk_buff *skb)
870 struct ulp_skb_cb *cb = ULP_SKB_CB(skb);
872 if (!(cb->flags & ULPCB_FLAG_NO_HDR))
873 cb->flags = ULPCB_FLAG_NEED_HDR;
874 cb->flags |= ULPCB_FLAG_NO_APPEND;
877 static void push_frames_if_head(struct sock *sk)
879 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
881 if (skb_queue_len(&csk->txq) == 1)
882 chtls_push_frames(csk, 1);
885 static int chtls_skb_copy_to_page_nocache(struct sock *sk,
886 struct iov_iter *from,
893 err = skb_do_copy_data_nocache(sk, skb, from, page_address(page) +
894 off, copy, skb->len);
899 skb->data_len += copy;
900 skb->truesize += copy;
901 sk->sk_wmem_queued += copy;
905 static bool csk_mem_free(struct chtls_dev *cdev, struct sock *sk)
907 return (cdev->max_host_sndbuf - sk->sk_wmem_queued > 0);
910 static int csk_wait_memory(struct chtls_dev *cdev,
911 struct sock *sk, long *timeo_p)
913 DEFINE_WAIT_FUNC(wait, woken_wake_function);
919 current_timeo = *timeo_p;
920 noblock = (*timeo_p ? false : true);
921 if (csk_mem_free(cdev, sk)) {
922 current_timeo = get_random_u32_below(HZ / 5) + 2;
923 vm_wait = get_random_u32_below(HZ / 5) + 2;
926 add_wait_queue(sk_sleep(sk), &wait);
928 sk_set_bit(SOCKWQ_ASYNC_NOSPACE, sk);
930 if (sk->sk_err || (sk->sk_shutdown & SEND_SHUTDOWN))
934 set_bit(SOCK_NOSPACE, &sk->sk_socket->flags);
937 if (signal_pending(current))
939 sk_clear_bit(SOCKWQ_ASYNC_NOSPACE, sk);
940 if (csk_mem_free(cdev, sk) && !vm_wait)
943 set_bit(SOCK_NOSPACE, &sk->sk_socket->flags);
944 sk->sk_write_pending++;
945 sk_wait_event(sk, ¤t_timeo, sk->sk_err ||
946 (sk->sk_shutdown & SEND_SHUTDOWN) ||
947 (csk_mem_free(cdev, sk) && !vm_wait), &wait);
948 sk->sk_write_pending--;
951 vm_wait -= current_timeo;
952 current_timeo = *timeo_p;
953 if (current_timeo != MAX_SCHEDULE_TIMEOUT) {
954 current_timeo -= vm_wait;
955 if (current_timeo < 0)
960 *timeo_p = current_timeo;
963 remove_wait_queue(sk_sleep(sk), &wait);
972 err = sock_intr_errno(*timeo_p);
976 static int chtls_proccess_cmsg(struct sock *sk, struct msghdr *msg,
977 unsigned char *record_type)
979 struct cmsghdr *cmsg;
982 for_each_cmsghdr(cmsg, msg) {
983 if (!CMSG_OK(msg, cmsg))
985 if (cmsg->cmsg_level != SOL_TLS)
988 switch (cmsg->cmsg_type) {
989 case TLS_SET_RECORD_TYPE:
990 if (cmsg->cmsg_len < CMSG_LEN(sizeof(*record_type)))
993 if (msg->msg_flags & MSG_MORE)
996 *record_type = *(unsigned char *)CMSG_DATA(cmsg);
1007 int chtls_sendmsg(struct sock *sk, struct msghdr *msg, size_t size)
1009 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
1010 struct chtls_dev *cdev = csk->cdev;
1011 struct tcp_sock *tp = tcp_sk(sk);
1012 struct sk_buff *skb;
1013 int mss, flags, err;
1019 flags = msg->msg_flags;
1020 timeo = sock_sndtimeo(sk, flags & MSG_DONTWAIT);
1022 if (!sk_in_state(sk, TCPF_ESTABLISHED | TCPF_CLOSE_WAIT)) {
1023 err = sk_stream_wait_connect(sk, &timeo);
1028 sk_clear_bit(SOCKWQ_ASYNC_NOSPACE, sk);
1030 if (sk->sk_err || (sk->sk_shutdown & SEND_SHUTDOWN))
1034 csk_set_flag(csk, CSK_TX_MORE_DATA);
1036 while (msg_data_left(msg)) {
1039 skb = skb_peek_tail(&csk->txq);
1041 copy = mss - skb->len;
1042 skb->ip_summed = CHECKSUM_UNNECESSARY;
1044 if (!csk_mem_free(cdev, sk))
1045 goto wait_for_sndbuf;
1047 if (is_tls_tx(csk) && !csk->tlshws.txleft) {
1048 unsigned char record_type = TLS_RECORD_TYPE_DATA;
1050 if (unlikely(msg->msg_controllen)) {
1051 err = chtls_proccess_cmsg(sk, msg,
1056 /* Avoid appending tls handshake, alert to tls data */
1058 tx_skb_finalize(skb);
1062 csk->tlshws.txleft = recordsz;
1063 csk->tlshws.type = record_type;
1066 if (!skb || (ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NO_APPEND) ||
1070 tx_skb_finalize(skb);
1071 push_frames_if_head(sk);
1074 if (is_tls_tx(csk)) {
1075 skb = get_record_skb(sk,
1082 skb = get_tx_skb(sk,
1083 select_size(sk, size, flags,
1087 goto wait_for_memory;
1089 skb->ip_summed = CHECKSUM_UNNECESSARY;
1095 if (msg->msg_flags & MSG_SPLICE_PAGES) {
1096 err = skb_splice_from_iter(skb, &msg->msg_iter, copy,
1099 if (err == -EMSGSIZE)
1104 sk_wmem_queued_add(sk, copy);
1105 } else if (skb_tailroom(skb) > 0) {
1106 copy = min(copy, skb_tailroom(skb));
1108 copy = min_t(int, copy, csk->tlshws.txleft);
1109 err = skb_add_data_nocache(sk, skb,
1110 &msg->msg_iter, copy);
1114 int i = skb_shinfo(skb)->nr_frags;
1115 struct page *page = TCP_PAGE(sk);
1116 int pg_size = PAGE_SIZE;
1117 int off = TCP_OFF(sk);
1121 pg_size = page_size(page);
1122 if (off < pg_size &&
1123 skb_can_coalesce(skb, i, page, off)) {
1128 if (i == (is_tls_tx(csk) ? (MAX_SKB_FRAGS - 1) :
1132 if (page && off == pg_size) {
1134 TCP_PAGE(sk) = page = NULL;
1135 pg_size = PAGE_SIZE;
1139 gfp_t gfp = sk->sk_allocation;
1140 int order = cdev->send_page_order;
1143 page = alloc_pages(gfp | __GFP_COMP |
1151 page = alloc_page(gfp);
1152 pg_size = PAGE_SIZE;
1155 goto wait_for_memory;
1159 if (copy > pg_size - off)
1160 copy = pg_size - off;
1162 copy = min_t(int, copy, csk->tlshws.txleft);
1164 err = chtls_skb_copy_to_page_nocache(sk, &msg->msg_iter,
1167 if (unlikely(err)) {
1168 if (!TCP_PAGE(sk)) {
1169 TCP_PAGE(sk) = page;
1174 /* Update the skb. */
1177 &skb_shinfo(skb)->frags[i - 1],
1180 skb_fill_page_desc(skb, i, page, off, copy);
1181 if (off + copy < pg_size) {
1182 /* space left keep page */
1184 TCP_PAGE(sk) = page;
1186 TCP_PAGE(sk) = NULL;
1189 TCP_OFF(sk) = off + copy;
1191 if (unlikely(skb->len == mss))
1192 tx_skb_finalize(skb);
1193 tp->write_seq += copy;
1198 csk->tlshws.txleft -= copy;
1200 if (corked(tp, flags) &&
1201 (sk_stream_wspace(sk) < sk_stream_min_wspace(sk)))
1202 ULP_SKB_CB(skb)->flags |= ULPCB_FLAG_NO_APPEND;
1207 if (ULP_SKB_CB(skb)->flags & ULPCB_FLAG_NO_APPEND)
1208 push_frames_if_head(sk);
1211 set_bit(SOCK_NOSPACE, &sk->sk_socket->flags);
1213 err = csk_wait_memory(cdev, sk, &timeo);
1218 csk_reset_flag(csk, CSK_TX_MORE_DATA);
1220 chtls_tcp_push(sk, flags);
1226 __skb_unlink(skb, &csk->txq);
1227 sk->sk_wmem_queued -= skb->truesize;
1234 if (csk_conn_inline(csk))
1235 csk_reset_flag(csk, CSK_TX_MORE_DATA);
1236 copied = sk_stream_error(sk, flags, err);
1240 void chtls_splice_eof(struct socket *sock)
1242 struct sock *sk = sock->sk;
1245 chtls_tcp_push(sk, 0);
1249 static void chtls_select_window(struct sock *sk)
1251 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
1252 struct tcp_sock *tp = tcp_sk(sk);
1253 unsigned int wnd = tp->rcv_wnd;
1255 wnd = max_t(unsigned int, wnd, tcp_full_space(sk));
1256 wnd = max_t(unsigned int, MIN_RCV_WND, wnd);
1258 if (wnd > MAX_RCV_WND)
1262 * Check if we need to grow the receive window in response to an increase in
1263 * the socket's receive buffer size. Some applications increase the buffer
1264 * size dynamically and rely on the window to grow accordingly.
1267 if (wnd > tp->rcv_wnd) {
1268 tp->rcv_wup -= wnd - tp->rcv_wnd;
1270 /* Mark the receive window as updated */
1271 csk_reset_flag(csk, CSK_UPDATE_RCV_WND);
1276 * Send RX credits through an RX_DATA_ACK CPL message. We are permitted
1277 * to return without sending the message in case we cannot allocate
1278 * an sk_buff. Returns the number of credits sent.
1280 static u32 send_rx_credits(struct chtls_sock *csk, u32 credits)
1282 struct cpl_rx_data_ack *req;
1283 struct sk_buff *skb;
1285 skb = alloc_skb(sizeof(*req), GFP_ATOMIC);
1288 __skb_put(skb, sizeof(*req));
1289 req = (struct cpl_rx_data_ack *)skb->head;
1291 set_wr_txq(skb, CPL_PRIORITY_ACK, csk->port_id);
1292 INIT_TP_WR(req, csk->tid);
1293 OPCODE_TID(req) = cpu_to_be32(MK_OPCODE_TID(CPL_RX_DATA_ACK,
1295 req->credit_dack = cpu_to_be32(RX_CREDITS_V(credits) |
1297 cxgb4_ofld_send(csk->cdev->ports[csk->port_id], skb);
1301 #define CREDIT_RETURN_STATE (TCPF_ESTABLISHED | \
1306 * Called after some received data has been read. It returns RX credits
1307 * to the HW for the amount of data processed.
1309 static void chtls_cleanup_rbuf(struct sock *sk, int copied)
1311 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
1312 struct tcp_sock *tp;
1319 if (!sk_in_state(sk, CREDIT_RETURN_STATE))
1322 chtls_select_window(sk);
1324 credits = tp->copied_seq - tp->rcv_wup;
1325 if (unlikely(!credits))
1329 * For coalescing to work effectively ensure the receive window has
1330 * at least 16KB left.
1332 must_send = credits + 16384 >= tp->rcv_wnd;
1334 if (must_send || credits >= thres)
1335 tp->rcv_wup += send_rx_credits(csk, credits);
1338 static int chtls_pt_recvmsg(struct sock *sk, struct msghdr *msg, size_t len,
1339 int flags, int *addr_len)
1341 struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
1342 struct chtls_hws *hws = &csk->tlshws;
1343 struct net_device *dev = csk->egress_dev;
1344 struct adapter *adap = netdev2adap(dev);
1345 struct tcp_sock *tp = tcp_sk(sk);
1346 unsigned long avail;
1354 timeo = sock_rcvtimeo(sk, flags & MSG_DONTWAIT);
1355 target = sock_rcvlowat(sk, flags & MSG_WAITALL, len);
1357 if (unlikely(csk_flag(sk, CSK_UPDATE_RCV_WND)))
1358 chtls_cleanup_rbuf(sk, copied);
1361 struct sk_buff *skb;
1364 if (unlikely(tp->urg_data &&
1365 tp->urg_seq == tp->copied_seq)) {
1368 if (signal_pending(current)) {
1369 copied = timeo ? sock_intr_errno(timeo) :
1374 skb = skb_peek(&sk->sk_receive_queue);
1377 if (csk->wr_credits &&
1378 skb_queue_len(&csk->txq) &&
1379 chtls_push_frames(csk, csk->wr_credits ==
1380 csk->wr_max_credits))
1381 sk->sk_write_space(sk);
1383 if (copied >= target && !READ_ONCE(sk->sk_backlog.tail))
1387 if (sk->sk_err || sk->sk_state == TCP_CLOSE ||
1388 (sk->sk_shutdown & RCV_SHUTDOWN) ||
1389 signal_pending(current))
1395 if (sock_flag(sk, SOCK_DONE))
1398 copied = sock_error(sk);
1401 if (sk->sk_shutdown & RCV_SHUTDOWN)
1403 if (sk->sk_state == TCP_CLOSE) {
1411 if (signal_pending(current)) {
1412 copied = sock_intr_errno(timeo);
1416 if (READ_ONCE(sk->sk_backlog.tail)) {
1419 chtls_cleanup_rbuf(sk, copied);
1423 if (copied >= target)
1425 chtls_cleanup_rbuf(sk, copied);
1426 sk_wait_data(sk, &timeo, NULL);
1430 skb_dst_set(skb, NULL);
1431 __skb_unlink(skb, &sk->sk_receive_queue);
1434 if (!copied && !timeo) {
1439 if (copied < target) {
1446 offset = hws->copied_seq;
1447 avail = skb->len - offset;
1451 if (unlikely(tp->urg_data)) {
1452 u32 urg_offset = tp->urg_seq - tp->copied_seq;
1454 if (urg_offset < avail) {
1457 } else if (!sock_flag(sk, SOCK_URGINLINE)) {
1458 /* First byte is urgent, skip */
1467 /* Set record type if not already done. For a non-data record,
1468 * do not proceed if record type could not be copied.
1470 if (ULP_SKB_CB(skb)->flags & ULPCB_FLAG_TLS_HDR) {
1471 struct tls_hdr *thdr = (struct tls_hdr *)skb->data;
1474 cerr = put_cmsg(msg, SOL_TLS, TLS_GET_RECORD_TYPE,
1475 sizeof(thdr->type), &thdr->type);
1477 if (cerr && thdr->type != TLS_RECORD_TYPE_DATA) {
1481 /* don't send tls header, skip copy */
1485 if (skb_copy_datagram_msg(skb, offset, msg, avail)) {
1494 hws->copied_seq += avail;
1496 if (tp->urg_data && after(tp->copied_seq, tp->urg_seq))
1499 if ((avail + offset) >= skb->len) {
1500 struct sk_buff *next_skb;
1501 if (ULP_SKB_CB(skb)->flags & ULPCB_FLAG_TLS_HDR) {
1502 tp->copied_seq += skb->len;
1503 hws->rcvpld = skb->hdr_len;
1505 atomic_inc(&adap->chcr_stats.tls_pdu_rx);
1506 tp->copied_seq += hws->rcvpld;
1508 chtls_free_skb(sk, skb);
1510 hws->copied_seq = 0;
1511 next_skb = skb_peek(&sk->sk_receive_queue);
1512 if (copied >= target && !next_skb)
1514 if (ULP_SKB_CB(next_skb)->flags & ULPCB_FLAG_TLS_HDR)
1520 chtls_cleanup_rbuf(sk, copied);
1526 * Peek at data in a socket's receive buffer.
1528 static int peekmsg(struct sock *sk, struct msghdr *msg,
1529 size_t len, int flags)
1531 struct tcp_sock *tp = tcp_sk(sk);
1532 u32 peek_seq, offset;
1533 struct sk_buff *skb;
1535 size_t avail; /* amount of available data in current skb */
1539 timeo = sock_rcvtimeo(sk, flags & MSG_DONTWAIT);
1540 peek_seq = tp->copied_seq;
1543 if (unlikely(tp->urg_data && tp->urg_seq == peek_seq)) {
1546 if (signal_pending(current)) {
1547 copied = timeo ? sock_intr_errno(timeo) :
1553 skb_queue_walk(&sk->sk_receive_queue, skb) {
1554 offset = peek_seq - ULP_SKB_CB(skb)->seq;
1555 if (offset < skb->len)
1559 /* empty receive queue */
1562 if (sock_flag(sk, SOCK_DONE))
1565 copied = sock_error(sk);
1568 if (sk->sk_shutdown & RCV_SHUTDOWN)
1570 if (sk->sk_state == TCP_CLOSE) {
1578 if (signal_pending(current)) {
1579 copied = sock_intr_errno(timeo);
1583 if (READ_ONCE(sk->sk_backlog.tail)) {
1584 /* Do not sleep, just process backlog. */
1588 sk_wait_data(sk, &timeo, NULL);
1591 if (unlikely(peek_seq != tp->copied_seq)) {
1592 if (net_ratelimit())
1593 pr_info("TCP(%s:%d), race in MSG_PEEK.\n",
1594 current->comm, current->pid);
1595 peek_seq = tp->copied_seq;
1600 avail = skb->len - offset;
1604 * Do we have urgent data here? We need to skip over the
1607 if (unlikely(tp->urg_data)) {
1608 u32 urg_offset = tp->urg_seq - peek_seq;
1610 if (urg_offset < avail) {
1612 * The amount of data we are preparing to copy
1613 * contains urgent data.
1615 if (!urg_offset) { /* First byte is urgent */
1616 if (!sock_flag(sk, SOCK_URGINLINE)) {
1624 /* stop short of the urgent data */
1631 * If MSG_TRUNC is specified the data is discarded.
1633 if (likely(!(flags & MSG_TRUNC)))
1634 if (skb_copy_datagram_msg(skb, offset, msg, len)) {
1649 int chtls_recvmsg(struct sock *sk, struct msghdr *msg, size_t len,
1650 int flags, int *addr_len)
1652 struct tcp_sock *tp = tcp_sk(sk);
1653 struct chtls_sock *csk;
1654 unsigned long avail; /* amount of available data in current skb */
1658 int target; /* Read at least this many bytes */
1662 if (unlikely(flags & MSG_OOB))
1663 return tcp_prot.recvmsg(sk, msg, len, flags, addr_len);
1665 if (unlikely(flags & MSG_PEEK))
1666 return peekmsg(sk, msg, len, flags);
1668 if (sk_can_busy_loop(sk) &&
1669 skb_queue_empty_lockless(&sk->sk_receive_queue) &&
1670 sk->sk_state == TCP_ESTABLISHED)
1671 sk_busy_loop(sk, flags & MSG_DONTWAIT);
1674 csk = rcu_dereference_sk_user_data(sk);
1677 return chtls_pt_recvmsg(sk, msg, len, flags, addr_len);
1679 timeo = sock_rcvtimeo(sk, flags & MSG_DONTWAIT);
1680 target = sock_rcvlowat(sk, flags & MSG_WAITALL, len);
1682 if (unlikely(csk_flag(sk, CSK_UPDATE_RCV_WND)))
1683 chtls_cleanup_rbuf(sk, copied);
1686 struct sk_buff *skb;
1689 if (unlikely(tp->urg_data && tp->urg_seq == tp->copied_seq)) {
1692 if (signal_pending(current)) {
1693 copied = timeo ? sock_intr_errno(timeo) :
1699 skb = skb_peek(&sk->sk_receive_queue);
1703 if (csk->wr_credits &&
1704 skb_queue_len(&csk->txq) &&
1705 chtls_push_frames(csk, csk->wr_credits ==
1706 csk->wr_max_credits))
1707 sk->sk_write_space(sk);
1709 if (copied >= target && !READ_ONCE(sk->sk_backlog.tail))
1713 if (sk->sk_err || sk->sk_state == TCP_CLOSE ||
1714 (sk->sk_shutdown & RCV_SHUTDOWN) ||
1715 signal_pending(current))
1718 if (sock_flag(sk, SOCK_DONE))
1721 copied = sock_error(sk);
1724 if (sk->sk_shutdown & RCV_SHUTDOWN)
1726 if (sk->sk_state == TCP_CLOSE) {
1734 if (signal_pending(current)) {
1735 copied = sock_intr_errno(timeo);
1740 if (READ_ONCE(sk->sk_backlog.tail)) {
1743 chtls_cleanup_rbuf(sk, copied);
1747 if (copied >= target)
1749 chtls_cleanup_rbuf(sk, copied);
1750 sk_wait_data(sk, &timeo, NULL);
1755 chtls_kfree_skb(sk, skb);
1756 if (!copied && !timeo) {
1761 if (copied < target)
1767 offset = tp->copied_seq - ULP_SKB_CB(skb)->seq;
1768 avail = skb->len - offset;
1772 if (unlikely(tp->urg_data)) {
1773 u32 urg_offset = tp->urg_seq - tp->copied_seq;
1775 if (urg_offset < avail) {
1778 } else if (!sock_flag(sk, SOCK_URGINLINE)) {
1788 if (likely(!(flags & MSG_TRUNC))) {
1789 if (skb_copy_datagram_msg(skb, offset,
1798 tp->copied_seq += avail;
1803 if (tp->urg_data && after(tp->copied_seq, tp->urg_seq))
1806 if (avail + offset >= skb->len) {
1807 chtls_free_skb(sk, skb);
1810 if (copied >= target &&
1811 !skb_peek(&sk->sk_receive_queue))
1817 chtls_cleanup_rbuf(sk, copied);