Home | History | Annotate | Download | only in video_engine
      1 /*
      2  *  Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
      3  *
      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
      6  *  tree. An additional intellectual property rights grant can be found
      7  *  in the file PATENTS.  All contributing project authors may
      8  *  be found in the AUTHORS file in the root of the source tree.
      9  */
     10 
     11 #ifndef WEBRTC_VIDEO_ENGINE_VIE_CHANNEL_MANAGER_H_
     12 #define WEBRTC_VIDEO_ENGINE_VIE_CHANNEL_MANAGER_H_
     13 
     14 #include <list>
     15 #include <map>
     16 
     17 #include "webrtc/engine_configurations.h"
     18 #include "webrtc/system_wrappers/interface/scoped_ptr.h"
     19 #include "webrtc/typedefs.h"
     20 #include "webrtc/video_engine/include/vie_rtp_rtcp.h"
     21 #include "webrtc/video_engine/vie_channel_group.h"
     22 #include "webrtc/video_engine/vie_defines.h"
     23 #include "webrtc/video_engine/vie_manager_base.h"
     24 #include "webrtc/video_engine/vie_remb.h"
     25 
     26 namespace webrtc {
     27 
     28 class Config;
     29 class CriticalSectionWrapper;
     30 class ProcessThread;
     31 class RtcpRttStats;
     32 class ViEChannel;
     33 class ViEEncoder;
     34 class VoEVideoSync;
     35 class VoiceEngine;
     36 
     37 typedef std::list<ChannelGroup*> ChannelGroups;
     38 typedef std::list<ViEChannel*> ChannelList;
     39 typedef std::map<int, ViEChannel*> ChannelMap;
     40 typedef std::map<int, ViEEncoder*> EncoderMap;
     41 
     42 class ViEChannelManager: private ViEManagerBase {
     43   friend class ViEChannelManagerScoped;
     44  public:
     45   ViEChannelManager(int engine_id,
     46                     int number_of_cores,
     47                     const Config& config);
     48   ~ViEChannelManager();
     49 
     50   void SetModuleProcessThread(ProcessThread* module_process_thread);
     51 
     52   // Creates a new channel. 'channel_id' will be the id of the created channel.
     53   int CreateChannel(int* channel_id,
     54                     const Config* config);
     55 
     56   // Creates a new channel grouped with |original_channel|. The new channel
     57   // will get its own |ViEEncoder| if |sender| is set to true. It will be a
     58   // receive only channel, without an own |ViEEncoder| if |sender| is false.
     59   int CreateChannel(int* channel_id, int original_channel, bool sender);
     60 
     61   // Deletes a channel.
     62   int DeleteChannel(int channel_id);
     63 
     64   // Set the voice engine instance to be used by all video channels.
     65   int SetVoiceEngine(VoiceEngine* voice_engine);
     66 
     67   // Enables lip sync of the channel.
     68   int ConnectVoiceChannel(int channel_id, int audio_channel_id);
     69 
     70   // Disables lip sync of the channel.
     71   int DisconnectVoiceChannel(int channel_id);
     72 
     73   VoiceEngine* GetVoiceEngine();
     74 
     75   // Adds a channel to include when sending REMB.
     76   bool SetRembStatus(int channel_id, bool sender, bool receiver);
     77 
     78   bool SetReservedTransmitBitrate(int channel_id,
     79                                   uint32_t reserved_transmit_bitrate_bps);
     80 
     81   // Updates the SSRCs for a channel. If one of the SSRCs already is registered,
     82   // it will simply be ignored and no error is returned.
     83   void UpdateSsrcs(int channel_id, const std::list<unsigned int>& ssrcs);
     84 
     85   // Sets bandwidth estimation related configurations.
     86   bool SetBandwidthEstimationConfig(int channel_id,
     87                                     const webrtc::Config& config);
     88 
     89   bool GetEstimatedSendBandwidth(int channel_id,
     90                                  uint32_t* estimated_bandwidth) const;
     91   bool GetEstimatedReceiveBandwidth(int channel_id,
     92                                     uint32_t* estimated_bandwidth) const;
     93 
     94  private:
     95   // Creates a channel object connected to |vie_encoder|. Assumed to be called
     96   // protected.
     97   bool CreateChannelObject(int channel_id,
     98                            ViEEncoder* vie_encoder,
     99                            RtcpBandwidthObserver* bandwidth_observer,
    100                            RemoteBitrateEstimator* remote_bitrate_estimator,
    101                            RtcpRttStats* rtcp_rtt_stats,
    102                            RtcpIntraFrameObserver* intra_frame_observer,
    103                            bool sender);
    104 
    105   // Used by ViEChannelScoped, forcing a manager user to use scoped.
    106   // Returns a pointer to the channel with id 'channel_id'.
    107   ViEChannel* ViEChannelPtr(int channel_id) const;
    108 
    109   // Methods used by ViECaptureScoped and ViEEncoderScoped.
    110   // Gets the ViEEncoder used as input for video_channel_id
    111   ViEEncoder* ViEEncoderPtr(int video_channel_id) const;
    112 
    113   // Returns a free channel id, -1 if failing.
    114   int FreeChannelId();
    115 
    116   // Returns a previously allocated channel id.
    117   void ReturnChannelId(int channel_id);
    118 
    119   // Returns the iterator to the ChannelGroup containing |channel_id|.
    120   ChannelGroup* FindGroup(int channel_id) const;
    121 
    122   // Returns true if at least one other channels uses the same ViEEncoder as
    123   // channel_id.
    124   bool ChannelUsingViEEncoder(int channel_id) const;
    125   void ChannelsUsingViEEncoder(int channel_id, ChannelList* channels) const;
    126 
    127   // Protects channel_map_ and free_channel_ids_.
    128   CriticalSectionWrapper* channel_id_critsect_;
    129   int engine_id_;
    130   int number_of_cores_;
    131 
    132   // TODO(mflodman) Make part of channel group.
    133   ChannelMap channel_map_;
    134   bool* free_channel_ids_;
    135   int free_channel_ids_size_;
    136 
    137   // List with all channel groups.
    138   std::list<ChannelGroup*> channel_groups_;
    139 
    140   // TODO(mflodman) Make part of channel group.
    141   // Maps Channel id -> ViEEncoder.
    142   EncoderMap vie_encoder_map_;
    143   VoEVideoSync* voice_sync_interface_;
    144 
    145   VoiceEngine* voice_engine_;
    146   ProcessThread* module_process_thread_;
    147   const Config& engine_config_;
    148 };
    149 
    150 class ViEChannelManagerScoped: private ViEManagerScopedBase {
    151  public:
    152   explicit ViEChannelManagerScoped(
    153       const ViEChannelManager& vie_channel_manager);
    154   ViEChannel* Channel(int vie_channel_id) const;
    155   ViEEncoder* Encoder(int vie_channel_id) const;
    156 
    157   // Returns true if at least one other channels uses the same ViEEncoder as
    158   // channel_id.
    159   bool ChannelUsingViEEncoder(int channel_id) const;
    160 
    161   // Returns a list with pointers to all channels using the same encoder as the
    162   // channel with |channel_id|, including the one with the specified id.
    163   void ChannelsUsingViEEncoder(int channel_id, ChannelList* channels) const;
    164 };
    165 
    166 }  // namespace webrtc
    167 
    168 #endif  // WEBRTC_VIDEO_ENGINE_VIE_CHANNEL_MANAGER_H_
    169