Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
d74fe031
Commit
d74fe031
authored
Nov 04, 2014
by
Henri Verbeet
Committed by
Alexandre Julliard
Nov 04, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wined3d: Calculate the SM4 output mapping in shader_sm4_init().
parent
909c5cc6
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
41 additions
and
34 deletions
+41
-34
directx.c
dlls/wined3d/directx.c
+0
-4
shader_sm4.c
dlls/wined3d/shader_sm4.c
+37
-30
wined3d_private.h
dlls/wined3d/wined3d_private.h
+4
-0
No files found.
dlls/wined3d/directx.c
View file @
d74fe031
...
@@ -36,10 +36,6 @@ WINE_DECLARE_DEBUG_CHANNEL(winediag);
...
@@ -36,10 +36,6 @@ WINE_DECLARE_DEBUG_CHANNEL(winediag);
#define WINE_DEFAULT_VIDMEM (64 * 1024 * 1024)
#define WINE_DEFAULT_VIDMEM (64 * 1024 * 1024)
#define DEFAULT_REFRESH_RATE 0
#define DEFAULT_REFRESH_RATE 0
#ifndef ARRAY_SIZE
#define ARRAY_SIZE(array) (sizeof(array)/sizeof((array)[0]))
#endif
/* The driver names reflect the lowest GPU supported
/* The driver names reflect the lowest GPU supported
* by a certain driver, so DRIVER_AMD_R300 supports
* by a certain driver, so DRIVER_AMD_R300 supports
* R3xx, R4xx and R5xx GPUs. */
* R3xx, R4xx and R5xx GPUs. */
...
...
dlls/wined3d/shader_sm4.c
View file @
d74fe031
...
@@ -176,7 +176,12 @@ struct wined3d_sm4_data
...
@@ -176,7 +176,12 @@ struct wined3d_sm4_data
{
{
struct
wined3d_shader_version
shader_version
;
struct
wined3d_shader_version
shader_version
;
const
DWORD
*
end
;
const
DWORD
*
end
;
const
struct
wined3d_shader_signature
*
output_signature
;
struct
{
enum
wined3d_shader_register_type
register_type
;
UINT
register_idx
;
}
output_map
[
MAX_REG_OUTPUT
];
struct
wined3d_shader_src_param
src_param
[
5
];
struct
wined3d_shader_src_param
src_param
[
5
];
struct
wined3d_shader_dst_param
dst_param
[
2
];
struct
wined3d_shader_dst_param
dst_param
[
2
];
...
@@ -331,20 +336,6 @@ static const struct wined3d_sm4_opcode_info *get_opcode_info(enum wined3d_sm4_op
...
@@ -331,20 +336,6 @@ static const struct wined3d_sm4_opcode_info *get_opcode_info(enum wined3d_sm4_op
return
NULL
;
return
NULL
;
}
}
static
void
map_sysval
(
enum
wined3d_sysval_semantic
sysval
,
struct
wined3d_shader_register
*
reg
)
{
unsigned
int
i
;
for
(
i
=
0
;
i
<
sizeof
(
sysval_map
)
/
sizeof
(
*
sysval_map
);
++
i
)
{
if
(
sysval
==
sysval_map
[
i
].
sysval
)
{
reg
->
type
=
sysval_map
[
i
].
register_type
;
reg
->
idx
[
0
].
offset
=
sysval_map
[
i
].
register_idx
;
}
}
}
static
void
map_register
(
const
struct
wined3d_sm4_data
*
priv
,
struct
wined3d_shader_register
*
reg
)
static
void
map_register
(
const
struct
wined3d_sm4_data
*
priv
,
struct
wined3d_shader_register
*
reg
)
{
{
switch
(
priv
->
shader_version
.
type
)
switch
(
priv
->
shader_version
.
type
)
...
@@ -352,23 +343,16 @@ static void map_register(const struct wined3d_sm4_data *priv, struct wined3d_sha
...
@@ -352,23 +343,16 @@ static void map_register(const struct wined3d_sm4_data *priv, struct wined3d_sha
case
WINED3D_SHADER_TYPE_PIXEL
:
case
WINED3D_SHADER_TYPE_PIXEL
:
if
(
reg
->
type
==
WINED3DSPR_OUTPUT
)
if
(
reg
->
type
==
WINED3DSPR_OUTPUT
)
{
{
unsigned
int
i
;
unsigned
int
reg_idx
=
reg
->
idx
[
0
].
offset
;
const
struct
wined3d_shader_signature
*
s
=
priv
->
output_signature
;
if
(
!
s
)
if
(
reg_idx
>=
ARRAY_SIZE
(
priv
->
output_map
)
)
{
{
ERR
(
"
Shader has no output signature, unable to map register.
\n
"
);
ERR
(
"
Invalid output index %u.
\n
"
,
reg_idx
);
break
;
break
;
}
}
for
(
i
=
0
;
i
<
s
->
element_count
;
++
i
)
reg
->
type
=
priv
->
output_map
[
reg_idx
].
register_type
;
{
reg
->
idx
[
0
].
offset
=
priv
->
output_map
[
reg_idx
].
register_idx
;
if
(
s
->
elements
[
i
].
register_idx
==
reg
->
idx
[
0
].
offset
)
{
map_sysval
(
s
->
elements
[
i
].
sysval_semantic
,
reg
);
break
;
}
}
}
}
break
;
break
;
...
@@ -399,14 +383,37 @@ static enum wined3d_data_type map_data_type(char t)
...
@@ -399,14 +383,37 @@ static enum wined3d_data_type map_data_type(char t)
static
void
*
shader_sm4_init
(
const
DWORD
*
byte_code
,
const
struct
wined3d_shader_signature
*
output_signature
)
static
void
*
shader_sm4_init
(
const
DWORD
*
byte_code
,
const
struct
wined3d_shader_signature
*
output_signature
)
{
{
struct
wined3d_sm4_data
*
priv
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
priv
));
struct
wined3d_sm4_data
*
priv
;
if
(
!
priv
)
unsigned
int
i
,
j
;
if
(
!
(
priv
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
priv
))))
{
{
ERR
(
"Failed to allocate private data
\n
"
);
ERR
(
"Failed to allocate private data
\n
"
);
return
NULL
;
return
NULL
;
}
}
priv
->
output_signature
=
output_signature
;
memset
(
priv
->
output_map
,
0xff
,
sizeof
(
priv
->
output_map
));
for
(
i
=
0
;
i
<
output_signature
->
element_count
;
++
i
)
{
struct
wined3d_shader_signature_element
*
e
=
&
output_signature
->
elements
[
i
];
if
(
e
->
register_idx
>=
ARRAY_SIZE
(
priv
->
output_map
))
{
WARN
(
"Invalid output index %u.
\n
"
,
e
->
register_idx
);
continue
;
}
for
(
j
=
0
;
j
<
ARRAY_SIZE
(
sysval_map
);
++
j
)
{
if
(
e
->
sysval_semantic
==
sysval_map
[
j
].
sysval
)
{
priv
->
output_map
[
e
->
register_idx
].
register_type
=
sysval_map
[
j
].
register_type
;
priv
->
output_map
[
e
->
register_idx
].
register_idx
=
sysval_map
[
j
].
register_idx
;
break
;
}
}
}
list_init
(
&
priv
->
src_free
);
list_init
(
&
priv
->
src_free
);
list_init
(
&
priv
->
src
);
list_init
(
&
priv
->
src
);
...
...
dlls/wined3d/wined3d_private.h
View file @
d74fe031
...
@@ -52,6 +52,10 @@
...
@@ -52,6 +52,10 @@
#include "wine/rbtree.h"
#include "wine/rbtree.h"
#include "wine/wgl_driver.h"
#include "wine/wgl_driver.h"
#ifndef ARRAY_SIZE
#define ARRAY_SIZE(array) (sizeof(array) / sizeof((array)[0]))
#endif
/* Driver quirks */
/* Driver quirks */
#define WINED3D_QUIRK_ARB_VS_OFFSET_LIMIT 0x00000001
#define WINED3D_QUIRK_ARB_VS_OFFSET_LIMIT 0x00000001
#define WINED3D_QUIRK_SET_TEXCOORD_W 0x00000002
#define WINED3D_QUIRK_SET_TEXCOORD_W 0x00000002
...
...
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