OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 CHROME_GPU_ARC_GPU_VIDEO_DECODE_ACCELERATOR_H_ | 5 #ifndef CHROME_GPU_ARC_GPU_VIDEO_DECODE_ACCELERATOR_H_ |
6 #define CHROME_GPU_ARC_GPU_VIDEO_DECODE_ACCELERATOR_H_ | 6 #define CHROME_GPU_ARC_GPU_VIDEO_DECODE_ACCELERATOR_H_ |
7 | 7 |
8 #include <list> | 8 #include <list> |
9 #include <memory> | 9 #include <memory> |
10 #include <queue> | 10 #include <queue> |
(...skipping 24 matching lines...) Expand all Loading... |
35 bool Initialize(const Config& config, | 35 bool Initialize(const Config& config, |
36 ArcVideoAccelerator::Client* client) override; | 36 ArcVideoAccelerator::Client* client) override; |
37 void SetNumberOfOutputBuffers(size_t number) override; | 37 void SetNumberOfOutputBuffers(size_t number) override; |
38 void BindSharedMemory(PortType port, | 38 void BindSharedMemory(PortType port, |
39 uint32_t index, | 39 uint32_t index, |
40 base::ScopedFD ashmem_fd, | 40 base::ScopedFD ashmem_fd, |
41 off_t offset, | 41 off_t offset, |
42 size_t length) override; | 42 size_t length) override; |
43 void BindDmabuf(PortType port, | 43 void BindDmabuf(PortType port, |
44 uint32_t index, | 44 uint32_t index, |
45 base::ScopedFD dmabuf_fd) override; | 45 base::ScopedFD dmabuf_fd, |
| 46 int32_t stride) override; |
46 void UseBuffer(PortType port, | 47 void UseBuffer(PortType port, |
47 uint32_t index, | 48 uint32_t index, |
48 const BufferMetadata& metadata) override; | 49 const BufferMetadata& metadata) override; |
49 void Reset() override; | 50 void Reset() override; |
50 | 51 |
51 // Implementation of the VideoDecodeAccelerator::Client interface. | 52 // Implementation of the VideoDecodeAccelerator::Client interface. |
52 void ProvidePictureBuffers(uint32_t requested_num_of_buffers, | 53 void ProvidePictureBuffers(uint32_t requested_num_of_buffers, |
53 uint32_t textures_per_buffer, | 54 uint32_t textures_per_buffer, |
54 const gfx::Size& dimensions, | 55 const gfx::Size& dimensions, |
55 uint32_t texture_target) override; | 56 uint32_t texture_target) override; |
(...skipping 15 matching lines...) Expand all Loading... |
71 InputRecord(int32_t bitstream_buffer_id, | 72 InputRecord(int32_t bitstream_buffer_id, |
72 uint32_t buffer_index, | 73 uint32_t buffer_index, |
73 int64_t timestamp); | 74 int64_t timestamp); |
74 }; | 75 }; |
75 | 76 |
76 // The information about the shared memory used as an input buffer. | 77 // The information about the shared memory used as an input buffer. |
77 struct InputBufferInfo { | 78 struct InputBufferInfo { |
78 // The file handle to access the buffer. It is owned by this class and | 79 // The file handle to access the buffer. It is owned by this class and |
79 // should be closed after use. | 80 // should be closed after use. |
80 base::ScopedFD handle; | 81 base::ScopedFD handle; |
81 off_t offset; | 82 |
82 size_t length; | 83 // The offset of the payload to the beginning of the shared memory. |
| 84 off_t offset = 0; |
| 85 |
| 86 // The size of the payload in bytes. |
| 87 size_t length = 0; |
83 | 88 |
84 InputBufferInfo(); | 89 InputBufferInfo(); |
85 InputBufferInfo(InputBufferInfo&& other); | 90 InputBufferInfo(InputBufferInfo&& other); |
86 ~InputBufferInfo(); | 91 ~InputBufferInfo(); |
87 }; | 92 }; |
88 | 93 |
| 94 // The information about the dmabuf used as an output buffer. |
| 95 struct OutputBufferInfo { |
| 96 base::ScopedFD handle; |
| 97 int32_t stride = 0; // In bytes. |
| 98 |
| 99 OutputBufferInfo(); |
| 100 OutputBufferInfo(OutputBufferInfo&& other); |
| 101 ~OutputBufferInfo(); |
| 102 }; |
| 103 |
89 // Helper function to Send the end-of-stream output buffer if | 104 // Helper function to Send the end-of-stream output buffer if |
90 // |pending_eos_output_buffer_| is true, or reuse the picture in ArcVDA. | 105 // |pending_eos_output_buffer_| is true, or reuse the picture in ArcVDA. |
91 void SendEosIfNeededOrReusePicture(uint32_t index); | 106 void SendEosIfNeededOrReusePicture(uint32_t index); |
92 | 107 |
93 // Helper function to validate |port| and |index|. | 108 // Helper function to validate |port| and |index|. |
94 bool ValidatePortAndIndex(PortType port, uint32_t index); | 109 bool ValidatePortAndIndex(PortType port, uint32_t index); |
95 | 110 |
| 111 // Helper function to verify the length of stride is legal. |
| 112 bool VerifyStride(const base::ScopedFD& fd, int32_t stride); |
| 113 |
96 // Creates an InputRecord for the given |bitstream_buffer_id|. The | 114 // Creates an InputRecord for the given |bitstream_buffer_id|. The |
97 // |buffer_index| is the index of the associated input buffer. The |timestamp| | 115 // |buffer_index| is the index of the associated input buffer. The |timestamp| |
98 // is the time the video frame should be displayed. | 116 // is the time the video frame should be displayed. |
99 void CreateInputRecord(int32_t bitstream_buffer_id, | 117 void CreateInputRecord(int32_t bitstream_buffer_id, |
100 uint32_t buffer_index, | 118 uint32_t buffer_index, |
101 int64_t timestamp); | 119 int64_t timestamp); |
102 | 120 |
103 // Finds the InputRecord which matches to given |bitstream_buffer_id|. | 121 // Finds the InputRecord which matches to given |bitstream_buffer_id|. |
104 // Returns |nullptr| if it cannot be found. | 122 // Returns |nullptr| if it cannot be found. |
105 InputRecord* FindInputRecord(int32_t bitstream_buffer_id); | 123 InputRecord* FindInputRecord(int32_t bitstream_buffer_id); |
106 | 124 |
107 // When true, an EOS output buffer need to be sent to |arc_client_| once an | 125 // When true, an EOS output buffer need to be sent to |arc_client_| once an |
108 // output buffer is available. | 126 // output buffer is available. |
109 bool pending_eos_output_buffer_; | 127 bool pending_eos_output_buffer_; |
110 | 128 |
111 std::unique_ptr<media::VideoDecodeAccelerator> vda_; | 129 std::unique_ptr<media::VideoDecodeAccelerator> vda_; |
112 | 130 |
113 // It's safe to use the pointer here, the life cycle of the |arc_client_| | 131 // It's safe to use the pointer here, the life cycle of the |arc_client_| |
114 // is longer than this ArcGpuVideoDecodeAccelerator. | 132 // is longer than this ArcGpuVideoDecodeAccelerator. |
115 ArcVideoAccelerator::Client* arc_client_; | 133 ArcVideoAccelerator::Client* arc_client_; |
116 | 134 |
117 // The next ID for the bitstream buffer, started from 0. | 135 // The next ID for the bitstream buffer, started from 0. |
118 int32_t next_bitstream_buffer_id_; | 136 int32_t next_bitstream_buffer_id_; |
119 | 137 |
120 gfx::Size coded_size_; | 138 gfx::Size coded_size_; |
| 139 media::VideoPixelFormat output_pixel_format_; |
121 | 140 |
122 // The |picture_buffer_id|s for Pictures that were returned to us from VDA | 141 // The |picture_buffer_id|s for Pictures that were returned to us from VDA |
123 // via PictureReady() while flushing. We keep them until NotifyFlushDone(); | 142 // via PictureReady() while flushing. We keep them until NotifyFlushDone(); |
124 // once it's called, we send one of the pending buffers from this queue (if | 143 // once it's called, we send one of the pending buffers from this queue (if |
125 // not empty), marked with an EOS flag, to |arc_client_|, and return the rest | 144 // not empty), marked with an EOS flag, to |arc_client_|, and return the rest |
126 // to VDA for reuse. | 145 // to VDA for reuse. |
127 std::queue<int32_t> buffers_pending_eos_; | 146 std::queue<int32_t> buffers_pending_eos_; |
128 | 147 |
129 // A list of most recent |kMaxNumberOfInputRecord| InputRecords. | 148 // A list of most recent |kMaxNumberOfInputRecord| InputRecords. |
130 // |kMaxNumberOfInputRecord| is defined in the cc file. | 149 // |kMaxNumberOfInputRecord| is defined in the cc file. |
131 std::list<InputRecord> input_records_; | 150 std::list<InputRecord> input_records_; |
132 | 151 |
133 // The details of the shared memory of each input buffers. | 152 // The details of the shared memory of each input buffers. |
134 std::vector<InputBufferInfo> input_buffer_info_; | 153 std::vector<InputBufferInfo> input_buffer_info_; |
135 | 154 |
136 // To keep those output buffers which have been bound by bindDmabuf() but not | 155 // To keep those output buffers which have been bound by bindDmabuf() but |
137 // be used yet. Will call VDA::ImportBufferForPicture() when those buffers are | 156 // haven't been passed to VDA yet. Will call VDA::ImportBufferForPicture() |
138 // used for the first time. | 157 // when those buffers are used for the first time. |
139 std::vector<base::ScopedFD> buffers_pending_import_; | 158 std::vector<OutputBufferInfo> buffers_pending_import_; |
140 | 159 |
141 base::ThreadChecker thread_checker_; | 160 base::ThreadChecker thread_checker_; |
142 size_t output_buffer_size_; | 161 size_t output_buffer_size_; |
143 | 162 |
144 gpu::GpuPreferences gpu_preferences_; | 163 gpu::GpuPreferences gpu_preferences_; |
145 | 164 |
146 DISALLOW_COPY_AND_ASSIGN(ArcGpuVideoDecodeAccelerator); | 165 DISALLOW_COPY_AND_ASSIGN(ArcGpuVideoDecodeAccelerator); |
147 }; | 166 }; |
148 | 167 |
149 } // namespace arc | 168 } // namespace arc |
150 } // namespace chromeos | 169 } // namespace chromeos |
151 | 170 |
152 #endif // CHROME_GPU_ARC_GPU_VIDEO_DECODE_ACCELERATOR_H_ | 171 #endif // CHROME_GPU_ARC_GPU_VIDEO_DECODE_ACCELERATOR_H_ |
OLD | NEW |