Add routine to flush context from CPT context processor cache.
Signed-off-by: Aakash Sasidharan <asasidharan@marvell.com>
Signed-off-by: Vidya Sagar Velumuri <vvelumuri@marvell.com>
Acked-by: Akhil Goyal <gakhil@marvell.com>
        return rc;
 }
 
+int
+roc_cpt_lf_ctx_flush(struct roc_cpt_lf *lf, uint64_t cptr)
+{
+       union cpt_lf_ctx_flush reg;
+
+       if (lf == NULL)
+               return -ENOTSUP;
+
+       reg.u = 0;
+       reg.s.pf_func = lf->pf_func;
+       reg.s.inval = 1;
+       reg.s.cptr = cptr;
+
+       plt_write64(reg.u, lf->rbase + CPT_LF_CTX_FLUSH);
+
+       return 0;
+}
+
 void
 cpt_lf_fini(struct roc_cpt_lf *lf)
 {
 
 void __roc_api roc_cpt_dev_clear(struct roc_cpt *roc_cpt);
 int __roc_api roc_cpt_lf_init(struct roc_cpt *roc_cpt, struct roc_cpt_lf *lf);
 void __roc_api roc_cpt_lf_fini(struct roc_cpt_lf *lf);
+int __roc_api roc_cpt_lf_ctx_flush(struct roc_cpt_lf *lf, uint64_t cptr);
 int __roc_api roc_cpt_afs_print(struct roc_cpt *roc_cpt);
 int __roc_api roc_cpt_lfs_print(struct roc_cpt *roc_cpt);
 void __roc_api roc_cpt_iq_disable(struct roc_cpt_lf *lf);
 
        roc_cpt_dev_init;
        roc_cpt_eng_grp_add;
        roc_cpt_iq_disable;
+       roc_cpt_lf_ctx_flush;
        roc_cpt_lf_init;
        roc_cpt_lf_fini;
        roc_cpt_lfs_print;