api: pass api and client main to rx thread 95/23895/4
authorFlorin Coras <fcoras@cisco.com>
Tue, 10 Dec 2019 00:42:50 +0000 (16:42 -0800)
committerDave Barach <openvpp@barachs.net>
Tue, 10 Dec 2019 12:28:47 +0000 (12:28 +0000)
Type: fix

Change-Id: Ib8313e87a89c80045edd897924917a88b98d1937
Signed-off-by: Florin Coras <fcoras@cisco.com>
src/vlibapi/api_common.h
src/vlibmemory/memory_client.c
src/vlibmemory/memory_client.h

index c3ef573..4d40104 100644 (file)
@@ -378,6 +378,12 @@ vlibapi_get_main (void)
   return my_api_main;
 }
 
+always_inline void
+vlibapi_set_main (api_main_t * am)
+{
+  my_api_main = am;
+}
+
 #endif /* included_api_common_h */
 
 /*
index f78288e..b509063 100644 (file)
 memory_client_main_t memory_client_main;
 __thread memory_client_main_t *my_memory_client_main = &memory_client_main;
 
+typedef struct rx_thread_fn_arg
+{
+  api_main_t *am;
+  memory_client_main_t *mm;
+} rx_thread_fn_arg_t;
+
 static void *
 rx_thread_fn (void *arg)
 {
+  rx_thread_fn_arg_t *a = (rx_thread_fn_arg_t *) arg;
+  memory_client_main_t *mm;
   svm_queue_t *q;
-  memory_client_main_t *mm = vlibapi_get_memory_client_main ();
 
+  vlibapi_set_main (a->am);
+  vlibapi_set_memory_client_main (a->mm);
+  clib_mem_free (a);
+
+  mm = vlibapi_get_memory_client_main ();
   q = vlibapi_get_main ()->vl_input_queue;
 
   /* So we can make the rx thread terminate cleanly */
@@ -419,6 +431,15 @@ connect_to_vlib_internal (const char *svm_name,
 
   if (thread_fn)
     {
+      if (thread_fn == rx_thread_fn)
+       {
+         rx_thread_fn_arg_t *arg;
+         arg = clib_mem_alloc (sizeof (*arg));
+         arg->am = vlibapi_get_main ();
+         arg->mm = vlibapi_get_memory_client_main ();
+         thread_fn_arg = (void *) arg;
+       }
+
       rv = pthread_create (&mm->rx_thread_handle,
                           NULL /*attr */ , thread_fn, thread_fn_arg);
       if (rv)
index 4d79478..a016869 100644 (file)
@@ -70,6 +70,12 @@ vlibapi_get_memory_client_main (void)
   return my_memory_client_main;
 }
 
+always_inline void
+vlibapi_set_memory_client_main (memory_client_main_t * mm)
+{
+  my_memory_client_main = mm;
+}
+
 #endif /* SRC_VLIBMEMORY_MEMORY_CLIENT_H_ */
 
 /*