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
157205c0
Commit
157205c0
authored
Feb 13, 2007
by
H. Verbeet
Committed by
Alexandre Julliard
Feb 14, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
d3d8: Don't store the d3d8 declaration in the wined3d object.
parent
efed9aea
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
113 additions
and
5 deletions
+113
-5
d3d8_private.h
dlls/d3d8/d3d8_private.h
+1
-0
device.c
dlls/d3d8/device.c
+7
-1
vertexdeclaration.c
dlls/d3d8/vertexdeclaration.c
+105
-0
vertexdeclaration.c
dlls/wined3d/vertexdeclaration.c
+0
-0
wined3d_private.h
dlls/wined3d/wined3d_private.h
+0
-4
No files found.
dlls/d3d8/d3d8_private.h
View file @
157205c0
...
@@ -619,6 +619,7 @@ typedef struct IDirect3DPixelShader8Impl {
...
@@ -619,6 +619,7 @@ typedef struct IDirect3DPixelShader8Impl {
* to see how not defined it here
* to see how not defined it here
*/
*/
void
load_local_constants
(
const
DWORD
*
d3d8_elements
,
IWineD3DVertexShader
*
wined3d_vertex_shader
);
void
load_local_constants
(
const
DWORD
*
d3d8_elements
,
IWineD3DVertexShader
*
wined3d_vertex_shader
);
size_t
convert_to_wined3d_declaration
(
const
DWORD
*
d3d8_elements
,
WINED3DVERTEXELEMENT
**
wined3d_elements
);
/* Callbacks */
/* Callbacks */
extern
HRESULT
WINAPI
D3D8CB_CreateSurface
(
IUnknown
*
device
,
IUnknown
*
pSuperior
,
UINT
Width
,
UINT
Height
,
extern
HRESULT
WINAPI
D3D8CB_CreateSurface
(
IUnknown
*
device
,
IUnknown
*
pSuperior
,
UINT
Width
,
UINT
Height
,
...
...
dlls/d3d8/device.c
View file @
157205c0
...
@@ -1165,6 +1165,8 @@ static HRESULT WINAPI IDirect3DDevice8Impl_ProcessVertices(LPDIRECT3DDEVICE8 ifa
...
@@ -1165,6 +1165,8 @@ static HRESULT WINAPI IDirect3DDevice8Impl_ProcessVertices(LPDIRECT3DDEVICE8 ifa
static
HRESULT
WINAPI
IDirect3DDevice8Impl_CreateVertexDeclaration
(
IDirect3DDevice8
*
iface
,
CONST
DWORD
*
declaration
,
IDirect3DVertexDeclaration8
**
decl_ptr
)
{
static
HRESULT
WINAPI
IDirect3DDevice8Impl_CreateVertexDeclaration
(
IDirect3DDevice8
*
iface
,
CONST
DWORD
*
declaration
,
IDirect3DVertexDeclaration8
**
decl_ptr
)
{
IDirect3DDevice8Impl
*
This
=
(
IDirect3DDevice8Impl
*
)
iface
;
IDirect3DDevice8Impl
*
This
=
(
IDirect3DDevice8Impl
*
)
iface
;
IDirect3DVertexDeclaration8Impl
*
object
;
IDirect3DVertexDeclaration8Impl
*
object
;
WINED3DVERTEXELEMENT
*
wined3d_elements
;
size_t
wined3d_element_count
;
HRESULT
hr
=
D3D_OK
;
HRESULT
hr
=
D3D_OK
;
TRACE
(
"(%p) : declaration %p
\n
"
,
This
,
declaration
);
TRACE
(
"(%p) : declaration %p
\n
"
,
This
,
declaration
);
...
@@ -1179,7 +1181,11 @@ static HRESULT WINAPI IDirect3DDevice8Impl_CreateVertexDeclaration(IDirect3DDevi
...
@@ -1179,7 +1181,11 @@ static HRESULT WINAPI IDirect3DDevice8Impl_CreateVertexDeclaration(IDirect3DDevi
object
->
ref_count
=
1
;
object
->
ref_count
=
1
;
object
->
lpVtbl
=
&
Direct3DVertexDeclaration8_Vtbl
;
object
->
lpVtbl
=
&
Direct3DVertexDeclaration8_Vtbl
;
hr
=
IWineD3DDevice_CreateVertexDeclaration
(
This
->
WineD3DDevice
,
&
object
->
wined3d_vertex_declaration
,
(
IUnknown
*
)
object
,
(
CONST
WINED3DVERTEXELEMENT
*
)
declaration
,
0
);
wined3d_element_count
=
convert_to_wined3d_declaration
(
declaration
,
&
wined3d_elements
);
hr
=
IWineD3DDevice_CreateVertexDeclaration
(
This
->
WineD3DDevice
,
&
object
->
wined3d_vertex_declaration
,
(
IUnknown
*
)
object
,
wined3d_elements
,
wined3d_element_count
);
HeapFree
(
GetProcessHeap
(),
0
,
wined3d_elements
);
if
(
FAILED
(
hr
))
{
if
(
FAILED
(
hr
))
{
ERR
(
"(%p) : IWineD3DDevice_CreateVertexDeclaration call failed
\n
"
,
This
);
ERR
(
"(%p) : IWineD3DDevice_CreateVertexDeclaration call failed
\n
"
,
This
);
HeapFree
(
GetProcessHeap
(),
0
,
object
);
HeapFree
(
GetProcessHeap
(),
0
,
object
);
...
...
dlls/d3d8/vertexdeclaration.c
View file @
157205c0
...
@@ -224,6 +224,111 @@ void load_local_constants(const DWORD *d3d8_elements, IWineD3DVertexShader *wine
...
@@ -224,6 +224,111 @@ void load_local_constants(const DWORD *d3d8_elements, IWineD3DVertexShader *wine
}
}
}
}
/* NOTE: Make sure these are in the correct numerical order. (see /include/wined3d_types.h) */
static
const
size_t
wined3d_type_sizes
[
WINED3DDECLTYPE_UNUSED
]
=
{
/*WINED3DDECLTYPE_FLOAT1*/
1
*
sizeof
(
float
),
/*WINED3DDECLTYPE_FLOAT2*/
2
*
sizeof
(
float
),
/*WINED3DDECLTYPE_FLOAT3*/
3
*
sizeof
(
float
),
/*WINED3DDECLTYPE_FLOAT4*/
4
*
sizeof
(
float
),
/*WINED3DDECLTYPE_D3DCOLOR*/
4
*
sizeof
(
BYTE
),
/*WINED3DDECLTYPE_UBYTE4*/
4
*
sizeof
(
BYTE
),
/*WINED3DDECLTYPE_SHORT2*/
2
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_SHORT4*/
4
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_UBYTE4N*/
4
*
sizeof
(
BYTE
),
/*WINED3DDECLTYPE_SHORT2N*/
2
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_SHORT4N*/
4
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_USHORT2N*/
2
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_USHORT4N*/
4
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_UDEC3*/
3
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_DEC3N*/
3
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_FLOAT16_2*/
2
*
sizeof
(
short
int
),
/*WINED3DDECLTYPE_FLOAT16_4*/
4
*
sizeof
(
short
int
)
};
typedef
struct
{
BYTE
usage
;
BYTE
usage_idx
;
}
wined3d_usage_t
;
static
const
wined3d_usage_t
wined3d_usage_lookup
[]
=
{
/*D3DVSDE_POSITION*/
{
WINED3DDECLUSAGE_POSITION
,
0
},
/*D3DVSDE_BLENDWEIGHT*/
{
WINED3DDECLUSAGE_BLENDWEIGHT
,
0
},
/*D3DVSDE_BLENDINDICES*/
{
WINED3DDECLUSAGE_BLENDINDICES
,
0
},
/*D3DVSDE_NORMAL*/
{
WINED3DDECLUSAGE_NORMAL
,
0
},
/*D3DVSDE_PSIZE*/
{
WINED3DDECLUSAGE_PSIZE
,
0
},
/*D3DVSDE_DIFFUSE*/
{
WINED3DDECLUSAGE_COLOR
,
0
},
/*D3DVSDE_SPECULAR*/
{
WINED3DDECLUSAGE_COLOR
,
1
},
/*D3DVSDE_TEXCOORD0*/
{
WINED3DDECLUSAGE_TEXCOORD
,
0
},
/*D3DVSDE_TEXCOORD1*/
{
WINED3DDECLUSAGE_TEXCOORD
,
1
},
/*D3DVSDE_TEXCOORD2*/
{
WINED3DDECLUSAGE_TEXCOORD
,
2
},
/*D3DVSDE_TEXCOORD3*/
{
WINED3DDECLUSAGE_TEXCOORD
,
3
},
/*D3DVSDE_TEXCOORD4*/
{
WINED3DDECLUSAGE_TEXCOORD
,
4
},
/*D3DVSDE_TEXCOORD5*/
{
WINED3DDECLUSAGE_TEXCOORD
,
5
},
/*D3DVSDE_TEXCOORD6*/
{
WINED3DDECLUSAGE_TEXCOORD
,
6
},
/*D3DVSDE_TEXCOORD7*/
{
WINED3DDECLUSAGE_TEXCOORD
,
7
},
/*D3DVSDE_POSITION2*/
{
WINED3DDECLUSAGE_POSITION
,
1
},
/*D3DVSDE_NORMAL2*/
{
WINED3DDECLUSAGE_NORMAL
,
1
},
};
/* TODO: find out where rhw (or positionT) is for declaration8 */
size_t
convert_to_wined3d_declaration
(
const
DWORD
*
d3d8_elements
,
WINED3DVERTEXELEMENT
**
wined3d_elements
)
{
const
DWORD
*
token
=
d3d8_elements
;
WINED3DVERTEXELEMENT
*
element
;
D3DVSD_TOKENTYPE
token_type
;
size_t
element_count
=
0
;
DWORD
stream
=
0
;
int
offset
=
0
;
TRACE
(
"d3d8_elements %p, wined3d_elements %p
\n
"
,
d3d8_elements
,
wined3d_elements
);
/* 128 should be enough for anyone... */
*
wined3d_elements
=
HeapAlloc
(
GetProcessHeap
(),
0
,
128
*
sizeof
(
WINED3DVERTEXELEMENT
));
while
(
D3DVSD_END
()
!=
*
token
)
{
token_type
=
((
*
token
&
D3DVSD_TOKENTYPEMASK
)
>>
D3DVSD_TOKENTYPESHIFT
);
if
(
token_type
==
D3DVSD_TOKEN_STREAM
&&
!
(
*
token
&
D3DVSD_STREAMTESSMASK
))
{
stream
=
((
*
token
&
D3DVSD_STREAMNUMBERMASK
)
>>
D3DVSD_STREAMNUMBERSHIFT
);
offset
=
0
;
}
else
if
(
token_type
==
D3DVSD_TOKEN_STREAMDATA
&&
!
(
token_type
&
0x10000000
))
{
DWORD
type
=
((
*
token
&
D3DVSD_DATATYPEMASK
)
>>
D3DVSD_DATATYPESHIFT
);
DWORD
reg
=
((
*
token
&
D3DVSD_VERTEXREGMASK
)
>>
D3DVSD_VERTEXREGSHIFT
);
TRACE
(
"Adding element %d:
\n
"
,
element_count
);
element
=
*
wined3d_elements
+
element_count
++
;
element
->
Stream
=
stream
;
element
->
Method
=
WINED3DDECLMETHOD_DEFAULT
;
element
->
Usage
=
wined3d_usage_lookup
[
reg
].
usage
;
element
->
UsageIndex
=
wined3d_usage_lookup
[
reg
].
usage_idx
;
element
->
Type
=
type
;
element
->
Offset
=
offset
;
element
->
Reg
=
reg
;
offset
+=
wined3d_type_sizes
[
type
];
}
else
if
(
token_type
==
D3DVSD_TOKEN_STREAMDATA
&&
(
token_type
&
0x10000000
))
{
TRACE
(
" 0x%08x SKIP(%u)
\n
"
,
token_type
,
((
token_type
&
D3DVSD_SKIPCOUNTMASK
)
>>
D3DVSD_SKIPCOUNTSHIFT
));
offset
+=
sizeof
(
DWORD
)
*
((
token_type
&
D3DVSD_SKIPCOUNTMASK
)
>>
D3DVSD_SKIPCOUNTSHIFT
);
}
if
(
element_count
>=
127
)
{
ERR
(
"More than 127 elements?
\n
"
);
break
;
}
token
+=
parse_token
(
token
);
}
/* END */
element
=
*
wined3d_elements
+
element_count
++
;
element
->
Stream
=
0xFF
;
element
->
Type
=
WINED3DDECLTYPE_UNUSED
;
return
element_count
;
}
const
IDirect3DVertexDeclaration8Vtbl
Direct3DVertexDeclaration8_Vtbl
=
const
IDirect3DVertexDeclaration8Vtbl
Direct3DVertexDeclaration8_Vtbl
=
{
{
IDirect3DVertexDeclaration8Impl_QueryInterface
,
IDirect3DVertexDeclaration8Impl_QueryInterface
,
...
...
dlls/wined3d/vertexdeclaration.c
View file @
157205c0
This diff is collapsed.
Click to expand it.
dlls/wined3d/wined3d_private.h
View file @
157205c0
...
@@ -1116,10 +1116,6 @@ typedef struct IWineD3DVertexDeclarationImpl {
...
@@ -1116,10 +1116,6 @@ typedef struct IWineD3DVertexDeclarationImpl {
DWORD
fvf
[
MAX_STREAMS
];
DWORD
fvf
[
MAX_STREAMS
];
DWORD
allFVF
;
DWORD
allFVF
;
/** dx8 compatible Declaration fields */
DWORD
*
pDeclaration8
;
DWORD
declaration8Length
;
WINED3DVERTEXELEMENT
*
pDeclarationWine
;
WINED3DVERTEXELEMENT
*
pDeclarationWine
;
UINT
declarationWNumElements
;
UINT
declarationWNumElements
;
}
IWineD3DVertexDeclarationImpl
;
}
IWineD3DVertexDeclarationImpl
;
...
...
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