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
4b4192f3
Commit
4b4192f3
authored
May 10, 2006
by
Robert Shearman
Committed by
Alexandre Julliard
May 10, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
rpcrt4: Correctly align the buffer to read/write array data to.
parent
95d79e2c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
43 additions
and
3 deletions
+43
-3
ndr_marshall.c
dlls/rpcrt4/ndr_marshall.c
+43
-3
No files found.
dlls/rpcrt4/ndr_marshall.c
View file @
4b4192f3
...
@@ -1906,6 +1906,8 @@ unsigned char * WINAPI NdrConformantArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -1906,6 +1906,8 @@ unsigned char * WINAPI NdrConformantArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
PFORMAT_STRING
pFormat
)
PFORMAT_STRING
pFormat
)
{
{
DWORD
size
=
0
,
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
DWORD
size
=
0
,
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
unsigned
char
alignment
=
pFormat
[
1
]
+
1
;
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
if
(
pFormat
[
0
]
!=
RPC_FC_CARRAY
)
FIXME
(
"format=%d
\n
"
,
pFormat
[
0
]);
if
(
pFormat
[
0
]
!=
RPC_FC_CARRAY
)
FIXME
(
"format=%d
\n
"
,
pFormat
[
0
]);
...
@@ -1915,6 +1917,8 @@ unsigned char * WINAPI NdrConformantArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -1915,6 +1917,8 @@ unsigned char * WINAPI NdrConformantArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
NDR_LOCAL_UINT32_WRITE
(
pStubMsg
->
Buffer
,
size
);
NDR_LOCAL_UINT32_WRITE
(
pStubMsg
->
Buffer
,
size
);
pStubMsg
->
Buffer
+=
4
;
pStubMsg
->
Buffer
+=
4
;
ALIGN_POINTER
(
pStubMsg
->
Buffer
,
alignment
);
memcpy
(
pStubMsg
->
Buffer
,
pMemory
,
size
*
esize
);
memcpy
(
pStubMsg
->
Buffer
,
pMemory
,
size
*
esize
);
pStubMsg
->
BufferMark
=
pStubMsg
->
Buffer
;
pStubMsg
->
BufferMark
=
pStubMsg
->
Buffer
;
pStubMsg
->
Buffer
+=
size
*
esize
;
pStubMsg
->
Buffer
+=
size
*
esize
;
...
@@ -1935,6 +1939,8 @@ unsigned char * WINAPI NdrConformantArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -1935,6 +1939,8 @@ unsigned char * WINAPI NdrConformantArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
unsigned
char
fMustAlloc
)
unsigned
char
fMustAlloc
)
{
{
DWORD
size
=
0
,
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
DWORD
size
=
0
,
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
unsigned
char
alignment
=
pFormat
[
1
]
+
1
;
TRACE
(
"(%p,%p,%p,%d)
\n
"
,
pStubMsg
,
ppMemory
,
pFormat
,
fMustAlloc
);
TRACE
(
"(%p,%p,%p,%d)
\n
"
,
pStubMsg
,
ppMemory
,
pFormat
,
fMustAlloc
);
if
(
pFormat
[
0
]
!=
RPC_FC_CARRAY
)
FIXME
(
"format=%d
\n
"
,
pFormat
[
0
]);
if
(
pFormat
[
0
]
!=
RPC_FC_CARRAY
)
FIXME
(
"format=%d
\n
"
,
pFormat
[
0
]);
...
@@ -1944,6 +1950,8 @@ unsigned char * WINAPI NdrConformantArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -1944,6 +1950,8 @@ unsigned char * WINAPI NdrConformantArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
if
(
fMustAlloc
||
!*
ppMemory
)
if
(
fMustAlloc
||
!*
ppMemory
)
*
ppMemory
=
NdrAllocate
(
pStubMsg
,
size
*
esize
);
*
ppMemory
=
NdrAllocate
(
pStubMsg
,
size
*
esize
);
ALIGN_POINTER
(
pStubMsg
->
Buffer
,
alignment
);
memcpy
(
*
ppMemory
,
pStubMsg
->
Buffer
,
size
*
esize
);
memcpy
(
*
ppMemory
,
pStubMsg
->
Buffer
,
size
*
esize
);
pStubMsg
->
BufferMark
=
pStubMsg
->
Buffer
;
pStubMsg
->
BufferMark
=
pStubMsg
->
Buffer
;
...
@@ -1962,14 +1970,19 @@ void WINAPI NdrConformantArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -1962,14 +1970,19 @@ void WINAPI NdrConformantArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
PFORMAT_STRING
pFormat
)
PFORMAT_STRING
pFormat
)
{
{
DWORD
size
=
0
,
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
DWORD
size
=
0
,
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
unsigned
char
alignment
=
pFormat
[
1
]
+
1
;
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
if
(
pFormat
[
0
]
!=
RPC_FC_CARRAY
)
FIXME
(
"format=%d
\n
"
,
pFormat
[
0
]);
if
(
pFormat
[
0
]
!=
RPC_FC_CARRAY
)
FIXME
(
"format=%d
\n
"
,
pFormat
[
0
]);
pFormat
=
ComputeConformance
(
pStubMsg
,
pMemory
,
pFormat
+
4
,
0
);
pFormat
=
ComputeConformance
(
pStubMsg
,
pMemory
,
pFormat
+
4
,
0
);
size
=
pStubMsg
->
MaxCount
;
size
=
pStubMsg
->
MaxCount
;
pStubMsg
->
BufferLength
+=
4
;
ALIGN_LENGTH
(
pStubMsg
->
BufferLength
,
alignment
);
/* conformance value plus array */
/* conformance value plus array */
pStubMsg
->
BufferLength
+=
size
of
(
DWORD
)
+
size
*
esize
;
pStubMsg
->
BufferLength
+=
size
*
esize
;
EmbeddedPointerBufferSize
(
pStubMsg
,
pMemory
,
pFormat
);
EmbeddedPointerBufferSize
(
pStubMsg
,
pMemory
,
pFormat
);
}
}
...
@@ -2015,6 +2028,7 @@ unsigned char* WINAPI NdrConformantVaryingArrayMarshall( PMIDL_STUB_MESSAGE pStu
...
@@ -2015,6 +2028,7 @@ unsigned char* WINAPI NdrConformantVaryingArrayMarshall( PMIDL_STUB_MESSAGE pStu
unsigned
char
*
pMemory
,
unsigned
char
*
pMemory
,
PFORMAT_STRING
pFormat
)
PFORMAT_STRING
pFormat
)
{
{
unsigned
char
alignment
=
pFormat
[
1
]
+
1
;
DWORD
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
DWORD
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
TRACE
(
"(%p, %p, %p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
TRACE
(
"(%p, %p, %p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
...
@@ -2036,6 +2050,8 @@ unsigned char* WINAPI NdrConformantVaryingArrayMarshall( PMIDL_STUB_MESSAGE pStu
...
@@ -2036,6 +2050,8 @@ unsigned char* WINAPI NdrConformantVaryingArrayMarshall( PMIDL_STUB_MESSAGE pStu
NDR_LOCAL_UINT32_WRITE
(
pStubMsg
->
Buffer
,
pStubMsg
->
ActualCount
);
NDR_LOCAL_UINT32_WRITE
(
pStubMsg
->
Buffer
,
pStubMsg
->
ActualCount
);
pStubMsg
->
Buffer
+=
4
;
pStubMsg
->
Buffer
+=
4
;
ALIGN_POINTER
(
pStubMsg
->
Buffer
,
alignment
);
memcpy
(
pStubMsg
->
Buffer
,
pMemory
+
pStubMsg
->
Offset
,
pStubMsg
->
ActualCount
*
esize
);
memcpy
(
pStubMsg
->
Buffer
,
pMemory
+
pStubMsg
->
Offset
,
pStubMsg
->
ActualCount
*
esize
);
pStubMsg
->
BufferMark
=
pStubMsg
->
Buffer
;
pStubMsg
->
BufferMark
=
pStubMsg
->
Buffer
;
pStubMsg
->
Buffer
+=
pStubMsg
->
ActualCount
*
esize
;
pStubMsg
->
Buffer
+=
pStubMsg
->
ActualCount
*
esize
;
...
@@ -2056,6 +2072,7 @@ unsigned char* WINAPI NdrConformantVaryingArrayUnmarshall( PMIDL_STUB_MESSAGE pS
...
@@ -2056,6 +2072,7 @@ unsigned char* WINAPI NdrConformantVaryingArrayUnmarshall( PMIDL_STUB_MESSAGE pS
PFORMAT_STRING
pFormat
,
PFORMAT_STRING
pFormat
,
unsigned
char
fMustAlloc
)
unsigned
char
fMustAlloc
)
{
{
unsigned
char
alignment
=
pFormat
[
1
]
+
1
;
DWORD
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
DWORD
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
TRACE
(
"(%p, %p, %p, %d)
\n
"
,
pStubMsg
,
ppMemory
,
pFormat
,
fMustAlloc
);
TRACE
(
"(%p, %p, %p, %d)
\n
"
,
pStubMsg
,
ppMemory
,
pFormat
,
fMustAlloc
);
...
@@ -2066,9 +2083,12 @@ unsigned char* WINAPI NdrConformantVaryingArrayUnmarshall( PMIDL_STUB_MESSAGE pS
...
@@ -2066,9 +2083,12 @@ unsigned char* WINAPI NdrConformantVaryingArrayUnmarshall( PMIDL_STUB_MESSAGE pS
RpcRaiseException
(
RPC_S_INTERNAL_ERROR
);
RpcRaiseException
(
RPC_S_INTERNAL_ERROR
);
return
NULL
;
return
NULL
;
}
}
pFormat
=
ReadConformance
(
pStubMsg
,
pFormat
);
pFormat
=
ReadConformance
(
pStubMsg
,
pFormat
);
pFormat
=
ReadVariance
(
pStubMsg
,
pFormat
);
pFormat
=
ReadVariance
(
pStubMsg
,
pFormat
);
ALIGN_POINTER
(
pStubMsg
->
Buffer
,
alignment
);
if
(
!*
ppMemory
||
fMustAlloc
)
if
(
!*
ppMemory
||
fMustAlloc
)
*
ppMemory
=
NdrAllocate
(
pStubMsg
,
pStubMsg
->
MaxCount
*
esize
);
*
ppMemory
=
NdrAllocate
(
pStubMsg
,
pStubMsg
->
MaxCount
*
esize
);
memcpy
(
*
ppMemory
+
pStubMsg
->
Offset
,
pStubMsg
->
Buffer
,
pStubMsg
->
ActualCount
*
esize
);
memcpy
(
*
ppMemory
+
pStubMsg
->
Offset
,
pStubMsg
->
Buffer
,
pStubMsg
->
ActualCount
*
esize
);
...
@@ -2109,6 +2129,7 @@ void WINAPI NdrConformantVaryingArrayFree( PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2109,6 +2129,7 @@ void WINAPI NdrConformantVaryingArrayFree( PMIDL_STUB_MESSAGE pStubMsg,
void
WINAPI
NdrConformantVaryingArrayBufferSize
(
PMIDL_STUB_MESSAGE
pStubMsg
,
void
WINAPI
NdrConformantVaryingArrayBufferSize
(
PMIDL_STUB_MESSAGE
pStubMsg
,
unsigned
char
*
pMemory
,
PFORMAT_STRING
pFormat
)
unsigned
char
*
pMemory
,
PFORMAT_STRING
pFormat
)
{
{
unsigned
char
alignment
=
pFormat
[
1
]
+
1
;
DWORD
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
DWORD
esize
=
*
(
const
WORD
*
)(
pFormat
+
2
);
TRACE
(
"(%p, %p, %p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
TRACE
(
"(%p, %p, %p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
...
@@ -2125,8 +2146,12 @@ void WINAPI NdrConformantVaryingArrayBufferSize( PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2125,8 +2146,12 @@ void WINAPI NdrConformantVaryingArrayBufferSize( PMIDL_STUB_MESSAGE pStubMsg,
/* compute length */
/* compute length */
pFormat
=
ComputeVariance
(
pStubMsg
,
pMemory
,
pFormat
,
0
);
pFormat
=
ComputeVariance
(
pStubMsg
,
pMemory
,
pFormat
,
0
);
/* conformance + offset + variance + array */
/* conformance + offset + variance */
pStubMsg
->
BufferLength
+=
3
*
sizeof
(
DWORD
)
+
pStubMsg
->
ActualCount
*
esize
;
pStubMsg
->
BufferLength
+=
3
*
sizeof
(
DWORD
);
ALIGN_LENGTH
(
pStubMsg
->
BufferLength
,
alignment
);
pStubMsg
->
BufferLength
+=
pStubMsg
->
ActualCount
*
esize
;
EmbeddedPointerBufferSize
(
pStubMsg
,
pMemory
,
pFormat
);
EmbeddedPointerBufferSize
(
pStubMsg
,
pMemory
,
pFormat
);
}
}
...
@@ -2152,6 +2177,7 @@ unsigned char * WINAPI NdrComplexArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2152,6 +2177,7 @@ unsigned char * WINAPI NdrComplexArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
{
{
ULONG
count
,
def
;
ULONG
count
,
def
;
BOOL
variance_present
;
BOOL
variance_present
;
unsigned
char
alignment
;
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
...
@@ -2162,6 +2188,8 @@ unsigned char * WINAPI NdrComplexArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2162,6 +2188,8 @@ unsigned char * WINAPI NdrComplexArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
return
NULL
;
return
NULL
;
}
}
alignment
=
pFormat
[
1
]
+
1
;
def
=
*
(
const
WORD
*
)
&
pFormat
[
2
];
def
=
*
(
const
WORD
*
)
&
pFormat
[
2
];
pFormat
+=
4
;
pFormat
+=
4
;
...
@@ -2182,6 +2210,8 @@ unsigned char * WINAPI NdrComplexArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2182,6 +2210,8 @@ unsigned char * WINAPI NdrComplexArrayMarshall(PMIDL_STUB_MESSAGE pStubMsg,
pStubMsg
->
Buffer
+=
4
;
pStubMsg
->
Buffer
+=
4
;
}
}
ALIGN_POINTER
(
pStubMsg
->
Buffer
,
alignment
);
for
(
count
=
0
;
count
<
pStubMsg
->
ActualCount
;
count
++
)
for
(
count
=
0
;
count
<
pStubMsg
->
ActualCount
;
count
++
)
pMemory
=
ComplexMarshall
(
pStubMsg
,
pMemory
,
pFormat
,
NULL
);
pMemory
=
ComplexMarshall
(
pStubMsg
,
pMemory
,
pFormat
,
NULL
);
...
@@ -2199,6 +2229,7 @@ unsigned char * WINAPI NdrComplexArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2199,6 +2229,7 @@ unsigned char * WINAPI NdrComplexArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
unsigned
char
fMustAlloc
)
unsigned
char
fMustAlloc
)
{
{
ULONG
count
,
esize
;
ULONG
count
,
esize
;
unsigned
char
alignment
;
unsigned
char
*
pMemory
;
unsigned
char
*
pMemory
;
TRACE
(
"(%p,%p,%p,%d)
\n
"
,
pStubMsg
,
ppMemory
,
pFormat
,
fMustAlloc
);
TRACE
(
"(%p,%p,%p,%d)
\n
"
,
pStubMsg
,
ppMemory
,
pFormat
,
fMustAlloc
);
...
@@ -2210,6 +2241,8 @@ unsigned char * WINAPI NdrComplexArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2210,6 +2241,8 @@ unsigned char * WINAPI NdrComplexArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
return
NULL
;
return
NULL
;
}
}
alignment
=
pFormat
[
1
]
+
1
;
pFormat
+=
4
;
pFormat
+=
4
;
pFormat
=
ReadConformance
(
pStubMsg
,
pFormat
);
pFormat
=
ReadConformance
(
pStubMsg
,
pFormat
);
...
@@ -2223,6 +2256,8 @@ unsigned char * WINAPI NdrComplexArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2223,6 +2256,8 @@ unsigned char * WINAPI NdrComplexArrayUnmarshall(PMIDL_STUB_MESSAGE pStubMsg,
memset
(
*
ppMemory
,
0
,
pStubMsg
->
MaxCount
*
esize
);
memset
(
*
ppMemory
,
0
,
pStubMsg
->
MaxCount
*
esize
);
}
}
ALIGN_POINTER
(
pStubMsg
->
Buffer
,
alignment
);
pMemory
=
*
ppMemory
;
pMemory
=
*
ppMemory
;
for
(
count
=
0
;
count
<
pStubMsg
->
ActualCount
;
count
++
)
for
(
count
=
0
;
count
<
pStubMsg
->
ActualCount
;
count
++
)
pMemory
=
ComplexUnmarshall
(
pStubMsg
,
pMemory
,
pFormat
,
NULL
,
fMustAlloc
);
pMemory
=
ComplexUnmarshall
(
pStubMsg
,
pMemory
,
pFormat
,
NULL
,
fMustAlloc
);
...
@@ -2238,6 +2273,7 @@ void WINAPI NdrComplexArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2238,6 +2273,7 @@ void WINAPI NdrComplexArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
PFORMAT_STRING
pFormat
)
PFORMAT_STRING
pFormat
)
{
{
ULONG
count
,
def
;
ULONG
count
,
def
;
unsigned
char
alignment
;
BOOL
variance_present
;
BOOL
variance_present
;
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
TRACE
(
"(%p,%p,%p)
\n
"
,
pStubMsg
,
pMemory
,
pFormat
);
...
@@ -2249,6 +2285,8 @@ void WINAPI NdrComplexArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2249,6 +2285,8 @@ void WINAPI NdrComplexArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
return
;
return
;
}
}
alignment
=
pFormat
[
1
]
+
1
;
def
=
*
(
const
WORD
*
)
&
pFormat
[
2
];
def
=
*
(
const
WORD
*
)
&
pFormat
[
2
];
pFormat
+=
4
;
pFormat
+=
4
;
...
@@ -2263,6 +2301,8 @@ void WINAPI NdrComplexArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
...
@@ -2263,6 +2301,8 @@ void WINAPI NdrComplexArrayBufferSize(PMIDL_STUB_MESSAGE pStubMsg,
if
(
variance_present
)
if
(
variance_present
)
pStubMsg
->
BufferLength
+=
2
*
sizeof
(
ULONG
);
pStubMsg
->
BufferLength
+=
2
*
sizeof
(
ULONG
);
ALIGN_LENGTH
(
pStubMsg
->
BufferLength
,
alignment
);
for
(
count
=
0
;
count
<
pStubMsg
->
ActualCount
;
count
++
)
for
(
count
=
0
;
count
<
pStubMsg
->
ActualCount
;
count
++
)
pMemory
=
ComplexBufferSize
(
pStubMsg
,
pMemory
,
pFormat
,
NULL
);
pMemory
=
ComplexBufferSize
(
pStubMsg
,
pMemory
,
pFormat
,
NULL
);
}
}
...
...
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