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

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

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
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 #ifndef MEDIA_MOJO_CLIENTS_MOJO_RENDERER_IMPL_H_ 5 #ifndef MEDIA_MOJO_CLIENTS_MOJO_RENDERER_IMPL_H_
6 #define MEDIA_MOJO_CLIENTS_MOJO_RENDERER_IMPL_H_ 6 #define MEDIA_MOJO_CLIENTS_MOJO_RENDERER_IMPL_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "media/base/renderer.h" 11 #include "media/base/renderer.h"
12 #include "media/mojo/interfaces/renderer.mojom.h" 12 #include "media/mojo/interfaces/renderer.mojom.h"
13 #include "mojo/public/cpp/bindings/binding.h" 13 #include "mojo/public/cpp/bindings/binding.h"
14 14
15 namespace base { 15 namespace base {
16 class SingleThreadTaskRunner; 16 class SingleThreadTaskRunner;
17 } 17 }
18 18
19 namespace media { 19 namespace media {
20 20
21 class DemuxerStreamProvider; 21 class DemuxerStreamProvider;
22 class MojoDemuxerStreamImpl;
22 class VideoOverlayFactory; 23 class VideoOverlayFactory;
23 class VideoRendererSink; 24 class VideoRendererSink;
24 25
25 // A media::Renderer that proxies to a mojom::Renderer. That 26 // A media::Renderer that proxies to a mojom::Renderer. That
26 // mojom::Renderer proxies back to the MojoRendererImpl via the 27 // mojom::Renderer proxies back to the MojoRendererImpl via the
27 // mojom::RendererClient interface. 28 // mojom::RendererClient interface.
28 // 29 //
29 // This class can be created on any thread, where the |remote_renderer| is 30 // This class can be created on any thread, where the |remote_renderer| is
30 // connected and passed in the constructor. Then Initialize() will be called on 31 // connected and passed in the constructor. Then Initialize() will be called on
31 // the |task_runner| and starting from that point this class is bound to the 32 // the |task_runner| and starting from that point this class is bound to the
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
81 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; 82 scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
82 83
83 // Overlay factory used to create overlays for video frames rendered 84 // Overlay factory used to create overlays for video frames rendered
84 // by the remote renderer. 85 // by the remote renderer.
85 std::unique_ptr<VideoOverlayFactory> video_overlay_factory_; 86 std::unique_ptr<VideoOverlayFactory> video_overlay_factory_;
86 87
87 // Video frame overlays are rendered onto this sink. 88 // Video frame overlays are rendered onto this sink.
88 // Rendering of a new overlay is only needed when video natural size changes. 89 // Rendering of a new overlay is only needed when video natural size changes.
89 VideoRendererSink* video_renderer_sink_; 90 VideoRendererSink* video_renderer_sink_;
90 91
91 // Provider of audio/video DemuxerStreams. Must be valid throughout the
92 // lifetime of |this|.
93 DemuxerStreamProvider* demuxer_stream_provider_;
94
95 // Client of |this| renderer passed in Initialize. 92 // Client of |this| renderer passed in Initialize.
96 media::RendererClient* client_; 93 media::RendererClient* client_;
97 94
95 // Mojo demuxer streams.
96 // Owned by MojoRendererImpl instead of remote mojom::Renderer
97 // becuase these demuxer streams need to be destroyed as soon as |this| is
98 // destroyed. The local demuxer streams returned by DemuxerStreamProvider
99 // cannot be used after |this| is destroyed.
100 std::unique_ptr<MojoDemuxerStreamImpl> audio_stream_;
101 std::unique_ptr<MojoDemuxerStreamImpl> video_stream_;
102
98 // This class is constructed on one thread and used exclusively on another 103 // This class is constructed on one thread and used exclusively on another
99 // thread. This member is used to safely pass the RendererPtr from one thread 104 // thread. This member is used to safely pass the RendererPtr from one thread
100 // to another. It is set in the constructor and is consumed in Initialize(). 105 // to another. It is set in the constructor and is consumed in Initialize().
101 mojom::RendererPtrInfo remote_renderer_info_; 106 mojom::RendererPtrInfo remote_renderer_info_;
102 107
103 // Remote Renderer, bound to |task_runner_| during Initialize(). 108 // Remote Renderer, bound to |task_runner_| during Initialize().
104 mojom::RendererPtr remote_renderer_; 109 mojom::RendererPtr remote_renderer_;
105 110
106 // Binding for RendererClient, bound to the |task_runner_|. 111 // Binding for RendererClient, bound to the |task_runner_|.
107 mojo::Binding<RendererClient> binding_; 112 mojo::Binding<RendererClient> binding_;
108 113
109 // Callbacks passed to Initialize() that we forward messages from 114 // Callbacks passed to Initialize() that we forward messages from
110 // |remote_renderer_| through. 115 // |remote_renderer_| through.
111 PipelineStatusCB init_cb_; 116 PipelineStatusCB init_cb_;
112 117
113 // Lock used to serialize access for |time_|. 118 // Lock used to serialize access for |time_|.
114 mutable base::Lock lock_; 119 mutable base::Lock lock_;
115 base::TimeDelta time_; 120 base::TimeDelta time_;
116 121
117 DISALLOW_COPY_AND_ASSIGN(MojoRendererImpl); 122 DISALLOW_COPY_AND_ASSIGN(MojoRendererImpl);
118 }; 123 };
119 124
120 } // namespace media 125 } // namespace media
121 126
122 #endif // MEDIA_MOJO_CLIENTS_MOJO_RENDERER_IMPL_H_ 127 #endif // MEDIA_MOJO_CLIENTS_MOJO_RENDERER_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698