OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
43 | 43 |
44 int FullBweSender::GetFeedbackIntervalMs() const { | 44 int FullBweSender::GetFeedbackIntervalMs() const { |
45 return kFeedbackIntervalMs; | 45 return kFeedbackIntervalMs; |
46 } | 46 } |
47 | 47 |
48 void FullBweSender::GiveFeedback(const FeedbackPacket& feedback) { | 48 void FullBweSender::GiveFeedback(const FeedbackPacket& feedback) { |
49 const SendSideBweFeedback& fb = | 49 const SendSideBweFeedback& fb = |
50 static_cast<const SendSideBweFeedback&>(feedback); | 50 static_cast<const SendSideBweFeedback&>(feedback); |
51 if (fb.packet_feedback_vector().empty()) | 51 if (fb.packet_feedback_vector().empty()) |
52 return; | 52 return; |
53 // TODO(sprang): Unconstify PacketInfo so we don't need temp copy? | 53 // TODO(sprang): Unconstify PacketInfo so we don't need temp copy? |
stefan-webrtc
2015/09/03 11:30:33
Has this been done already? I don't see any consts
sprang_webrtc
2015/09/03 13:24:09
This comment doesn't make sense any more. Removing
| |
54 std::vector<PacketInfo> packet_feedback_vector(fb.packet_feedback_vector()); | 54 std::vector<PacketInfo> packet_feedback_vector(fb.packet_feedback_vector()); |
55 for (PacketInfo& packet : packet_feedback_vector) { | 55 for (PacketInfo& packet_info : packet_feedback_vector) { |
56 if (!send_time_history_.GetSendTime(packet.sequence_number, | 56 if (!send_time_history_.Populate(&packet_info, true)) { |
57 &packet.send_time_ms, true)) { | |
58 LOG(LS_WARNING) << "Ack arrived too late."; | 57 LOG(LS_WARNING) << "Ack arrived too late."; |
59 } | 58 } |
60 } | 59 } |
61 | 60 |
62 int64_t rtt_ms = | 61 int64_t rtt_ms = |
63 clock_->TimeInMilliseconds() - feedback.latest_send_time_ms(); | 62 clock_->TimeInMilliseconds() - feedback.latest_send_time_ms(); |
64 rbe_->OnRttUpdate(rtt_ms, rtt_ms); | 63 rbe_->OnRttUpdate(rtt_ms, rtt_ms); |
65 BWE_TEST_LOGGING_PLOT(1, "RTT", clock_->TimeInMilliseconds(), rtt_ms); | 64 BWE_TEST_LOGGING_PLOT(1, "RTT", clock_->TimeInMilliseconds(), rtt_ms); |
66 | 65 |
67 rbe_->IncomingPacketFeedbackVector(packet_feedback_vector); | 66 rbe_->IncomingPacketFeedbackVector(packet_feedback_vector); |
(...skipping 20 matching lines...) Expand all Loading... | |
88 } else { | 87 } else { |
89 last_acked_seq_num_ = packet_feedback_vector.back().sequence_number; | 88 last_acked_seq_num_ = packet_feedback_vector.back().sequence_number; |
90 has_received_ack_ = true; | 89 has_received_ack_ = true; |
91 } | 90 } |
92 } | 91 } |
93 | 92 |
94 void FullBweSender::OnPacketsSent(const Packets& packets) { | 93 void FullBweSender::OnPacketsSent(const Packets& packets) { |
95 for (Packet* packet : packets) { | 94 for (Packet* packet : packets) { |
96 if (packet->GetPacketType() == Packet::kMedia) { | 95 if (packet->GetPacketType() == Packet::kMedia) { |
97 MediaPacket* media_packet = static_cast<MediaPacket*>(packet); | 96 MediaPacket* media_packet = static_cast<MediaPacket*>(packet); |
98 send_time_history_.AddAndRemoveOldSendTimes( | 97 PacketInfo info(0, media_packet->sender_timestamp_ms(), |
99 media_packet->header().sequenceNumber, | 98 media_packet->header().sequenceNumber, |
100 media_packet->GetAbsSendTimeInMs()); | 99 media_packet->payload_size(), packet->was_paced()); |
100 send_time_history_.AddAndRemoveOld(info); | |
101 } | 101 } |
102 } | 102 } |
103 } | 103 } |
104 | 104 |
105 void FullBweSender::OnReceiveBitrateChanged( | 105 void FullBweSender::OnReceiveBitrateChanged( |
106 const std::vector<unsigned int>& ssrcs, | 106 const std::vector<unsigned int>& ssrcs, |
107 unsigned int bitrate) { | 107 unsigned int bitrate) { |
108 feedback_observer_->OnReceivedEstimatedBitrate(bitrate); | 108 feedback_observer_->OnReceivedEstimatedBitrate(bitrate); |
109 } | 109 } |
110 | 110 |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
143 packet_feedback_vector_.back().arrival_time_ms; | 143 packet_feedback_vector_.back().arrival_time_ms; |
144 FeedbackPacket* fb = new SendSideBweFeedback( | 144 FeedbackPacket* fb = new SendSideBweFeedback( |
145 flow_id_, now_ms * 1000, corrected_send_time_ms, packet_feedback_vector_); | 145 flow_id_, now_ms * 1000, corrected_send_time_ms, packet_feedback_vector_); |
146 packet_feedback_vector_.clear(); | 146 packet_feedback_vector_.clear(); |
147 return fb; | 147 return fb; |
148 } | 148 } |
149 | 149 |
150 } // namespace bwe | 150 } // namespace bwe |
151 } // namespace testing | 151 } // namespace testing |
152 } // namespace webrtc | 152 } // namespace webrtc |
OLD | NEW |