Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(418)

Side by Side Diff: media/mojo/clients/mojo_renderer_impl.cc

Issue 2075193002: Fixes use-after-free in MojoDemuxerStreamImpl. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « media/mojo/clients/mojo_renderer_impl.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "media/mojo/clients/mojo_renderer_impl.h" 5 #include "media/mojo/clients/mojo_renderer_impl.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/callback_helpers.h" 10 #include "base/callback_helpers.h"
(...skipping 26 matching lines...) Expand all
37 } 37 }
38 38
39 void MojoRendererImpl::Initialize( 39 void MojoRendererImpl::Initialize(
40 DemuxerStreamProvider* demuxer_stream_provider, 40 DemuxerStreamProvider* demuxer_stream_provider,
41 media::RendererClient* client, 41 media::RendererClient* client,
42 const PipelineStatusCB& init_cb) { 42 const PipelineStatusCB& init_cb) {
43 DVLOG(1) << __FUNCTION__; 43 DVLOG(1) << __FUNCTION__;
44 DCHECK(task_runner_->BelongsToCurrentThread()); 44 DCHECK(task_runner_->BelongsToCurrentThread());
45 DCHECK(demuxer_stream_provider); 45 DCHECK(demuxer_stream_provider);
46 46
47 demuxer_stream_provider_ = demuxer_stream_provider;
48 client_ = client; 47 client_ = client;
49 init_cb_ = init_cb; 48 init_cb_ = init_cb;
50 49
51 // Create audio and video mojom::DemuxerStream and bind its lifetime to 50 // Create audio and video mojom::DemuxerStream and bind its lifetime to
52 // the pipe. 51 // the pipe.
53 DemuxerStream* const audio = 52 DemuxerStream* const audio =
54 demuxer_stream_provider_->GetStream(DemuxerStream::AUDIO); 53 demuxer_stream_provider->GetStream(DemuxerStream::AUDIO);
55 DemuxerStream* const video = 54 DemuxerStream* const video =
56 demuxer_stream_provider_->GetStream(DemuxerStream::VIDEO); 55 demuxer_stream_provider->GetStream(DemuxerStream::VIDEO);
57 56
58 mojom::DemuxerStreamPtr audio_stream; 57 mojom::DemuxerStreamPtr audio_stream;
59 if (audio) 58 if (audio) {
60 new MojoDemuxerStreamImpl(audio, GetProxy(&audio_stream)); 59 audio_stream_.reset(
60 new MojoDemuxerStreamImpl(audio, GetProxy(&audio_stream)));
61 }
61 62
62 mojom::DemuxerStreamPtr video_stream; 63 mojom::DemuxerStreamPtr video_stream;
63 if (video) 64 if (video) {
64 new MojoDemuxerStreamImpl(video, GetProxy(&video_stream)); 65 video_stream_.reset(
66 new MojoDemuxerStreamImpl(video, GetProxy(&video_stream)));
67 }
xhwang 2016/06/17 18:47:00 In theory, if the remote renderer doesn't care abo
alokp 2016/06/17 20:16:37 If we decide to support this use case it would be
alokp 2016/06/17 20:40:28 Whoops I did not think this through. You would sti
65 68
66 BindRemoteRendererIfNeeded(); 69 BindRemoteRendererIfNeeded();
67 70
68 // Using base::Unretained(this) is safe because |this| owns 71 // Using base::Unretained(this) is safe because |this| owns
69 // |remote_renderer_|, and the callback won't be dispatched if 72 // |remote_renderer_|, and the callback won't be dispatched if
70 // |remote_renderer_| is destroyed. 73 // |remote_renderer_| is destroyed.
71 remote_renderer_->Initialize( 74 remote_renderer_->Initialize(
72 binding_.CreateInterfacePtrAndBind(), std::move(audio_stream), 75 binding_.CreateInterfacePtrAndBind(), std::move(audio_stream),
73 std::move(video_stream), 76 std::move(video_stream),
74 base::Bind(&MojoRendererImpl::OnInitialized, base::Unretained(this))); 77 base::Bind(&MojoRendererImpl::OnInitialized, base::Unretained(this)));
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
129 base::TimeDelta MojoRendererImpl::GetMediaTime() { 132 base::TimeDelta MojoRendererImpl::GetMediaTime() {
130 base::AutoLock auto_lock(lock_); 133 base::AutoLock auto_lock(lock_);
131 DVLOG(3) << __FUNCTION__ << ": " << time_.InMilliseconds() << " ms"; 134 DVLOG(3) << __FUNCTION__ << ": " << time_.InMilliseconds() << " ms";
132 return time_; 135 return time_;
133 } 136 }
134 137
135 bool MojoRendererImpl::HasAudio() { 138 bool MojoRendererImpl::HasAudio() {
136 DVLOG(1) << __FUNCTION__; 139 DVLOG(1) << __FUNCTION__;
137 DCHECK(task_runner_->BelongsToCurrentThread()); 140 DCHECK(task_runner_->BelongsToCurrentThread());
138 DCHECK(remote_renderer_.get()); // We always bind the renderer. 141 DCHECK(remote_renderer_.get()); // We always bind the renderer.
139 return !!demuxer_stream_provider_->GetStream(DemuxerStream::AUDIO); 142 return !!audio_stream_;
140 } 143 }
141 144
142 bool MojoRendererImpl::HasVideo() { 145 bool MojoRendererImpl::HasVideo() {
143 DVLOG(1) << __FUNCTION__; 146 DVLOG(1) << __FUNCTION__;
144 DCHECK(task_runner_->BelongsToCurrentThread()); 147 DCHECK(task_runner_->BelongsToCurrentThread());
145 return !!demuxer_stream_provider_->GetStream(DemuxerStream::VIDEO); 148 return !!video_stream_;
146 } 149 }
147 150
148 void MojoRendererImpl::OnTimeUpdate(int64_t time_usec, int64_t max_time_usec) { 151 void MojoRendererImpl::OnTimeUpdate(int64_t time_usec, int64_t max_time_usec) {
149 DVLOG(3) << __FUNCTION__ << ": " << time_usec << ", " << max_time_usec; 152 DVLOG(3) << __FUNCTION__ << ": " << time_usec << ", " << max_time_usec;
150 DCHECK(task_runner_->BelongsToCurrentThread()); 153 DCHECK(task_runner_->BelongsToCurrentThread());
151 154
152 base::AutoLock auto_lock(lock_); 155 base::AutoLock auto_lock(lock_);
153 time_ = base::TimeDelta::FromMicroseconds(time_usec); 156 time_ = base::TimeDelta::FromMicroseconds(time_usec);
154 } 157 }
155 158
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
224 void MojoRendererImpl::OnInitialized(bool success) { 227 void MojoRendererImpl::OnInitialized(bool success) {
225 DVLOG(1) << __FUNCTION__; 228 DVLOG(1) << __FUNCTION__;
226 DCHECK(task_runner_->BelongsToCurrentThread()); 229 DCHECK(task_runner_->BelongsToCurrentThread());
227 DCHECK(!init_cb_.is_null()); 230 DCHECK(!init_cb_.is_null());
228 231
229 base::ResetAndReturn(&init_cb_).Run( 232 base::ResetAndReturn(&init_cb_).Run(
230 success ? PIPELINE_OK : PIPELINE_ERROR_INITIALIZATION_FAILED); 233 success ? PIPELINE_OK : PIPELINE_ERROR_INITIALIZATION_FAILED);
231 } 234 }
232 235
233 } // namespace media 236 } // namespace media
OLDNEW
« no previous file with comments | « media/mojo/clients/mojo_renderer_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698