| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 | {    Copyright (c) 1998-2002 by Florian Klaempfl    Generate i386 assembler for constants    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 n386con;{$i fpcdefs.inc}interface    uses       node,ncon,ncgcon;    type       ti386realconstnode = class(tcgrealconstnode)          function pass_1 : tnode;override;          procedure pass_2;override;       end;implementation    uses      systems,globals,      defutil,      cpubase,      cga,cgx86,cgobj,cgbase,cgutils;{*****************************************************************************                           TI386REALCONSTNODE*****************************************************************************}    function ti386realconstnode.pass_1 : tnode;      begin         result:=nil;         if is_number_float(value_real) and (value_real=1.0) or (value_real=0.0) then           begin              expectloc:=LOC_FPUREGISTER;              registersfpu:=1;           end         else           expectloc:=LOC_CREFERENCE;      end;    procedure ti386realconstnode.pass_2;      begin         if is_number_float(value_real) then           begin             if (value_real=1.0) then               begin                  emit_none(A_FLD1,S_NO);                  location_reset(location,LOC_FPUREGISTER,def_cgsize(resulttype.def));                  location.register:=NR_ST;                  tcgx86(cg).inc_fpu_stack;               end             else if (value_real=0.0) then               begin                  emit_none(A_FLDZ,S_NO);                  if (get_real_sign(value_real) < 0) then                    emit_none(A_FCHS,S_NO);                  location_reset(location,LOC_FPUREGISTER,def_cgsize(resulttype.def));                  location.register:=NR_ST;                  tcgx86(cg).inc_fpu_stack;               end            else              inherited pass_2;           end         else           inherited pass_2;      end;begin   crealconstnode:=ti386realconstnode;end.
 |