mirror of
https://github.com/LibreELEC/LibreELEC.tv.git
synced 2025-07-24 11:16:51 +00:00
Mesa-master: add various patches for OpenGL ES support (for testing)
This commit is contained in:
parent
dd7930da5a
commit
dd21782975
@ -0,0 +1,25 @@
|
||||
From d53566a498a502966ba0a1e863ec0eacdbf3cbbe Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 13:23:43 -0600
|
||||
Subject: [PATCH 01/14] mesa: fix set_tex_parameteri() call
|
||||
|
||||
---
|
||||
src/mesa/main/texparam.c | 2 +-
|
||||
1 files changed, 1 insertions(+), 1 deletions(-)
|
||||
|
||||
diff --git a/src/mesa/main/texparam.c b/src/mesa/main/texparam.c
|
||||
index 05d1442..6cbb999 100644
|
||||
--- a/src/mesa/main/texparam.c
|
||||
+++ b/src/mesa/main/texparam.c
|
||||
@@ -599,7 +599,7 @@ _mesa_TexParameterfv(GLenum target, GLenum pname, const GLfloat *params)
|
||||
iparams[1] = (GLint) params[1];
|
||||
iparams[2] = (GLint) params[2];
|
||||
iparams[3] = (GLint) params[3];
|
||||
- need_update = set_tex_parameteri(ctx, target, iparams);
|
||||
+ need_update = set_tex_parameteri(ctx, texObj, pname, iparams);
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,32 @@
|
||||
From d759a537726eccda7d6fccf6ecd09fdac0667088 Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 13:24:20 -0600
|
||||
Subject: [PATCH 02/14] st: added preprocessor test for FEATURE_texture_s3tc
|
||||
|
||||
---
|
||||
src/mesa/state_tracker/st_cb_texture.c | 2 ++
|
||||
1 files changed, 2 insertions(+), 0 deletions(-)
|
||||
|
||||
diff --git a/src/mesa/state_tracker/st_cb_texture.c b/src/mesa/state_tracker/st_cb_texture.c
|
||||
index 90a059c..019edb7 100644
|
||||
--- a/src/mesa/state_tracker/st_cb_texture.c
|
||||
+++ b/src/mesa/state_tracker/st_cb_texture.c
|
||||
@@ -119,6 +119,7 @@ static GLboolean
|
||||
is_compressed_mesa_format(const struct gl_texture_format *format)
|
||||
{
|
||||
switch (format->MesaFormat) {
|
||||
+#if FEATURE_texture_s3tc
|
||||
case MESA_FORMAT_RGB_DXT1:
|
||||
case MESA_FORMAT_RGBA_DXT1:
|
||||
case MESA_FORMAT_RGBA_DXT3:
|
||||
@@ -128,6 +129,7 @@ is_compressed_mesa_format(const struct gl_texture_format *format)
|
||||
case MESA_FORMAT_SRGBA_DXT3:
|
||||
case MESA_FORMAT_SRGBA_DXT5:
|
||||
return GL_TRUE;
|
||||
+#endif
|
||||
default:
|
||||
return GL_FALSE;
|
||||
}
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,25 @@
|
||||
From 6d710440334e321ebccaf2530cedfc161bf6aafc Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 13:24:37 -0600
|
||||
Subject: [PATCH 03/14] mesa: silence warning
|
||||
|
||||
---
|
||||
src/mesa/main/fbobject.c | 2 ++
|
||||
1 files changed, 2 insertions(+), 0 deletions(-)
|
||||
|
||||
diff --git a/src/mesa/main/fbobject.c b/src/mesa/main/fbobject.c
|
||||
index 825a230..877ec00 100644
|
||||
--- a/src/mesa/main/fbobject.c
|
||||
+++ b/src/mesa/main/fbobject.c
|
||||
@@ -644,6 +644,8 @@ _mesa_test_framebuffer_completeness(GLcontext *ctx, struct gl_framebuffer *fb)
|
||||
return;
|
||||
}
|
||||
}
|
||||
+#else
|
||||
+ (void) j;
|
||||
#endif
|
||||
|
||||
if (numImages == 0) {
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,80 @@
|
||||
From afb6542cd49f8188ec9857664f99a4e3444db98c Mon Sep 17 00:00:00 2001
|
||||
From: Chia-I Wu <olvaffe@gmail.com>
|
||||
Date: Thu, 3 Sep 2009 11:03:20 +0800
|
||||
Subject: [PATCH 04/14] glapi: Prefix includes with glapi.
|
||||
|
||||
This allows different sets of generated headers to be used.
|
||||
---
|
||||
src/mesa/glapi/glapi.c | 8 ++++----
|
||||
src/mesa/glapi/glapi_getproc.c | 8 ++++----
|
||||
src/mesa/glapi/glthread.c | 2 +-
|
||||
3 files changed, 9 insertions(+), 9 deletions(-)
|
||||
|
||||
diff --git a/src/mesa/glapi/glapi.c b/src/mesa/glapi/glapi.c
|
||||
index e36fccb..ad72fe4 100644
|
||||
--- a/src/mesa/glapi/glapi.c
|
||||
+++ b/src/mesa/glapi/glapi.c
|
||||
@@ -69,9 +69,9 @@
|
||||
#include <assert.h>
|
||||
#endif
|
||||
|
||||
-#include "glapi.h"
|
||||
-#include "glapioffsets.h"
|
||||
-#include "glapitable.h"
|
||||
+#include "glapi/glapi.h"
|
||||
+#include "glapi/glapioffsets.h"
|
||||
+#include "glapi/glapitable.h"
|
||||
|
||||
|
||||
/***** BEGIN NO-OP DISPATCH *****/
|
||||
@@ -145,7 +145,7 @@ static GLint NoOpUnused(void)
|
||||
return 0;
|
||||
}
|
||||
|
||||
-#include "glapitemp.h"
|
||||
+#include "glapi/glapitemp.h"
|
||||
|
||||
/***** END NO-OP DISPATCH *****/
|
||||
|
||||
diff --git a/src/mesa/glapi/glapi_getproc.c b/src/mesa/glapi/glapi_getproc.c
|
||||
index ed443c1..decdd05 100644
|
||||
--- a/src/mesa/glapi/glapi_getproc.c
|
||||
+++ b/src/mesa/glapi/glapi_getproc.c
|
||||
@@ -34,9 +34,9 @@
|
||||
#include <string.h>
|
||||
#include "main/glheader.h"
|
||||
#include "main/compiler.h"
|
||||
-#include "glapi.h"
|
||||
-#include "glapioffsets.h"
|
||||
-#include "glapitable.h"
|
||||
+#include "glapi/glapi.h"
|
||||
+#include "glapi/glapioffsets.h"
|
||||
+#include "glapi/glapitable.h"
|
||||
|
||||
|
||||
static void
|
||||
@@ -75,7 +75,7 @@ str_dup(const char *str)
|
||||
#endif
|
||||
|
||||
/* The code in this file is auto-generated with Python */
|
||||
-#include "glprocs.h"
|
||||
+#include "glapi/glprocs.h"
|
||||
|
||||
|
||||
/**
|
||||
diff --git a/src/mesa/glapi/glthread.c b/src/mesa/glapi/glthread.c
|
||||
index 737fd4d..dc90b36 100644
|
||||
--- a/src/mesa/glapi/glthread.c
|
||||
+++ b/src/mesa/glapi/glthread.c
|
||||
@@ -33,7 +33,7 @@
|
||||
#endif
|
||||
|
||||
#include "main/compiler.h"
|
||||
-#include "glthread.h"
|
||||
+#include "glapi/glthread.h"
|
||||
|
||||
|
||||
/*
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,329 @@
|
||||
From 8c7897870af76e1e6ce809ec81b99f33383053d7 Mon Sep 17 00:00:00 2001
|
||||
From: Chia-I Wu <olvaffe@gmail.com>
|
||||
Date: Thu, 3 Sep 2009 11:05:06 +0800
|
||||
Subject: [PATCH 05/14] glapi: Add OpenGL ES compatibility mode to scripts.
|
||||
|
||||
When the mode is on, the scripts would generate headers that are
|
||||
suitable for OpenGL ES overlay, that will be later introduced.
|
||||
---
|
||||
src/mesa/glapi/gl_offsets.py | 25 +++++++++++----
|
||||
src/mesa/glapi/gl_procs.py | 27 ++++++++++++++---
|
||||
src/mesa/glapi/gl_table.py | 67 +++++++++++++++++++++++++++++------------
|
||||
3 files changed, 87 insertions(+), 32 deletions(-)
|
||||
|
||||
diff --git a/src/mesa/glapi/gl_offsets.py b/src/mesa/glapi/gl_offsets.py
|
||||
index 59f8d37..197efca 100644
|
||||
--- a/src/mesa/glapi/gl_offsets.py
|
||||
+++ b/src/mesa/glapi/gl_offsets.py
|
||||
@@ -30,9 +30,10 @@ import license
|
||||
import sys, getopt
|
||||
|
||||
class PrintGlOffsets(gl_XML.gl_print_base):
|
||||
- def __init__(self):
|
||||
+ def __init__(self, es=False):
|
||||
gl_XML.gl_print_base.__init__(self)
|
||||
|
||||
+ self.es = es
|
||||
self.name = "gl_offsets.py (from Mesa)"
|
||||
self.header_tag = '_GLAPI_OFFSETS_H_'
|
||||
self.license = license.bsd_license_template % ( \
|
||||
@@ -56,7 +57,9 @@ class PrintGlOffsets(gl_XML.gl_print_base):
|
||||
|
||||
|
||||
for f in abi_functions:
|
||||
- print '#define _gloffset_%s %d' % (f.name, f.offset)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define _gloffset_%s %d' % (name, f.offset)
|
||||
last_static = f.offset
|
||||
|
||||
print ''
|
||||
@@ -64,7 +67,9 @@ class PrintGlOffsets(gl_XML.gl_print_base):
|
||||
print ''
|
||||
|
||||
for [f, index] in functions:
|
||||
- print '#define _gloffset_%s %d' % (f.name, f.offset)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define _gloffset_%s %d' % (name, f.offset)
|
||||
|
||||
print '#define _gloffset_FIRST_DYNAMIC %d' % (api.next_offset)
|
||||
|
||||
@@ -73,7 +78,9 @@ class PrintGlOffsets(gl_XML.gl_print_base):
|
||||
print ''
|
||||
|
||||
for [f, index] in functions:
|
||||
- print '#define _gloffset_%s driDispatchRemapTable[%s_remap_index]' % (f.name, f.name)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define _gloffset_%s driDispatchRemapTable[%s_remap_index]' % (name, f.name)
|
||||
|
||||
print ''
|
||||
print '#endif /* !defined(IN_DRI_DRIVER) */'
|
||||
@@ -82,22 +89,26 @@ class PrintGlOffsets(gl_XML.gl_print_base):
|
||||
|
||||
|
||||
def show_usage():
|
||||
- print "Usage: %s [-f input_file_name]" % sys.argv[0]
|
||||
+ print "Usage: %s [-f input_file_name] [-c]" % sys.argv[0]
|
||||
+ print " -c Enable compability with OpenGL ES."
|
||||
sys.exit(1)
|
||||
|
||||
if __name__ == '__main__':
|
||||
file_name = "gl_API.xml"
|
||||
|
||||
try:
|
||||
- (args, trail) = getopt.getopt(sys.argv[1:], "f:")
|
||||
+ (args, trail) = getopt.getopt(sys.argv[1:], "f:c")
|
||||
except Exception,e:
|
||||
show_usage()
|
||||
|
||||
+ es = False
|
||||
for (arg,val) in args:
|
||||
if arg == "-f":
|
||||
file_name = val
|
||||
+ elif arg == "-c":
|
||||
+ es = True
|
||||
|
||||
api = gl_XML.parse_GL_API( file_name )
|
||||
|
||||
- printer = PrintGlOffsets()
|
||||
+ printer = PrintGlOffsets(es)
|
||||
printer.Print( api )
|
||||
diff --git a/src/mesa/glapi/gl_procs.py b/src/mesa/glapi/gl_procs.py
|
||||
index cd1a68c..4af96ad 100644
|
||||
--- a/src/mesa/glapi/gl_procs.py
|
||||
+++ b/src/mesa/glapi/gl_procs.py
|
||||
@@ -30,9 +30,10 @@ import gl_XML, glX_XML
|
||||
import sys, getopt
|
||||
|
||||
class PrintGlProcs(gl_XML.gl_print_base):
|
||||
- def __init__(self, long_strings):
|
||||
+ def __init__(self, long_strings, es=False):
|
||||
gl_XML.gl_print_base.__init__(self)
|
||||
|
||||
+ self.es = es
|
||||
self.long_strings = long_strings
|
||||
self.name = "gl_procs.py (from Mesa)"
|
||||
self.license = license.bsd_license_template % ( \
|
||||
@@ -85,6 +86,18 @@ typedef struct {
|
||||
|
||||
def printBody(self, api):
|
||||
print ''
|
||||
+ if self.es:
|
||||
+ print '/* OpenGL ES specific prototypes */'
|
||||
+ for func in api.functionIterateByOffset():
|
||||
+ for n in func.entry_points:
|
||||
+ cat, num = api.get_category_for_name(n)
|
||||
+ if ((cat.startswith("es") and not (cat.endswith("core") or cat.endswith("compat"))) or
|
||||
+ cat.startswith("GL_OES")):
|
||||
+ print '/* category %s */' % api.get_category_for_name(n)[0]
|
||||
+ print 'GLAPI %s GLAPIENTRY %s(%s);' \
|
||||
+ % (func.return_type, "gl" + n, func.get_parameter_string(n))
|
||||
+ print ''
|
||||
+
|
||||
if self.long_strings:
|
||||
print 'static const char gl_string_table[] ='
|
||||
else:
|
||||
@@ -155,8 +168,9 @@ typedef struct {
|
||||
|
||||
|
||||
def show_usage():
|
||||
- print "Usage: %s [-f input_file_name] [-m mode]" % sys.argv[0]
|
||||
- print "mode can be one of:"
|
||||
+ print "Usage: %s [-f input_file_name] [-m mode] [-c]" % sys.argv[0]
|
||||
+ print "-c Enable compability with OpenGL ES."
|
||||
+ print "-m mode mode can be one of:"
|
||||
print " long - Create code for compilers that can handle very"
|
||||
print " long string constants. (default)"
|
||||
print " short - Create code for compilers that can only handle"
|
||||
@@ -167,11 +181,12 @@ if __name__ == '__main__':
|
||||
file_name = "gl_API.xml"
|
||||
|
||||
try:
|
||||
- (args, trail) = getopt.getopt(sys.argv[1:], "f:m:")
|
||||
+ (args, trail) = getopt.getopt(sys.argv[1:], "f:m:c")
|
||||
except Exception,e:
|
||||
show_usage()
|
||||
|
||||
long_string = 1
|
||||
+ es = False
|
||||
for (arg,val) in args:
|
||||
if arg == "-f":
|
||||
file_name = val
|
||||
@@ -182,7 +197,9 @@ if __name__ == '__main__':
|
||||
long_string = 1
|
||||
else:
|
||||
show_usage()
|
||||
+ elif arg == "-c":
|
||||
+ es = True
|
||||
|
||||
api = gl_XML.parse_GL_API(file_name, glX_XML.glx_item_factory())
|
||||
- printer = PrintGlProcs(long_string)
|
||||
+ printer = PrintGlProcs(long_string, es)
|
||||
printer.Print(api)
|
||||
diff --git a/src/mesa/glapi/gl_table.py b/src/mesa/glapi/gl_table.py
|
||||
index 55a3374..611dfd2 100644
|
||||
--- a/src/mesa/glapi/gl_table.py
|
||||
+++ b/src/mesa/glapi/gl_table.py
|
||||
@@ -30,9 +30,10 @@ import license
|
||||
import sys, getopt
|
||||
|
||||
class PrintGlTable(gl_XML.gl_print_base):
|
||||
- def __init__(self):
|
||||
+ def __init__(self, es=False):
|
||||
gl_XML.gl_print_base.__init__(self)
|
||||
|
||||
+ self.es = es
|
||||
self.header_tag = '_GLAPI_TABLE_H_'
|
||||
self.name = "gl_table.py (from Mesa)"
|
||||
self.license = license.bsd_license_template % ( \
|
||||
@@ -42,10 +43,27 @@ class PrintGlTable(gl_XML.gl_print_base):
|
||||
|
||||
|
||||
def printBody(self, api):
|
||||
+ if self.es:
|
||||
+ typedefs = []
|
||||
+ for t in api.typeIterate():
|
||||
+ if t.name == "fixed":
|
||||
+ typedefs.append("typedef int GLfixed;")
|
||||
+ elif t.name == "clampx":
|
||||
+ typedefs.append("typedef int GLclampx;")
|
||||
+ if typedefs:
|
||||
+ print '#ifndef HAVE_GLES_TYPES'
|
||||
+ print "\n".join(typedefs)
|
||||
+ print '#endif'
|
||||
+ print ''
|
||||
+ print 'struct _glapi_table'
|
||||
+ print '{'
|
||||
+
|
||||
for f in api.functionIterateByOffset():
|
||||
arg_string = f.get_parameter_string()
|
||||
print ' %s (GLAPIENTRYP %s)(%s); /* %d */' % (f.return_type, f.name, arg_string, f.offset)
|
||||
|
||||
+ print '};'
|
||||
+
|
||||
|
||||
def printRealHeader(self):
|
||||
print '#ifndef GLAPIENTRYP'
|
||||
@@ -56,21 +74,18 @@ class PrintGlTable(gl_XML.gl_print_base):
|
||||
print '# define GLAPIENTRYP GLAPIENTRY *'
|
||||
print '#endif'
|
||||
print ''
|
||||
- print ''
|
||||
- print 'struct _glapi_table'
|
||||
- print '{'
|
||||
return
|
||||
|
||||
|
||||
def printRealFooter(self):
|
||||
- print '};'
|
||||
return
|
||||
|
||||
|
||||
class PrintRemapTable(gl_XML.gl_print_base):
|
||||
- def __init__(self):
|
||||
+ def __init__(self, es=False):
|
||||
gl_XML.gl_print_base.__init__(self)
|
||||
|
||||
+ self.es = es
|
||||
self.header_tag = '_DISPATCH_H_'
|
||||
self.name = "gl_table.py (from Mesa)"
|
||||
self.license = license.bsd_license_template % ("(C) Copyright IBM Corporation 2005", "IBM")
|
||||
@@ -127,9 +142,11 @@ class PrintRemapTable(gl_XML.gl_print_base):
|
||||
|
||||
|
||||
for f in abi_functions:
|
||||
- print '#define CALL_%s(disp, parameters) (*((disp)->%s)) parameters' % (f.name, f.name)
|
||||
- print '#define GET_%s(disp) ((disp)->%s)' % (f.name, f.name)
|
||||
- print '#define SET_%s(disp, fn) ((disp)->%s = fn)' % (f.name, f.name)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define CALL_%s(disp, parameters) (*((disp)->%s)) parameters' % (name, f.name)
|
||||
+ print '#define GET_%s(disp) ((disp)->%s)' % (name, f.name)
|
||||
+ print '#define SET_%s(disp, fn) ((disp)->%s = fn)' % (name, f.name)
|
||||
|
||||
|
||||
print ''
|
||||
@@ -137,9 +154,11 @@ class PrintRemapTable(gl_XML.gl_print_base):
|
||||
print ''
|
||||
|
||||
for [f, index] in functions:
|
||||
- print '#define CALL_%s(disp, parameters) (*((disp)->%s)) parameters' % (f.name, f.name)
|
||||
- print '#define GET_%s(disp) ((disp)->%s)' % (f.name, f.name)
|
||||
- print '#define SET_%s(disp, fn) ((disp)->%s = fn)' % (f.name, f.name)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define CALL_%s(disp, parameters) (*((disp)->%s)) parameters' % (name, f.name)
|
||||
+ print '#define GET_%s(disp) ((disp)->%s)' % (name, f.name)
|
||||
+ print '#define SET_%s(disp, fn) ((disp)->%s = fn)' % (name, f.name)
|
||||
|
||||
print ''
|
||||
print '#else'
|
||||
@@ -149,7 +168,9 @@ class PrintRemapTable(gl_XML.gl_print_base):
|
||||
print ''
|
||||
|
||||
for [f, index] in functions:
|
||||
- print '#define %s_remap_index %u' % (f.name, index)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define %s_remap_index %u' % (name, index)
|
||||
|
||||
print ''
|
||||
|
||||
@@ -157,9 +178,11 @@ class PrintRemapTable(gl_XML.gl_print_base):
|
||||
arg_string = gl_XML.create_parameter_string( f.parameters, 0 )
|
||||
cast = '%s (GLAPIENTRYP)(%s)' % (f.return_type, arg_string)
|
||||
|
||||
- print '#define CALL_%s(disp, parameters) CALL_by_offset(disp, (%s), driDispatchRemapTable[%s_remap_index], parameters)' % (f.name, cast, f.name)
|
||||
- print '#define GET_%s(disp) GET_by_offset(disp, driDispatchRemapTable[%s_remap_index])' % (f.name, f.name)
|
||||
- print '#define SET_%s(disp, fn) SET_by_offset(disp, driDispatchRemapTable[%s_remap_index], fn)' % (f.name, f.name)
|
||||
+ for name in f.entry_points:
|
||||
+ if name == f.name or self.es:
|
||||
+ print '#define CALL_%s(disp, parameters) CALL_by_offset(disp, (%s), driDispatchRemapTable[%s_remap_index], parameters)' % (name, cast, f.name)
|
||||
+ print '#define GET_%s(disp) GET_by_offset(disp, driDispatchRemapTable[%s_remap_index])' % (name, f.name)
|
||||
+ print '#define SET_%s(disp, fn) SET_by_offset(disp, driDispatchRemapTable[%s_remap_index], fn)' % (name, f.name)
|
||||
|
||||
|
||||
print ''
|
||||
@@ -168,29 +191,33 @@ class PrintRemapTable(gl_XML.gl_print_base):
|
||||
|
||||
|
||||
def show_usage():
|
||||
- print "Usage: %s [-f input_file_name] [-m mode]" % sys.argv[0]
|
||||
+ print "Usage: %s [-f input_file_name] [-m mode] [-c]" % sys.argv[0]
|
||||
print " -m mode Mode can be 'table' or 'remap_table'."
|
||||
+ print " -c Enable compability with OpenGL ES."
|
||||
sys.exit(1)
|
||||
|
||||
if __name__ == '__main__':
|
||||
file_name = "gl_API.xml"
|
||||
|
||||
try:
|
||||
- (args, trail) = getopt.getopt(sys.argv[1:], "f:m:")
|
||||
+ (args, trail) = getopt.getopt(sys.argv[1:], "f:m:c")
|
||||
except Exception,e:
|
||||
show_usage()
|
||||
|
||||
mode = "table"
|
||||
+ es = False
|
||||
for (arg,val) in args:
|
||||
if arg == "-f":
|
||||
file_name = val
|
||||
elif arg == "-m":
|
||||
mode = val
|
||||
+ elif arg == "-c":
|
||||
+ es = True
|
||||
|
||||
if mode == "table":
|
||||
- printer = PrintGlTable()
|
||||
+ printer = PrintGlTable(es)
|
||||
elif mode == "remap_table":
|
||||
- printer = PrintRemapTable()
|
||||
+ printer = PrintRemapTable(es)
|
||||
else:
|
||||
show_usage()
|
||||
|
||||
--
|
||||
1.6.2.4
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,25 @@
|
||||
From a9293db50e645a44b8cc2c4b82f9dc521c27d076 Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 14:29:24 -0600
|
||||
Subject: [PATCH 09/14] es: update window title
|
||||
|
||||
---
|
||||
progs/es1/xegl/tri.c | 2 +-
|
||||
1 files changed, 1 insertions(+), 1 deletions(-)
|
||||
|
||||
diff --git a/progs/es1/xegl/tri.c b/progs/es1/xegl/tri.c
|
||||
index ca37c2d..233c021 100644
|
||||
--- a/progs/es1/xegl/tri.c
|
||||
+++ b/progs/es1/xegl/tri.c
|
||||
@@ -427,7 +427,7 @@ main(int argc, char *argv[])
|
||||
printf("EGL_CLIENT_APIS = %s\n", s);
|
||||
|
||||
make_x_window(x_dpy, egl_dpy,
|
||||
- "tri", 0, 0, winWidth, winHeight,
|
||||
+ "OpenGL ES 1.x tri", 0, 0, winWidth, winHeight,
|
||||
&win, &egl_ctx, &egl_surf);
|
||||
|
||||
XMapWindow(x_dpy, win);
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,22 @@
|
||||
From b8e64cc4390fb2f499f659374d8b4705846c7a19 Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 14:29:33 -0600
|
||||
Subject: [PATCH 10/14] es: updated Makefile comment
|
||||
|
||||
---
|
||||
progs/es1/xegl/Makefile | 2 +-
|
||||
1 files changed, 1 insertions(+), 1 deletions(-)
|
||||
|
||||
diff --git a/progs/es1/xegl/Makefile b/progs/es1/xegl/Makefile
|
||||
index fe0b05c..4b21ee3 100644
|
||||
--- a/progs/es1/xegl/Makefile
|
||||
+++ b/progs/es1/xegl/Makefile
|
||||
@@ -1,4 +1,4 @@
|
||||
-# progs/gles/xegl/Makefile
|
||||
+# progs/es1/xegl/Makefile
|
||||
|
||||
TOP = ../../..
|
||||
include $(TOP)/configs/current
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,594 @@
|
||||
From 96260c3e52d2f02170f935820d96ceef7a971e47 Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 14:29:47 -0600
|
||||
Subject: [PATCH 11/14] es: OpenGL ES 2.x demo programs
|
||||
|
||||
---
|
||||
progs/es2/xegl/Makefile | 51 +++++
|
||||
progs/es2/xegl/tri.c | 516 +++++++++++++++++++++++++++++++++++++++++++++++
|
||||
2 files changed, 567 insertions(+), 0 deletions(-)
|
||||
create mode 100644 progs/es2/xegl/Makefile
|
||||
create mode 100644 progs/es2/xegl/tri.c
|
||||
|
||||
diff --git a/progs/es2/xegl/Makefile b/progs/es2/xegl/Makefile
|
||||
new file mode 100644
|
||||
index 0000000..8904203
|
||||
--- /dev/null
|
||||
+++ b/progs/es2/xegl/Makefile
|
||||
@@ -0,0 +1,51 @@
|
||||
+# progs/es/es2/xegl/Makefile
|
||||
+
|
||||
+TOP = ../../..
|
||||
+include $(TOP)/configs/current
|
||||
+
|
||||
+
|
||||
+INCLUDE_DIRS = \
|
||||
+ -I$(TOP)/include \
|
||||
+
|
||||
+HEADERS = $(TOP)/include/GLES/egl.h
|
||||
+
|
||||
+
|
||||
+ES2_LIB_DEPS = \
|
||||
+ $(TOP)/$(LIB_DIR)/libEGL.so \
|
||||
+ $(TOP)/$(LIB_DIR)/libGLESv2.so
|
||||
+
|
||||
+
|
||||
+ES2_LIBS = \
|
||||
+ -L$(TOP)/$(LIB_DIR) -lEGL \
|
||||
+ -L$(TOP)/$(LIB_DIR) -lGLESv2 $(LIBDRM_LIB)
|
||||
+
|
||||
+PROGRAMS = \
|
||||
+ es2_info \
|
||||
+ tri
|
||||
+
|
||||
+
|
||||
+.c.o:
|
||||
+ $(CC) -c $(INCLUDE_DIRS) $(CFLAGS) $< -o $@
|
||||
+
|
||||
+
|
||||
+
|
||||
+default: $(PROGRAMS)
|
||||
+
|
||||
+
|
||||
+
|
||||
+es2_info.c:
|
||||
+ cp ../../es1/xegl/es1_info.c es2_info.c
|
||||
+
|
||||
+es2_info: es2_info.o $(ES2_LIB_DEPS)
|
||||
+ $(CC) $(CFLAGS) es2_info.o $(ES2_LIBS) -o $@
|
||||
+
|
||||
+tri: tri.o $(ES2_LIB_DEPS)
|
||||
+ $(CC) $(CFLAGS) tri.o $(ES2_LIBS) -o $@
|
||||
+
|
||||
+
|
||||
+
|
||||
+clean:
|
||||
+ rm -f *.o *~
|
||||
+ rm -f $(PROGRAMS)
|
||||
+ rm -f es2_info.c
|
||||
+
|
||||
diff --git a/progs/es2/xegl/tri.c b/progs/es2/xegl/tri.c
|
||||
new file mode 100644
|
||||
index 0000000..7238369
|
||||
--- /dev/null
|
||||
+++ b/progs/es2/xegl/tri.c
|
||||
@@ -0,0 +1,516 @@
|
||||
+/**************************************************************************
|
||||
+ *
|
||||
+ * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
|
||||
+ * All Rights Reserved.
|
||||
+ *
|
||||
+ **************************************************************************/
|
||||
+
|
||||
+/*
|
||||
+ * Draw a triangle with X/EGL and OpenGL ES 2.x
|
||||
+ */
|
||||
+
|
||||
+#define USE_FULL_GL 0
|
||||
+
|
||||
+
|
||||
+
|
||||
+#include <assert.h>
|
||||
+#include <math.h>
|
||||
+#include <stdlib.h>
|
||||
+#include <stdio.h>
|
||||
+#include <string.h>
|
||||
+#include <X11/Xlib.h>
|
||||
+#include <X11/Xutil.h>
|
||||
+#include <X11/keysym.h>
|
||||
+#if USE_FULL_GL
|
||||
+#include <GL/gl.h> /* use full OpenGL */
|
||||
+#else
|
||||
+#include <GLES2/gl2.h> /* use OpenGL ES 2.x */
|
||||
+#endif
|
||||
+#include <EGL/egl.h>
|
||||
+
|
||||
+
|
||||
+#define FLOAT_TO_FIXED(X) ((X) * 65535.0)
|
||||
+
|
||||
+
|
||||
+
|
||||
+static GLfloat view_rotx = 0.0, view_roty = 0.0;
|
||||
+
|
||||
+static GLint u_matrix = -1;
|
||||
+static GLint attr_pos = 0, attr_color = 1;
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+make_z_rot_matrix(GLfloat angle, GLfloat *m)
|
||||
+{
|
||||
+ float c = cos(angle * M_PI / 180.0);
|
||||
+ float s = sin(angle * M_PI / 180.0);
|
||||
+ int i;
|
||||
+ for (i = 0; i < 16; i++)
|
||||
+ m[i] = 0.0;
|
||||
+ m[0] = m[5] = m[10] = m[15] = 1.0;
|
||||
+
|
||||
+ m[0] = c;
|
||||
+ m[1] = s;
|
||||
+ m[4] = -s;
|
||||
+ m[5] = c;
|
||||
+}
|
||||
+
|
||||
+static void
|
||||
+make_scale_matrix(GLfloat xs, GLfloat ys, GLfloat zs, GLfloat *m)
|
||||
+{
|
||||
+ int i;
|
||||
+ for (i = 0; i < 16; i++)
|
||||
+ m[i] = 0.0;
|
||||
+ m[0] = xs;
|
||||
+ m[5] = ys;
|
||||
+ m[10] = zs;
|
||||
+ m[15] = 1.0;
|
||||
+}
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+mul_matrix(GLfloat *prod, const GLfloat *a, const GLfloat *b)
|
||||
+{
|
||||
+#define A(row,col) a[(col<<2)+row]
|
||||
+#define B(row,col) b[(col<<2)+row]
|
||||
+#define P(row,col) p[(col<<2)+row]
|
||||
+ GLfloat p[16];
|
||||
+ GLint i;
|
||||
+ for (i = 0; i < 4; i++) {
|
||||
+ const GLfloat ai0=A(i,0), ai1=A(i,1), ai2=A(i,2), ai3=A(i,3);
|
||||
+ P(i,0) = ai0 * B(0,0) + ai1 * B(1,0) + ai2 * B(2,0) + ai3 * B(3,0);
|
||||
+ P(i,1) = ai0 * B(0,1) + ai1 * B(1,1) + ai2 * B(2,1) + ai3 * B(3,1);
|
||||
+ P(i,2) = ai0 * B(0,2) + ai1 * B(1,2) + ai2 * B(2,2) + ai3 * B(3,2);
|
||||
+ P(i,3) = ai0 * B(0,3) + ai1 * B(1,3) + ai2 * B(2,3) + ai3 * B(3,3);
|
||||
+ }
|
||||
+ memcpy(prod, p, sizeof(p));
|
||||
+#undef A
|
||||
+#undef B
|
||||
+#undef PROD
|
||||
+}
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+draw(void)
|
||||
+{
|
||||
+ static const GLfloat verts[3][2] = {
|
||||
+ { -1, -1 },
|
||||
+ { 1, -1 },
|
||||
+ { 0, 1 }
|
||||
+ };
|
||||
+ static const GLfloat colors[3][3] = {
|
||||
+ { 1, 0, 0 },
|
||||
+ { 0, 1, 0 },
|
||||
+ { 0, 0, 1 }
|
||||
+ };
|
||||
+ GLfloat mat[16], rot[16], scale[16];
|
||||
+
|
||||
+ /* Set modelview/projection matrix */
|
||||
+ make_z_rot_matrix(view_rotx, rot);
|
||||
+ make_scale_matrix(0.5, 0.5, 0.5, scale);
|
||||
+ mul_matrix(mat, rot, scale);
|
||||
+ glUniformMatrix4fv(u_matrix, 1, GL_FALSE, mat);
|
||||
+
|
||||
+ glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
+
|
||||
+ {
|
||||
+ glVertexAttribPointer(attr_pos, 2, GL_FLOAT, GL_FALSE, 0, verts);
|
||||
+ glVertexAttribPointer(attr_color, 3, GL_FLOAT, GL_FALSE, 0, colors);
|
||||
+ glEnableVertexAttribArray(attr_pos);
|
||||
+ glEnableVertexAttribArray(attr_color);
|
||||
+
|
||||
+ glDrawArrays(GL_TRIANGLES, 0, 3);
|
||||
+
|
||||
+ glDisableVertexAttribArray(attr_pos);
|
||||
+ glDisableVertexAttribArray(attr_color);
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+
|
||||
+/* new window size or exposure */
|
||||
+static void
|
||||
+reshape(int width, int height)
|
||||
+{
|
||||
+ glViewport(0, 0, (GLint) width, (GLint) height);
|
||||
+}
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+create_shaders(void)
|
||||
+{
|
||||
+ static const char *fragShaderText =
|
||||
+ "varying vec4 v_color;\n"
|
||||
+ "void main() {\n"
|
||||
+ " gl_FragColor = v_color;\n"
|
||||
+ "}\n";
|
||||
+ static const char *vertShaderText =
|
||||
+ "uniform mat4 modelviewProjection;\n"
|
||||
+ "attribute vec4 pos;\n"
|
||||
+ "attribute vec4 color;\n"
|
||||
+ "varying vec4 v_color;\n"
|
||||
+ "void main() {\n"
|
||||
+ " gl_Position = modelviewProjection * pos;\n"
|
||||
+ " v_color = color;\n"
|
||||
+ "}\n";
|
||||
+
|
||||
+ GLuint fragShader, vertShader, program;
|
||||
+ GLint stat;
|
||||
+
|
||||
+ fragShader = glCreateShader(GL_FRAGMENT_SHADER);
|
||||
+ glShaderSource(fragShader, 1, (const char **) &fragShaderText, NULL);
|
||||
+ glCompileShader(fragShader);
|
||||
+ glGetShaderiv(fragShader, GL_COMPILE_STATUS, &stat);
|
||||
+ if (!stat) {
|
||||
+ printf("Error: fragment shader did not compile!\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ vertShader = glCreateShader(GL_VERTEX_SHADER);
|
||||
+ glShaderSource(vertShader, 1, (const char **) &vertShaderText, NULL);
|
||||
+ glCompileShader(vertShader);
|
||||
+ glGetShaderiv(vertShader, GL_COMPILE_STATUS, &stat);
|
||||
+ if (!stat) {
|
||||
+ printf("Error: vertex shader did not compile!\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ program = glCreateProgram();
|
||||
+ glAttachShader(program, fragShader);
|
||||
+ glAttachShader(program, vertShader);
|
||||
+ glLinkProgram(program);
|
||||
+
|
||||
+ glGetProgramiv(program, GL_LINK_STATUS, &stat);
|
||||
+ if (!stat) {
|
||||
+ char log[1000];
|
||||
+ GLsizei len;
|
||||
+ glGetProgramInfoLog(program, 1000, &len, log);
|
||||
+ printf("Error: linking:\n%s\n", log);
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ glUseProgram(program);
|
||||
+
|
||||
+ if (1) {
|
||||
+ /* test setting attrib locations */
|
||||
+ glBindAttribLocation(program, attr_pos, "pos");
|
||||
+ glBindAttribLocation(program, attr_color, "color");
|
||||
+ glLinkProgram(program); /* needed to put attribs into effect */
|
||||
+ }
|
||||
+ else {
|
||||
+ /* test automatic attrib locations */
|
||||
+ attr_pos = glGetAttribLocation(program, "pos");
|
||||
+ attr_color = glGetAttribLocation(program, "color");
|
||||
+ }
|
||||
+
|
||||
+ u_matrix = glGetUniformLocation(program, "modelviewProjection");
|
||||
+ printf("Uniform modelviewProjection at %d\n", u_matrix);
|
||||
+ printf("Attrib pos at %d\n", attr_pos);
|
||||
+ printf("Attrib color at %d\n", attr_color);
|
||||
+}
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+init(void)
|
||||
+{
|
||||
+ typedef void (*proc)();
|
||||
+
|
||||
+#if 1 /* test code */
|
||||
+ proc p = eglGetProcAddress("eglCreateContext");
|
||||
+ assert(p);
|
||||
+ p = eglGetProcAddress("glMapBufferOES");
|
||||
+ assert(p);
|
||||
+#endif
|
||||
+
|
||||
+ glClearColor(0.4, 0.4, 0.4, 0.0);
|
||||
+
|
||||
+ create_shaders();
|
||||
+}
|
||||
+
|
||||
+
|
||||
+/*
|
||||
+ * Create an RGB, double-buffered X window.
|
||||
+ * Return the window and context handles.
|
||||
+ */
|
||||
+static void
|
||||
+make_x_window(Display *x_dpy, EGLDisplay egl_dpy,
|
||||
+ const char *name,
|
||||
+ int x, int y, int width, int height,
|
||||
+ Window *winRet,
|
||||
+ EGLContext *ctxRet,
|
||||
+ EGLSurface *surfRet)
|
||||
+{
|
||||
+ static const EGLint attribs[] = {
|
||||
+ EGL_RED_SIZE, 1,
|
||||
+ EGL_GREEN_SIZE, 1,
|
||||
+ EGL_BLUE_SIZE, 1,
|
||||
+ EGL_DEPTH_SIZE, 1,
|
||||
+ EGL_NONE
|
||||
+ };
|
||||
+ static const EGLint ctx_attribs[] = {
|
||||
+ EGL_CONTEXT_CLIENT_VERSION, 2,
|
||||
+ EGL_NONE
|
||||
+ };
|
||||
+ int scrnum;
|
||||
+ XSetWindowAttributes attr;
|
||||
+ unsigned long mask;
|
||||
+ Window root;
|
||||
+ Window win;
|
||||
+ XVisualInfo *visInfo, visTemplate;
|
||||
+ int num_visuals;
|
||||
+ EGLContext ctx;
|
||||
+ EGLConfig config;
|
||||
+ EGLint num_configs;
|
||||
+ EGLint vid;
|
||||
+
|
||||
+ scrnum = DefaultScreen( x_dpy );
|
||||
+ root = RootWindow( x_dpy, scrnum );
|
||||
+
|
||||
+ if (!eglChooseConfig( egl_dpy, attribs, &config, 1, &num_configs)) {
|
||||
+ printf("Error: couldn't get an EGL visual config\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ assert(config);
|
||||
+ assert(num_configs > 0);
|
||||
+
|
||||
+ if (!eglGetConfigAttrib(egl_dpy, config, EGL_NATIVE_VISUAL_ID, &vid)) {
|
||||
+ printf("Error: eglGetConfigAttrib() failed\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ /* The X window visual must match the EGL config */
|
||||
+ visTemplate.visualid = vid;
|
||||
+ visInfo = XGetVisualInfo(x_dpy, VisualIDMask, &visTemplate, &num_visuals);
|
||||
+ if (!visInfo) {
|
||||
+ printf("Error: couldn't get X visual\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ /* window attributes */
|
||||
+ attr.background_pixel = 0;
|
||||
+ attr.border_pixel = 0;
|
||||
+ attr.colormap = XCreateColormap( x_dpy, root, visInfo->visual, AllocNone);
|
||||
+ attr.event_mask = StructureNotifyMask | ExposureMask | KeyPressMask;
|
||||
+ mask = CWBackPixel | CWBorderPixel | CWColormap | CWEventMask;
|
||||
+
|
||||
+ win = XCreateWindow( x_dpy, root, 0, 0, width, height,
|
||||
+ 0, visInfo->depth, InputOutput,
|
||||
+ visInfo->visual, mask, &attr );
|
||||
+
|
||||
+ /* set hints and properties */
|
||||
+ {
|
||||
+ XSizeHints sizehints;
|
||||
+ sizehints.x = x;
|
||||
+ sizehints.y = y;
|
||||
+ sizehints.width = width;
|
||||
+ sizehints.height = height;
|
||||
+ sizehints.flags = USSize | USPosition;
|
||||
+ XSetNormalHints(x_dpy, win, &sizehints);
|
||||
+ XSetStandardProperties(x_dpy, win, name, name,
|
||||
+ None, (char **)NULL, 0, &sizehints);
|
||||
+ }
|
||||
+
|
||||
+#if USE_FULL_GL /* XXX fix this when eglBindAPI() works */
|
||||
+ eglBindAPI(EGL_OPENGL_API);
|
||||
+#else
|
||||
+ eglBindAPI(EGL_OPENGL_ES_API);
|
||||
+#endif
|
||||
+
|
||||
+ ctx = eglCreateContext(egl_dpy, config, EGL_NO_CONTEXT, ctx_attribs );
|
||||
+ if (!ctx) {
|
||||
+ printf("Error: eglCreateContext failed\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ /* test eglQueryContext() */
|
||||
+ {
|
||||
+ EGLint val;
|
||||
+ eglQueryContext(egl_dpy, ctx, EGL_CONTEXT_CLIENT_VERSION, &val);
|
||||
+ assert(val == 2);
|
||||
+ }
|
||||
+
|
||||
+ *surfRet = eglCreateWindowSurface(egl_dpy, config, win, NULL);
|
||||
+ if (!*surfRet) {
|
||||
+ printf("Error: eglCreateWindowSurface failed\n");
|
||||
+ exit(1);
|
||||
+ }
|
||||
+
|
||||
+ {
|
||||
+ EGLint val;
|
||||
+ eglQuerySurface(egl_dpy, *surfRet, EGL_WIDTH, &val);
|
||||
+ assert(val == width);
|
||||
+ eglQuerySurface(egl_dpy, *surfRet, EGL_HEIGHT, &val);
|
||||
+ assert(val == height);
|
||||
+ eglQuerySurface(egl_dpy, *surfRet, EGL_SURFACE_TYPE, &val);
|
||||
+ assert(val == EGL_WINDOW_BIT);
|
||||
+ }
|
||||
+
|
||||
+ XFree(visInfo);
|
||||
+
|
||||
+ *winRet = win;
|
||||
+ *ctxRet = ctx;
|
||||
+}
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+event_loop(Display *dpy, Window win,
|
||||
+ EGLDisplay egl_dpy, EGLSurface egl_surf)
|
||||
+{
|
||||
+ while (1) {
|
||||
+ int redraw = 0;
|
||||
+ XEvent event;
|
||||
+
|
||||
+ XNextEvent(dpy, &event);
|
||||
+
|
||||
+ switch (event.type) {
|
||||
+ case Expose:
|
||||
+ redraw = 1;
|
||||
+ break;
|
||||
+ case ConfigureNotify:
|
||||
+ reshape(event.xconfigure.width, event.xconfigure.height);
|
||||
+ break;
|
||||
+ case KeyPress:
|
||||
+ {
|
||||
+ char buffer[10];
|
||||
+ int r, code;
|
||||
+ code = XLookupKeysym(&event.xkey, 0);
|
||||
+ if (code == XK_Left) {
|
||||
+ view_roty += 5.0;
|
||||
+ }
|
||||
+ else if (code == XK_Right) {
|
||||
+ view_roty -= 5.0;
|
||||
+ }
|
||||
+ else if (code == XK_Up) {
|
||||
+ view_rotx += 5.0;
|
||||
+ }
|
||||
+ else if (code == XK_Down) {
|
||||
+ view_rotx -= 5.0;
|
||||
+ }
|
||||
+ else {
|
||||
+ r = XLookupString(&event.xkey, buffer, sizeof(buffer),
|
||||
+ NULL, NULL);
|
||||
+ if (buffer[0] == 27) {
|
||||
+ /* escape */
|
||||
+ return;
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ redraw = 1;
|
||||
+ break;
|
||||
+ default:
|
||||
+ ; /*no-op*/
|
||||
+ }
|
||||
+
|
||||
+ if (redraw) {
|
||||
+ draw();
|
||||
+ eglSwapBuffers(egl_dpy, egl_surf);
|
||||
+ }
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+
|
||||
+static void
|
||||
+usage(void)
|
||||
+{
|
||||
+ printf("Usage:\n");
|
||||
+ printf(" -display <displayname> set the display to run on\n");
|
||||
+ printf(" -info display OpenGL renderer info\n");
|
||||
+}
|
||||
+
|
||||
+
|
||||
+int
|
||||
+main(int argc, char *argv[])
|
||||
+{
|
||||
+ const int winWidth = 300, winHeight = 300;
|
||||
+ Display *x_dpy;
|
||||
+ Window win;
|
||||
+ EGLSurface egl_surf;
|
||||
+ EGLContext egl_ctx;
|
||||
+ EGLDisplay egl_dpy;
|
||||
+ char *dpyName = NULL;
|
||||
+ GLboolean printInfo = GL_FALSE;
|
||||
+ EGLint egl_major, egl_minor;
|
||||
+ int i;
|
||||
+ const char *s;
|
||||
+
|
||||
+ for (i = 1; i < argc; i++) {
|
||||
+ if (strcmp(argv[i], "-display") == 0) {
|
||||
+ dpyName = argv[i+1];
|
||||
+ i++;
|
||||
+ }
|
||||
+ else if (strcmp(argv[i], "-info") == 0) {
|
||||
+ printInfo = GL_TRUE;
|
||||
+ }
|
||||
+ else {
|
||||
+ usage();
|
||||
+ return -1;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ x_dpy = XOpenDisplay(dpyName);
|
||||
+ if (!x_dpy) {
|
||||
+ printf("Error: couldn't open display %s\n",
|
||||
+ dpyName ? dpyName : getenv("DISPLAY"));
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ egl_dpy = eglGetDisplay(x_dpy);
|
||||
+ if (!egl_dpy) {
|
||||
+ printf("Error: eglGetDisplay() failed\n");
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ if (!eglInitialize(egl_dpy, &egl_major, &egl_minor)) {
|
||||
+ printf("Error: eglInitialize() failed\n");
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ s = eglQueryString(egl_dpy, EGL_VERSION);
|
||||
+ printf("EGL_VERSION = %s\n", s);
|
||||
+
|
||||
+ s = eglQueryString(egl_dpy, EGL_VENDOR);
|
||||
+ printf("EGL_VENDOR = %s\n", s);
|
||||
+
|
||||
+ s = eglQueryString(egl_dpy, EGL_EXTENSIONS);
|
||||
+ printf("EGL_EXTENSIONS = %s\n", s);
|
||||
+
|
||||
+ s = eglQueryString(egl_dpy, EGL_CLIENT_APIS);
|
||||
+ printf("EGL_CLIENT_APIS = %s\n", s);
|
||||
+
|
||||
+ make_x_window(x_dpy, egl_dpy,
|
||||
+ "OpenGL ES 2.x tri", 0, 0, winWidth, winHeight,
|
||||
+ &win, &egl_ctx, &egl_surf);
|
||||
+
|
||||
+ XMapWindow(x_dpy, win);
|
||||
+ if (!eglMakeCurrent(egl_dpy, egl_surf, egl_surf, egl_ctx)) {
|
||||
+ printf("Error: eglMakeCurrent() failed\n");
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ if (printInfo) {
|
||||
+ printf("GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER));
|
||||
+ printf("GL_VERSION = %s\n", (char *) glGetString(GL_VERSION));
|
||||
+ printf("GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR));
|
||||
+ printf("GL_EXTENSIONS = %s\n", (char *) glGetString(GL_EXTENSIONS));
|
||||
+ }
|
||||
+
|
||||
+ init();
|
||||
+
|
||||
+ /* Set initial projection/viewing transformation.
|
||||
+ * We can't be sure we'll get a ConfigureNotify event when the window
|
||||
+ * first appears.
|
||||
+ */
|
||||
+ reshape(winWidth, winHeight);
|
||||
+
|
||||
+ event_loop(x_dpy, win, egl_dpy, egl_surf);
|
||||
+
|
||||
+ eglDestroyContext(egl_dpy, egl_ctx);
|
||||
+ eglDestroySurface(egl_dpy, egl_surf);
|
||||
+ eglTerminate(egl_dpy);
|
||||
+
|
||||
+
|
||||
+ XDestroyWindow(x_dpy, win);
|
||||
+ XCloseDisplay(x_dpy);
|
||||
+
|
||||
+ return 0;
|
||||
+}
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,22 @@
|
||||
From ea625e90c1f9058a67e1a7906c8dce3224e2ee13 Mon Sep 17 00:00:00 2001
|
||||
From: Brian Paul <brianp@vmware.com>
|
||||
Date: Tue, 12 May 2009 14:30:40 -0600
|
||||
Subject: [PATCH 12/14] es: fix comment
|
||||
|
||||
---
|
||||
progs/es2/xegl/Makefile | 2 +-
|
||||
1 files changed, 1 insertions(+), 1 deletions(-)
|
||||
|
||||
diff --git a/progs/es2/xegl/Makefile b/progs/es2/xegl/Makefile
|
||||
index 8904203..bd5611a 100644
|
||||
--- a/progs/es2/xegl/Makefile
|
||||
+++ b/progs/es2/xegl/Makefile
|
||||
@@ -1,4 +1,4 @@
|
||||
-# progs/es/es2/xegl/Makefile
|
||||
+# progs/es2/xegl/Makefile
|
||||
|
||||
TOP = ../../..
|
||||
include $(TOP)/configs/current
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,39 @@
|
||||
From ba0efedd82bcbbd12fcced80fd72e7f5cd4ca55d Mon Sep 17 00:00:00 2001
|
||||
From: Chia-I Wu <olvaffe@gmail.com>
|
||||
Date: Thu, 3 Sep 2009 11:27:30 +0800
|
||||
Subject: [PATCH 13/14] progs/es: Link to libX11.
|
||||
|
||||
---
|
||||
progs/es1/xegl/Makefile | 2 +-
|
||||
progs/es2/xegl/Makefile | 2 +-
|
||||
2 files changed, 2 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/progs/es1/xegl/Makefile b/progs/es1/xegl/Makefile
|
||||
index 4b21ee3..7f684d6 100644
|
||||
--- a/progs/es1/xegl/Makefile
|
||||
+++ b/progs/es1/xegl/Makefile
|
||||
@@ -17,7 +17,7 @@ ES1_LIB_DEPS = \
|
||||
|
||||
ES1_LIBS = \
|
||||
-L$(TOP)/$(LIB_DIR) -lEGL \
|
||||
- -L$(TOP)/$(LIB_DIR) -lGLESv1_CM $(LIBDRM_LIB)
|
||||
+ -L$(TOP)/$(LIB_DIR) -lGLESv1_CM $(LIBDRM_LIB) -lX11
|
||||
|
||||
PROGRAMS = \
|
||||
drawtex \
|
||||
diff --git a/progs/es2/xegl/Makefile b/progs/es2/xegl/Makefile
|
||||
index bd5611a..88bb012 100644
|
||||
--- a/progs/es2/xegl/Makefile
|
||||
+++ b/progs/es2/xegl/Makefile
|
||||
@@ -17,7 +17,7 @@ ES2_LIB_DEPS = \
|
||||
|
||||
ES2_LIBS = \
|
||||
-L$(TOP)/$(LIB_DIR) -lEGL \
|
||||
- -L$(TOP)/$(LIB_DIR) -lGLESv2 $(LIBDRM_LIB)
|
||||
+ -L$(TOP)/$(LIB_DIR) -lGLESv2 $(LIBDRM_LIB) -lX11
|
||||
|
||||
PROGRAMS = \
|
||||
es2_info \
|
||||
--
|
||||
1.6.2.4
|
||||
|
@ -0,0 +1,208 @@
|
||||
From 5d16f7dc6922ae26b23080ec8cbe62c94580893a Mon Sep 17 00:00:00 2001
|
||||
From: Chia-I Wu <olvaffe@gmail.com>
|
||||
Date: Thu, 3 Sep 2009 11:31:17 +0800
|
||||
Subject: [PATCH 14/14] st/es: Add OpenGL ES state tracker.
|
||||
|
||||
---
|
||||
src/gallium/state_trackers/es/Makefile | 91 ++++++++++++++++++++++++
|
||||
src/gallium/state_trackers/es/st_es1_context.c | 41 +++++++++++
|
||||
src/gallium/state_trackers/es/st_es2_context.c | 41 +++++++++++
|
||||
3 files changed, 173 insertions(+), 0 deletions(-)
|
||||
create mode 100644 src/gallium/state_trackers/es/Makefile
|
||||
create mode 100644 src/gallium/state_trackers/es/st_es1_context.c
|
||||
create mode 100644 src/gallium/state_trackers/es/st_es2_context.c
|
||||
|
||||
diff --git a/src/gallium/state_trackers/es/Makefile b/src/gallium/state_trackers/es/Makefile
|
||||
new file mode 100644
|
||||
index 0000000..897d715
|
||||
--- /dev/null
|
||||
+++ b/src/gallium/state_trackers/es/Makefile
|
||||
@@ -0,0 +1,91 @@
|
||||
+# src/gallium/state_trackers/es/Makefile
|
||||
+
|
||||
+# Build the ES 1/2 state tracker libraries
|
||||
+# This consists of core Mesa ES, plus GL/gallium state tracker plus.
|
||||
+
|
||||
+TOP = ../../../..
|
||||
+include $(TOP)/configs/current
|
||||
+
|
||||
+GLES_1_VERSION_MAJOR = 1
|
||||
+GLES_1_VERSION_MINOR = 1
|
||||
+GLES_1_VERSION_PATCH = 0
|
||||
+
|
||||
+GLES_2_VERSION_MAJOR = 2
|
||||
+GLES_2_VERSION_MINOR = 0
|
||||
+GLES_2_VERSION_PATCH = 0
|
||||
+
|
||||
+
|
||||
+# Maybe move these into configs/default:
|
||||
+GLES_1_LIB = GLESv1_CM
|
||||
+GLES_1_LIB_NAME = lib$(GLES_1_LIB).so
|
||||
+GLES_2_LIB = GLESv2
|
||||
+GLES_2_LIB_NAME = lib$(GLES_2_LIB).so
|
||||
+
|
||||
+
|
||||
+INCLUDE_DIRS = \
|
||||
+ -I$(TOP)/src/mesa \
|
||||
+ -I$(TOP)/include
|
||||
+
|
||||
+ES1_SOURCES = \
|
||||
+ st_es1_context.c \
|
||||
+
|
||||
+ES1_OBJECTS = $(ES1_SOURCES:.c=.o)
|
||||
+
|
||||
+ES2_SOURCES = \
|
||||
+ st_es2_context.c \
|
||||
+
|
||||
+ES2_OBJECTS = $(ES2_SOURCES:.c=.o)
|
||||
+
|
||||
+
|
||||
+# we only need the gallium libs that the state trackers directly use:
|
||||
+GALLIUM_LIBS = \
|
||||
+ $(TOP)/src/gallium/auxiliary/cso_cache/libcso_cache.a \
|
||||
+ $(TOP)/src/gallium/auxiliary/rtasm/librtasm.a \
|
||||
+ $(TOP)/src/gallium/auxiliary/tgsi/libtgsi.a \
|
||||
+ $(TOP)/src/gallium/auxiliary/util/libutil.a
|
||||
+
|
||||
+ES1_LIBS = \
|
||||
+ $(TOP)/src/mesa/es/libes1gallium.a \
|
||||
+ $(TOP)/src/mesa/es/libes1api.a
|
||||
+
|
||||
+ES2_LIBS = \
|
||||
+ $(TOP)/src/mesa/es/libes2gallium.a \
|
||||
+ $(TOP)/src/mesa/es/libes2api.a
|
||||
+
|
||||
+SYS_LIBS = -lm -pthread
|
||||
+
|
||||
+
|
||||
+.c.o:
|
||||
+ $(CC) -c $(INCLUDE_DIRS) $(CFLAGS) $< -o $@
|
||||
+
|
||||
+
|
||||
+# Default: make both GL ES 1.1 and GL ES 2.0 libraries
|
||||
+default: $(TOP)/$(LIB_DIR)/$(GLES_1_LIB_NAME) $(TOP)/$(LIB_DIR)/$(GLES_2_LIB_NAME)
|
||||
+
|
||||
+# Make the shared libs
|
||||
+$(TOP)/$(LIB_DIR)/$(GLES_1_LIB_NAME): $(ES1_OBJECTS) $(ES1_LIBS)
|
||||
+ $(TOP)/bin/mklib -o $(GLES_1_LIB) \
|
||||
+ -major $(GLES_1_VERSION_MAJOR) \
|
||||
+ -minor $(GLES_1_VERSION_MINOR) \
|
||||
+ -patch $(GLES_1_VERSION_PATCH) \
|
||||
+ -install $(TOP)/$(LIB_DIR) \
|
||||
+ $(ES1_OBJECTS) \
|
||||
+ -Wl,--whole-archive $(ES1_LIBS) -Wl,--no-whole-archive \
|
||||
+ -Wl,--start-group $(GALLIUM_LIBS) -Wl,--end-group \
|
||||
+ $(SYS_LIBS)
|
||||
+
|
||||
+$(TOP)/$(LIB_DIR)/$(GLES_2_LIB_NAME): $(ES2_OBJECTS) $(ES1_LIBS)
|
||||
+ $(TOP)/bin/mklib -o $(GLES_2_LIB) \
|
||||
+ -major $(GLES_2_VERSION_MAJOR) \
|
||||
+ -minor $(GLES_2_VERSION_MINOR) \
|
||||
+ -patch $(GLES_2_VERSION_PATCH) \
|
||||
+ -install $(TOP)/$(LIB_DIR) \
|
||||
+ $(ES2_OBJECTS) \
|
||||
+ -Wl,--whole-archive $(ES2_LIBS) -Wl,--no-whole-archive \
|
||||
+ -Wl,--start-group $(GALLIUM_LIBS) -Wl,--end-group \
|
||||
+ $(SYS_LIBS)
|
||||
+
|
||||
+clean:
|
||||
+ -rm -f *.o *~
|
||||
+ -rm -f $(TOP)/$(LIB_DIR)/$(GLES_1_LIB_NAME)* $(TOP)/$(LIB_DIR)/$(GLES_2_LIB_NAME)*
|
||||
+ -rm -f *.pyc
|
||||
diff --git a/src/gallium/state_trackers/es/st_es1_context.c b/src/gallium/state_trackers/es/st_es1_context.c
|
||||
new file mode 100644
|
||||
index 0000000..46daf54
|
||||
--- /dev/null
|
||||
+++ b/src/gallium/state_trackers/es/st_es1_context.c
|
||||
@@ -0,0 +1,41 @@
|
||||
+/**************************************************************************
|
||||
+ *
|
||||
+ * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
|
||||
+ * All Rights Reserved.
|
||||
+ *
|
||||
+ * Permission is hereby granted, free of charge, to any person obtaining a
|
||||
+ * copy of this software and associated documentation files (the "Software"),
|
||||
+ * to deal in the Software without restriction, including without limitation
|
||||
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
+ * and/or sell copies of the Software, and to permit persons to whom the
|
||||
+ * Software is furnished to do so, subject to the following conditions:
|
||||
+ *
|
||||
+ * The above copyright notice and this permission notice shall be included
|
||||
+ * in all copies or substantial portions of the Software.
|
||||
+ *
|
||||
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
+ * TUNGSTEN GRAPHICS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
+ * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
|
||||
+ * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
+ * SOFTWARE.
|
||||
+ **************************************************************************/
|
||||
+
|
||||
+
|
||||
+/**
|
||||
+ * Extra per-context init for OpenGL ES 1.x only.
|
||||
+ */
|
||||
+
|
||||
+
|
||||
+#include "main/context.h"
|
||||
+
|
||||
+
|
||||
+/**
|
||||
+ * Called from _mesa_initialize_context()
|
||||
+ */
|
||||
+void
|
||||
+_mesa_initialize_context_extra(GLcontext *ctx)
|
||||
+{
|
||||
+ /* nothing for ES 1.x */
|
||||
+}
|
||||
diff --git a/src/gallium/state_trackers/es/st_es2_context.c b/src/gallium/state_trackers/es/st_es2_context.c
|
||||
new file mode 100644
|
||||
index 0000000..982df70
|
||||
--- /dev/null
|
||||
+++ b/src/gallium/state_trackers/es/st_es2_context.c
|
||||
@@ -0,0 +1,41 @@
|
||||
+/**************************************************************************
|
||||
+ *
|
||||
+ * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
|
||||
+ * All Rights Reserved.
|
||||
+ *
|
||||
+ * Permission is hereby granted, free of charge, to any person obtaining a
|
||||
+ * copy of this software and associated documentation files (the "Software"),
|
||||
+ * to deal in the Software without restriction, including without limitation
|
||||
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
+ * and/or sell copies of the Software, and to permit persons to whom the
|
||||
+ * Software is furnished to do so, subject to the following conditions:
|
||||
+ *
|
||||
+ * The above copyright notice and this permission notice shall be included
|
||||
+ * in all copies or substantial portions of the Software.
|
||||
+ *
|
||||
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
+ * TUNGSTEN GRAPHICS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
+ * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
|
||||
+ * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
+ * SOFTWARE.
|
||||
+ **************************************************************************/
|
||||
+
|
||||
+
|
||||
+/**
|
||||
+ * Extra per-context init for OpenGL ES 2.x only.
|
||||
+ */
|
||||
+
|
||||
+
|
||||
+#include "main/context.h"
|
||||
+
|
||||
+
|
||||
+/**
|
||||
+ * Called from _mesa_initialize_context()
|
||||
+ */
|
||||
+void
|
||||
+_mesa_initialize_context_extra(GLcontext *ctx)
|
||||
+{
|
||||
+ ctx->Point.PointSprite = GL_TRUE; /* always on for ES 2.x */
|
||||
+}
|
||||
--
|
||||
1.6.2.4
|
||||
|
Loading…
x
Reference in New Issue
Block a user