| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 | {    $Id$    This file is part of the Free Pascal simulator environment    Copyright (c) 1999-2000 by Florian Klaempfl    This unit implemements some helper routines    See the file COPYING.FPC, included in this distribution,    for details about the copyright.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. **********************************************************************}{$N+}unit simbase;  interface    uses       dos;    { global types }    type       { tindex must be at least of type integer }       tindex = integer;       int64 = comp;       qword = comp;       dword = longint;       tdword = array[0..3] of byte;       pbyte = ^byte;       pword = ^word;       pdword = ^dword;       pqword = ^qword;       tqwordrec = record          case tindex of             1 : (low32,high32 : dword);             2 : (bytes : array[0..7] of byte);             3 : (words : array[0..3] of word);       end;       oword = array[0..7] of word;       towordrec = record          case tindex of             1 : (bytes : array[0..15] of byte);             2 : (words : array[0..7] of word);             3 : (low64,high64 : qword);       end;    function hexstr(val : longint;cnt : byte) : string;    function qword2str(q : qword) : string;    function realtime : double;    var       stopsim : procedure;  implementation    function hexstr(val : longint;cnt : byte) : string;       const          HexTbl : array[0..15] of char='0123456789ABCDEF';       var         i : tindex;       begin          hexstr[0]:=char(cnt);          for i:=cnt downto 1 do            begin               hexstr[i]:=hextbl[val and $f];               val:=val shr 4;            end;       end;    function qword2str(q : qword) : string;      begin         qword2str:=hexstr(tqwordrec(q).high32,8)+hexstr(tqwordrec(q).low32,8);      end;    function realtime : double;      var         h,m,s,s100 : word;      begin         gettime(h,m,s,s100);         realtime:=h*3600+m*60+s+s100/100.0;      end;    procedure _stopsim;{$ifdef TP}far;{$endif TP}      begin         writeln('Simulation stopped');         halt(1);      end;begin   {$ifdef FPC}   stopsim:=@_stopsim;   {$else FPC}   stopsim:=_stopsim;   {$endif FPC}end.{  $Log$  Revision 1.2  2000-01-07 16:46:07  daniel    * copyright 2000  Revision 1.1  1999/06/14 11:49:48  florian    + initial revision, it runs simple Alpha Linux ELF executables       - integer operations are nearly completed (non with overflow checking)       - floating point operations aren't implemented (except loading and         storing)       - only the really necessary system calls are implemented by dummys         write syscalls are redirected to the console}
 |