scsi: cxgb4i: libcxgbi: add active open cmd for T6 adapters
Add T6 active open cmd to open active connections on T6 adapters. Signed-off-by: Varun Prakash <varun@chelsio.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
e0eed8ab73
commit
586be7cb69
|
@ -189,7 +189,6 @@ static void send_act_open_req(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
struct l2t_entry *e)
|
struct l2t_entry *e)
|
||||||
{
|
{
|
||||||
struct cxgb4_lld_info *lldi = cxgbi_cdev_priv(csk->cdev);
|
struct cxgb4_lld_info *lldi = cxgbi_cdev_priv(csk->cdev);
|
||||||
int t4 = is_t4(lldi->adapter_type);
|
|
||||||
int wscale = cxgbi_sock_compute_wscale(csk->mss_idx);
|
int wscale = cxgbi_sock_compute_wscale(csk->mss_idx);
|
||||||
unsigned long long opt0;
|
unsigned long long opt0;
|
||||||
unsigned int opt2;
|
unsigned int opt2;
|
||||||
|
@ -232,7 +231,7 @@ static void send_act_open_req(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
csk, &req->local_ip, ntohs(req->local_port),
|
csk, &req->local_ip, ntohs(req->local_port),
|
||||||
&req->peer_ip, ntohs(req->peer_port),
|
&req->peer_ip, ntohs(req->peer_port),
|
||||||
csk->atid, csk->rss_qid);
|
csk->atid, csk->rss_qid);
|
||||||
} else {
|
} else if (is_t5(lldi->adapter_type)) {
|
||||||
struct cpl_t5_act_open_req *req =
|
struct cpl_t5_act_open_req *req =
|
||||||
(struct cpl_t5_act_open_req *)skb->head;
|
(struct cpl_t5_act_open_req *)skb->head;
|
||||||
u32 isn = (prandom_u32() & ~7UL) - 1;
|
u32 isn = (prandom_u32() & ~7UL) - 1;
|
||||||
|
@ -260,12 +259,45 @@ static void send_act_open_req(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
csk, &req->local_ip, ntohs(req->local_port),
|
csk, &req->local_ip, ntohs(req->local_port),
|
||||||
&req->peer_ip, ntohs(req->peer_port),
|
&req->peer_ip, ntohs(req->peer_port),
|
||||||
csk->atid, csk->rss_qid);
|
csk->atid, csk->rss_qid);
|
||||||
|
} else {
|
||||||
|
struct cpl_t6_act_open_req *req =
|
||||||
|
(struct cpl_t6_act_open_req *)skb->head;
|
||||||
|
u32 isn = (prandom_u32() & ~7UL) - 1;
|
||||||
|
|
||||||
|
INIT_TP_WR(req, 0);
|
||||||
|
OPCODE_TID(req) = cpu_to_be32(MK_OPCODE_TID(CPL_ACT_OPEN_REQ,
|
||||||
|
qid_atid));
|
||||||
|
req->local_port = csk->saddr.sin_port;
|
||||||
|
req->peer_port = csk->daddr.sin_port;
|
||||||
|
req->local_ip = csk->saddr.sin_addr.s_addr;
|
||||||
|
req->peer_ip = csk->daddr.sin_addr.s_addr;
|
||||||
|
req->opt0 = cpu_to_be64(opt0);
|
||||||
|
req->params = cpu_to_be64(FILTER_TUPLE_V(
|
||||||
|
cxgb4_select_ntuple(
|
||||||
|
csk->cdev->ports[csk->port_id],
|
||||||
|
csk->l2t)));
|
||||||
|
req->rsvd = cpu_to_be32(isn);
|
||||||
|
|
||||||
|
opt2 |= T5_ISS_VALID;
|
||||||
|
opt2 |= RX_FC_DISABLE_F;
|
||||||
|
opt2 |= T5_OPT_2_VALID_F;
|
||||||
|
|
||||||
|
req->opt2 = cpu_to_be32(opt2);
|
||||||
|
req->rsvd2 = cpu_to_be32(0);
|
||||||
|
req->opt3 = cpu_to_be32(0);
|
||||||
|
|
||||||
|
log_debug(1 << CXGBI_DBG_TOE | 1 << CXGBI_DBG_SOCK,
|
||||||
|
"csk t6 0x%p, %pI4:%u-%pI4:%u, atid %d, qid %u.\n",
|
||||||
|
csk, &req->local_ip, ntohs(req->local_port),
|
||||||
|
&req->peer_ip, ntohs(req->peer_port),
|
||||||
|
csk->atid, csk->rss_qid);
|
||||||
}
|
}
|
||||||
|
|
||||||
set_wr_txq(skb, CPL_PRIORITY_SETUP, csk->port_id);
|
set_wr_txq(skb, CPL_PRIORITY_SETUP, csk->port_id);
|
||||||
|
|
||||||
pr_info_ipaddr("t%d csk 0x%p,%u,0x%lx,%u, rss_qid %u.\n",
|
pr_info_ipaddr("t%d csk 0x%p,%u,0x%lx,%u, rss_qid %u.\n",
|
||||||
(&csk->saddr), (&csk->daddr), t4 ? 4 : 5, csk,
|
(&csk->saddr), (&csk->daddr),
|
||||||
|
CHELSIO_CHIP_VERSION(lldi->adapter_type), csk,
|
||||||
csk->state, csk->flags, csk->atid, csk->rss_qid);
|
csk->state, csk->flags, csk->atid, csk->rss_qid);
|
||||||
|
|
||||||
cxgb4_l2t_send(csk->cdev->ports[csk->port_id], skb, csk->l2t);
|
cxgb4_l2t_send(csk->cdev->ports[csk->port_id], skb, csk->l2t);
|
||||||
|
@ -276,7 +308,6 @@ static void send_act_open_req6(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
struct l2t_entry *e)
|
struct l2t_entry *e)
|
||||||
{
|
{
|
||||||
struct cxgb4_lld_info *lldi = cxgbi_cdev_priv(csk->cdev);
|
struct cxgb4_lld_info *lldi = cxgbi_cdev_priv(csk->cdev);
|
||||||
int t4 = is_t4(lldi->adapter_type);
|
|
||||||
int wscale = cxgbi_sock_compute_wscale(csk->mss_idx);
|
int wscale = cxgbi_sock_compute_wscale(csk->mss_idx);
|
||||||
unsigned long long opt0;
|
unsigned long long opt0;
|
||||||
unsigned int opt2;
|
unsigned int opt2;
|
||||||
|
@ -294,10 +325,9 @@ static void send_act_open_req6(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
|
|
||||||
opt2 = RX_CHANNEL_V(0) |
|
opt2 = RX_CHANNEL_V(0) |
|
||||||
RSS_QUEUE_VALID_F |
|
RSS_QUEUE_VALID_F |
|
||||||
RX_FC_DISABLE_F |
|
|
||||||
RSS_QUEUE_V(csk->rss_qid);
|
RSS_QUEUE_V(csk->rss_qid);
|
||||||
|
|
||||||
if (t4) {
|
if (is_t4(lldi->adapter_type)) {
|
||||||
struct cpl_act_open_req6 *req =
|
struct cpl_act_open_req6 *req =
|
||||||
(struct cpl_act_open_req6 *)skb->head;
|
(struct cpl_act_open_req6 *)skb->head;
|
||||||
|
|
||||||
|
@ -322,7 +352,7 @@ static void send_act_open_req6(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
req->params = cpu_to_be32(cxgb4_select_ntuple(
|
req->params = cpu_to_be32(cxgb4_select_ntuple(
|
||||||
csk->cdev->ports[csk->port_id],
|
csk->cdev->ports[csk->port_id],
|
||||||
csk->l2t));
|
csk->l2t));
|
||||||
} else {
|
} else if (is_t5(lldi->adapter_type)) {
|
||||||
struct cpl_t5_act_open_req6 *req =
|
struct cpl_t5_act_open_req6 *req =
|
||||||
(struct cpl_t5_act_open_req6 *)skb->head;
|
(struct cpl_t5_act_open_req6 *)skb->head;
|
||||||
|
|
||||||
|
@ -345,12 +375,41 @@ static void send_act_open_req6(struct cxgbi_sock *csk, struct sk_buff *skb,
|
||||||
req->params = cpu_to_be64(FILTER_TUPLE_V(cxgb4_select_ntuple(
|
req->params = cpu_to_be64(FILTER_TUPLE_V(cxgb4_select_ntuple(
|
||||||
csk->cdev->ports[csk->port_id],
|
csk->cdev->ports[csk->port_id],
|
||||||
csk->l2t)));
|
csk->l2t)));
|
||||||
|
} else {
|
||||||
|
struct cpl_t6_act_open_req6 *req =
|
||||||
|
(struct cpl_t6_act_open_req6 *)skb->head;
|
||||||
|
|
||||||
|
INIT_TP_WR(req, 0);
|
||||||
|
OPCODE_TID(req) = cpu_to_be32(MK_OPCODE_TID(CPL_ACT_OPEN_REQ6,
|
||||||
|
qid_atid));
|
||||||
|
req->local_port = csk->saddr6.sin6_port;
|
||||||
|
req->peer_port = csk->daddr6.sin6_port;
|
||||||
|
req->local_ip_hi = *(__be64 *)(csk->saddr6.sin6_addr.s6_addr);
|
||||||
|
req->local_ip_lo = *(__be64 *)(csk->saddr6.sin6_addr.s6_addr +
|
||||||
|
8);
|
||||||
|
req->peer_ip_hi = *(__be64 *)(csk->daddr6.sin6_addr.s6_addr);
|
||||||
|
req->peer_ip_lo = *(__be64 *)(csk->daddr6.sin6_addr.s6_addr +
|
||||||
|
8);
|
||||||
|
req->opt0 = cpu_to_be64(opt0);
|
||||||
|
|
||||||
|
opt2 |= RX_FC_DISABLE_F;
|
||||||
|
opt2 |= T5_OPT_2_VALID_F;
|
||||||
|
|
||||||
|
req->opt2 = cpu_to_be32(opt2);
|
||||||
|
|
||||||
|
req->params = cpu_to_be64(FILTER_TUPLE_V(cxgb4_select_ntuple(
|
||||||
|
csk->cdev->ports[csk->port_id],
|
||||||
|
csk->l2t)));
|
||||||
|
|
||||||
|
req->rsvd2 = cpu_to_be32(0);
|
||||||
|
req->opt3 = cpu_to_be32(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
set_wr_txq(skb, CPL_PRIORITY_SETUP, csk->port_id);
|
set_wr_txq(skb, CPL_PRIORITY_SETUP, csk->port_id);
|
||||||
|
|
||||||
pr_info("t%d csk 0x%p,%u,0x%lx,%u, [%pI6]:%u-[%pI6]:%u, rss_qid %u.\n",
|
pr_info("t%d csk 0x%p,%u,0x%lx,%u, [%pI6]:%u-[%pI6]:%u, rss_qid %u.\n",
|
||||||
t4 ? 4 : 5, csk, csk->state, csk->flags, csk->atid,
|
CHELSIO_CHIP_VERSION(lldi->adapter_type), csk, csk->state,
|
||||||
|
csk->flags, csk->atid,
|
||||||
&csk->saddr6.sin6_addr, ntohs(csk->saddr.sin_port),
|
&csk->saddr6.sin6_addr, ntohs(csk->saddr.sin_port),
|
||||||
&csk->daddr6.sin6_addr, ntohs(csk->daddr.sin_port),
|
&csk->daddr6.sin6_addr, ntohs(csk->daddr.sin_port),
|
||||||
csk->rss_qid);
|
csk->rss_qid);
|
||||||
|
@ -1382,7 +1441,6 @@ static int init_act_open(struct cxgbi_sock *csk)
|
||||||
void *daddr;
|
void *daddr;
|
||||||
unsigned int step;
|
unsigned int step;
|
||||||
unsigned int size, size6;
|
unsigned int size, size6;
|
||||||
int t4 = is_t4(lldi->adapter_type);
|
|
||||||
unsigned int linkspeed;
|
unsigned int linkspeed;
|
||||||
unsigned int rcv_winf, snd_winf;
|
unsigned int rcv_winf, snd_winf;
|
||||||
|
|
||||||
|
@ -1428,12 +1486,15 @@ static int init_act_open(struct cxgbi_sock *csk)
|
||||||
cxgb4_clip_get(ndev, (const u32 *)&csk->saddr6.sin6_addr, 1);
|
cxgb4_clip_get(ndev, (const u32 *)&csk->saddr6.sin6_addr, 1);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (t4) {
|
if (is_t4(lldi->adapter_type)) {
|
||||||
size = sizeof(struct cpl_act_open_req);
|
size = sizeof(struct cpl_act_open_req);
|
||||||
size6 = sizeof(struct cpl_act_open_req6);
|
size6 = sizeof(struct cpl_act_open_req6);
|
||||||
} else {
|
} else if (is_t5(lldi->adapter_type)) {
|
||||||
size = sizeof(struct cpl_t5_act_open_req);
|
size = sizeof(struct cpl_t5_act_open_req);
|
||||||
size6 = sizeof(struct cpl_t5_act_open_req6);
|
size6 = sizeof(struct cpl_t5_act_open_req6);
|
||||||
|
} else {
|
||||||
|
size = sizeof(struct cpl_t6_act_open_req);
|
||||||
|
size6 = sizeof(struct cpl_t6_act_open_req6);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (csk->csk_family == AF_INET)
|
if (csk->csk_family == AF_INET)
|
||||||
|
@ -1794,7 +1855,8 @@ static void *t4_uld_add(const struct cxgb4_lld_info *lldi)
|
||||||
cdev->nports = lldi->nports;
|
cdev->nports = lldi->nports;
|
||||||
cdev->mtus = lldi->mtus;
|
cdev->mtus = lldi->mtus;
|
||||||
cdev->nmtus = NMTUS;
|
cdev->nmtus = NMTUS;
|
||||||
cdev->rx_credit_thres = cxgb4i_rx_credit_thres;
|
cdev->rx_credit_thres = (CHELSIO_CHIP_VERSION(lldi->adapter_type) <=
|
||||||
|
CHELSIO_T5) ? cxgb4i_rx_credit_thres : 0;
|
||||||
cdev->skb_tx_rsvd = CXGB4I_TX_HEADER_LEN;
|
cdev->skb_tx_rsvd = CXGB4I_TX_HEADER_LEN;
|
||||||
cdev->skb_rx_extra = sizeof(struct cpl_iscsi_hdr);
|
cdev->skb_rx_extra = sizeof(struct cpl_iscsi_hdr);
|
||||||
cdev->itp = &cxgb4i_iscsi_transport;
|
cdev->itp = &cxgb4i_iscsi_transport;
|
||||||
|
|
|
@ -1627,15 +1627,15 @@ static void csk_return_rx_credits(struct cxgbi_sock *csk, int copied)
|
||||||
csk->rcv_wup, cdev->rx_credit_thres,
|
csk->rcv_wup, cdev->rx_credit_thres,
|
||||||
csk->rcv_win);
|
csk->rcv_win);
|
||||||
|
|
||||||
|
if (!cdev->rx_credit_thres)
|
||||||
|
return;
|
||||||
|
|
||||||
if (csk->state != CTP_ESTABLISHED)
|
if (csk->state != CTP_ESTABLISHED)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
credits = csk->copied_seq - csk->rcv_wup;
|
credits = csk->copied_seq - csk->rcv_wup;
|
||||||
if (unlikely(!credits))
|
if (unlikely(!credits))
|
||||||
return;
|
return;
|
||||||
if (unlikely(cdev->rx_credit_thres == 0))
|
|
||||||
return;
|
|
||||||
|
|
||||||
must_send = credits + 16384 >= csk->rcv_win;
|
must_send = credits + 16384 >= csk->rcv_win;
|
||||||
if (must_send || credits >= cdev->rx_credit_thres)
|
if (must_send || credits >= cdev->rx_credit_thres)
|
||||||
csk->rcv_wup += cdev->csk_send_rx_credits(csk, credits);
|
csk->rcv_wup += cdev->csk_send_rx_credits(csk, credits);
|
||||||
|
|
Loading…
Reference in New Issue