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

Issue 2939493002: RTCVideoEncoder.SupportsNativeHandle() should return true (Closed)

Created:
3 years, 6 months ago by magjed_chromium
Modified:
3 years, 6 months ago
CC:
chromium-reviews, mlamouri+watch-content_chromium.org, posciak+watch_chromium.org, jam, feature-media-reviews_chromium.org, darin-cc_chromium.org, piman+watch_chromium.org
Target Ref:
refs/heads/master
Project:
chromium
Visibility:
Public.

Description

RTCVideoEncoder.SupportsNativeHandle() should return true RTCVideoEncoder.SupportsNativeHandle() means it can handle frames of type kNative, which in Chromium represents wrapped media::VideoFrames. Also, before accessing I420 data, i.e. DataY/U/V or StrideY/U/V, the function ToI420 should be called on webrtc::VideoFrameBuffer (these I420 functions will be removed from webrtc::VideoFrameBuffer soon). BUG=732345, 732418 Review-Url: https://codereview.chromium.org/2939493002 Cr-Commit-Position: refs/heads/master@{#478769} Committed: https://chromium.googlesource.com/chromium/src/+/927ddf0ccfa6947292f0551c83e427822ac18045

Patch Set 1 #

Total comments: 4
Unified diffs Side-by-side diffs Delta from patch set Stats (+11 lines, -8 lines) Patch
M content/renderer/media/gpu/rtc_video_encoder.h View 1 chunk +1 line, -0 lines 0 comments Download
M content/renderer/media/gpu/rtc_video_encoder.cc View 3 chunks +10 lines, -8 lines 4 comments Download

Messages

Total messages: 19 (12 generated)
magjed_chromium
emircan@ - please take a look.
3 years, 6 months ago (2017-06-12 19:42:38 UTC) #6
emircan
https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/gpu/rtc_video_encoder.cc File content/renderer/media/gpu/rtc_video_encoder.cc (right): https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/gpu/rtc_video_encoder.cc#newcode623 content/renderer/media/gpu/rtc_video_encoder.cc:623: : base::TimeDelta::FromMilliseconds(next_frame->ntp_time_ms()); We were hitting DCHECK before because next_frame->ntp_time_ms() ...
3 years, 6 months ago (2017-06-12 20:06:16 UTC) #8
magjed_chromium
https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/gpu/rtc_video_encoder.cc File content/renderer/media/gpu/rtc_video_encoder.cc (right): https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/gpu/rtc_video_encoder.cc#newcode623 content/renderer/media/gpu/rtc_video_encoder.cc:623: : base::TimeDelta::FromMilliseconds(next_frame->ntp_time_ms()); On 2017/06/12 20:06:16, emircan wrote: > We ...
3 years, 6 months ago (2017-06-12 20:28:14 UTC) #9
emircan
On 2017/06/12 20:28:14, magjed_chromium wrote: > https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/gpu/rtc_video_encoder.cc > File content/renderer/media/gpu/rtc_video_encoder.cc (right): > > https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/gpu/rtc_video_encoder.cc#newcode623 > ...
3 years, 6 months ago (2017-06-12 20:30:15 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.chromium.org/2939493002/20001
3 years, 6 months ago (2017-06-12 21:14:33 UTC) #14
commit-bot: I haz the power
Committed patchset #1 (id:20001) as https://chromium.googlesource.com/chromium/src/+/927ddf0ccfa6947292f0551c83e427822ac18045
3 years, 6 months ago (2017-06-12 21:19:38 UTC) #17
nisse-chromium (ooo August 14)
3 years, 6 months ago (2017-06-13 08:06:44 UTC) #19
Message was sent while issue was closed.
lgtm

https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/...
File content/renderer/media/gpu/rtc_video_encoder.cc (right):

https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/...
content/renderer/media/gpu/rtc_video_encoder.cc:623: :
base::TimeDelta::FromMilliseconds(next_frame->ntp_time_ms());
On 2017/06/12 20:06:16, emircan wrote:
> We were hitting DCHECK before because next_frame->ntp_time_ms() was 0. We
should
> still handle this case if webrtc makes a copy and drops the media::VideoFrame
> reference somehow, i.e. simulcast was doing that before.
> 
> I am not sure what to use here, maybe nisse@ can help. We need to input a
> strictly increasing presentation timestamp to HW encoders.
> next_frame->timestamp() is in 90 kHz; we can't use here and 90 kHz domain is
why
> we need to map back and forth. 

I don't quite understand the context here, but in general, the timestamp_us()
method should give you a valid and increasing timestamp.

https://codereview.chromium.org/2939493002/diff/20001/content/renderer/media/...
content/renderer/media/gpu/rtc_video_encoder.cc:640:
rtc::scoped_refptr<webrtc::I420BufferInterface> i420_buffer =
Do we intend to change ToI420 to a const method? If so, could use

rtc::scoped_refptr<const webrtc::I420BufferInterface> 

here, right away.

Powered by Google App Engine
This is Rietveld 408576698