diff options
author | Florin Coras <fcoras@cisco.com> | 2019-08-13 08:35:39 -0700 |
---|---|---|
committer | Florin Coras <fcoras@cisco.com> | 2019-08-13 08:35:39 -0700 |
commit | 5d8a806144fbf46c0575ef24ae081724dfbdbe75 (patch) | |
tree | cea8698b94cb6ce57e9d7644719c3f4cf8382c9f /src/vnet/session | |
parent | d8ca1e4a3f40c7c383412cd4a9aa42bf7c8ec270 (diff) |
session: fix enqueue notification on 32bit systems
Type:fix
Change-Id: I7b5566525fc30fe0d3cc8cd991960f6ed2f1fc27
Signed-off-by: Florin Coras <fcoras@cisco.com>
Diffstat (limited to 'src/vnet/session')
-rw-r--r-- | src/vnet/session/session.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/src/vnet/session/session.c b/src/vnet/session/session.c index 7b53a47023a..a102825c6f5 100644 --- a/src/vnet/session/session.c +++ b/src/vnet/session/session.c @@ -568,10 +568,10 @@ session_enqueue_notify (session_t * s) static void session_enqueue_notify_rpc (void *arg) { - session_handle_t sh = (session_handle_t) arg; + u32 session_index = pointer_to_uword (arg); session_t *s; - s = session_get_from_handle_if_valid (sh); + s = session_get_if_valid (session_index, vlib_get_thread_index ()); if (!s) return; @@ -586,8 +586,15 @@ void session_enqueue_notify_thread (session_handle_t sh) { u32 thread_index = session_thread_from_handle (sh); + u32 session_index = session_index_from_handle (sh); + + /* + * Pass session index (u32) as opposed to handle (u64) in case pointers + * are not 64-bit. + */ session_send_rpc_evt_to_thread (thread_index, - session_enqueue_notify_rpc, (void *) sh); + session_enqueue_notify_rpc, + uword_to_pointer (session_index, void *)); } int |