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
55043956
Commit
55043956
authored
Sep 09, 2010
by
Matteo Bruni
Committed by
Alexandre Julliard
Sep 13, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
d3dcompiler: D3DPreprocess implementation.
parent
1cb7e6f8
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
132 additions
and
84 deletions
+132
-84
compiler.c
dlls/d3dcompiler_43/compiler.c
+127
-83
d3dcompiler_43.spec
dlls/d3dcompiler_43/d3dcompiler_43.spec
+1
-1
d3dcompiler.h
include/d3dcompiler.h
+4
-0
No files found.
dlls/d3dcompiler_43/compiler.c
View file @
55043956
...
@@ -309,6 +309,86 @@ static int wpp_close_output(void)
...
@@ -309,6 +309,86 @@ static int wpp_close_output(void)
return
1
;
return
1
;
}
}
static
HRESULT
preprocess_shader
(
const
void
*
data
,
SIZE_T
data_size
,
const
D3D_SHADER_MACRO
*
defines
,
ID3DInclude
*
include
,
ID3DBlob
**
error_messages
)
{
int
ret
;
HRESULT
hr
=
S_OK
;
const
D3D_SHADER_MACRO
*
def
=
defines
;
static
const
struct
wpp_callbacks
wpp_callbacks
=
{
wpp_lookup_mem
,
wpp_open_mem
,
wpp_close_mem
,
wpp_read_mem
,
wpp_write_mem
,
wpp_error
,
wpp_warning
,
};
if
(
def
!=
NULL
)
{
while
(
def
->
Name
!=
NULL
)
{
wpp_add_define
(
def
->
Name
,
def
->
Definition
);
def
++
;
}
}
current_include
=
include
;
includes_size
=
0
;
wpp_output_size
=
wpp_output_capacity
=
0
;
wpp_output
=
NULL
;
wpp_set_callbacks
(
&
wpp_callbacks
);
wpp_messages_size
=
wpp_messages_capacity
=
0
;
wpp_messages
=
NULL
;
current_shader
.
buffer
=
data
;
current_shader
.
size
=
data_size
;
ret
=
wpp_parse
(
""
,
NULL
);
if
(
!
wpp_close_output
())
ret
=
1
;
if
(
ret
)
{
TRACE
(
"Error during shader preprocessing
\n
"
);
if
(
wpp_messages
)
{
int
size
;
ID3DBlob
*
buffer
;
TRACE
(
"Preprocessor messages:
\n
%s"
,
wpp_messages
);
if
(
error_messages
)
{
size
=
strlen
(
wpp_messages
)
+
1
;
hr
=
D3DCreateBlob
(
size
,
&
buffer
);
if
(
FAILED
(
hr
))
goto
cleanup
;
CopyMemory
(
ID3D10Blob_GetBufferPointer
(
buffer
),
wpp_messages
,
size
);
*
error_messages
=
buffer
;
}
}
if
(
data
)
TRACE
(
"Shader source:
\n
%s
\n
"
,
debugstr_an
(
data
,
data_size
));
hr
=
E_FAIL
;
}
cleanup:
/* Remove the previously added defines */
if
(
defines
!=
NULL
)
{
while
(
defines
->
Name
!=
NULL
)
{
wpp_del_define
(
defines
->
Name
);
defines
++
;
}
}
HeapFree
(
GetProcessHeap
(),
0
,
wpp_messages
);
return
hr
;
}
static
HRESULT
assemble_shader
(
const
char
*
preprocShader
,
const
char
*
preprocMessages
,
static
HRESULT
assemble_shader
(
const
char
*
preprocShader
,
const
char
*
preprocMessages
,
LPD3DBLOB
*
ppShader
,
LPD3DBLOB
*
ppErrorMsgs
)
LPD3DBLOB
*
ppShader
,
LPD3DBLOB
*
ppErrorMsgs
)
{
{
...
@@ -396,97 +476,24 @@ static HRESULT assemble_shader(const char *preprocShader, const char *preprocMes
...
@@ -396,97 +476,24 @@ static HRESULT assemble_shader(const char *preprocShader, const char *preprocMes
return
S_OK
;
return
S_OK
;
}
}
HRESULT
WINAPI
D3DAssemble
(
LPCVOID
data
,
SIZE_T
datasize
,
LPCSTR
filename
,
HRESULT
WINAPI
D3DAssemble
(
const
void
*
data
,
SIZE_T
datasize
,
const
char
*
filename
,
const
D3D_SHADER_MACRO
*
defines
,
ID3DInclude
*
include
,
const
D3D_SHADER_MACRO
*
defines
,
ID3DInclude
*
include
,
UINT
flags
,
UINT
flags
,
ID3DBlob
**
shader
,
ID3DBlob
**
error_messages
)
ID3DBlob
**
shader
,
ID3DBlob
**
error_messages
){
{
int
ret
;
HRESULT
hr
;
HRESULT
hr
;
CONST
D3D_SHADER_MACRO
*
def
=
defines
;
static
const
struct
wpp_callbacks
wpp_callbacks
=
{
wpp_lookup_mem
,
wpp_open_mem
,
wpp_close_mem
,
wpp_read_mem
,
wpp_write_mem
,
wpp_error
,
wpp_warning
,
};
EnterCriticalSection
(
&
wpp_mutex
);
EnterCriticalSection
(
&
wpp_mutex
);
/* TODO: flags */
/* TODO: flags */
if
(
flags
)
FIXME
(
"flags: %x
\n
"
,
flags
);
if
(
flags
)
FIXME
(
"flags %x
\n
"
,
flags
);
if
(
def
!=
NULL
)
{
while
(
def
->
Name
!=
NULL
)
{
wpp_add_define
(
def
->
Name
,
def
->
Definition
);
def
++
;
}
}
current_include
=
include
;
includes_size
=
0
;
if
(
shader
)
*
shader
=
NULL
;
if
(
error_messages
)
*
error_messages
=
NULL
;
wpp_output_size
=
wpp_output_capacity
=
0
;
wpp_output
=
NULL
;
/* Preprocess shader */
wpp_set_callbacks
(
&
wpp_callbacks
);
wpp_messages_size
=
wpp_messages_capacity
=
0
;
wpp_messages
=
NULL
;
current_shader
.
buffer
=
data
;
current_shader
.
size
=
datasize
;
ret
=
wpp_parse
(
""
,
NULL
);
if
(
shader
)
*
shader
=
NULL
;
if
(
!
wpp_close_output
())
if
(
error_messages
)
*
error_messages
=
NULL
;
ret
=
1
;
if
(
ret
)
{
TRACE
(
"Error during shader preprocessing
\n
"
);
if
(
wpp_messages
)
{
int
size
;
LPD3DBLOB
buffer
;
TRACE
(
"Preprocessor messages:
\n
"
);
hr
=
preprocess_shader
(
data
,
datasize
,
defines
,
include
,
error_messages
);
TRACE
(
"%s"
,
wpp_messages
);
if
(
SUCCEEDED
(
hr
))
hr
=
assemble_shader
(
wpp_output
,
wpp_messages
,
shader
,
error_messages
);
if
(
error_messages
)
{
size
=
strlen
(
wpp_messages
)
+
1
;
hr
=
D3DCreateBlob
(
size
,
&
buffer
);
if
(
FAILED
(
hr
))
goto
cleanup
;
CopyMemory
(
ID3D10Blob_GetBufferPointer
(
buffer
),
wpp_messages
,
size
);
*
error_messages
=
buffer
;
}
}
if
(
data
)
{
TRACE
(
"Shader source:
\n
"
);
TRACE
(
"%s
\n
"
,
debugstr_an
(
data
,
datasize
));
}
hr
=
D3DXERR_INVALIDDATA
;
goto
cleanup
;
}
hr
=
assemble_shader
(
wpp_output
,
wpp_messages
,
shader
,
error_messages
);
cleanup
:
/* Remove the previously added defines */
if
(
defines
!=
NULL
)
{
while
(
defines
->
Name
!=
NULL
)
{
wpp_del_define
(
defines
->
Name
);
defines
++
;
}
}
HeapFree
(
GetProcessHeap
(),
0
,
wpp_messages
);
HeapFree
(
GetProcessHeap
(),
0
,
wpp_output
);
HeapFree
(
GetProcessHeap
(),
0
,
wpp_output
);
LeaveCriticalSection
(
&
wpp_mutex
);
LeaveCriticalSection
(
&
wpp_mutex
);
return
hr
;
return
hr
;
...
@@ -508,3 +515,40 @@ HRESULT WINAPI D3DCompile(const void *data, SIZE_T data_size, const char *filena
...
@@ -508,3 +515,40 @@ HRESULT WINAPI D3DCompile(const void *data, SIZE_T data_size, const char *filena
return
D3DERR_INVALIDCALL
;
return
D3DERR_INVALIDCALL
;
}
}
HRESULT
WINAPI
D3DPreprocess
(
const
void
*
data
,
SIZE_T
size
,
const
char
*
filename
,
const
D3D_SHADER_MACRO
*
defines
,
ID3DInclude
*
include
,
ID3DBlob
**
shader
,
ID3DBlob
**
error_messages
)
{
HRESULT
hr
;
ID3DBlob
*
buffer
;
if
(
!
data
)
return
E_INVALIDARG
;
EnterCriticalSection
(
&
wpp_mutex
);
if
(
shader
)
*
shader
=
NULL
;
if
(
error_messages
)
*
error_messages
=
NULL
;
hr
=
preprocess_shader
(
data
,
size
,
defines
,
include
,
error_messages
);
if
(
SUCCEEDED
(
hr
))
{
if
(
shader
)
{
hr
=
D3DCreateBlob
(
wpp_output_size
,
&
buffer
);
if
(
FAILED
(
hr
))
goto
cleanup
;
CopyMemory
(
ID3D10Blob_GetBufferPointer
(
buffer
),
wpp_output
,
wpp_output_size
);
*
shader
=
buffer
;
}
else
hr
=
E_INVALIDARG
;
}
cleanup:
HeapFree
(
GetProcessHeap
(),
0
,
wpp_output
);
LeaveCriticalSection
(
&
wpp_mutex
);
return
hr
;
}
dlls/d3dcompiler_43/d3dcompiler_43.spec
View file @
55043956
...
@@ -11,7 +11,7 @@
...
@@ -11,7 +11,7 @@
@ stub D3DGetInputAndOutputSignatureBlob
@ stub D3DGetInputAndOutputSignatureBlob
@ stub D3DGetInputSignatureBlob
@ stub D3DGetInputSignatureBlob
@ stub D3DGetOutputSignatureBlob
@ stub D3DGetOutputSignatureBlob
@ st
ub D3DPreprocess
@ st
dcall D3DPreprocess(ptr long str ptr ptr ptr ptr)
@ stub D3DReflect
@ stub D3DReflect
@ stub D3DReturnFailure1
@ stub D3DReturnFailure1
@ stub D3DStripShader
@ stub D3DStripShader
include/d3dcompiler.h
View file @
55043956
...
@@ -47,4 +47,8 @@ HRESULT WINAPI D3DCompile(const void *data, SIZE_T data_size, const char *filena
...
@@ -47,4 +47,8 @@ HRESULT WINAPI D3DCompile(const void *data, SIZE_T data_size, const char *filena
HRESULT
WINAPI
D3DCreateBlob
(
SIZE_T
data_size
,
ID3DBlob
**
blob
);
HRESULT
WINAPI
D3DCreateBlob
(
SIZE_T
data_size
,
ID3DBlob
**
blob
);
HRESULT
WINAPI
D3DPreprocess
(
const
void
*
data
,
SIZE_T
size
,
const
char
*
filename
,
const
D3D_SHADER_MACRO
*
defines
,
ID3DInclude
*
include
,
ID3DBlob
**
shader
,
ID3DBlob
**
error_messages
);
#endif
#endif
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