| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | {    Copyright (c) 1998-2002 by Florian Klaempfl    Common x86 support for call nodes    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 nx86cal;{$i fpcdefs.inc}interface{ $define AnsiStrRef}    uses      symdef,      cgutils,      ncgcal;    type       { tx86callnode }       tx86callnode = class(tcgcallnode)        protected         procedure do_release_unused_return_value;override;         procedure set_result_location(realresdef: tstoreddef);override;         function can_call_ref(var ref: treference):boolean;override;         procedure do_call_ref(ref: treference);override;       end;implementation    uses      cgobj,      cgbase,cpubase,cgx86,cga,aasmdata,aasmcpu;{*****************************************************************************                             TX86CALLNODE*****************************************************************************}    procedure tx86callnode.do_release_unused_return_value;      begin        case location.loc of          LOC_FPUREGISTER :             begin               { release FPU stack }               emit_reg(A_FSTP,S_NO,NR_FPU_RESULT_REG);               tcgx86(cg).dec_fpu_stack;             end          else            inherited do_release_unused_return_value;        end;      end;  procedure tx86callnode.set_result_location(realresdef: tstoreddef);    begin      if (retloc.location^.loc=LOC_FPUREGISTER) then        begin          tcgx86(cg).inc_fpu_stack;          location_reset(location,LOC_FPUREGISTER,retloc.location^.size);          location.register:=retloc.location^.register;        end      else        inherited set_result_location(realresdef);    end;  function tx86callnode.can_call_ref(var ref: treference): boolean;    begin      tcgx86(cg).make_simple_ref(current_asmdata.CurrAsmList,ref);      result:=true;    end;  procedure tx86callnode.do_call_ref(ref: treference);    begin      current_asmdata.CurrAsmList.concat(taicpu.op_ref(A_CALL,S_NO,ref));    end;end.
 |