int                             status;
 };
 
+struct fcloop_rscn {
+       struct fcloop_tport             *tport;
+       struct work_struct              work;
+};
+
 enum {
        INI_IO_START            = 0,
        INI_IO_ACTIVE           = 1,
        return 0;
 }
 
+/*
+ * Simulate reception of RSCN and converting it to a initiator transport
+ * call to rescan a remote port.
+ */
+static void
+fcloop_tgt_rscn_work(struct work_struct *work)
+{
+       struct fcloop_rscn *tgt_rscn =
+               container_of(work, struct fcloop_rscn, work);
+       struct fcloop_tport *tport = tgt_rscn->tport;
+
+       if (tport->remoteport)
+               nvme_fc_rescan_remoteport(tport->remoteport);
+       kfree(tgt_rscn);
+}
+
+static void
+fcloop_tgt_discovery_evt(struct nvmet_fc_target_port *tgtport)
+{
+       struct fcloop_rscn *tgt_rscn;
+
+       tgt_rscn = kzalloc(sizeof(*tgt_rscn), GFP_KERNEL);
+       if (!tgt_rscn)
+               return;
+
+       tgt_rscn->tport = tgtport->private;
+       INIT_WORK(&tgt_rscn->work, fcloop_tgt_rscn_work);
+
+       schedule_work(&tgt_rscn->work);
+}
+
 static void
 fcloop_tfcp_req_free(struct kref *ref)
 {
        .fcp_op                 = fcloop_fcp_op,
        .fcp_abort              = fcloop_tgt_fcp_abort,
        .fcp_req_release        = fcloop_fcp_req_release,
+       .discovery_event        = fcloop_tgt_discovery_evt,
        .max_hw_queues          = FCLOOP_HW_QUEUES,
        .max_sgl_segments       = FCLOOP_SGL_SEGS,
        .max_dif_sgl_segments   = FCLOOP_SGL_SEGS,