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
2f3b916d
Commit
2f3b916d
authored
Jul 01, 2022
by
Zhiyi Zhang
Committed by
Alexandre Julliard
Jul 07, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
atl: Avoid NULL pointer reference in AtlComModuleRevokeClassObjects().
Signed-off-by:
Zhiyi Zhang
<
zzhang@codeweavers.com
>
parent
f4890dac
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
58 additions
and
0 deletions
+58
-0
atl.c
dlls/atl/atl.c
+6
-0
atl.c
dlls/atl100/tests/atl.c
+26
-0
atl.c
dlls/atl110/tests/atl.c
+26
-0
No files found.
dlls/atl/atl.c
View file @
2f3b916d
...
...
@@ -598,6 +598,9 @@ HRESULT WINAPI AtlComModuleRevokeClassObjects(_ATL_COM_MODULE *module)
return
E_INVALIDARG
;
for
(
iter
=
module
->
m_ppAutoObjMapFirst
;
iter
<
module
->
m_ppAutoObjMapLast
;
iter
++
)
{
if
(
!
(
*
iter
))
continue
;
hres
=
CoRevokeClassObject
((
*
iter
)
->
dwRegister
);
if
(
FAILED
(
hres
))
return
hres
;
...
...
@@ -617,6 +620,9 @@ HRESULT WINAPI AtlComModuleRevokeClassObjects(_ATL_COM_MODULE *module)
return
E_INVALIDARG
;
for
(
iter
=
module
->
m_ppAutoObjMapFirst
;
iter
<
module
->
m_ppAutoObjMapLast
;
iter
++
)
{
if
(
!
(
*
iter
))
continue
;
hres
=
CoRevokeClassObject
((
*
iter
)
->
pCache
->
dwRegister
);
if
(
FAILED
(
hres
))
return
hres
;
...
...
dlls/atl100/tests/atl.c
View file @
2f3b916d
...
...
@@ -1115,6 +1115,31 @@ static void test_AtlComModuleRegisterClassObjects(void)
ok
(
hr
==
S_FALSE
,
"Unexpected hr %#lx.
\n
"
,
hr
);
}
static
void
test_AtlComModuleRevokeClassObjects
(
void
)
{
_ATL_OBJMAP_ENTRY
*
null_entry
=
NULL
;
_ATL_COM_MODULE
module
;
HRESULT
hr
;
/* Test NULL module */
hr
=
AtlComModuleRevokeClassObjects
(
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"Unexpected hr %#lx.
\n
"
,
hr
);
/* Test NULL m_ppAutoObjMapFirst and m_ppAutoObjMapLast */
module
.
cbSize
=
sizeof
(
module
);
module
.
m_ppAutoObjMapFirst
=
NULL
;
module
.
m_ppAutoObjMapLast
=
NULL
;
hr
=
AtlComModuleRevokeClassObjects
(
&
module
);
ok
(
hr
==
S_OK
,
"Unexpected hr %#lx.
\n
"
,
hr
);
/* Test m_ppAutoObjMapFirst and m_ppAutoObjMapLast both pointing to a NULL entry */
module
.
cbSize
=
sizeof
(
module
);
module
.
m_ppAutoObjMapFirst
=
&
null_entry
;
module
.
m_ppAutoObjMapLast
=
&
null_entry
;
hr
=
AtlComModuleRevokeClassObjects
(
&
module
);
ok
(
hr
==
S_OK
,
"Unexpected hr %#lx.
\n
"
,
hr
);
}
START_TEST
(
atl
)
{
if
(
!
register_class
())
...
...
@@ -1132,6 +1157,7 @@ START_TEST(atl)
test_AtlAxCreateControl
();
test_AtlComModuleGetClassObject
();
test_AtlComModuleRegisterClassObjects
();
test_AtlComModuleRevokeClassObjects
();
CoUninitialize
();
}
dlls/atl110/tests/atl.c
View file @
2f3b916d
...
...
@@ -82,12 +82,38 @@ static void test_AtlComModuleRegisterClassObjects(void)
ok
(
hr
==
S_FALSE
,
"Unexpected hr %#lx.
\n
"
,
hr
);
}
static
void
test_AtlComModuleRevokeClassObjects
(
void
)
{
_ATL_OBJMAP_ENTRY_EX
*
null_entry
=
NULL
;
_ATL_COM_MODULE
module
;
HRESULT
hr
;
/* Test NULL module */
hr
=
AtlComModuleRevokeClassObjects
(
NULL
);
ok
(
hr
==
E_INVALIDARG
,
"Unexpected hr %#lx.
\n
"
,
hr
);
/* Test NULL m_ppAutoObjMapFirst and m_ppAutoObjMapLast */
module
.
cbSize
=
sizeof
(
module
);
module
.
m_ppAutoObjMapFirst
=
NULL
;
module
.
m_ppAutoObjMapLast
=
NULL
;
hr
=
AtlComModuleRevokeClassObjects
(
&
module
);
ok
(
hr
==
S_OK
,
"Unexpected hr %#lx.
\n
"
,
hr
);
/* Test m_ppAutoObjMapFirst and m_ppAutoObjMapLast both pointing to a NULL entry */
module
.
cbSize
=
sizeof
(
module
);
module
.
m_ppAutoObjMapFirst
=
&
null_entry
;
module
.
m_ppAutoObjMapLast
=
&
null_entry
;
hr
=
AtlComModuleRevokeClassObjects
(
&
module
);
ok
(
hr
==
S_OK
,
"Unexpected hr %#lx.
\n
"
,
hr
);
}
START_TEST
(
atl
)
{
CoInitialize
(
NULL
);
test_AtlComModuleGetClassObject
();
test_AtlComModuleRegisterClassObjects
();
test_AtlComModuleRevokeClassObjects
();
CoUninitialize
();
}
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