Here it is: https://gerrit.fd.io/r/c/vpp/+/32765
Note you also need https://gerrit.fd.io/r/c/vpp/+/32764/ to avoid false 
positives.

Best
ben

> -----Original Message-----
> From: Benoit Ganne (bganne)
> Sent: jeudi 17 juin 2021 11:40
> To: dmar...@me.com; jiangxiaom...@outlook.com
> Cc: vpp-dev@lists.fd.io
> Subject: RE: [vpp-dev] clib_mask_compare_u16_x64 has asan issue
> 
> 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 (#19599): https://lists.fd.io/g/vpp-dev/message/19599
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]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to