home *** CD-ROM | disk | FTP | other *** search
/ POINT Software Programming / PPROG1.ISO / pascal / visionix / vdpmiu.pas < prev    next >
Encoding:
Pascal/Delphi Source File  |  1993-12-23  |  80.5 KB  |  3,844 lines

  1. {
  2. ════════════════════════════════════════════════════════════════════════════
  3.  
  4.  Visionix DOS Protected Mode Interface Unit (VDPMI)
  5.    Version 0.3
  6.  Copyright 1991,92,93 Visionix
  7.  ALL RIGHTS RESERVED
  8.  
  9. ────────────────────────────────────────────────────────────────────────────
  10.  
  11.  Revision history in reverse chronological order:
  12.  
  13.  Initials  Date      Comment
  14.  --------  --------  -------------------------------------------------------
  15.  
  16.  jrt       10/25/93  Reintroduced unfinished code to implement a
  17.                      permanent reflection buffer.
  18.  
  19.  jrt       05/26/93  Added RealIntr, finished RefBuffIntr
  20.  
  21.  rag       05/19/93  Fixed bug for protected mode.  VDPMIDosAllocMemBlock
  22.                      is wrong, should have been VDPMIDosAllocMemory.
  23.                      Also VDPMIFreeDosBlock should have been
  24.                      VDPMIFreeDosMemory.
  25.  
  26.  mep       04/01/93  Finish majority of unit model.
  27.  
  28.  jrt       01/09/92  Added RefBuffIntr function.  May move to other unit
  29.                      at a later date.
  30.  
  31.  jrt       12/15/92  Created.
  32.  
  33. ────────────────────────────────────────────────────────────────────────────
  34. }
  35.  
  36. (*-
  37.  
  38. [TEXT]
  39.  
  40. <Overview>
  41.  
  42. This unit implements a function for all commands in the DOS Protected
  43. Mode Interface 0.9 and 1.0 specifications.  For more information,
  44. refer to the DPMI specification.  (Intel Order No. 240977-001)
  45.  
  46. Additionally, this unit impelements functions to assist in allocating
  47. and using protected mode to real mode "reflection buffers".  Reflection
  48. buffers are used when calling a real mode BIOS routine from protected mode.
  49.  
  50. The documentation for this unit will be enhanced in the next release.
  51.  
  52. <Interface>
  53.  
  54. -*)
  55.  
  56.  
  57. Unit VDPMIu;
  58.  
  59. Interface
  60.  
  61. Uses
  62.  
  63.   DOS,
  64.   VTypesu,
  65.   VGenu;
  66.  
  67. {────────────────────────────────────────────────────────────────────────────}
  68.  
  69.  
  70. {-----------------}
  71. { Error Constants }
  72. {-----------------}
  73.  
  74. Const
  75.  
  76.   dpmiNoErr  = 0;
  77.   dpmiGenErr = $CBAD;
  78.  
  79. Const
  80.  
  81. {-------------------------------------------------------}
  82. { Bitmaps/Constants for functions defined below:        }
  83. { - hexidecimal values are considered bitwise operants  }
  84. { - decimal values are considered constants             }
  85. {-------------------------------------------------------}
  86.  
  87.   { VDPMISimRealIntr.Flags,     }
  88.   { VDPMICallRealProc.Flags and }
  89.   { VDPMICallRealIntrProc       }
  90.   { - for DPMI 0.9 only.        }
  91.  
  92.    dpmibmResetIntrCtrlA20       = $1;
  93.  
  94.   { VDPMIGetVersion.Flags }
  95.  
  96.    dpmibmRunning32bit           = $1;
  97.    dpmibmProcessorRetRealMode   = $2;
  98.    dpmibmVirtMemSupport         = $4;
  99.    dpmibmRsvp1                  = $8;
  100.  
  101.   { VDPMIGetVersion.ProcType }
  102.  
  103.    dpmibm286                    = 2;
  104.    dpmibm386                    = 3;
  105.    dpmibm486                    = 4;
  106.  
  107.   { VDPMIGetCaps.CaoFlags }
  108.  
  109.    dpmibmPagedAccessSupport     = $1;
  110.    dpmibmPagedDirtySupport      = $1;
  111.    dpmibmExpRestartSupport      = $2;
  112.    dpmibmDevMapSupport          = $4;
  113.    dpmibmConvMemMapSupport      = $8;
  114.    dpmibmDemandZeroFilled       = $10;
  115.    dpmibmWriteProtClientCap     = $20;
  116.    dpmibmWriteProtHostCap       = $40;
  117.  
  118.  { VDPMIAllocLinMemory.Flags }
  119.  
  120.    dpmibmCreateCommitPages      = $1;
  121.  
  122.  { VDPMIResizeLinMemory.NewFlags -> see VDPMIAllocLinMemory.Flags }
  123.  
  124.    dpmibmSegDescUpdateReq       = $2;
  125.  
  126.  { VDPMIGetPageAttrs.PageAttr (each within PageAttrArr) }
  127.  
  128.    dpmibmPageType               = $1;  { 0..2 }
  129.    dpmibmPageReadWrite          = $4;  { 3 }
  130.    dpmibmAccessedBitsNext       = $8;  { 4 }
  131.    dpmibmPageAccessed           = $10; { 5 - see dpmibmAccessedBitsNext }
  132.    dpmibmPageWritten            = $20; { 6 - see dpmibmAccessedBitsNext }
  133.  
  134.  { VDPMITestDisableInts.PrevState and }
  135.  { VDPMITestEnableInts.PrevState      }
  136.  
  137.    dpmibmPrevDisabled           = 0;
  138.    dpmibmPrevEnabled            = 1;
  139.  
  140.  { VDPMITestInts.State }
  141.  
  142.    dpmibmNowDisabled            = 0;
  143.    dpmibmNowEnabled             = 1;
  144.  
  145.  { VDPMISetDebugWatchp.WatchType }
  146.  
  147.    dpmibmDebugExecute           = 0;
  148.    dpmibmDebugWrite             = 1;
  149.    dpmibmDebugReadWrite         = 2;
  150.  
  151.  { VDPMIGetDebugWatchpState.WatchState }
  152.  
  153.    dpmibmWatchpExecuted         = $1;
  154.  
  155.  { VDPMISerOneSharedMem.Flags }
  156.  
  157.    dpmibmSerRetWithoutSuspend   = $1;
  158.    dpmibmSerShared              = $2;
  159.  
  160.  { VDPMIFreeSerOnSharedMem.Flags }
  161.  
  162.    dpmibmReleaseSharedSer       = $1;
  163.    dpmibmFreePendingSer         = $2;
  164.  
  165.  { VDPMIGetCoprocStatus }
  166.  
  167.    dpmibmClientNumCoprocEnabled = $1;
  168.    dpmibmClientIsEmuCoproc      = $2;
  169.    dpmibmNumCoprocPresent       = $4;
  170.    dpmibmHostEmuCoprocInst      = $8;
  171.    dpmibmCoprocType             = $10; { 4..7 }
  172.  
  173.    dpmibmCoprocNone             = 0;
  174.    dpmibmCoproc80287            = 1;
  175.    dpmibmCoproc80387            = 2;
  176.    dpmibmCoproc80486            = 3;
  177.  
  178.  { VDPMISetCoProcEmulation.EmuFlags }
  179.  
  180.    dpmibmEnableClientNumCoproc  = $1;
  181.    dpmibmClientWillEmuCoproc    = $2;
  182.  
  183. {---------------------------}
  184. { Constants for RefBuffIntr }
  185. {---------------------------}
  186.  
  187. Const
  188.  
  189.   rb_ESAX    = $0001;
  190.   rb_ESBX    = $0002;
  191.   rb_ESCX    = $0003;
  192.   rb_ESDX    = $0004;
  193.   rb_ESSI    = $0005;
  194.   rb_ESDI    = $0006;
  195.   rb_ESBP    = $0007;
  196.  
  197.   rb_DSAX    = $0011;
  198.   rb_DSBX    = $0012;
  199.   rb_DSCX    = $0013;
  200.   rb_DSDX    = $0014;
  201.   rb_DSSI    = $0015;
  202.   rb_DSDI    = $0016;
  203.   rb_DSBP    = $0017;
  204.  
  205.   rb_down    = $0100;
  206.   rb_up      = $0200;
  207.   rb_updown  = $0300;
  208.   rb_downup  = $0300;
  209.  
  210.  
  211. {-----------------------------------}
  212. { DPMI Real mode register structure }
  213. {-----------------------------------}
  214.  
  215. Type
  216.  
  217.   QWORD      = Array[1..2] of LONGINT;
  218.  
  219.   TREGISTERS = REGISTERS;
  220.  
  221.   TDPMIErr   = WORD;
  222.  
  223.   {---------------------------------}
  224.  
  225.   TDPMIRealRegs = RECORD
  226.  
  227.     EDI    : LONGINT;
  228.     ESI    : LONGINT;
  229.     EBP    : LONGINT;
  230.     Resp1  : LONGINT;
  231.     EBX    : LONGINT;
  232.     EDX    : LONGINT;
  233.     ECX    : LONGINT;
  234.     EAX    : LONGINT;
  235.     Flags  : WORD;
  236.     ES     : WORD;
  237.     DS     : WORD;
  238.     FS     : WORD;
  239.     GS     : WORD;
  240.     IP     : WORD;
  241.     CS     : WORD;
  242.     SP     : WORD;
  243.     SS     : WORD;
  244.  
  245.   END;
  246.   PDPMIRealRegs = ^TDPMIRealRegs;
  247.  
  248.   {---------------------------------}
  249.  
  250.   TDescriptorT = RECORD
  251.  
  252.     DescLimit      : WORD;
  253.     DescLinBaseLo  : WORD;
  254.     DescLinBaseMid : BYTE;
  255.     DescAccess     : BYTE;
  256.     DescExtAccess  : BYTE;
  257.     DescLinBaseHi  : BYTE;
  258.  
  259.   END;
  260.  
  261.   PDescriptorT = ^TDescriptorT;
  262.  
  263.   {---------------------------------}
  264.  
  265.   PVectHandle = POINTER; { Selector:Offset }
  266.  
  267.   PSelOfs = POINTER; { Selector:Offset }
  268.  
  269.   PSelOfs32 = Array[1..6] of BYTE; { Selector:Offset-32BIT }
  270.  
  271.   {---------------------------------}
  272.  
  273.   TDescBuff = RECORD
  274.  
  275.     Selector   : WORD;
  276.     Descriptor : QWORD;
  277.  
  278.   END;
  279.   PDescBuff = ^TDescBuff;
  280.  
  281.   {---------------------------------}
  282.  
  283.   TStackFrame16 = RECORD
  284.  
  285.     RetCSIP    : LONGINT;
  286.     ErrorCode  : WORD;
  287.     ExceptCSIP : LONGINT;
  288.     Flags      : WORD;
  289.     SSSP       : LONGINT;
  290.  
  291.   END;
  292.   PStackFrame16 = ^TStackFrame16;
  293.  
  294.   {---------------------------------}
  295.  
  296.   TStackFrame32 = RECORD
  297.  
  298.     RetEIP      : LONGINT;
  299.     RetCSSel    : WORD;
  300.     Rsvp1       : WORD;
  301.     ErrorCode   : LONGINT;
  302.     ExceptEIP   : LONGINT;
  303.     ExceptCSSel : WORD;
  304.     Rsvp2       : WORD;
  305.     EFlags      : LONGINT;
  306.     ESP         : LONGINT;
  307.     SS          : WORD;
  308.     Rsvp3       : WORD;
  309.  
  310.   END;
  311.  
  312.   PStackFrame32 = ^TStackFrame32;
  313.  
  314.   {---------------------------------}
  315.  
  316.   TGetCapsBuff = RECORD
  317.  
  318.     MajorVer : BYTE;
  319.     MinorVer : BYTE;
  320.     Vendor   : Array[1..126] of CHAR;
  321.  
  322.   END;
  323.   PGetCapsBuff = ^TGetCapsBuff;
  324.  
  325.   {---------------------------------}
  326.  
  327.   TFreeMemInfo = RECORD
  328.  
  329.     MaxAvailBlock      : LONGINT;
  330.     MaxUnlockPageAlloc : LONGINT;
  331.     MaxLockPageAlloc   : LONGINT;
  332.     TotalLinAddrPages  : LONGINT;
  333.     TotalUnlockPages   : LONGINT;
  334.     FreePages          : LONGINT;
  335.     TotalPhyPages      : LONGINT;
  336.     FreeLinAddrPages   : LONGINT;
  337.     SizePageFile       : LONGINT;
  338.     Rsvp               : Array[1..12] of BYTE;
  339.  
  340.   END;
  341.   PFreeMemInfo = ^TFreeMemInfo;
  342.  
  343.   {---------------------------------}
  344.  
  345.   TPageAttr = Array[1..1] of WORD;
  346.   PPageAttr = ^PPageAttr;
  347.  
  348.   {---------------------------------}
  349.  
  350.   TMemInfo = RECORD
  351.  
  352.     HostPhyMemAlloc    : LONGINT;
  353.     HostVirtMemAlloc   : LONGINT;
  354.     HostVirtMemAvail   : LONGINT;
  355.     CurrVirtMemAlloc   : LONGINT;
  356.     CurrVirtMemAvail   : LONGINT;
  357.     ClientVirtMemAlloc : LONGINT;
  358.     ClientVirtMemAvail : LONGINT;
  359.     ClientMemLocked    : LONGINT;
  360.     ClientMaxMemLocked : LONGINT;
  361.     ClientMaxLinAddr   : LONGINT;
  362.     MaxBlockAvail      : LONGINT;
  363.     MinAllocUnit       : LONGINT;
  364.     AlignAllocUnit     : LONGINT;
  365.     Rsvp               : Array[1..76] of BYTE;
  366.  
  367.   END;
  368.   PMemInfo = ^TMemInfo;
  369.  
  370.   {---------------------------------}
  371.  
  372.   TRSPBuff = RECORD
  373.  
  374.     Desc16DataSeg     : QWORD;
  375.     Desc16CodeSeg     : QWORD;
  376.     Ofs16CallbackProc : WORD;
  377.     Rsvp              : Array[1..2] of BYTE;
  378.     Desc32DataSeg     : QWORD;
  379.     Desc32CodeSeg     : QWORD;
  380.     Ofs32CallbackProc : LONGINT;
  381.  
  382.   END;
  383.   PRSPBuff = ^TRSPBuff;
  384.  
  385.   {---------------------------------}
  386.  
  387.   TMemReqStruct = RECORD
  388.  
  389.     ReqMemBlockSize : LONGINT;
  390.     AllocBlockSize  : LONGINT;
  391.     SMemHandle      : LONGINT;
  392.     LinAddr         : LONGINT;
  393.     MemBlockName    : PSelOfs32;
  394.     Rsvp1           : Array[1..2] of BYTE;
  395.     Rsvp2           : Array[1..4] of BYTE;
  396.  
  397.   END;
  398.   PMemReqStruct = ^TMemReqStruct;
  399.  
  400.   {---------------------------------}
  401.  
  402. Type
  403.  
  404.   TVDPMIPermReflectBuff = RECORD
  405.  
  406.     Allocated : BOOLEAN;
  407.     InUse     : BOOLEAN;
  408.  
  409.     RealPtr   : POINTER;
  410.     ProtPtr   : POINTER;
  411.  
  412.     BuffSize  : LONGINT;
  413.  
  414.   END;
  415.  
  416.   PVDPMIPermReflectBuff = ^TVDPMIPermReflectBuff;
  417.  
  418.  
  419.  
  420. {────────────────────────────────────────────────────────────────────────────}
  421.  
  422. { see DPMI 0.9 spec for info on these functions }
  423. { can be used in any environment that is a DPMI }
  424. { server (BP 7.0 protected mode, windows dos    }
  425. { boxes, OS/2 dos boxes, etc.                   }
  426.  
  427.  
  428. Function  VDPMIErrToStr(               ErrCode        : WORD    ) : STRING;
  429.  
  430. Function  VDPMIInstalled                                          : BOOLEAN;
  431.  
  432. Function  VDPMIInstallInfo(        Var Support32bit   : BOOLEAN;
  433.                                    Var Processor      : BYTE;
  434.                                    Var MajorVer       : BYTE;
  435.                                    Var MinorVer       : BYTE;
  436.                                    Var NumParagraphs  : WORD;
  437.                                    Var DPMIEntry      : POINTER ) : TDPMIErr;
  438.  
  439. Function  VDPMIAllocLDTDescriptor(     NumDesc        : WORD;
  440.                                    Var BaseSelector   : WORD    ) : TDPMIErr;
  441.  
  442. Function  VDPMIFreeLDTDescriptor(      Selector       : WORD    ) : TDPMIErr;
  443.  
  444. Function  VDPMIMapSegToSel(            RealModeSeg    : WORD;
  445.                                    Var NewSelector    : WORD    ) : TDPMIErr;
  446.  
  447. Function  VDPMIGetSelectorDiff                                    : TDPMIErr;
  448.  
  449. Function  VDPMILockSel(                Selector       : WORD    ) : TDPMIErr;
  450.  
  451. Function  VDPMIUnlockSel(              Selector       : WORD    ) : TDPMIErr;
  452.  
  453. Function  VDPMIGetSegmentBase(         Selector       : WORD;
  454.                                    Var BaseAddr       : LONGINT ) : TDPMIErr;
  455.  
  456. Function  VDPMISetSegmentBase(         Selector       : WORD;
  457.                                        BaseAddr       : LONGINT ) : TDPMIErr;
  458.  
  459. Function  VDPMISetSegmentLimit(        Selector       : WORD;
  460.                                        Limit          : LONGINT ) : TDPMIErr;
  461.  
  462. Function  VDPMISetSegmentRights(       Selector       : WORD;
  463.                                        Rights         : BYTE;
  464.                                        ExtRights      : BYTE    ) : TDPMIErr;
  465.  
  466. Function  VDPMICreateAlias(            Selector       : WORD;
  467.                                    Var NewSelector    : WORD    ) : TDPMIErr;
  468.  
  469. Function  VDPMIGetDescriptor(          Selector       : WORD;
  470.                                        DescBuff       : POINTER ) : TDPMIErr;
  471.  
  472. Function  VDPMISetDescriptor(          Selector       : WORD;
  473.                                        DescBuff       : POINTER ) : TDPMIErr;
  474.  
  475. Function  VDPMIAllocSpecDescriptor(    Selector       : WORD    ) : TDPMIErr;
  476.  
  477. Function  VDPMIGetMultDescriptors(     NumDescs       : WORD;
  478.                                        DescBuff       : PDescBuff;
  479.                                    Var NumDescsCopied : WORD    ) : TDPMIErr;
  480.  
  481. Function  VDPMISetMultDescriptors(     NumDescs       : WORD;
  482.                                        DescBuff       : PDescBuff;
  483.                                    Var NumDescsCopied : WORD    ) : TDPMIErr;
  484.  
  485. Function  VDPMIAllocDOSMemory(         NumParas       : WORD;
  486.                                    Var RealModeSeg    : WORD;
  487.                                    Var ProtModeSel    : WORD    ) : TDPMIErr;
  488.  
  489. Function  VDPMIFreeDOSMemory(          ProtModeSel    : WORD    ) : TDPMIErr;
  490.  
  491. Function  VDPMIResizeDOSMemory(        Selector       : WORD;
  492.                                        NewBlockParas  : WORD;
  493.                                    Var MaxBlockSize   : WORD    ) : TDPMIErr;
  494.  
  495. Function  VDPMIGetRealIntrVector(      IntNum         : WORD;
  496.                                    Var Vector         : POINTER ) : TDPMIErr;
  497.  
  498. Function  VDPMISetRealIntrVector(      IntNum         : WORD;
  499.                                        Vector         : POINTER ) : TDPMIErr;
  500.  
  501. Function  VDPMIGetProcExpVector(       ExpNum         : BYTE;
  502.                                    Var Vector         : PVectHandle ) : TDPMIErr;
  503.  
  504. Function  VDPMISetProcExpVector(       ExpNum         : BYTE;
  505.                                        Vector         : PVectHandle ) : TDPMIErr;
  506.  
  507. Function  VDPMIGetProtIntrVector(      IntNum         : WORD;
  508.                                    Var Vector         : PVectHandle ) : TDPMIErr;
  509.  
  510. Function  VDPMISetProtIntrVector(      IntNum         : WORD;
  511.                                        Vector         : PVectHandle ) : TDPMIErr;
  512.  
  513. Function  VDPMIGetProtExtExpProc(      ExpNum         : BYTE;
  514.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  515.  
  516. Function  VDPMIGetRealExtExpProc(      ExpNum         : BYTE;
  517.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  518.  
  519. Function  VDPMISetProtExtExpProc(      ExpFaultNum    : BYTE;
  520.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  521.  
  522. Function  VDPMISetRealExtExpProc(      ExpFaultNum    : BYTE;
  523.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  524.  
  525. Function  VDPMISimRealIntr(            IntrNum        : WORD;
  526.                                        Flags          : WORD;
  527.                                        StackCopy      : WORD;
  528.                                        RealRegs       : PDPMIRealRegs) : TDPMIErr;
  529.  
  530. Function  VDPMICallRealProc(           Flags          : WORD;
  531.                                        StackCopy      : WORD;
  532.                                        RealRegs       : PDPMIRealRegs) : TDPMIErr;
  533.  
  534. Function  VDPMICallRealIntrProc(       Flags          : WORD;
  535.                                        StackCopy      : WORD;
  536.                                        RealRegs       : PDPMIRealRegs) : TDPMIErr;
  537.  
  538. Function  VDPMIAllocRealCallback(      ProtProc       : PSelOfs;
  539.                                        RealRegBuff    : PDPMIRealRegs;
  540.                                    Var CallBackAddr   : POINTER ) : TDPMIErr;
  541.  
  542. Function  VDPMIFreeRealCallback(       CallBackAddr   : POINTER ) : TDPMIErr;
  543.  
  544. Function  VDPMIGetStateSRProcs(    Var StateBuffSize  : WORD;
  545.                                    Var RealModeAddr   : POINTER;
  546.                                    Var ProtModeAddr   : POINTER ) : TDPMIErr;
  547.  
  548. Function  VDPMIGetRawSwitchProcs(  Var RealToProtAddr : POINTER;
  549.                                    Var ProtToRealAddr : POINTER ) : TDPMIErr;
  550.  
  551. Function  VDPMIGetVersion(         Var MajorVer       : BYTE;
  552.                                    Var MinorVer       : BYTE;
  553.                                    Var Flags          : WORD;
  554.                                    Var ProcType       : BYTE;
  555.                                    Var VirtMastPIC    : BYTE;
  556.                                    Var VirtSlavePIC   : BYTE    ) : TDPMIErr;
  557.  
  558. Function  VDPMIGetCaps(                InfoBuffer     : PGetCapsBuff;
  559.                                    Var CaoFlags       : WORD    ) : TDPMIErr;
  560.  
  561. Function  VDPMIGetFreeMemory(          InfoBuffer     : PFreeMemInfo ) : TDPMIErr;
  562.  
  563. Function  VDPMIAllocMemory(            Size           : LONGINT;
  564.                                    Var LinAddr        : LONGINT;
  565.                                    Var MemHandle      : LONGINT ) : TDPMIErr;
  566.  
  567. Function  VDPMIFreeMemory(             MemHandle      : LONGINT ) : TDPMIErr;
  568.  
  569. Function  VDPMIResizeMemory(           MemHandle      : LONGINT;
  570.                                        NewSize        : LONGINT;
  571.                                    Var NewMemHandle   : LONGINT;
  572.                                    Var NewLinAddr     : LONGINT ) : TDPMIErr;
  573.  
  574. Function  VDPMIAllocLinMemory(         LinAddr        : LONGINT;
  575.                                        Size           : LONGINT;
  576.                                        Flags          : LONGINT;
  577.                                    Var NewLinAddr     : LONGINT;
  578.                                    Var MemHandle      : LONGINT ) : TDPMIErr;
  579.  
  580. Function  VDPMIResizeLinMemory(        MemHandle      : LONGINT;
  581.                                        NewSize        : LONGINT;
  582.                                        NewFlags       : LONGINT;
  583.                                    Var NewLinAddr     : LONGINT;
  584.                                    Var NewMemHandle   : LONGINT ) : TDPMIErr;
  585.  
  586. Function  VDPMIGetPageAttrs(           MemHandle      : LONGINT;
  587.                                        BasePageOfs    : LONGINT;
  588.                                        NumPages       : LONGINT;
  589.                                    Var PageAttrArr    : PPageAttr ) : TDPMIErr;
  590.  
  591. Function  VDPMIModifyPageAttrs(        MemHandle      : LONGINT;
  592.                                        BasePageOfs    : LONGINT;
  593.                                        NumPages       : LONGINT;
  594.                                        PageAttrArr    : PPageAttr;
  595.                                    Var NewNumPages    : LONGINT ) : TDPMIErr;
  596.  
  597. Function  VDPMIMapDeviceMemory(        MemHandle      : LONGINT;
  598.                                        PageOfs        : LONGINT;
  599.                                        NumPages       : LONGINT;
  600.                                        PhyDevAddr     : LONGINT ) : TDPMIErr;
  601.  
  602. Function  VDPMIMapConvMemory(          MemHandle      : LONGINT;
  603.                                        PageOfs        : LONGINT;
  604.                                        NumPages       : LONGINT;
  605.                                        LinConvMemAddr : LONGINT ) : TDPMIErr;
  606.  
  607. Function  VDPMIGetMemorySizeBase(      MemHandle      : LONGINT;
  608.                                    Var Size           : LONGINT;
  609.                                    Var BaseAddr       : POINTER ) : TDPMIErr;
  610.  
  611. Function  VDPMIGetMemoryInfo(          MemInfo        : PMemInfo) : TDPMIErr;
  612.  
  613. Function  VDPMILockLinRegion(          LinearStart    : LONGINT;
  614.                                        Size           : LONGINT ) : TDPMIErr;
  615.  
  616. Function  VDPMIUnlockLinRegion(        LinearStart    : LONGINT;
  617.                                        Size           : LONGINT ) : TDPMIErr;
  618.  
  619. Function  VDPMIMarkRealRegionPageable( LinearStart    : LONGINT;
  620.                                        Size           : LONGINT ) : TDPMIErr;
  621.  
  622. Function  VDPMIRelockRealRegion(       LinearStart    : LONGINT;
  623.                                        Size           : LONGINT ) : TDPMIErr;
  624.  
  625. Function  VDPMIGetPageSize(        Var PageSize       : LONGINT ) : TDPMIErr;
  626.  
  627. Function  VDPMIMarkPagesCandidate(     LinearStart    : LONGINT;
  628.                                        Size           : LONGINT ) : TDPMIErr;
  629.  
  630. Function  VDPMIDiscardPages(           LinearStart    : LONGINT;
  631.                                        Size           : LONGINT ) : TDPMIErr;
  632.  
  633. Function  VDPMINominatePages(          LinearStart    : LONGINT;
  634.                                        Size           : LONGINT ) : TDPMIErr;
  635.  
  636. Function  VDPMIDiscardPageContents(    LinearStart    : LONGINT;
  637.                                        Size           : LONGINT ) : TDPMIErr;
  638.  
  639. Function  VDPMIMapPhysicalRegion(      PhysStart      : LONGINT;
  640.                                        Size           : LONGINT;
  641.                                    Var LinAddr        : LONGINT ) : TDPMIErr;
  642.  
  643. Function  VDPMIFreePhysicalRegion(     LinAddr        : LONGINT ) : TDPMIErr;
  644.  
  645. Function  VDPMITestDisableInts(    Var PrevState      : BYTE    ) : TDPMIErr;
  646.  
  647. Function  VDPMITestEnableInts(     Var PrevState      : BYTE    ) : TDPMIErr;
  648.  
  649. Function  VDPMITestInts(           Var State          : BYTE    ) : TDPMIErr;
  650.  
  651. Function  VDPMIGetVendorAPIEntry(      VendorName     : STRING;
  652.                                    Var APIEntry       : POINTER ) : TDPMIErr;
  653.  
  654. Function  VDPMISetDebugWatchp(         LinAddr        : LONGINT;
  655.                                        WatchSize      : BYTE;
  656.                                        WatchType      : BYTE;
  657.                                    Var WatchHandle    : WORD    ) : TDPMIErr;
  658.  
  659. Function  VDPMIClearDebugWatchp(       WatchHandle    : WORD    ) : TDPMIErr;
  660.  
  661.  
  662. Function  VDPMIGetDebugWatchpState(    WatchHandle    : WORD;
  663.                                    Var WatchState     : WORD    ) : TDPMIErr;
  664.  
  665. Function  VDPMIResetDebugWatchp(       WatchHandle    : WORD    ) : TDPMIErr;
  666.  
  667. Function  VDPMIInstallRSPCallback(     RSPBuff        : PRSPBuff) : TDPMIErr;
  668.  
  669. Function  VDPMITermAndStayResident(    RetCode        : BYTE;
  670.                                        DosParasToKeep : WORD    ) : TDPMIErr;
  671.  
  672. Function  VDPMIAllocSharedMemory(      MemReqStruct   : PMemReqStruct ) : TDPMIErr;
  673.  
  674. Function  VDPMIFreeSharedMemory(       SMemHandle     : LONGINT ) : TDPMIErr;
  675.  
  676. Function  VDPMISerOnSharedMem(         SMemHandle     : LONGINT;
  677.                                        Flags          : WORD    ) : TDPMIErr;
  678.  
  679. Function  VDPMIFreeSerOnSharedMem(     SMemHandle     : LONGINT;
  680.                                        Flags          : WORD    ) : TDPMIErr;
  681.  
  682. Function  VDPMIGetCoprocStatus                                    : WORD;
  683.  
  684. Function  VDPMISetCoProcEmulation(     EmuFlags       : WORD    ) : TDPMIErr;
  685.  
  686. Function  RefBuffIntr(                 Flags          : WORD;
  687.                                        IntNum         : BYTE;
  688.                                        R              : TREGISTERS;
  689.                                        BuffPtr        : POINTER;
  690.                                        BuffSize       : LONGINT ) : TDPMIErr;
  691.  
  692. {────────────────────────────────────────────────────────────────────────────}
  693.  
  694. Implementation
  695.  
  696. Var
  697.  
  698.   PermReflectBuff : TVDPMIPermReflectBuff;
  699.  
  700.  
  701. {────────────────────────────────────────────────────────────────────────────}
  702.  
  703. Function  VDPMIErrToStr(          ErrCode        : WORD         ) : STRING;
  704.  
  705. Var
  706.  
  707.   S : STRING;
  708.  
  709. BEGIN
  710.  
  711.   S := '';
  712.  
  713.   Case ErrCode of
  714.  
  715.     $0000..$7FFF: S := 'DOS error ' + IntToStr(ErrCode) + ' passed through by DPMI';
  716.     $8001: S := 'Unsupported function';
  717.     $8002: S := 'Object in wrong state for function';
  718.     $8003: S := 'System integrity would be endangered';
  719.     $8004: S := 'Deadlock detected';
  720.     $8005: S := 'Pending serialization request cancelled';
  721.     $8010: S := 'Out of DPMI internal resources';
  722.     $8011: S := 'Descriptor unavailable';
  723.     $8012: S := 'Linear memory unavailable';
  724.     $8013: S := 'Physical memory unavailable';
  725.     $8014: S := 'Backing store unavailable';
  726.     $8015: S := 'Callback unavailable';
  727.     $8016: S := 'Handle unavailable';
  728.     $8017: S := 'Maximum lock count exceeded';
  729.     $8018: S := 'Shared memory already serialized exclusively by another';
  730.     $8019: S := 'Shared memory already serialized shared by another client';
  731.     $8021: S := 'Invalid value for numeric or flag parameter';
  732.     $8022: S := 'Invalid segment selector';
  733.     $8023: S := 'Invalid handle';
  734.     $8024: S := 'Invalid callback';
  735.     $8025: S := 'Invalid linear address';
  736.     $8026: S := 'Request not supported by hardware';
  737.  
  738.   End;
  739.  
  740.   VDPMIErrToStr := S;
  741.  
  742. END;
  743.  
  744. {────────────────────────────────────────────────────────────────────────────}
  745.  
  746. Function  VDPMIInstalled                                          : BOOLEAN;
  747.  
  748. Var
  749.  
  750.   R : TREGISTERS;
  751.  
  752. BEGIN
  753.  
  754.   R.AX := $1687;
  755.   R.ES := 0;
  756.   R.DS := 0;
  757.  
  758.   Intr( $2F, R );
  759.  
  760.   VDPMIInstalled := (R.AX = 0);
  761.  
  762. END;
  763.  
  764. {────────────────────────────────────────────────────────────────────────────}
  765.  
  766. Function  VDPMIInstallInfo(        Var Support32bit   : BOOLEAN;
  767.                                    Var Processor      : BYTE;
  768.                                    Var MajorVer       : BYTE;
  769.                                    Var MinorVer       : BYTE;
  770.                                    Var NumParagraphs  : WORD;
  771.                                    Var DPMIEntry      : POINTER ) : TDPMIErr;
  772.  
  773. Var
  774.  
  775.   R : TREGISTERS;
  776.  
  777. BEGIN
  778.  
  779.   R.AX := $1687;
  780.   R.ES := 0;
  781.   R.DS := 0;
  782.  
  783.   Intr( $2F, R );
  784.  
  785.   If (R.AX <> 0) Then
  786.   BEGIN
  787.  
  788.     VDPMIInstallInfo := dpmiGenErr;
  789.     Exit;
  790.  
  791.   END
  792.   Else
  793.     VDPMIInstallInfo := dpmiNoErr;
  794.  
  795.   Support32bit  := (R.BX AND $1 <> 1);
  796.   Processor     := R.CL;
  797.   MajorVer      := R.DH;
  798.   MinorVer      := R.DL;
  799.   NumParagraphs := R.SI;
  800.   DPMIEntry     := Ptr( R.ES, R.DI );
  801.  
  802. END;
  803.  
  804. {────────────────────────────────────────────────────────────────────────────}
  805.  
  806. Function  VDPMIAllocLDTDescriptor(     NumDesc        : WORD;
  807.                                    Var BaseSelector   : WORD    ) : TDPMIErr;
  808.  
  809. Var
  810.  
  811.   R : TREGISTERS;
  812.  
  813. BEGIN
  814.  
  815.   R.AX := $0000;
  816.   R.CX := NumDesc;
  817.  
  818.   R.ES := 0;
  819.   R.DS := 0;
  820.  
  821.   Intr( $31, R );
  822.  
  823.   If (R.Flags AND FCarry <> 0) Then
  824.   BEGIN
  825.  
  826.     BaseSelector            := 0;
  827.     VDPMIAllocLDTDescriptor := R.AX;
  828.  
  829.   END
  830.   Else
  831.   BEGIN
  832.  
  833.     BaseSelector     := R.AX;
  834.     VDPMIAllocLDTDescriptor := 0;
  835.  
  836.   END;
  837.  
  838. END;
  839.  
  840. {────────────────────────────────────────────────────────────────────────────}
  841.  
  842. Function  VDPMIFreeLDTDescriptor(      Selector       : WORD    ) : TDPMIErr;
  843.  
  844. Var
  845.  
  846.   R : TREGISTERS;
  847.  
  848. BEGIN
  849.  
  850.   R.AX := $0001;
  851.   R.BX := Selector;
  852.  
  853.   R.ES := 0;
  854.   R.DS := 0;
  855.  
  856.   Intr( $31, R );
  857.  
  858.   If (R.Flags AND FCarry <> 0) Then
  859.   BEGIN
  860.  
  861.     VDPMIFreeLDTDescriptor := R.AX;
  862.  
  863.   END
  864.   Else
  865.   BEGIN
  866.  
  867.     VDPMIFreeLDTDescriptor := 0;
  868.  
  869.   END;
  870.  
  871. END;
  872.  
  873. {────────────────────────────────────────────────────────────────────────────}
  874.  
  875. Function  VDPMIMapSegToSel(            RealModeSeg    : WORD;
  876.                                    Var NewSelector    : WORD    ) : TDPMIErr;
  877.  
  878. Var
  879.  
  880.   R : TREGISTERS;
  881.  
  882. BEGIN
  883.  
  884.   R.AX := $0002;
  885.   R.BX := RealModeSeg;
  886.  
  887.   R.ES := 0;
  888.   R.DS := 0;
  889.  
  890.   Intr( $31, R );
  891.  
  892.   If (R.Flags AND FCarry <> 0) Then
  893.   BEGIN
  894.  
  895.     NewSelector      := 0;
  896.     VDPMIMapSegToSel := R.AX;
  897.  
  898.   END
  899.   Else
  900.   BEGIN
  901.  
  902.     VDPMIMapSegToSel := 0;
  903.  
  904.   END;
  905.  
  906. END;
  907.  
  908. {────────────────────────────────────────────────────────────────────────────}
  909.  
  910. Function  VDPMIGetSelectorDiff                                    : TDPMIErr;
  911.  
  912. Var
  913.  
  914.   R : TREGISTERS;
  915.  
  916. BEGIN
  917.  
  918.   R.AX := $0003;
  919.   R.ES := 0;
  920.   R.DS := 0;
  921.  
  922.   Intr( $31, R );
  923.  
  924.   VDPMIGetSelectorDiff := R.AX;
  925.  
  926. END;
  927.  
  928. {────────────────────────────────────────────────────────────────────────────}
  929.  
  930. Function  VDPMILockSel(                Selector       : WORD    ) : TDPMIErr;
  931.  
  932. Var
  933.  
  934.   R : TREGISTERS;
  935.  
  936. BEGIN
  937.  
  938.   R.AX := $0004;
  939.   R.BX := Selector;
  940.   R.ES := 0;
  941.   R.DS := 0;
  942.  
  943.   Intr( $31, R );
  944.  
  945.   VDPMILockSel := 0;  {!! Unknown return}
  946.  
  947. END;
  948.  
  949. {────────────────────────────────────────────────────────────────────────────}
  950.  
  951. Function  VDPMIUnlockSel(              Selector       : WORD    ) : TDPMIErr;
  952.  
  953. Var
  954.  
  955.   R : TREGISTERS;
  956.  
  957. BEGIN
  958.  
  959.   R.AX := $0005;
  960.   R.BX := Selector;
  961.   R.ES := 0;
  962.   R.DS := 0;
  963.  
  964.   Intr( $31, R );
  965.  
  966.   VDPMIUnlockSel := 0;  {!! Unknown return}
  967.  
  968. END;
  969.  
  970. {────────────────────────────────────────────────────────────────────────────}
  971.  
  972. Function  VDPMIGetSegmentBase(         Selector       : WORD;
  973.                                    Var BaseAddr       : LONGINT ) : TDPMIErr;
  974.  
  975. Var
  976.  
  977.   R : TREGISTERS;
  978.  
  979. BEGIN
  980.  
  981.   R.AX := $0006;
  982.   R.BX := Selector;
  983.  
  984.   R.ES := 0;
  985.   R.DS := 0;
  986.  
  987.   Intr( $31, R );
  988.  
  989.   If (R.Flags AND FCarry <> 0) Then
  990.   BEGIN
  991.  
  992.     VDPMIGetSegmentBase := R.AX;
  993.  
  994.   END
  995.   Else
  996.   BEGIN
  997.  
  998.     BaseAddr            := (R.CX SHL 16)+R.DX;
  999.     VDPMIGetSegmentBase := 0;
  1000.  
  1001.   END;
  1002.  
  1003. END;
  1004.  
  1005. {────────────────────────────────────────────────────────────────────────────}
  1006.  
  1007. Function  VDPMISetSegmentBase(         Selector       : WORD;
  1008.                                        BaseAddr       : LONGINT ) : TDPMIErr;
  1009.  
  1010. Var
  1011.  
  1012.   R : TREGISTERS;
  1013.  
  1014. BEGIN
  1015.  
  1016.   R.AX := $0007;
  1017.   R.BX := Selector;
  1018.  
  1019.   R.CX := TCastDWord(BaseAddr).HighWord;
  1020.   R.DX := TCastDWord(BaseAddr).LowWord;
  1021.  
  1022.   R.ES := 0;
  1023.   R.DS := 0;
  1024.  
  1025.   Intr( $31, R );
  1026.  
  1027.   If (R.Flags AND FCarry <> 0) Then
  1028.   BEGIN
  1029.  
  1030.     VDPMISetSegmentBase := R.AX;
  1031.  
  1032.   END
  1033.   Else
  1034.   BEGIN
  1035.  
  1036.     VDPMISetSegmentBase := 0;
  1037.  
  1038.   END;
  1039.  
  1040. END;
  1041.  
  1042. {────────────────────────────────────────────────────────────────────────────}
  1043.  
  1044. Function  VDPMISetSegmentLimit(        Selector       : WORD;
  1045.                                        Limit          : LONGINT ) : TDPMIErr;
  1046.  
  1047. Var
  1048.  
  1049.   R : TREGISTERS;
  1050.  
  1051. BEGIN
  1052.  
  1053.   R.AX := $0008;
  1054.   R.BX := Selector;
  1055.  
  1056.   R.CX := TCastDWord(Limit).HighWord;
  1057.   R.DX := TCastDWord(Limit).LowWord;
  1058.  
  1059.   R.ES := 0;
  1060.   R.DS := 0;
  1061.  
  1062.   Intr( $31, R );
  1063.  
  1064.   If (R.Flags AND FCarry <> 0) Then
  1065.   BEGIN
  1066.  
  1067.     VDPMISetSegmentLimit := R.AX;
  1068.  
  1069.   END
  1070.   Else
  1071.   BEGIN
  1072.  
  1073.     VDPMISetSegmentLimit := 0;
  1074.  
  1075.   END;
  1076.  
  1077. END;
  1078.  
  1079. {────────────────────────────────────────────────────────────────────────────}
  1080.  
  1081. Function  VDPMISetSegmentRights(       Selector       : WORD;
  1082.                                        Rights         : BYTE;
  1083.                                        ExtRights      : BYTE    ) : TDPMIErr;
  1084.  
  1085. Var
  1086.  
  1087.   R : TREGISTERS;
  1088.  
  1089. BEGIN
  1090.  
  1091.   R.AX := $0009;
  1092.   R.BX := Selector;
  1093.  
  1094.   R.CL := Rights;
  1095.   R.CH := ExtRights;
  1096.  
  1097.   R.ES := 0;
  1098.   R.DS := 0;
  1099.  
  1100.   Intr( $31, R );
  1101.  
  1102.   If (R.Flags AND FCarry <> 0) Then
  1103.   BEGIN
  1104.  
  1105.     VDPMISetSegmentRights := R.AX;
  1106.  
  1107.   END
  1108.   Else
  1109.   BEGIN
  1110.  
  1111.     VDPMISetSegmentRights := 0;
  1112.  
  1113.   END;
  1114.  
  1115. END;
  1116.  
  1117. {────────────────────────────────────────────────────────────────────────────}
  1118.  
  1119. Function  VDPMICreateAlias(            Selector       : WORD;
  1120.                                    Var NewSelector    : WORD    ) : TDPMIErr;
  1121.  
  1122. Var
  1123.  
  1124.   R : TREGISTERS;
  1125.  
  1126. BEGIN
  1127.  
  1128.   R.AX := $000A;
  1129.   R.BX := Selector;
  1130.  
  1131.   R.ES := 0;
  1132.   R.DS := 0;
  1133.  
  1134.   Intr( $31, R );
  1135.  
  1136.   If (R.Flags AND FCarry <> 0) Then
  1137.   BEGIN
  1138.  
  1139.     VDPMICreateAlias := R.AX;
  1140.  
  1141.   END
  1142.   Else
  1143.   BEGIN
  1144.  
  1145.     NewSelector      := R.AX;
  1146.     VDPMICreateAlias := 0;
  1147.  
  1148.   END;
  1149.  
  1150. END;
  1151.  
  1152. {────────────────────────────────────────────────────────────────────────────}
  1153.  
  1154. Function  VDPMIGetDescriptor(          Selector       : WORD;
  1155.                                        DescBuff       : POINTER ) : TDPMIErr;
  1156.  
  1157. Var
  1158.  
  1159.   R : TREGISTERS;
  1160.  
  1161. BEGIN
  1162.  
  1163.   R.AX := $000B;
  1164.   R.BX := Selector;
  1165.  
  1166.   R.ES := TCastDWord(DescBuff).HighWord;
  1167.   R.DI := TCastDWord(DescBuff).LowWord;
  1168.  
  1169.   R.DS := 0;
  1170.  
  1171.   Intr( $31, R );
  1172.  
  1173.   If (R.Flags AND FCarry <> 0) Then
  1174.   BEGIN
  1175.  
  1176.     VDPMIGetDescriptor := R.AX;
  1177.  
  1178.   END
  1179.   Else
  1180.   BEGIN
  1181.  
  1182.     VDPMIGetDescriptor := 0;
  1183.  
  1184.   END;
  1185.  
  1186. END;
  1187.  
  1188. {────────────────────────────────────────────────────────────────────────────}
  1189.  
  1190. Function  VDPMISetDescriptor(          Selector       : WORD;
  1191.                                        DescBuff       : POINTER ) : TDPMIErr;
  1192.  
  1193. Var
  1194.  
  1195.   R : TREGISTERS;
  1196.  
  1197. BEGIN
  1198.  
  1199.   R.AX := $000C;
  1200.   R.BX := Selector;
  1201.  
  1202.   R.ES := TCastDWord(DescBuff).HighWord;
  1203.   R.DI := TCastDWord(DescBuff).LowWord;
  1204.  
  1205.   R.DS := 0;
  1206.  
  1207.   Intr( $31, R );
  1208.  
  1209.   If (R.Flags AND FCarry <> 0) Then
  1210.   BEGIN
  1211.  
  1212.     VDPMISetDescriptor := R.AX;
  1213.  
  1214.   END
  1215.   Else
  1216.   BEGIN
  1217.  
  1218.     VDPMISetDescriptor := 0;
  1219.  
  1220.   END;
  1221.  
  1222. END;
  1223.  
  1224. {────────────────────────────────────────────────────────────────────────────}
  1225.  
  1226. Function  VDPMIAllocSpecDescriptor(    Selector       : WORD    ) : TDPMIErr;
  1227.  
  1228. Var
  1229.  
  1230.   R : TREGISTERS;
  1231.  
  1232. BEGIN
  1233.  
  1234.   R.AX := $000D;
  1235.   R.BX := Selector;
  1236.  
  1237.   R.ES := 0;
  1238.   R.DS := 0;
  1239.  
  1240.   Intr( $31, R );
  1241.  
  1242.   If (R.Flags AND FCarry <> 0) Then
  1243.   BEGIN
  1244.  
  1245.     VDPMIAllocSpecDescriptor := R.AX;
  1246.  
  1247.   END
  1248.   Else
  1249.   BEGIN
  1250.  
  1251.     VDPMIAllocSpecDescriptor := 0;
  1252.  
  1253.   END;
  1254.  
  1255. END;
  1256.  
  1257. {────────────────────────────────────────────────────────────────────────────}
  1258.  
  1259. Function  VDPMIGetMultDescriptors(     NumDescs       : WORD;
  1260.                                        DescBuff       : PDescBuff;
  1261.                                    Var NumDescsCopied : WORD    ) : TDPMIErr;
  1262.  
  1263. Var
  1264.  
  1265.   R : TREGISTERS;
  1266.  
  1267. BEGIN
  1268.  
  1269.   R.AX := $000E;
  1270.   R.CX := NumDescs;
  1271.  
  1272.   R.ES := TCastDWord(DescBuff).HighWord;
  1273.   R.DI := TCastDWord(DescBuff).LowWord;
  1274.  
  1275.   R.DS := 0;
  1276.  
  1277.   Intr( $31, R );
  1278.  
  1279.   If (R.Flags AND FCarry <> 0) Then
  1280.   BEGIN
  1281.  
  1282.     VDPMIGetMultDescriptors := R.AX;
  1283.  
  1284.   END
  1285.   Else
  1286.   BEGIN
  1287.  
  1288.     VDPMIGetMultDescriptors := 0;
  1289.     NumDescsCopied           := R.CX;
  1290.  
  1291.   END;
  1292.  
  1293. END;
  1294.  
  1295. {────────────────────────────────────────────────────────────────────────────}
  1296.  
  1297. Function  VDPMISetMultDescriptors(     NumDescs       : WORD;
  1298.                                        DescBuff       : PDescBuff;
  1299.                                    Var NumDescsCopied : WORD    ) : TDPMIErr;
  1300.  
  1301. Var
  1302.  
  1303.   R : TREGISTERS;
  1304.  
  1305. BEGIN
  1306.  
  1307.   R.AX := $000F;
  1308.   R.CX := NumDescs;
  1309.  
  1310.   R.ES := TCastDWord(DescBuff).HighWord;
  1311.   R.DI := TCastDWord(DescBuff).LowWord;
  1312.  
  1313.   R.DS := 0;
  1314.  
  1315.   Intr( $31, R );
  1316.  
  1317.   If (R.Flags AND FCarry <> 0) Then
  1318.   BEGIN
  1319.  
  1320.     VDPMISetMultDescriptors := R.AX;
  1321.  
  1322.   END
  1323.   Else
  1324.   BEGIN
  1325.  
  1326.     VDPMISetMultDescriptors := 0;
  1327.     NumDescsCopied          := R.CX;
  1328.  
  1329.   END;
  1330.  
  1331. END;
  1332.  
  1333. {────────────────────────────────────────────────────────────────────────────}
  1334.  
  1335. Function  VDPMIAllocDOSMemory(         NumParas       : WORD;
  1336.                                    Var RealModeSeg    : WORD;
  1337.                                    Var ProtModeSel    : WORD    ) : TDPMIErr;
  1338.  
  1339. Var
  1340.  
  1341.   R : TREGISTERS;
  1342.  
  1343. BEGIN
  1344.  
  1345.   R.AX := $0100;
  1346.   R.BX := NumParas;
  1347.  
  1348.   R.ES := $0;
  1349.   R.DS := $0;
  1350.  
  1351.   Intr( $31, R );
  1352.  
  1353.   If (R.Flags AND FCarry <> 0) Then
  1354.     VDPMIAllocDOSMemory := R.AX
  1355.   Else
  1356.   BEGIN
  1357.  
  1358.     RealModeSeg := R.AX;
  1359.     ProtModeSel := R.DX;
  1360.  
  1361.     VDPMIAllocDOSMemory := 0;
  1362.  
  1363.   END;
  1364.  
  1365. END;
  1366.  
  1367. {────────────────────────────────────────────────────────────────────────────}
  1368.  
  1369. Function  VDPMIFreeDOSMemory(          ProtModeSel    : WORD    ) : TDPMIErr;
  1370.  
  1371. Var
  1372.  
  1373.   R : TREGISTERS;
  1374.  
  1375. BEGIN
  1376.  
  1377.   R.AX := $0101;
  1378.   R.DX := ProtModeSel;
  1379.   R.ES := $0;
  1380.   R.DS := $0;
  1381.  
  1382.   Intr( $31, R );
  1383.  
  1384.   If (R.Flags AND FCarry <> 0) Then
  1385.     VDPMIFreeDOSMemory := R.AX
  1386.   Else
  1387.     VDPMIFreeDOSMemory := 0;
  1388.  
  1389. END;
  1390.  
  1391. {────────────────────────────────────────────────────────────────────────────}
  1392.  
  1393. Function  VDPMIResizeDOSMemory(        Selector       : WORD;
  1394.                                        NewBlockParas  : WORD;
  1395.                                    Var MaxBlockSize   : WORD    ) : TDPMIErr;
  1396.  
  1397. Var
  1398.  
  1399.   R : TREGISTERS;
  1400.  
  1401. BEGIN
  1402.  
  1403.   R.AX := $0102;
  1404.   R.BX := NewBlockParas;
  1405.   R.DX := Selector;
  1406.  
  1407.   R.ES := 0;
  1408.   R.DS := 0;
  1409.  
  1410.   Intr( $31, R );
  1411.  
  1412.   If (R.Flags AND FCarry <> 0) Then
  1413.   BEGIN
  1414.  
  1415.     VDPMIResizeDOSMemory := R.AX;
  1416.     MaxBlockSize         := R.BX;
  1417.  
  1418.   END
  1419.   Else
  1420.   BEGIN
  1421.  
  1422.     VDPMIResizeDOSMemory := 0;
  1423.  
  1424.   END;
  1425.  
  1426. END;
  1427.  
  1428. {────────────────────────────────────────────────────────────────────────────}
  1429.  
  1430. Function  VDPMIGetRealIntrVector(      IntNum         : WORD;
  1431.                                    Var Vector         : POINTER ) : TDPMIErr;
  1432.  
  1433. Var
  1434.  
  1435.   R : TREGISTERS;
  1436.  
  1437. BEGIN
  1438.  
  1439.   R.AX := $0200;
  1440.   R.BL := IntNum;
  1441.  
  1442.   R.ES := 0;
  1443.   R.DS := 0;
  1444.  
  1445.   Intr( $31, R );
  1446.  
  1447.   TCastDWord(Vector).HighWord := R.CX;
  1448.   TCastDWord(Vector).LowWord  := R.DX;
  1449.  
  1450.   VDPMIGetRealIntrVector := 0;
  1451.  
  1452. END;
  1453.  
  1454. {────────────────────────────────────────────────────────────────────────────}
  1455.  
  1456. Function  VDPMISetRealIntrVector(      IntNum         : WORD;
  1457.                                        Vector         : POINTER ) : TDPMIErr;
  1458.  
  1459. Var
  1460.  
  1461.   R : TREGISTERS;
  1462.  
  1463. BEGIN
  1464.  
  1465.   R.AX := $0201;
  1466.   R.BL := IntNum;
  1467.  
  1468.   R.CX := TCastDWord(Vector).HighWord;
  1469.   R.DX := TCastDWord(Vector).LowWord;
  1470.  
  1471.   R.ES := 0;
  1472.   R.DS := 0;
  1473.  
  1474.   Intr( $31, R );
  1475.  
  1476.   VDPMISetRealIntrVector := 0;
  1477.  
  1478. END;
  1479.  
  1480. {────────────────────────────────────────────────────────────────────────────}
  1481.  
  1482. Function  VDPMIGetProcExpVector(       ExpNum         : BYTE;
  1483.                                    Var Vector         : PVectHandle ) : TDPMIErr;
  1484.  
  1485. Var
  1486.  
  1487.   R : TREGISTERS;
  1488.  
  1489. BEGIN
  1490.  
  1491.   R.AX := $0202;
  1492.   R.BL := ExpNum;
  1493.  
  1494.   R.ES := 0;
  1495.   R.DS := 0;
  1496.  
  1497.   Intr( $31, R );
  1498.  
  1499.   If (R.Flags AND FCarry <> 0) Then
  1500.   BEGIN
  1501.  
  1502.     VDPMIGetProcExpVector := R.AX;
  1503.  
  1504.   END
  1505.   Else
  1506.   BEGIN
  1507.  
  1508.     TCastDWord(Vector).HighWord := R.CX;
  1509.     TCastDWord(Vector).LowWord  := R.DX;
  1510.     VDPMIGetProcExpVector       := 0;
  1511.  
  1512.   END;
  1513.  
  1514. END;
  1515.  
  1516. {────────────────────────────────────────────────────────────────────────────}
  1517.  
  1518. Function  VDPMISetProcExpVector(       ExpNum         : BYTE;
  1519.                                        Vector         : PVectHandle ) : TDPMIErr;
  1520.  
  1521. Var
  1522.  
  1523.   R : TREGISTERS;
  1524.  
  1525. BEGIN
  1526.  
  1527.   R.AX := $0203;
  1528.   R.BL := ExpNum;
  1529.  
  1530.   R.CX := TCastDWord(Vector).HighWord;
  1531.   R.DX := TCastDWord(Vector).LowWord;
  1532.  
  1533.   R.ES := 0;
  1534.   R.DS := 0;
  1535.  
  1536.   Intr( $31, R );
  1537.  
  1538.   If (R.Flags AND FCarry <> 0) Then
  1539.   BEGIN
  1540.  
  1541.     VDPMISetProcExpVector := R.AX;
  1542.  
  1543.   END
  1544.   Else
  1545.   BEGIN
  1546.  
  1547.     VDPMISetProcExpVector := 0;
  1548.  
  1549.   END;
  1550.  
  1551. END;
  1552.  
  1553. {────────────────────────────────────────────────────────────────────────────}
  1554.  
  1555. Function  VDPMIGetProtIntrVector(      IntNum         : WORD;
  1556.                                    Var Vector         : PVectHandle ) : TDPMIErr;
  1557.  
  1558. Var
  1559.  
  1560.   R : TREGISTERS;
  1561.  
  1562. BEGIN
  1563.  
  1564.   R.AX := $0204;
  1565.   R.BL := IntNum;
  1566.  
  1567.   R.ES := 0;
  1568.   R.DS := 0;
  1569.  
  1570.   Intr( $31, R );
  1571.  
  1572.   TCastDWord(Vector).HighWord := R.CX;
  1573.   TCastDWord(Vector).LowWord  := R.DX;
  1574.  
  1575.   VDPMIGetProtIntrVector := 0;
  1576.  
  1577. END;
  1578.  
  1579. {────────────────────────────────────────────────────────────────────────────}
  1580.  
  1581. Function  VDPMISetProtIntrVector(      IntNum         : WORD;
  1582.                                        Vector         : PVectHandle ) : TDPMIErr;
  1583.  
  1584. Var
  1585.  
  1586.   R : TREGISTERS;
  1587.  
  1588. BEGIN
  1589.  
  1590.   R.AX := $0205;
  1591.   R.BL := IntNum;
  1592.  
  1593.   R.CX := TCastDWord(Vector).HighWord;
  1594.   R.DX := TCastDWord(Vector).LowWord;
  1595.  
  1596.   R.ES := 0;
  1597.   R.DS := 0;
  1598.  
  1599.   Intr( $31, R );
  1600.  
  1601.   If (R.Flags AND FCarry <> 0) Then
  1602.   BEGIN
  1603.  
  1604.     VDPMISetProtIntrVector := R.AX;
  1605.  
  1606.   END
  1607.   Else
  1608.   BEGIN
  1609.  
  1610.     VDPMISetProtIntrVector := 0;
  1611.  
  1612.   END;
  1613.  
  1614. END;
  1615.  
  1616. {────────────────────────────────────────────────────────────────────────────}
  1617.  
  1618. Function  VDPMIGetProtExtExpProc(      ExpNum         : BYTE;
  1619.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  1620.  
  1621. Var
  1622.  
  1623.   R : TREGISTERS;
  1624.  
  1625. BEGIN
  1626.  
  1627.   R.AX := $0210;
  1628.   R.BL := ExpNum;
  1629.  
  1630.   R.ES := 0;
  1631.   R.DS := 0;
  1632.  
  1633.   Intr( $31, R );
  1634.  
  1635.   If (R.Flags AND FCarry <> 0) Then
  1636.   BEGIN
  1637.  
  1638.     VDPMIGetProtExtExpProc       := R.AX;
  1639.  
  1640.   END
  1641.   Else
  1642.   BEGIN
  1643.  
  1644.     TCastDWord(Handler).HighWord := R.CX;
  1645.     TCastDWord(Handler).LowWord  := R.DX; { !^! should be EDX }
  1646.     VDPMIGetProtExtExpProc       := 0;
  1647.  
  1648.   END;
  1649.  
  1650. END;
  1651.  
  1652. {────────────────────────────────────────────────────────────────────────────}
  1653.  
  1654. Function  VDPMIGetRealExtExpProc(      ExpNum         : BYTE;
  1655.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  1656.  
  1657. Var
  1658.  
  1659.   R : TREGISTERS;
  1660.  
  1661. BEGIN
  1662.  
  1663.   R.AX := $0211;
  1664.   R.BL := ExpNum;
  1665.  
  1666.   R.ES := 0;
  1667.   R.DS := 0;
  1668.  
  1669.   Intr( $31, R );
  1670.  
  1671.   If (R.Flags AND FCarry <> 0) Then
  1672.   BEGIN
  1673.  
  1674.     VDPMIGetRealExtExpProc       := R.AX;
  1675.  
  1676.   END
  1677.   Else
  1678.   BEGIN
  1679.  
  1680.     TCastDWord(Handler).HighWord := R.CX;
  1681.     TCastDWord(Handler).LowWord  := R.DX; { !^! should be EDX }
  1682.     VDPMIGetRealExtExpProc       := 0;
  1683.  
  1684.   END;
  1685.  
  1686. END;
  1687.  
  1688. {────────────────────────────────────────────────────────────────────────────}
  1689.  
  1690. Function  VDPMISetProtExtExpProc(      ExpFaultNum    : BYTE;
  1691.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  1692.  
  1693. Var
  1694.  
  1695.   R : TREGISTERS;
  1696.  
  1697. BEGIN
  1698.  
  1699.   R.AX := $0212;
  1700.   R.BL := ExpFaultNum;
  1701.  
  1702.   R.CX := TCastDWord(Handler).HighWord;
  1703.   R.DX := TCastDWord(Handler).LowWord;
  1704.  
  1705.   R.ES := 0;
  1706.   R.DS := 0;
  1707.  
  1708.   Intr( $31, R );
  1709.  
  1710.   If (R.Flags AND FCarry <> 0) Then
  1711.   BEGIN
  1712.  
  1713.     VDPMISetProtExtExpProc := R.AX;
  1714.  
  1715.   END
  1716.   Else
  1717.   BEGIN
  1718.  
  1719.     VDPMISetProtExtExpProc := 0;
  1720.  
  1721.   END;
  1722.  
  1723. END;
  1724.  
  1725. {────────────────────────────────────────────────────────────────────────────}
  1726.  
  1727. Function  VDPMISetRealExtExpProc(      ExpFaultNum    : BYTE;
  1728.                                    Var Handler        : PVectHandle ) : TDPMIErr;
  1729.  
  1730. Var
  1731.  
  1732.   R : TREGISTERS;
  1733.  
  1734. BEGIN
  1735.  
  1736.   R.AX := $0213;
  1737.   R.BL := ExpFaultNum;
  1738.  
  1739.   R.CX := TCastDWord(Handler).HighWord;
  1740.   R.DX := TCastDWord(Handler).LowWord;
  1741.  
  1742.   R.ES := 0;
  1743.   R.DS := 0;
  1744.  
  1745.   Intr( $31, R );
  1746.  
  1747.   If (R.Flags AND FCarry <> 0) Then
  1748.   BEGIN
  1749.  
  1750.     VDPMISetRealExtExpProc := R.AX;
  1751.  
  1752.   END
  1753.   Else
  1754.   BEGIN
  1755.  
  1756.     VDPMISetRealExtExpProc := 0;
  1757.  
  1758.   END;
  1759.  
  1760. END;
  1761.  
  1762. {────────────────────────────────────────────────────────────────────────────}
  1763.  
  1764. Function  VDPMISimRealIntr(            IntrNum        : WORD;
  1765.                                        Flags          : WORD;
  1766.                                        StackCopy      : WORD;
  1767.                                        RealRegs       : PDPMIRealRegs) : TDPMIErr;
  1768.  
  1769. Var
  1770.  
  1771.   R : TREGISTERS;
  1772.  
  1773. BEGIN
  1774.  
  1775.   R.AX := $0300;
  1776.   R.BL := IntrNum;
  1777.   R.BH := Flags;
  1778.   R.CX := StackCopy;
  1779.  
  1780.   R.ES := TCastDWord(RealRegs).HighWord;
  1781.   R.DI := TCastDWord(RealRegs).LowWord;
  1782.  
  1783.   R.DS := 0;
  1784.  
  1785.   Intr( $31, R );
  1786.  
  1787.   If (R.Flags AND FCarry <> 0) Then
  1788.   BEGIN
  1789.  
  1790.     VDPMISimRealIntr := R.AX;
  1791.  
  1792.   END
  1793.   Else
  1794.   BEGIN
  1795.  
  1796.     VDPMISimRealIntr := 0;
  1797.  
  1798.   END;
  1799.  
  1800. END;
  1801.  
  1802. {────────────────────────────────────────────────────────────────────────────}
  1803.  
  1804. Function  VDPMICallRealProc(           Flags          : WORD;
  1805.                                        StackCopy      : WORD;
  1806.                                        RealRegs       : PDPMIRealRegs) : TDPMIErr;
  1807.  
  1808. Var
  1809.  
  1810.   R : TREGISTERS;
  1811.  
  1812. BEGIN
  1813.  
  1814.   R.AX := $0301;
  1815.   R.BH := Flags;
  1816.   R.CX := StackCopy;
  1817.  
  1818.   R.ES := TCastDWord(RealRegs).HighWord;
  1819.   R.DI := TCastDWord(RealRegs).LowWord;
  1820.  
  1821.   R.DS := 0;
  1822.  
  1823.   Intr( $31, R );
  1824.  
  1825.   If (R.Flags AND FCarry <> 0) Then
  1826.   BEGIN
  1827.  
  1828.     VDPMICallRealProc := R.AX;
  1829.  
  1830.   END
  1831.   Else
  1832.   BEGIN
  1833.  
  1834.     VDPMICallRealProc := 0;
  1835.  
  1836.   END;
  1837.  
  1838. END;
  1839.  
  1840. {────────────────────────────────────────────────────────────────────────────}
  1841.  
  1842. Function  VDPMICallRealIntrProc(       Flags          : WORD;
  1843.                                        StackCopy      : WORD;
  1844.                                        RealRegs       : PDPMIRealRegs) : TDPMIErr;
  1845.  
  1846. Var
  1847.  
  1848.   R : TREGISTERS;
  1849.  
  1850. BEGIN
  1851.  
  1852.   R.AX := $0302;
  1853.   R.BH := Flags;
  1854.   R.CX := StackCopy;
  1855.  
  1856.   R.ES := TCastDWord(RealRegs).HighWord;
  1857.   R.DI := TCastDWord(RealRegs).LowWord;
  1858.  
  1859.   R.DS := 0;
  1860.  
  1861.   Intr( $31, R );
  1862.  
  1863.   If (R.Flags AND FCarry <> 0) Then
  1864.   BEGIN
  1865.  
  1866.     VDPMICallRealIntrProc := R.AX;
  1867.  
  1868.   END
  1869.   Else
  1870.   BEGIN
  1871.  
  1872.     VDPMICallRealIntrProc := 0;
  1873.  
  1874.   END;
  1875.  
  1876. END;
  1877.  
  1878. {────────────────────────────────────────────────────────────────────────────}
  1879.  
  1880. Function  VDPMIAllocRealCallback(      ProtProc       : PSelOfs;
  1881.                                        RealRegBuff    : PDPMIRealRegs;
  1882.                                    Var CallBackAddr   : POINTER ) : TDPMIErr;
  1883.  
  1884. Var
  1885.  
  1886.   R : TREGISTERS;
  1887.  
  1888. BEGIN
  1889.  
  1890.   R.AX := $0303;
  1891.  
  1892.   R.DS := TCastDWord(CallBackAddr).HighWord;
  1893.   R.SI := TCastDWord(CallBackAddr).LowWord;
  1894.  
  1895.   R.ES := TCastDWord(RealRegBuff).HighWord;
  1896.   R.DI := TCastDWord(RealRegBuff).LowWord;
  1897.  
  1898.   Intr( $31, R );
  1899.  
  1900.   If (R.Flags AND FCarry <> 0) Then
  1901.   BEGIN
  1902.  
  1903.     VDPMIAllocRealCallback := R.AX;
  1904.  
  1905.   END
  1906.   Else
  1907.   BEGIN
  1908.  
  1909.     VDPMIAllocRealCallback := 0;
  1910.  
  1911.   END;
  1912.  
  1913. END;
  1914.  
  1915. {────────────────────────────────────────────────────────────────────────────}
  1916.  
  1917. Function  VDPMIFreeRealCallback(       CallBackAddr   : POINTER ) : TDPMIErr;
  1918.  
  1919. Var
  1920.  
  1921.   R : TREGISTERS;
  1922.  
  1923. BEGIN
  1924.  
  1925.   R.AX := $0304;
  1926.  
  1927.   R.CX := TCastDWord(CallBackAddr).HighWord;
  1928.   R.DX := TCastDWord(CallBackAddr).LowWord;
  1929.  
  1930.   R.ES := 0;
  1931.   R.DS := 0;
  1932.  
  1933.   Intr( $31, R );
  1934.  
  1935.   If (R.Flags AND FCarry <> 0) Then
  1936.   BEGIN
  1937.  
  1938.     VDPMIFreeRealCallback := R.AX;
  1939.  
  1940.   END
  1941.   Else
  1942.   BEGIN
  1943.  
  1944.     VDPMIFreeRealCallback := 0;
  1945.  
  1946.   END;
  1947.  
  1948. END;
  1949.  
  1950. {────────────────────────────────────────────────────────────────────────────}
  1951.  
  1952. Function  VDPMIGetStateSRProcs(    Var StateBuffSize  : WORD;
  1953.                                    Var RealModeAddr   : POINTER;
  1954.                                    Var ProtModeAddr   : POINTER ) : TDPMIErr;
  1955.  
  1956. Var
  1957.  
  1958.   R : TREGISTERS;
  1959.  
  1960. BEGIN
  1961.  
  1962.   R.AX := $0305;
  1963.  
  1964.   R.ES := 0;
  1965.   R.DS := 0;
  1966.  
  1967.   Intr( $31, R );
  1968.  
  1969.   StateBuffSize := R.AX;
  1970.   TCastDWord(RealModeAddr).HighWord := R.CX;
  1971.   TCastDWord(RealModeAddr).LowWord  := R.DX;
  1972.   TCastDWord(ProtModeAddr).HighWord := R.SI;
  1973.   TCastDWord(ProtModeAddr).LowWord  := R.DI;
  1974.  
  1975.   VDPMIGetStateSRProcs := 0;
  1976.  
  1977. END;
  1978.  
  1979. {────────────────────────────────────────────────────────────────────────────}
  1980.  
  1981. Function  VDPMIGetRawSwitchProcs(  Var RealToProtAddr : POINTER;
  1982.                                    Var ProtToRealAddr : POINTER ) : TDPMIErr;
  1983.  
  1984. Var
  1985.  
  1986.   R : TREGISTERS;
  1987.  
  1988. BEGIN
  1989.  
  1990.   R.AX := $0306;
  1991.  
  1992.   R.ES := 0;
  1993.   R.DS := 0;
  1994.  
  1995.   Intr( $31, R );
  1996.  
  1997.   TCastDWord(RealToProtAddr).HighWord := R.CX;
  1998.   TCastDWord(RealToProtAddr).LowWord  := R.DX;
  1999.   TCastDWord(ProtToRealAddr).HighWord := R.SI;
  2000.   TCastDWord(ProtToRealAddr).LowWord  := R.DI;
  2001.  
  2002.   VDPMIGetRawSwitchProcs := 0;
  2003.  
  2004. END;
  2005.  
  2006. {────────────────────────────────────────────────────────────────────────────}
  2007.  
  2008. Function  VDPMIGetVersion(         Var MajorVer       : BYTE;
  2009.                                    Var MinorVer       : BYTE;
  2010.                                    Var Flags          : WORD;
  2011.                                    Var ProcType       : BYTE;
  2012.                                    Var VirtMastPIC    : BYTE;
  2013.                                    Var VirtSlavePIC   : BYTE    ) : TDPMIErr;
  2014.  
  2015. Var
  2016.  
  2017.   R : TREGISTERS;
  2018.  
  2019. BEGIN
  2020.  
  2021.   R.AX := $0400;
  2022.  
  2023.   R.ES := 0;
  2024.   R.DS := 0;
  2025.  
  2026.   Intr( $31, R );
  2027.  
  2028.   MajorVer     := R.AH;
  2029.   MinorVer     := R.AL;
  2030.   Flags        := R.BX;
  2031.   ProcType     := R.CL;
  2032.   VirtMastPIC  := R.DH;
  2033.   VirtSlavePIC := R.DL;
  2034.  
  2035.   VDPMIGetVersion := 0;
  2036.  
  2037. END;
  2038.  
  2039. {────────────────────────────────────────────────────────────────────────────}
  2040.  
  2041. Function  VDPMIGetCaps(                InfoBuffer     : PGetCapsBuff;
  2042.                                    Var CaoFlags       : WORD    ) : TDPMIErr;
  2043.  
  2044. Var
  2045.  
  2046.   R : TREGISTERS;
  2047.  
  2048. BEGIN
  2049.  
  2050.   R.AX := $0401;
  2051.  
  2052.   R.ES := TCastDWord(InfoBuffer).HighWord;
  2053.   R.DI := TCastDWord(InfoBuffer).LowWord;
  2054.  
  2055.   R.DS := 0;
  2056.  
  2057.   Intr( $31, R );
  2058.  
  2059.   If (R.Flags AND FCarry <> 0) Then
  2060.   BEGIN
  2061.  
  2062.     VDPMIGetCaps := R.AX;
  2063.  
  2064.   END
  2065.   Else
  2066.   BEGIN
  2067.  
  2068.     CaoFlags     := R.AX;
  2069.     VDPMIGetCaps := 0;
  2070.  
  2071.   END;
  2072.  
  2073. END;
  2074.  
  2075. {────────────────────────────────────────────────────────────────────────────}
  2076.  
  2077. Function  VDPMIGetFreeMemory(          InfoBuffer     : PFreeMemInfo ) : TDPMIErr;
  2078.  
  2079. Var
  2080.  
  2081.   R : TREGISTERS;
  2082.  
  2083. BEGIN
  2084.  
  2085.   R.AX := $0500;
  2086.  
  2087.   R.ES := TCastDWord(InfoBuffer).HighWord;
  2088.   R.DI := TCastDWord(InfoBuffer).LowWord;
  2089.  
  2090.   R.DS := 0;
  2091.  
  2092.   Intr( $31, R );
  2093.  
  2094.   VDPMIGetFreeMemory := 0;
  2095.  
  2096. END;
  2097.  
  2098. {────────────────────────────────────────────────────────────────────────────}
  2099.  
  2100. Function  VDPMIAllocMemory(            Size           : LONGINT;
  2101.                                    Var LinAddr        : LONGINT;
  2102.                                    Var MemHandle      : LONGINT ) : TDPMIErr;
  2103.  
  2104. Var
  2105.  
  2106.   R : TREGISTERS;
  2107.  
  2108. BEGIN
  2109.  
  2110.   R.AX := $0501;
  2111.  
  2112.   R.BX := TCastDWord(Size).HighWord;
  2113.   R.CX := TCastDWord(Size).LowWord;
  2114.  
  2115.   R.ES := 0;
  2116.   R.DS := 0;
  2117.  
  2118.   Intr( $31, R );
  2119.  
  2120.   If (R.Flags AND FCarry <> 0) Then
  2121.   BEGIN
  2122.  
  2123.     VDPMIAllocMemory := R.AX;
  2124.  
  2125.   END
  2126.   Else
  2127.   BEGIN
  2128.  
  2129.     TCastDWord(LinAddr).HighWord   := R.BX;
  2130.     TCastDWord(LinAddr).LowWord    := R.CX;
  2131.     TCastDWord(MemHandle).HighWord := R.SI;
  2132.     TCastDWord(MemHandle).LowWord  := R.DI;
  2133.  
  2134.     VDPMIAllocMemory := 0;
  2135.  
  2136.   END;
  2137.  
  2138. END;
  2139.  
  2140. {────────────────────────────────────────────────────────────────────────────}
  2141.  
  2142. Function  VDPMIFreeMemory(             MemHandle      : LONGINT ) : TDPMIErr;
  2143.  
  2144. Var
  2145.  
  2146.   R : TREGISTERS;
  2147.  
  2148. BEGIN
  2149.  
  2150.   R.AX := $0502;
  2151.  
  2152.   R.SI := TCastDWord(MemHandle).HighWord;
  2153.   R.DI := TCastDWord(MemHandle).LowWord;
  2154.  
  2155.   R.ES := 0;
  2156.   R.DS := 0;
  2157.  
  2158.   Intr( $31, R );
  2159.  
  2160.   If (R.Flags AND FCarry <> 0) Then
  2161.   BEGIN
  2162.  
  2163.     VDPMIFreeMemory := R.AX;
  2164.  
  2165.   END
  2166.   Else
  2167.   BEGIN
  2168.  
  2169.     VDPMIFreeMemory := 0;
  2170.  
  2171.   END;
  2172.  
  2173. END;
  2174.  
  2175. {────────────────────────────────────────────────────────────────────────────}
  2176.  
  2177. Function  VDPMIResizeMemory(           MemHandle      : LONGINT;
  2178.                                        NewSize        : LONGINT;
  2179.                                    Var NewMemHandle   : LONGINT;
  2180.                                    Var NewLinAddr     : LONGINT ) : TDPMIErr;
  2181.  
  2182. Var
  2183.  
  2184.   R : TREGISTERS;
  2185.  
  2186. BEGIN
  2187.  
  2188.   R.AX := $0503;
  2189.  
  2190.   R.BX := TCastDWord(NewSize).HighWord;
  2191.   R.CX := TCastDWord(NewSize).LowWord;
  2192.   R.SI := TCastDWord(MemHandle).HighWord;
  2193.   R.DI := TCastDWord(MemHandle).LowWord;
  2194.  
  2195.   R.ES := 0;
  2196.   R.DS := 0;
  2197.  
  2198.   Intr( $31, R );
  2199.  
  2200.   If (R.Flags AND FCarry <> 0) Then
  2201.   BEGIN
  2202.  
  2203.     VDPMIResizeMemory := R.AX;
  2204.  
  2205.   END
  2206.   Else
  2207.   BEGIN
  2208.  
  2209.     TCastDWord(NewLinAddr).HighWord   := R.BX;
  2210.     TCastDWord(NewLinAddr).LowWord    := R.CX;
  2211.     TCastDWord(NewMemHandle).HighWord := R.SI;
  2212.     TCastDWord(NewMemHandle).LowWord  := R.DI;
  2213.  
  2214.     VDPMIResizeMemory := 0;
  2215.  
  2216.   END;
  2217.  
  2218. END;
  2219.  
  2220. {────────────────────────────────────────────────────────────────────────────}
  2221.  
  2222. Function  VDPMIAllocLinMemory(         LinAddr        : LONGINT;
  2223.                                        Size           : LONGINT;
  2224.                                        Flags          : LONGINT;
  2225.                                    Var NewLinAddr     : LONGINT;
  2226.                                    Var MemHandle      : LONGINT ) : TDPMIErr;
  2227.  
  2228. Var
  2229.  
  2230.   R : TREGISTERS;
  2231.  
  2232. BEGIN
  2233.  
  2234.   R.AX := $0504;
  2235.  
  2236.   R.BX := TCastDWord(LinAddr).HighWord; { !^! R.EBX := LinAddr; }
  2237.   R.CX := TCastDWord(Size).HighWord;    { !^! R.ECX := Size;    }
  2238.   R.DX := TCastDWord(Flags).HighWord;   { !^! R.EDX := Flags;   }
  2239.  
  2240.   R.ES := 0;
  2241.   R.DS := 0;
  2242.  
  2243.   Intr( $31, R );
  2244.  
  2245.   If (R.Flags AND FCarry <> 0) Then
  2246.   BEGIN
  2247.  
  2248.     VDPMIAllocLinMemory := R.AX;
  2249.  
  2250.   END
  2251.   Else
  2252.   BEGIN
  2253.  
  2254.     TCastDWord(NewLinAddr).HighWord := R.BX; { !^! NewLinAddr := R.EBX; }
  2255.     TCastDWord(MemHandle).HighWord  := R.SI; { !^! MemHandle  := R.ESI; }
  2256.  
  2257.     VDPMIAllocLinMemory := 0;
  2258.  
  2259.   END;
  2260.  
  2261. END;
  2262.  
  2263. {────────────────────────────────────────────────────────────────────────────}
  2264.  
  2265. Function  VDPMIResizeLinMemory(        MemHandle      : LONGINT;
  2266.                                        NewSize        : LONGINT;
  2267.                                        NewFlags       : LONGINT;
  2268.                                    Var NewLinAddr     : LONGINT;
  2269.                                    Var NewMemHandle   : LONGINT ) : TDPMIErr;
  2270.  
  2271. Var
  2272.  
  2273.   R : TREGISTERS;
  2274.  
  2275. BEGIN
  2276.  
  2277.   R.AX := $0505;
  2278.  
  2279.   R.SI := TCastDWord(MemHandle).Highword; { !^! R.ESI := MemHandle; }
  2280.   R.CX := TCastDWord(NewSize).HighWord;   { !^! R.ECX := NewSize;   }
  2281.   R.DX := TCastDWord(NewFlags).HighWord;  { !^! R.EDX := NewFlags;  }
  2282.  
  2283.   R.ES := 0;
  2284.   R.DS := 0;
  2285.  
  2286.   Intr( $31, R );
  2287.  
  2288.   If (R.Flags AND FCarry <> 0) Then
  2289.   BEGIN
  2290.  
  2291.     VDPMIResizeLinMemory := R.AX;
  2292.  
  2293.   END
  2294.   Else
  2295.   BEGIN
  2296.  
  2297.     TCastDWord(NewLinAddr).HighWord := R.BX;    { !^! NewLinAddr := R.EBX; }
  2298.     TCastDWord(NewMemHandle).HighWord  := R.SI; { !^! NewMemHandle  := R.ESI; }
  2299.  
  2300.     VDPMIResizeLinMemory := 0;
  2301.  
  2302.   END;
  2303.  
  2304. END;
  2305.  
  2306. {────────────────────────────────────────────────────────────────────────────}
  2307.  
  2308. Function  VDPMIGetPageAttrs(           MemHandle      : LONGINT;
  2309.                                        BasePageOfs    : LONGINT;
  2310.                                        NumPages       : LONGINT;
  2311.                                    Var PageAttrArr    : PPageAttr ) : TDPMIErr;
  2312.  
  2313. Var
  2314.  
  2315.   R : TREGISTERS;
  2316.  
  2317. BEGIN
  2318.  
  2319.   R.AX := $0506;
  2320.  
  2321.   R.SI := TCastDWord(MemHandle).Highword;   { !^! R.ESI := MemHandle; }
  2322.   R.BX := TCastDWord(BasePageOfs).Highword; { !^! R.EBX := BasePageOfs; }
  2323.   R.CX := TCastDWord(NumPages).Highword;    { !^! R.ECX := NumPages; }
  2324.   R.ES := TCastDWord(PageAttrArr).Highword;
  2325.   R.DX := TCastDWord(PageAttrArr).Lowword;  { !^! R.EDX ... }
  2326.  
  2327.   R.DS := 0;
  2328.  
  2329.   Intr( $31, R );
  2330.  
  2331.   If (R.Flags AND FCarry <> 0) Then
  2332.   BEGIN
  2333.  
  2334.     VDPMIGetPageAttrs := R.AX;
  2335.  
  2336.   END
  2337.   Else
  2338.   BEGIN
  2339.  
  2340.     VDPMIGetPageAttrs := 0;
  2341.  
  2342.   END;
  2343.  
  2344. END;
  2345.  
  2346. {────────────────────────────────────────────────────────────────────────────}
  2347.  
  2348. Function  VDPMIModifyPageAttrs(        MemHandle      : LONGINT;
  2349.                                        BasePageOfs    : LONGINT;
  2350.                                        NumPages       : LONGINT;
  2351.                                        PageAttrArr    : PPageAttr;
  2352.                                    Var NewNumPages    : LONGINT ) : TDPMIErr;
  2353.  
  2354. Var
  2355.  
  2356.   R : TREGISTERS;
  2357.  
  2358. BEGIN
  2359.  
  2360.   R.AX := $0507;
  2361.  
  2362.   R.SI := TCastDWord(MemHandle).Highword;   { !^! R.ESI := MemHandle; }
  2363.   R.BX := TCastDWord(BasePageOfs).Highword; { !^! R.EBX := BasePageOfs; }
  2364.   R.CX := TCastDWord(NumPages).Highword;    { !^! R.ECX := NumPages; }
  2365.   R.ES := TCastDWord(PageAttrArr).Highword;
  2366.   R.DX := TCastDWord(PageAttrArr).Lowword;  { !^! R.EDX ... }
  2367.  
  2368.   R.DS := 0;
  2369.  
  2370.   Intr( $31, R );
  2371.  
  2372.   If (R.Flags AND FCarry <> 0) Then
  2373.   BEGIN
  2374.  
  2375.     VDPMIModifyPageAttrs := R.AX;
  2376.  
  2377.   END
  2378.   Else
  2379.   BEGIN
  2380.  
  2381.     TCastDWord(NewNumPages).Highword := R.CX; { !^! NewNumPages := R.ECX; }
  2382.     VDPMIModifyPageAttrs := 0;
  2383.  
  2384.   END;
  2385.  
  2386. END;
  2387.  
  2388. {────────────────────────────────────────────────────────────────────────────}
  2389.  
  2390. Function  VDPMIMapDeviceMemory(        MemHandle      : LONGINT;
  2391.                                        PageOfs        : LONGINT;
  2392.                                        NumPages       : LONGINT;
  2393.                                        PhyDevAddr     : LONGINT ) : TDPMIErr;
  2394.  
  2395. Var
  2396.  
  2397.   R : TREGISTERS;
  2398.  
  2399. BEGIN
  2400.  
  2401.   R.AX := $0508;
  2402.  
  2403.   R.SI := TCastDWord(MemHandle).Highword;  { !^! R.ESI := MemHandle; }
  2404.   R.BX := TCastDWord(PageOfs).Highword;    { !^! R.EBX := PageOfs; }
  2405.   R.CX := TCastDWord(NumPages).Highword;   { !^! R.ECX := NumPages; }
  2406.   R.DX := TCastDWord(PhyDevAddr).Lowword;  { !^! R.EDX := PhyDevAddr; }
  2407.  
  2408.   R.ES := 0;
  2409.   R.DS := 0;
  2410.  
  2411.   Intr( $31, R );
  2412.  
  2413.   If (R.Flags AND FCarry <> 0) Then
  2414.   BEGIN
  2415.  
  2416.     VDPMIMapDeviceMemory := R.AX;
  2417.  
  2418.   END
  2419.   Else
  2420.   BEGIN
  2421.  
  2422.     VDPMIMapDeviceMemory := 0;
  2423.  
  2424.   END;
  2425.  
  2426. END;
  2427.  
  2428. {────────────────────────────────────────────────────────────────────────────}
  2429.  
  2430. Function  VDPMIMapConvMemory(          MemHandle      : LONGINT;
  2431.                                        PageOfs        : LONGINT;
  2432.                                        NumPages       : LONGINT;
  2433.                                        LinConvMemAddr : LONGINT ) : TDPMIErr;
  2434.  
  2435. Var
  2436.  
  2437.   R : TREGISTERS;
  2438.  
  2439. BEGIN
  2440.  
  2441.   R.AX := $0509;
  2442.  
  2443.   R.SI := TCastDWord(MemHandle).Highword;     { !^! R.ESI := MemHandle; }
  2444.   R.BX := TCastDWord(PageOfs).Highword;       { !^! R.EBX := PageOfs; }
  2445.   R.CX := TCastDWord(NumPages).Highword;      { !^! R.ECX := NumPages; }
  2446.   R.DX := TCastDWord(LinConvMemAddr).Lowword; { !^! R.EDX := LinConvMemAddr; }
  2447.  
  2448.   R.ES := 0;
  2449.   R.DS := 0;
  2450.  
  2451.   Intr( $31, R );
  2452.  
  2453.   If (R.Flags AND FCarry <> 0) Then
  2454.   BEGIN
  2455.  
  2456.     VDPMIMapConvMemory := R.AX;
  2457.  
  2458.   END
  2459.   Else
  2460.   BEGIN
  2461.  
  2462.     VDPMIMapConvMemory := 0;
  2463.  
  2464.   END;
  2465.  
  2466. END;
  2467.  
  2468. {────────────────────────────────────────────────────────────────────────────}
  2469.  
  2470. Function  VDPMIGetMemorySizeBase(      MemHandle      : LONGINT;
  2471.                                    Var Size           : LONGINT;
  2472.                                    Var BaseAddr       : POINTER ) : TDPMIErr;
  2473.  
  2474. Var
  2475.  
  2476.   R : TREGISTERS;
  2477.  
  2478. BEGIN
  2479.  
  2480.   R.AX := $050A;
  2481.  
  2482.   R.SI := TCastDWord(MemHandle).HighWord;
  2483.   R.DI := TCastDWord(MemHandle).LowWord;
  2484.  
  2485.   R.ES := 0;
  2486.   R.DS := 0;
  2487.  
  2488.   Intr( $31, R );
  2489.  
  2490.   If (R.Flags AND FCarry <> 0) Then
  2491.   BEGIN
  2492.  
  2493.     VDPMIGetMemorySizeBase := R.AX;
  2494.  
  2495.   END
  2496.   Else
  2497.   BEGIN
  2498.  
  2499.     TCastDWord(Size).HighWord     := R.SI;
  2500.     TCastDWord(Size).LowWord      := R.DI;
  2501.     TCastDWord(BaseAddr).HighWord := R.BX;
  2502.     TCastDWord(BaseAddr).LowWord  := R.CX;
  2503.  
  2504.     VDPMIGetMemorySizeBase := 0;
  2505.  
  2506.   END;
  2507.  
  2508. END;
  2509.  
  2510. {────────────────────────────────────────────────────────────────────────────}
  2511.  
  2512. Function  VDPMIGetMemoryInfo(          MemInfo        : PMemInfo) : TDPMIErr;
  2513.  
  2514. Var
  2515.  
  2516.   R : TREGISTERS;
  2517.  
  2518. BEGIN
  2519.  
  2520.   R.AX := $050B;
  2521.  
  2522.   R.ES := TCastDWord(MemInfo).HighWord;
  2523.   R.DI := TCastDWord(MemInfo).LowWord;
  2524.  
  2525.   R.DS := 0;
  2526.  
  2527.   Intr( $31, R );
  2528.  
  2529.   If (R.Flags AND FCarry <> 0) Then
  2530.     VDPMIGetMemoryInfo := R.AX
  2531.   Else
  2532.     VDPMIGetMemoryInfo := 0;
  2533.  
  2534. END;
  2535.  
  2536. {────────────────────────────────────────────────────────────────────────────}
  2537.  
  2538. Function  VDPMILockLinRegion(          LinearStart    : LONGINT;
  2539.                                        Size           : LONGINT ) : TDPMIErr;
  2540.  
  2541. Var
  2542.  
  2543.   R : TREGISTERS;
  2544.  
  2545. BEGIN
  2546.  
  2547.   R.AX := $0600;
  2548.   R.BX := TCastDWord(LinearStart).HighWord;
  2549.   R.CX := TCastDWord(LinearStart).LowWord;
  2550.   R.SI := TCastDWord(Size).HighWord;
  2551.   R.DI := TCastDWord(Size).LowWord;
  2552.  
  2553.   R.ES := 0;
  2554.   R.DS := 0;
  2555.  
  2556.   Intr( $31, R );
  2557.  
  2558.   If (R.Flags AND FCarry <> 0) Then
  2559.   BEGIN
  2560.  
  2561.     VDPMILockLinRegion := R.AX;
  2562.  
  2563.   END
  2564.   Else
  2565.   BEGIN
  2566.  
  2567.     VDPMILockLinRegion := 0;
  2568.  
  2569.   END;
  2570.  
  2571. END;
  2572.  
  2573. {────────────────────────────────────────────────────────────────────────────}
  2574.  
  2575. Function  VDPMIUnlockLinRegion(        LinearStart    : LONGINT;
  2576.                                        Size           : LONGINT ) : TDPMIErr;
  2577.  
  2578. Var
  2579.  
  2580.   R : TREGISTERS;
  2581.  
  2582. BEGIN
  2583.  
  2584.   R.AX := $0601;
  2585.   R.BX := TCastDWord(LinearStart).HighWord;
  2586.   R.CX := TCastDWord(LinearStart).LowWord;
  2587.   R.SI := TCastDWord(Size).HighWord;
  2588.   R.DI := TCastDWord(Size).LowWord;
  2589.  
  2590.   R.ES := 0;
  2591.   R.DS := 0;
  2592.  
  2593.   Intr( $31, R );
  2594.  
  2595.   If (R.Flags AND FCarry <> 0) Then
  2596.   BEGIN
  2597.  
  2598.     VDPMIUnlockLinRegion := R.AX;
  2599.  
  2600.   END
  2601.   Else
  2602.   BEGIN
  2603.  
  2604.     VDPMIUnlockLinRegion := 0;
  2605.  
  2606.   END;
  2607.  
  2608. END;
  2609.  
  2610. {────────────────────────────────────────────────────────────────────────────}
  2611.  
  2612. Function  VDPMIMarkRealRegionPageable( LinearStart    : LONGINT;
  2613.                                        Size           : LONGINT ) : TDPMIErr;
  2614.  
  2615. Var
  2616.  
  2617.   R : TREGISTERS;
  2618.  
  2619. BEGIN
  2620.  
  2621.   R.AX := $0602;
  2622.  
  2623.   R.BX := TCastDWord(LinearStart).HighWord;
  2624.   R.CX := TCastDWord(LinearStart).LowWord;
  2625.   R.SI := TCastDWord(Size).HighWord;
  2626.   R.DI := TCastDWord(Size).LowWord;
  2627.  
  2628.   R.ES := 0;
  2629.   R.DS := 0;
  2630.  
  2631.   Intr( $31, R );
  2632.  
  2633.   If (R.Flags AND FCarry <> 0) Then
  2634.   BEGIN
  2635.  
  2636.     VDPMIMarkRealRegionPageable := R.AX;
  2637.  
  2638.   END
  2639.   Else
  2640.   BEGIN
  2641.  
  2642.     VDPMIMarkRealRegionPageable := 0;
  2643.  
  2644.   END;
  2645.  
  2646. END;
  2647.  
  2648. {────────────────────────────────────────────────────────────────────────────}
  2649.  
  2650. Function  VDPMIRelockRealRegion(       LinearStart    : LONGINT;
  2651.                                        Size           : LONGINT ) : TDPMIErr;
  2652.  
  2653. Var
  2654.  
  2655.   R : TREGISTERS;
  2656.  
  2657. BEGIN
  2658.  
  2659.   R.AX := $0603;
  2660.  
  2661.   R.BX := TCastDWord(LinearStart).HighWord;
  2662.   R.CX := TCastDWord(LinearStart).LowWord;
  2663.   R.SI := TCastDWord(Size).HighWord;
  2664.   R.DI := TCastDWord(Size).LowWord;
  2665.  
  2666.   R.ES := 0;
  2667.   R.DS := 0;
  2668.  
  2669.   Intr( $31, R );
  2670.  
  2671.   If (R.Flags AND FCarry <> 0) Then
  2672.   BEGIN
  2673.  
  2674.     VDPMIRelockRealRegion := R.AX;
  2675.  
  2676.   END
  2677.   Else
  2678.   BEGIN
  2679.  
  2680.     VDPMIRelockRealRegion := 0;
  2681.  
  2682.   END;
  2683.  
  2684. END;
  2685.  
  2686. {────────────────────────────────────────────────────────────────────────────}
  2687.  
  2688. Function  VDPMIGetPageSize(        Var PageSize       : LONGINT ) : TDPMIErr;
  2689.  
  2690. Var
  2691.  
  2692.   R : TREGISTERS;
  2693.  
  2694. BEGIN
  2695.  
  2696.   R.AX := $0604;
  2697.  
  2698.   R.ES := 0;
  2699.   R.DS := 0;
  2700.  
  2701.   Intr( $31, R );
  2702.  
  2703.   If (R.Flags AND FCarry <> 0) Then
  2704.   BEGIN
  2705.  
  2706.     VDPMIGetPageSize := R.AX;
  2707.  
  2708.   END
  2709.   Else
  2710.   BEGIN
  2711.  
  2712.     TCastDWord(PageSize).HighWord := R.BX;
  2713.     TCastDWord(PageSize).LowWord  := R.CX;
  2714.     VDPMIGetPageSize              := 0;
  2715.  
  2716.   END;
  2717.  
  2718. END;
  2719.  
  2720. {────────────────────────────────────────────────────────────────────────────}
  2721.  
  2722. Function  VDPMIMarkPagesCandidate(     LinearStart    : LONGINT;
  2723.                                        Size           : LONGINT ) : TDPMIErr;
  2724.  
  2725. Var
  2726.  
  2727.   R : TREGISTERS;
  2728.  
  2729. BEGIN
  2730.  
  2731.   R.AX := $0700;
  2732.  
  2733.   R.BX := TCastDWord(LinearStart).HighWord;
  2734.   R.CX := TCastDWord(LinearStart).LowWord;
  2735.   R.SI := TCastDWord(Size).HighWord;
  2736.   R.DI := TCastDWord(Size).LowWord;
  2737.  
  2738.   R.ES := 0;
  2739.   R.DS := 0;
  2740.  
  2741.   Intr( $31, R );
  2742.  
  2743.   If (R.Flags AND FCarry <> 0) Then
  2744.   BEGIN
  2745.  
  2746.     VDPMIMarkPagesCandidate := R.AX;
  2747.  
  2748.   END
  2749.   Else
  2750.   BEGIN
  2751.  
  2752.     VDPMIMarkPagesCandidate := 0;
  2753.  
  2754.   END;
  2755.  
  2756. END;
  2757.  
  2758. {────────────────────────────────────────────────────────────────────────────}
  2759.  
  2760. Function  VDPMIDiscardPages(           LinearStart    : LONGINT;
  2761.                                        Size           : LONGINT ) : TDPMIErr;
  2762.  
  2763. Var
  2764.  
  2765.   R : TREGISTERS;
  2766.  
  2767. BEGIN
  2768.  
  2769.   R.AX := $0701;
  2770.  
  2771.   R.BX := TCastDWord(LinearStart).HighWord;
  2772.   R.CX := TCastDWord(LinearStart).LowWord;
  2773.   R.SI := TCastDWord(Size).HighWord;
  2774.   R.DI := TCastDWord(Size).LowWord;
  2775.  
  2776.   R.ES := 0;
  2777.   R.DS := 0;
  2778.  
  2779.   Intr( $31, R );
  2780.  
  2781.   If (R.Flags AND FCarry <> 0) Then
  2782.   BEGIN
  2783.  
  2784.     VDPMIDiscardPages := R.AX;
  2785.  
  2786.   END
  2787.   Else
  2788.   BEGIN
  2789.  
  2790.     VDPMIDiscardPages := 0;
  2791.  
  2792.   END;
  2793.  
  2794. END;
  2795.  
  2796. {────────────────────────────────────────────────────────────────────────────}
  2797.  
  2798. Function  VDPMINominatePages(          LinearStart    : LONGINT;
  2799.                                        Size           : LONGINT ) : TDPMIErr;
  2800.  
  2801. Var
  2802.  
  2803.   R : TREGISTERS;
  2804.  
  2805. BEGIN
  2806.  
  2807.   R.AX := $0702;
  2808.  
  2809.   R.BX := TCastDWord(LinearStart).HighWord;
  2810.   R.CX := TCastDWord(LinearStart).LowWord;
  2811.   R.SI := TCastDWord(Size).HighWord;
  2812.   R.DI := TCastDWord(Size).LowWord;
  2813.  
  2814.   R.ES := 0;
  2815.   R.DS := 0;
  2816.  
  2817.   Intr( $31, R );
  2818.  
  2819.   If (R.Flags AND FCarry <> 0) Then
  2820.   BEGIN
  2821.  
  2822.     VDPMINominatePages := R.AX;
  2823.  
  2824.   END
  2825.   Else
  2826.   BEGIN
  2827.  
  2828.     VDPMINominatePages := 0;
  2829.  
  2830.   END;
  2831.  
  2832. END;
  2833.  
  2834. {────────────────────────────────────────────────────────────────────────────}
  2835.  
  2836. Function  VDPMIDiscardPageContents(    LinearStart    : LONGINT;
  2837.                                        Size           : LONGINT ) : TDPMIErr;
  2838.  
  2839. Var
  2840.  
  2841.   R : TREGISTERS;
  2842.  
  2843. BEGIN
  2844.  
  2845.   R.AX := $0703;
  2846.  
  2847.   R.BX := TCastDWord(LinearStart).HighWord;
  2848.   R.CX := TCastDWord(LinearStart).LowWord;
  2849.   R.SI := TCastDWord(Size).HighWord;
  2850.   R.DI := TCastDWord(Size).LowWord;
  2851.  
  2852.   R.ES := 0;
  2853.   R.DS := 0;
  2854.  
  2855.   Intr( $31, R );
  2856.  
  2857.   If (R.Flags AND FCarry <> 0) Then
  2858.   BEGIN
  2859.  
  2860.     VDPMIDiscardPageContents := R.AX;
  2861.  
  2862.   END
  2863.   Else
  2864.   BEGIN
  2865.  
  2866.     VDPMIDiscardPageContents := 0;
  2867.  
  2868.   END;
  2869.  
  2870. END;
  2871.  
  2872. {────────────────────────────────────────────────────────────────────────────}
  2873.  
  2874. Function  VDPMIMapPhysicalRegion(      PhysStart      : LONGINT;
  2875.                                        Size           : LONGINT;
  2876.                                    Var LinAddr        : LONGINT ) : TDPMIErr;
  2877.  
  2878. Var
  2879.  
  2880.   R : TREGISTERS;
  2881.  
  2882. BEGIN
  2883.  
  2884.   R.AX := $0800;
  2885.  
  2886.   R.BX := TCastDWord(PhysStart).HighWord;
  2887.   R.CX := TCastDWord(PhysStart).LowWord;
  2888.   R.SI := TCastDWord(Size).HighWord;
  2889.   R.DI := TCastDWord(Size).LowWord;
  2890.  
  2891.   R.ES := 0;
  2892.   R.DS := 0;
  2893.  
  2894.   Intr( $31, R );
  2895.  
  2896.   If (R.Flags AND FCarry <> 0) Then
  2897.   BEGIN
  2898.  
  2899.     VDPMIMapPhysicalRegion       := R.AX;
  2900.  
  2901.   END
  2902.   Else
  2903.   BEGIN
  2904.  
  2905.     TCastDWord(LinAddr).HighWord := R.BX;
  2906.     TCastDWord(LinAddr).LowWord  := R.CX;
  2907.     VDPMIMapPhysicalRegion       := 0;
  2908.  
  2909.   END;
  2910.  
  2911. END;
  2912.  
  2913. {────────────────────────────────────────────────────────────────────────────}
  2914.  
  2915. Function  VDPMIFreePhysicalRegion(     LinAddr        : LONGINT ) : TDPMIErr;
  2916.  
  2917. Var
  2918.  
  2919.   R : TREGISTERS;
  2920.  
  2921. BEGIN
  2922.  
  2923.   R.AX := $0801;
  2924.  
  2925.   R.BX := TCastDWord(LinAddr).HighWord;
  2926.   R.CX := TCastDWord(LinAddr).LowWord;
  2927.  
  2928.   R.ES := 0;
  2929.   R.DS := 0;
  2930.  
  2931.   Intr( $31, R );
  2932.  
  2933.   If (R.Flags AND FCarry <> 0) Then
  2934.   BEGIN
  2935.  
  2936.     VDPMIFreePhysicalRegion := R.AX;
  2937.  
  2938.   END
  2939.   Else
  2940.   BEGIN
  2941.  
  2942.     VDPMIFreePhysicalRegion := 0;
  2943.  
  2944.   END;
  2945.  
  2946. END;
  2947.  
  2948. {────────────────────────────────────────────────────────────────────────────}
  2949.  
  2950. Function  VDPMITestDisableInts(    Var PrevState      : BYTE    ) : TDPMIErr;
  2951.  
  2952. Var
  2953.  
  2954.   R : TREGISTERS;
  2955.  
  2956. BEGIN
  2957.  
  2958.   R.AX := $0900;
  2959.  
  2960.   R.ES := 0;
  2961.   R.DS := 0;
  2962.  
  2963.   Intr( $31, R );
  2964.  
  2965.   PrevState := R.AL;
  2966.  
  2967.   VDPMITestDisableInts := 0;
  2968.  
  2969. END;
  2970.  
  2971. {────────────────────────────────────────────────────────────────────────────}
  2972.  
  2973. Function  VDPMITestEnableInts(     Var PrevState      : BYTE    ) : TDPMIErr;
  2974.  
  2975. Var
  2976.  
  2977.   R : TREGISTERS;
  2978.  
  2979. BEGIN
  2980.  
  2981.   R.AX := $0901;
  2982.  
  2983.   R.ES := 0;
  2984.   R.DS := 0;
  2985.  
  2986.   Intr( $31, R );
  2987.  
  2988.   PrevState := R.AL;
  2989.  
  2990.   VDPMITestEnableInts := 0;
  2991.  
  2992. END;
  2993.  
  2994. {────────────────────────────────────────────────────────────────────────────}
  2995.  
  2996. Function  VDPMITestInts(           Var State          : BYTE    ) : TDPMIErr;
  2997.  
  2998. Var
  2999.  
  3000.   R : TREGISTERS;
  3001.  
  3002. BEGIN
  3003.  
  3004.   R.AX := $0902;
  3005.  
  3006.   R.ES := 0;
  3007.   R.DS := 0;
  3008.  
  3009.   Intr( $31, R );
  3010.  
  3011.   State := R.AL;
  3012.  
  3013.   VDPMITestInts := 0;
  3014.  
  3015. END;
  3016.  
  3017. {────────────────────────────────────────────────────────────────────────────}
  3018.  
  3019. Function  VDPMIGetVendorAPIEntry(      VendorName     : STRING;
  3020.                                    Var APIEntry       : POINTER ) : TDPMIErr;
  3021.  
  3022. Type
  3023.  
  3024.   TChar = Array[1..1] of CHAR;
  3025.   PChar = ^TChar;
  3026.  
  3027. Var
  3028.  
  3029.   R     : TREGISTERS;
  3030.   PStr1 : PChar;
  3031.  
  3032. BEGIN
  3033.  
  3034.   R.AX := $0A00;
  3035.  
  3036.   GetMem(PStr1, SizeOf(VendorName[0]));
  3037.  
  3038.   Move(VendorName[1], PStr1, Byte(VendorName[0]));
  3039.   PStr1^[Byte(VendorName[0])+1] := #0;           {!^! 0 or #0?}
  3040.  
  3041.   R.DS := TCastDWord(PStr1).HighWord;
  3042.   R.SI := TCastDWord(PStr1).LowWord;
  3043.  
  3044.   R.ES := 0;
  3045.  
  3046.   Intr( $31, R );
  3047.  
  3048.   If (R.Flags AND FCarry <> 0) Then
  3049.   BEGIN
  3050.  
  3051.     VDPMIGetVendorAPIEntry := R.AX;
  3052.  
  3053.   END
  3054.   Else
  3055.   BEGIN
  3056.  
  3057.     TCastDWord(APIEntry).HighWord := R.ES;
  3058.     TCastDWord(APIEntry).LowWord  := R.DI;
  3059.  
  3060.     VDPMIGetVendorAPIEntry := 0;
  3061.  
  3062.   END;
  3063.  
  3064.   FreeMem(PStr1, SizeOf(VendorName[0]));
  3065.  
  3066. END;
  3067.  
  3068. {────────────────────────────────────────────────────────────────────────────}
  3069.  
  3070. Function  VDPMISetDebugWatchp(         LinAddr        : LONGINT;
  3071.                                        WatchSize      : BYTE;
  3072.                                        WatchType      : BYTE;
  3073.                                    Var WatchHandle    : WORD    ) : TDPMIErr;
  3074.  
  3075. Var
  3076.  
  3077.   R : TREGISTERS;
  3078.  
  3079. BEGIN
  3080.  
  3081.   R.AX := $0B00;
  3082.  
  3083.   R.BX := TCastDWord(LinAddr).HighWord;
  3084.   R.CX := TCastDWord(LinAddr).LowWord;
  3085.   R.DL := WatchSize;
  3086.   R.DH := WatchType;
  3087.  
  3088.   R.ES := 0;
  3089.   R.DS := 0;
  3090.  
  3091.   Intr( $31, R );
  3092.  
  3093.   If (R.Flags AND FCarry <> 0) Then
  3094.   BEGIN
  3095.  
  3096.     VDPMISetDebugWatchp := R.AX;
  3097.  
  3098.   END
  3099.   Else
  3100.   BEGIN
  3101.  
  3102.     WatchHandle         := R.BX;
  3103.     VDPMISetDebugWatchp := 0;
  3104.  
  3105.   END;
  3106.  
  3107. END;
  3108.  
  3109. {────────────────────────────────────────────────────────────────────────────}
  3110.  
  3111. Function  VDPMIClearDebugWatchp(       WatchHandle    : WORD    ) : TDPMIErr;
  3112.  
  3113. Var
  3114.  
  3115.   R : TREGISTERS;
  3116.  
  3117. BEGIN
  3118.  
  3119.   R.AX := $0B01;
  3120.   R.BX := WatchHandle;
  3121.  
  3122.   R.ES := 0;
  3123.   R.DS := 0;
  3124.  
  3125.   Intr( $31, R );
  3126.  
  3127.   If (R.Flags AND FCarry <> 0) Then
  3128.   BEGIN
  3129.  
  3130.     VDPMIClearDebugWatchp := R.AX;
  3131.  
  3132.   END
  3133.   Else
  3134.   BEGIN
  3135.  
  3136.     VDPMIClearDebugWatchp := 0;
  3137.  
  3138.   END;
  3139.  
  3140. END;
  3141.  
  3142. {────────────────────────────────────────────────────────────────────────────}
  3143.  
  3144. Function  VDPMIGetDebugWatchpState(    WatchHandle    : WORD;
  3145.                                    Var WatchState     : WORD    ) : TDPMIErr;
  3146.  
  3147. Var
  3148.  
  3149.   R : TREGISTERS;
  3150.  
  3151. BEGIN
  3152.  
  3153.   R.AX := $0B02;
  3154.   R.BX := WatchHandle;
  3155.  
  3156.   R.ES := 0;
  3157.   R.DS := 0;
  3158.  
  3159.   Intr( $31, R );
  3160.  
  3161.   If (R.Flags AND FCarry <> 0) Then
  3162.   BEGIN
  3163.  
  3164.     VDPMIGetDebugWatchpState := R.AX;
  3165.  
  3166.   END
  3167.   Else
  3168.   BEGIN
  3169.  
  3170.     WatchState               := R.AX;
  3171.     VDPMIGetDebugWatchpState := 0;
  3172.  
  3173.   END;
  3174.  
  3175. END;
  3176.  
  3177. {────────────────────────────────────────────────────────────────────────────}
  3178.  
  3179. Function  VDPMIResetDebugWatchp(       WatchHandle    : WORD    ) : TDPMIErr;
  3180.  
  3181. Var
  3182.  
  3183.   R : TREGISTERS;
  3184.  
  3185. BEGIN
  3186.  
  3187.   R.AX := $0B03;
  3188.   R.BX := WatchHandle;
  3189.  
  3190.   R.ES := 0;
  3191.   R.DS := 0;
  3192.  
  3193.   Intr( $31, R );
  3194.  
  3195.   If (R.Flags AND FCarry <> 0) Then
  3196.   BEGIN
  3197.  
  3198.     VDPMIResetDebugWatchp := R.AX;
  3199.  
  3200.   END
  3201.   Else
  3202.   BEGIN
  3203.  
  3204.     VDPMIResetDebugWatchp := 0;
  3205.  
  3206.   END;
  3207.  
  3208. END;
  3209.  
  3210. {────────────────────────────────────────────────────────────────────────────}
  3211.  
  3212. Function  VDPMIInstallRSPCallback(     RSPBuff        : PRSPBuff) : TDPMIErr;
  3213.  
  3214. Var
  3215.  
  3216.   R : TREGISTERS;
  3217.  
  3218. BEGIN
  3219.  
  3220.   R.AX := $0C00;
  3221.  
  3222.   R.ES := TCastDWord(RSPBuff).HighWord;
  3223.   R.DI := TCastDWord(RSPBuff).LowWord;
  3224.  
  3225.   R.DS := 0;
  3226.  
  3227.   Intr( $31, R );
  3228.  
  3229.   If (R.Flags AND FCarry <> 0) Then
  3230.   BEGIN
  3231.  
  3232.     VDPMIInstallRSPCallback := R.AX;
  3233.  
  3234.   END
  3235.   Else
  3236.   BEGIN
  3237.  
  3238.     VDPMIInstallRSPCallback := 0;
  3239.  
  3240.   END;
  3241.  
  3242. END;
  3243.  
  3244. {────────────────────────────────────────────────────────────────────────────}
  3245.  
  3246. Function  VDPMITermAndStayResident(    RetCode        : BYTE;
  3247.                                        DosParasToKeep : WORD    ) : TDPMIErr;
  3248.  
  3249. Var
  3250.  
  3251.   R : TREGISTERS;
  3252.  
  3253. BEGIN
  3254.  
  3255.   R.AX := $0C01;
  3256.  
  3257.   R.BL := RetCode;
  3258.   R.DX := DosParasToKeep;
  3259.  
  3260.   R.ES := 0;
  3261.   R.DS := 0;
  3262.  
  3263.   Intr( $31, R );
  3264.  
  3265.   VDPMITermAndStayResident := 0;
  3266.  
  3267. END;
  3268.  
  3269. {────────────────────────────────────────────────────────────────────────────}
  3270.  
  3271. Function  VDPMIAllocSharedMemory(      MemReqStruct   : PMemReqStruct ) : TDPMIErr;
  3272.  
  3273. Var
  3274.  
  3275.   R : TREGISTERS;
  3276.  
  3277. BEGIN
  3278.  
  3279.   R.AX := $0D00;
  3280.  
  3281.   R.ES := TCastDWord(MemReqStruct).HighWord;
  3282.   R.DI := TCastDWord(MemReqStruct).LowWord;
  3283.  
  3284.   R.DS := 0;
  3285.  
  3286.   Intr( $31, R );
  3287.  
  3288.   If (R.Flags AND FCarry <> 0) Then
  3289.   BEGIN
  3290.  
  3291.     VDPMIAllocSharedMemory := R.AX;
  3292.  
  3293.   END
  3294.   Else
  3295.   BEGIN
  3296.  
  3297.     VDPMIAllocSharedMemory := 0;
  3298.  
  3299.   END;
  3300.  
  3301. END;
  3302.  
  3303. {────────────────────────────────────────────────────────────────────────────}
  3304.  
  3305. Function  VDPMIFreeSharedMemory(       SMemHandle     : LONGINT ) : TDPMIErr;
  3306.  
  3307. Var
  3308.  
  3309.   R : TREGISTERS;
  3310.  
  3311. BEGIN
  3312.  
  3313.   R.AX := $0D01;
  3314.  
  3315.   R.SI := TCastDWord(SMemHandle).HighWord;
  3316.   R.DI := TCastDWord(SMemHandle).LowWord;
  3317.  
  3318.   R.ES := 0;
  3319.   R.DS := 0;
  3320.  
  3321.   Intr( $31, R );
  3322.  
  3323.   If (R.Flags AND FCarry <> 0) Then
  3324.   BEGIN
  3325.  
  3326.     VDPMIFreeSharedMemory := R.AX;
  3327.  
  3328.   END
  3329.   Else
  3330.   BEGIN
  3331.  
  3332.     VDPMIFreeSharedMemory := 0;
  3333.  
  3334.   END;
  3335.  
  3336. END;
  3337.  
  3338. {────────────────────────────────────────────────────────────────────────────}
  3339.  
  3340. Function  VDPMISerOnSharedMem(         SMemHandle     : LONGINT;
  3341.                                        Flags          : WORD    ) : TDPMIErr;
  3342.  
  3343. Var
  3344.  
  3345.   R : TREGISTERS;
  3346.  
  3347. BEGIN
  3348.  
  3349.   R.AX := $0D02;
  3350.  
  3351.   R.SI := TCastDWord(SMemHandle).HighWord;
  3352.   R.DI := TCastDWord(SMemHandle).LowWord;
  3353.   R.DX := Flags;
  3354.  
  3355.   R.ES := 0;
  3356.   R.DS := 0;
  3357.  
  3358.   Intr( $31, R );
  3359.  
  3360.   If (R.Flags AND FCarry <> 0) Then
  3361.   BEGIN
  3362.  
  3363.     VDPMISerOnSharedMem := R.AX;
  3364.  
  3365.   END
  3366.   Else
  3367.   BEGIN
  3368.  
  3369.     VDPMISerOnSharedMem := 0;
  3370.  
  3371.   END;
  3372.  
  3373. END;
  3374.  
  3375. {────────────────────────────────────────────────────────────────────────────}
  3376.  
  3377. Function  VDPMIFreeSerOnSharedMem(     SMemHandle     : LONGINT;
  3378.                                        Flags          : WORD    ) : TDPMIErr;
  3379.  
  3380. Var
  3381.  
  3382.   R : TREGISTERS;
  3383.  
  3384. BEGIN
  3385.  
  3386.   R.AX := $0D03;
  3387.  
  3388.   R.SI := TCastDWord(SMemHandle).HighWord;
  3389.   R.DI := TCastDWord(SMemHandle).LowWord;
  3390.   R.DX := Flags;
  3391.  
  3392.   R.ES := 0;
  3393.   R.DS := 0;
  3394.  
  3395.   Intr( $31, R );
  3396.  
  3397.   If (R.Flags AND FCarry <> 0) Then
  3398.   BEGIN
  3399.  
  3400.     VDPMIFreeSerOnSharedMem := R.AX;
  3401.  
  3402.   END
  3403.   Else
  3404.   BEGIN
  3405.  
  3406.     VDPMIFreeSerOnSharedMem := 0;
  3407.  
  3408.   END;
  3409.  
  3410. END;
  3411.  
  3412. {────────────────────────────────────────────────────────────────────────────}
  3413.  
  3414. Function  VDPMIGetCoprocStatus                                    : WORD;
  3415.  
  3416. Var
  3417.  
  3418.   R : TREGISTERS;
  3419.  
  3420. BEGIN
  3421.  
  3422.   R.AX := $0E00;
  3423.  
  3424.   R.ES := 0;
  3425.   R.DS := 0;
  3426.  
  3427.   Intr( $31, R );
  3428.  
  3429.   VDPMIGetCoprocStatus := R.AX;
  3430.  
  3431. END;
  3432.  
  3433. {────────────────────────────────────────────────────────────────────────────}
  3434.  
  3435. Function  VDPMISetCoProcEmulation(     EmuFlags       : WORD    ) : TDPMIErr;
  3436.  
  3437. Var
  3438.  
  3439.   R : TREGISTERS;
  3440.  
  3441. BEGIN
  3442.  
  3443.   R.AX := $0E01;
  3444.   R.BX := EmuFlags;
  3445.  
  3446.   R.ES := 0;
  3447.   R.DS := 0;
  3448.  
  3449.   Intr( $31, R );
  3450.  
  3451.   If (R.Flags AND FCarry <> 0) Then
  3452.   BEGIN
  3453.  
  3454.     VDPMISetCoProcEmulation := R.AX;
  3455.  
  3456.   END
  3457.   Else
  3458.   BEGIN
  3459.  
  3460.     VDPMISetCoProcEmulation := 0;
  3461.  
  3462.   END;
  3463.  
  3464. END;
  3465.  
  3466. {────────────────────────────────────────────────────────────────────────────}
  3467.  
  3468. Function  RealIntr(                    IntNum         : BYTE;
  3469.                                        R              : TREGISTERS ):WORD;
  3470.  
  3471. Var
  3472.  
  3473.   RR : TDPMIRealRegs;
  3474.  
  3475. BEGIN
  3476.  
  3477.   RR.EDI   := R.DI;
  3478.   RR.ESI   := R.SI;
  3479.   RR.EBP   := R.BP;
  3480.   RR.EBX   := R.BX;
  3481.   RR.EDX   := R.DX;
  3482.   RR.ECX   := R.CX;
  3483.   RR.EAX   := R.AX;
  3484.   RR.Flags := R.Flags;
  3485.   RR.ES    := R.ES;
  3486.   RR.DS    := R.DS;
  3487.   RR.FS    := 0;
  3488.   RR.GS    := 0;
  3489.  
  3490.   RR.SS    := 0;
  3491.   RR.SP    := 0;
  3492.  
  3493.  
  3494.   VDPMISimRealIntr( IntNum, 0, 0, @RR );
  3495.  
  3496.  
  3497.   R.DI     := Word( RR.EDI );
  3498.   R.SI     := Word( RR.ESI );
  3499.   R.BP     := Word( RR.EBP );
  3500.   R.BX     := Word( RR.EBX );
  3501.   R.DX     := Word( RR.EDX );
  3502.   R.CX     := Word( RR.ECX );
  3503.   R.AX     := Word( RR.EAX );
  3504.   R.Flags  := RR.Flags;
  3505.   R.ES     := RR.ES;
  3506.   R.DS     := RR.DS;
  3507.  
  3508.  
  3509. END;
  3510.  
  3511. {────────────────────────────────────────────────────────────────────────────}
  3512.  
  3513. Procedure RefBuffCopyUp(               BuffPtr        : POINTER;
  3514.                                        RBProt         : POINTER;
  3515.                                        BuffSize       : LONGINT   );
  3516.  
  3517. BEGIN
  3518.  
  3519.   Move( RBProt^, BuffPtr^, BuffSize );
  3520.  
  3521. END;
  3522.  
  3523. {────────────────────────────────────────────────────────────────────────────}
  3524.  
  3525. Procedure RefBuffCopyDown(             BuffPtr        : POINTER;
  3526.                                        RBProt         : POINTER;
  3527.                                        BuffSize       : LONGINT   );
  3528.  
  3529.  
  3530. BEGIN
  3531.  
  3532.   Move( BuffPtr^, RBProt^, BuffSize );
  3533.  
  3534. END;
  3535.  
  3536. {────────────────────────────────────────────────────────────────────────────}
  3537.  
  3538.  
  3539. Function  RefBuffNew(                  Flags          : WORD;
  3540.                                        BuffPtr        : POINTER;
  3541.                                        BuffSize       : LONGINT;
  3542.                                    Var RBReal         : POINTER;
  3543.                                    Var RBProt         : POINTER    ) : WORD;
  3544.  
  3545.  
  3546.  
  3547.  
  3548. Var
  3549.  
  3550.   Err        : WORD;
  3551.   RBRealSeg  : WORD;
  3552.   RBProtSel  : WORD;
  3553.  
  3554. BEGIN
  3555.  
  3556.   {----------------------------}
  3557.   { Allocate reflection buffer }
  3558.   {----------------------------}
  3559.  
  3560.   Err := VDPMIAllocDOSMemory  ( ( BuffSize Div 16)+1,
  3561.                                 RBRealSeg,
  3562.                                 RBProtSel               );
  3563.  
  3564.   If Err=0 Then
  3565.   BEGIN
  3566.  
  3567.  
  3568.     RBProt := Ptr( RBProtSel, 0 );
  3569.  
  3570.     RBReal := Ptr( RBRealSeg, 0 );
  3571.  
  3572.     {--------------------------------}
  3573.     { if copy "down" then move bytes }
  3574.     { to reflection buff             }
  3575.     {--------------------------------}
  3576.  
  3577.     If (Flags and rb_down)<>0 Then
  3578.     BEGIN
  3579.  
  3580.       Move( BuffPtr^,
  3581.             RBProt^,
  3582.             BuffSize            );
  3583.  
  3584.     END;
  3585.  
  3586.   END   { if err=0 (alloc ref buff) }
  3587.   ELSE
  3588.   BEGIN
  3589.  
  3590.   END; { if err=0 (alloc ref buff) }
  3591.  
  3592.   RefBuffNew := Err;
  3593.  
  3594. END;
  3595.  
  3596. {────────────────────────────────────────────────────────────────────────────}
  3597.  
  3598. Procedure RefBuffDispose(              RBProt         : POINTER    );
  3599.  
  3600.  
  3601. Var
  3602.  
  3603.   Err : WORD;
  3604.  
  3605. BEGIN
  3606.  
  3607.   Err := VDPMIFreeDosMemory( TCastDWord( RBProt ).HighWord );
  3608.  
  3609. END;
  3610.  
  3611.  
  3612. {────────────────────────────────────────────────────────────────────────────}
  3613.  
  3614. Function  RefBuffIntr(                 Flags          : WORD;
  3615.                                        IntNum         : BYTE;
  3616.                                        R              : TREGISTERS;
  3617.                                        BuffPtr        : POINTER;
  3618.                                        BuffSize       : LONGINT ) : TDPMIErr;
  3619.  
  3620. {---------------------------------------------------------------------------
  3621.   $0001  rb_ESBX    ES:BX points to buff
  3622.   $0002  rb_ESSI    ES:SI points to buff
  3623.   $0003  rb_ESDI    ES:DI points to buff
  3624.  
  3625.   $0004  rb_DSBX    DS:BX points to buff
  3626.   $0005  rb_DSSI    DS:SI points to buff
  3627.   $0006  rb_DSDI    DS:DI points to buff
  3628.  
  3629.   $0100  rb_down    Copy the reflected buffer down to real mode
  3630.   $0200  rb_up      Copy the reflected buffer up from real mode
  3631.   $0300  rb_downup  Copy the reflected buffer down to real mode and back up
  3632.   $0300  rb_updown  Copy the reflected buffer down to real mode and back up
  3633. ----------------------------------------------------------------------------}
  3634.  
  3635. Var
  3636.  
  3637.   Err        : WORD;
  3638.   RBRealSeg  : WORD;
  3639.   RBProtSel  : WORD;
  3640.  
  3641.   RBProt     : POINTER;
  3642.   RBReal     : POINTER;
  3643.  
  3644. BEGIN
  3645.  
  3646. {$IFNDEF DPMI}
  3647.  
  3648.   Intr( IntNum, R );
  3649.  
  3650. {$ELSE}
  3651.  
  3652.   {----------------------------}
  3653.   { Allocate reflection buffer }
  3654.   { and do the copy down       }
  3655.   {----------------------------}
  3656.  
  3657.   Err := RefBuffNew( Flags,
  3658.                      BuffPtr,
  3659.                      BuffSize,
  3660.                      RBReal,
  3661.                      RBProt       );
  3662.  
  3663.   If Err=0 Then
  3664.   BEGIN
  3665.  
  3666.     RBRealSeg := TCastDWord( RBReal ).HighWord;
  3667.  
  3668.     {-------------------------------}
  3669.     { modify TREGISTERS to point to }
  3670.     { reflecion buffer              }
  3671.     {-------------------------------}
  3672.  
  3673.     Case (Flags and $00FF) Of
  3674.  
  3675.       rb_ESAX : BEGIN R.ES := RBRealSeg;  R.AX := 0; END;
  3676.       rb_ESBX : BEGIN R.ES := RBRealSeg;  R.BX := 0; END;
  3677.       rb_ESCX : BEGIN R.ES := RBRealSeg;  R.CX := 0; END;
  3678.       rb_ESDX : BEGIN R.ES := RBRealSeg;  R.DX := 0; END;
  3679.       rb_ESSI : BEGIN R.ES := RBRealSeg;  R.SI := 0; END;
  3680.       rb_ESDI : BEGIN R.ES := RBRealSeg;  R.DI := 0; END;
  3681.       rb_ESBP : BEGIN R.ES := RBRealSeg;  R.BP := 0; END;
  3682.  
  3683.       rb_DSAX : BEGIN R.DS := RBRealSeg;  R.AX := 0; END;
  3684.       rb_DSBX : BEGIN R.DS := RBRealSeg;  R.BX := 0; END;
  3685.       rb_DSCX : BEGIN R.DS := RBRealSeg;  R.CX := 0; END;
  3686.       rb_DSDX : BEGIN R.DS := RBRealSeg;  R.DX := 0; END;
  3687.       rb_DSSI : BEGIN R.DS := RBRealSeg;  R.SI := 0; END;
  3688.       rb_DSDI : BEGIN R.DS := RBRealSeg;  R.DI := 0; END;
  3689.       rb_DSBP : BEGIN R.DS := RBRealSeg;  R.BP := 0; END;
  3690.  
  3691.     END;
  3692.  
  3693.     {-------------------}
  3694.     { perform interrupt }
  3695.     {-------------------}
  3696.  
  3697.     RealIntr( IntNum, R );
  3698.  
  3699.     {--------------------------------}
  3700.     { if copy "up" then move bytes   }
  3701.     { from reflection buff           }
  3702.     {--------------------------------}
  3703.  
  3704.     If (Flags and rb_up)<>0 Then
  3705.     BEGIN
  3706.  
  3707.       RefBuffCopyUp( BuffPtr,
  3708.                      RBProt,
  3709.                      BuffSize       );
  3710.  
  3711.     END;
  3712.  
  3713.     {------------------------}
  3714.     { free reflection buffer }
  3715.     {------------------------}
  3716.  
  3717.     RefBuffDispose( RBProt );
  3718.  
  3719.   END   { if err=0 (alloc ref buff) }
  3720.   ELSE
  3721.   BEGIN
  3722.  
  3723.  
  3724.   END; { if err=0 (alloc ref buff) }
  3725.  
  3726.  
  3727. {$endif} {if DPMI / ELSE }
  3728.  
  3729. END;
  3730.  
  3731. {────────────────────────────────────────────────────────────────────────────}
  3732.  
  3733. (*
  3734. Function VDPMIPermReflectBuffNew( Size           : LONGINT ) : WORD;
  3735.  
  3736. Var
  3737.  
  3738.   ERR       : WORD;
  3739.   RBRealSeg : WORD;
  3740.   RBProtSel : WORD;
  3741.  
  3742. BEGIN
  3743.  
  3744.   {---------------------------------------------------}
  3745.   { if the buffer is already allocated, dispose of it }
  3746.   {---------------------------------------------------}
  3747.  
  3748.   If PermReflectBuff.Allocated Then
  3749.     Err := VDPMIPermReflectBuffDispose;
  3750.  
  3751.  
  3752.   {--------------------------------}
  3753.   { get the DOS (below 1mb) memory }
  3754.   {--------------------------------}
  3755.  
  3756.   Err := VDPMIAllocDosMemBlock( (Size Div 16)+1,
  3757.                                 RBRealSeg,
  3758.                                 RBProtSel               );
  3759.  
  3760.   IF Err=0 Then
  3761.   BEGIN
  3762.  
  3763.     With PermReflectBuff Do
  3764.     BEGIN
  3765.  
  3766.  
  3767.       {---------------------------------------}
  3768.       { while interrupts are off, fill in the }
  3769.       { PermReflectBuff structure             }
  3770.       {---------------------------------------}
  3771.  
  3772.       ASM CLI END;
  3773.  
  3774.       Allocated := TRUE;
  3775.       InUse     := FALSE;
  3776.       RealPtr   := Ptr( RBRealSeg, 0 );
  3777.       ProtPtr   := Ptr( RBProtSel, 0 );
  3778.       BuffSize  := Size;
  3779.  
  3780.  
  3781.       ASM STI END;
  3782.  
  3783.     END; { with }
  3784.  
  3785.   END; { If err=0 }
  3786.  
  3787.   VDPMIPermReflectBuffNew := Err;
  3788.  
  3789. END;
  3790.  
  3791. {────────────────────────────────────────────────────────────────────────────}
  3792.  
  3793. Function VDPMIPermReflectBuffDispose : WORD;
  3794.  
  3795. BEGIN
  3796.  
  3797.   Err := 0;
  3798.  
  3799.   With PermReflectBuff Do
  3800.   BEGIN
  3801.  
  3802.     {------------------------------}
  3803.     { has a buffer been allocated? }
  3804.     {------------------------------}
  3805.  
  3806.     If Allocated = TRUE Then
  3807.     BEGIN
  3808.  
  3809.       {---------------------------------}
  3810.       { make sure some async  procedure }
  3811.       { isnt using the buffer           }
  3812.       {---------------------------------}
  3813.  
  3814.       Repeat Until InUse=FALSE;
  3815.  
  3816.       ASM CLI END;
  3817.  
  3818.       Allocated := FALSE;
  3819.  
  3820.       ASM STI END;
  3821.  
  3822.       Err := VDPMIFreeDosMemBlock( Seg( ProtPtr^ ) );
  3823.  
  3824.     END;
  3825.  
  3826.   END;
  3827.  
  3828.   VDPMIPermReflectBuffDispose := Err;
  3829.  
  3830. END;
  3831.  
  3832. *)
  3833.  
  3834.  
  3835. {────────────────────────────────────────────────────────────────────────────}
  3836. {────────────────────────────────────────────────────────────────────────────}
  3837. {────────────────────────────────────────────────────────────────────────────}
  3838.  
  3839. BEGIN
  3840.  
  3841.   PermReflectBuff.Allocated := FALSE;
  3842.  
  3843. END.
  3844.