summaryrefslogblamecommitdiff
path: root/audio/wmix/files/patch-ab
blob: 53619fa0a532ee88cfb59bee37666b6c574db056 (plain) (tree)
1
2
3
4
5
6
7
8
9

                                        

               
              


                     
              



















                                                                                                                                                               
                




























                                                                                                                                                           
                

















                                                                 
                



























                                                                        
                



























                                                                        
                  








                                                 
*** mix.c.orig	Fri Apr 20 11:52:28 2001
--- mix.c	Sun Jul 22 12:19:34 2001
***************
*** 20,26 ****
--- 20,28 ----
  #include <stdlib.h>
  #include <string.h>
  #include <ctype.h>
+ #ifdef linux
  #include <getopt.h>
+ #endif
  #include <time.h>
  #include <unistd.h>
  #include <fcntl.h>
***************
*** 887,899 ****
  #ifdef CUSTOM
  #undef SOUND_DEVICE_NAMES
  
! #define SOUND_DEVICE_NAMES	{"Master Volume", "Bass", "Treble", "FM Synth Volume", "PCM - Wave Volume", "PC Speaker", "Line In Level", \
! 				 "Microphone Level", "CD Input Volume", "Mixer Level", "PCM2 - Wave Volume", "Recording Volume", "Input Gain", "Output Gain", \
! 				 "Line1 Input", "Line2 Input", "Line3 Input", "Digital 1", "Digital 2", "Digital 3", \
! 				 "Phone Input", "Phone Output", "Video Card Volume", "Radio Card volume", "Monitor Volume"}
  #endif
      char *names[] = SOUND_DEVICE_NAMES;
      struct mixer_info mixer_info;
  
      if ((mixer_fd = open(value("mixerdev"), O_RDWR)) == -1) {
  	printf("error: cannot open mixer device %s\n", value("mixerdev"));
--- 889,903 ----
  #ifdef CUSTOM
  #undef SOUND_DEVICE_NAMES
  
! #define SOUND_DEVICE_NAMES	{" Master Volume", " Bass", " Treble", " Synth Volume", " Wave Volume", " PC Speaker", " Line In Level", \
! 				 " Microphone Level", " CD Volume", " Mixer Level", " Wave 2 Volume", " Recording Volume", " Input Gain", " Output Gain", \
! 				 " Line1 Input", " Line2 Input", " Line3 Input", " Digital 1", " Digital 2", " Digital 3", \
! 				 " Phone Input", " Phone Output", " Video Card Volume", " Radio Card Volume", " Monitor Volume"}
  #endif
      char *names[] = SOUND_DEVICE_NAMES;
+ #ifndef __FreeBSD__
      struct mixer_info mixer_info;
+ #endif
  
      if ((mixer_fd = open(value("mixerdev"), O_RDWR)) == -1) {
  	printf("error: cannot open mixer device %s\n", value("mixerdev"));
***************
*** 921,932 ****
  	exit(1);
      }
  
      if (ioctl(mixer_fd, SOUND_MIXER_INFO, &mixer_info) == -1) {
  	printf("error: cannot get mixer info off mixer\n");
  	exit(1);
      }
- 
      printf("%s (%s) [", mixer_info.name, mixer_info.id);
      for (count = 0; count < SOUND_MIXER_NRDEVICES; count++) {
  	if ((1 << count) & devmask) {
  	    strcpy(mixer[nchannels].name, names[count]);
--- 925,940 ----
  	exit(1);
      }
  
+ #ifdef __FreeBSD__
+     printf("[");
+ #else
      if (ioctl(mixer_fd, SOUND_MIXER_INFO, &mixer_info) == -1) {
  	printf("error: cannot get mixer info off mixer\n");
  	exit(1);
      }
      printf("%s (%s) [", mixer_info.name, mixer_info.id);
+ #endif
+ 
      for (count = 0; count < SOUND_MIXER_NRDEVICES; count++) {
  	if ((1 << count) & devmask) {
  	    strcpy(mixer[nchannels].name, names[count]);
***************
*** 946,951 ****
--- 954,960 ----
  	    printf("0");
  	}
      }
+ 
      printf("]\n");
  }
  
***************
*** 953,971 ****
  {
      int i;
      int left, right, foo;
      int retry = 3;
      int stat = 1;
      struct mixer_info mixer_info;
      static int modify_counter;
-     static Mixer old_mix[SOUND_MIXER_NRDEVICES];
  
      /* check for possible failure here - happens with older kernels */
      if (ioctl(mixer_fd, SOUND_MIXER_INFO, &mixer_info)) {
  	while (retry-- && stat)
  	    stat = ioctl(mixer_fd, SOUND_MIXER_INFO, &mixer_info);
      }
  
!     if (mixer_info.modify_counter != modify_counter) {
  	i = 0;
  	/* this happens if mixer was changed by another program,
  	 * so we need to update the values.  We do not know, under OSS,
--- 962,987 ----
  {
      int i;
      int left, right, foo;
+     char doupdate = 0;
+     static Mixer old_mix[SOUND_MIXER_NRDEVICES];
+ #ifndef __FreeBSD__
      int retry = 3;
      int stat = 1;
      struct mixer_info mixer_info;
      static int modify_counter;
  
      /* check for possible failure here - happens with older kernels */
      if (ioctl(mixer_fd, SOUND_MIXER_INFO, &mixer_info)) {
  	while (retry-- && stat)
  	    stat = ioctl(mixer_fd, SOUND_MIXER_INFO, &mixer_info);
      }
+     doupdate = mixer_info.modify_counter != modify_counter;
+ #else
+     /* clearly something better would be nice, but hey, it works! */
+     doupdate = 1;
+ #endif
  
!     if (doupdate) {
  	i = 0;
  	/* this happens if mixer was changed by another program,
  	 * so we need to update the values.  We do not know, under OSS,
***************
*** 1022,1028 ****
--- 1038,1046 ----
  	    }
  	}
      }
+ #ifndef __FreeBSD__
      modify_counter = mixer_info.modify_counter;
+ #endif
      memcpy(old_mix, mixer, sizeof(mixer));
  }