1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun * Audio support data for mISDN_dsp.
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Copyright 2002/2003 by Andreas Eversberg (jolly@eversberg.eu)
5*4882a593Smuzhiyun * Rewritten by Peter
6*4882a593Smuzhiyun *
7*4882a593Smuzhiyun * This software may be used and distributed according to the terms
8*4882a593Smuzhiyun * of the GNU General Public License, incorporated herein by reference.
9*4882a593Smuzhiyun *
10*4882a593Smuzhiyun */
11*4882a593Smuzhiyun
12*4882a593Smuzhiyun #include <linux/delay.h>
13*4882a593Smuzhiyun #include <linux/mISDNif.h>
14*4882a593Smuzhiyun #include <linux/mISDNdsp.h>
15*4882a593Smuzhiyun #include <linux/export.h>
16*4882a593Smuzhiyun #include <linux/bitrev.h>
17*4882a593Smuzhiyun #include "core.h"
18*4882a593Smuzhiyun #include "dsp.h"
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun /* ulaw[unsigned char] -> signed 16-bit */
21*4882a593Smuzhiyun s32 dsp_audio_ulaw_to_s32[256];
22*4882a593Smuzhiyun /* alaw[unsigned char] -> signed 16-bit */
23*4882a593Smuzhiyun s32 dsp_audio_alaw_to_s32[256];
24*4882a593Smuzhiyun
25*4882a593Smuzhiyun s32 *dsp_audio_law_to_s32;
26*4882a593Smuzhiyun EXPORT_SYMBOL(dsp_audio_law_to_s32);
27*4882a593Smuzhiyun
28*4882a593Smuzhiyun /* signed 16-bit -> law */
29*4882a593Smuzhiyun u8 dsp_audio_s16_to_law[65536];
30*4882a593Smuzhiyun EXPORT_SYMBOL(dsp_audio_s16_to_law);
31*4882a593Smuzhiyun
32*4882a593Smuzhiyun /* alaw -> ulaw */
33*4882a593Smuzhiyun u8 dsp_audio_alaw_to_ulaw[256];
34*4882a593Smuzhiyun /* ulaw -> alaw */
35*4882a593Smuzhiyun static u8 dsp_audio_ulaw_to_alaw[256];
36*4882a593Smuzhiyun u8 dsp_silence;
37*4882a593Smuzhiyun
38*4882a593Smuzhiyun
39*4882a593Smuzhiyun /*****************************************************
40*4882a593Smuzhiyun * generate table for conversion of s16 to alaw/ulaw *
41*4882a593Smuzhiyun *****************************************************/
42*4882a593Smuzhiyun
43*4882a593Smuzhiyun #define AMI_MASK 0x55
44*4882a593Smuzhiyun
linear2alaw(short int linear)45*4882a593Smuzhiyun static inline unsigned char linear2alaw(short int linear)
46*4882a593Smuzhiyun {
47*4882a593Smuzhiyun int mask;
48*4882a593Smuzhiyun int seg;
49*4882a593Smuzhiyun int pcm_val;
50*4882a593Smuzhiyun static int seg_end[8] = {
51*4882a593Smuzhiyun 0xFF, 0x1FF, 0x3FF, 0x7FF, 0xFFF, 0x1FFF, 0x3FFF, 0x7FFF
52*4882a593Smuzhiyun };
53*4882a593Smuzhiyun
54*4882a593Smuzhiyun pcm_val = linear;
55*4882a593Smuzhiyun if (pcm_val >= 0) {
56*4882a593Smuzhiyun /* Sign (7th) bit = 1 */
57*4882a593Smuzhiyun mask = AMI_MASK | 0x80;
58*4882a593Smuzhiyun } else {
59*4882a593Smuzhiyun /* Sign bit = 0 */
60*4882a593Smuzhiyun mask = AMI_MASK;
61*4882a593Smuzhiyun pcm_val = -pcm_val;
62*4882a593Smuzhiyun }
63*4882a593Smuzhiyun
64*4882a593Smuzhiyun /* Convert the scaled magnitude to segment number. */
65*4882a593Smuzhiyun for (seg = 0; seg < 8; seg++) {
66*4882a593Smuzhiyun if (pcm_val <= seg_end[seg])
67*4882a593Smuzhiyun break;
68*4882a593Smuzhiyun }
69*4882a593Smuzhiyun /* Combine the sign, segment, and quantization bits. */
70*4882a593Smuzhiyun return ((seg << 4) |
71*4882a593Smuzhiyun ((pcm_val >> ((seg) ? (seg + 3) : 4)) & 0x0F)) ^ mask;
72*4882a593Smuzhiyun }
73*4882a593Smuzhiyun
74*4882a593Smuzhiyun
alaw2linear(unsigned char alaw)75*4882a593Smuzhiyun static inline short int alaw2linear(unsigned char alaw)
76*4882a593Smuzhiyun {
77*4882a593Smuzhiyun int i;
78*4882a593Smuzhiyun int seg;
79*4882a593Smuzhiyun
80*4882a593Smuzhiyun alaw ^= AMI_MASK;
81*4882a593Smuzhiyun i = ((alaw & 0x0F) << 4) + 8 /* rounding error */;
82*4882a593Smuzhiyun seg = (((int) alaw & 0x70) >> 4);
83*4882a593Smuzhiyun if (seg)
84*4882a593Smuzhiyun i = (i + 0x100) << (seg - 1);
85*4882a593Smuzhiyun return (short int) ((alaw & 0x80) ? i : -i);
86*4882a593Smuzhiyun }
87*4882a593Smuzhiyun
ulaw2linear(unsigned char ulaw)88*4882a593Smuzhiyun static inline short int ulaw2linear(unsigned char ulaw)
89*4882a593Smuzhiyun {
90*4882a593Smuzhiyun short mu, e, f, y;
91*4882a593Smuzhiyun static short etab[] = {0, 132, 396, 924, 1980, 4092, 8316, 16764};
92*4882a593Smuzhiyun
93*4882a593Smuzhiyun mu = 255 - ulaw;
94*4882a593Smuzhiyun e = (mu & 0x70) / 16;
95*4882a593Smuzhiyun f = mu & 0x0f;
96*4882a593Smuzhiyun y = f * (1 << (e + 3));
97*4882a593Smuzhiyun y += etab[e];
98*4882a593Smuzhiyun if (mu & 0x80)
99*4882a593Smuzhiyun y = -y;
100*4882a593Smuzhiyun return y;
101*4882a593Smuzhiyun }
102*4882a593Smuzhiyun
103*4882a593Smuzhiyun #define BIAS 0x84 /*!< define the add-in bias for 16 bit samples */
104*4882a593Smuzhiyun
linear2ulaw(short sample)105*4882a593Smuzhiyun static unsigned char linear2ulaw(short sample)
106*4882a593Smuzhiyun {
107*4882a593Smuzhiyun static int exp_lut[256] = {
108*4882a593Smuzhiyun 0, 0, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3,
109*4882a593Smuzhiyun 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
110*4882a593Smuzhiyun 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
111*4882a593Smuzhiyun 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
112*4882a593Smuzhiyun 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
113*4882a593Smuzhiyun 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
114*4882a593Smuzhiyun 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
115*4882a593Smuzhiyun 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
116*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
117*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
118*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
119*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
120*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
121*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
122*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
123*4882a593Smuzhiyun 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7};
124*4882a593Smuzhiyun int sign, exponent, mantissa;
125*4882a593Smuzhiyun unsigned char ulawbyte;
126*4882a593Smuzhiyun
127*4882a593Smuzhiyun /* Get the sample into sign-magnitude. */
128*4882a593Smuzhiyun sign = (sample >> 8) & 0x80; /* set aside the sign */
129*4882a593Smuzhiyun if (sign != 0)
130*4882a593Smuzhiyun sample = -sample; /* get magnitude */
131*4882a593Smuzhiyun
132*4882a593Smuzhiyun /* Convert from 16 bit linear to ulaw. */
133*4882a593Smuzhiyun sample = sample + BIAS;
134*4882a593Smuzhiyun exponent = exp_lut[(sample >> 7) & 0xFF];
135*4882a593Smuzhiyun mantissa = (sample >> (exponent + 3)) & 0x0F;
136*4882a593Smuzhiyun ulawbyte = ~(sign | (exponent << 4) | mantissa);
137*4882a593Smuzhiyun
138*4882a593Smuzhiyun return ulawbyte;
139*4882a593Smuzhiyun }
140*4882a593Smuzhiyun
dsp_audio_generate_law_tables(void)141*4882a593Smuzhiyun void dsp_audio_generate_law_tables(void)
142*4882a593Smuzhiyun {
143*4882a593Smuzhiyun int i;
144*4882a593Smuzhiyun for (i = 0; i < 256; i++)
145*4882a593Smuzhiyun dsp_audio_alaw_to_s32[i] = alaw2linear(bitrev8((u8)i));
146*4882a593Smuzhiyun
147*4882a593Smuzhiyun for (i = 0; i < 256; i++)
148*4882a593Smuzhiyun dsp_audio_ulaw_to_s32[i] = ulaw2linear(bitrev8((u8)i));
149*4882a593Smuzhiyun
150*4882a593Smuzhiyun for (i = 0; i < 256; i++) {
151*4882a593Smuzhiyun dsp_audio_alaw_to_ulaw[i] =
152*4882a593Smuzhiyun linear2ulaw(dsp_audio_alaw_to_s32[i]);
153*4882a593Smuzhiyun dsp_audio_ulaw_to_alaw[i] =
154*4882a593Smuzhiyun linear2alaw(dsp_audio_ulaw_to_s32[i]);
155*4882a593Smuzhiyun }
156*4882a593Smuzhiyun }
157*4882a593Smuzhiyun
158*4882a593Smuzhiyun void
dsp_audio_generate_s2law_table(void)159*4882a593Smuzhiyun dsp_audio_generate_s2law_table(void)
160*4882a593Smuzhiyun {
161*4882a593Smuzhiyun int i;
162*4882a593Smuzhiyun
163*4882a593Smuzhiyun if (dsp_options & DSP_OPT_ULAW) {
164*4882a593Smuzhiyun /* generating ulaw-table */
165*4882a593Smuzhiyun for (i = -32768; i < 32768; i++) {
166*4882a593Smuzhiyun dsp_audio_s16_to_law[i & 0xffff] =
167*4882a593Smuzhiyun bitrev8(linear2ulaw(i));
168*4882a593Smuzhiyun }
169*4882a593Smuzhiyun } else {
170*4882a593Smuzhiyun /* generating alaw-table */
171*4882a593Smuzhiyun for (i = -32768; i < 32768; i++) {
172*4882a593Smuzhiyun dsp_audio_s16_to_law[i & 0xffff] =
173*4882a593Smuzhiyun bitrev8(linear2alaw(i));
174*4882a593Smuzhiyun }
175*4882a593Smuzhiyun }
176*4882a593Smuzhiyun }
177*4882a593Smuzhiyun
178*4882a593Smuzhiyun
179*4882a593Smuzhiyun /*
180*4882a593Smuzhiyun * the seven bit sample is the number of every second alaw-sample ordered by
181*4882a593Smuzhiyun * aplitude. 0x00 is negative, 0x7f is positive amplitude.
182*4882a593Smuzhiyun */
183*4882a593Smuzhiyun u8 dsp_audio_seven2law[128];
184*4882a593Smuzhiyun u8 dsp_audio_law2seven[256];
185*4882a593Smuzhiyun
186*4882a593Smuzhiyun /********************************************************************
187*4882a593Smuzhiyun * generate table for conversion law from/to 7-bit alaw-like sample *
188*4882a593Smuzhiyun ********************************************************************/
189*4882a593Smuzhiyun
190*4882a593Smuzhiyun void
dsp_audio_generate_seven(void)191*4882a593Smuzhiyun dsp_audio_generate_seven(void)
192*4882a593Smuzhiyun {
193*4882a593Smuzhiyun int i, j, k;
194*4882a593Smuzhiyun u8 spl;
195*4882a593Smuzhiyun u8 sorted_alaw[256];
196*4882a593Smuzhiyun
197*4882a593Smuzhiyun /* generate alaw table, sorted by the linear value */
198*4882a593Smuzhiyun for (i = 0; i < 256; i++) {
199*4882a593Smuzhiyun j = 0;
200*4882a593Smuzhiyun for (k = 0; k < 256; k++) {
201*4882a593Smuzhiyun if (dsp_audio_alaw_to_s32[k]
202*4882a593Smuzhiyun < dsp_audio_alaw_to_s32[i])
203*4882a593Smuzhiyun j++;
204*4882a593Smuzhiyun }
205*4882a593Smuzhiyun sorted_alaw[j] = i;
206*4882a593Smuzhiyun }
207*4882a593Smuzhiyun
208*4882a593Smuzhiyun /* generate tabels */
209*4882a593Smuzhiyun for (i = 0; i < 256; i++) {
210*4882a593Smuzhiyun /* spl is the source: the law-sample (converted to alaw) */
211*4882a593Smuzhiyun spl = i;
212*4882a593Smuzhiyun if (dsp_options & DSP_OPT_ULAW)
213*4882a593Smuzhiyun spl = dsp_audio_ulaw_to_alaw[i];
214*4882a593Smuzhiyun /* find the 7-bit-sample */
215*4882a593Smuzhiyun for (j = 0; j < 256; j++) {
216*4882a593Smuzhiyun if (sorted_alaw[j] == spl)
217*4882a593Smuzhiyun break;
218*4882a593Smuzhiyun }
219*4882a593Smuzhiyun /* write 7-bit audio value */
220*4882a593Smuzhiyun dsp_audio_law2seven[i] = j >> 1;
221*4882a593Smuzhiyun }
222*4882a593Smuzhiyun for (i = 0; i < 128; i++) {
223*4882a593Smuzhiyun spl = sorted_alaw[i << 1];
224*4882a593Smuzhiyun if (dsp_options & DSP_OPT_ULAW)
225*4882a593Smuzhiyun spl = dsp_audio_alaw_to_ulaw[spl];
226*4882a593Smuzhiyun dsp_audio_seven2law[i] = spl;
227*4882a593Smuzhiyun }
228*4882a593Smuzhiyun }
229*4882a593Smuzhiyun
230*4882a593Smuzhiyun
231*4882a593Smuzhiyun /* mix 2*law -> law */
232*4882a593Smuzhiyun u8 dsp_audio_mix_law[65536];
233*4882a593Smuzhiyun
234*4882a593Smuzhiyun /******************************************************
235*4882a593Smuzhiyun * generate mix table to mix two law samples into one *
236*4882a593Smuzhiyun ******************************************************/
237*4882a593Smuzhiyun
238*4882a593Smuzhiyun void
dsp_audio_generate_mix_table(void)239*4882a593Smuzhiyun dsp_audio_generate_mix_table(void)
240*4882a593Smuzhiyun {
241*4882a593Smuzhiyun int i, j;
242*4882a593Smuzhiyun s32 sample;
243*4882a593Smuzhiyun
244*4882a593Smuzhiyun i = 0;
245*4882a593Smuzhiyun while (i < 256) {
246*4882a593Smuzhiyun j = 0;
247*4882a593Smuzhiyun while (j < 256) {
248*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i];
249*4882a593Smuzhiyun sample += dsp_audio_law_to_s32[j];
250*4882a593Smuzhiyun if (sample > 32767)
251*4882a593Smuzhiyun sample = 32767;
252*4882a593Smuzhiyun if (sample < -32768)
253*4882a593Smuzhiyun sample = -32768;
254*4882a593Smuzhiyun dsp_audio_mix_law[(i << 8) | j] =
255*4882a593Smuzhiyun dsp_audio_s16_to_law[sample & 0xffff];
256*4882a593Smuzhiyun j++;
257*4882a593Smuzhiyun }
258*4882a593Smuzhiyun i++;
259*4882a593Smuzhiyun }
260*4882a593Smuzhiyun }
261*4882a593Smuzhiyun
262*4882a593Smuzhiyun
263*4882a593Smuzhiyun /*************************************
264*4882a593Smuzhiyun * generate different volume changes *
265*4882a593Smuzhiyun *************************************/
266*4882a593Smuzhiyun
267*4882a593Smuzhiyun static u8 dsp_audio_reduce8[256];
268*4882a593Smuzhiyun static u8 dsp_audio_reduce7[256];
269*4882a593Smuzhiyun static u8 dsp_audio_reduce6[256];
270*4882a593Smuzhiyun static u8 dsp_audio_reduce5[256];
271*4882a593Smuzhiyun static u8 dsp_audio_reduce4[256];
272*4882a593Smuzhiyun static u8 dsp_audio_reduce3[256];
273*4882a593Smuzhiyun static u8 dsp_audio_reduce2[256];
274*4882a593Smuzhiyun static u8 dsp_audio_reduce1[256];
275*4882a593Smuzhiyun static u8 dsp_audio_increase1[256];
276*4882a593Smuzhiyun static u8 dsp_audio_increase2[256];
277*4882a593Smuzhiyun static u8 dsp_audio_increase3[256];
278*4882a593Smuzhiyun static u8 dsp_audio_increase4[256];
279*4882a593Smuzhiyun static u8 dsp_audio_increase5[256];
280*4882a593Smuzhiyun static u8 dsp_audio_increase6[256];
281*4882a593Smuzhiyun static u8 dsp_audio_increase7[256];
282*4882a593Smuzhiyun static u8 dsp_audio_increase8[256];
283*4882a593Smuzhiyun
284*4882a593Smuzhiyun static u8 *dsp_audio_volume_change[16] = {
285*4882a593Smuzhiyun dsp_audio_reduce8,
286*4882a593Smuzhiyun dsp_audio_reduce7,
287*4882a593Smuzhiyun dsp_audio_reduce6,
288*4882a593Smuzhiyun dsp_audio_reduce5,
289*4882a593Smuzhiyun dsp_audio_reduce4,
290*4882a593Smuzhiyun dsp_audio_reduce3,
291*4882a593Smuzhiyun dsp_audio_reduce2,
292*4882a593Smuzhiyun dsp_audio_reduce1,
293*4882a593Smuzhiyun dsp_audio_increase1,
294*4882a593Smuzhiyun dsp_audio_increase2,
295*4882a593Smuzhiyun dsp_audio_increase3,
296*4882a593Smuzhiyun dsp_audio_increase4,
297*4882a593Smuzhiyun dsp_audio_increase5,
298*4882a593Smuzhiyun dsp_audio_increase6,
299*4882a593Smuzhiyun dsp_audio_increase7,
300*4882a593Smuzhiyun dsp_audio_increase8,
301*4882a593Smuzhiyun };
302*4882a593Smuzhiyun
303*4882a593Smuzhiyun void
dsp_audio_generate_volume_changes(void)304*4882a593Smuzhiyun dsp_audio_generate_volume_changes(void)
305*4882a593Smuzhiyun {
306*4882a593Smuzhiyun register s32 sample;
307*4882a593Smuzhiyun int i;
308*4882a593Smuzhiyun int num[] = { 110, 125, 150, 175, 200, 300, 400, 500 };
309*4882a593Smuzhiyun int denum[] = { 100, 100, 100, 100, 100, 100, 100, 100 };
310*4882a593Smuzhiyun
311*4882a593Smuzhiyun i = 0;
312*4882a593Smuzhiyun while (i < 256) {
313*4882a593Smuzhiyun dsp_audio_reduce8[i] = dsp_audio_s16_to_law[
314*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[7] / num[7]) & 0xffff];
315*4882a593Smuzhiyun dsp_audio_reduce7[i] = dsp_audio_s16_to_law[
316*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[6] / num[6]) & 0xffff];
317*4882a593Smuzhiyun dsp_audio_reduce6[i] = dsp_audio_s16_to_law[
318*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[5] / num[5]) & 0xffff];
319*4882a593Smuzhiyun dsp_audio_reduce5[i] = dsp_audio_s16_to_law[
320*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[4] / num[4]) & 0xffff];
321*4882a593Smuzhiyun dsp_audio_reduce4[i] = dsp_audio_s16_to_law[
322*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[3] / num[3]) & 0xffff];
323*4882a593Smuzhiyun dsp_audio_reduce3[i] = dsp_audio_s16_to_law[
324*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[2] / num[2]) & 0xffff];
325*4882a593Smuzhiyun dsp_audio_reduce2[i] = dsp_audio_s16_to_law[
326*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[1] / num[1]) & 0xffff];
327*4882a593Smuzhiyun dsp_audio_reduce1[i] = dsp_audio_s16_to_law[
328*4882a593Smuzhiyun (dsp_audio_law_to_s32[i] * denum[0] / num[0]) & 0xffff];
329*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[0] / denum[0];
330*4882a593Smuzhiyun if (sample < -32768)
331*4882a593Smuzhiyun sample = -32768;
332*4882a593Smuzhiyun else if (sample > 32767)
333*4882a593Smuzhiyun sample = 32767;
334*4882a593Smuzhiyun dsp_audio_increase1[i] = dsp_audio_s16_to_law[sample & 0xffff];
335*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[1] / denum[1];
336*4882a593Smuzhiyun if (sample < -32768)
337*4882a593Smuzhiyun sample = -32768;
338*4882a593Smuzhiyun else if (sample > 32767)
339*4882a593Smuzhiyun sample = 32767;
340*4882a593Smuzhiyun dsp_audio_increase2[i] = dsp_audio_s16_to_law[sample & 0xffff];
341*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[2] / denum[2];
342*4882a593Smuzhiyun if (sample < -32768)
343*4882a593Smuzhiyun sample = -32768;
344*4882a593Smuzhiyun else if (sample > 32767)
345*4882a593Smuzhiyun sample = 32767;
346*4882a593Smuzhiyun dsp_audio_increase3[i] = dsp_audio_s16_to_law[sample & 0xffff];
347*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[3] / denum[3];
348*4882a593Smuzhiyun if (sample < -32768)
349*4882a593Smuzhiyun sample = -32768;
350*4882a593Smuzhiyun else if (sample > 32767)
351*4882a593Smuzhiyun sample = 32767;
352*4882a593Smuzhiyun dsp_audio_increase4[i] = dsp_audio_s16_to_law[sample & 0xffff];
353*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[4] / denum[4];
354*4882a593Smuzhiyun if (sample < -32768)
355*4882a593Smuzhiyun sample = -32768;
356*4882a593Smuzhiyun else if (sample > 32767)
357*4882a593Smuzhiyun sample = 32767;
358*4882a593Smuzhiyun dsp_audio_increase5[i] = dsp_audio_s16_to_law[sample & 0xffff];
359*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[5] / denum[5];
360*4882a593Smuzhiyun if (sample < -32768)
361*4882a593Smuzhiyun sample = -32768;
362*4882a593Smuzhiyun else if (sample > 32767)
363*4882a593Smuzhiyun sample = 32767;
364*4882a593Smuzhiyun dsp_audio_increase6[i] = dsp_audio_s16_to_law[sample & 0xffff];
365*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[6] / denum[6];
366*4882a593Smuzhiyun if (sample < -32768)
367*4882a593Smuzhiyun sample = -32768;
368*4882a593Smuzhiyun else if (sample > 32767)
369*4882a593Smuzhiyun sample = 32767;
370*4882a593Smuzhiyun dsp_audio_increase7[i] = dsp_audio_s16_to_law[sample & 0xffff];
371*4882a593Smuzhiyun sample = dsp_audio_law_to_s32[i] * num[7] / denum[7];
372*4882a593Smuzhiyun if (sample < -32768)
373*4882a593Smuzhiyun sample = -32768;
374*4882a593Smuzhiyun else if (sample > 32767)
375*4882a593Smuzhiyun sample = 32767;
376*4882a593Smuzhiyun dsp_audio_increase8[i] = dsp_audio_s16_to_law[sample & 0xffff];
377*4882a593Smuzhiyun
378*4882a593Smuzhiyun i++;
379*4882a593Smuzhiyun }
380*4882a593Smuzhiyun }
381*4882a593Smuzhiyun
382*4882a593Smuzhiyun
383*4882a593Smuzhiyun /**************************************
384*4882a593Smuzhiyun * change the volume of the given skb *
385*4882a593Smuzhiyun **************************************/
386*4882a593Smuzhiyun
387*4882a593Smuzhiyun /* this is a helper function for changing volume of skb. the range may be
388*4882a593Smuzhiyun * -8 to 8, which is a shift to the power of 2. 0 == no volume, 3 == volume*8
389*4882a593Smuzhiyun */
390*4882a593Smuzhiyun void
dsp_change_volume(struct sk_buff * skb,int volume)391*4882a593Smuzhiyun dsp_change_volume(struct sk_buff *skb, int volume)
392*4882a593Smuzhiyun {
393*4882a593Smuzhiyun u8 *volume_change;
394*4882a593Smuzhiyun int i, ii;
395*4882a593Smuzhiyun u8 *p;
396*4882a593Smuzhiyun int shift;
397*4882a593Smuzhiyun
398*4882a593Smuzhiyun if (volume == 0)
399*4882a593Smuzhiyun return;
400*4882a593Smuzhiyun
401*4882a593Smuzhiyun /* get correct conversion table */
402*4882a593Smuzhiyun if (volume < 0) {
403*4882a593Smuzhiyun shift = volume + 8;
404*4882a593Smuzhiyun if (shift < 0)
405*4882a593Smuzhiyun shift = 0;
406*4882a593Smuzhiyun } else {
407*4882a593Smuzhiyun shift = volume + 7;
408*4882a593Smuzhiyun if (shift > 15)
409*4882a593Smuzhiyun shift = 15;
410*4882a593Smuzhiyun }
411*4882a593Smuzhiyun volume_change = dsp_audio_volume_change[shift];
412*4882a593Smuzhiyun i = 0;
413*4882a593Smuzhiyun ii = skb->len;
414*4882a593Smuzhiyun p = skb->data;
415*4882a593Smuzhiyun /* change volume */
416*4882a593Smuzhiyun while (i < ii) {
417*4882a593Smuzhiyun *p = volume_change[*p];
418*4882a593Smuzhiyun p++;
419*4882a593Smuzhiyun i++;
420*4882a593Smuzhiyun }
421*4882a593Smuzhiyun }
422