[ Thread Index | 
Date Index
| More lists.liballeg.org/allegro-developers Archives
] 
- To: alleg-developers@xxxxxxxxxx
- Subject: [AD] Mixer patch
- From: Chris <chris.kcat@xxxxxxxxxx>
- Date: Tue, 18 Apr 2006 03:50:50 -0700
- Domainkey-signature: a=rsa-sha1; q=dns; c=nofws;        s=beta; d=gmail.com;        h=received:from:to:subject:date:user-agent:mime-version:content-type:message-id;        b=cN6LvMb5TCIDOwbRoHcxQGry/d8u/KZkvmzD1DOPjvK/HQWp4qNiVH35VNvTc4UTHzLw8mPb+dKFF7/kOzF2bVza7B1A/Haob9fSRWkcBd9fViMUAHqpAJWFcaKe/XD6ECu4GZmQxljvgjeBdTNhamzSjhhZMA841vub8J3J1z0=
Seems I completely forgot about this. There was a report on a.cc a while ago 
that said that the mixer would crash if you switched to quality 0 after it 
was initialized, due to the volume table not being allocated. It was also 
suggested (by Peter Wang, IIRC) to use a static allocated table instead of 
dynamic. This patch does just that.
Index: src/mixer.c
===================================================================
--- src/mixer.c	(revision 5716)
+++ src/mixer.c	(working copy)
@@ -72,7 +72,7 @@
 /* lookup table for converting sample volumes */
 #define MIX_VOLUME_LEVELS     32
 typedef signed int MIXER_VOL_TABLE[256];
-static MIXER_VOL_TABLE *mix_vol_table = NULL;
+static MIXER_VOL_TABLE mix_vol_table[MIX_VOLUME_LEVELS];
 
 /* stats for the mixing code */
 static int mix_voices;
@@ -290,40 +290,16 @@
 
    LOCK_DATA(mix_buffer, mix_size*mix_channels * sizeof(*mix_buffer));
 
-   /* 16 bit output isn't required for the high quality mixers */
-   if ((!_sound_hq) || (mix_channels == 1)) {
-      /* no high quality mixer available */
-      _sound_hq = 0;
+   for (j=0; j<MIX_VOLUME_LEVELS; j++)
+      for (i=0; i<256; i++)
+	 mix_vol_table[j][i] = ((i-128) * 256 * j / MIX_VOLUME_LEVELS) << 8;
 
-      /* volume table for mixing samples into the temporary buffer */
-      mix_vol_table = _AL_MALLOC_ATOMIC(sizeof(MIXER_VOL_TABLE) * MIX_VOLUME_LEVELS);
-      if (!mix_vol_table) {
-         _AL_FREE(mix_buffer);
-         mix_buffer = NULL;
-         mix_size = 0;
-         mix_freq = 0;
-         mix_channels = 0;
-         mix_bits = 0;
-         return -1;
-      }
-
-      LOCK_DATA(mix_vol_table, sizeof(MIXER_VOL_TABLE) * MIX_VOLUME_LEVELS);
-
-      for (j=0; j<MIX_VOLUME_LEVELS; j++)
-         for (i=0; i<256; i++)
-            mix_vol_table[j][i] = ((i-128) * 256 * j / MIX_VOLUME_LEVELS) << 8;
-   }
-   /* We no longer need to use prebuilt stuff for the high quality mixers */
-
    mixer_lock_mem();
 
 #ifdef ALLEGRO_MULTITHREADED
    /* Woops. Forgot to clean up incase this fails. :) */
    mixer_mutex = system_driver->create_mutex();
    if (!mixer_mutex) {
-      if(mix_vol_table)
-         _AL_FREE(mix_vol_table);
-      mix_vol_table = NULL;
       _AL_FREE(mix_buffer);
       mix_buffer = NULL;
       mix_size = 0;
@@ -353,10 +329,6 @@
       _AL_FREE(mix_buffer);
    mix_buffer = NULL;
 
-   if (mix_vol_table)
-      _AL_FREE(mix_vol_table);
-   mix_vol_table = NULL;
-
    mix_size = 0;
    mix_freq = 0;
    mix_channels = 0;