Table of Contents

This is part of Family API which allow to create dual-os version of program runs under OS/2 and DOS

Note: This is legacy API call. It is recommended to use 32-bit equivalent

2021/09/17 04:47 · prokushev · 0 Comments
2021/08/20 03:18 · prokushev · 0 Comments

DosAllocShrSeg

This call allocates a named shared memory segment to a process.

Syntax

DosAllocShrSeg (Size, Name, Selector)

Parameters

Return Code

rc (USHORT) - return:Return code descriptions are:

Remarks

DosAllocShrSeg allocates a named segment of up to 64KB in size, which is movable and swappable. The segment can be shared by any process that knows the name of the segment.

To access the shared segment, another process issues DosGetShrSeg, specifying the segment name. The selector returned by DosGetShrSeg is the same as the one returned by DosAllocShrSeg.

The maximum number of segments a process can define with DosAllocShrSeg or access with DosGetShrSeg is 256.

;Note: This request may be issued from privilege level 2. However, the segment is allocated as a privilege level 3 segment.

Bindings

C

#define INCL_DOSMEMMGR
 
USHORT  rc = DosAllocShrSeg(Size, Name, Selector);
 
USHORT  Size;          /* Number of bytes requested */
PSZ     Name;          /* Name string */
PSEL    Selector;      /* Selector allocated (returned) */
 
USHORT  rc;            /* return code */

MASM

EXTRN  DosAllocShrSeg:FAR
INCL_DOSMEMMGR      EQU 1
 
PUSH   WORD    Size          ;Number of bytes requested
PUSH@  ASCIIZ  Name          ;Name string
PUSH@  WORD    Selector      ;Selector allocated (returned)
CALL   DosAllocShrSeg
 
Returns WORD

Example Code

This example requests a segment of memory with 27 bytes named “stock.dat”.

#define INCL_DOSMEMMGR
 
#define NUMBER_OF_BYTES 27
#define NAME_SEG "\\SHAREMEM\\stock.dat"
 
SEL    Selector;
USHORT rc;
 
   rc = DosAllocShrSeg(NUMBER_OF_BYTES,   /* # of bytes requested */
                       NAME_SEG,          /* Name string */
                       &Selector);        /* Selector allocated */