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
af28d72a
Commit
af28d72a
authored
Mar 14, 2010
by
Andrew Nguyen
Committed by
Alexandre Julliard
Mar 15, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dxdiagn: Fix string copy behavior with an excessively short buffer in…
dxdiagn: Fix string copy behavior with an excessively short buffer in IDxDiagContainer::EnumPropNames.
parent
f1e00541
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
66 additions
and
6 deletions
+66
-6
container.c
dlls/dxdiagn/container.c
+5
-5
container.c
dlls/dxdiagn/tests/container.c
+61
-1
No files found.
dlls/dxdiagn/container.c
View file @
af28d72a
...
@@ -196,16 +196,16 @@ static HRESULT WINAPI IDxDiagContainerImpl_EnumPropNames(PDXDIAGCONTAINER iface,
...
@@ -196,16 +196,16 @@ static HRESULT WINAPI IDxDiagContainerImpl_EnumPropNames(PDXDIAGCONTAINER iface,
p
=
This
->
properties
;
p
=
This
->
properties
;
while
(
NULL
!=
p
)
{
while
(
NULL
!=
p
)
{
if
(
dwIndex
==
i
)
{
if
(
dwIndex
==
i
)
{
if
(
cchPropName
<=
strlenW
(
p
->
vName
))
{
TRACE
(
"Found property name %s, copying string
\n
"
,
debugstr_w
(
p
->
vName
));
return
DXDIAG_E_INSUFFICIENT_BUFFER
;
}
lstrcpynW
(
pwszPropName
,
p
->
vName
,
cchPropName
);
lstrcpynW
(
pwszPropName
,
p
->
vName
,
cchPropName
);
return
S_OK
;
return
(
cchPropName
<=
strlenW
(
p
->
vName
))
?
DXDIAG_E_INSUFFICIENT_BUFFER
:
S_OK
;
}
}
p
=
p
->
next
;
p
=
p
->
next
;
++
i
;
++
i
;
}
}
TRACE
(
"Failed to find property name at specified index
\n
"
);
return
E_INVALIDARG
;
return
E_INVALIDARG
;
}
}
...
...
dlls/dxdiagn/tests/container.c
View file @
af28d72a
...
@@ -394,7 +394,6 @@ static void test_EnumPropNames(void)
...
@@ -394,7 +394,6 @@ static void test_EnumPropNames(void)
IDxDiagContainer
*
child
=
NULL
;
IDxDiagContainer
*
child
=
NULL
;
DWORD
count
,
index
,
propcount
;
DWORD
count
,
index
,
propcount
;
static
const
WCHAR
testW
[]
=
{
't'
,
'e'
,
's'
,
't'
,
0
};
static
const
WCHAR
testW
[]
=
{
't'
,
'e'
,
's'
,
't'
,
0
};
static
const
WCHAR
zerotestW
[]
=
{
0
,
'e'
,
's'
,
't'
,
0
};
if
(
!
create_root_IDxDiagContainer
())
if
(
!
create_root_IDxDiagContainer
())
{
{
...
@@ -460,6 +459,67 @@ static void test_EnumPropNames(void)
...
@@ -460,6 +459,67 @@ static void test_EnumPropNames(void)
ok
(
!
memcmp
(
property
,
testW
,
sizeof
(
testW
)),
ok
(
!
memcmp
(
property
,
testW
,
sizeof
(
testW
)),
"Expected the property buffer to be unchanged, got %s
\n
"
,
wine_dbgstr_w
(
property
));
"Expected the property buffer to be unchanged, got %s
\n
"
,
wine_dbgstr_w
(
property
));
trace
(
"Starting property enumeration of the %s container:
\n
"
,
wine_dbgstr_w
(
container
));
/* We should be able to enumerate as many properties as the value that
* IDxDiagContainer::GetNumberOfProps returns. */
for
(
index
=
0
;
index
<=
propcount
;
index
++
)
{
/* A buffer size of 1 is unlikely to be valid, as only a null terminator
* could be stored, and it is unlikely that a property name could be empty. */
DWORD
buffersize
=
1
;
memcpy
(
property
,
testW
,
sizeof
(
testW
));
hr
=
IDxDiagContainer_EnumPropNames
(
child
,
index
,
property
,
buffersize
);
if
(
hr
==
E_INVALIDARG
)
{
/* We should get here when index is one more than the maximum index value. */
ok
(
propcount
==
index
,
"Expected IDxDiagContainer::EnumPropNames to return E_INVALIDARG "
"on the last index %d, got 0x%08x
\n
"
,
index
,
hr
);
ok
(
!
memcmp
(
property
,
testW
,
sizeof
(
testW
)),
"Expected the property buffer to be unchanged, got %s
\n
"
,
wine_dbgstr_w
(
property
));
break
;
}
else
if
(
hr
==
DXDIAG_E_INSUFFICIENT_BUFFER
)
{
WCHAR
temp
[
256
];
ok
(
property
[
0
]
==
'\0'
,
"Expected the property buffer string to be empty, got %s
\n
"
,
wine_dbgstr_w
(
property
));
hr
=
IDxDiagContainer_EnumPropNames
(
child
,
index
,
temp
,
sizeof
(
temp
)
/
sizeof
(
WCHAR
));
ok
(
hr
==
S_OK
,
"Expected IDxDiagContainer::EnumPropNames to return S_OK, got 0x%08x
\n
"
,
hr
);
/* Show that the DirectX SDK's stipulation that the buffer be at
* least 256 characters long is a mere suggestion, and smaller sizes
* can be acceptable also. IDxDiagContainer::EnumPropNames doesn't
* provide a way of getting the exact size required, so the buffersize
* value will be iterated to at most 256 characters. */
for
(
buffersize
=
2
;
buffersize
<=
256
;
buffersize
++
)
{
memcpy
(
property
,
testW
,
sizeof
(
testW
));
hr
=
IDxDiagContainer_EnumPropNames
(
child
,
index
,
property
,
buffersize
);
if
(
hr
!=
DXDIAG_E_INSUFFICIENT_BUFFER
)
break
;
ok
(
!
memcmp
(
temp
,
property
,
sizeof
(
WCHAR
)
*
(
buffersize
-
1
)),
"Expected truncated property name string, got %s
\n
"
,
wine_dbgstr_w
(
property
));
}
ok
(
hr
==
S_OK
,
"Expected IDxDiagContainer::EnumPropNames to return S_OK, "
"got hr = 0x%08x, buffersize = %d
\n
"
,
hr
,
buffersize
);
if
(
hr
==
S_OK
)
trace
(
"child[%d] = %s, length = %d
\n
"
,
index
,
wine_dbgstr_w
(
property
),
buffersize
);
}
else
{
ok
(
0
,
"IDxDiagContainer::EnumPropNames unexpectedly returned 0x%08x
\n
"
,
hr
);
break
;
}
}
IDxDiagContainer_Release
(
child
);
IDxDiagContainer_Release
(
child
);
cleanup:
cleanup:
...
...
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