Cleanup indications on exit.
[asterisk/asterisk.git] / codecs / codec_ulaw.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 1999 - 2005, Digium, Inc.
5  *
6  * Mark Spencer <markster@digium.com>
7  *
8  * See http://www.asterisk.org for more information about
9  * the Asterisk project. Please do not directly contact
10  * any of the maintainers of this project for assistance;
11  * the project provides a web site, mailing lists and IRC
12  * channels for your use.
13  *
14  * This program is free software, distributed under the terms of
15  * the GNU General Public License Version 2. See the LICENSE file
16  * at the top of the source tree.
17  */
18
19 /*! \file
20  *
21  * \brief codec_ulaw.c - translate between signed linear and ulaw
22  * 
23  * \ingroup codecs
24  */
25
26 /*** MODULEINFO
27         <support_level>core</support_level>
28  ***/
29
30 #include "asterisk.h"
31
32 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
33
34 #include "asterisk/module.h"
35 #include "asterisk/config.h"
36 #include "asterisk/translate.h"
37 #include "asterisk/ulaw.h"
38 #include "asterisk/utils.h"
39
40 #define BUFFER_SAMPLES   8096   /* size for the translation buffers */
41
42 /* Sample frame data */
43 #include "asterisk/slin.h"
44 #include "ex_ulaw.h"
45
46 /*! \brief convert and store samples in outbuf */
47 static int ulawtolin_framein(struct ast_trans_pvt *pvt, struct ast_frame *f)
48 {
49         int i = f->samples;
50         unsigned char *src = f->data.ptr;
51         int16_t *dst = pvt->outbuf.i16 + pvt->samples;
52
53         pvt->samples += i;
54         pvt->datalen += i * 2;  /* 2 bytes/sample */
55
56         /* convert and copy in outbuf */
57         while (i--)
58                 *dst++ = AST_MULAW(*src++);
59
60         return 0;
61 }
62
63 /*! \brief convert and store samples in outbuf */
64 static int lintoulaw_framein(struct ast_trans_pvt *pvt, struct ast_frame *f)
65 {
66         int i = f->samples;
67         char *dst = pvt->outbuf.c + pvt->samples;
68         int16_t *src = f->data.ptr;
69
70         pvt->samples += i;
71         pvt->datalen += i;      /* 1 byte/sample */
72
73         while (i--)
74                 *dst++ = AST_LIN2MU(*src++);
75
76         return 0;
77 }
78
79 /*!
80  * \brief The complete translator for ulawToLin.
81  */
82
83 static struct ast_translator ulawtolin = {
84         .name = "ulawtolin",
85         .framein = ulawtolin_framein,
86         .sample = ulaw_sample,
87         .buffer_samples = BUFFER_SAMPLES,
88         .buf_size = BUFFER_SAMPLES * 2,
89 };
90
91 static struct ast_translator testlawtolin = {
92         .name = "testlawtolin",
93         .framein = ulawtolin_framein,
94         .sample = ulaw_sample,
95         .buffer_samples = BUFFER_SAMPLES,
96         .buf_size = BUFFER_SAMPLES * 2,
97 };
98
99 /*!
100  * \brief The complete translator for LinToulaw.
101  */
102
103 static struct ast_translator lintoulaw = {
104         .name = "lintoulaw",
105         .framein = lintoulaw_framein,
106         .sample = slin8_sample,
107         .buf_size = BUFFER_SAMPLES,
108         .buffer_samples = BUFFER_SAMPLES,
109 };
110
111 static struct ast_translator lintotestlaw = {
112         .name = "lintotestlaw",
113         .framein = lintoulaw_framein,
114         .sample = slin8_sample,
115         .buf_size = BUFFER_SAMPLES,
116         .buffer_samples = BUFFER_SAMPLES,
117 };
118
119 static int reload(void)
120 {
121         return AST_MODULE_LOAD_SUCCESS;
122 }
123
124 static int unload_module(void)
125 {
126         int res;
127
128         res = ast_unregister_translator(&lintoulaw);
129         res |= ast_unregister_translator(&ulawtolin);
130         res |= ast_unregister_translator(&testlawtolin);
131         res |= ast_unregister_translator(&lintotestlaw);
132
133         return res;
134 }
135
136 static int load_module(void)
137 {
138         int res;
139
140         ast_format_set(&lintoulaw.src_format, AST_FORMAT_SLINEAR, 0);
141         ast_format_set(&lintoulaw.dst_format, AST_FORMAT_ULAW, 0);
142
143         ast_format_set(&lintotestlaw.src_format, AST_FORMAT_SLINEAR, 0);
144         ast_format_set(&lintotestlaw.dst_format, AST_FORMAT_TESTLAW, 0);
145
146         ast_format_set(&ulawtolin.src_format, AST_FORMAT_ULAW, 0);
147         ast_format_set(&ulawtolin.dst_format, AST_FORMAT_SLINEAR, 0);
148
149         ast_format_set(&testlawtolin.src_format, AST_FORMAT_TESTLAW, 0);
150         ast_format_set(&testlawtolin.dst_format, AST_FORMAT_SLINEAR, 0);
151
152         res = ast_register_translator(&ulawtolin);
153         if (!res) {
154                 res = ast_register_translator(&lintoulaw);
155                 res |= ast_register_translator(&lintotestlaw);
156                 res |= ast_register_translator(&testlawtolin);
157         } else
158                 ast_unregister_translator(&ulawtolin);
159         if (res)
160                 return AST_MODULE_LOAD_FAILURE;
161         return AST_MODULE_LOAD_SUCCESS;
162 }
163
164 AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_DEFAULT, "mu-Law Coder/Decoder",
165                 .load = load_module,
166                 .unload = unload_module,
167                 .reload = reload,
168                );