==1==ERROR: AddressSanitizer: heap-use-after-free on address 0x518000055980 at pc 0x5583bc134d65 bp 0x78aa16535b90 sp 0x78aa16535360 WRITE of size 512 at 0x518000055980 thread T18 (Realtime AudioW) #0 0x5583bc134d64 in __asan_memset _asan_rtl_:3 #1 0x5583de5c0e61 in Zero ./../../third_party/blink/renderer/platform/audio/audio_channel.h:0:0 #2 0x5583de5c0e61 in blink::AudioBus::Zero() ./../../third_party/blink/renderer/platform/audio/audio_bus.cc:106:13 #3 0x5583e211ebcd in blink::AudioWorkletHandler::Process(unsigned int) ./../../third_party/blink/renderer/modules/webaudio/audio_worklet_handler.cc:125:24 #4 0x5583e20b0cf6 in blink::AudioHandler::ProcessIfNecessary(unsigned int) ./../../third_party/blink/renderer/modules/webaudio/audio_handler.cc:347:7 #5 0x5583e218f8d2 in blink::DeferredTaskHandler::ProcessAutomaticPullNodes(unsigned int) ./../../third_party/blink/renderer/modules/webaudio/deferred_task_handler.cc:198:41 #6 0x5583e2206a9f in blink::RealtimeAudioDestinationHandler::Render(blink::AudioBus*, unsigned int, blink::AudioIOPosition const&, blink::AudioCallbackMetric const&, base::TimeDelta, media::AudioGlitchInfo const&) ./../../third_party/blink/renderer/modules/webaudio/realtime_audio_destination_handler.cc:246:37 #7 0x5583e2212745 in PullFromCallback ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:589:14 #8 0x5583e2212745 in blink::AudioDestination::ProvideResamplerInput(int, blink::AudioBus*) ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:575:3 #9 0x5583e22145fe in Invoke ./../../base/functional/bind_internal.h:738:12 #10 0x5583e22145fe in MakeItSo > &, int, blink::AudioBus *> ./../../base/functional/bind_internal.h:930:12 #11 0x5583e22145fe in RunImpl > &, 0UL> ./../../base/functional/bind_internal.h:1067:14 #12 0x5583e22145fe in base::internal::Invoker, base::internal::BindState>, void (int, blink::AudioBus*)>::Run(base::internal::BindStateBase*, int, blink::AudioBus*) ./../../base/functional/bind_internal.h:987:12 #13 0x5583e21bd1ab in base::RepeatingCallback::Run(int, blink::AudioBus*) const & ./../../base/functional/callback.h:344:12 #14 0x5583e21bc5f3 in Run ./../../third_party/blink/renderer/platform/wtf/functional.h:305:22 #15 0x5583e21bc5f3 in blink::MediaMultiChannelResampler::ProvideResamplerInput(int, media::AudioBus*) ./../../third_party/blink/renderer/platform/audio/media_multi_channel_resampler.cc:59:12 #16 0x5583e21bcec6 in Invoke ./../../base/functional/bind_internal.h:738:12 #17 0x5583e21bcec6 in MakeItSo > &, int, media::AudioBus *> ./../../base/functional/bind_internal.h:930:12 #18 0x5583e21bcec6 in RunImpl > &, 0UL> ./../../base/functional/bind_internal.h:1067:14 #19 0x5583e21bcec6 in base::internal::Invoker, base::internal::BindState>, void (int, media::AudioBus*)>::Run(base::internal::BindStateBase*, int, media::AudioBus*) ./../../base/functional/bind_internal.h:987:12 #20 0x5583bedcb58b in base::RepeatingCallback::Run(int, media::AudioBus*) const & ./../../base/functional/callback.h:344:12 #21 0x5583bee4212d in Invoke ./../../base/functional/bind_internal.h:738:12 #22 0x5583bee4212d in MakeItSo, int> &, int, float *> ./../../base/functional/bind_internal.h:930:12 #23 0x5583bee4212d in RunImpl, int> &, 0UL, 1UL> ./../../base/functional/bind_internal.h:1067:14 #24 0x5583bee4212d in base::internal::Invoker, base::internal::BindState, int>, void (int, float*)>::Run(base::internal::BindStateBase*, int, float*) ./../../base/functional/bind_internal.h:987:12 #25 0x5583bee87dfb in base::RepeatingCallback::Run(int, float*) const & ./../../base/functional/callback.h:344:12 #26 0x5583bee872f9 in media::SincResampler::Resample(int, float*) ./../../media/base/sinc_resampler.cc:283:14 #27 0x5583e220cbfa in blink::AudioDestination::RequestRender(unsigned long, unsigned long, base::TimeDelta, base::TimeTicks, media::AudioGlitchInfo const&) ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:556:19 #28 0x5583e22138fa in Invoke, unsigned int, unsigned long, base::TimeDelta, base::TimeTicks, media::AudioGlitchInfo> ./../../base/functional/bind_internal.h:738:12 #29 0x5583e22138fa in MakeItSo, unsigned int, unsigned long, base::TimeDelta, base::TimeTicks, media::AudioGlitchInfo> > ./../../base/functional/bind_internal.h:930:12 #30 0x5583e22138fa in RunImpl, unsigned int, unsigned long, base::TimeDelta, base::TimeTicks, media::AudioGlitchInfo>, 0UL, 1UL, 2UL, 3UL, 4UL, 5UL> ./../../base/functional/bind_internal.h:1067:14 #31 0x5583e22138fa in base::internal::Invoker&&, unsigned int&&, unsigned long&&, base::TimeDelta&&, base::TimeTicks&&, media::AudioGlitchInfo&&>, base::internal::BindState, unsigned int, unsigned long, base::TimeDelta, base::TimeTicks, media::AudioGlitchInfo>, void ()>::RunOnce(base::internal::BindStateBase*) ./../../base/functional/bind_internal.h:980:12 #32 0x5583cf1a6fd4 in Run ./../../base/functional/callback.h:156:12 #33 0x5583cf1a6fd4 in base::TaskAnnotator::RunTaskImpl(base::PendingTask&) ./../../base/task/common/task_annotator.cc:203:34 #34 0x5583cf20e236 in RunTask<(lambda at ../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:486:11)> ./../../base/task/common/task_annotator.h:90:5 #35 0x5583cf20e236 in base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::DoWorkImpl(base::LazyNow*) ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:484:23 #36 0x5583cf20d150 in base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::DoWork() ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:346:40 #37 0x5583cf20ef7a in non-virtual thunk to base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::DoWork() ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:0:0 #38 0x5583cf096b2d in base::MessagePumpDefault::Run(base::MessagePump::Delegate*) ./../../base/message_loop/message_pump_default.cc:40:55 #39 0x5583cf20fbe6 in base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::Run(bool, base::TimeDelta) ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:654:12 #40 0x5583cf1370af in base::RunLoop::Run(base::Location const&) ./../../base/run_loop.cc:134:14 #41 0x5583cba8de86 in blink::scheduler::NonMainThreadImpl::SimpleThreadImpl::Run() ./../../third_party/blink/renderer/platform/scheduler/worker/non_main_thread_impl.cc:188:14 #42 0x5583cf2dc667 in base::(anonymous namespace)::ThreadFunc(void*) ./../../base/threading/platform_thread_posix.cc:101:13 #43 0x5583bc134706 in asan_thread_start(void*) _asan_rtl_:28 0x518000055980 is located 256 bytes inside of 768-byte region [0x518000055880,0x518000055b80) freed by thread T0 (chrome) here: #0 0x5583bc136a46 in __interceptor_free _asan_rtl_:3 #1 0x5583bee85ffc in AlignedFree ./../../base/memory/aligned_memory.h:54:3 #2 0x5583bee85ffc in operator() ./../../base/memory/aligned_memory.h:62:5 #3 0x5583bee85ffc in reset ./../../third_party/libc++/src/include/__memory/unique_ptr.h:468:7 #4 0x5583bee85ffc in ~unique_ptr ./../../third_party/libc++/src/include/__memory/unique_ptr.h:429:71 #5 0x5583bee85ffc in media::SincResampler::~SincResampler() ./../../media/base/sinc_resampler.cc:194:31 #6 0x5583bee42340 in operator() ./../../third_party/libc++/src/include/__memory/unique_ptr.h:67:5 #7 0x5583bee42340 in reset ./../../third_party/libc++/src/include/__memory/unique_ptr.h:278:7 #8 0x5583bee42340 in ~unique_ptr ./../../third_party/libc++/src/include/__memory/unique_ptr.h:248:71 #9 0x5583bee42340 in __destroy_at >, 0> ./../../third_party/libc++/src/include/__memory/construct_at.h:67:11 #10 0x5583bee42340 in destroy >, void, 0> ./../../third_party/libc++/src/include/__memory/allocator_traits.h:340:5 #11 0x5583bee42340 in __base_destruct_at_end ./../../third_party/libc++/src/include/vector:950:7 #12 0x5583bee42340 in __clear ./../../third_party/libc++/src/include/vector:944:5 #13 0x5583bee42340 in std::__Cr::vector>, std::__Cr::allocator>>>::__destroy_vector::operator()() ./../../third_party/libc++/src/include/vector:522:16 #14 0x5583bee411ad in ~vector ./../../third_party/libc++/src/include/vector:533:67 #15 0x5583bee411ad in ~MultiChannelResampler ./../../media/base/multi_channel_resampler.cc:47:47 #16 0x5583bee411ad in media::MultiChannelResampler::~MultiChannelResampler() ./../../media/base/multi_channel_resampler.cc:47:47 #17 0x5583e22098b2 in operator() ./../../third_party/libc++/src/include/__memory/unique_ptr.h:67:5 #18 0x5583e22098b2 in reset ./../../third_party/libc++/src/include/__memory/unique_ptr.h:278:7 #19 0x5583e22098b2 in ~unique_ptr ./../../third_party/libc++/src/include/__memory/unique_ptr.h:248:71 #20 0x5583e22098b2 in ~MediaMultiChannelResampler ./../../third_party/blink/renderer/platform/audio/media_multi_channel_resampler.h:25:23 #21 0x5583e22098b2 in operator() ./../../third_party/libc++/src/include/__memory/unique_ptr.h:67:5 #22 0x5583e22098b2 in reset ./../../third_party/libc++/src/include/__memory/unique_ptr.h:278:7 #23 0x5583e22098b2 in ~unique_ptr ./../../third_party/libc++/src/include/__memory/unique_ptr.h:248:71 #24 0x5583e22098b2 in blink::AudioDestination::~AudioDestination() ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:99:1 #25 0x5583e2205745 in DeleteInternal ./../../third_party/blink/renderer/platform/wtf/thread_safe_ref_counted.h:65:5 #26 0x5583e2205745 in Destruct ./../../third_party/blink/renderer/platform/wtf/thread_safe_ref_counted.h:45:5 #27 0x5583e2205745 in Release ./../../base/memory/ref_counted.h:416:7 #28 0x5583e2205745 in Release ./../../base/memory/scoped_refptr.h:384:8 #29 0x5583e2205745 in ~scoped_refptr ./../../base/memory/scoped_refptr.h:273:7 #30 0x5583e2205745 in operator= ./../../base/memory/scoped_refptr.h:299:3 #31 0x5583e2205745 in blink::RealtimeAudioDestinationHandler::CreatePlatformDestination() ./../../third_party/blink/renderer/modules/webaudio/realtime_audio_destination_handler.cc:347:25 #32 0x5583e2205e92 in blink::RealtimeAudioDestinationHandler::SetChannelCount(unsigned int, blink::ExceptionState&) ./../../third_party/blink/renderer/modules/webaudio/realtime_audio_destination_handler.cc:137:3 #33 0x5583e04ff634 in blink::(anonymous namespace)::v8_audio_node::ChannelCountAttributeSetCallback(v8::FunctionCallbackInfo const&) ./gen/third_party/blink/renderer/bindings/modules/v8/v8_audio_node.cc:166:17 #34 0x5583c1da0e08 in v8::internal::FunctionCallbackArguments::CallOrConstruct(v8::internal::Tagged, bool) ./../../v8/src/api/api-arguments-inl.h:95:3 #35 0x5583c1d9e060 in HandleApiCallHelper ./../../v8/src/builtins/builtins-api.cc:108:36 #36 0x5583c1d9e060 in v8::internal::Builtins::InvokeApiFunction(v8::internal::Isolate*, bool, v8::internal::Handle, v8::internal::Handle, int, v8::internal::Handle*, v8::internal::Handle) ./../../v8/src/builtins/builtins-api.cc:196:10 #37 0x5583c2df4356 in v8::internal::Object::SetPropertyWithAccessor(v8::internal::LookupIterator*, v8::internal::Handle, v8::Maybe) ./../../v8/src/objects/objects.cc:1549:5 #38 0x5583c2dfa760 in v8::internal::Object::SetPropertyInternal(v8::internal::LookupIterator*, v8::internal::Handle, v8::Maybe, v8::internal::StoreOrigin, bool*) ./../../v8/src/objects/objects.cc:2288:16 #39 0x5583c2df9db6 in v8::internal::Object::SetProperty(v8::internal::LookupIterator*, v8::internal::Handle, v8::internal::StoreOrigin, v8::Maybe) ./../../v8/src/objects/objects.cc:2361:9 #40 0x5583c2615691 in v8::internal::StoreIC::Store(v8::internal::Handle, v8::internal::Handle, v8::internal::Handle, v8::internal::StoreOrigin) ./../../v8/src/ic/ic.cc:1948:5 #41 0x5583c26292fd in __RT_impl_Runtime_StoreIC_Miss ./../../v8/src/ic/ic.cc:2929:3 #42 0x5583c26292fd in v8::internal::Runtime_StoreIC_Miss(int, unsigned long*, v8::internal::Isolate*) ./../../v8/src/ic/ic.cc:2901:1 #43 0x5583c5d2aef5 in Builtins_CEntry_Return1_ArgvOnStack_NoBuiltinExit setup-isolate-deserialize.cc:0:0 #44 0x5583c5e15e26 in Builtins_SetNamedPropertyHandler setup-isolate-deserialize.cc:0:0 #45 0x5583c5c8b8a6 in Builtins_InterpreterEntryTrampoline setup-isolate-deserialize.cc:0:0 #46 0x5583c5c8931b in Builtins_JSEntryTrampoline setup-isolate-deserialize.cc:0:0 #47 0x5583c5c8905e in Builtins_JSEntry setup-isolate-deserialize.cc:0:0 #48 0x5583c215316c in Call ./../../v8/src/execution/simulator.h:187:12 #49 0x5583c215316c in v8::internal::(anonymous namespace)::Invoke(v8::internal::Isolate*, v8::internal::(anonymous namespace)::InvokeParams const&) ./../../v8/src/execution/execution.cc:420:22 #50 0x5583c2151a9a in v8::internal::Execution::Call(v8::internal::Isolate*, v8::internal::Handle, v8::internal::Handle, int, v8::internal::Handle*) ./../../v8/src/execution/execution.cc:506:10 #51 0x5583c1caf483 in v8::Function::Call(v8::Local, v8::Local, int, v8::Local*) ./../../v8/src/api/api.cc:5572:7 #52 0x5583dae3699f in blink::V8ScriptRunner::CallFunction(v8::Local, blink::ExecutionContext*, v8::Local, int, v8::Local*, v8::Isolate*) ./../../third_party/blink/renderer/bindings/core/v8/v8_script_runner.cc:870:17 #53 0x5583df92e7fe in CallInternal ./../../third_party/blink/renderer/bindings/core/v8/callback_invoke_helper.cc:142:12 #54 0x5583df92e7fe in blink::bindings::CallbackInvokeHelper::Call(int, v8::Local*) ./../../third_party/blink/renderer/bindings/core/v8/callback_invoke_helper.cc:163:10 #55 0x5583df93f4e2 in blink::V8EventHandlerNonNull::InvokeWithoutRunnabilityCheck(blink::bindings::V8ValueOrScriptWrappableAdapter, blink::HeapVector const&) ./gen/third_party/blink/renderer/bindings/core/v8/v8_event_handler_non_null.cc:189:13 #56 0x5583db98a81a in blink::JSEventHandler::InvokeInternal(blink::EventTarget&, blink::Event&, v8::Local) ./../../third_party/blink/renderer/bindings/core/v8/js_event_handler.cc:134:14 #57 0x5583db861aaa in blink::JSBasedEventListener::Invoke(blink::ExecutionContext*, blink::Event*) ./../../third_party/blink/renderer/bindings/core/v8/js_based_event_listener.cc:158:5 #58 0x5583db851d76 in blink::EventTarget::FireEventListeners(blink::Event&, blink::EventTargetData*, blink::HeapVector, 1u>) ./../../third_party/blink/renderer/core/dom/events/event_target.cc:1112:15 #59 0x5583db84fd74 in blink::EventTarget::FireEventListeners(blink::Event&) ./../../third_party/blink/renderer/core/dom/events/event_target.cc:1031:29 previously allocated by thread T0 (chrome) here: #0 0x5583bc1377a7 in ___interceptor_posix_memalign _asan_rtl_:3 #1 0x5583cf07fbc8 in base::AlignedAlloc(unsigned long, unsigned long) ./../../base/memory/aligned_memory.cc:34:13 #2 0x5583bee851c5 in media::SincResampler::SincResampler(double, int, base::RepeatingCallback) ./../../media/base/sinc_resampler.cc:170:11 #3 0x5583bee405fe in make_unique > ./../../third_party/libc++/src/include/__memory/unique_ptr.h:620:30 #4 0x5583bee405fe in media::MultiChannelResampler::MultiChannelResampler(int, double, unsigned long, base::RepeatingCallback) ./../../media/base/multi_channel_resampler.cc:27:27 #5 0x5583e21bc16a in make_unique > ./../../third_party/libc++/src/include/__memory/unique_ptr.h:620:30 #6 0x5583e21bc16a in blink::MediaMultiChannelResampler::MediaMultiChannelResampler(int, double, unsigned int, WTF::CrossThreadFunction) ./../../third_party/blink/renderer/platform/audio/media_multi_channel_resampler.cc:23:16 #7 0x5583e22117eb in make_unique > ./../../third_party/libc++/src/include/__memory/unique_ptr.h:620:30 #8 0x5583e22117eb in blink::AudioDestination::AudioDestination(blink::AudioIOCallback&, blink::WebAudioSinkDescriptor const&, unsigned int, blink::WebAudioLatencyHint const&, std::__Cr::optional, unsigned int) ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:427:18 #9 0x5583e22094a6 in blink::AudioDestination::Create(blink::AudioIOCallback&, blink::WebAudioSinkDescriptor const&, unsigned int, blink::WebAudioLatencyHint const&, std::__Cr::optional, unsigned int) ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:92:11 #10 0x5583e2205683 in blink::RealtimeAudioDestinationHandler::CreatePlatformDestination() ./../../third_party/blink/renderer/modules/webaudio/realtime_audio_destination_handler.cc:347:27 #11 0x5583e2205503 in blink::RealtimeAudioDestinationHandler::Initialize() ./../../third_party/blink/renderer/modules/webaudio/realtime_audio_destination_handler.cc:78:3 #12 0x5583e2155396 in blink::BaseAudioContext::Initialize() ./../../third_party/blink/renderer/modules/webaudio/base_audio_context.cc:122:34 #13 0x5583e2090de9 in blink::AudioContext::AudioContext(blink::LocalDOMWindow&, blink::WebAudioLatencyHint const&, std::__Cr::optional, blink::WebAudioSinkDescriptor) ./../../third_party/blink/renderer/modules/webaudio/audio_context.cc:295:3 #14 0x5583e208e9de in Call &, blink::WebAudioSinkDescriptor &> ./../../v8/include/cppgc/allocation.h:241:32 #15 0x5583e208e9de in MakeGarbageCollected &, blink::WebAudioSinkDescriptor &> ./../../v8/include/cppgc/allocation.h:279:7 #16 0x5583e208e9de in MakeGarbageCollected &, blink::WebAudioSinkDescriptor &> ./../../third_party/blink/renderer/platform/heap/garbage_collected.h:37:10 #17 0x5583e208e9de in blink::AudioContext::Create(blink::ExecutionContext*, blink::AudioContextOptions const*, blink::ExceptionState&) ./../../third_party/blink/renderer/modules/webaudio/audio_context.cc:211:33 #18 0x5583e051c32b in blink::(anonymous namespace)::v8_audio_context::ConstructorCallback(v8::FunctionCallbackInfo const&) ./gen/third_party/blink/renderer/bindings/modules/v8/v8_audio_context.cc:293:23 #19 0x5583c1da0e08 in v8::internal::FunctionCallbackArguments::CallOrConstruct(v8::internal::Tagged, bool) ./../../v8/src/api/api-arguments-inl.h:95:3 #20 0x5583c1d9edf5 in v8::internal::MaybeHandle v8::internal::(anonymous namespace)::HandleApiCallHelper(v8::internal::Isolate*, v8::internal::Handle, v8::internal::Handle, v8::internal::Handle, unsigned long*, int) ./../../v8/src/builtins/builtins-api.cc:108:36 #21 0x5583c1d9cdef in v8::internal::Builtin_Impl_HandleApiConstruct(v8::internal::BuiltinArguments, v8::internal::Isolate*) ./../../v8/src/builtins/builtins-api.cc:139:3 #22 0x5583c5d2ae35 in Builtins_CEntry_Return1_ArgvOnStack_BuiltinExit setup-isolate-deserialize.cc:0:0 #23 0x5583c5c8c4ce in construct_stub_invoke_deopt_addr setup-isolate-deserialize.cc:0:0 #24 0x5583c5e21113 in Builtins_ConstructHandler setup-isolate-deserialize.cc:0:0 #25 0x5583c5c8b8a6 in Builtins_InterpreterEntryTrampoline setup-isolate-deserialize.cc:0:0 #26 0x5583c5c8931b in Builtins_JSEntryTrampoline setup-isolate-deserialize.cc:0:0 #27 0x5583c5c8905e in Builtins_JSEntry setup-isolate-deserialize.cc:0:0 #28 0x5583c215316c in Call ./../../v8/src/execution/simulator.h:187:12 #29 0x5583c215316c in v8::internal::(anonymous namespace)::Invoke(v8::internal::Isolate*, v8::internal::(anonymous namespace)::InvokeParams const&) ./../../v8/src/execution/execution.cc:420:22 #30 0x5583c2155a41 in v8::internal::Execution::CallScript(v8::internal::Isolate*, v8::internal::Handle, v8::internal::Handle, v8::internal::Handle) ./../../v8/src/execution/execution.cc:517:10 #31 0x5583c1c6ee1e in v8::Script::Run(v8::Local, v8::Local) ./../../v8/src/api/api.cc:2128:7 #32 0x5583dae323f3 in blink::V8ScriptRunner::RunCompiledScript(v8::Isolate*, v8::Local, v8::Local, blink::ExecutionContext*) ./../../third_party/blink/renderer/bindings/core/v8/v8_script_runner.cc:511:22 #33 0x5583dae33ab4 in blink::V8ScriptRunner::CompileAndRunScript(blink::ScriptState*, blink::ClassicScript*, blink::ExecuteScriptPolicy, blink::V8ScriptRunner::RethrowErrorsOption) ./../../third_party/blink/renderer/bindings/core/v8/v8_script_runner.cc:634:22 #34 0x5583ddd0d213 in blink::ClassicScript::RunScriptOnScriptStateAndReturnValue(blink::ScriptState*, blink::ExecuteScriptPolicy, blink::V8ScriptRunner::RethrowErrorsOption) ./../../third_party/blink/renderer/core/script/classic_script.cc:222:10 #35 0x5583ddd62954 in blink::Script::RunScriptOnScriptState(blink::ScriptState*, blink::ExecuteScriptPolicy, blink::V8ScriptRunner::RethrowErrorsOption) ./../../third_party/blink/renderer/core/script/script.cc:33:17 #36 0x5583ddd62c9b in blink::Script::RunScript(blink::LocalDOMWindow*, blink::ExecuteScriptPolicy, blink::V8ScriptRunner::RethrowErrorsOption) ./../../third_party/blink/renderer/core/script/script.cc:40:3 Thread T18 (Realtime AudioW) created by T0 (chrome) here: #0 0x5583bc11c511 in ___interceptor_pthread_create _asan_rtl_:3 #1 0x5583cf2dbbb8 in base::(anonymous namespace)::CreateThread(unsigned long, bool, base::PlatformThreadBase::Delegate*, base::PlatformThreadHandle*, base::ThreadType, base::MessagePumpType) ./../../base/threading/platform_thread_posix.cc:146:13 #2 0x5583cf28c8f8 in base::SimpleThread::StartAsync() ./../../base/threading/simple_thread.cc:55:13 #3 0x5583cba8bb1a in blink::NonMainThread::CreateThread(blink::ThreadCreationParams const&) ./../../third_party/blink/renderer/platform/scheduler/worker/non_main_thread_impl.cc:41:11 #4 0x5583de2727ca in blink::WorkerBackingThread::WorkerBackingThread(blink::ThreadCreationParams const&) ./../../third_party/blink/renderer/core/workers/worker_backing_thread.cc:114:23 #5 0x5583e221f2a1 in make_unique ./../../third_party/libc++/src/include/__memory/unique_ptr.h:620:30 #6 0x5583e221f2a1 in blink::RealtimeAudioWorkletThread::RealtimeAudioWorkletThread(blink::WorkerReportingProxy&, base::TimeDelta) ./../../third_party/blink/renderer/modules/webaudio/realtime_audio_worklet_thread.cc:87:30 #7 0x5583e21293b8 in make_unique ./../../third_party/libc++/src/include/__memory/unique_ptr.h:620:30 #8 0x5583e21293b8 in CreateWorkletThreadWithConstraints ./../../third_party/blink/renderer/modules/webaudio/audio_worklet_messaging_proxy.cc:131:12 #9 0x5583e21293b8 in blink::AudioWorkletMessagingProxy::CreateWorkerThread() ./../../third_party/blink/renderer/modules/webaudio/audio_worklet_messaging_proxy.cc:116:10 #10 0x5583de269b95 in blink::ThreadedMessagingProxyBase::InitializeWorkerThread(std::__Cr::unique_ptr>, std::__Cr::optional const&, std::__Cr::optional const> const&, std::__Cr::unique_ptr>) ./../../third_party/blink/renderer/core/workers/threaded_messaging_proxy_base.cc:77:20 #11 0x5583e18031f9 in blink::ThreadedWorkletMessagingProxy::Initialize(blink::WorkerClients*, blink::WorkletModuleResponsesMap*, std::__Cr::optional const&, mojo::StructPtr) ./../../third_party/blink/renderer/core/workers/threaded_worklet_messaging_proxy.cc:160:3 #12 0x5583e21261cd in blink::AudioWorklet::CreateGlobalScope() ./../../third_party/blink/renderer/modules/webaudio/audio_worklet.cc:82:10 #13 0x5583de2b270f in blink::Worklet::FetchAndInvokeScript(blink::KURL const&, WTF::String const&, blink::WorkletPendingTasks*) ./../../third_party/blink/renderer/core/workers/worklet.cc:171:24 #14 0x5583de2b36a4 in Invoke, blink::KURL, blink::V8RequestCredentials, cppgc::internal::BasicPersistent > ./../../base/functional/bind_internal.h:738:12 #15 0x5583de2b36a4 in MakeItSo, blink::KURL, blink::V8RequestCredentials, cppgc::internal::BasicPersistent > > ./../../base/functional/bind_internal.h:930:12 #16 0x5583de2b36a4 in RunImpl, blink::KURL, blink::V8RequestCredentials, cppgc::internal::BasicPersistent >, 0UL, 1UL, 2UL, 3UL> ./../../base/functional/bind_internal.h:1067:14 #17 0x5583de2b36a4 in base::internal::Invoker&&, blink::KURL&&, blink::V8RequestCredentials&&, cppgc::internal::BasicPersistent&&>, base::internal::BindState, blink::KURL, blink::V8RequestCredentials, cppgc::internal::BasicPersistent>, void ()>::RunOnce(base::internal::BindStateBase*) ./../../base/functional/bind_internal.h:980:12 #18 0x5583cf1a6fd4 in Run ./../../base/functional/callback.h:156:12 #19 0x5583cf1a6fd4 in base::TaskAnnotator::RunTaskImpl(base::PendingTask&) ./../../base/task/common/task_annotator.cc:203:34 #20 0x5583cf20e236 in RunTask<(lambda at ../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:486:11)> ./../../base/task/common/task_annotator.h:90:5 #21 0x5583cf20e236 in base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::DoWorkImpl(base::LazyNow*) ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:484:23 #22 0x5583cf20d150 in base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::DoWork() ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:346:40 #23 0x5583cf20ef7a in non-virtual thunk to base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::DoWork() ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:0:0 #24 0x5583cf096b2d in base::MessagePumpDefault::Run(base::MessagePump::Delegate*) ./../../base/message_loop/message_pump_default.cc:40:55 #25 0x5583cf20fbe6 in base::sequence_manager::internal::ThreadControllerWithMessagePumpImpl::Run(bool, base::TimeDelta) ./../../base/task/sequence_manager/thread_controller_with_message_pump_impl.cc:654:12 #26 0x5583cf1370af in base::RunLoop::Run(base::Location const&) ./../../base/run_loop.cc:134:14 #27 0x5583e647c02c in content::RendererMain(content::MainFunctionParams) ./../../content/renderer/renderer_main.cc:359:16 #28 0x5583cc7e4368 in content::RunZygote(content::ContentMainDelegate*) ./../../content/app/content_main_runner_impl.cc:703:14 #29 0x5583cc7e5469 in content::RunOtherNamedProcessTypeMain(std::__Cr::basic_string, std::__Cr::allocator> const&, content::MainFunctionParams, content::ContentMainDelegate*) ./../../content/app/content_main_runner_impl.cc:807:12 #30 0x5583cc7e7d4f in content::ContentMainRunnerImpl::Run() ./../../content/app/content_main_runner_impl.cc:1175:10 #31 0x5583cc7e2645 in content::RunContentProcess(content::ContentMainParams, content::ContentMainRunner*) ./../../content/app/content_main.cc:333:36 #32 0x5583cc7e2c3b in content::ContentMain(content::ContentMainParams) ./../../content/app/content_main.cc:346:10 #33 0x5583bc16f9b3 in ChromeMain ./../../chrome/app/chrome_main.cc:230:12 #34 0x78aaac229d8f in __libc_start_call_main ./csu/../sysdeps/nptl/libc_start_call_main.h:58:16 SUMMARY: AddressSanitizer: heap-use-after-free (/home/pwn11/asan-linux-release/chrome+0xf2e7d64) (BuildId: ae1cf88400c90eab) Shadow bytes around the buggy address: 0x518000055700: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 0x518000055780: 00 00 00 00 00 00 00 00 00 00 00 01 fa fa fa fa 0x518000055800: fa fa fa fa fa fa fa fa fa fa fa fa fa fa f7 fa 0x518000055880: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd 0x518000055900: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd =>0x518000055980:[fd]fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd 0x518000055a00: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd 0x518000055a80: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd 0x518000055b00: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd 0x518000055b80: fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa fa 0x518000055c00: fa fa fa fa fa fa fa fa fa fa fa fa fa fa f7 fa Shadow byte legend (one shadow byte represents 8 application bytes): Addressable: 00 Partially addressable: 01 02 03 04 05 06 07 Heap left redzone: fa Freed heap region: fd Stack left redzone: f1 Stack mid redzone: f2 Stack right redzone: f3 Stack after return: f5 Stack use after scope: f8 Global redzone: f9 Global init order: f6 Poisoned by user: f7 Container overflow: fc Array cookie: ac Intra object redzone: bb ASan internal: fe Left alloca redzone: ca Right alloca redzone: cb ==1==ADDITIONAL INFO ==1==Note: Please include this section with the ASan report. Task trace: #0 0x5583e220ad46 in blink::AudioDestination::Render(base::TimeDelta, base::TimeTicks, media::AudioGlitchInfo const&, media::AudioBus*) ./../../third_party/blink/renderer/platform/audio/audio_destination.cc:204:34 Command line: `/proc/self/exe --type=renderer --crashpad-handler-pid=1079542 --enable-crash-reporter=, --user-data-dir=/tmp/xx2 --no-subproc-heap-profiling --change-stack-guard-on-fork=enable --file-url-path-alias=/gen=/home/pwn11/asan-linux-release/gen --disable-databases --disable-gpu-compositing --lang=en-US --num-raster-threads=4 --enable-main-frame-before-activation --renderer-client-id=5 --time-ticks-at-unix-epoch=-1721620696610055 --launch-time-ticks=130784094492 --shared-files=v8_context_snapshot_data:100 --metrics-shmem-handle=4,i,472013991247985170,11568835115277167954,2097152 --field-trial-handle=3,i,6690326979181892439,8267522154067825575,262144 --variations-seed-version` MiraclePtr Status: MANUAL ANALYSIS REQUIRED A pointer to the same region was extracted from a raw_ptr object prior to this crash. The "use" and "free" threads don't match. This crash is likely to have been caused by a race condition that is mislabeled as a use-after-free. Make sure that the "free" is sequenced after the "use" (e.g. both are on the same sequence, or the "free" is in a task posted after the "use"). Otherwise, the crash is still exploitable with MiraclePtr. Refer to https://chromium.googlesource.com/chromium/src/+/main/base/memory/raw_ptr.md for details. ==1==END OF ADDITIONAL INFO ==1==ABORTING