I have a fix in progress for this one (I mean tell ASan to accept overflow there), I'll try to push it today.
Best ben > -----Original Message----- > From: vpp-dev@lists.fd.io <vpp-dev@lists.fd.io> On Behalf Of Damjan Marion > via lists.fd.io > Sent: jeudi 17 juin 2021 11:33 > To: jiangxiaom...@outlook.com > Cc: vpp-dev@lists.fd.io > Subject: Re: [vpp-dev] clib_mask_compare_u16_x64 has asan issue > > > yes, for performance reason it is written as it is, you can ask asan to > ignore it > > > — > Damjan > > > On 17.06.2021., at 11:28, jiangxiaom...@outlook.com wrote: > > > > Hi Damjan Marion, > > vector function: clib_mask_compare_u16_x64 has ASAN Issue, > > > > clib_mask_compare_u16_x64 (u16 v, u16 *a, u32 n_elts) > { > ... > u16x32u *av = (u16x32u *) a; > ... > > x = i8x32_pack (v16 == av[0], v16 == av[1]); <----- av[0] > will read 64 bytes, but a[0] only have 2 bytes > > > > This function will lead to session node crash if ASAS enabled > > > > > ================================================================= > > Program received signal SIGSEGV, Segmentation fault. > [Switching to Thread 0x7ff96f54d700 (LWP 113687)] > 0x00007ffff73de5c1 in > __asan::FakeStack::AddrIsInFakeStack(unsigned long, unsigned long*, > unsigned long*) () from /home/dev/code/net- > base/dist/script/test/../../lib/libasan.so.5 > Missing separate debuginfos, use: debuginfo-install libgcc- > 4.8.5-44.el7.x86_64 libstdc++-4.8.5-44.el7.x86_64 libuuid-2.23.2- > 65.el7_9.1.x86_64 mbedtls-2.7.17-1.el7.x86_64 pkcs11-helper-1.11- > 3.el7.x86_64 > (gdb) bt > #0 0x00007ffff73de5c1 in > __asan::FakeStack::AddrIsInFakeStack(unsigned long, unsigned long*, > unsigned long*) () from /home/dev/code/net- > base/dist/script/test/../../lib/libasan.so.5 > #1 0x00007ffff74c5a11 in > __asan::ThreadStackContainsAddress(__sanitizer::ThreadContextBase*, void*) > () from /home/dev/code/net-base/dist/script/test/../../lib/libasan.so.5 > #2 0x00007ffff74dfdc2 in > __sanitizer::ThreadRegistry::FindThreadContextLocked(bool > (*)(__sanitizer::ThreadContextBase*, void*), void*) () from > /home/dev/code/net-base/dist/script/test/../../lib/libasan.so.5 > #3 0x00007ffff74c6e5a in > __asan::FindThreadByStackAddress(unsigned long) () from > /home/dev/code/net-base/dist/script/test/../../lib/libasan.so.5 > #4 0x00007ffff73d8fb6 in > __asan::GetStackAddressInformation(unsigned long, unsigned long, > __asan::StackAddressDescription*) () from /home/dev/code/net- > base/dist/script/test/../../lib/libasan.so.5 > #5 0x00007ffff73da3f9 in > __asan::AddressDescription::AddressDescription(unsigned long, unsigned > long, bool) () from /home/dev/code/net- > base/dist/script/test/../../lib/libasan.so.5 > #6 0x00007ffff73dce51 in > __asan::ErrorGeneric::ErrorGeneric(unsigned int, unsigned long, unsigned > long, unsigned long, unsigned long, bool, unsigned long) () from > /home/dev/code/net-base/dist/script/test/../../lib/libasan.so.5 > #7 0x00007ffff74c0c2a in __asan::ReportGenericError(unsigned > long, unsigned long, unsigned long, unsigned long, bool, unsigned long, > unsigned int, bool) () from /home/dev/code/net- > base/dist/script/test/../../lib/libasan.so.5 > #8 0x00007ffff74c2194 in __asan_report_load_n () from > /home/dev/code/net-base/dist/script/test/../../lib/libasan.so.5 > #9 0x00007ffff41c34c5 in clib_mask_compare_u16_x64 (v=2, > a=0x7fffd38cb980, n_elts=1) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vppinfra/vector_funcs.h:24 > #10 0x00007ffff41c374c in clib_mask_compare_u16 (v=2, > a=0x7fffd38cb980, mask=0x7ff96ecf5310, n_elts=1) at /home/dev/code/net- > base/.vpp-21.06-rc2/src/vppinfra/vector_funcs.h:79 > #11 0x00007ffff41c3b7b in enqueue_one (vm=0x7fffd1c73080, > node=0x7fffd2d21040, used_elt_bmp=0x7ff96ecf5440, next_index=2, > buffers=0x7fffd1d3b2d0, nexts=0x7fffd38cb980, n_buffers=1, n_left=1, > tmp=0x7ff96ecf5480) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/buffer_funcs.c:30 > #12 0x00007ffff41fe451 in vlib_buffer_enqueue_to_next_fn_hsw > (vm=0x7fffd1c73080, node=0x7fffd2d21040, buffers=0x7fffd1d3b2d0, > nexts=0x7fffd38cb980, count=1) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/buffer_funcs.c:110 > #13 0x00007ffff5aff172 in vlib_buffer_enqueue_to_next > (vm=0x7fffd1c73080, node=0x7fffd2d21040, buffers=0x7fffd1d3b2d0, > nexts=0x7fffd38cb980, count=1) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/buffer_node.h:344 > #14 0x00007ffff5b16b0a in session_flush_pending_tx_buffers > (wrk=0x7fffd4d1ad40, node=0x7fffd2d21040) at /home/dev/code/net-base/.vpp- > 21.06-rc2/src/vnet/session/session_node.c:1626 > #15 0x00007ffff5b1a3db in session_queue_node_fn > (vm=0x7fffd1c73080, node=0x7fffd2d21040, frame=0x0) at /home/dev/code/net- > base/.vpp-21.06-rc2/src/vnet/session/session_node.c:1793 > #16 0x00007ffff40a1bfb in dispatch_node (vm=0x7fffd1c73080, > node=0x7fffd2d21040, type=VLIB_NODE_TYPE_INPUT, > dispatch_state=VLIB_NODE_STATE_POLLING, frame=0x0, > last_time_stamp=101201619637438) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/main.c:1024 > #17 0x00007ffff40a6aef in vlib_main_or_worker_loop > (vm=0x7fffd1c73080, is_main=0) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/main.c:1618 > #18 0x00007ffff40a8713 in vlib_worker_loop (vm=0x7fffd1c73080) > at /home/dev/code/net-base/.vpp-21.06-rc2/src/vlib/main.c:1783 > #19 0x00007ffff413f573 in vlib_worker_thread_fn > (arg=0x7fffd685c500) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/threads.c:1562 > #20 0x00007ffff377b504 in clib_calljmp () at > /home/dev/code/net-base/.vpp-21.06-rc2/src/vppinfra/longjmp.S:123 > #21 0x00007ff96f54cc30 in ?? () > #22 0x00007ffff4132d71 in vlib_worker_thread_bootstrap_fn > (arg=0x7fffd685c500) at /home/dev/code/net-base/.vpp-21.06- > rc2/src/vlib/threads.c:431 > #23 0x00007fffc8dce4bd in eal_thread_loop (arg=0x0) at ../src- > dpdk/lib/librte_eal/linux/eal_thread.c:127 > #24 0x00007ffff3b4cea5 in start_thread (arg=0x7ff96f54d700) at > pthread_create.c:307 > #25 0x00007ffff30d49fd in clone () at > ../sysdeps/unix/sysv/linux/x86_64/clone.S:111 > (gdb) > > > > >
-=-=-=-=-=-=-=-=-=-=-=- Links: You receive all messages sent to this group. View/Reply Online (#19595): https://lists.fd.io/g/vpp-dev/message/19595 Mute This Topic: https://lists.fd.io/mt/83600497/21656 Group Owner: vpp-dev+ow...@lists.fd.io Unsubscribe: https://lists.fd.io/g/vpp-dev/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-