You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@trafficserver.apache.org by "Susan Hinrichs (JIRA)" <ji...@apache.org> on 2015/05/26 17:19:17 UTC

[jira] [Assigned] (TS-3378) SpdyRequest used after free()

     [ https://issues.apache.org/jira/browse/TS-3378?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Susan Hinrichs reassigned TS-3378:
----------------------------------

    Assignee: Susan Hinrichs

> 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
>            Assignee: Susan Hinrichs
>             Fix For: 6.0.0
>
>
> 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)