1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
/* Extrastereo effect plugin
* (linearly increases difference between L&R channels)
*
* Current limitations:
* - only AFMT_S16_LE is supported currently
*
* License: GPLv2 (as a mix of pl_volume.c and
* xmms:stereo_plugin/stereo.c)
*
* Author: pl <p_l@gmx.fr> (c) 2002 and beyond...
* */
#define PLUGIN
#include <stdio.h>
#include <stdlib.h>
#include <inttypes.h>
#include "audio_out.h"
#include "audio_plugin.h"
#include "audio_plugin_internal.h"
#include "afmt.h"
static ao_info_t info = {
"Extra stereo plugin",
"extrastereo",
"pl <p_l@gmx.fr>",
""
};
LIBAO_PLUGIN_EXTERN(extrastereo)
// local data
static struct {
float mul; // intensity
int inuse; // This plugin is in use TRUE, FALSE
int format; // sample format
} pl_extrastereo = {2.5, 0, 0};
// to set/get/query special features/parameters
static int control(int cmd,int arg){
switch(cmd){
case AOCONTROL_PLUGIN_SET_LEN:
return CONTROL_OK;
}
return CONTROL_UNKNOWN;
}
// open & setup audio device
// return: 1=success 0=fail
static int init(){
switch(ao_plugin_data.format){
case(AFMT_S16_LE):
break;
default:
fprintf(stderr,"[pl_extrastereo] Audio format not yet suported \n");
return 0;
}
pl_extrastereo.mul=ao_plugin_cfg.pl_extrastereo_mul;
pl_extrastereo.format=ao_plugin_data.format;
pl_extrastereo.inuse=1;
printf("[pl_extrastereo] Extra stereo plugin in use (multiplier=%2.2f).\n",
pl_extrastereo.mul);
return 1;
}
// close plugin
static void uninit(){
pl_extrastereo.inuse=0;
}
// empty buffers
static void reset(){
}
// processes 'ao_plugin_data.len' bytes of 'data'
// called for every block of data
static int play(){
switch(pl_extrastereo.format){
case(AFMT_S16_LE): {
int16_t* data=(int16_t*)ao_plugin_data.data;
int len=ao_plugin_data.len / 2; // 16 bits samples
float mul = pl_extrastereo.mul;
int32_t i, avg, ltmp, rtmp;
for (i=0; i < len ; i += 2) {
avg = (data[i] + data[i + 1]) / 2;
ltmp = avg + (int) (mul * (data[i] - avg));
rtmp = avg + (int) (mul * (data[i + 1] - avg));
if (ltmp < -32768) {
ltmp = -32768;
} else if (ltmp > 32767) {
ltmp = 32767;
}
if (rtmp < -32768) {
rtmp = -32768;
} else if (rtmp > 32767) {
rtmp = 32767;
}
data[i] = ltmp;
data[i + 1] = rtmp;
}
break;
}
default:
return 0;
}
return 1;
}
|