Added tls rx stats and reset tls rx/tx stats when chtls driver unload.
Signed-off-by: Vinay Kumar Yadav <vinay.yadav@chelsio.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
 {
        struct chtls_sock *csk = rcu_dereference_sk_user_data(sk);
        struct chtls_hws *hws = &csk->tlshws;
+       struct net_device *dev = csk->egress_dev;
+       struct adapter *adap = netdev2adap(dev);
        struct tcp_sock *tp = tcp_sk(sk);
        unsigned long avail;
        int buffers_freed;
                                tp->copied_seq += skb->len;
                                hws->rcvpld = skb->hdr_len;
                        } else {
+                               atomic_inc(&adap->chcr_stats.tls_pdu_rx);
                                tp->copied_seq += hws->rcvpld;
                        }
                        chtls_free_skb(sk, skb);
 
 {
        struct tls_toe_device *dev;
        struct chtls_dev *cdev;
+       struct adapter *adap;
 
        dev = container_of(kref, struct tls_toe_device, kref);
        cdev = to_chtls_dev(dev);
+
+       /* Reset tls rx/tx stats */
+       adap = pci_get_drvdata(cdev->pdev);
+       atomic_set(&adap->chcr_stats.tls_pdu_tx, 0);
+       atomic_set(&adap->chcr_stats.tls_pdu_rx, 0);
+
        chtls_free_uld(cdev);
 }