Remove DTMF detection. Talk team has been in the loop and there is no need for
DTMF detection at the receiver side. test=voe_auto_test, VoE extended test DTMF Review URL: https://webrtc-codereview.appspot.com/1168004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@3663 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
		| @@ -342,13 +342,6 @@ typedef struct        // All levels are reported in dB | |||||||
|     StatVal a_nlp; |     StatVal a_nlp; | ||||||
| } EchoStatistics; | } EchoStatistics; | ||||||
|  |  | ||||||
| enum TelephoneEventDetectionMethods |  | ||||||
| { |  | ||||||
|     kInBand = 0, |  | ||||||
|     kOutOfBand = 1, |  | ||||||
|     kInAndOutOfBand = 2 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| enum NsModes    // type of Noise Suppression | enum NsModes    // type of Noise Suppression | ||||||
| { | { | ||||||
|     kNsUnchanged = 0,   // previously set mode |     kNsUnchanged = 0,   // previously set mode | ||||||
|   | |||||||
| @@ -13,8 +13,8 @@ | |||||||
|  |  | ||||||
| #include <vector> | #include <vector> | ||||||
|  |  | ||||||
| #include "modules/interface/module.h" | #include "webrtc/modules/interface/module.h" | ||||||
| #include "modules/rtp_rtcp/interface/rtp_rtcp_defines.h" | #include "webrtc/modules/rtp_rtcp/interface/rtp_rtcp_defines.h" | ||||||
|  |  | ||||||
| namespace webrtc { | namespace webrtc { | ||||||
| // Forward declarations. | // Forward declarations. | ||||||
| @@ -796,19 +796,11 @@ class RtpRtcp : public Module { | |||||||
|         const WebRtc_UWord16 packetSizeSamples) = 0; |         const WebRtc_UWord16 packetSizeSamples) = 0; | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|     *   Outband TelephoneEvent(DTMF) detection |     *   Forward DTMF to decoder for playout. | ||||||
|     * |     * | ||||||
|     *   return -1 on failure else 0 |     *   return -1 on failure else 0 | ||||||
|     */ |     */ | ||||||
|     virtual WebRtc_Word32 SetTelephoneEventStatus( |     virtual int SetTelephoneEventForwardToDecoder(bool forwardToDecoder) = 0; | ||||||
|         const bool enable, |  | ||||||
|         const bool forwardToDecoder, |  | ||||||
|         const bool detectEndOfTone = false) = 0; |  | ||||||
|  |  | ||||||
|     /* |  | ||||||
|     *   Is outband TelephoneEvent(DTMF) turned on/off? |  | ||||||
|     */ |  | ||||||
|     virtual bool TelephoneEvent() const = 0; |  | ||||||
|  |  | ||||||
|     /* |     /* | ||||||
|     *   Returns true if received DTMF events are forwarded to the decoder using |     *   Returns true if received DTMF events are forwarded to the decoder using | ||||||
|   | |||||||
| @@ -207,9 +207,6 @@ protected: | |||||||
|  |  | ||||||
| class RtpAudioFeedback { | class RtpAudioFeedback { | ||||||
|  public: |  public: | ||||||
|   virtual void OnReceivedTelephoneEvent(const WebRtc_Word32 id, |  | ||||||
|                                         const WebRtc_UWord8 event, |  | ||||||
|                                         const bool endOfEvent) = 0; |  | ||||||
|  |  | ||||||
|   virtual void OnPlayTelephoneEvent(const WebRtc_Word32 id, |   virtual void OnPlayTelephoneEvent(const WebRtc_Word32 id, | ||||||
|                                     const WebRtc_UWord8 event, |                                     const WebRtc_UWord8 event, | ||||||
| @@ -304,10 +301,6 @@ class NullRtpAudioFeedback : public RtpAudioFeedback { | |||||||
|  public: |  public: | ||||||
|   virtual ~NullRtpAudioFeedback() {} |   virtual ~NullRtpAudioFeedback() {} | ||||||
|  |  | ||||||
|   virtual void OnReceivedTelephoneEvent(const WebRtc_Word32 id, |  | ||||||
|                                         const WebRtc_UWord8 event, |  | ||||||
|                                         const bool endOfEvent) {} |  | ||||||
|  |  | ||||||
|   virtual void OnPlayTelephoneEvent(const WebRtc_Word32 id, |   virtual void OnPlayTelephoneEvent(const WebRtc_Word32 id, | ||||||
|                                     const WebRtc_UWord8 event, |                                     const WebRtc_UWord8 event, | ||||||
|                                     const WebRtc_UWord16 lengthMs, |                                     const WebRtc_UWord16 lengthMs, | ||||||
|   | |||||||
| @@ -247,10 +247,7 @@ class MockRtpRtcp : public RtpRtcp { | |||||||
|       WebRtc_Word32(RtpAudioFeedback* messagesCallback)); |       WebRtc_Word32(RtpAudioFeedback* messagesCallback)); | ||||||
|   MOCK_METHOD1(SetAudioPacketSize, |   MOCK_METHOD1(SetAudioPacketSize, | ||||||
|       WebRtc_Word32(const WebRtc_UWord16 packetSizeSamples)); |       WebRtc_Word32(const WebRtc_UWord16 packetSizeSamples)); | ||||||
|   MOCK_METHOD3(SetTelephoneEventStatus, |   MOCK_METHOD1(SetTelephoneEventForwardToDecoder, int(bool forwardToDecoder)); | ||||||
|       WebRtc_Word32(const bool enable, const bool forwardToDecoder, const bool detectEndOfTone)); |  | ||||||
|   MOCK_CONST_METHOD0(TelephoneEvent, |  | ||||||
|       bool()); |  | ||||||
|   MOCK_CONST_METHOD0(TelephoneEventForwardToDecoder, |   MOCK_CONST_METHOD0(TelephoneEventForwardToDecoder, | ||||||
|       bool()); |       bool()); | ||||||
|   MOCK_CONST_METHOD1(SendTelephoneEventActive, |   MOCK_CONST_METHOD1(SendTelephoneEventActive, | ||||||
|   | |||||||
| @@ -27,9 +27,7 @@ RTPReceiverAudio::RTPReceiverAudio(const WebRtc_Word32 id, | |||||||
|       critical_section_rtp_receiver_audio_( |       critical_section_rtp_receiver_audio_( | ||||||
|           CriticalSectionWrapper::CreateCriticalSection()), |           CriticalSectionWrapper::CreateCriticalSection()), | ||||||
|       last_received_frequency_(8000), |       last_received_frequency_(8000), | ||||||
|       telephone_event_(false), |  | ||||||
|       telephone_event_forward_to_decoder_(false), |       telephone_event_forward_to_decoder_(false), | ||||||
|       telephone_event_detect_end_of_tone_(false), |  | ||||||
|       telephone_event_payload_type_(-1), |       telephone_event_payload_type_(-1), | ||||||
|       cng_nb_payload_type_(-1), |       cng_nb_payload_type_(-1), | ||||||
|       cng_wb_payload_type_(-1), |       cng_wb_payload_type_(-1), | ||||||
| @@ -51,23 +49,13 @@ WebRtc_UWord32 RTPReceiverAudio::AudioFrequency() const { | |||||||
| } | } | ||||||
|  |  | ||||||
| // Outband TelephoneEvent(DTMF) detection | // Outband TelephoneEvent(DTMF) detection | ||||||
| WebRtc_Word32 RTPReceiverAudio::SetTelephoneEventStatus( | int RTPReceiverAudio::SetTelephoneEventForwardToDecoder( | ||||||
|     const bool enable, |     bool forward_to_decoder) { | ||||||
|     const bool forward_to_decoder, |  | ||||||
|     const bool detect_end_of_tone) { |  | ||||||
|   CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); |   CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); | ||||||
|   telephone_event_ = enable; |  | ||||||
|   telephone_event_detect_end_of_tone_ = detect_end_of_tone; |  | ||||||
|   telephone_event_forward_to_decoder_ = forward_to_decoder; |   telephone_event_forward_to_decoder_ = forward_to_decoder; | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| // Is outband TelephoneEvent(DTMF) turned on/off? |  | ||||||
| bool RTPReceiverAudio::TelephoneEvent() const { |  | ||||||
|   CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); |  | ||||||
|   return telephone_event_; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Is forwarding of outband telephone events turned on/off? | // Is forwarding of outband telephone events turned on/off? | ||||||
| bool RTPReceiverAudio::TelephoneEventForwardToDecoder() const { | bool RTPReceiverAudio::TelephoneEventForwardToDecoder() const { | ||||||
|   CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); |   CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); | ||||||
| @@ -194,34 +182,6 @@ WebRtc_Word32 RTPReceiverAudio::OnNewPayloadTypeCreated( | |||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| void RTPReceiverAudio::SendTelephoneEvents( |  | ||||||
|     WebRtc_UWord8 number_of_new_events, |  | ||||||
|     WebRtc_UWord8 new_events[MAX_NUMBER_OF_PARALLEL_TELEPHONE_EVENTS], |  | ||||||
|     WebRtc_UWord8 number_of_removed_events, |  | ||||||
|     WebRtc_UWord8 removed_events[MAX_NUMBER_OF_PARALLEL_TELEPHONE_EVENTS]) { |  | ||||||
|  |  | ||||||
|   // Copy these variables since we can't hold the critsect when we call the |  | ||||||
|   // callback. cb_audio_feedback_ and id_ are immutable though. |  | ||||||
|   bool telephone_event; |  | ||||||
|   bool telephone_event_detect_end_of_tone; |  | ||||||
|   { |  | ||||||
|     CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); |  | ||||||
|     telephone_event = telephone_event_; |  | ||||||
|     telephone_event_detect_end_of_tone = telephone_event_detect_end_of_tone_; |  | ||||||
|   } |  | ||||||
|   if (telephone_event) { |  | ||||||
|     for (int n = 0; n < number_of_new_events; ++n) { |  | ||||||
|       cb_audio_feedback_->OnReceivedTelephoneEvent(id_, new_events[n], false); |  | ||||||
|     } |  | ||||||
|     if (telephone_event_detect_end_of_tone) { |  | ||||||
|       for (int n = 0; n < number_of_removed_events; ++n) { |  | ||||||
|         cb_audio_feedback_->OnReceivedTelephoneEvent( |  | ||||||
|             id_, removed_events[n], true); |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| WebRtc_Word32 RTPReceiverAudio::ParseRtpPacket( | WebRtc_Word32 RTPReceiverAudio::ParseRtpPacket( | ||||||
|     WebRtcRTPHeader* rtp_header, |     WebRtcRTPHeader* rtp_header, | ||||||
|     const ModuleRTPUtility::PayloadUnion& specific_payload, |     const ModuleRTPUtility::PayloadUnion& specific_payload, | ||||||
| @@ -316,10 +276,6 @@ WebRtc_Word32 RTPReceiverAudio::ParseAudioCodecSpecific( | |||||||
|     const WebRtc_UWord16 payload_length, |     const WebRtc_UWord16 payload_length, | ||||||
|     const ModuleRTPUtility::AudioPayload& audio_specific, |     const ModuleRTPUtility::AudioPayload& audio_specific, | ||||||
|     const bool is_red) { |     const bool is_red) { | ||||||
|   WebRtc_UWord8 new_events[MAX_NUMBER_OF_PARALLEL_TELEPHONE_EVENTS] = {}; |  | ||||||
|   WebRtc_UWord8 removed_events[MAX_NUMBER_OF_PARALLEL_TELEPHONE_EVENTS] = {}; |  | ||||||
|   WebRtc_UWord8 number_of_new_events = 0; |  | ||||||
|   WebRtc_UWord8 number_of_removed_events = 0; |  | ||||||
|  |  | ||||||
|   if (payload_length == 0) { |   if (payload_length == 0) { | ||||||
|     return 0; |     return 0; | ||||||
| @@ -355,16 +311,12 @@ WebRtc_Word32 RTPReceiverAudio::ParseAudioCodecSpecific( | |||||||
|       if (event != telephone_event_reported_.end()) { |       if (event != telephone_event_reported_.end()) { | ||||||
|         // we have already seen this event |         // we have already seen this event | ||||||
|         if (end) { |         if (end) { | ||||||
|           removed_events[number_of_removed_events] = payload_data[4 * n]; |  | ||||||
|           number_of_removed_events++; |  | ||||||
|           telephone_event_reported_.erase(payload_data[4 * n]); |           telephone_event_reported_.erase(payload_data[4 * n]); | ||||||
|         } |         } | ||||||
|       } else { |       } else { | ||||||
|         if (end) { |         if (end) { | ||||||
|           // don't add if it's a end of a tone |           // don't add if it's a end of a tone | ||||||
|         } else { |         } else { | ||||||
|           new_events[number_of_new_events] = payload_data[4 * n]; |  | ||||||
|           number_of_new_events++; |  | ||||||
|           telephone_event_reported_.insert(payload_data[4 * n]); |           telephone_event_reported_.insert(payload_data[4 * n]); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| @@ -376,12 +328,6 @@ WebRtc_Word32 RTPReceiverAudio::ParseAudioCodecSpecific( | |||||||
|     // RFC 4733 See 2.5.1.5. & 2.5.2.4.  Multiple Events in a Packet |     // RFC 4733 See 2.5.1.5. & 2.5.2.4.  Multiple Events in a Packet | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // This needs to be called without locks held. |  | ||||||
|   SendTelephoneEvents(number_of_new_events, |  | ||||||
|                       new_events, |  | ||||||
|                       number_of_removed_events, |  | ||||||
|                       removed_events); |  | ||||||
|  |  | ||||||
|   { |   { | ||||||
|     CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); |     CriticalSectionScoped lock(critical_section_rtp_receiver_audio_.get()); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -33,13 +33,8 @@ class RTPReceiverAudio : public RTPReceiverStrategy { | |||||||
|  |  | ||||||
|   WebRtc_UWord32 AudioFrequency() const; |   WebRtc_UWord32 AudioFrequency() const; | ||||||
|  |  | ||||||
|   // Outband TelephoneEvent (DTMF) detection |   // Forward DTMFs to decoder for playout. | ||||||
|   WebRtc_Word32 SetTelephoneEventStatus(const bool enable, |   int SetTelephoneEventForwardToDecoder(bool forward_to_decoder); | ||||||
|                                         const bool forward_to_decoder, |  | ||||||
|                                         const bool detect_end_of_tone); |  | ||||||
|  |  | ||||||
|   // Is outband DTMF(AVT) turned on/off? |  | ||||||
|   bool TelephoneEvent() const; |  | ||||||
|  |  | ||||||
|   // Is forwarding of outband telephone events turned on/off? |   // Is forwarding of outband telephone events turned on/off? | ||||||
|   bool TelephoneEventForwardToDecoder() const; |   bool TelephoneEventForwardToDecoder() const; | ||||||
| @@ -98,11 +93,6 @@ class RTPReceiverAudio : public RTPReceiverStrategy { | |||||||
|                            bool* should_discard_changes); |                            bool* should_discard_changes); | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   void SendTelephoneEvents( |  | ||||||
|       WebRtc_UWord8 number_of_new_events, |  | ||||||
|       WebRtc_UWord8 new_events[MAX_NUMBER_OF_PARALLEL_TELEPHONE_EVENTS], |  | ||||||
|       WebRtc_UWord8 number_of_removed_events, |  | ||||||
|       WebRtc_UWord8 removed_events[MAX_NUMBER_OF_PARALLEL_TELEPHONE_EVENTS]); |  | ||||||
|  |  | ||||||
|   WebRtc_Word32 ParseAudioCodecSpecific( |   WebRtc_Word32 ParseAudioCodecSpecific( | ||||||
|       WebRtcRTPHeader* rtp_header, |       WebRtcRTPHeader* rtp_header, | ||||||
| @@ -116,9 +106,7 @@ class RTPReceiverAudio : public RTPReceiverStrategy { | |||||||
|  |  | ||||||
|   WebRtc_UWord32 last_received_frequency_; |   WebRtc_UWord32 last_received_frequency_; | ||||||
|  |  | ||||||
|   bool telephone_event_; |  | ||||||
|   bool telephone_event_forward_to_decoder_; |   bool telephone_event_forward_to_decoder_; | ||||||
|   bool telephone_event_detect_end_of_tone_; |  | ||||||
|   WebRtc_Word8 telephone_event_payload_type_; |   WebRtc_Word8 telephone_event_payload_type_; | ||||||
|   std::set<WebRtc_UWord8> telephone_event_reported_; |   std::set<WebRtc_UWord8> telephone_event_reported_; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1582,29 +1582,17 @@ WebRtc_Word32 ModuleRtpRtcpImpl::SetStorePacketsStatus( | |||||||
|   return 0;  // TODO(pwestin): change to void. |   return 0;  // TODO(pwestin): change to void. | ||||||
| } | } | ||||||
|  |  | ||||||
| // Out-band TelephoneEvent detection. | // Forward DTMFs to decoder for playout. | ||||||
| WebRtc_Word32 ModuleRtpRtcpImpl::SetTelephoneEventStatus( | int ModuleRtpRtcpImpl::SetTelephoneEventForwardToDecoder( | ||||||
|     const bool enable, |     bool forward_to_decoder) { | ||||||
|     const bool forward_to_decoder, |  | ||||||
|     const bool detect_end_of_tone) { |  | ||||||
|   WEBRTC_TRACE(kTraceModuleCall, kTraceRtpRtcp, id_, |   WEBRTC_TRACE(kTraceModuleCall, kTraceRtpRtcp, id_, | ||||||
|                "SetTelephoneEventStatus(enable:%d forward_to_decoder:%d" |                "SetTelephoneEventForwardToDecoder(forward_to_decoder:%d)", | ||||||
|                " detect_end_of_tone:%d)", enable, forward_to_decoder, |                forward_to_decoder); | ||||||
|                detect_end_of_tone); |  | ||||||
|  |  | ||||||
|   assert(audio_); |   assert(audio_); | ||||||
|   assert(rtp_telephone_event_handler_); |   assert(rtp_telephone_event_handler_); | ||||||
|   return rtp_telephone_event_handler_->SetTelephoneEventStatus( |   return rtp_telephone_event_handler_->SetTelephoneEventForwardToDecoder( | ||||||
|            enable, forward_to_decoder, detect_end_of_tone); |       forward_to_decoder); | ||||||
| } |  | ||||||
|  |  | ||||||
| // Is out-band TelephoneEvent turned on/off? |  | ||||||
| bool ModuleRtpRtcpImpl::TelephoneEvent() const { |  | ||||||
|   WEBRTC_TRACE(kTraceModuleCall, kTraceRtpRtcp, id_, "TelephoneEvent()"); |  | ||||||
|  |  | ||||||
|   assert(audio_); |  | ||||||
|   assert(rtp_telephone_event_handler_); |  | ||||||
|   return rtp_telephone_event_handler_->TelephoneEvent(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Is forwarding of out-band telephone events turned on/off? | // Is forwarding of out-band telephone events turned on/off? | ||||||
|   | |||||||
| @@ -345,14 +345,8 @@ class ModuleRtpRtcpImpl : public RtpRtcp { | |||||||
|   virtual WebRtc_Word32 SetAudioPacketSize( |   virtual WebRtc_Word32 SetAudioPacketSize( | ||||||
|       const WebRtc_UWord16 packet_size_samples); |       const WebRtc_UWord16 packet_size_samples); | ||||||
|  |  | ||||||
|   // Outband DTMF detection. |   // Forward DTMFs to decoder for playout. | ||||||
|   virtual WebRtc_Word32 SetTelephoneEventStatus( |   virtual int SetTelephoneEventForwardToDecoder(bool forward_to_decoder); | ||||||
|       const bool enable, |  | ||||||
|       const bool forward_to_decoder, |  | ||||||
|       const bool detect_end_of_tone = false); |  | ||||||
|  |  | ||||||
|   // Is outband DTMF turned on/off? |  | ||||||
|   virtual bool TelephoneEvent() const; |  | ||||||
|  |  | ||||||
|   // Is forwarding of outband telephone events turned on/off? |   // Is forwarding of outband telephone events turned on/off? | ||||||
|   virtual bool TelephoneEventForwardToDecoder() const; |   virtual bool TelephoneEventForwardToDecoder() const; | ||||||
|   | |||||||
| @@ -190,11 +190,8 @@ TEST_F(RtpRtcpAudioTest, Basic) { | |||||||
|   EXPECT_EQ(0, module1->SetSSRC(test_ssrc)); |   EXPECT_EQ(0, module1->SetSSRC(test_ssrc)); | ||||||
|   EXPECT_EQ(0, module1->SetStartTimestamp(test_timestamp)); |   EXPECT_EQ(0, module1->SetStartTimestamp(test_timestamp)); | ||||||
|  |  | ||||||
|   EXPECT_FALSE(module1->TelephoneEvent()); |  | ||||||
|  |  | ||||||
|   // Test detection at the end of a DTMF tone. |   // Test detection at the end of a DTMF tone. | ||||||
|   EXPECT_EQ(0, module2->SetTelephoneEventStatus(true, true, true)); |   EXPECT_EQ(0, module2->SetTelephoneEventForwardToDecoder(true)); | ||||||
|   EXPECT_EQ(true, module2->TelephoneEvent()); |  | ||||||
|  |  | ||||||
|   EXPECT_EQ(0, module1->SetSendingStatus(true)); |   EXPECT_EQ(0, module1->SetSendingStatus(true)); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -93,28 +93,6 @@ Channel::InFrameType(WebRtc_Word16 frameType) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
| int |  | ||||||
| Channel::IncomingDtmf(const WebRtc_UWord8 digitDtmf, const bool end) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceInfo, kTraceVoice, VoEId(_instanceId,_channelId), |  | ||||||
|                "Channel::IncomingDtmf(digitDtmf=%u, end=%d)", |  | ||||||
|                digitDtmf, end); |  | ||||||
|  |  | ||||||
|     if (digitDtmf != 999) |  | ||||||
|     { |  | ||||||
|         CriticalSectionScoped cs(&_callbackCritSect); |  | ||||||
|         if (_telephoneEventDetectionPtr) |  | ||||||
|         { |  | ||||||
|             _telephoneEventDetectionPtr->OnReceivedTelephoneEventInband( |  | ||||||
|                 _channelId, digitDtmf, end); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| WebRtc_Word32 | WebRtc_Word32 | ||||||
| Channel::OnRxVadDetected(const int vadDecision) | Channel::OnRxVadDetected(const int vadDecision) | ||||||
| { | { | ||||||
| @@ -510,29 +488,6 @@ Channel::IncomingRTCPPacket(const WebRtc_Word8* incomingRtcpPacket, | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| void |  | ||||||
| Channel::OnReceivedTelephoneEvent(const WebRtc_Word32 id, |  | ||||||
|                                   const WebRtc_UWord8 event, |  | ||||||
|                                   const bool endOfEvent) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceStream, kTraceVoice, VoEId(_instanceId,_channelId), |  | ||||||
|                  "Channel::OnReceivedTelephoneEvent(id=%d, event=%u," |  | ||||||
|                  " endOfEvent=%d)", id, event, endOfEvent); |  | ||||||
|  |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     if (_outOfBandTelephoneEventDetecion) |  | ||||||
|     { |  | ||||||
|         CriticalSectionScoped cs(&_callbackCritSect); |  | ||||||
|  |  | ||||||
|         if (_telephoneEventDetectionPtr) |  | ||||||
|         { |  | ||||||
|             _telephoneEventDetectionPtr->OnReceivedTelephoneEventOutOfBand( |  | ||||||
|                 _channelId, event, endOfEvent); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void | void | ||||||
| Channel::OnPlayTelephoneEvent(const WebRtc_Word32 id, | Channel::OnPlayTelephoneEvent(const WebRtc_Word32 id, | ||||||
|                               const WebRtc_UWord8 event, |                               const WebRtc_UWord8 event, | ||||||
| @@ -1123,9 +1078,6 @@ Channel::Channel(const WebRtc_Word32 channelId, | |||||||
|     _encryptionPtr(NULL), |     _encryptionPtr(NULL), | ||||||
|     _rtpAudioProc(NULL), |     _rtpAudioProc(NULL), | ||||||
|     _rxAudioProcessingModulePtr(NULL), |     _rxAudioProcessingModulePtr(NULL), | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     _telephoneEventDetectionPtr(NULL), |  | ||||||
| #endif |  | ||||||
|     _rxVadObserverPtr(NULL), |     _rxVadObserverPtr(NULL), | ||||||
|     _oldVadDecision(-1), |     _oldVadDecision(-1), | ||||||
|     _sendFrameType(0), |     _sendFrameType(0), | ||||||
| @@ -1149,8 +1101,6 @@ Channel::Channel(const WebRtc_Word32 channelId, | |||||||
|     _decrypting(false), |     _decrypting(false), | ||||||
|     _playOutbandDtmfEvent(false), |     _playOutbandDtmfEvent(false), | ||||||
|     _playInbandDtmfEvent(false), |     _playInbandDtmfEvent(false), | ||||||
|     _inbandTelephoneEventDetection(false), |  | ||||||
|     _outOfBandTelephoneEventDetecion(false), |  | ||||||
|     _extraPayloadType(0), |     _extraPayloadType(0), | ||||||
|     _insertExtraRTPPacket(false), |     _insertExtraRTPPacket(false), | ||||||
|     _extraMarkerBit(false), |     _extraMarkerBit(false), | ||||||
| @@ -1268,15 +1218,6 @@ Channel::~Channel() | |||||||
|                      "~Channel() failed to de-register VAD callback" |                      "~Channel() failed to de-register VAD callback" | ||||||
|                      " (Audio coding module)"); |                      " (Audio coding module)"); | ||||||
|     } |     } | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     if (_audioCodingModule.RegisterIncomingMessagesCallback(NULL) == -1) |  | ||||||
|     { |  | ||||||
|         WEBRTC_TRACE(kTraceWarning, kTraceVoice, |  | ||||||
|                      VoEId(_instanceId,_channelId), |  | ||||||
|                      "~Channel() failed to de-register incoming messages " |  | ||||||
|                      "callback (Audio coding module)"); |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
|     // De-register modules in process thread |     // De-register modules in process thread | ||||||
| #ifndef WEBRTC_EXTERNAL_TRANSPORT | #ifndef WEBRTC_EXTERNAL_TRANSPORT | ||||||
|     if (_moduleProcessThreadPtr->DeRegisterModule(&_socketTransportModule) |     if (_moduleProcessThreadPtr->DeRegisterModule(&_socketTransportModule) | ||||||
| @@ -1380,7 +1321,7 @@ Channel::Init() | |||||||
|     // be transmitted since the Transport object will then be invalid. |     // be transmitted since the Transport object will then be invalid. | ||||||
|  |  | ||||||
|     const bool rtpRtcpFail = |     const bool rtpRtcpFail = | ||||||
|         ((_rtpRtcpModule->SetTelephoneEventStatus(false, true, true) == -1) || |         ((_rtpRtcpModule->SetTelephoneEventForwardToDecoder(true) == -1) || | ||||||
|         // RTCP is enabled by default |         // RTCP is enabled by default | ||||||
|         (_rtpRtcpModule->SetRTCPStatus(kRtcpCompound) == -1)); |         (_rtpRtcpModule->SetRTCPStatus(kRtcpCompound) == -1)); | ||||||
|     if (rtpRtcpFail) |     if (rtpRtcpFail) | ||||||
| @@ -1768,10 +1709,8 @@ Channel::StopReceiving() | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
|     bool dtmfDetection = _rtpRtcpModule->TelephoneEvent(); |  | ||||||
|     // Recover DTMF detection status. |     // Recover DTMF detection status. | ||||||
|     WebRtc_Word32 ret = _rtpRtcpModule->SetTelephoneEventStatus(dtmfDetection, |     WebRtc_Word32 ret = _rtpRtcpModule->SetTelephoneEventForwardToDecoder(true); | ||||||
|                                                                true, true); |  | ||||||
|     if (ret != 0) { |     if (ret != 0) { | ||||||
|         _engineStatisticsPtr->SetLastError( |         _engineStatisticsPtr->SetLastError( | ||||||
|             VE_INVALID_OPERATION, kTraceWarning, |             VE_INVALID_OPERATION, kTraceWarning, | ||||||
| @@ -4455,144 +4394,6 @@ Channel::GetSendTelephoneEventPayloadType(unsigned char& type) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|  |  | ||||||
| WebRtc_Word32 |  | ||||||
| Channel::RegisterTelephoneEventDetection( |  | ||||||
|     TelephoneEventDetectionMethods detectionMethod, |  | ||||||
|     VoETelephoneEventObserver& observer) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceInfo, kTraceVoice, VoEId(_instanceId,_channelId), |  | ||||||
|                  "Channel::RegisterTelephoneEventDetection()"); |  | ||||||
|     CriticalSectionScoped cs(&_callbackCritSect); |  | ||||||
|  |  | ||||||
|     if (_telephoneEventDetectionPtr) |  | ||||||
|     { |  | ||||||
|         _engineStatisticsPtr->SetLastError( |  | ||||||
|             VE_INVALID_OPERATION, kTraceError, |  | ||||||
|             "RegisterTelephoneEventDetection() detection already enabled"); |  | ||||||
|         return -1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     _telephoneEventDetectionPtr = &observer; |  | ||||||
|  |  | ||||||
|     switch (detectionMethod) |  | ||||||
|     { |  | ||||||
|         case kInBand: |  | ||||||
|             _inbandTelephoneEventDetection = true; |  | ||||||
|             _outOfBandTelephoneEventDetecion = false; |  | ||||||
|             break; |  | ||||||
|         case kOutOfBand: |  | ||||||
|             _inbandTelephoneEventDetection = false; |  | ||||||
|             _outOfBandTelephoneEventDetecion = true; |  | ||||||
|             break; |  | ||||||
|         case kInAndOutOfBand: |  | ||||||
|             _inbandTelephoneEventDetection = true; |  | ||||||
|             _outOfBandTelephoneEventDetecion = true; |  | ||||||
|             break; |  | ||||||
|         default: |  | ||||||
|             _engineStatisticsPtr->SetLastError( |  | ||||||
|                 VE_INVALID_ARGUMENT, kTraceError, |  | ||||||
|                 "RegisterTelephoneEventDetection() invalid detection method"); |  | ||||||
|             return -1; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (_inbandTelephoneEventDetection) |  | ||||||
|     { |  | ||||||
|         // Enable in-band Dtmf detectin in the ACM. |  | ||||||
|         if (_audioCodingModule.RegisterIncomingMessagesCallback(this) != 0) |  | ||||||
|         { |  | ||||||
|             _engineStatisticsPtr->SetLastError( |  | ||||||
|                 VE_AUDIO_CODING_MODULE_ERROR, kTraceError, |  | ||||||
|                 "RegisterTelephoneEventDetection() failed to enable Dtmf " |  | ||||||
|                 "detection"); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     // Enable/disable out-of-band detection of received telephone-events. |  | ||||||
|     // When enabled, RtpAudioFeedback::OnReceivedTelephoneEvent() will be |  | ||||||
|     // called two times by the RTP/RTCP module (start & end). |  | ||||||
|     const bool forwardToDecoder = |  | ||||||
|         _rtpRtcpModule->TelephoneEventForwardToDecoder(); |  | ||||||
|     const bool detectEndOfTone = true; |  | ||||||
|     _rtpRtcpModule->SetTelephoneEventStatus(_outOfBandTelephoneEventDetecion, |  | ||||||
|                                            forwardToDecoder, |  | ||||||
|                                            detectEndOfTone); |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int |  | ||||||
| Channel::DeRegisterTelephoneEventDetection() |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceInfo, kTraceVoice, VoEId(_instanceId, _channelId), |  | ||||||
|                  "Channel::DeRegisterTelephoneEventDetection()"); |  | ||||||
|  |  | ||||||
|     CriticalSectionScoped cs(&_callbackCritSect); |  | ||||||
|  |  | ||||||
|     if (!_telephoneEventDetectionPtr) |  | ||||||
|     { |  | ||||||
|         _engineStatisticsPtr->SetLastError( |  | ||||||
|             VE_INVALID_OPERATION, |  | ||||||
|             kTraceWarning, |  | ||||||
|             "DeRegisterTelephoneEventDetection() detection already disabled"); |  | ||||||
|         return 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     // Disable out-of-band event detection |  | ||||||
|     const bool forwardToDecoder = |  | ||||||
|         _rtpRtcpModule->TelephoneEventForwardToDecoder(); |  | ||||||
|     _rtpRtcpModule->SetTelephoneEventStatus(false, forwardToDecoder); |  | ||||||
|  |  | ||||||
|     // Disable in-band Dtmf detection |  | ||||||
|     _audioCodingModule.RegisterIncomingMessagesCallback(NULL); |  | ||||||
|  |  | ||||||
|     _inbandTelephoneEventDetection = false; |  | ||||||
|     _outOfBandTelephoneEventDetecion = false; |  | ||||||
|     _telephoneEventDetectionPtr = NULL; |  | ||||||
|  |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int |  | ||||||
| Channel::GetTelephoneEventDetectionStatus( |  | ||||||
|     bool& enabled, |  | ||||||
|     TelephoneEventDetectionMethods& detectionMethod) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceInfo, kTraceVoice, VoEId(_instanceId, _channelId), |  | ||||||
|                  "Channel::GetTelephoneEventDetectionStatus()"); |  | ||||||
|  |  | ||||||
|     { |  | ||||||
|         CriticalSectionScoped cs(&_callbackCritSect); |  | ||||||
|         enabled = (_telephoneEventDetectionPtr != NULL); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (enabled) |  | ||||||
|     { |  | ||||||
|         if (_inbandTelephoneEventDetection && !_outOfBandTelephoneEventDetecion) |  | ||||||
|             detectionMethod = kInBand; |  | ||||||
|         else if (!_inbandTelephoneEventDetection |  | ||||||
|             && _outOfBandTelephoneEventDetecion) |  | ||||||
|             detectionMethod = kOutOfBand; |  | ||||||
|         else if (_inbandTelephoneEventDetection |  | ||||||
|             && _outOfBandTelephoneEventDetecion) |  | ||||||
|             detectionMethod = kInAndOutOfBand; |  | ||||||
|         else |  | ||||||
|         { |  | ||||||
|             assert(false); |  | ||||||
|             return -1; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     WEBRTC_TRACE(kTraceStateInfo, kTraceVoice, |  | ||||||
|                VoEId(_instanceId, _channelId), |  | ||||||
|                "GetTelephoneEventDetectionStatus() => enabled=%d," |  | ||||||
|                "detectionMethod=%d", enabled, detectionMethod); |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #endif  // #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|  |  | ||||||
| int | int | ||||||
| Channel::UpdateRxVadDetection(AudioFrame& audioFrame) | Channel::UpdateRxVadDetection(AudioFrame& audioFrame) | ||||||
| { | { | ||||||
|   | |||||||
| @@ -73,9 +73,6 @@ class Channel: | |||||||
|     public RtpAudioFeedback, |     public RtpAudioFeedback, | ||||||
|     public AudioPacketizationCallback, // receive encoded packets from the ACM |     public AudioPacketizationCallback, // receive encoded packets from the ACM | ||||||
|     public ACMVADCallback, // receive voice activity from the ACM |     public ACMVADCallback, // receive voice activity from the ACM | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     public AudioCodingFeedback, // inband Dtmf detection in the ACM |  | ||||||
| #endif |  | ||||||
|     public MixerParticipant // supplies output mixer with audio frames |     public MixerParticipant // supplies output mixer with audio frames | ||||||
| { | { | ||||||
| public: | public: | ||||||
| @@ -296,15 +293,6 @@ public: | |||||||
|     bool DtmfPlayoutStatus() const; |     bool DtmfPlayoutStatus() const; | ||||||
|     int SetSendTelephoneEventPayloadType(unsigned char type); |     int SetSendTelephoneEventPayloadType(unsigned char type); | ||||||
|     int GetSendTelephoneEventPayloadType(unsigned char& type); |     int GetSendTelephoneEventPayloadType(unsigned char& type); | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     int RegisterTelephoneEventDetection( |  | ||||||
|             TelephoneEventDetectionMethods detectionMethod, |  | ||||||
|             VoETelephoneEventObserver& observer); |  | ||||||
|     int DeRegisterTelephoneEventDetection(); |  | ||||||
|     int GetTelephoneEventDetectionStatus( |  | ||||||
|             bool& enabled, |  | ||||||
|             TelephoneEventDetectionMethods& detectionMethod); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|     // VoEAudioProcessingImpl |     // VoEAudioProcessingImpl | ||||||
|     int UpdateRxVadDetection(AudioFrame& audioFrame); |     int UpdateRxVadDetection(AudioFrame& audioFrame); | ||||||
| @@ -372,11 +360,6 @@ public: | |||||||
|     // From ACMVADCallback in the ACM |     // From ACMVADCallback in the ACM | ||||||
|     WebRtc_Word32 InFrameType(WebRtc_Word16 frameType); |     WebRtc_Word32 InFrameType(WebRtc_Word16 frameType); | ||||||
|  |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
| public: // From AudioCodingFeedback in the ACM |  | ||||||
|     int IncomingDtmf(const WebRtc_UWord8 digitDtmf, const bool end); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     WebRtc_Word32 OnRxVadDetected(const int vadDecision); |     WebRtc_Word32 OnRxVadDetected(const int vadDecision); | ||||||
|  |  | ||||||
| @@ -603,9 +586,6 @@ private: | |||||||
|     Encryption* _encryptionPtr; // WebRtc SRTP or external encryption |     Encryption* _encryptionPtr; // WebRtc SRTP or external encryption | ||||||
|     scoped_ptr<AudioProcessing> _rtpAudioProc; |     scoped_ptr<AudioProcessing> _rtpAudioProc; | ||||||
|     AudioProcessing* _rxAudioProcessingModulePtr; // far end AudioProcessing |     AudioProcessing* _rxAudioProcessingModulePtr; // far end AudioProcessing | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     VoETelephoneEventObserver* _telephoneEventDetectionPtr; |  | ||||||
| #endif |  | ||||||
|     VoERxVadCallback* _rxVadObserverPtr; |     VoERxVadCallback* _rxVadObserverPtr; | ||||||
|     WebRtc_Word32 _oldVadDecision; |     WebRtc_Word32 _oldVadDecision; | ||||||
|     WebRtc_Word32 _sendFrameType; // Send data is voice, 1-voice, 0-otherwise |     WebRtc_Word32 _sendFrameType; // Send data is voice, 1-voice, 0-otherwise | ||||||
| @@ -634,8 +614,6 @@ private: | |||||||
|     // VoEDtmf |     // VoEDtmf | ||||||
|     bool _playOutbandDtmfEvent; |     bool _playOutbandDtmfEvent; | ||||||
|     bool _playInbandDtmfEvent; |     bool _playInbandDtmfEvent; | ||||||
|     bool _inbandTelephoneEventDetection; |  | ||||||
|     bool _outOfBandTelephoneEventDetecion; |  | ||||||
|     // VoeRTP_RTCP |     // VoeRTP_RTCP | ||||||
|     WebRtc_UWord8 _extraPayloadType; |     WebRtc_UWord8 _extraPayloadType; | ||||||
|     bool _insertExtraRTPPacket; |     bool _insertExtraRTPPacket; | ||||||
|   | |||||||
| @@ -33,35 +33,12 @@ | |||||||
| #ifndef WEBRTC_VOICE_ENGINE_VOE_DTMF_H | #ifndef WEBRTC_VOICE_ENGINE_VOE_DTMF_H | ||||||
| #define WEBRTC_VOICE_ENGINE_VOE_DTMF_H | #define WEBRTC_VOICE_ENGINE_VOE_DTMF_H | ||||||
|  |  | ||||||
| #include "common_types.h" | #include "webrtc/common_types.h" | ||||||
|  |  | ||||||
| namespace webrtc { | namespace webrtc { | ||||||
|  |  | ||||||
| class VoiceEngine; | class VoiceEngine; | ||||||
|  |  | ||||||
| // VoETelephoneEventObserver |  | ||||||
| class WEBRTC_DLLEXPORT VoETelephoneEventObserver |  | ||||||
| { |  | ||||||
| public: |  | ||||||
|     // This method will be called after the detection of an inband |  | ||||||
|     // telephone event. The event code is given as output in the |  | ||||||
|     // |eventCode| parameter. |  | ||||||
|     virtual void OnReceivedTelephoneEventInband(int channel, |  | ||||||
|                                                 int eventCode, |  | ||||||
|                                                 bool endOfEvent) = 0; |  | ||||||
|  |  | ||||||
|     // This method will be called after the detection of an out-of-band |  | ||||||
|     // telephone event. The event code is given as output in the |  | ||||||
|     // |eventCode| parameter. |  | ||||||
|     virtual void OnReceivedTelephoneEventOutOfBand( |  | ||||||
|         int channel, |  | ||||||
|         int eventCode, |  | ||||||
|         bool endOfEvent) = 0; |  | ||||||
|  |  | ||||||
| protected: |  | ||||||
|     virtual ~VoETelephoneEventObserver() {} |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| // VoEDtmf | // VoEDtmf | ||||||
| class WEBRTC_DLLEXPORT VoEDtmf | class WEBRTC_DLLEXPORT VoEDtmf | ||||||
| { | { | ||||||
| @@ -122,22 +99,6 @@ public: | |||||||
|     // Stops playing out a DTMF feedback tone locally. |     // Stops playing out a DTMF feedback tone locally. | ||||||
|     virtual int StopPlayingDtmfTone() = 0; |     virtual int StopPlayingDtmfTone() = 0; | ||||||
|  |  | ||||||
|     // Installs an instance of a VoETelephoneEventObserver derived class and |  | ||||||
|     // activates detection of telephone events for the specified |channel|. |  | ||||||
|     virtual int RegisterTelephoneEventDetection( |  | ||||||
|         int channel, TelephoneEventDetectionMethods detectionMethod, |  | ||||||
|         VoETelephoneEventObserver& observer) = 0; |  | ||||||
|  |  | ||||||
|     // Removes an instance of a VoETelephoneEventObserver derived class and |  | ||||||
|     // disables detection of telephone events for the specified |channel|. |  | ||||||
|     virtual int DeRegisterTelephoneEventDetection(int channel) = 0; |  | ||||||
|  |  | ||||||
|     // Gets the current telephone-event detection status for a specified |  | ||||||
|     // |channel|. |  | ||||||
|     virtual int GetTelephoneEventDetectionStatus( |  | ||||||
|         int channel, bool& enabled, |  | ||||||
|         TelephoneEventDetectionMethods& detectionMethod) = 0; |  | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
|     VoEDtmf() {} |     VoEDtmf() {} | ||||||
|     virtual ~VoEDtmf() {} |     virtual ~VoEDtmf() {} | ||||||
|   | |||||||
| @@ -3319,71 +3319,6 @@ int VoEExtendedTest::TestDtmf() { | |||||||
|   AOK(); |   AOK(); | ||||||
|   ANL(); |   ANL(); | ||||||
|  |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|   TEST(RegisterTelephoneEventDetection - several channels); ANL(); |  | ||||||
|  |  | ||||||
|   ci.channels = 1; |  | ||||||
|   ci.pacsize = 160; |  | ||||||
|   ci.plfreq = 8000; |  | ||||||
|   ci.pltype = 0; |  | ||||||
|   ci.rate = 64000; |  | ||||||
|   strcpy(ci.plname, "PCMU"); |  | ||||||
|   TEST_MUSTPASS(codec->SetSendCodec(0, ci)); |  | ||||||
|  |  | ||||||
|   int ch2 = voe_base_->CreateChannel(); |  | ||||||
|   TEST_MUSTPASS(voe_base_->SetSendDestination(ch2, 8002, "127.0.0.1")); |  | ||||||
|   TEST_MUSTPASS(voe_base_->SetLocalReceiver(ch2, 8002)); |  | ||||||
|   TEST_MUSTPASS(voe_base_->StartReceive(ch2)); |  | ||||||
|   TEST_MUSTPASS(codec->SetSendCodec(ch2, ci)); |  | ||||||
|   TEST_MUSTPASS(voe_base_->StartPlayout(ch2)); |  | ||||||
|   TEST_MUSTPASS(voe_base_->StartSend(ch2)); |  | ||||||
|   MARK(); |  | ||||||
|  |  | ||||||
|   DtmfCallback *d = new DtmfCallback(); |  | ||||||
|   TEST_MUSTPASS(dtmf->SetDtmfFeedbackStatus(false)); |  | ||||||
|  |  | ||||||
|   TEST_MUSTPASS(voe_base_->StopSend(0)); |  | ||||||
|   TEST_MUSTPASS(voe_base_->StopPlayout(0)); |  | ||||||
|   TEST_MUSTPASS(voe_base_->StartSend(0)); |  | ||||||
|   TEST_MUSTPASS(voe_base_->StartPlayout(0)); |  | ||||||
|  |  | ||||||
|   // In-band |  | ||||||
|   TEST_MUSTPASS(dtmf->RegisterTelephoneEventDetection(0, kInBand, *d)); |  | ||||||
|   TEST_MUSTPASS(dtmf->RegisterTelephoneEventDetection(ch2, kInBand, *d)); |  | ||||||
|   TEST_LOG("\nSending in-band telephone events:"); |  | ||||||
|   for(int i = 0; i < 16; i++) |  | ||||||
|   { |  | ||||||
|     TEST_LOG("\n  %d ", i); fflush(NULL); |  | ||||||
|     TEST_MUSTPASS(dtmf->SendTelephoneEvent(0, i, false, 160, 10)); |  | ||||||
|     TEST_MUSTPASS(dtmf->SendTelephoneEvent(ch2, i, false, 160, 10)); |  | ||||||
|     SleepMs(500); |  | ||||||
|   } |  | ||||||
|   TEST_LOG("\nDetected %d events \n", d->counter); |  | ||||||
|   TEST_MUSTPASS(d->counter != 32); |  | ||||||
|   TEST_MUSTPASS(dtmf->DeRegisterTelephoneEventDetection(0)); |  | ||||||
|   TEST_MUSTPASS(dtmf->DeRegisterTelephoneEventDetection(ch2)); |  | ||||||
|  |  | ||||||
|   // Out-of-band |  | ||||||
|   d->counter = 0; |  | ||||||
|   TEST_MUSTPASS(dtmf->RegisterTelephoneEventDetection(0, kOutOfBand, *d)); |  | ||||||
|   TEST_MUSTPASS(dtmf->RegisterTelephoneEventDetection(ch2, kOutOfBand, *d)); |  | ||||||
|   TEST_LOG("\nSending out-band telephone events:"); |  | ||||||
|   for(int i = 0; i < 16; i++) |  | ||||||
|   { |  | ||||||
|     TEST_LOG("\n  %d ", i); fflush(NULL); |  | ||||||
|     TEST_MUSTPASS(dtmf->SendTelephoneEvent(0, i, true, 160, 10)); |  | ||||||
|     TEST_MUSTPASS(dtmf->SendTelephoneEvent(ch2, i, true, 160, 10)); |  | ||||||
|     SleepMs(500); |  | ||||||
|   } |  | ||||||
|   TEST_LOG("\nDetected %d events \n", d->counter); |  | ||||||
|   TEST_MUSTPASS(d->counter != 32); |  | ||||||
|   TEST_MUSTPASS(dtmf->DeRegisterTelephoneEventDetection(0)); |  | ||||||
|   TEST_MUSTPASS(dtmf->DeRegisterTelephoneEventDetection(ch2)); |  | ||||||
|   delete d; |  | ||||||
|  |  | ||||||
|   AOK(); ANL(); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
|   TEST_MUSTPASS(dtmf->SetDtmfFeedbackStatus(true, false)); |   TEST_MUSTPASS(dtmf->SetDtmfFeedbackStatus(true, false)); | ||||||
|   TEST_MUSTPASS(voe_base_->StopSend(0)); |   TEST_MUSTPASS(voe_base_->StopSend(0)); | ||||||
|   TEST_MUSTPASS(voe_base_->StopPlayout(0)); |   TEST_MUSTPASS(voe_base_->StopPlayout(0)); | ||||||
|   | |||||||
| @@ -8,15 +8,15 @@ | |||||||
|  *  be found in the AUTHORS file in the root of the source tree. |  *  be found in the AUTHORS file in the root of the source tree. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "voe_dtmf_impl.h" | #include "webrtc/voice_engine/voe_dtmf_impl.h" | ||||||
|  |  | ||||||
| #include "channel.h" | #include "webrtc/system_wrappers/interface/critical_section_wrapper.h" | ||||||
| #include "critical_section_wrapper.h" | #include "webrtc/system_wrappers/interface/trace.h" | ||||||
| #include "output_mixer.h" | #include "webrtc/voice_engine/channel.h" | ||||||
| #include "trace.h" | #include "webrtc/voice_engine/include/voe_errors.h" | ||||||
| #include "transmit_mixer.h" | #include "webrtc/voice_engine/output_mixer.h" | ||||||
| #include "voe_errors.h" | #include "webrtc/voice_engine/transmit_mixer.h" | ||||||
| #include "voice_engine_impl.h" | #include "webrtc/voice_engine/voice_engine_impl.h" | ||||||
|  |  | ||||||
| namespace webrtc { | namespace webrtc { | ||||||
|  |  | ||||||
| @@ -271,94 +271,6 @@ int VoEDtmfImpl::StopPlayingDtmfTone() | |||||||
|     return _shared->output_mixer()->StopPlayingDtmfTone(); |     return _shared->output_mixer()->StopPlayingDtmfTone(); | ||||||
| } | } | ||||||
|  |  | ||||||
| int VoEDtmfImpl::RegisterTelephoneEventDetection( |  | ||||||
|     int channel, |  | ||||||
|     TelephoneEventDetectionMethods detectionMethod, |  | ||||||
|     VoETelephoneEventObserver& observer) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceApiCall, kTraceVoice, VoEId(_shared->instance_id(), -1), |  | ||||||
|       "RegisterTelephoneEventDetection(channel=%d, detectionMethod=%d," |  | ||||||
|       "observer=0x%x)", channel, detectionMethod, &observer); |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     if (!_shared->statistics().Initialized()) |  | ||||||
|     { |  | ||||||
|         _shared->SetLastError(VE_NOT_INITED, kTraceError); |  | ||||||
|         return -1; |  | ||||||
|     } |  | ||||||
|     voe::ScopedChannel sc(_shared->channel_manager(), channel); |  | ||||||
|     voe::Channel* channelPtr = sc.ChannelPtr(); |  | ||||||
|     if (channelPtr == NULL) |  | ||||||
|     { |  | ||||||
|         _shared->SetLastError(VE_CHANNEL_NOT_VALID, kTraceError, |  | ||||||
|             "RegisterTelephoneEventDetection() failed to locate channel"); |  | ||||||
|         return -1; |  | ||||||
|     } |  | ||||||
|     return channelPtr->RegisterTelephoneEventDetection(detectionMethod, |  | ||||||
|                                                        observer); |  | ||||||
| #else |  | ||||||
|     _shared->SetLastError(VE_FUNC_NOT_SUPPORTED, kTraceError, |  | ||||||
|         "SetTelephoneEventDetectionStatus() Dtmf detection is not supported"); |  | ||||||
|     return -1; |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int VoEDtmfImpl::DeRegisterTelephoneEventDetection(int channel) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceApiCall, kTraceVoice, VoEId(_shared->instance_id(), -1), |  | ||||||
|             "DeRegisterTelephoneEventDetection(channel=%d)", channel); |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     if (!_shared->statistics().Initialized()) |  | ||||||
|     { |  | ||||||
|         _shared->SetLastError(VE_NOT_INITED, kTraceError); |  | ||||||
|         return -1; |  | ||||||
|     } |  | ||||||
|     voe::ScopedChannel sc(_shared->channel_manager(), channel); |  | ||||||
|     voe::Channel* channelPtr = sc.ChannelPtr(); |  | ||||||
|     if (channelPtr == NULL) |  | ||||||
|     { |  | ||||||
|         _shared->SetLastError(VE_CHANNEL_NOT_VALID, kTraceError, |  | ||||||
|             "DeRegisterTelephoneEventDe tection() failed to locate channel"); |  | ||||||
|             return -1; |  | ||||||
|     } |  | ||||||
|     return channelPtr->DeRegisterTelephoneEventDetection(); |  | ||||||
| #else |  | ||||||
|     _shared->SetLastError(VE_FUNC_NOT_SUPPORTED, kTraceError, |  | ||||||
|         "DeRegisterTelephoneEventDetection() Dtmf detection is not supported"); |  | ||||||
|     return -1; |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| int VoEDtmfImpl::GetTelephoneEventDetectionStatus( |  | ||||||
|     int channel, |  | ||||||
|     bool& enabled, |  | ||||||
|     TelephoneEventDetectionMethods& detectionMethod) |  | ||||||
| { |  | ||||||
|     WEBRTC_TRACE(kTraceApiCall, kTraceVoice, VoEId(_shared->instance_id(), -1), |  | ||||||
|                "GetTelephoneEventDetectionStatus(channel=%d)", channel); |  | ||||||
| #ifdef WEBRTC_DTMF_DETECTION |  | ||||||
|     if (!_shared->statistics().Initialized()) |  | ||||||
|     { |  | ||||||
|         _shared->SetLastError(VE_NOT_INITED, kTraceError); |  | ||||||
|         return -1; |  | ||||||
|     } |  | ||||||
|     voe::ScopedChannel sc(_shared->channel_manager(), channel); |  | ||||||
|     voe::Channel* channelPtr = sc.ChannelPtr(); |  | ||||||
|     if (channelPtr == NULL) |  | ||||||
|     { |  | ||||||
|         _shared->SetLastError(VE_CHANNEL_NOT_VALID, kTraceError, |  | ||||||
|             "GetTelephoneEventDetectionStatus() failed to locate channel"); |  | ||||||
|         return -1; |  | ||||||
|     } |  | ||||||
|     return channelPtr->GetTelephoneEventDetectionStatus(enabled, |  | ||||||
|                                                         detectionMethod); |  | ||||||
| #else |  | ||||||
|     _shared->SetLastError(VE_FUNC_NOT_SUPPORTED, kTraceError, |  | ||||||
|         "GetTelephoneEventDetectionStatus() Dtmf detection is not supported"); |  | ||||||
|     return -1; |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
|  |  | ||||||
| int VoEDtmfImpl::SetDtmfFeedbackStatus(bool enable, bool directFeedback) | int VoEDtmfImpl::SetDtmfFeedbackStatus(bool enable, bool directFeedback) | ||||||
| { | { | ||||||
|     WEBRTC_TRACE(kTraceApiCall, kTraceVoice, VoEId(_shared->instance_id(), -1), |     WEBRTC_TRACE(kTraceApiCall, kTraceVoice, VoEId(_shared->instance_id(), -1), | ||||||
|   | |||||||
| @@ -11,9 +11,8 @@ | |||||||
| #ifndef WEBRTC_VOICE_ENGINE_VOE_DTMF_IMPL_H | #ifndef WEBRTC_VOICE_ENGINE_VOE_DTMF_IMPL_H | ||||||
| #define WEBRTC_VOICE_ENGINE_VOE_DTMF_IMPL_H | #define WEBRTC_VOICE_ENGINE_VOE_DTMF_IMPL_H | ||||||
|  |  | ||||||
| #include "voe_dtmf.h" | #include "webrtc/voice_engine/include/voe_dtmf.h" | ||||||
|  | #include "webrtc/voice_engine/shared_data.h" | ||||||
| #include "shared_data.h" |  | ||||||
|  |  | ||||||
| namespace webrtc | namespace webrtc | ||||||
| { | { | ||||||
| @@ -48,18 +47,6 @@ public: | |||||||
|  |  | ||||||
|     virtual int StopPlayingDtmfTone(); |     virtual int StopPlayingDtmfTone(); | ||||||
|  |  | ||||||
|     virtual int RegisterTelephoneEventDetection( |  | ||||||
|         int channel, |  | ||||||
|         TelephoneEventDetectionMethods detectionMethod, |  | ||||||
|         VoETelephoneEventObserver& observer); |  | ||||||
|  |  | ||||||
|     virtual int DeRegisterTelephoneEventDetection(int channel); |  | ||||||
|  |  | ||||||
|     virtual int GetTelephoneEventDetectionStatus( |  | ||||||
|         int channel, |  | ||||||
|         bool& enabled, |  | ||||||
|         TelephoneEventDetectionMethods& detectionMethod); |  | ||||||
|  |  | ||||||
|     virtual int SetDtmfPlayoutStatus(int channel, bool enable); |     virtual int SetDtmfPlayoutStatus(int channel, bool enable); | ||||||
|  |  | ||||||
|     virtual int GetDtmfPlayoutStatus(int channel, bool& enabled); |     virtual int GetDtmfPlayoutStatus(int channel, bool& enabled); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 turaj@webrtc.org
					turaj@webrtc.org