| ------------------------------------------------------------------------------ |
| -- -- |
| -- GNU ADA RUN-TIME LIBRARY (GNARL) COMPONENTS -- |
| -- -- |
| -- S Y S T E M . O S _ I N T E R F A C E -- |
| -- -- |
| -- B o d y -- |
| -- -- |
| -- Copyright (C) 1991-1994, Florida State University -- |
| -- Copyright (C) 1995-2003, Ada Core Technologies -- |
| -- -- |
| -- GNARL is free software; you can redistribute it and/or modify it under -- |
| -- terms of the GNU General Public License as published by the Free Soft- -- |
| -- ware Foundation; either version 2, or (at your option) any later ver- -- |
| -- sion. GNARL is distributed in the hope that it will be useful, but WITH- -- |
| -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY -- |
| -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -- |
| -- for more details. You should have received a copy of the GNU General -- |
| -- Public License distributed with GNARL; see file COPYING. If not, write -- |
| -- to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, -- |
| -- MA 02111-1307, USA. -- |
| -- -- |
| -- As a special exception, if other files instantiate generics from this -- |
| -- unit, or you link this unit with other files to produce an executable, -- |
| -- this unit does not by itself cause the resulting executable to be -- |
| -- covered by the GNU General Public License. This exception does not -- |
| -- however invalidate any other reasons why the executable file might be -- |
| -- covered by the GNU Public License. -- |
| -- -- |
| -- GNARL was developed by the GNARL team at Florida State University. -- |
| -- Extensive contributions were provided by Ada Core Technologies, Inc. -- |
| -- -- |
| ------------------------------------------------------------------------------ |
| |
| -- This is the OS/2 version of this package |
| |
| pragma Polling (Off); |
| -- Turn off polling, we do not want ATC polling to take place during |
| -- tasking operations. It causes infinite loops and other problems. |
| |
| with Interfaces.OS2Lib.Errors; |
| with Interfaces.OS2Lib.Synchronization; |
| |
| package body System.OS_Interface is |
| |
| use Interfaces; |
| use Interfaces.OS2Lib; |
| use Interfaces.OS2Lib.Synchronization; |
| use Interfaces.OS2Lib.Errors; |
| |
| ----------- |
| -- Yield -- |
| ----------- |
| |
| -- Give up the remainder of the time-slice and yield the processor |
| -- to other threads of equal priority. Yield will return immediately |
| -- without giving up the current time-slice when the only threads |
| -- that are ready have a lower priority. |
| |
| -- ??? Just giving up the current time-slice seems not to be enough |
| -- to get the thread to the end of the ready queue if OS/2 does use |
| -- a queue at all. As a partial work-around, we give up two time-slices. |
| |
| -- This is the best we can do now, and at least is sufficient for passing |
| -- the ACVC 2.0.1 Annex D tests. |
| |
| procedure Yield is |
| begin |
| Delay_For (0); |
| Delay_For (0); |
| end Yield; |
| |
| --------------- |
| -- Delay_For -- |
| --------------- |
| |
| procedure Delay_For (Period : in Duration_In_Millisec) is |
| Result : APIRET; |
| |
| begin |
| pragma Assert (Period >= 0, "GNULLI---Delay_For: negative argument"); |
| |
| -- ??? DosSleep is not the appropriate function for a delay in real |
| -- time. It only gives up some number of scheduled time-slices. |
| -- Use a timer instead or block for some semaphore with a time-out. |
| Result := DosSleep (ULONG (Period)); |
| |
| if Result = ERROR_TS_WAKEUP then |
| |
| -- Do appropriate processing for interrupted sleep |
| -- Can we raise an exception here? |
| |
| null; |
| end if; |
| |
| pragma Assert (Result = NO_ERROR, "GNULLI---Error in Delay_For"); |
| end Delay_For; |
| |
| ----------- |
| -- Clock -- |
| ----------- |
| |
| function Clock return Duration is |
| |
| -- Implement conversion from tick count to Duration |
| -- using fixed point arithmetic. The frequency of |
| -- the Intel 8254 timer chip is 18.2 * 2**16 Hz. |
| |
| Tick_Duration : constant := 1.0 / (18.2 * 2**16); |
| Tick_Count : aliased QWORD; |
| |
| begin |
| -- Read nr of clock ticks since boot time |
| |
| Must_Not_Fail (DosTmrQueryTime (Tick_Count'Access)); |
| |
| return Tick_Count * Tick_Duration; |
| end Clock; |
| |
| end System.OS_Interface; |