xref: /OK3568_Linux_fs/kernel/drivers/isdn/mISDN/dsp_audio.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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