remove some useless includes from codecs
[asterisk/asterisk.git] / codecs / codec_g722.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 1999 - 2006, Digium, Inc.
5  *
6  * Matthew Fredrickson <creslin@digium.com>
7  *
8  * Special thanks to Steve Underwood for the implementation
9  * and for doing the 8khz<->g.722 direct translation code.
10  *
11  * See http://www.asterisk.org for more information about
12  * the Asterisk project. Please do not directly contact
13  * any of the maintainers of this project for assistance;
14  * the project provides a web site, mailing lists and IRC
15  * channels for your use.
16  *
17  * This program is free software, distributed under the terms of
18  * the GNU General Public License Version 2. See the LICENSE file
19  * at the top of the source tree.
20  */
21
22 /*! \file
23  *
24  * \brief codec_g722.c - translate between signed linear and ITU G.722-64kbps
25  *
26  * \ingroup codecs
27  */
28
29 #include "asterisk.h"
30
31 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
32
33 #include <fcntl.h>
34
35 #include "asterisk/linkedlists.h"
36 #include "asterisk/module.h"
37 #include "asterisk/config.h"
38 #include "asterisk/translate.h"
39 #include "asterisk/utils.h"
40
41 #define BUFFER_SAMPLES   8096   /* size for the translation buffers */
42 #define BUF_SHIFT       5
43
44 /* Sample frame data */
45
46 #include "g722/g722.h"
47 #include "slin_g722_ex.h"
48 #include "g722_slin_ex.h"
49
50 struct g722_encoder_pvt {
51         g722_encode_state_t g722;
52 };
53
54 struct g722_decoder_pvt {
55         g722_decode_state_t g722;
56 };
57
58 /*! \brief init a new instance of g722_encoder_pvt. */
59 static int lintog722_new(struct ast_trans_pvt *pvt)
60 {
61         struct g722_encoder_pvt *tmp = pvt->pvt;
62
63         g722_encode_init(&tmp->g722, 64000, G722_SAMPLE_RATE_8000);
64
65         return 0;
66 }
67
68 static int lin16tog722_new(struct ast_trans_pvt *pvt)
69 {
70         struct g722_encoder_pvt *tmp = pvt->pvt;
71
72         g722_encode_init(&tmp->g722, 64000, 0);
73
74         return 0;
75 }
76
77 /*! \brief init a new instance of g722_encoder_pvt. */
78 static int g722tolin_new(struct ast_trans_pvt *pvt)
79 {
80         struct g722_decoder_pvt *tmp = pvt->pvt;
81
82         g722_decode_init(&tmp->g722, 64000, G722_SAMPLE_RATE_8000);
83
84         return 0;
85 }
86
87 static int g722tolin16_new(struct ast_trans_pvt *pvt)
88 {
89         struct g722_decoder_pvt *tmp = pvt->pvt;
90
91         g722_decode_init(&tmp->g722, 64000, 0);
92
93         return 0;
94 }
95
96 static int g722tolin_framein(struct ast_trans_pvt *pvt, struct ast_frame *f)
97 {
98         struct g722_decoder_pvt *tmp = pvt->pvt;
99         unsigned char *src = f->data;
100         int16_t *dst = (int16_t *) pvt->outbuf + pvt->samples;
101
102         g722_decode(&tmp->g722, dst, src, f->samples);
103         pvt->samples += f->samples;
104         pvt->datalen += 2 * f->samples;
105
106         return 0;
107 }
108
109 static int lintog722_framein(struct ast_trans_pvt *pvt, struct ast_frame *f)
110 {
111         struct g722_encoder_pvt *tmp = pvt->pvt;
112         int16_t *src = f->data;
113
114         g722_encode(&tmp->g722, (uint8_t*)(&pvt->outbuf[pvt->datalen]), src, f->samples);
115         /* Since G.722 64kbps per second is one bye per sample, all of these
116            calculations are easy */
117         pvt->samples += f->samples;
118         pvt->datalen += f->samples;
119
120         return 0;
121 }
122
123 static struct ast_frame *g722tolin_sample(void)
124 {
125         static struct ast_frame f = {
126                 .frametype = AST_FRAME_VOICE,
127                 .subclass = AST_FORMAT_G722,
128                 .datalen = sizeof(g722_slin_ex),
129                 .samples = sizeof(g722_slin_ex) / sizeof(g722_slin_ex[0]),
130                 .src = __PRETTY_FUNCTION__,
131                 .data = g722_slin_ex,
132         };
133
134         return &f;
135 }
136
137 static struct ast_frame *g722tolin16_sample(void)
138 {
139         static struct ast_frame f = {
140                 .frametype = AST_FRAME_VOICE,
141                 .subclass = AST_FORMAT_G722,
142                 .datalen = sizeof(slin_g722_ex),
143                 .samples = sizeof(slin_g722_ex) / sizeof(slin_g722_ex[0]),
144                 .src = __PRETTY_FUNCTION__,
145                 .data = slin_g722_ex,
146         };
147
148         return &f;
149 }
150
151 static struct ast_frame *lintog722_sample (void)
152 {
153         static struct ast_frame f = {
154                 .frametype = AST_FRAME_VOICE,
155                 .subclass = AST_FORMAT_SLINEAR,
156                 .datalen = sizeof(slin_g722_ex),
157                 .samples = sizeof(slin_g722_ex) / sizeof(slin_g722_ex[0]),
158                 .src = __PRETTY_FUNCTION__,
159                 .data = slin_g722_ex,
160         };
161
162         return &f;
163 }
164
165 static struct ast_frame *lin16tog722_sample (void)
166 {
167         static struct ast_frame f = {
168                 .frametype = AST_FRAME_VOICE,
169                 .subclass = AST_FORMAT_SLINEAR16,
170                 .datalen = sizeof(slin_g722_ex),
171                 .samples = sizeof(slin_g722_ex) / sizeof(slin_g722_ex[0]),
172                 .src = __PRETTY_FUNCTION__,
173                 .data = slin_g722_ex,
174         };
175
176         return &f;
177 }
178
179 static struct ast_translator g722tolin = {
180         .name = "g722tolin",
181         .srcfmt = AST_FORMAT_G722,
182         .dstfmt = AST_FORMAT_SLINEAR,
183         .newpvt = g722tolin_new,        /* same for both directions */
184         .framein = g722tolin_framein,
185         .sample = g722tolin_sample,
186         .desc_size = sizeof(struct g722_decoder_pvt),
187         .buffer_samples = BUFFER_SAMPLES,
188         .buf_size = BUFFER_SAMPLES,
189         .plc_samples = 160,
190 };
191
192 static struct ast_translator lintog722 = {
193         .name = "lintog722",
194         .srcfmt = AST_FORMAT_SLINEAR,
195         .dstfmt = AST_FORMAT_G722,
196         .newpvt = lintog722_new,        /* same for both directions */
197         .framein = lintog722_framein,
198         .sample = lintog722_sample,
199         .desc_size = sizeof(struct g722_encoder_pvt),
200         .buffer_samples = BUFFER_SAMPLES,
201         .buf_size = BUFFER_SAMPLES,
202 };
203
204 static struct ast_translator g722tolin16 = {
205         .name = "g722tolin16",
206         .srcfmt = AST_FORMAT_G722,
207         .dstfmt = AST_FORMAT_SLINEAR16,
208         .newpvt = g722tolin16_new,      /* same for both directions */
209         .framein = g722tolin_framein,
210         .sample = g722tolin16_sample,
211         .desc_size = sizeof(struct g722_decoder_pvt),
212         .buffer_samples = BUFFER_SAMPLES,
213         .buf_size = BUFFER_SAMPLES,
214         .plc_samples = 160,
215 };
216
217 static struct ast_translator lin16tog722 = {
218         .name = "lin16tog722",
219         .srcfmt = AST_FORMAT_SLINEAR16,
220         .dstfmt = AST_FORMAT_G722,
221         .newpvt = lin16tog722_new,      /* same for both directions */
222         .framein = lintog722_framein,
223         .sample = lin16tog722_sample,
224         .desc_size = sizeof(struct g722_encoder_pvt),
225         .buffer_samples = BUFFER_SAMPLES,
226         .buf_size = BUFFER_SAMPLES,
227 };
228
229 static int parse_config(int reload)
230 {
231         struct ast_variable *var;
232         struct ast_flags config_flags = { reload ? CONFIG_FLAG_FILEUNCHANGED : 0 };
233         struct ast_config *cfg = ast_config_load("codecs.conf", config_flags);
234
235         if (cfg == NULL)
236                 return -1;
237         if (cfg == CONFIG_STATUS_FILEUNCHANGED)
238                 return 0;
239         for (var = ast_variable_browse(cfg, "plc"); var; var = var->next) {
240                 if (!strcasecmp(var->name, "genericplc")) {
241                         g722tolin.useplc = ast_true(var->value) ? 1 : 0;
242                         ast_verb(3, "codec_g722: %susing generic PLC\n",
243                                         g722tolin.useplc ? "" : "not ");
244                 }
245         }
246         ast_config_destroy(cfg);
247         return 0;
248 }
249
250 static int reload(void)
251 {
252         if (parse_config(1))
253                 return AST_MODULE_LOAD_DECLINE;
254         return AST_MODULE_LOAD_SUCCESS;
255 }
256
257 static int unload_module(void)
258 {
259         int res = 0;
260
261         res |= ast_unregister_translator(&g722tolin);
262         res |= ast_unregister_translator(&lintog722);
263         res |= ast_unregister_translator(&g722tolin16);
264         res |= ast_unregister_translator(&lin16tog722);
265
266         return res;
267 }
268
269 static int load_module(void)
270 {
271         int res = 0;
272
273         if (parse_config(0))
274                 return AST_MODULE_LOAD_DECLINE;
275
276         res |= ast_register_translator(&g722tolin);
277         res |= ast_register_translator(&lintog722);
278         res |= ast_register_translator(&g722tolin16);
279         res |= ast_register_translator(&lin16tog722);
280
281         if (res) {
282                 unload_module();
283                 return AST_MODULE_LOAD_FAILURE;
284         }       
285
286         return AST_MODULE_LOAD_SUCCESS;
287 }
288
289 AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_DEFAULT, "ITU G.722-64kbps G722 Transcoder",
290                 .load = load_module,
291                 .unload = unload_module,
292                 .reload = reload,
293                );