<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>al_attach_mixer_to_voice failure</title>
		<link>http://www.allegro.cc/forums/view/618299</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Thu, 10 Dec 2020 10:20:54 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi,</p><p>I am doing some testing of my game and some players have problem with audio. I was able to discover that the problem is function <span class="source-code"><a href="http://www.allegro.cc/manual/al_attach_mixer_to_voice"><span class="a">al_attach_mixer_to_voice</span></a></span> which fails. But it only happen to only a small portion of testers.</p><p>I of course read the documentation but I am not exactly &quot;drivers guy&quot; so I do not know where the underlying problem could be and how to solve it. Do you have any idea? Thanks for the answers.</p><p>Code snipped of my audio initialization. It failed on line 33.</p><div class="source-code"><div class="toolbar"><span class="button numbers"><b>#</b></span><span class="button select">Select</span><span class="button expand">Expand</span></div><div class="inner"><span class="number">  1</span><span class="k1">bool</span> N_Audio_Player::init<span class="k2">(</span><span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  <span class="c">// Create voice.</span>
<span class="number">  4</span>  voice_ <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_voice"><span class="a">al_create_voice</span></a><span class="k2">(</span><span class="n">44100</span>, ALLEGRO_AUDIO_DEPTH_INT16, ALLEGRO_CHANNEL_CONF_2<span class="k2">)</span><span class="k2">;</span>
<span class="number">  5</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> voice_<span class="k2">)</span> <span class="k2">{</span>
<span class="number">  6</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot create voice."</span><span class="k2">;</span>
<span class="number">  7</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number">  8</span>  <span class="k2">}</span>
<span class="number">  9</span>
<span class="number"> 10</span>  <span class="c">// Create mixers.</span>
<span class="number"> 11</span>  mixer_master_ <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_mixer"><span class="a">al_create_mixer</span></a><span class="k2">(</span><span class="n">44100</span>, ALLEGRO_AUDIO_DEPTH_FLOAT32, ALLEGRO_CHANNEL_CONF_2<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> mixer_master_<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 13</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot create master mixer."</span><span class="k2">;</span>
<span class="number"> 14</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 15</span>  <span class="k2">}</span>
<span class="number"> 16</span>  mixer_music_ <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_mixer"><span class="a">al_create_mixer</span></a><span class="k2">(</span><span class="n">44100</span>, ALLEGRO_AUDIO_DEPTH_FLOAT32, ALLEGRO_CHANNEL_CONF_2<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> mixer_music_<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 18</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot create music mixer."</span><span class="k2">;</span>
<span class="number"> 19</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 20</span>  <span class="k2">}</span>
<span class="number"> 21</span>  mixer_sounds_ <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_mixer"><span class="a">al_create_mixer</span></a><span class="k2">(</span><span class="n">44100</span>, ALLEGRO_AUDIO_DEPTH_FLOAT32, ALLEGRO_CHANNEL_CONF_2<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> mixer_sounds_<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 23</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot create sounds mixer."</span><span class="k2">;</span>
<span class="number"> 24</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 25</span>  <span class="k2">}</span>
<span class="number"> 26</span>  mixer_ambient_ <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_mixer"><span class="a">al_create_mixer</span></a><span class="k2">(</span><span class="n">44100</span>, ALLEGRO_AUDIO_DEPTH_FLOAT32, ALLEGRO_CHANNEL_CONF_2<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 27</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> mixer_ambient_<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 28</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot create ambient mixer."</span><span class="k2">;</span>
<span class="number"> 29</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 30</span>  <span class="k2">}</span>
<span class="number"> 31</span>
<span class="number"> 32</span>  <span class="c">// Attache mixers.</span>
<span class="number"> 33</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> <a href="http://www.allegro.cc/manual/al_attach_mixer_to_voice"><span class="a">al_attach_mixer_to_voice</span></a><span class="k2">(</span>mixer_master_, voice_<span class="k2">)</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 34</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot attach master mixer."</span><span class="k2">;</span>
<span class="number"> 35</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 36</span>  <span class="k2">}</span>
<span class="number"> 37</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> <a href="http://www.allegro.cc/manual/al_attach_mixer_to_mixer"><span class="a">al_attach_mixer_to_mixer</span></a><span class="k2">(</span>mixer_music_, mixer_master_<span class="k2">)</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 38</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot attach music mixer."</span><span class="k2">;</span>
<span class="number"> 39</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 40</span>  <span class="k2">}</span>
<span class="number"> 41</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> <a href="http://www.allegro.cc/manual/al_attach_mixer_to_mixer"><span class="a">al_attach_mixer_to_mixer</span></a><span class="k2">(</span>mixer_sounds_, mixer_master_<span class="k2">)</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 42</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot attach sounds mixer."</span><span class="k2">;</span>
<span class="number"> 43</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 44</span>  <span class="k2">}</span>
<span class="number"> 45</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> <a href="http://www.allegro.cc/manual/al_attach_mixer_to_mixer"><span class="a">al_attach_mixer_to_mixer</span></a><span class="k2">(</span>mixer_ambient_, mixer_master_<span class="k2">)</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 46</span>    n_error<span class="k2">(</span><span class="k2">)</span> <span class="k3">&lt;</span><span class="k3">&lt;</span> <span class="s">"[N_Audio_Player::init] Cannot attach ambient mixer."</span><span class="k2">;</span>
<span class="number"> 47</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 48</span>  <span class="k2">}</span>
<span class="number"> 49</span>
<span class="number"> 50</span>  <span class="c">// Create sample instances.</span>
<span class="number"> 51</span>  <span class="k1">for</span> <span class="k2">(</span><span class="k1">int</span> i <span class="k3">=</span> <span class="n">0</span><span class="k2">;</span> i <span class="k3">&lt;</span> <span class="n">16</span><span class="k2">;</span> <span class="k3">+</span><span class="k3">+</span>i<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 52</span>    <a href="http://www.allegro.cc/manual/ALLEGRO_SAMPLE_INSTANCE"><span class="a">ALLEGRO_SAMPLE_INSTANCE</span></a> <span class="k3">*</span><span class="k1">const</span> instance <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_sample_instance"><span class="a">al_create_sample_instance</span></a><span class="k2">(</span>nullptr<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 53</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span> instance<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 54</span>      <span class="k1">break</span><span class="k2">;</span>
<span class="number"> 55</span>    <span class="k2">}</span>
<span class="number"> 56</span>
<span class="number"> 57</span>    instances_.push_back<span class="k2">(</span>instance<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 58</span>    instances_frames_.push_back<span class="k2">(</span>std::make_pair<span class="k2">(</span>nil<span class="k2">(</span><span class="k2">)</span>, nullptr<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 59</span>  <span class="k2">}</span>
<span class="number"> 60</span>
<span class="number"> 61</span>  <span class="c">// Set gains.</span>
<span class="number"> 62</span>  update_mixers_gain<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 63</span>  <span class="k1">return</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 64</span><span class="k2">}</span>
</div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (archlinka)</author>
		<pubDate>Tue, 08 Dec 2020 02:25:44 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>First of all, what OS are you using, and what version of Allegro, and also the compiler version used to produce it.</p><p>The call to start_voice may be failing for some.</p><p><a href="https://github.com/liballeg/allegro5/blob/master/addons/audio/kcm_voice.c#L298">https://github.com/liballeg/allegro5/blob/master/addons/audio/kcm_voice.c#L298</a></p><p>It depends on the audio driver in use.</p><p>Can you do some debugging? Are you proficient with gdb or another debugger?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 08 Dec 2020 02:38:31 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi, I can debug. Problem is that on all of my PCs it&#39;s working fine. But some others have problems.</p><p>The user who has this problem uses Windows 10. I am using msvc (don&#39;t know version because I am not at work) and Allegro version is 5.2.6 from NuGet package.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (archlinka)</author>
		<pubDate>Tue, 08 Dec 2020 02:49:07 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>You&#39;ll probably need your players to debug for you, with MSVS or gdb.</p><p>I don&#39;t know much about the audio drivers, maybe @Peter Hull could help?</p><p><b>EDIT</b><br />It can also fail if already attached to a stream.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Thu, 10 Dec 2020 10:20:54 +0000</pubDate>
	</item>
</rss>
