<?xml version="1.0"?>
<rss version="2.0">
	<channel>
		<title>al_get_opengl_proc_address failed</title>
		<link>http://www.allegro.cc/forums/view/618046</link>
		<description>Allegro.cc Forum Thread</description>
		<webMaster>matthew@allegro.cc (Matthew Leverton)</webMaster>
		<lastBuildDate>Thu, 20 Feb 2020 07:56:42 +0000</lastBuildDate>
	</channel>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>I was thinking of posting the error on github, but unfortunately it is not possible, my current email was hijacked and when trying a new email, github blocks it. Anyway.</p><p>Have a error from al_get_opengl_proc_address(), give wrongs pointers and get a segfault in the L28.</p><p>TESTCASE:</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;allegro5/allegro.h&gt;</span>
<span class="number">  3</span><span class="p">#include &lt;allegro5/allegro_image.h&gt;</span>
<span class="number">  4</span>
<span class="number">  5</span><span class="k1">int</span> main<span class="k2">(</span><span class="k2">)</span><span class="k2">{</span>
<span class="number">  6</span>  <span class="k1">int</span> err,i,CICLO<span class="k3">=</span><span class="n">1</span>,redraw<span class="k3">=</span><span class="n">0</span><span class="k2">;</span>
<span class="number">  7</span>  <span class="c">//Prepara ALLEGRO</span>
<span class="number">  8</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_DISPLAY"><span class="a">ALLEGRO_DISPLAY</span></a><span class="k3">*</span>dsp<span class="k2">;</span>
<span class="number">  9</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT"><span class="a">ALLEGRO_EVENT</span></a> event<span class="k2">;</span>
<span class="number"> 10</span>  <a href="http://www.allegro.cc/manual/ALLEGRO_EVENT_QUEUE"><span class="a">ALLEGRO_EVENT_QUEUE</span></a><span class="k3">*</span>queue<span class="k2">;</span>
<span class="number"> 11</span>
<span class="number"> 12</span>  <span class="c">//Inicializa Allegro</span>
<span class="number"> 13</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="k2">{</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Fallo AL_INIT\n"</span><span class="k2">)</span><span class="k2">;</span><span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span><span class="k2">}</span>
<span class="number"> 14</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="k2">)</span><span class="k2">;</span>
<span class="number"> 15</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="k2">)</span><span class="k2">;</span>
<span class="number"> 16</span>  <span class="c">//al_init_image_addon();</span>
<span class="number"> 17</span>  <span class="c">//al_set_new_display_flags(ALLEGRO_OPENGL_ES_PROFILE);</span>
<span class="number"> 18</span>  dsp<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">640</span>,<span class="n">480</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>dsp<span class="k2">)</span><span class="k2">{</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"Fallo creando display\n"</span><span class="k2">)</span><span class="k2">;</span><span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span><span class="k2">}</span>
<span class="number"> 20</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>dsp,<span class="s">"HAPPY VIDEO"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 21</span>  <span class="c">//timer=al_create_timer(1/60);</span>
<span class="number"> 22</span>  queue<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="k2">)</span><span class="k2">;</span>
<span class="number"> 23</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>queue,<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="k2">)</span><span class="k2">;</span>
<span class="number"> 24</span>  <span class="c">//al_register_event_source(queue,al_get_display_event_source(dsp));</span>
<span class="number"> 25</span>
<span class="number"> 26</span>  <span class="k1">void</span><span class="k3">*</span>f<span class="k3">=</span><a href="http://www.allegro.cc/manual/al_get_opengl_proc_address"><span class="a">al_get_opengl_proc_address</span></a><span class="k2">(</span><span class="s">"glGetString"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 27</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"PROC ADDRESS: %p\n"</span>,f<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 28</span>  <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>version_string <span class="k3">=</span> <span class="k2">(</span><span class="k2">(</span><span class="k1">const</span> <span class="k1">char</span><span class="k3">*</span><span class="k2">(</span><span class="k3">*</span><span class="k2">)</span><span class="k2">(</span><span class="k1">int</span><span class="k2">)</span><span class="k2">)</span>f<span class="k2">)</span><span class="k2">(</span><span class="n">0x1F02</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>  <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"PROC ADDRESS: %s\n"</span>,version_string<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 30</span>  <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 31</span><span class="k2">}</span>
</div></div><p>
Line compiling: gcc pru.c -o pru -lallegro -g</p><p>RESULT:<br />PROC ADDRESS: 0xfffffffff4f535e0<br />(SIGSEGV in 0xfffffffff4f535e0)</p><p>I also trying with a TESTCASE for SDL:</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;stddef.h&gt;</span>
<span class="number">  2</span><span class="p">#include &lt;stdio.h&gt;</span>
<span class="number">  3</span><span class="p">#include &lt;stdlib.h&gt;</span>
<span class="number">  4</span>
<span class="number">  5</span><span class="p">#include &lt;SDL.h&gt;</span>
<span class="number">  6</span>
<span class="number">  7</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">  8</span><span class="k2">{</span>
<span class="number">  9</span>
<span class="number"> 10</span>    <span class="c">// Jesus Christ SDL, you suck!</span>
<span class="number"> 11</span>    SDL_SetHint<span class="k2">(</span>SDL_HINT_NO_SIGNAL_HANDLERS, <span class="s">"no"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 12</span>
<span class="number"> 13</span>    <span class="k1">if</span> <span class="k2">(</span>SDL_Init<span class="k2">(</span>SDL_INIT_VIDEO<span class="k2">)</span> <span class="k3">&lt;</span> <span class="n">0</span><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 14</span>        <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"SDL init failed\n"</span><span class="k2">)</span><span class="k2">;</span><span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span><span class="k2">}</span>
<span class="number"> 15</span>
<span class="number"> 16</span>    SDL_Window <span class="k3">*</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_865.html" target="_blank">window</a> <span class="k3">=</span>
<span class="number"> 17</span>        SDL_CreateWindow<span class="k2">(</span><span class="s">"hi"</span>, SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED,
<span class="number"> 18</span>                         <span class="n">1000</span>, <span class="n">500</span>, SDL_WINDOW_OPENGL <span class="k3">|</span> SDL_WINDOW_SHOWN <span class="k3">|</span>
<span class="number"> 19</span>                                    SDL_WINDOW_RESIZABLE<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 20</span>    <span class="k1">if</span> <span class="k2">(</span><span class="k3">!</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_865.html" target="_blank">window</a><span class="k2">)</span><span class="k2">{</span>
<span class="number"> 21</span>        <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"failed to create SDL window\n"</span><span class="k2">)</span><span class="k2">;</span><span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span><span class="k2">}</span>
<span class="number"> 22</span>
<span class="number"> 23</span>    SDL_GLContext glcontext <span class="k3">=</span> SDL_GL_CreateContext<span class="k2">(</span><a href="http://www.delorie.com/djgpp/doc/libc/libc_865.html" target="_blank">window</a><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>glcontext<span class="k2">)</span><span class="k2">{</span>
<span class="number"> 25</span>        <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"failed to create SDL GL context\n"</span><span class="k2">)</span><span class="k2">;</span><span class="k1">return</span> <span class="k3">-</span><span class="n">1</span><span class="k2">;</span><span class="k2">}</span>
<span class="number"> 26</span>
<span class="number"> 27</span>    <span class="k1">void</span><span class="k3">*</span>f<span class="k3">=</span>SDL_GL_GetProcAddress<span class="k2">(</span><span class="s">"glGetString"</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">"PROC ADDRESS: %p\n"</span>,f<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 29</span>    <span class="k1">const</span> <span class="k1">char</span> <span class="k3">*</span>version_string <span class="k3">=</span> <span class="k2">(</span><span class="k2">(</span><span class="k1">const</span> <span class="k1">char</span><span class="k3">*</span><span class="k2">(</span><span class="k3">*</span><span class="k2">)</span><span class="k2">(</span><span class="k1">int</span><span class="k2">)</span><span class="k2">)</span>f<span class="k2">)</span><span class="k2">(</span><span class="n">0x1F02</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 30</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"PROC ADDRESS: %s\n"</span>,version_string<span class="k2">)</span><span class="k2">;</span>
<span class="number"> 31</span>
<span class="number"> 32</span>    <a href="http://www.delorie.com/djgpp/doc/libc/libc_624.html" target="_blank">printf</a><span class="k2">(</span><span class="s">"properly terminated\n"</span><span class="k2">)</span><span class="k2">;</span>
<span class="number"> 33</span>    <span class="k1">return</span> <span class="n">0</span><span class="k2">;</span>
<span class="number"> 34</span><span class="k2">}</span>
</div></div><p>
Line Compiling: gcc -o main main.c `pkg-config --libs --cflags mpv sdl2` -std=c99</p><p>RESULT:<br />PROC ADDRESS: 0x7fafcd76b5e0<br />PROC ADDRESS: 3.0 Mesa 19.3.4<br />properly terminated</p><p>-------------------------------------------------------------</p><p>This is my first serious fault discovered in Allegro 5...
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (RmBeer2)</author>
		<pubDate>Mon, 17 Feb 2020 23:45:47 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Bah humbug. This is not a bug in Allegro. You didn&#39;t request ALLEGRO_OPENGL, so you were using D3D. Which means al_get_opengl_proc_address will fail spectacularly.</p><p>Well, at least if you were on Windows that code would fail.</p><p>On Linux, it <b>should</b> work.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 18 Feb 2020 00:11:12 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Is this with Allegro from distribution package, or compiled from source?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (gusnan)</author>
		<pubDate>Tue, 18 Feb 2020 00:52:52 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>@Edgar</p><p>It fails the same anyway, I have already tried all the context variants for OpenGL.</p><p>@gusnan</p><p>For both. (From the system and from the source code)
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (RmBeer2)</author>
		<pubDate>Tue, 18 Feb 2020 02:12:09 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>glGetString is OpenGL 2.0. It will fail if your drivers aren&#39;t recent enough. But you say you&#39;re using Mesa?</p><p>What platform are you on that fails? What version of Allegro are you using? What version are your MesaGL drivers?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Tue, 18 Feb 2020 02:17:15 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>this is the first like that i use: al_set_new_display_flags(ALLEGRO_OPENGL);<br />(in the comment line)</p><p>Yes, i use mesa.<br />Allegro from the system and from the source code in both sides, all updated in less of 1 day.<br />Also for the Archlinux system is updated in less of 3 days.</p><p>Archlinux Kernel: Linux 5.5.3-arch1-1 #1 SMP PREEMPT Tue, 11 Feb 2020 15:35:41 +0000 x86_64 GNU/Linux<br />mesa 19.3.4-2</p><p><b>EDIT:</b><br />mesa 19.3.4-2 is only get from testing... i unknown what patches&#39;re applied...<br />But it doesn&#39;t matter, since in the SDL testcase it works.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (RmBeer2)</author>
		<pubDate>Tue, 18 Feb 2020 02:32:34 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Rmbeer2, post the solution. You were incorrectly casting as a different type of function signature, were you not?
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Wed, 19 Feb 2020 03:50:22 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>Just add #include &lt;allegro5/allegro_opengl.h&gt; and it will work.</p><p>Also, never compile without warnings, that would have easily avoided that mistake.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Elias)</author>
		<pubDate>Thu, 20 Feb 2020 01:29:48 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>SOLUTION: Read the complete documentation and add this line:</p><p>#include &lt;allegro5/allegro_opengl.h&gt;</p><p><img src="http://www.allegro.cc/forums/smileys/rolleyes.gif" alt="::)" />
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (RmBeer2)</author>
		<pubDate>Thu, 20 Feb 2020 03:00:15 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>From what I read of your conversation on IRC, you incorrectly cast a function pointer as well.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Edgar Reynaldo)</author>
		<pubDate>Thu, 20 Feb 2020 03:26:32 +0000</pubDate>
	</item>
	<item>
		<description><![CDATA[<div class="mockup v2"><p>No, I don&#39;t think so, when I added that line of #include everything worked fine and without warnings.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (RmBeer2)</author>
		<pubDate>Thu, 20 Feb 2020 03:55:07 +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/618046/1044964#target">Edgar Reynaldo</a> said:</div><div class="quote"><p>From what I read of your conversation on IRC, you incorrectly cast a function pointer as well. </p></div></div><p>

Well, the effect of forgetting the #include means the compiler (after displaying a big warning) just assumes all undefined functions return int and so essentially the 64-bit function pointer got cast to a 32-bit int.
</p></div>]]>
		</description>
		<author>no-reply@allegro.cc (Elias)</author>
		<pubDate>Thu, 20 Feb 2020 07:56:42 +0000</pubDate>
	</item>
</rss>
