Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 <linux/videodev2.h> | 5 #include <linux/videodev2.h> |
| 6 | 6 |
| 7 #include "base/numerics/safe_conversions.h" | 7 #include "base/numerics/safe_conversions.h" |
| 8 #include "content/common/gpu/media/exynos_v4l2_video_device.h" | 8 #include "content/common/gpu/media/exynos_v4l2_video_device.h" |
| 9 #include "content/common/gpu/media/tegra_v4l2_video_device.h" | 9 #include "content/common/gpu/media/tegra_v4l2_video_device.h" |
| 10 | 10 |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 99 bytesperline = base::checked_cast<int>(format.fmt.pix.bytesperline); | 99 bytesperline = base::checked_cast<int>(format.fmt.pix.bytesperline); |
| 100 sizeimage = base::checked_cast<int>(format.fmt.pix.sizeimage); | 100 sizeimage = base::checked_cast<int>(format.fmt.pix.sizeimage); |
| 101 visible_size.SetSize(base::checked_cast<int>(format.fmt.pix.width), | 101 visible_size.SetSize(base::checked_cast<int>(format.fmt.pix.width), |
| 102 base::checked_cast<int>(format.fmt.pix.height)); | 102 base::checked_cast<int>(format.fmt.pix.height)); |
| 103 frame_format = | 103 frame_format = |
| 104 V4L2Device::V4L2PixFmtToVideoFrameFormat(format.fmt.pix.pixelformat); | 104 V4L2Device::V4L2PixFmtToVideoFrameFormat(format.fmt.pix.pixelformat); |
| 105 } | 105 } |
| 106 | 106 |
| 107 int horiz_bpp = | 107 int horiz_bpp = |
| 108 media::VideoFrame::PlaneHorizontalBitsPerPixel(frame_format, 0); | 108 media::VideoFrame::PlaneHorizontalBitsPerPixel(frame_format, 0); |
| 109 DVLOG(3) << "CodedSizeFromV4L2Format: bytesperline=" << bytesperline | |
| 110 << ", sizeimage=" << sizeimage | |
| 111 << ", visible_size=" << visible_size.width() | |
|
Pawel Osciak
2014/07/24 05:24:59
Nit: visible_size.ToString()
wuchengli
2014/07/30 09:18:05
Done.
| |
| 112 << "x" << visible_size.height() | |
| 113 << ", frame_format=" << frame_format | |
|
Pawel Osciak
2014/07/24 05:24:59
Nit: VideoFrame::FormatToString(frame_format)
wuchengli
2014/07/30 09:18:05
Done.
| |
| 114 << ", horiz_bpp=" << horiz_bpp; | |
| 109 if (sizeimage == 0 || bytesperline == 0 || horiz_bpp == 0 || | 115 if (sizeimage == 0 || bytesperline == 0 || horiz_bpp == 0 || |
| 110 (bytesperline * 8) % horiz_bpp != 0) { | 116 (bytesperline * 8) % horiz_bpp != 0) { |
| 111 DLOG(ERROR) << "Invalid format provided"; | 117 DLOG(ERROR) << "Invalid format provided"; |
| 112 return coded_size; | 118 return coded_size; |
| 113 } | 119 } |
| 114 | 120 |
| 115 // Round up sizeimage to full bytesperlines. sizeimage does not have to be | 121 // Round up sizeimage to full bytesperlines. sizeimage does not have to be |
| 116 // a multiple of bytesperline, as in V4L2 terms it's just a byte size of | 122 // a multiple of bytesperline, as in V4L2 terms it's just a byte size of |
| 117 // the buffer, unrelated to its payload. | 123 // the buffer, unrelated to its payload. |
| 118 sizeimage = ((sizeimage + bytesperline - 1) / bytesperline) * bytesperline; | 124 sizeimage = ((sizeimage + bytesperline - 1) / bytesperline) * bytesperline; |
| 119 | 125 |
| 120 coded_size.SetSize(bytesperline * 8 / horiz_bpp, sizeimage / bytesperline); | 126 coded_size.SetSize(bytesperline * 8 / horiz_bpp, sizeimage / bytesperline); |
| 127 DVLOG(3) << "coded_size=" << coded_size.width() << "x" << coded_size.height(); | |
| 121 | 128 |
| 122 // Sanity checks. Calculated coded size has to contain given visible size | 129 // Sanity checks. Calculated coded size has to contain given visible size |
| 123 // and fulfill buffer byte size requirements for each plane. | 130 // and fulfill buffer byte size requirements for each plane. |
| 124 DCHECK(gfx::Rect(coded_size).Contains(gfx::Rect(visible_size))); | 131 DCHECK(gfx::Rect(coded_size).Contains(gfx::Rect(visible_size))); |
| 125 | 132 |
| 126 if (V4L2_TYPE_IS_MULTIPLANAR(format.type)) { | |
| 127 for (size_t i = 0; i < format.fmt.pix_mp.num_planes; ++i) { | |
| 128 DCHECK_LE( | |
| 129 format.fmt.pix_mp.plane_fmt[i].sizeimage, | |
|
Pawel Osciak
2014/07/24 05:24:59
Perhaps we could keep the checks, but make them DC
wuchengli
2014/07/30 09:18:05
As mentioned in bug 387701, the extra 256-byte pad
| |
| 130 media::VideoFrame::PlaneAllocationSize(frame_format, i, coded_size)); | |
| 131 DCHECK_LE(format.fmt.pix_mp.plane_fmt[i].bytesperline, | |
| 132 base::checked_cast<__u32>(coded_size.width())); | |
| 133 } | |
| 134 } | |
| 135 | |
| 136 return coded_size; | 133 return coded_size; |
| 137 } | 134 } |
| 138 | 135 |
| 139 } // namespace content | 136 } // namespace content |
| OLD | NEW |