Leif Hedstrom created TS-3378:
---------------------------------
Summary: SpdyRequest used after free()
Key: TS-3378
URL: https://issues.apache.org/jira/browse/TS-3378
Project: Traffic Server
Issue Type: Bug
Components: SPDY
Reporter: Leif Hedstrom
I see this on our docs.ts machine:
{code}
==1310==ERROR: AddressSanitizer: heap-use-after-free on address 0x6110004fc974
at pc 0x7c2162 bp 0x7fff97c95010 sp 0x7fff97c95008
READ of size 1 at 0x6110004fc974 thread T0 ([ET_NET 0])
#0 0x7c2161 in spdy_process_fetch
/usr/local/src/trafficserver/proxy/spdy/SpdyClientSession.cc:339
#1 0x7c2161 in SpdyClientSession::state_session_readwrite(int, void*)
/usr/local/src/trafficserver/proxy/spdy/SpdyClientSession.cc:253
#2 0x4f1308 in Continuation::handleEvent(int, void*)
../iocore/eventsystem/I_Continuation.h:146
#3 0x4f1308 in FetchSM::InvokePluginExt(int)
/usr/local/src/trafficserver/proxy/FetchSM.cc:250
#4 0x4f455a in FetchSM::fetch_handler(int, void*)
/usr/local/src/trafficserver/proxy/FetchSM.cc:516
#5 0x59f737 in Continuation::handleEvent(int, void*)
../iocore/eventsystem/I_Continuation.h:146
#6 0x59f737 in PluginVC::process_write_side(bool)
/usr/local/src/trafficserver/proxy/PluginVC.cc:519
#7 0x5aa2fd in PluginVC::main_handler(int, void*)
/usr/local/src/trafficserver/proxy/PluginVC.cc:210
#8 0xc6aabe in Continuation::handleEvent(int, void*)
/usr/local/src/trafficserver/iocore/eventsystem/I_Continuation.h:146
#9 0xc6aabe in EThread::process_event(Event*, int)
/usr/local/src/trafficserver/iocore/eventsystem/UnixEThread.cc:144
#10 0xc6d0d9 in EThread::execute()
/usr/local/src/trafficserver/iocore/eventsystem/UnixEThread.cc:238
#11 0x498481 in main /usr/local/src/trafficserver/proxy/Main.cc:1759
#12 0x2b01d58c0af4 in __libc_start_main (/lib64/libc.so.6+0x21af4)
#13 0x4ab124 (/opt/ats/bin/traffic_server+0x4ab124)
0x6110004fc974 is located 52 bytes inside of 224-byte region
[0x6110004fc940,0x6110004fca20)
freed by thread T0 ([ET_NET 0]) here:
#0 0x2b01d1d2e1c7 in __interceptor_free
../../.././libsanitizer/asan/asan_malloc_linux.cc:62
#1 0x7c8433 in ClassAllocator<SpdyRequest>::free(SpdyRequest*)
../../lib/ts/Allocator.h:138
#2 0x7c8433 in SpdyClientSession::cleanup_request(int)
/usr/local/src/trafficserver/proxy/spdy/SpdyClientSession.h:146
#3 0x7c8433 in
spdy_prepare_status_response_and_clean_request(SpdyClientSession*, int, char
const*) /usr/local/src/trafficserver/proxy/spdy/SpdyCa
llbacks.cc:85
#4 0x7c1094 in spdy_process_fetch
/usr/local/src/trafficserver/proxy/spdy/SpdyClientSession.cc:354
#5 0x7c1094 in SpdyClientSession::state_session_readwrite(int, void*)
/usr/local/src/trafficserver/proxy/spdy/SpdyClientSession.cc:253
#6 0x4f1c95 in Continuation::handleEvent(int, void*)
../iocore/eventsystem/I_Continuation.h:146
#7 0x4f1c95 in FetchSM::InvokePluginExt(int)
/usr/local/src/trafficserver/proxy/FetchSM.cc:259
#8 0x4f2eaa in FetchSM::process_fetch_read(int)
/usr/local/src/trafficserver/proxy/FetchSM.cc:465
#9 0x4f4542 in FetchSM::fetch_handler(int, void*)
/usr/local/src/trafficserver/proxy/FetchSM.cc:514
#10 0x59e077 in Continuation::handleEvent(int, void*)
../iocore/eventsystem/I_Continuation.h:146
#11 0x59e077 in PluginVC::process_read_side(bool)
/usr/local/src/trafficserver/proxy/PluginVC.cc:640
#12 0x5aab79 in PluginVC::main_handler(int, void*)
/usr/local/src/trafficserver/proxy/PluginVC.cc:206
#13 0xc6aabe in Continuation::handleEvent(int, void*)
/usr/local/src/trafficserver/iocore/eventsystem/I_Continuation.h:146
#14 0xc6aabe in EThread::process_event(Event*, int)
/usr/local/src/trafficserver/iocore/eventsystem/UnixEThread.cc:144
#15 0xc6d0d9 in EThread::execute()
/usr/local/src/trafficserver/iocore/eventsystem/UnixEThread.cc:238
#16 0x498481 in main /usr/local/src/trafficserver/proxy/Main.cc:1759
#17 0x2b01d58c0af4 in __libc_start_main (/lib64/libc.so.6+0x21af4)
previously allocated by thread T5 ([ET_NET 4]) here:
#0 0x2b01d1d2e93b in __interceptor_posix_memalign
../../.././libsanitizer/asan/asan_malloc_linux.cc:130
#1 0x2b01d2c18309 in ats_memalign
/usr/local/src/trafficserver/lib/ts/ink_memory.cc:96
#2 0x7c89ba in ClassAllocator<SpdyRequest>::alloc()
../../lib/ts/Allocator.h:124
#3 0x7c89ba in spdy_on_ctrl_recv_callback(spdylay_session*,
spdylay_frame_type, spdylay_frame*, void*)
/usr/local/src/trafficserver/proxy/spdy/Spd
yCallbacks.cc:328
#4 0x2b01d3f1afff in spdylay_session_call_on_ctrl_frame_received
/admin/src/spdylay/lib/spdylay_session.c:1634
#5 0x2b01d3f1afff in spdylay_session_on_syn_stream_received
/admin/src/spdylay/lib/spdylay_session.c:1782
#6 0x300000166 (+0x270009166)
Thread T5 ([ET_NET 4]) created by T0 ([ET_NET 0]) here:
#0 0x2b01d1cfd86a in __interceptor_pthread_create
../../.././libsanitizer/asan/asan_interceptors.cc:183
#1 0xc6a365 in ink_thread_create ../../lib/ts/ink_thread.h:148
#2 0xc6a365 in Thread::start(char const*, unsigned long, void* (*)(void*),
void*) /usr/local/src/trafficserver/iocore/eventsystem/Thread.cc:103
#3 0xc728e6 in EventProcessor::start(int, unsigned long)
/usr/local/src/trafficserver/iocore/eventsystem/UnixEventProcessor.cc:140
#4 0x4981f6 in main /usr/local/src/trafficserver/proxy/Main.cc:1572
#5 0x2b01d58c0af4 in __libc_start_main (/lib64/libc.so.6+0x21af4)
SUMMARY: AddressSanitizer: heap-use-after-free
/usr/local/src/trafficserver/proxy/spdy/SpdyClientSession.cc:339
spdy_process_fetch
{code}
>From what it looks, we cleanup the "req" member in
{code}
cleanup_request(int streamId);
{code}
But the req is still being used (and the pointer is not cleared either) after
this.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)