home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / gnat-2.06-src.tgz / tar.out / fsf / gnat / ada / s-os2thr.ads < prev    next >
Text File  |  1996-09-28  |  7KB  |  165 lines

  1. ------------------------------------------------------------------------------
  2. --                                                                          --
  3. --                 GNU ADA RUNTIME LIBRARY (GNARL) COMPONENTS               --
  4. --                                                                          --
  5. --                 S Y S T E M . O S 2 L I B . T H R E A D S                --
  6. --                                                                          --
  7. --                                  S p e c                                 --
  8. --                                                                          --
  9. --                             $Revision: 1.6 $                             --
  10. --                                                                          --
  11. --          Copyright (c) 1993,1994,1995 NYU, All Rights Reserved           --
  12. --                                                                          --
  13. --  GNARL is free software; you can redistribute it and/or modify it  under --
  14. --  terms  of  the  GNU  Library General Public License as published by the --
  15. --  Free Software Foundation; either version 2,  or (at  your  option)  any --
  16. --  later  version.   GNARL is distributed in the hope that it will be use- --
  17. --  ful, but but WITHOUT ANY WARRANTY; without even the implied warranty of --
  18. --  MERCHANTABILITY  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Gen- --
  19. --  eral Library Public License for more details.  You should have received --
  20. --  a  copy of the GNU Library General Public License along with GNARL; see --
  21. --  file COPYING. If not, write to the Free Software Foundation,  675  Mass --
  22. --  Ave, Cambridge, MA 02139, USA.                                          --
  23. --                                                                          --
  24. ------------------------------------------------------------------------------
  25.  
  26. with Interfaces.C;
  27.  
  28. package System.OS2Lib.Threads is
  29. pragma Preelaborate (Threads);
  30.  
  31.    use Interfaces.C;
  32.  
  33.    type PID is new unsigned_long;
  34.    type PPID is access all PID;
  35.    --  Process ID, and pointer to process ID
  36.  
  37.    type TID is new unsigned_long;
  38.    type PTID is access all TID;
  39.    --  Thread ID, and pointer to thread ID
  40.  
  41.    -------------------------------------------------------------
  42.    -- Thread Creation, Activation, Suspension And Termination --
  43.    -------------------------------------------------------------
  44.  
  45.    --  Note: <bsedos.h> defines the "Informations" and "param" parameter below
  46.    --  as a ULONG, but everyone knows that in general an address will be passed
  47.    --  to it. We declared it here with type PVOID (which it should have had)
  48.    --  because Ada is a bit more sensitive to mixing integers and addresses.
  49.  
  50.    type PFNTHREAD is access procedure (Informations : System.Address);
  51.    --  TBSL should use PVOID instead of Address as per above node ???
  52.  
  53.    function DosCreateThread
  54.      (F_ptid  : PTID;
  55.       pfn     : PFNTHREAD;
  56.       param   : PVOID;
  57.       flag    : ULONG;
  58.       cbStack : ULONG)
  59.       return    APIRET;
  60.    pragma Import (C, DosCreateThread, "DosCreateThread");
  61.  
  62.    Block_child     : constant := 1;
  63.    No_Block_child  : constant := 0;
  64.    Commit_stack    : constant := 2;
  65.    No_Commit_stack : constant := 0;
  66.    --  Values for "flag" parameter in DosCreateThread call
  67.  
  68.    procedure DosExit (Action : ULONG; Result : ULONG);
  69.    pragma Import (C, DosExit, "DosExit");
  70.  
  71.    EXIT_THREAD  : constant := 0;
  72.    EXIT_PROCESS : constant := 1;
  73.    --  Values for "Action" parameter in Dos_Exit call
  74.  
  75.    function DosResumeThread (Id : TID) return APIRET;
  76.    pragma Import (C, DosResumeThread, "DosResumeThread");
  77.  
  78.    function DosSuspendThread (Id : TID) return APIRET;
  79.    pragma Import (C, DosSuspendThread, "DosSuspendThread");
  80.  
  81.    procedure DosWaitThread (Thread_Ptr : PTID; Option : ULONG);
  82.    pragma Import (C, DosWaitThread, "DosWaitThread");
  83.  
  84.    DCWW_WAIT   : constant := 0;
  85.    DCWW_NOWAIT : constant := 1;
  86.    --  Values for "Option" parameter in DosWaitThread call
  87.  
  88.    ---------------------------------------------------
  89.    -- Accessing properties of Threads and Processes --
  90.    ---------------------------------------------------
  91.  
  92.    --  Structures translated from BSETIB.H
  93.  
  94.    --  Thread Information Block (TIB)
  95.    --  Need documentation clarifying distinction between TIB, TIB2 ???
  96.  
  97.    type TIB2 is record
  98.       tib2_ultid        : ULONG;  -- Thread I.D.
  99.       tib2_ulpri        : ULONG;  -- Thread priority
  100.       tib2_version      : ULONG;  -- Version number for this structure
  101.       tib2_usMCCount    : USHORT; -- Must Complete count
  102.       tib2_fMCForceFlag : USHORT; -- Must Complete force flag
  103.    end record;
  104.  
  105.    type PTIB2 is access all TIB2;
  106.  
  107.    --  Thread Information Block (TIB)
  108.  
  109.    type TIB is record
  110.       tib_pexchain      : PVOID;  -- Head of exception handler chain
  111.       tib_pstack        : PVOID;  -- Pointer to base of stack
  112.       tib_pstacklimit   : PVOID;  -- Pointer to end of stack
  113.       tib_ptib2         : PTIB2;  -- Pointer to system specific TIB
  114.       tib_version       : ULONG;  -- Version number for this TIB structure
  115.       tib_ordinal       : ULONG;  -- Thread ordinal number
  116.    end record;
  117.  
  118.    type PTIB is access all TIB;
  119.  
  120.    --  Process Information Block (PIB)
  121.  
  122.    type PIB is record
  123.       pib_ulpid         : ULONG;   -- Process I.D.
  124.       pib_ulppid        : ULONG;   -- Parent process I.D.
  125.       pib_hmte          : ULONG;   -- Program (.EXE) module handle
  126.       pib_pchcmd        : PCHAR;   -- Command line pointer
  127.       pib_pchenv        : PCHAR;   -- Environment pointer
  128.       pib_flstatus      : ULONG;   -- Process' status bits
  129.       pib_ultype        : ULONG;   -- Process' type code
  130.    end record;
  131.  
  132.    type PPIB is access all PIB;
  133.  
  134.    function DosGetInfoBlocks
  135.      (Pptib : access PTIB;
  136.       Pppib : access PPIB)
  137.       return  APIRET;
  138.    pragma Import (C, DosGetInfoBlocks, "DosGetInfoBlocks");
  139.  
  140.    -----------------
  141.    --  Priorities --
  142.    -----------------
  143.  
  144.    function DosSetPriority
  145.      (Scope   : ULONG;
  146.       Class   : ULONG;
  147.       Delta_P : long;
  148.       PorTid  : TID)
  149.       return    APIRET;
  150.    pragma Import (C, DosSetPriority, "DosSetPriority");
  151.  
  152.    PRTYS_PROCESS     : constant := 0;
  153.    PRTYS_PROCESSTREE : constant := 1;
  154.    PRTYS_THREAD      : constant := 2;
  155.    --  Values for "Scope" parameter in DosSetPriority call
  156.  
  157.    PRTYC_NOCHANGE         : constant := 0;
  158.    PRTYC_IDLETIME         : constant := 1;
  159.    PRTYC_REGULAR          : constant := 2;
  160.    PRTYC_TIMECRITICAL     : constant := 3;
  161.    PRTYC_FOREGROUNDSERVER : constant := 4;
  162.    --  Values for "class" parameter in DosSetPriority call
  163.  
  164. end System.OS2Lib.Threads;
  165.