2011-07-07 08:21:25 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
*/
|
|
|
|
|
|
2017-09-15 06:47:31 +02:00
|
|
|
#ifndef MODULES_AUDIO_CODING_CODECS_G711_G711_INTERFACE_H_
|
|
|
|
|
#define MODULES_AUDIO_CODING_CODECS_G711_G711_INTERFACE_H_
|
2011-07-07 08:21:25 +00:00
|
|
|
|
2022-10-07 21:47:49 +00:00
|
|
|
#include <stddef.h>
|
2018-07-25 16:05:48 +02:00
|
|
|
#include <stdint.h>
|
2011-07-07 08:21:25 +00:00
|
|
|
|
|
|
|
|
// Comfort noise constants
|
2013-03-21 13:38:29 +00:00
|
|
|
#define G711_WEBRTC_SPEECH 1
|
|
|
|
|
#define G711_WEBRTC_CNG 2
|
2011-07-07 08:21:25 +00:00
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
|
* WebRtcG711_EncodeA(...)
|
|
|
|
|
*
|
|
|
|
|
* This function encodes a G711 A-law frame and inserts it into a packet.
|
|
|
|
|
* Input speech length has be of any length.
|
|
|
|
|
*
|
|
|
|
|
* Input:
|
|
|
|
|
* - speechIn : Input speech vector
|
|
|
|
|
* - len : Samples in speechIn
|
|
|
|
|
*
|
|
|
|
|
* Output:
|
|
|
|
|
* - encoded : The encoded data vector
|
|
|
|
|
*
|
2015-02-23 15:27:52 +00:00
|
|
|
* Return value : Length (in bytes) of coded data.
|
|
|
|
|
* Always equal to len input parameter.
|
2011-07-07 08:21:25 +00:00
|
|
|
*/
|
|
|
|
|
|
Update a ton of audio code to use size_t more correctly and in general reduce
use of int16_t/uint16_t.
This is the upshot of a recommendation by henrik.lundin and kwiberg on an original small change ( https://webrtc-codereview.appspot.com/42569004/#ps1 ) to stop using int16_t just because values could fit in it, and is similar in nature to a previous "mass change to use size_t more" ( https://webrtc-codereview.appspot.com/23129004/ ) which also needed to be split up for review but to land all at once, since, like adding "const", such changes tend to cause a lot of transitive effects.
This was be reviewed and approved in pieces:
https://codereview.webrtc.org/1224093003
https://codereview.webrtc.org/1224123002
https://codereview.webrtc.org/1224163002
https://codereview.webrtc.org/1225133003
https://codereview.webrtc.org/1225173002
https://codereview.webrtc.org/1227163003
https://codereview.webrtc.org/1227203003
https://codereview.webrtc.org/1227213002
https://codereview.webrtc.org/1227893002
https://codereview.webrtc.org/1228793004
https://codereview.webrtc.org/1228803003
https://codereview.webrtc.org/1228823002
https://codereview.webrtc.org/1228823003
https://codereview.webrtc.org/1228843002
https://codereview.webrtc.org/1230693002
https://codereview.webrtc.org/1231713002
The change is being landed as TBR to all the folks who reviewed the above.
BUG=chromium:81439
TEST=none
R=andrew@webrtc.org, pbos@webrtc.org
TBR=aluebs, andrew, asapersson, henrika, hlundin, jan.skoglund, kwiberg, minyue, pbos, pthatcher
Review URL: https://codereview.webrtc.org/1230503003 .
Cr-Commit-Position: refs/heads/master@{#9768}
2015-08-24 14:52:23 -07:00
|
|
|
size_t WebRtcG711_EncodeA(const int16_t* speechIn,
|
|
|
|
|
size_t len,
|
|
|
|
|
uint8_t* encoded);
|
2011-07-07 08:21:25 +00:00
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
|
* WebRtcG711_EncodeU(...)
|
|
|
|
|
*
|
|
|
|
|
* This function encodes a G711 U-law frame and inserts it into a packet.
|
|
|
|
|
* Input speech length has be of any length.
|
|
|
|
|
*
|
|
|
|
|
* Input:
|
|
|
|
|
* - speechIn : Input speech vector
|
|
|
|
|
* - len : Samples in speechIn
|
|
|
|
|
*
|
|
|
|
|
* Output:
|
|
|
|
|
* - encoded : The encoded data vector
|
|
|
|
|
*
|
2015-02-23 15:27:52 +00:00
|
|
|
* Return value : Length (in bytes) of coded data.
|
|
|
|
|
* Always equal to len input parameter.
|
2011-07-07 08:21:25 +00:00
|
|
|
*/
|
|
|
|
|
|
Update a ton of audio code to use size_t more correctly and in general reduce
use of int16_t/uint16_t.
This is the upshot of a recommendation by henrik.lundin and kwiberg on an original small change ( https://webrtc-codereview.appspot.com/42569004/#ps1 ) to stop using int16_t just because values could fit in it, and is similar in nature to a previous "mass change to use size_t more" ( https://webrtc-codereview.appspot.com/23129004/ ) which also needed to be split up for review but to land all at once, since, like adding "const", such changes tend to cause a lot of transitive effects.
This was be reviewed and approved in pieces:
https://codereview.webrtc.org/1224093003
https://codereview.webrtc.org/1224123002
https://codereview.webrtc.org/1224163002
https://codereview.webrtc.org/1225133003
https://codereview.webrtc.org/1225173002
https://codereview.webrtc.org/1227163003
https://codereview.webrtc.org/1227203003
https://codereview.webrtc.org/1227213002
https://codereview.webrtc.org/1227893002
https://codereview.webrtc.org/1228793004
https://codereview.webrtc.org/1228803003
https://codereview.webrtc.org/1228823002
https://codereview.webrtc.org/1228823003
https://codereview.webrtc.org/1228843002
https://codereview.webrtc.org/1230693002
https://codereview.webrtc.org/1231713002
The change is being landed as TBR to all the folks who reviewed the above.
BUG=chromium:81439
TEST=none
R=andrew@webrtc.org, pbos@webrtc.org
TBR=aluebs, andrew, asapersson, henrika, hlundin, jan.skoglund, kwiberg, minyue, pbos, pthatcher
Review URL: https://codereview.webrtc.org/1230503003 .
Cr-Commit-Position: refs/heads/master@{#9768}
2015-08-24 14:52:23 -07:00
|
|
|
size_t WebRtcG711_EncodeU(const int16_t* speechIn,
|
|
|
|
|
size_t len,
|
|
|
|
|
uint8_t* encoded);
|
2011-07-07 08:21:25 +00:00
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
|
* WebRtcG711_DecodeA(...)
|
|
|
|
|
*
|
|
|
|
|
* This function decodes a packet G711 A-law frame.
|
|
|
|
|
*
|
|
|
|
|
* Input:
|
|
|
|
|
* - encoded : Encoded data
|
|
|
|
|
* - len : Bytes in encoded vector
|
|
|
|
|
*
|
|
|
|
|
* Output:
|
|
|
|
|
* - decoded : The decoded vector
|
|
|
|
|
* - speechType : 1 normal, 2 CNG (for G711 it should
|
|
|
|
|
* always return 1 since G711 does not have a
|
|
|
|
|
* built-in DTX/CNG scheme)
|
|
|
|
|
*
|
|
|
|
|
* Return value : >0 - Samples in decoded vector
|
|
|
|
|
* -1 - Error
|
|
|
|
|
*/
|
|
|
|
|
|
Update a ton of audio code to use size_t more correctly and in general reduce
use of int16_t/uint16_t.
This is the upshot of a recommendation by henrik.lundin and kwiberg on an original small change ( https://webrtc-codereview.appspot.com/42569004/#ps1 ) to stop using int16_t just because values could fit in it, and is similar in nature to a previous "mass change to use size_t more" ( https://webrtc-codereview.appspot.com/23129004/ ) which also needed to be split up for review but to land all at once, since, like adding "const", such changes tend to cause a lot of transitive effects.
This was be reviewed and approved in pieces:
https://codereview.webrtc.org/1224093003
https://codereview.webrtc.org/1224123002
https://codereview.webrtc.org/1224163002
https://codereview.webrtc.org/1225133003
https://codereview.webrtc.org/1225173002
https://codereview.webrtc.org/1227163003
https://codereview.webrtc.org/1227203003
https://codereview.webrtc.org/1227213002
https://codereview.webrtc.org/1227893002
https://codereview.webrtc.org/1228793004
https://codereview.webrtc.org/1228803003
https://codereview.webrtc.org/1228823002
https://codereview.webrtc.org/1228823003
https://codereview.webrtc.org/1228843002
https://codereview.webrtc.org/1230693002
https://codereview.webrtc.org/1231713002
The change is being landed as TBR to all the folks who reviewed the above.
BUG=chromium:81439
TEST=none
R=andrew@webrtc.org, pbos@webrtc.org
TBR=aluebs, andrew, asapersson, henrika, hlundin, jan.skoglund, kwiberg, minyue, pbos, pthatcher
Review URL: https://codereview.webrtc.org/1230503003 .
Cr-Commit-Position: refs/heads/master@{#9768}
2015-08-24 14:52:23 -07:00
|
|
|
size_t WebRtcG711_DecodeA(const uint8_t* encoded,
|
|
|
|
|
size_t len,
|
|
|
|
|
int16_t* decoded,
|
|
|
|
|
int16_t* speechType);
|
2011-07-07 08:21:25 +00:00
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
|
* WebRtcG711_DecodeU(...)
|
|
|
|
|
*
|
|
|
|
|
* This function decodes a packet G711 U-law frame.
|
|
|
|
|
*
|
|
|
|
|
* Input:
|
|
|
|
|
* - encoded : Encoded data
|
|
|
|
|
* - len : Bytes in encoded vector
|
|
|
|
|
*
|
|
|
|
|
* Output:
|
|
|
|
|
* - decoded : The decoded vector
|
|
|
|
|
* - speechType : 1 normal, 2 CNG (for G711 it should
|
|
|
|
|
* always return 1 since G711 does not have a
|
|
|
|
|
* built-in DTX/CNG scheme)
|
|
|
|
|
*
|
|
|
|
|
* Return value : >0 - Samples in decoded vector
|
|
|
|
|
* -1 - Error
|
|
|
|
|
*/
|
|
|
|
|
|
Update a ton of audio code to use size_t more correctly and in general reduce
use of int16_t/uint16_t.
This is the upshot of a recommendation by henrik.lundin and kwiberg on an original small change ( https://webrtc-codereview.appspot.com/42569004/#ps1 ) to stop using int16_t just because values could fit in it, and is similar in nature to a previous "mass change to use size_t more" ( https://webrtc-codereview.appspot.com/23129004/ ) which also needed to be split up for review but to land all at once, since, like adding "const", such changes tend to cause a lot of transitive effects.
This was be reviewed and approved in pieces:
https://codereview.webrtc.org/1224093003
https://codereview.webrtc.org/1224123002
https://codereview.webrtc.org/1224163002
https://codereview.webrtc.org/1225133003
https://codereview.webrtc.org/1225173002
https://codereview.webrtc.org/1227163003
https://codereview.webrtc.org/1227203003
https://codereview.webrtc.org/1227213002
https://codereview.webrtc.org/1227893002
https://codereview.webrtc.org/1228793004
https://codereview.webrtc.org/1228803003
https://codereview.webrtc.org/1228823002
https://codereview.webrtc.org/1228823003
https://codereview.webrtc.org/1228843002
https://codereview.webrtc.org/1230693002
https://codereview.webrtc.org/1231713002
The change is being landed as TBR to all the folks who reviewed the above.
BUG=chromium:81439
TEST=none
R=andrew@webrtc.org, pbos@webrtc.org
TBR=aluebs, andrew, asapersson, henrika, hlundin, jan.skoglund, kwiberg, minyue, pbos, pthatcher
Review URL: https://codereview.webrtc.org/1230503003 .
Cr-Commit-Position: refs/heads/master@{#9768}
2015-08-24 14:52:23 -07:00
|
|
|
size_t WebRtcG711_DecodeU(const uint8_t* encoded,
|
|
|
|
|
size_t len,
|
|
|
|
|
int16_t* decoded,
|
|
|
|
|
int16_t* speechType);
|
2012-11-19 08:02:55 +00:00
|
|
|
|
2011-07-07 08:21:25 +00:00
|
|
|
/**********************************************************************
|
|
|
|
|
* WebRtcG711_Version(...)
|
|
|
|
|
*
|
|
|
|
|
* This function gives the version string of the G.711 codec.
|
|
|
|
|
*
|
|
|
|
|
* Input:
|
|
|
|
|
* - lenBytes: the size of Allocated space (in Bytes) where
|
|
|
|
|
* the version number is written to (in string format).
|
|
|
|
|
*
|
|
|
|
|
* Output:
|
|
|
|
|
* - version: Pointer to a buffer where the version number is
|
|
|
|
|
* written to.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2013-03-21 13:38:29 +00:00
|
|
|
int16_t WebRtcG711_Version(char* version, int16_t lenBytes);
|
2011-07-07 08:21:25 +00:00
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2017-09-15 06:47:31 +02:00
|
|
|
#endif // MODULES_AUDIO_CODING_CODECS_G711_G711_INTERFACE_H_
|