<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>Allegro 5.0.10 memory leak?</title>
		<link>http://www.allegro.cc/forums/view/615065</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Thu, 12 Feb 2015 01:27:51 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Hi,<br />with the following example</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 "stdafx.h"</span>
<span class="number">  2</span><span class="p">#include &lt;vld.h&gt;</span>
<span class="number">  3</span><span class="p">#define ALLEGRO_STATICLINK</span>
<span class="number">  4</span><span class="p">#include "allegro5/allegro.h"</span>
<span class="number">  5</span>
<span class="number">  6</span><span class="c">// Resolution</span>
<span class="number">  7</span><span class="k1">const</span> <span class="k1">int</span> SCREENW <span class="k3">=</span> <span class="n">1280</span><span class="k2">;</span>
<span class="number">  8</span><span class="k1">const</span> <span class="k1">int</span> SCREENH <span class="k3">=</span> <span class="n">800</span><span class="k2">;</span>
<span class="number">  9</span><span class="k1">const</span> <span class="k1">bool</span> FULLSCREEN <span class="k3">=</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 10</span>
<span class="number"> 11</span><span class="c">// Display</span>
<span class="number"> 12</span><a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a> <span class="k3">*</span>display <span class="k3">=</span> NULL<span class="k2">;</span>
<span class="number"> 13</span>
<span class="number"> 14</span><span class="k1">bool</span> init<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 15</span><span class="k2">{</span>
<span class="number"> 16</span>  <span class="c">// Install Allegro</span>
<span class="number"> 17</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.allegro.cc/manual/al_init"><span class="a">al_init</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">)</span>
<span class="number"> 18</span>    <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 19</span>
<span class="number"> 20</span>  <span class="c">// Create the display</span>
<span class="number"> 21</span>  <a href="http://www.allegro.cc/manual/al_set_new_display_flags"><span class="a">al_set_new_display_flags</span></a><span class="k2">(</span>ALLEGRO_OPENGL <span class="k3">|</span> <span class="k2">(</span>FULLSCREEN ? ALLEGRO_FULLSCREEN <span class="k2">:</span> <span class="n">0</span><span class="k2">)</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 22</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>SCREENW, SCREENH<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 23</span>  <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span>display<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="number"> 26</span>  <span class="c">// Success</span>
<span class="number"> 27</span>  <span class="k1">return</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 28</span><span class="k2">}</span>
<span class="number"> 29</span>
<span class="number"> 30</span><span class="k1">void</span> done<span class="k2">(</span><span class="k2">)</span>
<span class="number"> 31</span><span class="k2">{</span>  
<span class="number"> 32</span>  <span class="c">// Free resources</span>
<span class="number"> 33</span>  <span class="k1">if</span> <span class="k2">(</span>display<span class="k2">)</span>
<span class="number"> 34</span>  <span class="k2">{</span>
<span class="number"> 35</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"> 36</span>    display <span class="k3">=</span> NULL<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="c">// Uninstall allegro</span>
<span class="number"> 40</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"> 41</span><span class="k2">}</span>
<span class="number"> 42</span>
<span class="number"> 43</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="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>init<span class="k2">(</span><span class="k2">)</span><span class="k2">)</span>
<span class="number"> 46</span>  <span class="k2">{</span>
<span class="number"> 47</span>    done<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 48</span>    <span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span>
<span class="number"> 49</span>  <span class="k2">}</span>
<span class="number"> 50</span>
<span class="number"> 51</span>  done<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 52</span>
<span class="number"> 53</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 54</span><span class="k2">}</span>
</div></div><p>

Visual leak detector (vld) reports 4 memory leaks</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>WARNING: Visual Leak Detector detected memory leaks<span class="k3">!</span>
<span class="number">  2</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span> Block <span class="n">98</span> at <span class="n">0x00866990</span><span class="k2">:</span> <span class="n">4</span> bytes <span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span>
<span class="number">  3</span>  Leak Hash: <span class="n">0x004A3546</span>, Count: <span class="n">1</span>, Total <span class="n">4</span> bytes
<span class="number">  4</span>  Call Stack <span class="k2">(</span>TID <span class="n">2696</span><span class="k2">)</span><span class="k2">:</span>
<span class="number">  5</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\dbgmalloc.c <span class="k2">(</span><span class="n">55</span><span class="k2">)</span><span class="k2">:</span> MSVCR110D.dll<span class="k3">!</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a>
<span class="number">  6</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\memory.c <span class="k2">(</span><span class="n">44</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_malloc_with_context"><span class="a">al_malloc_with_context</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number">  7</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\threads.c <span class="k2">(</span><span class="n">283</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_create_mutex"><span class="a">al_create_mutex</span></a> <span class="k3">+</span> <span class="n">0x16</span> bytes
<span class="number">  8</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\d3d_disp.cpp <span class="k2">(</span><span class="n">698</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>_al_d3d_init_display <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number">  9</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">150</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>maybe_d3d_init_display
<span class="number"> 10</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">172</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>win_initialize <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 11</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">61</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>find_system <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 12</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">241</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_system"><span class="a">al_install_system</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 13</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">20</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>init <span class="k3">+</span> <span class="n">0xF</span> bytes
<span class="number"> 14</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">48</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>main <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 15</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">536</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>__tmainCRTStartup <span class="k3">+</span> <span class="n">0x19</span> bytes
<span class="number"> 16</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">377</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>mainCRTStartup
<span class="number"> 17</span>    <span class="n">0x7701919F</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> KERNEL32.DLL<span class="k3">!</span>BaseThreadInitThunk <span class="k3">+</span> <span class="n">0xE</span> bytes
<span class="number"> 18</span>    <span class="n">0x77CD0BBB</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x84</span> bytes
<span class="number"> 19</span>    <span class="n">0x77CD0B91</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x5A</span> bytes
<span class="number"> 20</span>  Data:
<span class="number"> 21</span>    <span class="n">10</span> <span class="n">2B</span> <span class="n">8A</span> <span class="n">00</span>                                                  .<span class="k3">+</span>...... ........
<span class="number"> 22</span>
<span class="number"> 23</span>
<span class="number"> 24</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span> Block <span class="n">99</span> at <span class="n">0x008A2B10</span><span class="k2">:</span> <span class="n">24</span> bytes <span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span>
<span class="number"> 25</span>  Leak Hash: <span class="n">0x4BB34128</span>, Count: <span class="n">1</span>, Total <span class="n">24</span> bytes
<span class="number"> 26</span>  Call Stack <span class="k2">(</span>TID <span class="n">2696</span><span class="k2">)</span><span class="k2">:</span>
<span class="number"> 27</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\dbgmalloc.c <span class="k2">(</span><span class="n">55</span><span class="k2">)</span><span class="k2">:</span> MSVCR110D.dll<span class="k3">!</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a>
<span class="number"> 28</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\memory.c <span class="k2">(</span><span class="n">44</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_malloc_with_context"><span class="a">al_malloc_with_context</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 29</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wxthread.c <span class="k2">(</span><span class="n">102</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>_al_mutex_init <span class="k3">+</span> <span class="n">0x13</span> bytes
<span class="number"> 30</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\threads.c <span class="k2">(</span><span class="n">286</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_create_mutex"><span class="a">al_create_mutex</span></a> <span class="k3">+</span> <span class="n">0x9</span> bytes
<span class="number"> 31</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\d3d_disp.cpp <span class="k2">(</span><span class="n">698</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>_al_d3d_init_display <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 32</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">150</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>maybe_d3d_init_display
<span class="number"> 33</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">172</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>win_initialize <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 34</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">61</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>find_system <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 35</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">241</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_system"><span class="a">al_install_system</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 36</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">20</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>init <span class="k3">+</span> <span class="n">0xF</span> bytes
<span class="number"> 37</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">48</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>main <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 38</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">536</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>__tmainCRTStartup <span class="k3">+</span> <span class="n">0x19</span> bytes
<span class="number"> 39</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">377</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>mainCRTStartup
<span class="number"> 40</span>    <span class="n">0x7701919F</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> KERNEL32.DLL<span class="k3">!</span>BaseThreadInitThunk <span class="k3">+</span> <span class="n">0xE</span> bytes
<span class="number"> 41</span>    <span class="n">0x77CD0BBB</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x84</span> bytes
<span class="number"> 42</span>    <span class="n">0x77CD0B91</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x5A</span> bytes
<span class="number"> 43</span>  Data:
<span class="number"> 44</span>    FF FF FF FF    FF FF FF FF    <span class="n">00</span> <span class="n">00</span> <span class="n">00</span> <span class="n">00</span>    <span class="n">00</span> <span class="n">00</span> <span class="n">00</span> <span class="n">00</span>     ........ ........
<span class="number"> 45</span>    <span class="n">00</span> <span class="n">00</span> <span class="n">00</span> <span class="n">00</span>    D0 <span class="n">07</span> <span class="n">00</span> <span class="n">02</span>                                   ........ ........
<span class="number"> 46</span>
<span class="number"> 47</span>
<span class="number"> 48</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span> Block <span class="n">100</span> at <span class="n">0x008A2B68</span><span class="k2">:</span> <span class="n">4</span> bytes <span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span>
<span class="number"> 49</span>  Leak Hash: <span class="n">0x55D94109</span>, Count: <span class="n">1</span>, Total <span class="n">4</span> bytes
<span class="number"> 50</span>  Call Stack <span class="k2">(</span>TID <span class="n">2696</span><span class="k2">)</span><span class="k2">:</span>
<span class="number"> 51</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\dbgmalloc.c <span class="k2">(</span><span class="n">55</span><span class="k2">)</span><span class="k2">:</span> MSVCR110D.dll<span class="k3">!</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a>
<span class="number"> 52</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\memory.c <span class="k2">(</span><span class="n">44</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_malloc_with_context"><span class="a">al_malloc_with_context</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 53</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\threads.c <span class="k2">(</span><span class="n">283</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_create_mutex"><span class="a">al_create_mutex</span></a> <span class="k3">+</span> <span class="n">0x16</span> bytes
<span class="number"> 54</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\d3d_disp.cpp <span class="k2">(</span><span class="n">699</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>_al_d3d_init_display <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 55</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">150</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>maybe_d3d_init_display
<span class="number"> 56</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">172</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>win_initialize <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 57</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">61</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>find_system <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 58</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">241</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_system"><span class="a">al_install_system</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 59</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">20</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>init <span class="k3">+</span> <span class="n">0xF</span> bytes
<span class="number"> 60</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">48</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>main <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 61</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">536</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>__tmainCRTStartup <span class="k3">+</span> <span class="n">0x19</span> bytes
<span class="number"> 62</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">377</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>mainCRTStartup
<span class="number"> 63</span>    <span class="n">0x7701919F</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> KERNEL32.DLL<span class="k3">!</span>BaseThreadInitThunk <span class="k3">+</span> <span class="n">0xE</span> bytes
<span class="number"> 64</span>    <span class="n">0x77CD0BBB</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x84</span> bytes
<span class="number"> 65</span>    <span class="n">0x77CD0B91</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x5A</span> bytes
<span class="number"> 66</span>  Data:
<span class="number"> 67</span>    A8 <span class="n">2B</span> <span class="n">8A</span> <span class="n">00</span>                                                  .<span class="k3">+</span>...... ........
<span class="number"> 68</span>
<span class="number"> 69</span>
<span class="number"> 70</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span> Block <span class="n">101</span> at <span class="n">0x008A2BA8</span><span class="k2">:</span> <span class="n">24</span> bytes <span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span><span class="k3">-</span>
<span class="number"> 71</span>  Leak Hash: <span class="n">0x1E203567</span>, Count: <span class="n">1</span>, Total <span class="n">24</span> bytes
<span class="number"> 72</span>  Call Stack <span class="k2">(</span>TID <span class="n">2696</span><span class="k2">)</span><span class="k2">:</span>
<span class="number"> 73</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\dbgmalloc.c <span class="k2">(</span><span class="n">55</span><span class="k2">)</span><span class="k2">:</span> MSVCR110D.dll<span class="k3">!</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_551.html" target="_blank">malloc</a>
<span class="number"> 74</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\memory.c <span class="k2">(</span><span class="n">44</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_malloc_with_context"><span class="a">al_malloc_with_context</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 75</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wxthread.c <span class="k2">(</span><span class="n">102</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>_al_mutex_init <span class="k3">+</span> <span class="n">0x13</span> bytes
<span class="number"> 76</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\threads.c <span class="k2">(</span><span class="n">286</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_create_mutex"><span class="a">al_create_mutex</span></a> <span class="k3">+</span> <span class="n">0x9</span> bytes
<span class="number"> 77</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\d3d_disp.cpp <span class="k2">(</span><span class="n">699</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>_al_d3d_init_display <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 78</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">150</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>maybe_d3d_init_display
<span class="number"> 79</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\win\wsystem.c <span class="k2">(</span><span class="n">172</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>win_initialize <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 80</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">61</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>find_system <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 81</span>    d:\libraries\build\allegro\src\allegro-git\allegro-git\src\system.c <span class="k2">(</span><span class="n">241</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span><a href="http://www.allegro.cc/manual/al_install_system"><span class="a">al_install_system</span></a> <span class="k3">+</span> <span class="n">0xA</span> bytes
<span class="number"> 82</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">20</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>init <span class="k3">+</span> <span class="n">0xF</span> bytes
<span class="number"> 83</span>    d:\dnl\a5leak\main.cpp <span class="k2">(</span><span class="n">48</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>main <span class="k3">+</span> <span class="n">0x5</span> bytes
<span class="number"> 84</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">536</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>__tmainCRTStartup <span class="k3">+</span> <span class="n">0x19</span> bytes
<span class="number"> 85</span>    f:\dd\vctools\crt_bld\self_x86\crt\src\crtexe.c <span class="k2">(</span><span class="n">377</span><span class="k2">)</span><span class="k2">:</span> A5Leak.exe<span class="k3">!</span>mainCRTStartup
<span class="number"> 86</span>    <span class="n">0x7701919F</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> KERNEL32.DLL<span class="k3">!</span>BaseThreadInitThunk <span class="k3">+</span> <span class="n">0xE</span> bytes
<span class="number"> 87</span>    <span class="n">0x77CD0BBB</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x84</span> bytes
<span class="number"> 88</span>    <span class="n">0x77CD0B91</span> <span class="k2">(</span>File <span class="k1">and</span> <a href="http://www.allegro.cc/manual/line"><span class="a">line</span></a> number <span class="k1">not</span> available<span class="k2">)</span><span class="k2">:</span> ntdll.dll<span class="k3">!</span>RtlInitializeExceptionChain <span class="k3">+</span> <span class="n">0x5A</span> bytes
<span class="number"> 89</span>  Data:
<span class="number"> 90</span>    FF FF FF FF    FF FF FF FF    <span class="n">00</span> <span class="n">00</span> <span class="n">00</span> <span class="n">00</span>    <span class="n">00</span> <span class="n">00</span> <span class="n">00</span> <span class="n">00</span>     ........ ........
<span class="number"> 91</span>    <span class="n">00</span> <span class="n">00</span> <span class="n">00</span> <span class="n">00</span>    D0 <span class="n">07</span> <span class="n">00</span> <span class="n">02</span>                                   ........ ........
<span class="number"> 92</span>
<span class="number"> 93</span>
<span class="number"> 94</span>Visual Leak Detector detected <span class="n">4</span> memory leaks <span class="k2">(</span><span class="n">200</span> bytes<span class="k2">)</span>.
<span class="number"> 95</span>Largest number used: <span class="n">11536</span> bytes.
<span class="number"> 96</span>Total allocations: <span class="n">39327</span> bytes.
<span class="number"> 97</span>Visual Leak Detector is now exiting.
</div></div><p>

The same thing doesn&#39;t happen if I remove the ALLEGRO_OPENGL flag from al_set_new_display_flags().</p><p>Is this something I&#39;m not doing correctly or is it a bug in the Allegro library (Windows 8.1, MSVC 2012, Allegro 5.0.10 binaries downloaded from <a href="https://www.allegro.cc/files/">https://www.allegro.cc/files/</a>)?</p><p>Cheers,<br /><u>XDnl</u>
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (_XDnl_)</author>
		<pubDate>Tue, 10 Feb 2015 05:55:53 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>It&#39;s kind of bizzare... can you set a breakpoint in <span class="source-code">src<span class="k3">/</span>win<span class="k3">/</span>d3d_disp.cpp:2500</span> and see if it&#39;s hit when you&#39;re shutting down Allegro?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (SiegeLord)</author>
		<pubDate>Tue, 10 Feb 2015 08:26:02 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I have tried your suggestion and actually the function <span class="source-code">d3d_shutdown<span class="k2">(</span><span class="k2">)</span></span> doesn&#39;t get called when the <span class="source-code">ALLEGRO_OPENGL</span> flag is set.<br />If I remove that flag instead, the <span class="source-code">d3d_shutdown<span class="k2">(</span><span class="k2">)</span></span> function is called.</p><p>Could someone reproduce this bug?</p><p>Edit: </p><p>After a closer inspection, I&#39;ve noticed what follows.<br />If <span class="source-code">ALLEGRO_OPENGL</span> is not set, then function <span class="source-code">win_shutdown<span class="k2">(</span><span class="k2">)</span></span> (wsystem.c) calls</p><div class="source-code snippet"><div class="inner"><pre><span class="k1">static</span> <span class="k1">void</span> win_shutdown<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span>
<span class="k2">{</span>
   ...

   display_driver <span class="k3">=</span> vt-&gt;get_display_driver<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
   <span class="k1">if</span> <span class="k2">(</span>display_driver <span class="k3">&amp;</span><span class="k3">&amp;</span> display_driver-&gt;shutdown<span class="k2">)</span> 
   <span class="k2">{</span>
      <span class="c">// Calls d3d_shutdown()</span>
      display_driver-&gt;shutdown<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
   <span class="k2">}</span>

   ...
<span class="k2">}</span>
</pre></div></div><p>

Otherwise, <span class="source-code">display_driver-&gt;shutdown</span> is zero and as a consequence <span class="source-code">d3d_shutdown<span class="k2">(</span><span class="k2">)</span></span> is not called.<br />I don&#39;t know the inner mechanisms of Allegro, but this seems ok to me.<br />If <span class="source-code">ALLEGRO_OPENGL</span> flag is set, we shouldn&#39;t call <span class="source-code">d3d_shutdown<span class="k2">(</span><span class="k2">)</span></span> because DirectX is not being used.<br />Maybe the <span class="source-code"><a href="http://www.allegro.cc/manual/al_create_display"><span class="a">al_create_display</span></a><span class="k2">(</span><span class="k2">)</span></span> has some fallback mechanism (could it be <span class="source-code">maybe_d3d_init_display<span class="k2">(</span><span class="k2">)</span></span>?) which creates some DirectX&#39;s related data and later &quot;forgets&quot; to release it?</p><p>Edit 2:<br />After <b>further</b> inspection, I&#39;ve reconstructed the calls flow.</p><p>wsystem.c </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> ALLEGRO_SYSTEM <span class="k3">*</span>win_initialize<span class="k2">(</span><span class="k1">int</span> flags<span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>  ....
<span class="number">  4</span>   <span class="c">// Always called, whether ALLEGRO_OPENGL is set or not</span>
<span class="number">  5</span>   d3d_available <span class="k3">=</span> maybe_d3d_init_display<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  6</span>
<span class="number">  7</span>   <span class="k1">return</span> <span class="k3">&amp;</span>_al_win_system-&gt;system<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="k1">static</span> <span class="k1">bool</span> maybe_d3d_init_display<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span>
<span class="number"> 11</span><span class="k2">{</span>
<span class="number"> 12</span><span class="p">#ifdef ALLEGRO_CFG_D3D</span>
<span class="number"> 13</span>   <span class="k1">return</span> _al_d3d_init_display<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 14</span><span class="p">#else</span>
<span class="number"> 15</span>   <span class="k1">return</span> <span class="k1">false</span><span class="k2">;</span>
<span class="number"> 16</span><span class="p">#endif</span>
<span class="number"> 17</span><span class="k2">}</span>
</div></div><p>
d3d_disp.cpp</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> _al_d3d_init_display<span class="k2">(</span><span class="k2">)</span>
<span class="number">  2</span><span class="k2">{</span>
<span class="number">  3</span>....
<span class="number">  4</span>   <span class="c">// Leaked mutexes as signaled by Visual Leak Detector?</span>
<span class="number">  5</span>   present_mutex <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_mutex"><span class="a">al_create_mutex</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  6</span>   _al_d3d_lost_device_mutex <span class="k3">=</span> <a href="http://www.allegro.cc/manual/al_create_mutex"><span class="a">al_create_mutex</span></a><span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  7</span>
<span class="number">  8</span>   _al_d3d_bmp_init<span class="k2">(</span><span class="k2">)</span><span class="k2">;</span>
<span class="number">  9</span>
<span class="number"> 10</span>   <span class="k1">return</span> <span class="k1">true</span><span class="k2">;</span>
<span class="number"> 11</span><span class="k2">}</span>
<span class="number"> 12</span>
<span class="number"> 13</span><span class="k1">static</span> <span class="k1">void</span> d3d_shutdown<span class="k2">(</span><span class="k1">void</span><span class="k2">)</span>
<span class="number"> 14</span><span class="k2">{</span>
<span class="number"> 15</span> 
<span class="number"> 16</span>...
<span class="number"> 17</span>   <span class="c">// Frees the mutexes, but this function isn't called when ALLEGRO_OPENGL is set!!!</span>
<span class="number"> 18</span>   <a href="http://www.allegro.cc/manual/al_destroy_mutex"><span class="a">al_destroy_mutex</span></a><span class="k2">(</span>present_mutex<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 19</span>   <a href="http://www.allegro.cc/manual/al_destroy_mutex"><span class="a">al_destroy_mutex</span></a><span class="k2">(</span>_al_d3d_lost_device_mutex<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span>....
<span class="number"> 21</span><span class="k2">}</span>
</div></div><p>

Sorry for my english, I hope these observations are helpful. <img src="http://www.allegro.cc/forums/smileys/smiley.gif" alt=":)" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (_XDnl_)</author>
		<pubDate>Tue, 10 Feb 2015 17:56:08 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>My best guess is that its a mistake to initialize the D3D code at all if the user requested OpenGL.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Thomas Fjellstrom)</author>
		<pubDate>Wed, 11 Feb 2015 06:30:45 +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/615065/1010135#target">_XDnl_</a> said:</div><div class="quote"><p>  Sorry for my english, I hope these observations are helpful. <img src="http://www.allegro.cc/forums/smileys/smiley.gif" alt=":)" /> </p></div></div><p>They certainly were! Thanks a lot for investigating. This should now be fixed in <a href="http://sourceforge.net/p/alleg/allegro/ci/1bc8c1cdaef59966f60027a222ae2f230522729c/">5.1@1bc8c1</a>.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (SiegeLord)</author>
		<pubDate>Wed, 11 Feb 2015 11:01:34 +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/615065/1010168#target">Thomas Fjellstrom</a> said:</div><div class="quote"><p> My best guess is that its a mistake to initialize the D3D code at all if the user requested OpenGL. </p></div></div><p>I found this interesting, and now my eyes bleed trying to figure out the code order in the patch <img src="http://www.allegro.cc/forums/smileys/grin.gif" alt=";D" /></p><p>Kidding aside, I guess the fact is that as I understand it the CFG_D3D flags is not indicative of user request but it is in fact a <i>configuration flag</i> ...a bit subtle to find.  </p><p>Really a good catch.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (pkrcel)</author>
		<pubDate>Wed, 11 Feb 2015 14:42:26 +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/615065/1010190#target">pkrcel</a> said:</div><div class="quote"><p>Kidding aside, I guess the fact is that as I understand it the CFG_D3D flags is not indicative of user request but it is in fact a configuration flag ...a bit subtle to find.</p></div></div><p>Indeed. CFG/HAVE/WANT things are all compile time macros. But the code actually calls d3d code, when Opengl is requested at run time. </p><p>I guess my main nit-pick was why the d3d code was even being entered if opengl was requested. With the current fix, at least it isn&#39;t going to call an init function when not requested. It&#39;s now calling into the d3d destroy display function which now will just return if the driver vtable isn&#39;t set up. Solves the problem. Though it&#39;s possible to avoid that call entirely with some state stored in the system driver (bool d3d_in_use; or something). Its arguable which is &quot;better&quot;.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Thomas Fjellstrom)</author>
		<pubDate>Wed, 11 Feb 2015 17:32:01 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Awesome, all&#39;s well that ends well! <img src="http://www.allegro.cc/forums/smileys/grin.gif" alt=";D" /><br />When it&#39;s finished, I&#39;ll post an A5 project I&#39;m working on.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (_XDnl_)</author>
		<pubDate>Thu, 12 Feb 2015 01:27:51 +0000</pubDate>
	</item>
</rss>
