diff options
author | Richard Purdie <rpurdie@linux.intel.com> | 2009-06-16 22:32:06 +0100 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2009-06-16 22:32:06 +0100 |
commit | 1acaab0f4bcbcb648167a15a924def801be63979 (patch) | |
tree | 8a4560acdb0077acc48bddfe02cce24e135b231a /meta/packages/qemu/qemu-git | |
parent | 1275962e51a9809be1d6c8702753005197206d72 (diff) | |
download | openembedded-core-1acaab0f4bcbcb648167a15a924def801be63979.tar.gz openembedded-core-1acaab0f4bcbcb648167a15a924def801be63979.tar.bz2 openembedded-core-1acaab0f4bcbcb648167a15a924def801be63979.tar.xz openembedded-core-1acaab0f4bcbcb648167a15a924def801be63979.zip |
qemu: Fix a GL passthrough bug
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
Diffstat (limited to 'meta/packages/qemu/qemu-git')
-rw-r--r-- | meta/packages/qemu/qemu-git/qemugl-allow-glxcontext-release.patch | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/meta/packages/qemu/qemu-git/qemugl-allow-glxcontext-release.patch b/meta/packages/qemu/qemu-git/qemugl-allow-glxcontext-release.patch new file mode 100644 index 000000000..979e8afc4 --- /dev/null +++ b/meta/packages/qemu/qemu-git/qemugl-allow-glxcontext-release.patch @@ -0,0 +1,63 @@ +Allow releasing the GLXContext/Drawable with glXMakeCurrent. + +--- +commit d942ed4e853e08d2298f3e11e9a952c1d952bff5 +tree f0a934efd8a8ff48e2d96f0d6fc7d70bef106bfe +parent 93619e6be184f8de08759d347825ee0d678a6f9c +author Andrzej Zaborowski <andrew.zaborowski@intel.com> Tue, 16 Jun 2009 22:22:05 +0200 +committer Andrzej Zaborowski <andrew.zaborowski@intel.com> Tue, 16 Jun 2009 22:22:05 +0200 + + target-i386/opengl_exec.c | 31 ++++++++++++++++--------------- + 1 files changed, 16 insertions(+), 15 deletions(-) + +diff --git a/target-i386/opengl_exec.c b/target-i386/opengl_exec.c +index 4a69b9b..3d6fb21 100644 +--- a/target-i386/opengl_exec.c ++++ b/target-i386/opengl_exec.c +@@ -1600,10 +1600,9 @@ int do_function_call(int func_number, arg_t *args, char *ret_string) + fprintf(stderr, "client_drawable=%p fake_ctx=%d\n", + (void *) client_drawable, fake_ctxt); + +- if (client_drawable == 0 && fake_ctxt == 0) { ++ if (client_drawable == 0 && fake_ctxt == 0) + ret_int = glXMakeCurrent(dpy, 0, NULL); +- process->current_state = &process->default_state; +- } else if ((drawable = (GLXDrawable) ++ else if ((drawable = (GLXDrawable) + get_association_fakepbuffer_pbuffer( + process, client_drawable))) { + GLXContext ctxt = get_association_fakecontext_glxcontext( +@@ -1651,19 +1650,21 @@ int do_function_call(int func_number, arg_t *args, char *ret_string) + } + + if (ret_int) { +- for (i = 0; i < process->nb_states; i ++) { +- if (process->glstates[i]->fake_ctxt == fake_ctxt) { +- /* HACK !!! REMOVE */ +- process->current_state = process->glstates[i]; +- process->current_state->drawable = drawable; +- break; +- } +- } ++ if (fake_ctxt) { ++ for (i = 0; i < process->nb_states; i ++) ++ if (process->glstates[i]->fake_ctxt == fake_ctxt) { ++ /* HACK !!! REMOVE */ ++ process->current_state = process->glstates[i]; ++ process->current_state->drawable = drawable; ++ break; ++ } + +- if (i == process->nb_states) { +- fprintf(stderr, "error remembering the new context\n"); +- exit(-1); +- } ++ if (i == process->nb_states) { ++ fprintf(stderr, "error remembering the new context\n"); ++ exit(-1); ++ } ++ } else ++ process->current_state = &process->default_state; + } + break; + } |