OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 MEDIA_CAST_TRANSPORT_PACING_PACED_SENDER_H_ | 5 #ifndef MEDIA_CAST_TRANSPORT_PACING_PACED_SENDER_H_ |
6 #define MEDIA_CAST_TRANSPORT_PACING_PACED_SENDER_H_ | 6 #define MEDIA_CAST_TRANSPORT_PACING_PACED_SENDER_H_ |
7 | 7 |
8 #include <list> | 8 #include <list> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/memory/scoped_ptr.h" | 12 #include "base/memory/scoped_ptr.h" |
13 #include "base/memory/weak_ptr.h" | 13 #include "base/memory/weak_ptr.h" |
14 #include "base/single_thread_task_runner.h" | 14 #include "base/single_thread_task_runner.h" |
15 #include "base/threading/non_thread_safe.h" | 15 #include "base/threading/non_thread_safe.h" |
16 #include "base/time/default_tick_clock.h" | 16 #include "base/time/default_tick_clock.h" |
17 #include "base/time/tick_clock.h" | 17 #include "base/time/tick_clock.h" |
18 #include "base/time/time.h" | 18 #include "base/time/time.h" |
19 #include "media/cast/transport/cast_transport_config.h" | 19 #include "media/cast/transport/cast_transport_config.h" |
20 #include "media/cast/transport/transport/udp_transport.h" | 20 #include "media/cast/transport/transport/udp_transport.h" |
21 | 21 |
22 namespace media { | 22 namespace media { |
23 namespace cast { | 23 namespace cast { |
24 | 24 |
25 class LoggingImpl; | 25 class LoggingImpl; |
26 | 26 |
27 namespace transport { | 27 namespace transport { |
28 | 28 |
| 29 // Use std::pair for free comparison operators. |
| 30 // { capture_time, ssrc, packet_id } |
| 31 // The PacketKey is designed to meet two criteria: |
| 32 // 1. When we re-send the same packet again, we can use the packet key |
| 33 // to identify it so that we can de-duplicate packets in the queue. |
| 34 // 2. The sort order of the PacketKey determines the order that packets |
| 35 // are sent out. Using the capture_time as the first member basically |
| 36 // means that older packets are sent first. |
| 37 typedef std::pair<base::TimeTicks, std::pair<uint32, uint16> > PacketKey; |
| 38 typedef std::vector<std::pair<PacketKey, PacketRef> > SendPacketVector; |
| 39 |
29 // We have this pure virtual class to enable mocking. | 40 // We have this pure virtual class to enable mocking. |
30 class PacedPacketSender { | 41 class PacedPacketSender { |
31 public: | 42 public: |
32 // Inform the pacer / sender of the total number of packets. | 43 virtual bool SendPackets(const SendPacketVector& packets) = 0; |
33 virtual bool SendPackets(const PacketList& packets) = 0; | 44 virtual bool ResendPackets(const SendPacketVector& packets) = 0; |
34 virtual bool ResendPackets(const PacketList& packets) = 0; | 45 virtual bool SendRtcpPacket(uint32 ssrc, PacketRef packet) = 0; |
35 virtual bool SendRtcpPacket(PacketRef packet) = 0; | |
36 | 46 |
37 virtual ~PacedPacketSender() {} | 47 virtual ~PacedPacketSender() {} |
| 48 |
| 49 static PacketKey MakePacketKey(const base::TimeTicks& ticks, |
| 50 uint32 ssrc, |
| 51 uint16 packet_id); |
38 }; | 52 }; |
39 | 53 |
40 class PacedSender : public PacedPacketSender, | 54 class PacedSender : public PacedPacketSender, |
41 public base::NonThreadSafe, | 55 public base::NonThreadSafe, |
42 public base::SupportsWeakPtr<PacedSender> { | 56 public base::SupportsWeakPtr<PacedSender> { |
43 public: | 57 public: |
44 // The |external_transport| should only be used by the Cast receiver and for | 58 // The |external_transport| should only be used by the Cast receiver and for |
45 // testing. | 59 // testing. |
46 PacedSender( | 60 PacedSender( |
47 base::TickClock* clock, | 61 base::TickClock* clock, |
48 LoggingImpl* logging, | 62 LoggingImpl* logging, |
49 PacketSender* external_transport, | 63 PacketSender* external_transport, |
50 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner); | 64 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner); |
51 | 65 |
52 virtual ~PacedSender(); | 66 virtual ~PacedSender(); |
53 | 67 |
54 // These must be called before non-RTCP packets are sent. | 68 // These must be called before non-RTCP packets are sent. |
55 void RegisterAudioSsrc(uint32 audio_ssrc); | 69 void RegisterAudioSsrc(uint32 audio_ssrc); |
56 void RegisterVideoSsrc(uint32 video_ssrc); | 70 void RegisterVideoSsrc(uint32 video_ssrc); |
57 | 71 |
58 // PacedPacketSender implementation. | 72 // PacedPacketSender implementation. |
59 virtual bool SendPackets(const PacketList& packets) OVERRIDE; | 73 virtual bool SendPackets(const SendPacketVector& packets) OVERRIDE; |
60 virtual bool ResendPackets(const PacketList& packets) OVERRIDE; | 74 virtual bool ResendPackets(const SendPacketVector& packets) OVERRIDE; |
61 virtual bool SendRtcpPacket(PacketRef packet) OVERRIDE; | 75 virtual bool SendRtcpPacket(uint32 ssrc, PacketRef packet) OVERRIDE; |
62 | 76 |
63 private: | 77 private: |
64 // Actually sends the packets to the transport. | 78 // Actually sends the packets to the transport. |
65 void SendStoredPackets(); | 79 void SendStoredPackets(); |
66 void LogPacketEvent(const Packet& packet, bool retransmit); | 80 void LogPacketEvent(const Packet& packet, bool retransmit); |
67 | 81 |
68 enum PacketType { | 82 enum PacketType { |
69 PacketType_RTCP, | 83 PacketType_RTCP, |
70 PacketType_Resend, | 84 PacketType_Resend, |
71 PacketType_Normal | 85 PacketType_Normal |
(...skipping 21 matching lines...) Expand all Loading... |
93 // resend packets have second highest priority and then comes everything | 107 // resend packets have second highest priority and then comes everything |
94 // else. | 108 // else. |
95 PacketRef GetNextPacket(PacketType* packet_type); | 109 PacketRef GetNextPacket(PacketType* packet_type); |
96 | 110 |
97 base::TickClock* const clock_; // Not owned by this class. | 111 base::TickClock* const clock_; // Not owned by this class. |
98 LoggingImpl* const logging_; // Not owned by this class. | 112 LoggingImpl* const logging_; // Not owned by this class. |
99 PacketSender* transport_; // Not owned by this class. | 113 PacketSender* transport_; // Not owned by this class. |
100 scoped_refptr<base::SingleThreadTaskRunner> transport_task_runner_; | 114 scoped_refptr<base::SingleThreadTaskRunner> transport_task_runner_; |
101 uint32 audio_ssrc_; | 115 uint32 audio_ssrc_; |
102 uint32 video_ssrc_; | 116 uint32 video_ssrc_; |
103 // Note: We can't combine the |packet_list_| and the |resend_packet_list_| | 117 std::map<PacketKey, std::pair<PacketType, PacketRef> > packet_list_; |
104 // since then we might get reordering of the retransmitted packets. | |
105 std::deque<PacketRef> rtcp_packet_list_; | |
106 std::deque<PacketRef> resend_packet_list_; | |
107 std::deque<PacketRef> packet_list_; | |
108 | 118 |
109 // Maximum burst size for the next three bursts. | 119 // Maximum burst size for the next three bursts. |
110 size_t max_burst_size_; | 120 size_t max_burst_size_; |
111 size_t next_max_burst_size_; | 121 size_t next_max_burst_size_; |
112 size_t next_next_max_burst_size_; | 122 size_t next_next_max_burst_size_; |
113 // Number of packets already sent in the current burst. | 123 // Number of packets already sent in the current burst. |
114 size_t current_burst_size_; | 124 size_t current_burst_size_; |
115 // This is when the current burst ends. | 125 // This is when the current burst ends. |
116 base::TimeTicks burst_end_; | 126 base::TimeTicks burst_end_; |
117 | 127 |
118 State state_; | 128 State state_; |
119 | 129 |
120 // NOTE: Weak pointers must be invalidated before all other member variables. | 130 // NOTE: Weak pointers must be invalidated before all other member variables. |
121 base::WeakPtrFactory<PacedSender> weak_factory_; | 131 base::WeakPtrFactory<PacedSender> weak_factory_; |
122 | 132 |
123 DISALLOW_COPY_AND_ASSIGN(PacedSender); | 133 DISALLOW_COPY_AND_ASSIGN(PacedSender); |
124 }; | 134 }; |
125 | 135 |
126 } // namespace transport | 136 } // namespace transport |
127 } // namespace cast | 137 } // namespace cast |
128 } // namespace media | 138 } // namespace media |
129 | 139 |
130 #endif // MEDIA_CAST_TRANSPORT_PACING_PACED_SENDER_H_ | 140 #endif // MEDIA_CAST_TRANSPORT_PACING_PACED_SENDER_H_ |
OLD | NEW |