<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>[A5.1 SVN] crash when ending application</title>
		<link>http://www.allegro.cc/forums/view/608012</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Thu, 04 Aug 2011 01:41:09 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Since lately, my game crashes during exit. I&#39;ve tracked down this to 
</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">static</span> <span class="k1">void</span> shutdown_system_driver<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span>
</pre></div></div><p> <br />in system.c, where a destructor call for user_exe_path is called, on already destroyed data. It helps to move the new lines up, like this: 
</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">static</span> <span class="k1">void</span> shutdown_system_driver<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>   <span class="k1">if</span> <span class="k2">(</span>active_sysdrv<span class="k2">)</span> <span class="k2">{</span>
<span class="number">  4</span>      <a href="http://www.allegro.cc/manual/ALLEGRO_CONFIG"><span class="a">ALLEGRO_CONFIG</span></a> <span class="k3">*</span>temp <span class="k3">=</span> active_sysdrv-&gt;config<span class="k2">;</span>
<span class="number">  5</span>      <span class="k1">if</span> <span class="k2">(</span>active_sysdrv-&gt;user_exe_path<span class="k2">)</span>                   <span class="k3">&lt;</span><span class="k3">&lt;</span><span class="k3">-</span><span class="k3">-</span> <span class="k1">new</span> lines
<span class="number">  6</span>         <a href="http://www.allegro.cc/manual/al_destroy_path"><span class="a">al_destroy_path</span></a><span class="k2">(</span>active_sysdrv-&gt;user_exe_path<span class="k2">)</span><span class="k2">;</span>   <span class="k3">&lt;</span><span class="k3">&lt;</span><span class="k3">-</span><span class="k3">-</span> must be called before shutdown_system<span class="k2">(</span><span class="k2">)</span>
<span class="number">  7</span>      <span class="k1">if</span> <span class="k2">(</span>active_sysdrv-&gt;vt <span class="k3">&amp;</span><span class="k3">&amp;</span> active_sysdrv-&gt;vt-&gt;shutdown_system<span class="k2">)</span>
<span class="number">  8</span>         active_sysdrv-&gt;vt-&gt;shutdown_system<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  9</span>      active_sysdrv <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 10</span>      <span class="c">/* active_sysdrv is not accessible here so we copied it */</span>
<span class="number"> 11</span>      <a href="http://www.allegro.cc/manual/al_destroy_config"><span class="a">al_destroy_config</span></a><span class="k2">(</span>temp<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span> 
<span class="number"> 13</span>      <span class="k1">while</span> <span class="k2">(</span><span class="k3">!</span>_al_vector_is_empty<span class="k2">(</span><span class="k3">&amp;</span>_al_system_interfaces<span class="k2">)</span><span class="k2">)</span>
<span class="number"> 14</span>         _al_vector_delete_at<span class="k2">(</span><span class="k3">&amp;</span>_al_system_interfaces, _al_vector_size<span class="k2">(</span><span class="k3">&amp;</span>_al_system_interfaces<span class="k2">)</span><span class="k3">-</span><span class="n">1</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 15</span>      _al_vector_free<span class="k2">(</span><span class="k3">&amp;</span>_al_system_interfaces<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 16</span>      _al_vector_init<span class="k2">(</span><span class="k3">&amp;</span>_al_system_interfaces, <span class="k1">sizeof</span><span class="k2">(</span>ALLEGRO_SYSTEM_INTERFACE <span class="k3">*</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 17</span>   <span class="k2">}</span>
<span class="number"> 18</span><span class="k2">}</span>
</div></div><p>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (tobing)</author>
		<pubDate>Wed, 03 Aug 2011 23:07:05 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Makes sense, but it&#39;s not destroying it twice, it&#39;s trying to access user_exe_path through a freed pointer.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Trent Gamblin)</author>
		<pubDate>Wed, 03 Aug 2011 23:14:33 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>It doesn&#39;t look like the user_exe_path has anything to do with with current driver. Can you explain why your fix is necessary?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (kazzmir)</author>
		<pubDate>Wed, 03 Aug 2011 23:20:19 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>My understanding was that active_sysdrv was being freed.</p><p>Edit: that comment seems to be erroneuous now.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Trent Gamblin)</author>
		<pubDate>Thu, 04 Aug 2011 00:44:54 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Thanks, I committed it to SVN. (Was also me who had added those 2 lines to the wrong place... just wanted to get my speedhack entry working under Windows and wasn&#39;t careful enough <img src="http://www.allegro.cc/forums/smileys/tongue.gif" alt=":P" />)
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Elias)</author>
		<pubDate>Thu, 04 Aug 2011 01:41:09 +0000</pubDate>
	</item>
</rss>
