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
8ec6cfed
Commit
8ec6cfed
authored
Mar 30, 2010
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Pack the COPYDATASTRUCT structure in messages to allow crossing 32/64 boundaries.
parent
5c652698
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
8 deletions
+28
-8
message.c
dlls/user32/message.c
+28
-8
No files found.
dlls/user32/message.c
View file @
8ec6cfed
...
...
@@ -139,6 +139,13 @@ struct packed_WINDOWPOS
DWORD
__pad3
;
};
struct
packed_COPYDATASTRUCT
{
ULONGLONG
dwData
;
DWORD
cbData
;
ULONGLONG
lpData
;
};
/* the structures are unpacked on top of the packed ones, so make sure they fit */
C_ASSERT
(
sizeof
(
struct
packed_CREATESTRUCTW
)
>=
sizeof
(
CREATESTRUCTW
)
);
C_ASSERT
(
sizeof
(
struct
packed_DRAWITEMSTRUCT
)
>=
sizeof
(
DRAWITEMSTRUCT
)
);
...
...
@@ -146,6 +153,7 @@ C_ASSERT( sizeof(struct packed_MEASUREITEMSTRUCT) >= sizeof(MEASUREITEMSTRUCT) )
C_ASSERT
(
sizeof
(
struct
packed_DELETEITEMSTRUCT
)
>=
sizeof
(
DELETEITEMSTRUCT
)
);
C_ASSERT
(
sizeof
(
struct
packed_COMPAREITEMSTRUCT
)
>=
sizeof
(
COMPAREITEMSTRUCT
)
);
C_ASSERT
(
sizeof
(
struct
packed_WINDOWPOS
)
>=
sizeof
(
WINDOWPOS
)
);
C_ASSERT
(
sizeof
(
struct
packed_COPYDATASTRUCT
)
>=
sizeof
(
COPYDATASTRUCT
)
);
union
packed_structs
{
...
...
@@ -155,6 +163,7 @@ union packed_structs
struct
packed_DELETEITEMSTRUCT
dls
;
struct
packed_COMPAREITEMSTRUCT
cis
;
struct
packed_WINDOWPOS
wp
;
struct
packed_COPYDATASTRUCT
cds
;
};
/* description of the data fields that need to be packed along with a sent message */
...
...
@@ -761,9 +770,12 @@ static size_t pack_message( HWND hwnd, UINT message, WPARAM wparam, LPARAM lpara
}
case
WM_COPYDATA
:
{
COPYDATASTRUCT
*
cp
=
(
COPYDATASTRUCT
*
)
lparam
;
push_data
(
data
,
cp
,
sizeof
(
*
cp
)
);
if
(
cp
->
lpData
)
push_data
(
data
,
cp
->
lpData
,
cp
->
cbData
);
COPYDATASTRUCT
*
cds
=
(
COPYDATASTRUCT
*
)
lparam
;
data
->
ps
.
cds
.
cbData
=
cds
->
cbData
;
data
->
ps
.
cds
.
dwData
=
cds
->
dwData
;
data
->
ps
.
cds
.
lpData
=
pack_ptr
(
cds
->
lpData
);
push_data
(
data
,
&
data
->
ps
.
cds
,
sizeof
(
data
->
ps
.
cds
)
);
if
(
cds
->
lpData
)
push_data
(
data
,
cds
->
lpData
,
cds
->
cbData
);
return
0
;
}
case
WM_NOTIFY
:
...
...
@@ -1081,13 +1093,21 @@ static BOOL unpack_message( HWND hwnd, UINT message, WPARAM *wparam, LPARAM *lpa
}
case
WM_COPYDATA
:
{
COPYDATASTRUCT
*
cp
=
*
buffer
;
if
(
size
<
sizeof
(
*
cp
))
return
FALSE
;
if
(
cp
->
lpData
)
COPYDATASTRUCT
cds
;
if
(
size
<
sizeof
(
ps
->
cds
))
return
FALSE
;
cds
.
dwData
=
(
ULONG_PTR
)
unpack_ptr
(
ps
->
cds
.
dwData
);
if
(
ps
->
cds
.
lpData
)
{
cds
.
cbData
=
ps
->
cds
.
cbData
;
cds
.
lpData
=
&
ps
->
cds
+
1
;
minsize
=
sizeof
(
ps
->
cds
)
+
cds
.
cbData
;
}
else
{
minsize
=
sizeof
(
*
cp
)
+
cp
->
cbData
;
c
p
->
lpData
=
cp
+
1
;
cds
.
cbData
=
0
;
c
ds
.
lpData
=
0
;
}
memcpy
(
&
ps
->
cds
,
&
cds
,
sizeof
(
cds
)
);
break
;
}
case
WM_NOTIFY
:
...
...
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