Hi Benoit,

Thank you I will have another go tomorrow.


On 17/06/2021, 15:28, "Benoit Ganne (bganne) via lists.fd.io" 
<vpp-dev@lists.fd.io on behalf of bganne=cisco....@lists.fd.io> wrote:

    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 (#19601): https://lists.fd.io/g/vpp-dev/message/19601
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