Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1580 lines
43 KiB

  1. /*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  2. Copyright (c) 1993 - 1999 Microsoft Corporation
  3. Module Name :
  4. memsize.c
  5. Abstract :
  6. This file contains the routines called by MIDL 2.0 stubs and the
  7. intepreter for computing the memory size needed to hold a parameter being
  8. unmarshalled.
  9. Author :
  10. David Kays dkays November 1993.
  11. Revision History :
  12. Note:
  13. Simple types are not checked for buffer over-run since we are
  14. only reading from the buffer and not writing from it. So if
  15. a buffer overun actually occures, no real damage is done.
  16. ---------------------------------------------------------------------*/
  17. #include "precomp.hxx"
  18. #include "..\..\ndr20\ndrole.h"
  19. void
  20. Ndr64UDTSimpleTypeMemorySize(
  21. PMIDL_STUB_MESSAGE pStubMsg,
  22. PNDR64_FORMAT pFormat )
  23. /*++
  24. --*/
  25. {
  26. ALIGN(pStubMsg->Buffer, NDR64_SIMPLE_TYPE_MEMALIGN(*(PFORMAT_STRING)pFormat));
  27. pStubMsg->Buffer += NDR64_SIMPLE_TYPE_BUFSIZE(*(PFORMAT_STRING)pFormat);
  28. LENGTH_ALIGN( pStubMsg->MemorySize,
  29. NDR64_SIMPLE_TYPE_MEMALIGN(*(PFORMAT_STRING)pFormat) );
  30. pStubMsg->MemorySize += NDR64_SIMPLE_TYPE_MEMSIZE(*(PFORMAT_STRING)pFormat);
  31. }
  32. void
  33. Ndr64pRangeMemorySize(
  34. PMIDL_STUB_MESSAGE pStubMsg,
  35. PNDR64_FORMAT pFormat )
  36. /*++
  37. --*/
  38. {
  39. const NDR64_RANGE_FORMAT * pRangeFormat =
  40. (const NDR64_RANGE_FORMAT*)pFormat;
  41. Ndr64UDTSimpleTypeMemorySize( pStubMsg,
  42. (PFORMAT_STRING)&pRangeFormat->RangeType );
  43. }
  44. void
  45. Ndr64pInterfacePointerMemorySize(
  46. PMIDL_STUB_MESSAGE pStubMsg,
  47. PNDR64_FORMAT pFormat )
  48. /*++
  49. Routine Description :
  50. Computes the memory size needed for an interface pointer.
  51. Arguments :
  52. pStubMsg - Pointer to stub message.
  53. pFormat - Pointer's format string description.
  54. Return :
  55. The current memory size.
  56. // wire representation of a marshalled interface pointer
  57. typedef struct tagMInterfacePointer
  58. {
  59. ULONG ulCntData; // size of data
  60. [size_is(ulCntData)] BYTE abData[]; // data (OBJREF)
  61. } MInterfacePointer;
  62. --*/
  63. {
  64. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  65. // Unmarshal the conformant size and the count field.
  66. CHECK_EOB_WITH_WRAP_RAISE_BSD( pStubMsg->Buffer, (sizeof(NDR64_WIRE_COUNT_TYPE)+sizeof(ulong)) );
  67. NDR64_UINT32 MaxCount = Ndr64pConvertTo2GB( *(NDR64_WIRE_COUNT_TYPE *) pStubMsg->Buffer );
  68. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE);
  69. ulong ulCntData = *(ulong *) pStubMsg->Buffer;
  70. pStubMsg->Buffer += sizeof(ulong);
  71. if ( MaxCount != ulCntData )
  72. {
  73. RpcRaiseException( RPC_X_BAD_STUB_DATA );
  74. return;
  75. }
  76. RpcTryFinally
  77. {
  78. CHECK_EOB_WITH_WRAP_RAISE_BSD( pStubMsg->Buffer, MaxCount );
  79. if( (MaxCount > 0) && NDR64_IS_WALKIP(pStubMsg->uFlags) )
  80. {
  81. #if defined(DEBUG_WALKIP)
  82. CHAR AppName[MAX_PATH];
  83. memset(AppName, 0, sizeof(AppName ) );
  84. GetModuleFileNameA( NULL, AppName, sizeof(AppName ) );
  85. DbgPrint("WALKIP64 %s %p\n", AppName, pStubMsg->Buffer );
  86. #else
  87. IStream *pStream = (*NdrpCreateStreamOnMemory)(pStubMsg->Buffer, MaxCount);
  88. if(pStream == 0)
  89. RpcRaiseException(RPC_S_OUT_OF_MEMORY);
  90. HRESULT hr = (*pfnCoReleaseMarshalData)(pStream);
  91. pStream->Release();
  92. if(FAILED(hr))
  93. RpcRaiseException(hr);
  94. #endif
  95. }
  96. }
  97. RpcFinally
  98. {
  99. pStubMsg->Buffer += MaxCount;
  100. }
  101. RpcEndFinally
  102. }
  103. __forceinline void
  104. Ndr64pPointerMemorySizeInternal(
  105. PMIDL_STUB_MESSAGE pStubMsg,
  106. NDR64_PTR_WIRE_TYPE *pBufferMark,
  107. PNDR64_FORMAT pFormat )
  108. /*++
  109. Routine Description :
  110. Private routine for computing the memory size required for a pointer to
  111. anything. This is the entry point for pointers embedded in structures
  112. arrays, or unions.
  113. Used for FC64_RP, FC64_UP, FC64_FP, FC64_OP.
  114. Arguments :
  115. pStubMsg - Pointer to stub message.
  116. pBufferMark - Location in the buffer where a unique or full pointer's id is.
  117. Unused for ref pointers.
  118. pFormat - Pointer's format string description.
  119. Return :
  120. The computed memory size.
  121. --*/
  122. {
  123. const NDR64_POINTER_FORMAT *pPointerFormat = (NDR64_POINTER_FORMAT*) pFormat;
  124. PFORMAT_STRING pPointeeFormat = (PFORMAT_STRING)pPointerFormat->Pointee;
  125. switch ( pPointerFormat->FormatCode )
  126. {
  127. case FC64_RP :
  128. break;
  129. case FC64_UP :
  130. case FC64_OP :
  131. if ( ! *pBufferMark )
  132. return;
  133. break;
  134. case FC64_IP :
  135. if ( ! *pBufferMark )
  136. return;
  137. Ndr64pInterfacePointerMemorySize(pStubMsg,
  138. pPointeeFormat );
  139. return;
  140. case FC64_FP :
  141. //
  142. // Check if we've already mem sized this full pointer.
  143. //
  144. if ( Ndr64pFullPointerQueryRefId( pStubMsg,
  145. Ndr64pWirePtrToRefId(*pBufferMark),
  146. FULL_POINTER_MEM_SIZED,
  147. 0 ) )
  148. return;
  149. break;
  150. default :
  151. NDR_ASSERT(0,"Ndr64pPointerMemorySize : bad format char");
  152. RpcRaiseException( RPC_S_INTERNAL_ERROR );
  153. return;
  154. }
  155. //
  156. // We align all memory pointers on at least a void * boundary.
  157. //
  158. LENGTH_ALIGN( pStubMsg->MemorySize, PTR_MEM_ALIGN );
  159. if ( NDR64_SIMPLE_POINTER( pPointerFormat->Flags ) )
  160. {
  161. ALIGN(pStubMsg->Buffer, NDR64_SIMPLE_TYPE_BUFALIGN( *pPointeeFormat ));
  162. pStubMsg->Buffer += NDR64_SIMPLE_TYPE_BUFSIZE( *pPointeeFormat );
  163. LENGTH_ALIGN( pStubMsg->MemorySize,
  164. NDR64_SIMPLE_TYPE_MEMALIGN( *pPointeeFormat ) );
  165. pStubMsg->MemorySize += NDR64_SIMPLE_TYPE_MEMSIZE( *pPointeeFormat );
  166. return;
  167. }
  168. // Pointer to complex type.
  169. if ( NDR64_POINTER_DEREF( pPointerFormat->Flags ) )
  170. pStubMsg->MemorySize += PTR_MEM_SIZE;
  171. SAVE_CONTEXT<uchar> uFlagsSave( pStubMsg->uFlags );
  172. NDR64_RESET_EMBEDDED_FLAGS_TO_STANDALONE(pStubMsg->uFlags);
  173. Ndr64TopLevelTypeMemorySize( pStubMsg,
  174. pPointeeFormat );
  175. return;
  176. }
  177. void NDR64_MEMSIZE_POINTER_QUEUE_ELEMENT::Dispatch(PMIDL_STUB_MESSAGE pStubMsg)
  178. {
  179. SAVE_CONTEXT<uchar> uFlagsSave( pStubMsg->uFlags, uFlags );
  180. Ndr64pPointerMemorySizeInternal( pStubMsg,
  181. pBufferMark,
  182. pFormat );
  183. }
  184. #if defined(DBG)
  185. void NDR64_MEMSIZE_POINTER_QUEUE_ELEMENT::Print()
  186. {
  187. DbgPrint("NDR64_MEMSIZE_POINTER_QUEUE_ELEMENT:\n");
  188. DbgPrint("pNext: %p\n", pNext );
  189. DbgPrint("pFormat: %p\n", pFormat );
  190. DbgPrint("uFlags: %u\n", uFlags );
  191. DbgPrint("pBufferMark: %p\n", pBufferMark );
  192. }
  193. #endif
  194. void
  195. Ndr64pEnquePointerMemorySize(
  196. PMIDL_STUB_MESSAGE pStubMsg,
  197. NDR64_PTR_WIRE_TYPE *pBufferMark,
  198. PNDR64_FORMAT pFormat )
  199. {
  200. NDR64_POINTER_CONTEXT PointerContext( pStubMsg );
  201. RpcTryFinally
  202. {
  203. if ( !PointerContext.ShouldEnque() )
  204. {
  205. Ndr64pPointerMemorySizeInternal( pStubMsg,
  206. pBufferMark,
  207. pFormat );
  208. }
  209. else
  210. {
  211. NDR64_MEMSIZE_POINTER_QUEUE_ELEMENT*pElement =
  212. new(PointerContext.GetActiveState())
  213. NDR64_MEMSIZE_POINTER_QUEUE_ELEMENT(pStubMsg,
  214. (PFORMAT_STRING)pFormat,
  215. pBufferMark );
  216. PointerContext.Enque( pElement );
  217. }
  218. PointerContext.DispatchIfRequired();
  219. }
  220. RpcFinally
  221. {
  222. PointerContext.EndContext();
  223. }
  224. RpcEndFinally
  225. }
  226. void
  227. Ndr64pPointerMemorySize(
  228. PMIDL_STUB_MESSAGE pStubMsg,
  229. NDR64_PTR_WIRE_TYPE *pBufferMark,
  230. PNDR64_FORMAT pFormat )
  231. {
  232. SAVE_CONTEXT<uchar> uFlagsSave( pStubMsg->uFlags );
  233. NDR64_RESET_EMBEDDED_FLAGS_TO_STANDALONE(pStubMsg->uFlags);
  234. if ( !NdrIsLowStack(pStubMsg) )
  235. {
  236. Ndr64pPointerMemorySizeInternal(
  237. pStubMsg,
  238. pBufferMark,
  239. pFormat );
  240. return;
  241. }
  242. Ndr64pEnquePointerMemorySize(
  243. pStubMsg,
  244. pBufferMark,
  245. pFormat );
  246. }
  247. __forceinline void
  248. Ndr64TopLevelPointerMemorySize(
  249. PMIDL_STUB_MESSAGE pStubMsg,
  250. PNDR64_FORMAT pFormat )
  251. {
  252. NDR64_PTR_WIRE_TYPE * pBufferMark = NULL;
  253. //
  254. // If this is not a ref pointer then mark where the pointer's id is in
  255. // the buffer and increment the stub message buffer pointer.
  256. //
  257. if ( *(PFORMAT_STRING)pFormat != FC64_RP )
  258. {
  259. ALIGN(pStubMsg->Buffer, NDR64_PTR_WIRE_ALIGN );
  260. pBufferMark = (NDR64_PTR_WIRE_TYPE*)pStubMsg->Buffer;
  261. pStubMsg->Buffer += sizeof( NDR64_PTR_WIRE_TYPE );
  262. }
  263. pStubMsg->MemorySize += PTR_MEM_SIZE;
  264. Ndr64pPointerMemorySize( pStubMsg,
  265. pBufferMark,
  266. pFormat );
  267. }
  268. __forceinline void
  269. Ndr64EmbeddedPointerMemorySize(
  270. PMIDL_STUB_MESSAGE pStubMsg,
  271. PNDR64_FORMAT pFormat )
  272. {
  273. ALIGN(pStubMsg->Buffer, NDR64_PTR_WIRE_ALIGN );
  274. NDR64_PTR_WIRE_TYPE * pBufferMark = (NDR64_PTR_WIRE_TYPE*)pStubMsg->Buffer;
  275. pStubMsg->Buffer += sizeof( NDR64_PTR_WIRE_TYPE );
  276. pStubMsg->MemorySize += PTR_MEM_SIZE;
  277. if ( pStubMsg->IgnoreEmbeddedPointers )
  278. return;
  279. POINTER_MEMSIZE_SWAP_CONTEXT SwapContext( pStubMsg );
  280. Ndr64pPointerMemorySize( pStubMsg,
  281. pBufferMark,
  282. pFormat );
  283. }
  284. void
  285. Ndr64SimpleStructMemorySize(
  286. PMIDL_STUB_MESSAGE pStubMsg,
  287. PNDR64_FORMAT pFormat )
  288. /*++
  289. Routine Description :
  290. Computes the memory size required for a simple structure.
  291. Used for FC64_STRUCT and FC64_PSTRUCT.
  292. Arguments :
  293. pStubMsg - Pointer to stub message.
  294. pFormat - Structure's format string description.
  295. Return :
  296. The computed memory size.
  297. --*/
  298. {
  299. const NDR64_STRUCTURE_HEADER_FORMAT * const pStructFormat =
  300. (NDR64_STRUCTURE_HEADER_FORMAT*) pFormat;
  301. ALIGN( pStubMsg->Buffer, pStructFormat->Alignment );
  302. uchar *pBufferSave = pStubMsg->Buffer;
  303. LENGTH_ALIGN( pStubMsg->MemorySize, pStructFormat->Alignment );
  304. CHECK_EOB_RAISE_BSD( pStubMsg->Buffer + pStructFormat->MemorySize );
  305. pStubMsg->Buffer += pStructFormat->MemorySize;
  306. pStubMsg->MemorySize += pStructFormat->MemorySize;
  307. if ( pStructFormat->Flags.HasPointerInfo )
  308. {
  309. Ndr64pPointerLayoutMemorySize( pStubMsg,
  310. pStructFormat + 1,
  311. 0,
  312. pBufferSave );
  313. }
  314. }
  315. void
  316. Ndr64ConformantStructMemorySize(
  317. PMIDL_STUB_MESSAGE pStubMsg,
  318. PNDR64_FORMAT pFormat )
  319. /*++
  320. Routine Description :
  321. Computes the memory size required for a conformant structure.
  322. Arguments :
  323. pStubMsg - Pointer to stub message.
  324. pFormat - Pointer's format string description.
  325. Return :
  326. The computed memory size.
  327. --*/
  328. {
  329. const NDR64_CONF_STRUCTURE_HEADER_FORMAT * const pStructFormat =
  330. (NDR64_CONF_STRUCTURE_HEADER_FORMAT*) pFormat;
  331. NDR64_WIRE_COUNT_TYPE MaxCount;
  332. const NDR64_CONF_ARRAY_HEADER_FORMAT * const pArrayFormat =
  333. (NDR64_CONF_ARRAY_HEADER_FORMAT *) pStructFormat->ArrayDescription;
  334. if ( !NDR64_IS_CONF_MARK_VALID( pStubMsg->uFlags ) )
  335. {
  336. // Align for the conformance count.
  337. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  338. MaxCount = *((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer);
  339. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE);
  340. }
  341. else
  342. {
  343. MaxCount = *(NDR64_WIRE_COUNT_TYPE*)pStubMsg->ConformanceMark;
  344. }
  345. NDR64_UINT32 StructSize = Ndr64pConvertTo2GB( (NDR64_UINT64)pStructFormat->MemorySize +
  346. ( MaxCount * (NDR64_UINT64)pArrayFormat->ElementSize ) );
  347. // Realign for struct
  348. ALIGN(pStubMsg->Buffer, pStructFormat->Alignment);
  349. uchar *pBufferSave = pStubMsg->Buffer;
  350. LENGTH_ALIGN( pStubMsg->MemorySize, pStructFormat->Alignment );
  351. CHECK_EOB_WITH_WRAP_RAISE_IB( pStubMsg->Buffer, StructSize );
  352. pStubMsg->Buffer += StructSize;
  353. pStubMsg->MemorySize += StructSize;
  354. if ( pStructFormat->Flags.HasPointerInfo )
  355. {
  356. Ndr64pPointerLayoutMemorySize( pStubMsg,
  357. pStructFormat + 1,
  358. (NDR64_UINT32)MaxCount,
  359. pBufferSave );
  360. }
  361. }
  362. void
  363. Ndr64ComplexStructMemorySize(
  364. PMIDL_STUB_MESSAGE pStubMsg,
  365. PNDR64_FORMAT pFormat )
  366. /*++
  367. Routine Description :
  368. Computes the memory size required for a complex structure.
  369. Used for FC64_BOGUS_STRUCT.
  370. Arguments :
  371. pStubMsg - Pointer to stub message.
  372. pFormat - Pointer's format string description.
  373. Return :
  374. The computed memory size.
  375. Notes:
  376. This routine can calculate the memory size with or without pointees.
  377. When calculating size with pointees at the top level, the routine calls
  378. itself recursively to find out where pointees would be and then remember
  379. the context using pStubMsg->MemorySize and pStubMsg->PointerBufferMark.
  380. --*/
  381. {
  382. const NDR64_BOGUS_STRUCTURE_HEADER_FORMAT * pStructFormat =
  383. (NDR64_BOGUS_STRUCTURE_HEADER_FORMAT*) pFormat;
  384. const NDR64_CONF_BOGUS_STRUCTURE_HEADER_FORMAT * pConfStructFormat =
  385. (NDR64_CONF_BOGUS_STRUCTURE_HEADER_FORMAT*) pFormat;
  386. bool fSetPointerBufferMark = !pStubMsg->IgnoreEmbeddedPointers &&
  387. !pStubMsg->PointerBufferMark;
  388. if ( fSetPointerBufferMark )
  389. {
  390. pStubMsg->IgnoreEmbeddedPointers = TRUE;
  391. // This gets clobbered.
  392. uchar * BufferSave = pStubMsg->Buffer;
  393. ulong MemorySizeSave = pStubMsg->MemorySize;
  394. //
  395. // Get a buffer pointer to where the struct's pointees are.
  396. //
  397. Ndr64ComplexStructMemorySize(
  398. pStubMsg,
  399. pFormat );
  400. // Mark where the pointees begin.
  401. pStubMsg->PointerBufferMark = pStubMsg->Buffer;
  402. pStubMsg->PointerLength = pStubMsg->MemorySize;
  403. pStubMsg->IgnoreEmbeddedPointers = FALSE;
  404. pStubMsg->MemorySize = MemorySizeSave;
  405. pStubMsg->Buffer = BufferSave;
  406. }
  407. PFORMAT_STRING pFormatPointers = (PFORMAT_STRING)pStructFormat->PointerLayout;
  408. PFORMAT_STRING pFormatArray = NULL;
  409. PFORMAT_STRING pMemberLayout = ( *(PFORMAT_STRING)pFormat == FC64_CONF_BOGUS_STRUCT ||
  410. *(PFORMAT_STRING)pFormat == FC64_FORCED_CONF_BOGUS_STRUCT ) ?
  411. (PFORMAT_STRING)( pConfStructFormat + 1) :
  412. (PFORMAT_STRING)( pStructFormat + 1);
  413. SAVE_CONTEXT<uchar> uFlagsSave( pStubMsg->uFlags );
  414. SAVE_CONTEXT<uchar*> ConformanceMarkSave( pStubMsg->ConformanceMark );
  415. // Get conformant array description.
  416. if ( pStructFormat->Flags.HasConfArray )
  417. {
  418. pFormatArray = (PFORMAT_STRING)pConfStructFormat->ConfArrayDescription;
  419. if ( ! NDR64_IS_CONF_MARK_VALID( pStubMsg->uFlags ) )
  420. {
  421. NDR64_WIRE_COUNT_TYPE ConformanceSize;
  422. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  423. // conformance count marker
  424. pStubMsg->ConformanceMark = pStubMsg->Buffer;
  425. // Handle multidimensional arrays.
  426. ConformanceSize = pConfStructFormat->Dimensions * sizeof(NDR64_WIRE_COUNT_TYPE);
  427. CHECK_EOB_RAISE_BSD( pStubMsg->Buffer + ConformanceSize );
  428. pStubMsg->Buffer += ConformanceSize;
  429. NDR64_SET_CONF_MARK_VALID( pStubMsg->uFlags );
  430. }
  431. }
  432. else
  433. {
  434. pFormatArray = 0;
  435. }
  436. ALIGN(pStubMsg->Buffer, pStructFormat->Alignment);
  437. for ( ; ; )
  438. {
  439. switch ( *pMemberLayout )
  440. {
  441. case FC64_STRUCT:
  442. {
  443. const NDR64_SIMPLE_REGION_FORMAT *pRegion =
  444. (NDR64_SIMPLE_REGION_FORMAT*) pMemberLayout;
  445. ALIGN( pStubMsg->Buffer, pRegion->Alignment );
  446. CHECK_EOB_RAISE_BSD( pStubMsg->Buffer + pRegion->RegionSize );
  447. pStubMsg->Buffer += pRegion->RegionSize;
  448. pStubMsg->MemorySize += pRegion->RegionSize;
  449. pMemberLayout += sizeof( *pRegion );
  450. break;
  451. }
  452. case FC64_STRUCTPADN :
  453. {
  454. const NDR64_MEMPAD_FORMAT *pMemPad = (NDR64_MEMPAD_FORMAT*)pMemberLayout;
  455. pStubMsg->MemorySize += pMemPad->MemPad;
  456. pMemberLayout += sizeof(*pMemPad);
  457. break;
  458. }
  459. case FC64_POINTER :
  460. Ndr64EmbeddedPointerMemorySize(
  461. pStubMsg,
  462. pFormatPointers );
  463. pFormatPointers += sizeof(NDR64_POINTER_FORMAT);
  464. pMemberLayout += sizeof(NDR64_SIMPLE_MEMBER_FORMAT);
  465. break;
  466. case FC64_EMBEDDED_COMPLEX :
  467. {
  468. const NDR64_EMBEDDED_COMPLEX_FORMAT * pEmbeddedFormat =
  469. (NDR64_EMBEDDED_COMPLEX_FORMAT*) pMemberLayout;
  470. Ndr64EmbeddedTypeMemorySize( pStubMsg,
  471. pEmbeddedFormat->Type );
  472. pMemberLayout += sizeof(*pEmbeddedFormat);
  473. break;
  474. }
  475. case FC64_BUFFER_ALIGN:
  476. {
  477. const NDR64_BUFFER_ALIGN_FORMAT *pBufAlign =
  478. (NDR64_BUFFER_ALIGN_FORMAT*) pMemberLayout;
  479. ALIGN( pStubMsg->Buffer, pBufAlign->Alignment );
  480. pMemberLayout += sizeof( *pBufAlign );
  481. break;
  482. }
  483. case FC64_CHAR :
  484. case FC64_WCHAR :
  485. case FC64_INT8:
  486. case FC64_UINT8:
  487. case FC64_INT16:
  488. case FC64_UINT16:
  489. case FC64_INT32:
  490. case FC64_UINT32:
  491. case FC64_INT64:
  492. case FC64_UINT64:
  493. case FC64_FLOAT32 :
  494. case FC64_FLOAT64 :
  495. case FC64_ERROR_STATUS_T:
  496. ALIGN(pStubMsg->Buffer, NDR64_SIMPLE_TYPE_BUFALIGN(*pMemberLayout));
  497. pStubMsg->Buffer += NDR64_SIMPLE_TYPE_BUFSIZE( *pMemberLayout );
  498. pStubMsg->MemorySize += NDR64_SIMPLE_TYPE_MEMSIZE(*pMemberLayout);
  499. pMemberLayout += sizeof(NDR64_SIMPLE_MEMBER_FORMAT);
  500. break;
  501. case FC64_IGNORE:
  502. ALIGN(pStubMsg->Buffer, NDR64_PTR_WIRE_ALIGN );
  503. pStubMsg->Buffer += sizeof(NDR64_PTR_WIRE_TYPE) ;
  504. pStubMsg->MemorySize += PTR_MEM_SIZE;
  505. pMemberLayout += sizeof(NDR64_SIMPLE_MEMBER_FORMAT);
  506. break;
  507. case FC64_END :
  508. goto ComplexMemorySizeEnd;
  509. default :
  510. NDR_ASSERT(0,"Ndr64ComplexStructMemorySize : bad format char");
  511. RpcRaiseException( RPC_S_INTERNAL_ERROR );
  512. return;
  513. }
  514. }
  515. ComplexMemorySizeEnd :
  516. if ( pFormatArray )
  517. {
  518. Ndr64EmbeddedTypeMemorySize( pStubMsg,
  519. pFormatArray );
  520. }
  521. else
  522. {
  523. // If the structure doesn't have a conformant array, align it again
  524. ALIGN( pStubMsg->Buffer, pStructFormat->Alignment );
  525. }
  526. if ( fSetPointerBufferMark )
  527. {
  528. pStubMsg->Buffer = pStubMsg->PointerBufferMark;
  529. pStubMsg->MemorySize = pStubMsg->PointerLength;
  530. pStubMsg->PointerBufferMark = 0;
  531. pStubMsg->PointerLength = 0;
  532. }
  533. }
  534. void
  535. Ndr64FixedArrayMemorySize(
  536. PMIDL_STUB_MESSAGE pStubMsg,
  537. PNDR64_FORMAT pFormat )
  538. /*++
  539. Routine Description :
  540. Computes the memory size of a fixed array of any number of dimensions.
  541. Arguments :
  542. pStubMsg - Pointer to stub message.
  543. pFormat - Pointer's format string description.
  544. Return :
  545. The computed memory size.
  546. --*/
  547. {
  548. const NDR64_FIX_ARRAY_HEADER_FORMAT * pArrayFormat =
  549. (NDR64_FIX_ARRAY_HEADER_FORMAT*) pFormat;
  550. ALIGN(pStubMsg->Buffer, pArrayFormat->Alignment );
  551. LENGTH_ALIGN( pStubMsg->MemorySize, pArrayFormat->Alignment );
  552. CHECK_EOB_RAISE_BSD( pStubMsg->Buffer + pArrayFormat->TotalSize );
  553. uchar *pBufferStart = pStubMsg->Buffer;
  554. pStubMsg->Buffer += pArrayFormat->TotalSize;
  555. pStubMsg->MemorySize += pArrayFormat->TotalSize;
  556. if ( pArrayFormat->Flags.HasPointerInfo )
  557. {
  558. Ndr64pPointerLayoutMemorySize( pStubMsg,
  559. pArrayFormat + 1,
  560. 0,
  561. pBufferStart );
  562. }
  563. }
  564. void
  565. Ndr64ConformantArrayMemorySize(
  566. PMIDL_STUB_MESSAGE pStubMsg,
  567. PNDR64_FORMAT pFormat )
  568. /*++
  569. Routine Description :
  570. Computes the memory size of a top level one dimensional conformant array.
  571. Arguments :
  572. pStubMsg - Pointer to stub message.
  573. pFormat - Pointer's format string description.
  574. Return :
  575. The computed memory size.
  576. --*/
  577. {
  578. const NDR64_CONF_ARRAY_HEADER_FORMAT *pArrayFormat =
  579. (NDR64_CONF_ARRAY_HEADER_FORMAT*) pFormat;
  580. NDR64_WIRE_COUNT_TYPE MaxCount;
  581. if ( !NDR64_IS_CONF_MARK_VALID( pStubMsg->uFlags ) )
  582. {
  583. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  584. MaxCount = *((NDR64_WIRE_COUNT_TYPE*)pStubMsg->Buffer);
  585. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE);
  586. }
  587. else
  588. {
  589. MaxCount = *(NDR64_WIRE_COUNT_TYPE*)pStubMsg->ConformanceMark;
  590. }
  591. NDR64_UINT32 Size = Ndr64pConvertTo2GB( MaxCount *
  592. (NDR64_UINT64)pArrayFormat->ElementSize );
  593. ALIGN(pStubMsg->Buffer, pArrayFormat->Alignment );
  594. LENGTH_ALIGN( pStubMsg->MemorySize, pArrayFormat->Alignment );
  595. CHECK_EOB_WITH_WRAP_RAISE_IB( pStubMsg->Buffer, Size );
  596. uchar *pBufferStart = pStubMsg->Buffer;
  597. pStubMsg->Buffer += Size;
  598. pStubMsg->MemorySize += Size;
  599. if ( pArrayFormat->Flags.HasPointerInfo )
  600. {
  601. Ndr64pPointerLayoutMemorySize( pStubMsg,
  602. pArrayFormat + 1,
  603. (NDR64_UINT32)MaxCount,
  604. pBufferStart );
  605. }
  606. }
  607. void
  608. Ndr64ConformantVaryingArrayMemorySize(
  609. PMIDL_STUB_MESSAGE pStubMsg,
  610. PNDR64_FORMAT pFormat )
  611. /*++
  612. Routine Description :
  613. Computes the memory size of a one dimensional top level conformant
  614. varying array.
  615. Arguments :
  616. pStubMsg - Pointer to stub message.
  617. pFormat - Pointer's format string description.
  618. Return :
  619. The computed memory size.
  620. --*/
  621. {
  622. const NDR64_CONF_VAR_ARRAY_HEADER_FORMAT * pArrayFormat =
  623. (NDR64_CONF_VAR_ARRAY_HEADER_FORMAT*) pFormat;
  624. NDR64_WIRE_COUNT_TYPE MaxCount;
  625. if ( ! NDR64_IS_CONF_MARK_VALID( pStubMsg->uFlags ) )
  626. {
  627. // Align the buffer for conformance unmarshalling.
  628. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  629. MaxCount = *((NDR64_WIRE_COUNT_TYPE*)pStubMsg->Buffer);
  630. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE);
  631. }
  632. else
  633. {
  634. MaxCount = *(NDR64_WIRE_COUNT_TYPE*)pStubMsg->ConformanceMark;
  635. }
  636. //
  637. // Get the offset and actual count in case needed for pointer sizing.
  638. //
  639. ALIGN(pStubMsg->Buffer,NDR64_WIRE_COUNT_ALIGN);
  640. NDR64_WIRE_COUNT_TYPE Offset = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[0];
  641. NDR64_WIRE_COUNT_TYPE ActualCount = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[1];
  642. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE) * 2;
  643. NDR64_UINT32 MemorySize = Ndr64pConvertTo2GB(MaxCount *
  644. (NDR64_UINT64)pArrayFormat->ElementSize );
  645. NDR64_UINT32 BufferSize = Ndr64pConvertTo2GB(ActualCount *
  646. (NDR64_UINT64)pArrayFormat->ElementSize );
  647. if ( (Offset != 0) ||
  648. (MaxCount < ActualCount) )
  649. RpcRaiseException( RPC_X_INVALID_BOUND );
  650. //
  651. // Do the memory size increment now in case the actual count is 0.
  652. //
  653. LENGTH_ALIGN( pStubMsg->MemorySize, pArrayFormat->Alignment );
  654. pStubMsg->MemorySize += MemorySize;
  655. ALIGN(pStubMsg->Buffer, pArrayFormat->Alignment);
  656. CHECK_EOB_WITH_WRAP_RAISE_IB( pStubMsg->Buffer, BufferSize );
  657. uchar *pBufferStart = pStubMsg->Buffer;
  658. pStubMsg->Buffer += BufferSize;
  659. if ( pArrayFormat->Flags.HasPointerInfo )
  660. {
  661. Ndr64pPointerLayoutMemorySize( pStubMsg,
  662. pArrayFormat + 1,
  663. (NDR64_UINT32)ActualCount,
  664. pBufferStart );
  665. }
  666. }
  667. void
  668. Ndr64VaryingArrayMemorySize(
  669. PMIDL_STUB_MESSAGE pStubMsg,
  670. PNDR64_FORMAT pFormat )
  671. /*++
  672. Routine Description :
  673. Computes the memory size of a top level or embedded varying array.
  674. Used for FC64_SMVARRAY and FC64_LGVARRAY.
  675. Arguments :
  676. pStubMsg - Pointer to stub message.
  677. pFormat - Pointer's format string description.
  678. Return :
  679. The computed memory size.
  680. --*/
  681. {
  682. const NDR64_VAR_ARRAY_HEADER_FORMAT * pArrayFormat =
  683. (NDR64_VAR_ARRAY_HEADER_FORMAT*) pFormat;
  684. //
  685. // Get the offset and actual count.
  686. //
  687. ALIGN( pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  688. NDR64_WIRE_COUNT_TYPE Offset = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[0];
  689. NDR64_WIRE_COUNT_TYPE ActualCount = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[1];
  690. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE) * 2;
  691. NDR64_UINT32 BufferSize =
  692. Ndr64pConvertTo2GB( ActualCount *
  693. (NDR64_UINT64)pArrayFormat->ElementSize );
  694. if ( ( Offset != 0 ) ||
  695. ( BufferSize > pArrayFormat->TotalSize ) )
  696. RpcRaiseException( RPC_X_INVALID_BOUND );
  697. LENGTH_ALIGN( pStubMsg->MemorySize, pArrayFormat->Alignment );
  698. pStubMsg->MemorySize += pArrayFormat->TotalSize;
  699. ALIGN(pStubMsg->Buffer, pArrayFormat->Alignment);
  700. CHECK_EOB_WITH_WRAP_RAISE_IB( pStubMsg->Buffer, BufferSize );
  701. uchar *pBufferStart = pStubMsg->Buffer;
  702. pStubMsg->Buffer += BufferSize;
  703. if ( pArrayFormat->Flags.HasPointerInfo )
  704. {
  705. Ndr64pPointerLayoutMemorySize( pStubMsg,
  706. pArrayFormat + 1,
  707. (NDR64_UINT32)ActualCount,
  708. pBufferStart );
  709. }
  710. }
  711. void
  712. Ndr64ComplexArrayMemorySize(
  713. PMIDL_STUB_MESSAGE pStubMsg,
  714. PNDR64_FORMAT pFormat )
  715. /*++
  716. Routine Description :
  717. Computes the memory size of a top level complex array.
  718. Arguments :
  719. pStubMsg - Pointer to stub message.
  720. pFormat - Pointer's format string description.
  721. Return :
  722. The computed memory size.
  723. --*/
  724. {
  725. const NDR64_BOGUS_ARRAY_HEADER_FORMAT *pArrayFormat =
  726. (NDR64_BOGUS_ARRAY_HEADER_FORMAT *) pFormat;
  727. bool fSetPointerBufferMark = ! pStubMsg->IgnoreEmbeddedPointers &&
  728. ! pStubMsg->PointerBufferMark;
  729. if ( fSetPointerBufferMark )
  730. {
  731. pStubMsg->IgnoreEmbeddedPointers = TRUE;
  732. // Save this since it gets clobbered.
  733. ulong MemorySizeSave = pStubMsg->MemorySize;
  734. uchar* pBufferSave = pStubMsg->Buffer;
  735. //
  736. // Get a buffer pointer to where the array's pointees are.
  737. //
  738. Ndr64ComplexArrayMemorySize(
  739. pStubMsg,
  740. pFormat );
  741. // This is where the array pointees start.
  742. pStubMsg->PointerBufferMark = pStubMsg->Buffer;
  743. pStubMsg->PointerLength = pStubMsg->MemorySize;
  744. pStubMsg->IgnoreEmbeddedPointers = FALSE;
  745. pStubMsg->MemorySize = MemorySizeSave;
  746. pStubMsg->Buffer = pBufferSave;
  747. }
  748. BOOL IsFixed = ( pArrayFormat->FormatCode == FC64_FIX_BOGUS_ARRAY ) ||
  749. ( pArrayFormat->FormatCode == FC64_FIX_FORCED_BOGUS_ARRAY );
  750. PFORMAT_STRING pElementFormat = (PFORMAT_STRING)pArrayFormat->Element;
  751. SAVE_CONTEXT<uchar> uFlagsSave( pStubMsg->uFlags );
  752. SAVE_CONTEXT<uchar*> ConformanceMarkSave( pStubMsg->ConformanceMark );
  753. SAVE_CONTEXT<uchar*> VarianceMarkSave( pStubMsg->VarianceMark );
  754. NDR64_WIRE_COUNT_TYPE Elements = pArrayFormat->NumberElements;
  755. NDR64_WIRE_COUNT_TYPE Count = Elements;
  756. NDR64_WIRE_COUNT_TYPE Offset = 0;
  757. if ( !IsFixed )
  758. {
  759. const NDR64_CONF_VAR_BOGUS_ARRAY_HEADER_FORMAT* pConfVarFormat=
  760. (NDR64_CONF_VAR_BOGUS_ARRAY_HEADER_FORMAT*)pFormat;
  761. if ( pConfVarFormat->ConfDescription )
  762. {
  763. if ( ! NDR64_IS_CONF_MARK_VALID( pStubMsg->uFlags ) )
  764. {
  765. //
  766. // The outer most array dimension sets the conformance marker.
  767. //
  768. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN);
  769. pStubMsg->ConformanceMark = pStubMsg->Buffer;
  770. // Increment past conformance count(s).
  771. pStubMsg->Buffer += pArrayFormat->NumberDims * sizeof(NDR64_WIRE_COUNT_TYPE);
  772. CHECK_EOB_RAISE_BSD( pStubMsg->Buffer );
  773. NDR64_SET_CONF_MARK_VALID( pStubMsg->uFlags );
  774. }
  775. Elements = *(NDR64_WIRE_COUNT_TYPE*)pStubMsg->ConformanceMark;
  776. pStubMsg->ConformanceMark += sizeof(NDR64_WIRE_COUNT_TYPE);
  777. Offset = 0;
  778. Count = Elements;
  779. }
  780. if ( pConfVarFormat->VarDescription )
  781. {
  782. if ( ! NDR64_IS_VAR_MARK_VALID( pStubMsg->uFlags ) )
  783. {
  784. NDR64_UINT32 Dimensions;
  785. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN);
  786. // Mark where the variance counts are.
  787. pStubMsg->VarianceMark = pStubMsg->Buffer;
  788. Dimensions = pArrayFormat->Flags.IsArrayofStrings ?
  789. (pArrayFormat->NumberDims - 1) :
  790. (pArrayFormat->NumberDims);
  791. pStubMsg->Buffer += Dimensions * sizeof(NDR64_WIRE_COUNT_TYPE) * 2;
  792. CHECK_EOB_RAISE_BSD( pStubMsg->Buffer );
  793. if ( NDR64_IS_ARRAY_OR_STRING( *pElementFormat ) )
  794. NDR64_SET_VAR_MARK_VALID( pStubMsg->uFlags );
  795. }
  796. else if ( !NDR64_IS_ARRAY_OR_STRING( *pElementFormat ) )
  797. NDR64_RESET_VAR_MARK_VALID( pStubMsg->uFlags );
  798. Offset = ((NDR64_WIRE_COUNT_TYPE*)pStubMsg->VarianceMark)[0];
  799. Count = ((NDR64_WIRE_COUNT_TYPE*)pStubMsg->VarianceMark)[1];
  800. pStubMsg->VarianceMark += sizeof(NDR64_WIRE_COUNT_TYPE) * 2;
  801. if ( Elements < (Offset + Count) )
  802. RpcRaiseException( RPC_X_INVALID_BOUND );
  803. }
  804. }
  805. NDR64_UINT32 ElementMemorySize =
  806. Ndr64pMemorySize( pStubMsg,
  807. pElementFormat,
  808. TRUE );
  809. pStubMsg->MemorySize+= Ndr64pConvertTo2GB(Offset *
  810. (NDR64_UINT64)ElementMemorySize);
  811. Ndr64pConvertTo2GB( Elements *
  812. (NDR64_UINT64)ElementMemorySize );
  813. Ndr64pConvertTo2GB( Count *
  814. (NDR64_UINT64)ElementMemorySize );
  815. NDR64_WIRE_COUNT_TYPE LeftOverGap = Elements - Count - Offset;
  816. ALIGN(pStubMsg->Buffer, pArrayFormat->Alignment);
  817. for ( ; Count--; )
  818. {
  819. Ndr64EmbeddedTypeMemorySize( pStubMsg,
  820. pElementFormat );
  821. }
  822. pStubMsg->MemorySize += Ndr64pConvertTo2GB(LeftOverGap *
  823. ElementMemorySize );
  824. if ( fSetPointerBufferMark )
  825. {
  826. pStubMsg->Buffer = pStubMsg->PointerBufferMark;
  827. pStubMsg->MemorySize = pStubMsg->PointerLength;
  828. pStubMsg->PointerBufferMark = 0;
  829. pStubMsg->PointerLength = 0;
  830. }
  831. }
  832. void
  833. Ndr64NonConformantStringMemorySize(
  834. PMIDL_STUB_MESSAGE pStubMsg,
  835. PNDR64_FORMAT pFormat )
  836. /*++
  837. Routine Description :
  838. Computes the memory size of a non conformant string.
  839. Arguments :
  840. pStubMsg - Pointer to stub message.
  841. pFormat - Pointer's format string description.
  842. Return :
  843. The computed memory size.
  844. --*/
  845. {
  846. const NDR64_NON_CONFORMANT_STRING_FORMAT * pStringFormat =
  847. (NDR64_NON_CONFORMANT_STRING_FORMAT*) pFormat;
  848. ALIGN(pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  849. NDR64_WIRE_COUNT_TYPE Offset = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[0];
  850. NDR64_WIRE_COUNT_TYPE ActualCount = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[1];
  851. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE) * 2;
  852. NDR64_UINT32 BufferSize =
  853. Ndr64pConvertTo2GB( ActualCount *
  854. (NDR64_UINT64)pStringFormat->Header.ElementSize );
  855. if ( pStringFormat->Header.FormatCode == FC64_WCHAR_STRING )
  856. {
  857. // Align memory just in case.
  858. LENGTH_ALIGN( pStubMsg->MemorySize, 0x1 );
  859. }
  860. CHECK_EOB_WITH_WRAP_RAISE_BSD( pStubMsg->Buffer, BufferSize );
  861. pStubMsg->Buffer += BufferSize;
  862. pStubMsg->MemorySize += pStringFormat->TotalSize;
  863. }
  864. void
  865. Ndr64ConformantStringMemorySize(
  866. PMIDL_STUB_MESSAGE pStubMsg,
  867. PNDR64_FORMAT pFormat )
  868. /*++
  869. Routine Description :
  870. Computes the memory size of a top level conformant string.
  871. Arguments :
  872. pStubMsg - Pointer to stub message.
  873. pFormat - Pointer's format string description.
  874. Return :
  875. The computed memory size.
  876. --*/
  877. {
  878. const NDR64_CONFORMANT_STRING_FORMAT * const pStringFormat =
  879. (NDR64_CONFORMANT_STRING_FORMAT*) pFormat;
  880. NDR64_WIRE_COUNT_TYPE MaxCount;
  881. if ( ! NDR64_IS_CONF_MARK_VALID( pStubMsg->uFlags ) )
  882. {
  883. ALIGN( pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  884. MaxCount = *((NDR64_WIRE_COUNT_TYPE*)pStubMsg->Buffer);
  885. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE);
  886. }
  887. else
  888. {
  889. MaxCount = *(NDR64_WIRE_COUNT_TYPE*)pStubMsg->ConformanceMark;
  890. }
  891. ALIGN( pStubMsg->Buffer, NDR64_WIRE_COUNT_ALIGN );
  892. NDR64_WIRE_COUNT_TYPE Offset = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[0];
  893. NDR64_WIRE_COUNT_TYPE ActualCount = ((NDR64_WIRE_COUNT_TYPE *)pStubMsg->Buffer)[1];
  894. pStubMsg->Buffer += sizeof(NDR64_WIRE_COUNT_TYPE) * 2;
  895. NDR64_UINT32 TransmittedSize =
  896. Ndr64pConvertTo2GB( ActualCount *
  897. (NDR64_UINT64)pStringFormat->Header.ElementSize );
  898. NDR64_UINT32 MemorySize =
  899. Ndr64pConvertTo2GB( MaxCount *
  900. (NDR64_UINT64)pStringFormat->Header.ElementSize );
  901. CHECK_EOB_WITH_WRAP_RAISE_BSD( pStubMsg->Buffer, TransmittedSize );
  902. if ( pStringFormat->Header.FormatCode == FC64_CONF_WCHAR_STRING )
  903. {
  904. // Align memory just in case.
  905. LENGTH_ALIGN( pStubMsg->MemorySize, 0x1 );
  906. }
  907. pStubMsg->Buffer += TransmittedSize;
  908. pStubMsg->MemorySize += MemorySize;
  909. }
  910. void
  911. Ndr64UnionMemorySize(
  912. PMIDL_STUB_MESSAGE pStubMsg,
  913. PNDR64_FORMAT pFormat )
  914. /*++
  915. Routine Description :
  916. Computes the memory size of an encapsulated union.
  917. Used for FC64_ENCAPSULATED_UNION.
  918. Arguments :
  919. pStubMsg - Pointer to stub message.
  920. pFormat - Pointer's format string description.
  921. Return :
  922. The computed memory size.
  923. --*/
  924. {
  925. const NDR64_UNION_ARM_SELECTOR* pArmSelector;
  926. NDR64_FORMAT_CHAR SwitchType;
  927. NDR64_UINT32 MemorySize;
  928. switch(*(PFORMAT_STRING)pFormat)
  929. {
  930. case FC64_NON_ENCAPSULATED_UNION:
  931. {
  932. const NDR64_NON_ENCAPSULATED_UNION* pNonEncapUnionFormat =
  933. (const NDR64_NON_ENCAPSULATED_UNION*) pFormat;
  934. ALIGN(pStubMsg->Buffer, pNonEncapUnionFormat->Alignment);
  935. SwitchType = pNonEncapUnionFormat->SwitchType;
  936. pArmSelector = (NDR64_UNION_ARM_SELECTOR*)(pNonEncapUnionFormat + 1);
  937. MemorySize = pNonEncapUnionFormat->MemorySize;
  938. break;
  939. }
  940. case FC64_ENCAPSULATED_UNION:
  941. {
  942. const NDR64_ENCAPSULATED_UNION* pEncapUnionFormat =
  943. (const NDR64_ENCAPSULATED_UNION*)pFormat;
  944. ALIGN(pStubMsg->Buffer, pEncapUnionFormat->Alignment);
  945. SwitchType = pEncapUnionFormat->SwitchType;
  946. pArmSelector = (NDR64_UNION_ARM_SELECTOR*)(pEncapUnionFormat + 1);
  947. MemorySize = pEncapUnionFormat->MemorySize;
  948. break;
  949. }
  950. default:
  951. NDR_ASSERT("Bad union format\n", 0);
  952. return;
  953. }
  954. EXPR_VALUE SwitchIs =
  955. Ndr64pSimpleTypeToExprValue( SwitchType,
  956. pStubMsg->Buffer );
  957. pStubMsg->MemorySize += MemorySize;
  958. pStubMsg->Buffer += NDR64_SIMPLE_TYPE_BUFSIZE(SwitchType);
  959. ALIGN(pStubMsg->Buffer, pArmSelector->Alignment);
  960. PNDR64_FORMAT pArmFormat =
  961. Ndr64pFindUnionArm( pStubMsg,
  962. pArmSelector,
  963. SwitchIs );
  964. if ( ! pArmFormat )
  965. return;
  966. Ndr64EmbeddedTypeMemorySize( pStubMsg,
  967. pArmFormat );
  968. }
  969. void
  970. Ndr64XmitOrRepAsMemorySize(
  971. PMIDL_STUB_MESSAGE pStubMsg,
  972. PNDR64_FORMAT pFormat,
  973. bool bIsEmbedded )
  974. /*++
  975. Routine Description :
  976. Computes the memory size required for the presented type of a
  977. transmit as or represent as.
  978. See mrshl.c for the description of the FC layout.
  979. Arguments :
  980. pStubMsg - Pointer to stub message.
  981. pFormat - Pointer's format string description.
  982. Return :
  983. The computed memory size of the presented type object.
  984. --*/
  985. {
  986. NDR64_TRANSMIT_AS_FORMAT *pTransFormat = ( NDR64_TRANSMIT_AS_FORMAT *) pFormat;
  987. NDR_ASSERT( pTransFormat->FormatCode == FC64_TRANSMIT_AS || pTransFormat->FormatCode , "invalid format string for user marshal" );
  988. pStubMsg->MemorySize += pTransFormat->PresentedTypeMemorySize;
  989. // In NDR64, Xmit/Rep cannot be a pointer or contain a pointer.
  990. // So we don't need to worry about the pointer queue here.
  991. if ( bIsEmbedded )
  992. {
  993. Ndr64EmbeddedTypeMemorySize( pStubMsg,
  994. pTransFormat->TransmittedType );
  995. }
  996. else
  997. {
  998. Ndr64TopLevelTypeMemorySize( pStubMsg,
  999. pTransFormat->TransmittedType );
  1000. }
  1001. }
  1002. void
  1003. Ndr64TopLevelXmitOrRepAsMemorySize(
  1004. PMIDL_STUB_MESSAGE pStubMsg,
  1005. PNDR64_FORMAT pFormat )
  1006. {
  1007. Ndr64XmitOrRepAsMemorySize( pStubMsg,
  1008. pFormat,
  1009. false );
  1010. }
  1011. void
  1012. Ndr64EmbeddedXmitOrRepAsMemorySize(
  1013. PMIDL_STUB_MESSAGE pStubMsg,
  1014. PNDR64_FORMAT pFormat )
  1015. {
  1016. Ndr64XmitOrRepAsMemorySize( pStubMsg,
  1017. pFormat,
  1018. true );
  1019. }
  1020. void
  1021. NDR64_USR_MRSHL_MEMSIZE_POINTER_QUEUE_ELEMENT::Dispatch(MIDL_STUB_MESSAGE *pStubMsg)
  1022. {
  1023. Ndr64TopLevelTypeMemorySize( pStubMsg,
  1024. pFormat );
  1025. }
  1026. #if defined(DBG)
  1027. void
  1028. NDR64_USR_MRSHL_MEMSIZE_POINTER_QUEUE_ELEMENT::Print()
  1029. {
  1030. DbgPrint("NDR64_USR_MRSHL_MEMSIZE_POINTER_QUEUE_ELEMENT\n");
  1031. DbgPrint("pFormat: %p\n", pFormat );
  1032. }
  1033. #endif
  1034. void
  1035. Ndr64UserMarshallPointeeMemorySize(
  1036. PMIDL_STUB_MESSAGE pStubMsg,
  1037. PNDR64_FORMAT pFormat )
  1038. {
  1039. if ( pStubMsg->IgnoreEmbeddedPointers )
  1040. return;
  1041. if ( !pStubMsg->pPointerQueueState ||
  1042. !pStubMsg->pPointerQueueState->GetActiveQueue() )
  1043. {
  1044. POINTER_MEMSIZE_SWAP_CONTEXT SwapContext( pStubMsg );
  1045. Ndr64TopLevelTypeMemorySize(
  1046. pStubMsg,
  1047. pFormat );
  1048. return;
  1049. }
  1050. NDR64_USR_MRSHL_MEMSIZE_POINTER_QUEUE_ELEMENT*pElement =
  1051. new(pStubMsg->pPointerQueueState)
  1052. NDR64_USR_MRSHL_MEMSIZE_POINTER_QUEUE_ELEMENT((PFORMAT_STRING)pFormat );
  1053. pStubMsg->pPointerQueueState->GetActiveQueue()->Enque( pElement );
  1054. }
  1055. void
  1056. Ndr64UserMarshalMemorySize(
  1057. PMIDL_STUB_MESSAGE pStubMsg,
  1058. PNDR64_FORMAT pFormat,
  1059. bool bIsEmbedded )
  1060. /*++
  1061. Routine Description :
  1062. Computes the memory size required for a usr_marshal type.
  1063. See mrshl.c for the description of the layouts.
  1064. Arguments :
  1065. pStubMsg - Pointer to stub message.
  1066. pFormat - Pointer's format string description.
  1067. Return :
  1068. The memory size of the usr_marshall object.
  1069. --*/
  1070. {
  1071. NDR64_USER_MARSHAL_FORMAT *pUserFormat = ( NDR64_USER_MARSHAL_FORMAT *) pFormat;
  1072. pStubMsg->MemorySize += pUserFormat->UserTypeMemorySize;
  1073. ALIGN( pStubMsg->Buffer, pUserFormat->TransmittedTypeWireAlignment );
  1074. if ( pUserFormat->Flags & USER_MARSHAL_POINTER )
  1075. {
  1076. if ( ( pUserFormat->Flags & USER_MARSHAL_UNIQUE ) ||
  1077. (( pUserFormat->Flags & USER_MARSHAL_REF ) && bIsEmbedded) )
  1078. {
  1079. // it's embedded: unique or ref.
  1080. pStubMsg->Buffer += sizeof(NDR64_PTR_WIRE_TYPE);
  1081. }
  1082. Ndr64UserMarshallPointeeMemorySize( pStubMsg,
  1083. pUserFormat->TransmittedType );
  1084. return;
  1085. }
  1086. if ( bIsEmbedded )
  1087. {
  1088. Ndr64EmbeddedTypeMemorySize( pStubMsg,
  1089. pUserFormat->TransmittedType );
  1090. }
  1091. else
  1092. {
  1093. Ndr64TopLevelTypeMemorySize( pStubMsg,
  1094. pUserFormat->TransmittedType );
  1095. }
  1096. return;
  1097. }
  1098. void
  1099. Ndr64TopLevelUserMarshalMemorySize(
  1100. PMIDL_STUB_MESSAGE pStubMsg,
  1101. PNDR64_FORMAT pFormat )
  1102. {
  1103. Ndr64UserMarshalMemorySize( pStubMsg,
  1104. pFormat,
  1105. false );
  1106. }
  1107. void
  1108. Ndr64EmbeddedUserMarshalMemorySize(
  1109. PMIDL_STUB_MESSAGE pStubMsg,
  1110. PNDR64_FORMAT pFormat )
  1111. {
  1112. Ndr64UserMarshalMemorySize( pStubMsg,
  1113. pFormat,
  1114. true );
  1115. }
  1116. // define the jump table
  1117. #define NDR64_BEGIN_TABLE \
  1118. PNDR64_MEM_SIZE_ROUTINE extern const Ndr64MemSizeRoutinesTable[] = \
  1119. {
  1120. #define NDR64_TABLE_END \
  1121. };
  1122. #define NDR64_ZERO_ENTRY NULL
  1123. #define NDR64_UNUSED_TABLE_ENTRY( number, tokenname ) ,NULL
  1124. #define NDR64_UNUSED_TABLE_ENTRY_NOSYM( number ) ,NULL
  1125. #define NDR64_TABLE_ENTRY( number, tokenname, marshall, embeddedmarshall, unmarshall, embeddedunmarshall, buffersize, embeddedbuffersize, memsize, embeddedmemsize, free, embeddedfree, typeflags ) \
  1126. ,memsize
  1127. #define NDR64_SIMPLE_TYPE_TABLE_ENTRY( number, tokenname, buffersize, memorysize) \
  1128. ,Ndr64UDTSimpleTypeMemorySize
  1129. #include "tokntbl.h"
  1130. C_ASSERT( sizeof(Ndr64MemSizeRoutinesTable)/sizeof(PNDR64_MEM_SIZE_ROUTINE) == 256 );
  1131. #undef NDR64_BEGIN_TABLE
  1132. #undef NDR64_TABLE_ENTRY
  1133. #define NDR64_BEGIN_TABLE \
  1134. PNDR64_MEM_SIZE_ROUTINE extern const Ndr64EmbeddedMemSizeRoutinesTable[] = \
  1135. {
  1136. #define NDR64_TABLE_ENTRY( number, tokenname, marshall, embeddedmarshall, unmarshall, embeddedunmarshall, buffersize, embeddedbuffersize, memsize, embeddedmemsize, free, embeddedfree, typeflags ) \
  1137. ,embeddedmemsize
  1138. #include "tokntbl.h"
  1139. C_ASSERT( sizeof(Ndr64EmbeddedMemSizeRoutinesTable)/sizeof(PNDR64_MEM_SIZE_ROUTINE) == 256 );