VCL event handling changes 50/11050/1
authorKeith Burns (alagalah) <alagalah@gmail.com>
Fri, 9 Mar 2018 00:46:25 +0000 (16:46 -0800)
committerKeith Burns (alagalah) <alagalah@gmail.com>
Fri, 9 Mar 2018 00:46:25 +0000 (16:46 -0800)
- added vce_get_event_handler()
- added check for event before blocking on mutex in vppcom_session_accept()

Change-Id: I8e19ea5fcbaa40279cb28152b9923ca8f1328670
Signed-off-by: Keith Burns (alagalah) <alagalah@gmail.com>
src/vcl/vcl_event.c
src/vcl/vcl_event.h
src/vcl/vppcom.c

index 65d2870..64f55b9 100644 (file)
@@ -79,6 +79,21 @@ vce_get_event_from_index(vce_event_thread_t *evt, u32 ev_idx)
   return ev;
 }
 
+vce_event_handler_reg_t *
+vce_get_event_handler (vce_event_thread_t *evt, vce_event_key_t *evk)
+{
+  vce_event_handler_reg_t *handler = 0;
+  uword *p;
+
+  clib_spinlock_lock (&evt->handlers_lockp);
+  p = hash_get (evt->handlers_index_by_event_key, evk->as_u64);
+  if (p)
+    handler = pool_elt_at_index (evt->vce_event_handlers, p[0]);
+  clib_spinlock_unlock (&evt->handlers_lockp);
+
+  return handler;
+}
+
 vce_event_handler_reg_t *
 vce_register_handler (vce_event_thread_t *evt, vce_event_key_t *evk,
                      vce_event_callback_t cb)
index 7b64ede..a2e247e 100644 (file)
@@ -100,6 +100,16 @@ void vce_clear_event (vce_event_thread_t *evt, vce_event_t *ev);
  */
 vce_event_t * vce_get_event_from_index(vce_event_thread_t *evt, u32 ev_idx);
 
+/**
+ * @brief vce_get_event_handler()
+ * - returns handler if exists or 0
+ * @param evt - vce_event_thread_t - event system state
+ * @param evk - event key
+ * @return vce_event_handler_reg_t *
+ */
+vce_event_handler_reg_t * vce_get_event_handler (vce_event_thread_t *evt,
+                                                vce_event_key_t *evk);
+
 /**
  * @brief vce_register_handler
  * - used by functions who need to be notified that an event has occurred
index 1f98576..4dea4aa 100644 (file)
@@ -2754,7 +2754,8 @@ vppcom_session_accept (uint32_t listen_session_index, vppcom_endpt_t * ep,
   reg = vce_register_handler (&vcm->event_thread, &evk,
                              vce_connect_request_handler_fn);
 
-  ev = 0;
+  ev = vce_get_event_from_index (&vcm->event_thread, reg->ev_idx);
+
   pthread_mutex_lock (&reg->handler_lock);
   while (!ev)
     {