| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 | {    Copyright (c) 2014 by Jonas Maebe    Generate LLVM bytecode 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 nllvmcal;{$i fpcdefs.inc}interface    uses      parabase,      ncgcal,      cgutils;    type      tllvmcallparanode = class(tcgcallparanode)       protected        function push_zero_sized_value_para: boolean; override;      end;      tllvmcallnode = class(tcgcallnode)       protected        function can_call_ref(var ref: treference): boolean; override;        procedure pushparas; override;      end;implementation     uses       verbose,       ncal;{*****************************************************************************                          TLLVMCALLPARANODE *****************************************************************************}    function tllvmcallparanode.push_zero_sized_value_para: boolean;      begin        { part of the signature -> need to be pushed }        result:=true;      end;{*****************************************************************************                           TLLVMCALLNODE *****************************************************************************}    function tllvmcallnode.can_call_ref(var ref: treference): boolean;      begin        result:=false;      end;    procedure tllvmcallnode.pushparas;      var        n: tcgcallparanode;        paraindex: longint;      begin        { we just pass the temp paralocs here }        if not assigned(varargsparas) then          setlength(paralocs,procdefinition.paras.count)        else          setlength(paralocs,procdefinition.paras.count+varargsparas.count);        n:=tcgcallparanode(left);        while assigned(n) do          begin            { TODO: check whether this is correct for left-to-right calling              conventions, may also depend on whether or not llvm knows about              the calling convention }            if not(cpf_varargs_para in n.callparaflags) then              paraindex:=procdefinition.paras.indexof(n.parasym)            else              paraindex:=procdefinition.paras.count+varargsparas.indexof(n.parasym);            if paraindex=-1 then             internalerror(2014010602);            paralocs[paraindex]:[email protected];            n:=tcgcallparanode(n.right);         end;      end;begin  ccallnode:=tllvmcallnode;end.
 |