<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>al_uninstall_system excutes a function called &quot;shutdown&quot; if present</title>
		<link>http://www.allegro.cc/forums/view/617518</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Sat, 28 Jul 2018 01:22:59 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I was experiencing some random crashes when uninstalling Allegro.</p><p>I found out that if I have a function called <span class="source-code">shutdown<span class="k2">(</span><span class="k2">)</span></span>,  <span class="source-code"><a href="http://www.allegro.cc/manual/al_uninstall_system"><span class="a">al_uninstall_system</span></a></span> will execute it twice when called.</p><p>I&#39;m compiling with GCC on Linux. Compiling with G++ does not reproduce the error.
</p><ul><li><p>Allegro v5.2.4.1
</p></li><li><p>GCC v4.8.4
</p></li><li><p>Linux v3.13.0-37</p></li></ul><p>If I rename the function, no error or warnings are emitted.</p><p>The code below runs fine, but <span class="source-code">shutdown<span class="k2">(</span><span class="k2">)</span></span> is called twice when Allegro is uninstalled.
</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="p">#include &lt;stdio.h&gt;</span>
<span class="number">  2</span><span class="p">#include &lt;stdlib.h&gt;</span>
<span class="number">  3</span><span class="p">#include &lt;allegro5/allegro.h&gt;</span>
<span class="number">  4</span><span class="p">#include &lt;allegro5/allegro_font.h&gt;</span>
<span class="number">  5</span>
<span class="number">  6</span><a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a> <span class="k3">*</span>display<span class="k2">;</span>
<span class="number">  7</span><a href="http://www.allegro.cc/manual/ALLEGRO_FONT"><span class="a">ALLEGRO_FONT</span></a> <span class="k3">*</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a><span class="k2">;</span>
<span class="number">  8</span>
<span class="number">  9</span><span class="k1">void</span> abort_on_error<span class="k2">(</span><span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>message<span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 10</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_345.html" target="_blank">fprintf</a><span class="k2">(</span>stderr, <span class="s">"%s\n"</span>, message<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 11</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_298.html" target="_blank">exit</a><span class="k2">(</span>EXIT_FAILURE<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span><span class="k2">}</span>
<span class="number"> 13</span>
<span class="number"> 14</span><span class="k1">void</span> setup<span class="k2">(</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 15</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</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, NULL<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 16</span>    abort_on_error<span class="k2">(</span><span class="s">"Failed to init Allegro"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>  
<span class="number"> 18</span>  display <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_display"><span class="a">al_create_display</span></a><span class="k2">(</span><span class="n">320</span>, <span class="n">240</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 19</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>display<span class="k2">)</span> abort_on_error<span class="k2">(</span><span class="s">"Failed to create window"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span>
<span class="number"> 21</span>  <a href="http://www.allegro.cc/manual/al_set_window_title"><span class="a">al_set_window_title</span></a><span class="k2">(</span>display, <span class="s">"Allegro Test"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</span>  
<span class="number"> 23</span>  <a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a> <span class="k3">=</span> al_create_builtin_font<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a><span class="k2">)</span> abort_on_error<span class="k2">(</span><span class="s">"Failed to create font"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 25</span><span class="k2">}</span>
<span class="number"> 26</span>
<span class="number"> 27</span><span class="k1">void</span> shutdown<span class="k2">(</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 28</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Calling shutdown()\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span><span class="k2">}</span>
<span class="number"> 30</span>
<span class="number"> 31</span><span class="k1">void</span> real_shutdown<span class="k2">(</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 32</span>  <a href="http://www.allegro.cc/manual/al_destroy_font"><span class="a">al_destroy_font</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 33</span>  <a href="http://www.allegro.cc/manual/al_destroy_display"><span class="a">al_destroy_display</span></a><span class="k2">(</span>display<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 34</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"al_uninstall_system() start\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 35</span>  <a href="http://www.allegro.cc/manual/al_uninstall_system"><span class="a">al_uninstall_system</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 36</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"al_uninstall_system() end\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 37</span><span class="k2">}</span>
<span class="number"> 38</span>
<span class="number"> 39</span><span class="k1">void</span> play<span class="k2">(</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 40</span>  <a href="http://www.allegro.cc/manual/al_clear_to_color"><span class="a">al_clear_to_color</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/al_map_rgb_f"><span class="a">al_map_rgb_f</span></a><span class="k2">(</span><span class="n">0</span>,<span class="n">0</span>,<span class="n">0</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 41</span>  <a href="http://www.allegro.cc/manual/al_draw_text"><span class="a">al_draw_text</span></a><span class="k2">(</span><a href="http://www.allegro.cc/manual/font"><span class="a">font</span></a>, <a href="http://www.allegro.cc/manual/al_map_rgb_f"><span class="a">al_map_rgb_f</span></a><span class="k2">(</span><span class="n">1</span>,<span class="n">1</span>,<span class="n">1</span><span class="k2">)</span>, <span class="n">10</span>, <span class="n">10</span>, <span class="n">0</span>, <span class="s">"Allegro Test"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 42</span>  <a href="http://www.allegro.cc/manual/al_flip_display"><span class="a">al_flip_display</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 43</span>  <a href="http://www.allegro.cc/manual/al_rest"><span class="a">al_rest</span></a><span class="k2">(</span><span class="n">2</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 44</span><span class="k2">}</span>
<span class="number"> 45</span>
<span class="number"> 46</span><span class="k1">int</span> main <span class="k2">(</span><span class="k1">int</span> argc, <span class="k1">char</span> <span class="k3">*</span>argv<span class="k2">[</span><span class="k2">]</span><span class="k2">)</span> <span class="k2">{</span>
<span class="number"> 47</span>  setup<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 48</span>  play<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 49</span>  real_shutdown<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 50</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 51</span><span class="k2">}</span>
</div></div><p>

<b>Output:</b>
</p><pre>al_uninstall_system() start
Calling shutdown()
Calling shutdown()
al_uninstall_system() end
</pre><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Roy Balela)</author>
		<pubDate>Sat, 28 Jul 2018 00:05:27 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Am I blind, but when do you call &quot;void shutdown()&quot;?</p><p>I see you&#39;re program prints &quot;Calling shutdown()&quot;, but it was never called.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (DanielH)</author>
		<pubDate>Sat, 28 Jul 2018 00:31:58 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Just put a breakpoint on <span class="source-code">shutdown<span class="k2">(</span><span class="k2">)</span></span> to see where it is being called from?</p><p>As you probably know you would normally just call <span class="source-code"><a href="http://www.allegro.cc/manual/al_init"><span class="a">al_init</span></a></span>, not <span class="source-code"><a href="http://www.allegro.cc/manual/al_install_system"><span class="a">al_install_system</span></a></span> or <span class="source-code"><a href="http://www.allegro.cc/manual/al_uninstall_system"><span class="a">al_uninstall_system</span></a></span>.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (torhu)</author>
		<pubDate>Sat, 28 Jul 2018 00:45:16 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>It&#39;s a linking bug. Allegro sees your shutdown function and calls it mistakenly, thinking it is its own version of shutdown.</p><p>You can debug this easily by setting a breakpoint in your shutdown function. Then when allegro calls it, gdb will stop and let you get a backtrace. Do it twice. Post the results.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Sat, 28 Jul 2018 00:49:16 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p><b>Backtrace:</b>
</p><pre>#0  shutdown () at test.c:28
#1  0x00007ffff5de0786 in xcb_disconnect ()
   from /usr/lib/x86_64-linux-gnu/libxcb.so.1
#2  0x00007ffff6caf4e7 in XCloseDisplay ()
   from /usr/lib/x86_64-linux-gnu/libX11.so.6
#3  0x00007ffff7b77a17 in ?? ()
   from /usr/lib/x86_64-linux-gnu/liballegro.so.5.2
#4  0x00007ffff7b2bcd5 in ?? ()
   from /usr/lib/x86_64-linux-gnu/liballegro.so.5.2
#5  0x00007ffff7b1fd4d in _al_run_exit_funcs ()
   from /usr/lib/x86_64-linux-gnu/liballegro.so.5.2
#6  0x00007ffff7b2bdb5 in al_uninstall_system ()
   from /usr/lib/x86_64-linux-gnu/liballegro.so.5.2
#7  0x0000000000400c89 in real_shutdown () at test.c:35
#8  0x0000000000400da5 in main (argc=1, argv=0x7fffffffe158) at test.c:49
</pre><p>

</p><div class="quote_container"><div class="title"><a href="http://www.allegro.cc/forums/thread/617518/1038702#target">Edgar Reynaldo</a> said:</div><div class="quote"><p>It&#39;s a linking bug. Allegro sees your shutdown function and calls it mistakenly, thinking it is its own version of shutdown.</p></div></div><p>
Apparently, yes. I just found out <span class="source-code">shutdown<span class="k2">(</span><span class="k2">)</span></span> is POSIX function(<a href="https://linux.die.net/man/2/shutdown">https://linux.die.net/man/2/shutdown</a>), so I better not have another function with the same name.</p><p>Thank you! <img src="http://www.allegro.cc/forums/smileys/grin.gif" alt=";D" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Roy Balela)</author>
		<pubDate>Sat, 28 Jul 2018 01:22:59 +0000</pubDate>
	</item>
</rss>
