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
7c166d67
Commit
7c166d67
authored
Dec 08, 2017
by
Huw Davies
Committed by
Alexandre Julliard
Dec 08, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ole32: Properly align HENHMETAFILE marshal data.
Signed-off-by:
Huw Davies
<
huw@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
eb810fbb
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
24 additions
and
16 deletions
+24
-16
usrmarshal.c
dlls/ole32/tests/usrmarshal.c
+17
-13
usrmarshal.c
dlls/ole32/usrmarshal.c
+7
-3
No files found.
dlls/ole32/tests/usrmarshal.c
View file @
7c166d67
...
...
@@ -347,7 +347,7 @@ static void test_marshal_HENHMETAFILE(void)
USER_MARSHAL_CB
umcb
;
MIDL_STUB_MESSAGE
stub_msg
;
RPC_MESSAGE
rpc_msg
;
unsigned
char
*
buffer
;
unsigned
char
*
buffer
,
*
buffer_end
;
ULONG
size
;
HENHMETAFILE
hemf
;
HENHMETAFILE
hemf2
=
NULL
;
...
...
@@ -356,26 +356,28 @@ static void test_marshal_HENHMETAFILE(void)
hemf
=
create_emf
();
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
NULL
,
0
,
MSHCTX_DIFFERENTMACHINE
);
size
=
HENHMETAFILE_UserSize
(
&
umcb
.
Flags
,
0
,
&
hemf
);
ok
(
size
>
2
0
,
"size should be at least 20
bytes, not %d
\n
"
,
size
);
size
=
HENHMETAFILE_UserSize
(
&
umcb
.
Flags
,
1
,
&
hemf
);
ok
(
size
>
2
4
,
"size should be at least 24
bytes, not %d
\n
"
,
size
);
buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
size
);
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
buffer
,
size
,
MSHCTX_DIFFERENTMACHINE
);
HENHMETAFILE_UserMarshal
(
&
umcb
.
Flags
,
buffer
,
&
hemf
);
wirehemf
=
buffer
;
buffer_end
=
HENHMETAFILE_UserMarshal
(
&
umcb
.
Flags
,
buffer
+
1
,
&
hemf
);
ok
(
buffer_end
==
buffer
+
size
,
"got %p buffer %p
\n
"
,
buffer_end
,
buffer
);
wirehemf
=
buffer
+
4
;
ok
(
*
(
DWORD
*
)
wirehemf
==
WDT_REMOTE_CALL
,
"wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
wirehemf
+=
sizeof
(
DWORD
);
ok
(
*
(
DWORD
*
)
wirehemf
==
(
DWORD
)(
DWORD_PTR
)
hemf
,
"wirestgm + 0x4 should be hemf instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
wirehemf
+=
sizeof
(
DWORD
);
ok
(
*
(
DWORD
*
)
wirehemf
==
(
size
-
0x1
0
),
"wirestgm + 0x8 should be size - 0x10
instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
ok
(
*
(
DWORD
*
)
wirehemf
==
(
size
-
0x1
4
),
"wirestgm + 0x8 should be size - 0x14
instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
wirehemf
+=
sizeof
(
DWORD
);
ok
(
*
(
DWORD
*
)
wirehemf
==
(
size
-
0x1
0
),
"wirestgm + 0xc should be size - 0x10
instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
ok
(
*
(
DWORD
*
)
wirehemf
==
(
size
-
0x1
4
),
"wirestgm + 0xc should be size - 0x14
instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
wirehemf
+=
sizeof
(
DWORD
);
ok
(
*
(
DWORD
*
)
wirehemf
==
EMR_HEADER
,
"wirestgm + 0x10 should be EMR_HEADER instead of %d
\n
"
,
*
(
DWORD
*
)
wirehemf
);
/* ... rest of data not tested - refer to tests for GetEnhMetaFileBits
* at this point */
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
buffer
,
size
,
MSHCTX_DIFFERENTMACHINE
);
HENHMETAFILE_UserUnmarshal
(
&
umcb
.
Flags
,
buffer
,
&
hemf2
);
buffer_end
=
HENHMETAFILE_UserUnmarshal
(
&
umcb
.
Flags
,
buffer
+
1
,
&
hemf2
);
ok
(
buffer_end
==
buffer
+
size
,
"got %p buffer %p
\n
"
,
buffer_end
,
buffer
);
ok
(
hemf2
!=
NULL
,
"HENHMETAFILE didn't unmarshal
\n
"
);
HeapFree
(
GetProcessHeap
(),
0
,
buffer
);
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
NULL
,
0
,
MSHCTX_DIFFERENTMACHINE
);
...
...
@@ -386,18 +388,20 @@ static void test_marshal_HENHMETAFILE(void)
hemf
=
NULL
;
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
NULL
,
0
,
MSHCTX_DIFFERENTMACHINE
);
size
=
HENHMETAFILE_UserSize
(
&
umcb
.
Flags
,
0
,
&
hemf
);
ok
(
size
==
8
,
"size should be 8
bytes, not %d
\n
"
,
size
);
size
=
HENHMETAFILE_UserSize
(
&
umcb
.
Flags
,
1
,
&
hemf
);
ok
(
size
==
12
,
"size should be 12
bytes, not %d
\n
"
,
size
);
buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
size
);
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
buffer
,
size
,
MSHCTX_DIFFERENTMACHINE
);
HENHMETAFILE_UserMarshal
(
&
umcb
.
Flags
,
buffer
,
&
hemf
);
wirehemf
=
buffer
;
buffer_end
=
HENHMETAFILE_UserMarshal
(
&
umcb
.
Flags
,
buffer
+
1
,
&
hemf
);
ok
(
buffer_end
==
buffer
+
size
,
"got %p buffer %p
\n
"
,
buffer_end
,
buffer
);
wirehemf
=
buffer
+
4
;
ok
(
*
(
DWORD
*
)
wirehemf
==
WDT_REMOTE_CALL
,
"wirestgm + 0x0 should be WDT_REMOTE_CALL instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
wirehemf
+=
sizeof
(
DWORD
);
ok
(
*
(
DWORD
*
)
wirehemf
==
(
DWORD
)(
DWORD_PTR
)
hemf
,
"wirestgm + 0x4 should be hemf instead of 0x%08x
\n
"
,
*
(
DWORD
*
)
wirehemf
);
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
buffer
,
size
,
MSHCTX_DIFFERENTMACHINE
);
HENHMETAFILE_UserUnmarshal
(
&
umcb
.
Flags
,
buffer
,
&
hemf2
);
buffer_end
=
HENHMETAFILE_UserUnmarshal
(
&
umcb
.
Flags
,
buffer
+
1
,
&
hemf2
);
ok
(
buffer_end
==
buffer
+
size
,
"got %p buffer %p
\n
"
,
buffer_end
,
buffer
);
ok
(
hemf2
==
NULL
,
"NULL HENHMETAFILE didn't unmarshal
\n
"
);
HeapFree
(
GetProcessHeap
(),
0
,
buffer
);
init_user_marshal_cb
(
&
umcb
,
&
stub_msg
,
&
rpc_msg
,
NULL
,
0
,
MSHCTX_DIFFERENTMACHINE
);
...
...
dlls/ole32/usrmarshal.c
View file @
7c166d67
...
...
@@ -1095,11 +1095,11 @@ void __RPC_USER HMETAFILE_UserFree(ULONG *pFlags, HMETAFILE *phmf)
* the first parameter is a ULONG.
* This function is only intended to be called by the RPC runtime.
*/
ULONG
__RPC_USER
HENHMETAFILE_UserSize
(
ULONG
*
pFlags
,
ULONG
StartingS
ize
,
HENHMETAFILE
*
phEmf
)
ULONG
__RPC_USER
HENHMETAFILE_UserSize
(
ULONG
*
pFlags
,
ULONG
s
ize
,
HENHMETAFILE
*
phEmf
)
{
ULONG
size
=
StartingSize
;
TRACE
(
"(%s, %d, %p
\n
"
,
debugstr_user_flags
(
pFlags
),
size
,
*
phEmf
)
;
TRACE
(
"(%s, %d, %p
\n
"
,
debugstr_user_flags
(
pFlags
),
StartingSize
,
*
phEmf
);
ALIGN_LENGTH
(
size
,
3
);
size
+=
sizeof
(
ULONG
);
if
(
LOWORD
(
*
pFlags
)
==
MSHCTX_INPROC
)
...
...
@@ -1144,6 +1144,8 @@ unsigned char * __RPC_USER HENHMETAFILE_UserMarshal(ULONG *pFlags, unsigned char
{
TRACE
(
"(%s, %p, &%p
\n
"
,
debugstr_user_flags
(
pFlags
),
pBuffer
,
*
phEmf
);
ALIGN_POINTER
(
pBuffer
,
3
);
if
(
LOWORD
(
*
pFlags
)
==
MSHCTX_INPROC
)
{
if
(
sizeof
(
*
phEmf
)
==
8
)
...
...
@@ -1202,6 +1204,8 @@ unsigned char * __RPC_USER HENHMETAFILE_UserUnmarshal(ULONG *pFlags, unsigned ch
TRACE
(
"(%s, %p, %p
\n
"
,
debugstr_user_flags
(
pFlags
),
pBuffer
,
phEmf
);
ALIGN_POINTER
(
pBuffer
,
3
);
fContext
=
*
(
ULONG
*
)
pBuffer
;
pBuffer
+=
sizeof
(
ULONG
);
...
...
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