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
15d64280
Commit
15d64280
authored
Oct 22, 2012
by
Józef Kucia
Committed by
Alexandre Julliard
Oct 23, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
d3dx9/tests: Add tests for filling floating-point textures.
parent
2c19f22c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
124 additions
and
0 deletions
+124
-0
texture.c
dlls/d3dx9_36/tests/texture.c
+124
-0
No files found.
dlls/d3dx9_36/tests/texture.c
View file @
15d64280
...
...
@@ -85,6 +85,43 @@ static const unsigned char dds_volume_map[] = {
0x0f
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x00
,
0x10
,
0x84
,
0xef
,
0x7b
,
0xaa
,
0xab
,
0xab
,
0xab
};
#define ADMITTED_ERROR 0.0001f
static
inline
float
relative_error
(
float
expected
,
float
got
)
{
return
expected
==
0
.
0
f
?
fabs
(
expected
-
got
)
:
fabs
(
1
.
0
f
-
got
/
expected
);
}
#define expect_vec4(expected, got) expect_vec4_(__LINE__, expected, got)
static
inline
void
expect_vec4_
(
unsigned
int
line
,
const
D3DXVECTOR4
*
expected
,
const
D3DXVECTOR4
*
got
)
{
ok_
(
__FILE__
,
line
)(
relative_error
(
expected
->
x
,
got
->
x
)
<
ADMITTED_ERROR
&&
relative_error
(
expected
->
y
,
got
->
y
)
<
ADMITTED_ERROR
&&
relative_error
(
expected
->
z
,
got
->
z
)
<
ADMITTED_ERROR
&&
relative_error
(
expected
->
w
,
got
->
w
)
<
ADMITTED_ERROR
,
"Expected (%f, %f, %f, %f), got (%f, %f, %f, %f)
\n
"
,
expected
->
x
,
expected
->
y
,
expected
->
z
,
expected
->
w
,
got
->
x
,
got
->
y
,
got
->
z
,
got
->
w
);
}
static
inline
float
float_16_to_32
(
unsigned
short
in
)
{
unsigned
short
s
=
(
in
&
0x8000
);
unsigned
short
e
=
(
in
&
0x7C00
)
>>
10
;
unsigned
short
m
=
in
&
0x3FF
;
float
sgn
=
(
s
?
-
1
.
0
f
:
1
.
0
f
);
if
(
e
==
0
)
{
if
(
m
==
0
)
return
sgn
*
0
.
0
f
;
/* +0.0 or -0.0 */
else
return
sgn
*
powf
(
2
,
-
14
.
0
f
)
*
(
m
/
1024
.
0
f
);
}
else
{
return
sgn
*
powf
(
2
,
e
-
15
.
0
f
)
*
(
1
.
0
f
+
(
m
/
1024
.
0
f
));
}
}
static
BOOL
is_autogenmipmap_supported
(
IDirect3DDevice9
*
device
,
D3DRESOURCETYPE
resource_type
)
{
HRESULT
hr
;
...
...
@@ -1011,6 +1048,93 @@ static void test_D3DXFillTexture(IDirect3DDevice9 *device)
}
else
skip
(
"Failed to create texture
\n
"
);
/* test floating-point textures */
hr
=
IDirect3DDevice9_CreateTexture
(
device
,
4
,
4
,
1
,
0
,
D3DFMT_A16B16G16R16F
,
D3DPOOL_MANAGED
,
&
tex
,
NULL
);
if
(
SUCCEEDED
(
hr
))
{
hr
=
D3DXFillTexture
(
tex
,
fillfunc
,
NULL
);
todo_wine
ok
(
hr
==
D3D_OK
,
"D3DXFillTexture returned %#x, expected %#x
\n
"
,
hr
,
D3D_OK
);
hr
=
IDirect3DTexture9_LockRect
(
tex
,
0
,
&
lock_rect
,
NULL
,
D3DLOCK_READONLY
);
if
(
SUCCEEDED
(
hr
))
{
pitch
=
lock_rect
.
Pitch
/
sizeof
(
WORD
);
for
(
y
=
0
;
y
<
4
;
y
++
)
{
WORD
*
ptr
=
(
WORD
*
)
lock_rect
.
pBits
+
y
*
pitch
;
for
(
x
=
0
;
x
<
4
;
x
++
)
{
D3DXVECTOR4
got
,
expected
;
got
.
x
=
float_16_to_32
(
*
ptr
++
);
got
.
y
=
float_16_to_32
(
*
ptr
++
);
got
.
z
=
float_16_to_32
(
*
ptr
++
);
got
.
w
=
float_16_to_32
(
*
ptr
++
);
expected
.
x
=
(
x
+
0
.
5
f
)
/
4
.
0
f
;
expected
.
y
=
(
y
+
0
.
5
f
)
/
4
.
0
f
;
expected
.
z
=
1
.
0
f
/
4
.
0
f
;
expected
.
w
=
1
.
0
f
;
todo_wine
expect_vec4
(
&
expected
,
&
got
);
}
}
IDirect3DTexture9_UnlockRect
(
tex
,
0
);
}
else
skip
(
"Failed to lock texture
\n
"
);
IDirect3DTexture9_Release
(
tex
);
}
else
skip
(
"Failed to create D3DFMT_A16B16G16R16F texture
\n
"
);
hr
=
IDirect3DDevice9_CreateTexture
(
device
,
4
,
4
,
1
,
0
,
D3DFMT_A32B32G32R32F
,
D3DPOOL_MANAGED
,
&
tex
,
NULL
);
if
(
SUCCEEDED
(
hr
))
{
hr
=
D3DXFillTexture
(
tex
,
fillfunc
,
NULL
);
todo_wine
ok
(
hr
==
D3D_OK
,
"D3DXFillTexture returned %#x, expected %#x
\n
"
,
hr
,
D3D_OK
);
hr
=
IDirect3DTexture9_LockRect
(
tex
,
0
,
&
lock_rect
,
NULL
,
D3DLOCK_READONLY
);
if
(
SUCCEEDED
(
hr
))
{
pitch
=
lock_rect
.
Pitch
/
sizeof
(
float
);
for
(
y
=
0
;
y
<
4
;
y
++
)
{
float
*
ptr
=
(
float
*
)
lock_rect
.
pBits
+
y
*
pitch
;
for
(
x
=
0
;
x
<
4
;
x
++
)
{
D3DXVECTOR4
got
,
expected
;
got
.
x
=
*
ptr
++
;
got
.
y
=
*
ptr
++
;
got
.
z
=
*
ptr
++
;
got
.
w
=
*
ptr
++
;
expected
.
x
=
(
x
+
0
.
5
f
)
/
4
.
0
f
;
expected
.
y
=
(
y
+
0
.
5
f
)
/
4
.
0
f
;
expected
.
z
=
1
.
0
f
/
4
.
0
f
;
expected
.
w
=
1
.
0
f
;
todo_wine
expect_vec4
(
&
expected
,
&
got
);
}
}
IDirect3DTexture9_UnlockRect
(
tex
,
0
);
}
else
skip
(
"Failed to lock texture
\n
"
);
IDirect3DTexture9_Release
(
tex
);
}
else
skip
(
"Failed to create D3DFMT_A32B32G32R32F texture
\n
"
);
}
static
void
WINAPI
fillfunc_cube
(
D3DXVECTOR4
*
value
,
const
D3DXVECTOR3
*
texcoord
,
...
...
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