Jump to content

DosSubAllocMem: Difference between revisions

From EDM2
Ak120 (talk | contribs)
mNo edit summary
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
DosSubAllocMem allocates a memory block from a memory pool created using [[DosSubSetMem]].
=== Syntax ===
=== Syntax ===
 
  DosSubAllocMem( ''pOffset'', ''pBlockOffset'', ''ulSize'' )
  rc = DosSubAllocMem( ''pOffset'',  
                      ''pBlockOffset'',  
                      ''ulSize'' );
 


=== Parameters ===
=== Parameters ===
PVOID ''pOffset'' (input)
;PVOID ''pOffset'' (input):This is the offset of the memory pool from which the memory block is to be allocated.
 
;PPVOID ''pBlockOffset'' (output):This is a pointer to a longword, in which the offset of the allocated memory block is to be stored.
This is the offset of the memory pool from which the memory block is to
;ULONG ''ulSize'' (input):The size, in bytes, of the memory block requested.
be allocated.
 
 
PPVOID ''pBlockOffset'' (output)
 
This is a pointer to a longword, in which the offset of the allocated
memory block is to be stored.
 
 
ULONG ''ulSize'' (input)
 
The size, in bytes, of the memory block requested.
 
   
   
=== Returns ===
=== Returns ===
  APIRET rc
APIRET rc
The following values can be returned
The following values can be returned    
     
{{RetVal
{| border="1"
|v1 = 87
|-
|w1 = ERROR_INVALID_PARAMETER
|0
|v2 = 311
|NO_ERROR
|w2 = ERROR_DOSSUB_NOMEM
|-
|v3 = 532
|87
|w3 = ERROR_DOSSUB_CORRUPTED
|ERROR_INVALID_PARAMETER
}}
|-
|311
|ERROR_DOSSUB_NOMEM
|-
|532
|ERROR_DOSSUB_CORRUPTED
|}
=== Include Info ===
 
#define INCL_DOSMEMMGR
#include <os2.h>
#include <bsememf.h>
 


=== Usage Explanation ===
=== Usage Explanation ===
The size should be a multiple of 8 bytes. If it is not, the system will round it up. The maximum value is the size of the memory pool initialized with [[DosSubSetMem]] minus 64 bytes.


DosSubAllocMem allocates a memory block from a memory pool created using [[DosSubSetMem]].
The size should be a multiple of 8 bytes. If it is not, the system will
round it up. The maximum value is the size of the memory pool initialized
with [[DosSubSetMem]] minus 64 bytes.
=== Relevant Structures ===
=== Gotchas ===
=== Gotchas ===
The maximum value is the size of the memory pool initialized with [[DosSubSetMem]] minus 64 bytes.
The maximum value is the size of the memory pool initialized with [[DosSubSetMem]] minus 64 bytes.


=== Sample Code ===
=== Sample Code ===
<pre>
<pre>
#define INCL_YOURSTUFF
#define INCL_DOSMEMMGR
#include  
#include <os2.h>
#include  
#include <bsememf.h>


PVOID Offset;
PVOID Offset;
Line 77: Line 38:


PPVOID BlockOffset;
PPVOID BlockOffset;
/* Pointer to a variable that will recieve the */
/* Pointer to a variable that will receive the */
/* offset of the suballocated memory.          */
/* offset of the suballocated memory.          */


Line 103: Line 64:
</pre>
</pre>
=== See Also ===
=== See Also ===
[[OS2 API:CPI:DosSubFreeMem|DosSubFreeMem]],
*[[DosSubFreeMem]]
[[OS2 API:CPI:DosSubUnsetMem|DosSubUnsetMem]],
*[[DosSubUnsetMem]]
[[OS2 API:CPI:DosSubSetMem|DosSubSetMem]]  
*[[DosSubSetMem]]


[[Category:The OS/2 API Project]]
[[Category:Dos]]

Latest revision as of 10:34, 2 March 2018

DosSubAllocMem allocates a memory block from a memory pool created using DosSubSetMem.

Syntax

DosSubAllocMem( pOffset, pBlockOffset, ulSize )

Parameters

PVOID pOffset (input)
This is the offset of the memory pool from which the memory block is to be allocated.
PPVOID pBlockOffset (output)
This is a pointer to a longword, in which the offset of the allocated memory block is to be stored.
ULONG ulSize (input)
The size, in bytes, of the memory block requested.

Returns

APIRET rc

The following values can be returned

0 NO_ERROR
87 ERROR_INVALID_PARAMETER
311 ERROR_DOSSUB_NOMEM
532 ERROR_DOSSUB_CORRUPTED


Usage Explanation

The size should be a multiple of 8 bytes. If it is not, the system will round it up. The maximum value is the size of the memory pool initialized with DosSubSetMem minus 64 bytes.

Gotchas

The maximum value is the size of the memory pool initialized with DosSubSetMem minus 64 bytes.

Sample Code

#define INCL_DOSMEMMGR
#include <os2.h>
#include <bsememf.h>

PVOID Offset;
		/* Offset to the memory pool from which the */
		/* memory is to be allocated.               */

PPVOID BlockOffset;
		/* Pointer to a variable that will receive the */
		/* offset of the suballocated memory.          */

ULONG Size;
		/* The requested size in bytes. */

APIRET rc;
		/* Just to take care of the return code */

/* Use DosSubSetMem to create a memory pool and set the Offset */
/* variable to the address of this memory pool.                */

Size = 57;
		/* Rounded up to 64 bytes. */

rc = DosSubAllocMem( Offset, BlockOffset, Size);
		/* The BlockOffset variable will now contain the address */
		/* of the memory block we have allocated from the        */
		/* memory pool.                                          */

if (rc != 0)
{
   /* We have an error we must take care of. */
}

See Also