| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 | {    Copyright (c) 1998-2002 by Florian Klaempfl    Helper routines for register allocator    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    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.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ****************************************************************************}unit rgbase;{$i fpcdefs.inc}interface    uses      cpuBase,cgBase;    type      TRegNameTable = array[tregisterindex] of string[19];      TRegisterIndexTable = array[tregisterindex] of tregisterindex;    function findreg_by_number_table(r:Tregister;const regnumber_index:TRegisterIndexTable):tregisterindex;    function findreg_by_name_table(const s:string;const regname_table:TRegNameTable;const regname_index:TRegisterIndexTable):tregisterindex;implementation    function findreg_by_name_table(const s:string;const regname_table:TRegNameTable;const regname_index:TRegisterIndexTable):tregisterindex;      var        i,p,q : tregisterindex;      begin        p:=Low(tregisterindex);        q:=high(tregisterindex);        repeat          i:=(p+q) shr 1;          if s>regname_table[regname_index[i]] then            p:=i+1          else            q:=i;        until p=q;        if regname_table[regname_index[p]]=s then          result:=regname_index[p]        else          result:=0;      end;    function findreg_by_number_table(r:Tregister;const regnumber_index:TRegisterIndexTable):tregisterindex;      var        i,p,q : longint;      begin        p:=Low(tregisterindex);        q:=high(tregisterindex);        repeat          i:=(p+q) shr 1;          if r>regnumber_table[regnumber_index[i]] then            p:=i+1          else            q:=i;        until p=q;        if regnumber_table[regnumber_index[p]]=r then          result:=regnumber_index[p]        else          result:=0;      end;end.
 |