<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Calling al_install_audio from a DLL?</title>
		<link>http://www.allegro.cc/forums/view/617811</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Tue, 16 Apr 2019 08:57:32 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>My engine will init allegro inside the DLL on startup and will shut it down before it terminates. When al_install_audio is called, it will hang 100 percent of the time. Why? I worked around the issue by making sure audio init/shutdown is done from the calling process (the EXE). Just wondering what is the problem as all the other init routines work without any apparent issues.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Mon, 15 Apr 2019 01:44:22 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I initialise allegro sound from within a dll as well but it works for me.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Mon, 15 Apr 2019 05:56:20 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/617811/1042009#target">Edgar Reynaldo</a> said:</div><div class="quote"><p> I initialise allegro sound from within a dll as well but it works for me.
</p></div></div><p>Interesting. I&#39;ve had this problem since I&#39;ve first started using Allegro with Delphi. It&#39;s been on my list of things to investigate so I figure I would see if I can get to the bottom of it. I will keep digging.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Mon, 15 Apr 2019 06:44:31 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Are you using global init or do you call an install function?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Mon, 15 Apr 2019 07:07:46 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><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>procedure TEngine.InitAllegro<span class="k2">;</span>
<span class="number">  2</span>begin
<span class="number">  3</span>  FAudioInstalled <span class="k2">:</span><span class="k3">=</span> False<span class="k2">;</span>
<span class="number">  4</span>  FMouseInstalled <span class="k2">:</span><span class="k3">=</span> False<span class="k2">;</span>
<span class="number">  5</span>  FCodecInstalled <span class="k2">:</span><span class="k3">=</span> False<span class="k2">;</span>
<span class="number">  6</span>  FKeyboardInstalled <span class="k2">:</span><span class="k3">=</span> False<span class="k2">;</span>
<span class="number">  7</span>
<span class="number">  8</span>  <span class="c">// init allegro</span>
<span class="number">  9</span>  <a href="http://www.allegro.cc/manual/al_install_system"><span class="a">al_install_system</span></a> <span class="k2">(</span>ALLEGRO_VERSION_INT, nil<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 10</span>
<span class="number"> 11</span>  <span class="c">// init addons</span>
<span class="number"> 12</span>  al_init_video_addon<span class="k2">;</span>
<span class="number"> 13</span>  <a href="http://www.allegro.cc/manual/al_init_font_addon"><span class="a">al_init_font_addon</span></a><span class="k2">;</span>
<span class="number"> 14</span>  <a href="http://www.allegro.cc/manual/al_init_ttf_addon"><span class="a">al_init_ttf_addon</span></a><span class="k2">;</span>
<span class="number"> 15</span>  <a href="http://www.allegro.cc/manual/al_init_primitives_addon"><span class="a">al_init_primitives_addon</span></a><span class="k2">;</span>
<span class="number"> 16</span>  al_init_native_dialog_addon<span class="k2">;</span>
<span class="number"> 17</span>  <a href="http://www.allegro.cc/manual/al_init_image_addon"><span class="a">al_init_image_addon</span></a><span class="k2">;</span>
<span class="number"> 18</span>
<span class="number"> 19</span>  <span class="c">// install devices</span>
<span class="number"> 20</span>  FKeyboardInstalled <span class="k2">:</span><span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_install_keyboard"><span class="a">al_install_keyboard</span></a><span class="k2">;</span>
<span class="number"> 21</span>  FMouseInstalled <span class="k2">:</span><span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_install_mouse"><span class="a">al_install_mouse</span></a><span class="k2">;</span>
<span class="number"> 22</span>
<span class="number"> 23</span>  <span class="c">// will hang here if called inside dll, but if called from the EXE, works fine.</span>
<span class="number"> 24</span>  FAudioInstalled <span class="k2">:</span><span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_install_audio"><span class="a">al_install_audio</span></a><span class="k2">;</span> <span class="c">//&lt;--- hang</span>
<span class="number"> 25</span>  FCodecInstalled <span class="k2">:</span><span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_init_acodec_addon"><span class="a">al_init_acodec_addon</span></a><span class="k2">;</span>
<span class="number"> 26</span>
<span class="number"> 27</span>  <span class="c">// init audio</span>
<span class="number"> 28</span>  FVoice <span class="k2">:</span><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"> 29</span>  FMixer <span class="k2">:</span><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"> 30</span>  <a href="http://www.allegro.cc/manual/al_set_default_mixer"><span class="a">al_set_default_mixer</span></a><span class="k2">(</span>FMixer<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 31</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>FMixer, FVoice<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 32</span>  <a href="http://www.allegro.cc/manual/al_reserve_samples"><span class="a">al_reserve_samples</span></a><span class="k2">(</span>ALLEGRO_MAX_CHANNELS<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 33</span>
<span class="number"> 34</span>  <span class="c">// init event queues</span>
<span class="number"> 35</span>  FQueue <span class="k2">:</span><span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_event_queue"><span class="a">al_create_event_queue</span></a><span class="k2">;</span>
<span class="number"> 36</span>  <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>FQueue, <a href="http://www.allegro.cc/manual/al_get_keyboard_event_source"><span class="a">al_get_keyboard_event_source</span></a><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 37</span>  <a href="http://www.allegro.cc/manual/al_register_event_source"><span class="a">al_register_event_source</span></a><span class="k2">(</span>FQueue, <a href="http://www.allegro.cc/manual/al_get_mouse_event_source"><span class="a">al_get_mouse_event_source</span></a><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 38</span>
<span class="number"> 39</span>  InitCommonColors<span class="k2">;</span>
<span class="number"> 40</span>end<span class="k2">;</span>
<span class="number"> 41</span>
<span class="number"> 42</span>constructor TEngine.Create<span class="k2">;</span>
<span class="number"> 43</span>begin
<span class="number"> 44</span>  InitAllegro
<span class="number"> 45</span>  ...
<span class="number"> 46</span>end<span class="k2">;</span>
<span class="number"> 47</span>
<span class="number"> 48</span>destructor TEngine.Destroy<span class="k2">;</span>
<span class="number"> 49</span>begin
<span class="number"> 50</span>  ...
<span class="number"> 51</span>  ShutdownAllegro<span class="k2">;</span>
<span class="number"> 52</span>end<span class="k2">;</span>
</div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Mon, 15 Apr 2019 10:07:21 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>This is stupid but try initializing audio before installing the keyboard and mouse.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Mon, 15 Apr 2019 14:24:01 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/617811/1042016#target">Edgar Reynaldo</a> said:</div><div class="quote"><p> This is stupid but try initializing audio before installing the keyboard and mouse.
</p></div></div><p>no, a good idea actually but sadly the same result
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Tue, 16 Apr 2019 01:09:26 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Can you debug this? Step into al_install_audio, and see where it hangs.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 16 Apr 2019 01:10:28 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/617811/1042021#target">Edgar Reynaldo</a> said:</div><div class="quote"><p> Can you debug this? Step into al_install_audio, and see where it hangs.
</p></div></div><p>Wish I could. Rem I&#39;m using Delphi (Object Pascal). I can step up to the function call is all.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Tue, 16 Apr 2019 01:31:19 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>How did you build / link to allegro?</p><p>What libraries did you use and where did you get them?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 16 Apr 2019 01:37:49 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>You have to convert .h headers to Delphi (object pascal), and just ref as external routines.</p><p>void my_cfunction(void);</p><p>procedure my_cfunction; cdecl; external &#39;allegro5.dll&#39;;</p><p>compile this and you can directly call my_cfunction in Pascal.</p><p>The binaries from <a href="https://github.com/liballeg/allegro5/releases">https://github.com/liballeg/allegro5/releases</a>, 32bit monolithic version
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Tue, 16 Apr 2019 01:51:24 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Does allegro.log get created?</p><p>You can enable it in release mode by doing...</p><div class="source-code snippet"><div class="inner"><pre><a href="http://www.allegro.cc/manual/al_set_config_value"><span class="a">al_set_config_value</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_get_system_config"><span class="a">al_get_system_config</span></a><span class="k2">(</span><span class="k2">)</span>, <span class="s">"trace"</span>, <span class="s">"level"</span>, <span class="s">"debug"</span><span class="k2">)</span>
</pre></div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 16 Apr 2019 02:26:45 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>ok, good call. Log attached. Thx. </p><p>stops at this line:</p><p>audio-dsound I dsound.cpp:271  _dsound_open [   2.27177] Starting DirectSound...</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="c">/* FIXME: Use default device until we have device enumeration */</span>
<span class="number"> 2</span>   hr <span class="k3">=</span> DirectSoundCreate8<span class="k2">(</span>NULL, <span class="k3">&amp;</span>device, NULL<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 3</span>   <span class="k1">if</span> <span class="k2">(</span>FAILED<span class="k2">(</span>hr<span class="k2">)</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 4</span>      ALLEGRO_ERROR<span class="k2">(</span><span class="s">"DirectSoundCreate8 failed: %s\n"</span>, ds_get_error<span class="k2">(</span>hr<span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 5</span>      <span class="k1">return</span> <span class="n">1</span><span class="k2">;</span>
<span class="number"> 6</span>   <span class="k2">}</span>
</div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Tue, 16 Apr 2019 02:40:28 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Clues :</p><p><a href="https://www.gamedev.net/forums/topic/164218-directsoundcreate8-will-not-return/">https://www.gamedev.net/forums/topic/164218-directsoundcreate8-will-not-return/</a>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 16 Apr 2019 02:55:33 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Ok, useful info there. Thx for that.</p><p>In Delphi, it has the concept of a unit and can have an init/final section:</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>unit uEngine<span class="k2">;</span>
<span class="number">  2</span>
<span class="number">  3</span>interface
<span class="number">  4</span>
<span class="number">  5</span>implementation
<span class="number">  6</span>
<span class="number">  7</span>initialization
<span class="number">  8</span>  Engine_Init<span class="k2">;</span>
<span class="number">  9</span>
<span class="number"> 10</span>finalization
<span class="number"> 11</span>  Engine_Shutdown<span class="k2">;</span>
<span class="number"> 12</span>
<span class="number"> 13</span>end.
</div></div><p>

There is where I usually init and shut down the engine when the DLL  loads into the calling process. What I will do to see if it makes a diff is call from DLL_PROCESS_ATTACH/DLL_PROCESS_DETACH.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Tue, 16 Apr 2019 03:10:02 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Bump for news of progress
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 16 Apr 2019 04:11:29 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>nope, still hangs and there are other issues with the dllmain approach. I discovered that delphi unit init/final methods is safer, the RTL will call in the proper order and they only run once so Engine_Init/Shutdown only runs once. Will keep digging. Thanks for your help bro.</p><p>Hmm... what is the difference between calling DirectSoundCreate8(NULL, &amp;device, NULL) inside DLL vs outside I wonder?</p><p><b>Edit 1:</b> <br />I found this - <a href="http://forums.codeguru.com/showthread.php?407844-DirectSoundCreate8-wont-initialize-in-DLL">http://forums.codeguru.com/showthread.php?407844-DirectSoundCreate8-wont-initialize-in-DLL</a></p><p>He suggests calling from main EXE which is the only way I got it to work.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (codetricity)</author>
		<pubDate>Tue, 16 Apr 2019 05:39:54 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Right, I don&#39;t Engine::Init in dllmain but in EagleSystem::Initialize which the user calls from main. At least that&#39;s what I see being described here.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 16 Apr 2019 08:57:32 +0000</pubDate>
	</item>
</rss>
