mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-12 15:45:18 +00:00
Zap optimization
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@665 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -935,33 +935,41 @@ int set_actual_gain(int fd, int chan, float rxgain, float txgain, int law)
|
||||
float lrxgain;
|
||||
int j,k;
|
||||
g.chan = chan;
|
||||
/* caluculate linear value of tx gain */
|
||||
ltxgain = pow(10.0,txgain / 20.0);
|
||||
/* caluculate linear value of rx gain */
|
||||
lrxgain = pow(10.0,rxgain / 20.0);
|
||||
if (law == ZT_LAW_ALAW) {
|
||||
for (j=0;j<256;j++) {
|
||||
k = (int)(((float)AST_ALAW(j)) * lrxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.rxgain[j] = AST_LIN2A(k);
|
||||
k = (int)(((float)AST_ALAW(j)) * ltxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.txgain[j] = AST_LIN2A(k);
|
||||
if ((rxgain != 0.0) || (txgain != 0.0)) {
|
||||
/* caluculate linear value of tx gain */
|
||||
ltxgain = pow(10.0,txgain / 20.0);
|
||||
/* caluculate linear value of rx gain */
|
||||
lrxgain = pow(10.0,rxgain / 20.0);
|
||||
if (law == ZT_LAW_ALAW) {
|
||||
for (j=0;j<256;j++) {
|
||||
k = (int)(((float)AST_ALAW(j)) * lrxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.rxgain[j] = AST_LIN2A(k);
|
||||
k = (int)(((float)AST_ALAW(j)) * ltxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.txgain[j] = AST_LIN2A(k);
|
||||
}
|
||||
} else {
|
||||
for (j=0;j<256;j++) {
|
||||
k = (int)(((float)AST_MULAW(j)) * lrxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.rxgain[j] = AST_LIN2MU(k);
|
||||
k = (int)(((float)AST_MULAW(j)) * ltxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.txgain[j] = AST_LIN2MU(k);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
for (j=0;j<256;j++) {
|
||||
k = (int)(((float)AST_MULAW(j)) * lrxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.rxgain[j] = AST_LIN2MU(k);
|
||||
k = (int)(((float)AST_MULAW(j)) * ltxgain);
|
||||
if (k > 32767) k = 32767;
|
||||
if (k < -32767) k = -32767;
|
||||
g.txgain[j] = AST_LIN2MU(k);
|
||||
g.rxgain[j] = j;
|
||||
g.txgain[j] = j;
|
||||
}
|
||||
}
|
||||
|
||||
/* set 'em */
|
||||
return(ioctl(fd,ZT_SETGAINS,&g));
|
||||
}
|
||||
|
Reference in New Issue
Block a user