Jump to content

DosAliasMem: Difference between revisions

From EDM2
Created page with "==Description== DosAliasMem creates a private Read/Write alias or an LDT code segment alias to part of an existing memory object. The alias object is accessible only to the pr..."
 
Ak120 (talk | contribs)
mNo edit summary
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
==Description==
DosAliasMem creates a private Read/Write alias or an LDT code segment alias to part of an existing memory object. The alias object is accessible only to the process that created it. The original object must be accessible to the caller of DosAliasMem.
DosAliasMem creates a private Read/Write alias or an LDT code segment alias to part of an existing memory object. The alias object is accessible only to the process that created it. The original object must be accessible to the caller of DosAliasMem.  


==Syntax==
==Syntax==
<PRE>
  DosAliasMem (pMem, cbSize, ppAlias, flags)
#define INCL_DOSMEMMGR
#include os2.h>


    APIRET APIENTRY DosAliasMem (PVOID pMem, ULONG cbSize, PPVOID ppAlias, ULONG flags)
</PRE>
==Parameters==
==Parameters==
; pMem (PMEM) input : Contains the address of the memory to be aliased. It must be on a page boundary (that is, 4K aligned), but may specify an address within a memory object.  
;pMem (PMEM) input: Contains the address of the memory to be aliased. It must be on a page boundary (that is, 4K aligned), but may specify an address within a memory object.
 
;cbSize (CBSIZE) input: Specifies the size in bytes for the memory to alias. The entire range must lie within a single memory object and must be committed if OBJ_SELMAPALL is specified.
; cbSize (CBSIZE) input : Specifies the size in bytes for the memory to alias. The entire range must lie within a single memory object and must be committed if OBJ_SELMAPALL is specified.  
;ppAlias (PPALIAS) output: Address of a location in which the address of the aliased memory is returned. The corresponding LDT selector is not explicitly returned but may be calculated by using the Compatibility Mapping Algorithm
 
sel = (SEL) ((ULONG) (*ppAlias) >> 13 | 7)
; ppAlias (PPALIAS) output : Address of a location in which the address of the aliased memory is returned. The corresponding LDT selector is not explicitly returned but may be calculated by using the Compatibility Mapping Algorithm
;flags (FLAGS) input : Flags are defined as follows:
 
:'''OBJ_SELMAPALL (0x00000800)'''
    sel = (SEL) ((ULONG) (*ppAlias) >> 13 | 7)
::OBJ_SELMAPALL creates a Read/Write 32 bit alias to the address specified. The entire range must be committed, start on page boundary and be within the extent of a single memory object. An LDT selector is created to map the entire range specified.
 
::If OBJ_SELMAPALL is not specified, then size is rounded up to a 4K multiple and the alias created inherits the permissions from the pages of the original object.
; flags (FLAGS) input : Flags are defined as follows
::OBJ_TILE may be specified, but currently this is enforced whether or not specified. This forces LDT selectors to be based on 64K boundaries.  
 
:'''SEL_CODE (0x00000001)'''
'''OBJ_SELMAPALL (0x00000800)'''
::Marks the LDT alias selector(s) Read-Executable code selectors.  
 
:'''SEL_USE32 (0x00000002)'''
OBJ_SELMAPALL creates a Read/Write 32 bit alias to the address specified. The entire range must be committed, start on page boundary and be within the extent of a single memory object. An LDT selector is created to map the entire range specified.
::Used with OBJ_SELMAPALL, otherwise ignored. Marks the first alias LDT selector as a 32 bit selector by setting the BIG/C32 bit.
 
If OBJ_SELMAPALL is not specified, then size is rounded up to a 4K multiple and the alias created inherits the permissions from the pages of the original object.
 
OBJ_TILE may be specified, but currently this is enforced whether or not specified. This forces LDT selectors to be based on 64K boundaries.  
 
'''SEL_CODE (0x00000001)'''
 
Marks the LDT alias selector(s) Read-Executable code selectors.  
'''SEL_USE32 (0x00000002)'''
 
Used with OBJ_SELMAPALL, otherwise ignored. Marks the first alias LDT selector as a 32 bit selector by setting the BIG/C32 bit.


==Return Code==
==Return Code==
ulrc (APIRET) returns
;ulrc (APIRET) returns:DosAliasMem returns one of the following values:
 
*0 NO_ERROR
DosAliasMem returns one of the following values
*8 ERROR_NOT_ENOUGH_MEMORY
 
*87 ERROR_INVALID_PARAMETER
* 0         NO_ERROR
*95 ERROR_INTERRUPT
*           ERROR_NOT_ENOUGH_MEMORY
*32798 ERROR_CROSSES_OBJECT_BOUNDARY
* 87       ERROR_INVALID_PARAMETER
* 95       ERROR_INTERRUPT  
* 32798     ERROR_CROSSES_OBJECT_BOUNDARY  


==Remarks==
==Remarks==
An export for DosAliasMem does not appear in versions of OS2386.LIB distributed prior to Warp Server for e-business. When using older versions, the following statements should be added to the link edit .DEF file
An export for DosAliasMem does not appear in versions of OS2386.LIB distributed prior to Warp Server for e-business. When using older versions, the following statements should be added to the link edit .DEF file
  importsDosAliasMem = DOSCALLS.298
  importsDosAliasMem = DOSCALLS.298
An alias is removed by calling DosFreeMem with the alias address.
An alias is removed by calling DosFreeMem with the alias address.


Though it is possible to create a Read/Write alias to a code segment to allow code modification this is not recommended. On Pentium(R) processors, and later, pipe-lining techniques used by the processor might allow the processor not to be aware of the modified code, if appropriate pipe-line serialization is not performed by the programmer. For further information see the processor documentation.  
Though it is possible to create a Read/Write alias to a code segment to allow code modification this is not recommended. On Pentium® processors, and later, pipe-lining techniques used by the processor might allow the processor not to be aware of the modified code, if appropriate pipe-line serialization is not performed by the programmer. For further information see the processor documentation.


==Example Code==
==Example Code==
<PRE>
<PRE>
#define INCL_DOSMEMMGR#include int main(int argc, char *argv[], char *envp[])
#define INCL_DOSMEMMGR
#include <os2.h>
 
int main(int argc, char *argv[], char *envp[])
{
{
   PVOID pAlias;
   PVOID pAlias;
Line 72: Line 53:


   rc = DosAliasMem(pMem, 128*1024,  pAlias, OBJ_TILE);
   rc = DosAliasMem(pMem, 128*1024,  pAlias, OBJ_TILE);
  .
   .
   .
   .
   .
   .
   .
   return 0;
   return 0;
}
}
</PRE>
</PRE>
==Related Functions==
==Related Functions==
* [[OS2 API:CPI:DosAllocMem|DosAllocMem]]
*[[DosAllocMem]]
* [[OS2 API:CPI:DosAllocSharedMem|DosAllocSharedMem]]
*[[DosAllocSharedMem]]
* [[OS2 API:CPI:DosFreeMem|DosFreeMem]]
*[[DosFreeMem]]
 


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

Latest revision as of 12:54, 10 July 2020

DosAliasMem creates a private Read/Write alias or an LDT code segment alias to part of an existing memory object. The alias object is accessible only to the process that created it. The original object must be accessible to the caller of DosAliasMem.

Syntax

DosAliasMem (pMem, cbSize, ppAlias, flags)

Parameters

pMem (PMEM) input
Contains the address of the memory to be aliased. It must be on a page boundary (that is, 4K aligned), but may specify an address within a memory object.
cbSize (CBSIZE) input
Specifies the size in bytes for the memory to alias. The entire range must lie within a single memory object and must be committed if OBJ_SELMAPALL is specified.
ppAlias (PPALIAS) output
Address of a location in which the address of the aliased memory is returned. The corresponding LDT selector is not explicitly returned but may be calculated by using the Compatibility Mapping Algorithm
sel = (SEL) ((ULONG) (*ppAlias) >> 13 | 7)
flags (FLAGS) input
Flags are defined as follows:
OBJ_SELMAPALL (0x00000800)
OBJ_SELMAPALL creates a Read/Write 32 bit alias to the address specified. The entire range must be committed, start on page boundary and be within the extent of a single memory object. An LDT selector is created to map the entire range specified.
If OBJ_SELMAPALL is not specified, then size is rounded up to a 4K multiple and the alias created inherits the permissions from the pages of the original object.
OBJ_TILE may be specified, but currently this is enforced whether or not specified. This forces LDT selectors to be based on 64K boundaries.
SEL_CODE (0x00000001)
Marks the LDT alias selector(s) Read-Executable code selectors.
SEL_USE32 (0x00000002)
Used with OBJ_SELMAPALL, otherwise ignored. Marks the first alias LDT selector as a 32 bit selector by setting the BIG/C32 bit.

Return Code

ulrc (APIRET) returns
DosAliasMem returns one of the following values:
  • 0 NO_ERROR
  • 8 ERROR_NOT_ENOUGH_MEMORY
  • 87 ERROR_INVALID_PARAMETER
  • 95 ERROR_INTERRUPT
  • 32798 ERROR_CROSSES_OBJECT_BOUNDARY

Remarks

An export for DosAliasMem does not appear in versions of OS2386.LIB distributed prior to Warp Server for e-business. When using older versions, the following statements should be added to the link edit .DEF file

importsDosAliasMem = DOSCALLS.298

An alias is removed by calling DosFreeMem with the alias address.

Though it is possible to create a Read/Write alias to a code segment to allow code modification this is not recommended. On Pentium® processors, and later, pipe-lining techniques used by the processor might allow the processor not to be aware of the modified code, if appropriate pipe-line serialization is not performed by the programmer. For further information see the processor documentation.

Example Code

#define INCL_DOSMEMMGR
#include <os2.h>

int main(int argc, char *argv[], char *envp[])
{
   PVOID pAlias;
   PVOID pMem;
   APIRET rc;

   /* alias a read-only shared memory object as a private read/write */
   /* object. This will allow clients of this object to read only    */
   /* while allowing the owner to update it.                         */

   rc=DosAllocSharedMem( pMem,NULL,128*1024,
      PAG_READ+PAG_COMMIT+OBJ_GIVEABLE);

   rc = DosAliasMem(pMem, 128*1024,  pAlias, OBJ_TILE);
   .
   .
   .
   return 0;
}

Related Functions