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

Issue 2394483005: iOS: Optimize video scaling and cropping (Closed)

Created:
4 years, 2 months ago by magjed_webrtc
Modified:
4 years, 2 months ago
Reviewers:
tkchin_webrtc
CC:
webrtc-reviews_webrtc.org, tterriberry_mozilla.com, zhengzhonghou_agora.io, video-team_agora.io, stefan-webrtc, mflodman
Target Ref:
refs/pending/heads/master
Project:
webrtc
Visibility:
Public.

Description

iOS: Optimize video scaling and cropping This CL makes scaling and cropping lazy in AVFoundationVideoCapturer and provides optimized paths for SW and HW encoding. For SW encoding, an efficient NV12 -> I420 cropping and scaling is implemented in CoreVideoFrameBuffer::NativeToI420. For HW encoding, an efficient NV12 -> NV12 cropping and scaling is implemented in CoreVideoFrameBuffer::CropAndScaleTo. The performance improvement over the existing cropping and scaling is that it is now done in one step instead of making an intermediary copy of the Y plane. There might still be room for improvement in the HW path using some HW support. That will be explored in a future CL. BUG=b/30939444 Committed: https://crrev.com/5a8724564c2245603ba59edf8d6d2736d0efa0ce Cr-Commit-Position: refs/heads/master@{#14701}

Patch Set 1 #

Patch Set 2 : Fix unittest. #

Total comments: 17

Patch Set 3 : Fix Zekes comments. #

Patch Set 4 : Add comment about the different resolution variables. #

Unified diffs Side-by-side diffs Delta from patch set Stats (+316 lines, -67 lines) Patch
M webrtc/common_video/corevideo_frame_buffer.cc View 1 2 2 chunks +104 lines, -17 lines 0 comments Download
M webrtc/common_video/include/corevideo_frame_buffer.h View 1 2 3 2 chunks +26 lines, -0 lines 0 comments Download
M webrtc/common_video/libyuv/include/webrtc_libyuv.h View 1 chunk +9 lines, -0 lines 0 comments Download
M webrtc/common_video/libyuv/libyuv_unittest.cc View 1 2 chunks +51 lines, -0 lines 0 comments Download
M webrtc/common_video/libyuv/webrtc_libyuv.cc View 1 chunk +58 lines, -0 lines 0 comments Download
M webrtc/modules/video_coding/codecs/h264/h264_video_toolbox_encoder.h View 1 chunk +1 line, -0 lines 0 comments Download
M webrtc/modules/video_coding/codecs/h264/h264_video_toolbox_encoder.mm View 1 2 3 chunks +40 lines, -17 lines 0 comments Download
M webrtc/sdk/objc/Framework/Classes/avfoundationvideocapturer.mm View 1 2 3 3 chunks +27 lines, -33 lines 0 comments Download

Messages

Total messages: 17 (10 generated)
magjed_webrtc
Zeke - please take a look.
4 years, 2 months ago (2016-10-18 15:35:25 UTC) #7
tkchin_webrtc
lgtm https://codereview.webrtc.org/2394483005/diff/40001/webrtc/common_video/corevideo_frame_buffer.cc File webrtc/common_video/corevideo_frame_buffer.cc (right): https://codereview.webrtc.org/2394483005/diff/40001/webrtc/common_video/corevideo_frame_buffer.cc#newcode94 webrtc/common_video/corevideo_frame_buffer.cc:94: std::vector<uint8_t>* tmp_buffer, is buffer passed in so that ...
4 years, 2 months ago (2016-10-19 00:48:32 UTC) #8
magjed_webrtc
https://codereview.webrtc.org/2394483005/diff/40001/webrtc/common_video/corevideo_frame_buffer.cc File webrtc/common_video/corevideo_frame_buffer.cc (right): https://codereview.webrtc.org/2394483005/diff/40001/webrtc/common_video/corevideo_frame_buffer.cc#newcode94 webrtc/common_video/corevideo_frame_buffer.cc:94: std::vector<uint8_t>* tmp_buffer, On 2016/10/19 00:48:32, tkchin_webrtc wrote: > is ...
4 years, 2 months ago (2016-10-19 13:19:34 UTC) #9
tkchin_webrtc
lgtm https://codereview.webrtc.org/2394483005/diff/40001/webrtc/common_video/corevideo_frame_buffer.cc File webrtc/common_video/corevideo_frame_buffer.cc (right): https://codereview.webrtc.org/2394483005/diff/40001/webrtc/common_video/corevideo_frame_buffer.cc#newcode142 webrtc/common_video/corevideo_frame_buffer.cc:142: CVPixelBufferUnlockBaseAddress(pixel_buffer_, kCVPixelBufferLock_ReadOnly); On 2016/10/19 13:19:34, magjed_webrtc wrote: > ...
4 years, 2 months ago (2016-10-19 22:50:17 UTC) #10
commit-bot: I haz the power
CQ is trying da patch. Follow status at https://chromium-cq-status.appspot.com/v2/patch-status/codereview.webrtc.org/2394483005/80001
4 years, 2 months ago (2016-10-20 08:51:49 UTC) #13
commit-bot: I haz the power
Committed patchset #4 (id:80001)
4 years, 2 months ago (2016-10-20 10:34:31 UTC) #15
commit-bot: I haz the power
4 years, 2 months ago (2016-10-20 10:34:40 UTC) #17
Message was sent while issue was closed.
Patchset 4 (id:??) landed as
https://crrev.com/5a8724564c2245603ba59edf8d6d2736d0efa0ce
Cr-Commit-Position: refs/heads/master@{#14701}

Powered by Google App Engine
This is Rietveld 408576698