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
67e0b356
Commit
67e0b356
authored
Oct 20, 2011
by
Vitaliy Margolen
Committed by
Alexandre Julliard
Oct 25, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dinput: Restore checks for DirectX 3 buffer size.
parent
6376b4cf
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
44 additions
and
29 deletions
+44
-29
device.c
dlls/dinput/device.c
+2
-2
device.c
dlls/dinput/tests/device.c
+42
-27
No files found.
dlls/dinput/device.c
View file @
67e0b356
...
@@ -1288,10 +1288,10 @@ HRESULT WINAPI IDirectInputDevice2WImpl_GetDeviceData(LPDIRECTINPUTDEVICE8W ifac
...
@@ -1288,10 +1288,10 @@ HRESULT WINAPI IDirectInputDevice2WImpl_GetDeviceData(LPDIRECTINPUTDEVICE8W ifac
TRACE
(
"(%p) %p -> %p(%d) x%d, 0x%08x
\n
"
,
TRACE
(
"(%p) %p -> %p(%d) x%d, 0x%08x
\n
"
,
This
,
dod
,
entries
,
entries
?
*
entries
:
0
,
dodsize
,
flags
);
This
,
dod
,
entries
,
entries
?
*
entries
:
0
,
dodsize
,
flags
);
if
(
This
->
dinput
->
dwVersion
==
0x0800
)
if
(
This
->
dinput
->
dwVersion
==
0x0800
||
dodsize
==
sizeof
(
DIDEVICEOBJECTDATA_DX3
)
)
{
{
if
(
!
This
->
acquired
)
return
DIERR_NOTACQUIRED
;
if
(
!
This
->
queue_len
)
return
DIERR_NOTBUFFERED
;
if
(
!
This
->
queue_len
)
return
DIERR_NOTBUFFERED
;
if
(
!
This
->
acquired
)
return
DIERR_NOTACQUIRED
;
}
}
if
(
!
This
->
queue_len
)
if
(
!
This
->
queue_len
)
...
...
dlls/dinput/tests/device.c
View file @
67e0b356
...
@@ -78,7 +78,9 @@ static void test_object_info(LPDIRECTINPUTDEVICE device, HWND hwnd)
...
@@ -78,7 +78,9 @@ static void test_object_info(LPDIRECTINPUTDEVICE device, HWND hwnd)
DIDEVICEOBJECTINSTANCE
obj_info
;
DIDEVICEOBJECTINSTANCE
obj_info
;
DWORD
obj_types
[]
=
{
DIDFT_BUTTON
,
DIDFT_AXIS
,
DIDFT_POV
};
DWORD
obj_types
[]
=
{
DIDFT_BUTTON
,
DIDFT_AXIS
,
DIDFT_POV
};
int
type_index
;
int
type_index
;
int
cnt
=
0
,
cnt1
=
0
;
int
cnt1
=
0
;
DWORD
cnt
=
0
;
DIDEVICEOBJECTDATA
buffer
[
5
];
hr
=
IDirectInputDevice_EnumObjects
(
device
,
enum_callback
,
&
cnt
,
DIDFT_ALL
);
hr
=
IDirectInputDevice_EnumObjects
(
device
,
enum_callback
,
&
cnt
,
DIDFT_ALL
);
ok
(
SUCCEEDED
(
hr
),
"EnumObjects() failed: %08x
\n
"
,
hr
);
ok
(
SUCCEEDED
(
hr
),
"EnumObjects() failed: %08x
\n
"
,
hr
);
...
@@ -98,18 +100,51 @@ static void test_object_info(LPDIRECTINPUTDEVICE device, HWND hwnd)
...
@@ -98,18 +100,51 @@ static void test_object_info(LPDIRECTINPUTDEVICE device, HWND hwnd)
ok
(
SUCCEEDED
(
hr
),
"EnumObjects() failed: %08x
\n
"
,
hr
);
ok
(
SUCCEEDED
(
hr
),
"EnumObjects() failed: %08x
\n
"
,
hr
);
}
}
/* Test buffered mode */
memset
(
&
dp
,
0
,
sizeof
(
dp
));
dp
.
diph
.
dwSize
=
sizeof
(
DIPROPDWORD
);
dp
.
diph
.
dwHeaderSize
=
sizeof
(
DIPROPHEADER
);
dp
.
diph
.
dwHow
=
DIPH_DEVICE
;
dp
.
diph
.
dwObj
=
0
;
dp
.
dwData
=
0
;
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_BUFFERSIZE
,
(
LPCDIPROPHEADER
)
&
dp
.
diph
);
ok
(
hr
==
DI_OK
,
"SetProperty() failed: %08x
\n
"
,
hr
);
cnt
=
5
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
&&
cnt
==
5
,
"GetDeviceData() failed: %08x cnt: %d
\n
"
,
hr
,
cnt
);
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
DIDEVICEOBJECTDATA_DX3
),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DIERR_NOTBUFFERED
,
"GetDeviceData() should have failed: %08x
\n
"
,
hr
);
IDirectInputDevice_Acquire
(
device
);
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
DIDEVICEOBJECTDATA_DX3
),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DIERR_NOTBUFFERED
,
"GetDeviceData() should have failed: %08x
\n
"
,
hr
);
IDirectInputDevice_Unacquire
(
device
);
dp
.
dwData
=
20
;
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_BUFFERSIZE
,
(
LPCDIPROPHEADER
)
&
dp
.
diph
);
ok
(
hr
==
DI_OK
,
"SetProperty() failed: %08x
\n
"
,
hr
);
cnt
=
5
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
,
"GetDeviceData() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
DIDEVICEOBJECTDATA_DX3
),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DIERR_NOTACQUIRED
,
"GetDeviceData() should have failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_Acquire
(
device
);
ok
(
hr
==
DI_OK
,
"Acquire() failed: %08x
\n
"
,
hr
);
cnt
=
1
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
,
"GetDeviceData() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_Unacquire
(
device
);
ok
(
hr
==
DI_OK
,
"Unacquire() failed: %08x
\n
"
,
hr
);
cnt
=
1
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
,
"GetDeviceData() failed: %08x
\n
"
,
hr
);
/* No need to test devices without axis */
/* No need to test devices without axis */
obj_info
.
dwSize
=
sizeof
(
obj_info
);
obj_info
.
dwSize
=
sizeof
(
obj_info
);
hr
=
IDirectInputDevice_GetObjectInfo
(
device
,
&
obj_info
,
16
,
DIPH_BYOFFSET
);
hr
=
IDirectInputDevice_GetObjectInfo
(
device
,
&
obj_info
,
16
,
DIPH_BYOFFSET
);
if
(
SUCCEEDED
(
hr
))
if
(
SUCCEEDED
(
hr
))
{
{
DWORD
cnt
;
DIDEVICEOBJECTDATA
buffer
[
5
];
/* No device supports per axis relative/absolute mode */
/* No device supports per axis relative/absolute mode */
memset
(
&
dp
,
0
,
sizeof
(
dp
));
dp
.
diph
.
dwSize
=
sizeof
(
DIPROPDWORD
);
dp
.
diph
.
dwHeaderSize
=
sizeof
(
DIPROPHEADER
);
dp
.
diph
.
dwHow
=
DIPH_BYOFFSET
;
dp
.
diph
.
dwHow
=
DIPH_BYOFFSET
;
dp
.
diph
.
dwObj
=
16
;
dp
.
diph
.
dwObj
=
16
;
dp
.
dwData
=
DIPROPAXISMODE_ABS
;
dp
.
dwData
=
DIPROPAXISMODE_ABS
;
...
@@ -122,29 +157,9 @@ static void test_object_info(LPDIRECTINPUTDEVICE device, HWND hwnd)
...
@@ -122,29 +157,9 @@ static void test_object_info(LPDIRECTINPUTDEVICE device, HWND hwnd)
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_AXISMODE
,
&
dp
.
diph
);
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_AXISMODE
,
&
dp
.
diph
);
ok
(
hr
==
DI_OK
,
"SetProperty() failed: %08x
\n
"
,
hr
);
ok
(
hr
==
DI_OK
,
"SetProperty() failed: %08x
\n
"
,
hr
);
dp
.
dwData
=
0
;
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_BUFFERSIZE
,
(
LPCDIPROPHEADER
)
&
dp
.
diph
);
ok
(
hr
==
DI_OK
,
"SetProperty() failed: %08x
\n
"
,
hr
);
cnt
=
5
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
&&
cnt
==
5
,
"GetDeviceData() failed: %08x cnt: %d
\n
"
,
hr
,
cnt
);
dp
.
dwData
=
20
;
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_BUFFERSIZE
,
(
LPCDIPROPHEADER
)
&
dp
.
diph
);
ok
(
hr
==
DI_OK
,
"SetProperty() failed: %08x
\n
"
,
hr
);
cnt
=
1
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
,
"GetDeviceData() failed: %08x
\n
"
,
hr
);
/* Cannot change mode while acquired */
/* Cannot change mode while acquired */
hr
=
IDirectInputDevice_Acquire
(
device
);
hr
=
IDirectInputDevice_Acquire
(
device
);
ok
(
hr
==
DI_OK
,
"Acquire() failed: %08x
\n
"
,
hr
);
ok
(
hr
==
DI_OK
,
"Acquire() failed: %08x
\n
"
,
hr
);
cnt
=
1
;
hr
=
IDirectInputDevice_GetDeviceData
(
device
,
sizeof
(
buffer
[
0
]),
buffer
,
&
cnt
,
0
);
ok
(
hr
==
DI_OK
,
"GetDeviceData() failed: %08x
\n
"
,
hr
);
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_AXISMODE
,
&
dp
.
diph
);
hr
=
IDirectInputDevice_SetProperty
(
device
,
DIPROP_AXISMODE
,
&
dp
.
diph
);
ok
(
hr
==
DIERR_ACQUIRED
,
"SetProperty() returned: %08x
\n
"
,
hr
);
ok
(
hr
==
DIERR_ACQUIRED
,
"SetProperty() returned: %08x
\n
"
,
hr
);
...
...
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