Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
15a4a77a
Commit
15a4a77a
authored
Mar 04, 2001
by
Lionel Ulmer
Committed by
Alexandre Julliard
Mar 04, 2001
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- add tracing to OpenGL thunks
- update to latest gl.spec file
parent
0c2885e1
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
115 additions
and
58 deletions
+115
-58
make_opengl
dlls/opengl32/make_opengl
+113
-57
opengl32.spec
dlls/opengl32/opengl32.spec
+2
-1
opengl_ext.c
dlls/opengl32/opengl_ext.c
+0
-0
opengl_norm.c
dlls/opengl32/opengl_norm.c
+0
-0
No files found.
dlls/opengl32/make_opengl
View file @
15a4a77a
...
@@ -8,6 +8,8 @@
...
@@ -8,6 +8,8 @@
# spec files are located. These files are part of the OpenGL
# spec files are located. These files are part of the OpenGL
# sample implementation CVS tree and are located in
# sample implementation CVS tree and are located in
# CVS_ROOT/projects/ogl-sample/main/doc/registry/specs.
# CVS_ROOT/projects/ogl-sample/main/doc/registry/specs.
# You can find them on the web at the following URL :
# http://oss.sgi.com/cgi-bin/cvsweb.cgi/projects/ogl-sample/main/doc/registry/specs/
#
#
# - opengl_version is the OpenGL version emulated by the library
# - opengl_version is the OpenGL version emulated by the library
# (can be 1.0 to 1.2).
# (can be 1.0 to 1.2).
...
@@ -34,12 +36,95 @@
...
@@ -34,12 +36,95 @@
#
#
#
#
# Files to generate
#
$spec_file
=
"opengl32.spec"
;
$norm_file
=
"opengl_norm.c"
;
$ext_file
=
"opengl_ext.c"
;
# Set to 0 for removing the ENTER / LEAVE GL calls
$gen_thread_safe
=
1
;
# Prefix used for the local variables
$ext_prefix
=
"func_"
;
# If set to 1, generate TRACEs for each OpenGL function
$gen_traces
=
1
;
#
# List of categories to put in the 'opengl_norm.c' file
#
%
cat_1_0
=
(
"display-list"
=>
1
,
"drawing"
=>
1
,
"drawing-control"
=>
1
,
"feedback"
=>
1
,
"framebuf"
=>
1
,
"misc"
=>
1
,
"modeling"
=>
1
,
"pixel-op"
=>
1
,
"pixel-rw"
=>
1
,
"state-req"
=>
1
,
"xform"
=>
1
);
%
cat_1_1
=
(
%
cat_1_0
,
"1_1"
=>
1
);
%
cat_1_2
=
(
%
cat_1_1
,
"VERSION_1_2"
=>
1
,
"ARB_multitexture"
=>
1
);
%
norm_categories
=
();
#
# This hash table gives the conversion between OpenGL types and what
# is used by the TRACE printfs
#
%
debug_conv
=
(
"GLbitfield"
=>
"%d"
,
"GLboolean"
=>
"%d"
,
"GLbyte"
=>
"%d"
,
"GLclampd"
=>
"%f"
,
"GLclampf"
=>
"%f"
,
"GLdouble"
=>
"%f"
,
"GLenum"
=>
"%d"
,
"GLfloat"
=>
"%f"
,
"GLint"
=>
"%d"
,
"GLshort"
=>
"%d"
,
"GLsizei"
=>
"%d"
,
"GLstring"
=>
"%s"
,
"GLubyte"
=>
"%d"
,
"GLuint"
=>
"%d"
,
"GLushort"
=>
"%d"
,
"GLvoid"
=>
"(void)"
,
"_GLfuncptr"
=>
"%p"
);
#
# This hash table gives the conversion between OpenGL types and what
# is used in the .spec file
#
%
arg_conv
=
(
"GLbitfield"
=>
[
"long"
,
4
],
"GLboolean"
=>
[
"long"
,
4
],
"GLbyte"
=>
[
"long"
,
4
],
"GLclampd"
=>
[
"double"
,
8
],
"GLclampf"
=>
[
"long"
,
4
],
"GLdouble"
=>
[
"double"
,
8
],
"GLenum"
=>
[
"long"
,
4
],
"GLfloat"
=>
[
"long"
,
4
],
"GLint"
=>
[
"long"
,
4
],
"GLshort"
=>
[
"long"
,
4
],
"GLsizei"
=>
[
"long"
,
4
],
"GLstring"
=>
[
"str"
,
4
],
"GLubyte"
=>
[
"long"
,
4
],
"GLuint"
=>
[
"long"
,
4
],
"GLushort"
=>
[
"long"
,
4
],
"GLvoid"
=>
[
"void"
,
4
],
"_GLfuncptr"
=>
[
"ptr"
,
4
]);
#
# This functions generates the thunk for a given function.
# This functions generates the thunk for a given function.
#
#
sub
GenerateThunk
{
sub
GenerateThunk
{
my
(
$func_ref
,
$comment
,
$prefix
,
$thread_safe
)
=
@_
;
my
(
$func_ref
,
$comment
,
$prefix
,
$thread_safe
)
=
@_
;
my
(
$ret
)
=
(
""
);
my
(
$ret
)
=
(
""
);
my
(
$call_arg
)
=
(
""
);
my
(
$call_arg
)
=
(
""
);
my
(
$trace_arg
)
=
(
""
);
# If for opengl_norm.c, generate a nice heading otherwise Patrik won't be happy :-)
# If for opengl_norm.c, generate a nice heading otherwise Patrik won't be happy :-)
if
(
$comment
eq
1
)
{
if
(
$comment
eq
1
)
{
...
@@ -53,9 +138,15 @@ sub GenerateThunk {
...
@@ -53,9 +138,15 @@ sub GenerateThunk {
$name
=
$func_ref
->
[
2
]
->
[
$i
]
->
[
1
];
$name
=
$func_ref
->
[
2
]
->
[
$i
]
->
[
1
];
$ret
=
$ret
.
"$type $name"
;
$ret
=
$ret
.
"$type $name"
;
$call_arg
=
$call_arg
.
"$name"
;
$call_arg
=
$call_arg
.
"$name"
;
if
(
$type
=~
/\*/
)
{
$trace_arg
=
$trace_arg
.
"%p"
;
}
else
{
$trace_arg
=
$trace_arg
.
$debug_conv
{
$type
};
}
if
(
$i
!=
$#
{
@
{
$func_ref
->
[
2
]}})
{
if
(
$i
!=
$#
{
@
{
$func_ref
->
[
2
]}})
{
$ret
=
$ret
.
", "
;
$ret
=
$ret
.
", "
;
$call_arg
=
$call_arg
.
", "
;
$call_arg
=
$call_arg
.
", "
;
$trace_arg
=
$trace_arg
.
", "
;
}
else
{
}
else
{
$ret
=
$ret
.
" "
;
$ret
=
$ret
.
" "
;
$call_arg
=
$call_arg
.
" "
;
$call_arg
=
$call_arg
.
" "
;
...
@@ -65,6 +156,13 @@ sub GenerateThunk {
...
@@ -65,6 +156,13 @@ sub GenerateThunk {
if
(
$func_ref
->
[
1
]
ne
"void"
)
{
if
(
$func_ref
->
[
1
]
ne
"void"
)
{
$ret
=
$ret
.
" "
.
$func_ref
->
[
1
]
.
" ret_value;\n"
;
$ret
=
$ret
.
" "
.
$func_ref
->
[
1
]
.
" ret_value;\n"
;
}
}
if
(
$gen_traces
)
{
$ret
=
$ret
.
" TRACE(\"("
.
$trace_arg
.
")\\n\""
;
if
(
$trace_arg
ne
""
)
{
$ret
=
$ret
.
", "
.
$call_arg
;
}
$ret
=
$ret
.
");\n"
;
}
if
(
$thread_safe
)
{
if
(
$thread_safe
)
{
$ret
=
$ret
.
" ENTER_GL();\n"
;
$ret
=
$ret
.
" ENTER_GL();\n"
;
}
}
...
@@ -86,63 +184,6 @@ sub GenerateThunk {
...
@@ -86,63 +184,6 @@ sub GenerateThunk {
}
}
#
#
# This hash table gives the conversion between OpenGL types and what
# is used in the .spec file
#
%
arg_conv
=
(
"GLbitfield"
=>
[
"long"
,
4
],
"GLboolean"
=>
[
"long"
,
4
],
"GLbyte"
=>
[
"long"
,
4
],
"GLclampd"
=>
[
"double"
,
8
],
"GLclampf"
=>
[
"long"
,
4
],
"GLdouble"
=>
[
"double"
,
8
],
"GLenum"
=>
[
"long"
,
4
],
"GLfloat"
=>
[
"long"
,
4
],
"GLint"
=>
[
"long"
,
4
],
"GLshort"
=>
[
"long"
,
4
],
"GLsizei"
=>
[
"long"
,
4
],
"GLstring"
=>
[
"str"
,
4
],
"GLubyte"
=>
[
"long"
,
4
],
"GLuint"
=>
[
"long"
,
4
],
"GLushort"
=>
[
"long"
,
4
],
"GLvoid"
=>
[
"void"
,
4
],
"_GLfuncptr"
=>
[
"ptr"
,
4
]);
#
# Files to generate
#
$spec_file
=
"opengl32.spec"
;
$norm_file
=
"opengl_norm.c"
;
$ext_file
=
"opengl_ext.c"
;
# Set to 0 for removing the ENTER / LEAVE GL calls
$gen_thread_safe
=
1
;
# Prefix used for the local variables
$ext_prefix
=
"func_"
;
#
# List of categories to put in the 'opengl_norm.c' file
#
%
cat_1_0
=
(
"display-list"
=>
1
,
"drawing"
=>
1
,
"drawing-control"
=>
1
,
"feedback"
=>
1
,
"framebuf"
=>
1
,
"misc"
=>
1
,
"modeling"
=>
1
,
"pixel-op"
=>
1
,
"pixel-rw"
=>
1
,
"state-req"
=>
1
,
"xform"
=>
1
);
%
cat_1_1
=
(
%
cat_1_0
,
"1_1"
=>
1
);
%
cat_1_2
=
(
%
cat_1_1
,
"VERSION_1_2"
=>
1
,
"ARB_multitexture"
=>
1
);
%
norm_categories
=
();
#
# Extract and checks the number of arguments
# Extract and checks the number of arguments
#
#
if
(
$#ARGV
!=
1
)
{
if
(
$#ARGV
!=
1
)
{
...
@@ -177,6 +218,11 @@ while ($line = <TYPES>) {
...
@@ -177,6 +218,11 @@ while ($line = <TYPES>) {
}
}
# This is to override the 'void' -> '*' bogus conversion
# This is to override the 'void' -> '*' bogus conversion
$pseudo_to_opengl
{
"void"
}
=
"void"
;
$pseudo_to_opengl
{
"void"
}
=
"void"
;
# This is a bug in the spec file...
$pseudo_to_opengl
{
"FfdTargetSGIX"
}
=
"GLint"
;
$pseudo_to_opengl
{
"FfdMaskSGIX"
}
=
"GLint"
;
$pseudo_to_opengl
{
"IglooFunctionSelectSGIX"
}
=
"GLint"
;
$pseudo_to_opengl
{
"IglooParameterSGIX"
}
=
"GLint"
;
#
#
# Then, create the list of all OpenGL functions using the 'gl.spec'
# Then, create the list of all OpenGL functions using the 'gl.spec'
...
@@ -322,8 +368,12 @@ open(SPEC, ">" . $spec_file);
...
@@ -322,8 +368,12 @@ open(SPEC, ">" . $spec_file);
print
SPEC
"
print
SPEC
"
name opengl32
name opengl32
type win32
type win32
init OpenGL32_Init
init OpenGL32_Init
import x11drv
import x11drv
import kernel32
debug_channels (opengl)
@ stdcall wglCreateContext(long) wglCreateContext
@ stdcall wglCreateContext(long) wglCreateContext
@ stdcall wglCreateLayerContext(long long) wglCreateLayerContext
@ stdcall wglCreateLayerContext(long long) wglCreateLayerContext
...
@@ -378,9 +428,12 @@ print NORM "
...
@@ -378,9 +428,12 @@ print NORM "
#include \"config.h\"
#include \"config.h\"
#include \"wine_gl.h\"
#include \"wine_gl.h\"
#include \"debugtools.h\"
typedef const GLubyte * GLstring;
typedef const GLubyte * GLstring;
DEFAULT_DEBUG_CHANNEL(opengl);
"
;
"
;
foreach
(
sort
keys
%
norm_functions
)
{
foreach
(
sort
keys
%
norm_functions
)
{
$string
=
GenerateThunk
(
$norm_functions
{
$_
},
1
,
""
,
$gen_thread_safe
);
$string
=
GenerateThunk
(
$norm_functions
{
$_
},
1
,
""
,
$gen_thread_safe
);
...
@@ -398,11 +451,14 @@ print EXT "
...
@@ -398,11 +451,14 @@ print EXT "
#include \"config.h\"
#include \"config.h\"
#include \"wine_gl.h\"
#include \"wine_gl.h\"
#include \"debugtools.h\"
typedef const GLubyte * GLstring;
typedef const GLubyte * GLstring;
#include \"opengl_ext.h\"
#include \"opengl_ext.h\"
DEFAULT_DEBUG_CHANNEL(opengl);
"
;
"
;
# First, generate the function pointers
# First, generate the function pointers
...
...
dlls/opengl32/opengl32.spec
View file @
15a4a77a
name opengl32
name opengl32
type win32
type win32
init OpenGL32_Init
init OpenGL32_Init
import x11drv
import x11drv
import kernel32
import kernel32
...
...
dlls/opengl32/opengl_ext.c
View file @
15a4a77a
This diff is collapsed.
Click to expand it.
dlls/opengl32/opengl_norm.c
View file @
15a4a77a
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment