Jiri Daněk created DISPATCH-2172:
------------------------------------
Summary: TSan data race from qd_message_free in
system_tests_http1_adaptor
Key: DISPATCH-2172
URL: https://issues.apache.org/jira/browse/DISPATCH-2172
Project: Qpid Dispatch
Issue Type: Bug
Affects Versions: 1.17.0
Reporter: Jiri Daněk
Seen at current head (with PR changes only touching Travis CI) in
system_tests_http1_adaptor
https://github.com/apache/qpid-dispatch/pull/1258/checks?check_run_id=2827236011#step:25:3447
{noformat}
69: WARNING: ThreadSanitizer: data race (pid=3415)
69: Read of size 8 at 0x7b4800022620 by thread T4 (mutexes: write M1463):
69: #0 qd_message_free
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/message.c:1037
(libqpid-dispatch.so+0x86510)
69: #1 qdr_do_message_to_addr_free
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/router_core_thread.c:102
(libqpid-dispatch.so+0xcd356)
69: #2 qdr_general_handler
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/router_core.c:942
(libqpid-dispatch.so+0xc6c2b)
69: #3 qd_timer_visit
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/timer.c:317
(libqpid-dispatch.so+0xf7b9d)
69: #4 handle
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1006
(libqpid-dispatch.so+0xf1bae)
69: #5 thread_run
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1121
(libqpid-dispatch.so+0xf60c5)
69: #6 _thread_init
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
(libqpid-dispatch.so+0x968c2)
69:
69: Previous write of size 8 at 0x7b4800022620 by thread T2:
69: #0 qd_message_stream_data_release
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/message.c:2680
(libqpid-dispatch.so+0x87acf)
69: #1 qdr_http1_out_data_fifo_cleanup
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_adaptor.c:152
(libqpid-dispatch.so+0x43b41)
69: #2 _server_request_free
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_server.c:1647
(libqpid-dispatch.so+0x4f1ed)
69: #3 _server_request_free
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_server.c:1645
(libqpid-dispatch.so+0x4f843)
69: #4 _process_request
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_server.c:734
(libqpid-dispatch.so+0x4f843)
69: #5 _handle_connection_events
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_server.c:659
(libqpid-dispatch.so+0x4ff55)
69: #6 handle_event_with_context
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:802
(libqpid-dispatch.so+0xf1c5d)
69: #7 do_handle_raw_connection_event
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:808
(libqpid-dispatch.so+0xf1c5d)
69: #8 handle
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1089
(libqpid-dispatch.so+0xf1c5d)
69: #9 thread_run
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1121
(libqpid-dispatch.so+0xf60c5)
69: #10 _thread_init
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
(libqpid-dispatch.so+0x968c2)
69:
69: Location is heap block of size 384 at 0x7b4800022500 allocated by thread
T1:
69: #0 posix_memalign <null> (libtsan.so.0+0x32a23)
69: #1 qd_alloc
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/alloc_pool.c:396
(libqpid-dispatch.so+0x5c663)
69: #2 new_qd_message_t
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/message.c:91
(libqpid-dispatch.so+0x81721)
69: #3 qd_message_copy
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/message.c:1099
(libqpid-dispatch.so+0x83c48)
69: #4 qdr_forward_new_delivery_CT
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/forwarder.c:153
(libqpid-dispatch.so+0xbdb7b)
69: #5 qdr_forward_balanced_CT
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/forwarder.c:905
(libqpid-dispatch.so+0xbf20d)
69: #6 qdr_forward_message_CT
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/forwarder.c:1120
(libqpid-dispatch.so+0xc2600)
69: #7 qdr_link_forward_CT
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/transfer.c:572
(libqpid-dispatch.so+0xd6033)
69: #8 qdr_link_deliver_CT
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/transfer.c:862
(libqpid-dispatch.so+0xd7582)
69: #9 router_core_thread
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/router_core_thread.c:239
(libqpid-dispatch.so+0xce0db)
69: #10 _thread_init
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
(libqpid-dispatch.so+0x968c2)
69:
69: Mutex M1463 (0x7b10000094c0) created at:
69: #0 pthread_mutex_init <null> (libtsan.so.0+0x49603)
69: #1 sys_mutex
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:43
(libqpid-dispatch.so+0x9691c)
69: #2 qd_message
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/message.c:1005
(libqpid-dispatch.so+0x81cc7)
69: #3 _client_rx_headers_done_cb
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_client.c:849
(libqpid-dispatch.so+0x454d8)
69: #4 process_headers_done
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_codec.c:837
(libqpid-dispatch.so+0x411c8)
69: #5 parse_header
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_codec.c:917
(libqpid-dispatch.so+0x411c8)
69: #6 decode_incoming
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_codec.c:1294
(libqpid-dispatch.so+0x411c8)
69: #7 h1_codec_connection_rx_data
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_codec.c:1339
(libqpid-dispatch.so+0x411c8)
69: #8 _handle_conn_read_event
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_client.c:404
(libqpid-dispatch.so+0x45c79)
69: #9 _handle_connection_events
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/adaptors/http1/http1_client.c:511
(libqpid-dispatch.so+0x4826c)
69: #10 handle_event_with_context
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:802
(libqpid-dispatch.so+0xf1c5d)
69: #11 do_handle_raw_connection_event
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:808
(libqpid-dispatch.so+0xf1c5d)
69: #12 handle
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1089
(libqpid-dispatch.so+0xf1c5d)
69: #13 thread_run
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1121
(libqpid-dispatch.so+0xf60c5)
69: #14 _thread_init
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:172
(libqpid-dispatch.so+0x968c2)
69:
69: Thread T4 (tid=3420, running) created by main thread at:
69: #0 pthread_create <null> (libtsan.so.0+0x5bf45)
69: #1 sys_thread
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:181
(libqpid-dispatch.so+0x96d5e)
69: #2 qd_server_run
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1499
(libqpid-dispatch.so+0xf6302)
69: #3 main_process
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:115
(qdrouterd+0x40287c)
69: #4 main
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:369
(qdrouterd+0x4024fc)
69:
69: Thread T2 (tid=3418, running) created by main thread at:
69: #0 pthread_create <null> (libtsan.so.0+0x5bf45)
69: #1 sys_thread
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:181
(libqpid-dispatch.so+0x96d5e)
69: #2 qd_server_run
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/server.c:1499
(libqpid-dispatch.so+0xf6302)
69: #3 main_process
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:115
(qdrouterd+0x40287c)
69: #4 main
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:369
(qdrouterd+0x4024fc)
69:
69: Thread T1 (tid=3417, running) created by main thread at:
69: #0 pthread_create <null> (libtsan.so.0+0x5bf45)
69: #1 sys_thread
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/posix/threading.c:181
(libqpid-dispatch.so+0x96d5e)
69: #2 qdr_core
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_core/router_core.c:124
(libqpid-dispatch.so+0xc75d6)
69: #3 qd_router_setup_late
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/router_node.c:2124
(libqpid-dispatch.so+0xedb98)
69: #4 ffi_call_unix64 <null> (libffi.so.6+0x6c03)
69: #5 main_process
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:97
(qdrouterd+0x40281c)
69: #6 main
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/router/src/main.c:369
(qdrouterd+0x4024fc)
69:
69: SUMMARY: ThreadSanitizer: data race
/home/runner/work/qpid-dispatch/qpid-dispatch/qpid-dispatch/src/message.c:1037
in qd_message_free
69: ==================
69: ThreadSanitizer: reported 1 warnings
{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]