Mercurial > mplayer.hg
view mixer.c @ 988:c6f88600d409
Enable to avoid checking version of gcc. New tests of as
author | nickols_k |
---|---|
date | Mon, 04 Jun 2001 09:38:18 +0000 |
parents | abd7391a31e3 |
children | 72cacd3b8f30 |
line wrap: on
line source
#include <string.h> #include <sys/ioctl.h> #include <sys/soundcard.h> #include <fcntl.h> #include <stdio.h> #include <unistd.h> #include "mixer.h" char * mixer_device="/dev/mixer"; int mixer_usemaster=0; void mixer_getvolume( int *l,int *r ) { int fd,v,cmd,devs; fd=open( mixer_device,O_RDONLY ); if ( fd != -1 ) { ioctl( fd,SOUND_MIXER_READ_DEVMASK,&devs ); if ( ( devs & SOUND_MASK_PCM ) && ( mixer_usemaster==0 ) ) cmd=SOUND_MIXER_READ_PCM; else if ( ( devs & SOUND_MASK_VOLUME ) && ( mixer_usemaster==1 ) ) cmd=SOUND_MIXER_READ_VOLUME; else { close( fd ); return; } ioctl( fd,cmd,&v ); *r=( v & 0xFF00 ) >> 8; *l=( v & 0x00FF ); close( fd ); } } void mixer_setvolume( int l,int r ) { int fd,v,cmd,devs; fd=open( mixer_device,O_RDONLY ); if ( fd != -1 ) { ioctl( fd,SOUND_MIXER_READ_DEVMASK,&devs ); if ( ( devs & SOUND_MASK_PCM ) && ( mixer_usemaster==0 ) ) cmd=SOUND_MIXER_WRITE_PCM; else if ( ( devs & SOUND_MASK_VOLUME ) && ( mixer_usemaster==1 ) ) cmd=SOUND_MIXER_WRITE_VOLUME; else { close( fd ); return; } v=( r << 8 ) | l; ioctl( fd,cmd,&v ); close( fd ); } } int mixer_l=0; int mixer_r=0; void mixer_incvolume( void ) { mixer_getvolume( &mixer_l,&mixer_r ); if ( mixer_l < 100 ) mixer_l++; if ( mixer_r < 100 ) mixer_r++; mixer_setvolume( mixer_l,mixer_r ); } void mixer_decvolume( void ) { mixer_getvolume( &mixer_l,&mixer_r ); if ( mixer_l > 0 ) mixer_l--; if ( mixer_r > 0 ) mixer_r--; mixer_setvolume( mixer_l,mixer_r ); } int mixer_getbothvolume( void ) { mixer_getvolume( &mixer_l,&mixer_r ); return ( mixer_l + mixer_r ) / 2; }