Jiri Daněk created DISPATCH-2181:
------------------------------------

             Summary: Data race coming from Proton 
(pni_raw_connection_process/post_event) in system_tests_tcp_adaptor
                 Key: DISPATCH-2181
                 URL: https://issues.apache.org/jira/browse/DISPATCH-2181
             Project: Qpid Dispatch
          Issue Type: Bug
    Affects Versions: 1.17.0
            Reporter: Jiri Daněk


PR build, but  containing only CMake changes, unlikely to have caused this.

https://github.com/apache/qpid-dispatch/pull/1267/checks?check_run_id=2872865179#step:25:5231

{noformat}
71: ::TcpAdaptor::test_80_stats 2021-06-21 07:43:37.568445 test_80 check stats 
in qdmanage START
71: 2021-06-21 07:43:37.872270 test_80 check stats in qdmanage SUCCESS
71: PASSED2021-06-21 07:43:37.874339 TCP_TEST Stopping echo server ES_INTA
71: 2021-06-21 07:43:37.975012 TCP_TEST Stopping echo server ES_INTB
71: 2021-06-21 07:43:38.075261 TCP_TEST Stopping echo server ES_INTC
71: 2021-06-21 07:43:38.131639 TCP_TEST Stopping echo server ES_EA1
71: 2021-06-21 07:43:38.183962 TCP_TEST Stopping echo server ES_EA2
71: 2021-06-21 07:43:38.275843 TCP_TEST Stopping echo server ES_EB1
71: 2021-06-21 07:43:38.376357 TCP_TEST Stopping echo server ES_EB2
71: 2021-06-21 07:43:38.476605 TCP_TEST Stopping echo server ES_EC1
71: 2021-06-21 07:43:38.569269 TCP_TEST Stopping echo server ES_EC2
71: 2021-06-21 07:43:38.655474 TCP_TEST Stopping echo server NS_EC2_CONN_STALL
71: 
71: Router INTA output file:
71: >>>>
71: ==================
71: WARNING: ThreadSanitizer: data race (pid=3231)
71:   Write of size 4 at 0x7b6800032338 by thread T4 (mutexes: write M261):
71:     #0 post_event 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2304
 (libqpid-proton-proactor.so.1+0x14108)
71:     #1 poller_do_epoll 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2534
 (libqpid-proton-proactor.so.1+0x14108)
71:     #2 next_event_batch 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2438
 (libqpid-proton-proactor.so.1+0x14108)
71:     #3 pn_proactor_wait 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2650
 (libqpid-proton-proactor.so.1+0x14622)
71:     #4 thread_run 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1106 
(qdrouterd+0x4e3ebe)
71:     #5 _thread_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
 (qdrouterd+0x4868bd)
71: 
71:   Previous read of size 4 at 0x7b6800032338 by thread T2 (mutexes: write 
M2585):
71:     #0 pni_raw_connection_process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll_raw_connection.c:355
 (libqpid-proton-proactor.so.1+0x108ec)
71:     #1 process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2230
 (libqpid-proton-proactor.so.1+0x108ec)
71:     #2 next_event_batch 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2419
 (libqpid-proton-proactor.so.1+0x108ec)
71:     #3 pn_proactor_wait 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2650
 (libqpid-proton-proactor.so.1+0x14622)
71:     #4 thread_run 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1106 
(qdrouterd+0x4e3ebe)
71:     #5 _thread_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
 (qdrouterd+0x4868bd)
71: 
71:   Location is heap block of size 1536 at 0x7b6800031e00 allocated by thread 
T4:
71:     #0 calloc <null> (libtsan.so.0+0x32b3e)
71:     #1 pn_raw_connection 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll_raw_connection.c:168
 (libqpid-proton-proactor.so.1+0xdf82)
71:     #2 qdr_tcp_connection_egress 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:1086
 (qdrouterd+0x448b52)
71:     #3 qdr_tcp_deliver 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:1531
 (qdrouterd+0x448e86)
71:     #4 qdr_link_process_deliveries 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/transfer.c:178
 (qdrouterd+0x4c43d0)
71:     #5 qdr_tcp_push 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:1509
 (qdrouterd+0x44707c)
71:     #6 qdr_connection_process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/connections.c:414
 (qdrouterd+0x497c7d)
71:     #7 on_activate 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:186
 (qdrouterd+0x449491)
71:     #8 qd_timer_visit 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/timer.c:316 
(qdrouterd+0x4e6bb5)
71:     #9 handle 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1006 
(qdrouterd+0x4e1be6)
71:     #10 thread_run 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1121 
(qdrouterd+0x4e4005)
71:     #11 _thread_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
 (qdrouterd+0x4868bd)
71: 
71:   Mutex M261 (0x7b640003cd20) created at:
71:     #0 pthread_mutex_init <null> (libtsan.so.0+0x49603)
71:     #1 pmutex_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll-internal.h:323
 (libqpid-proton-proactor.so.1+0xd52c)
71:     #2 pn_proactor 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:1941
 (libqpid-proton-proactor.so.1+0xd52c)
71:     #3 qd_server 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1354 
(qdrouterd+0x4e4264)
71:     #4 qd_dispatch_prepare 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/dispatch.c:333 
(qdrouterd+0x466486)
71:     #5 ffi_call_unix64 <null> (libffi.so.6+0x6c03)
71:     #6 main_process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:97
 (qdrouterd+0x426c6c)
71:     #7 main 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:369
 (qdrouterd+0x42622c)
71: 
71:   Mutex M2585 (0x7b6800031e00) created at:
71:     #0 pthread_mutex_init <null> (libtsan.so.0+0x49603)
71:     #1 pmutex_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll-internal.h:323
 (libqpid-proton-proactor.so.1+0x146eb)
71:     #2 task_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:224
 (libqpid-proton-proactor.so.1+0x146eb)
71:     #3 praw_connection_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll_raw_connection.c:141
 (libqpid-proton-proactor.so.1+0x146eb)
71:     #4 pn_proactor_raw_connect 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll_raw_connection.c:179
 (libqpid-proton-proactor.so.1+0x146eb)
71:     #5 qdr_tcp_connection_egress 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:1088
 (qdrouterd+0x448bbf)
71:     #6 qdr_tcp_deliver 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:1531
 (qdrouterd+0x448e86)
71:     #7 qdr_link_process_deliveries 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/transfer.c:178
 (qdrouterd+0x4c43d0)
71:     #8 qdr_tcp_push 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:1509
 (qdrouterd+0x44707c)
71:     #9 qdr_connection_process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/connections.c:414
 (qdrouterd+0x497c7d)
71:     #10 on_activate 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/tcp_adaptor.c:186
 (qdrouterd+0x449491)
71:     #11 qd_timer_visit 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/timer.c:316 
(qdrouterd+0x4e6bb5)
71:     #12 handle 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1006 
(qdrouterd+0x4e1be6)
71:     #13 thread_run 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1121 
(qdrouterd+0x4e4005)
71:     #14 _thread_init 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
 (qdrouterd+0x4868bd)
71: 
71:   Thread T4 (tid=3238, running) created by main thread at:
71:     #0 pthread_create <null> (libtsan.so.0+0x5bf45)
71:     #1 sys_thread 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:181
 (qdrouterd+0x486d4c)
71:     #2 qd_server_run 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1499 
(qdrouterd+0x4e4bec)
71:     #3 main_process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:115
 (qdrouterd+0x426ccc)
71:     #4 main 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:369
 (qdrouterd+0x42622c)
71: 
71:   Thread T2 (tid=3236, running) created by main thread at:
71:     #0 pthread_create <null> (libtsan.so.0+0x5bf45)
71:     #1 sys_thread 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:181
 (qdrouterd+0x486d4c)
71:     #2 qd_server_run 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1499 
(qdrouterd+0x4e4bec)
71:     #3 main_process 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:115
 (qdrouterd+0x426ccc)
71:     #4 main 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:369
 (qdrouterd+0x42622c)
71: 
71: SUMMARY: ThreadSanitizer: data race 
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-proton/c/src/proactor/epoll.c:2304
 in post_event
71: ==================
71: ThreadSanitizer: reported 1 warnings
71: 
{noformat}



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to