123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363 |
- {
- Copyright (c) 2014 by Florian Klaempfl
- Symbol table overrides for WebAssembly
- 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 symcpu;
- {$i fpcdefs.inc}
- interface
- uses
- globtype,
- cpubase,
- aasmdata,
- symtype,
- symdef,symsym,
- cgutils;
- type
- { defs }
- tcpufiledef = class(tfiledef)
- end;
- tcpufiledefclass = class of tcpufiledef;
- tcpuvariantdef = class(tvariantdef)
- end;
- tcpuvariantdefclass = class of tcpuvariantdef;
- tcpuformaldef = class(tformaldef)
- end;
- tcpuformaldefclass = class of tcpuformaldef;
- tcpuforwarddef = class(tforwarddef)
- end;
- tcpuforwarddefclass = class of tcpuforwarddef;
- tcpuundefineddef = class(tundefineddef)
- end;
- tcpuundefineddefclass = class of tcpuundefineddef;
- tcpuerrordef = class(terrordef)
- end;
- tcpuerrordefclass = class of tcpuerrordef;
- tcpupointerdef = class(tpointerdef)
- end;
- tcpupointerdefclass = class of tcpupointerdef;
- tcpurecorddef = class(trecorddef)
- end;
- tcpurecorddefclass = class of tcpurecorddef;
- tcpuimplementedinterface = class(timplementedinterface)
- end;
- tcpuimplementedinterfaceclass = class of tcpuimplementedinterface;
- tcpuobjectdef = class(tobjectdef)
- end;
- tcpuobjectdefclass = class of tcpuobjectdef;
- tcpuclassrefdef = class(tclassrefdef)
- end;
- tcpuclassrefdefclass = class of tcpuclassrefdef;
- tcpuarraydef = class(tarraydef)
- end;
- tcpuarraydefclass = class of tcpuarraydef;
- tcpuorddef = class(torddef)
- end;
- tcpuorddefclass = class of tcpuorddef;
- tcpufloatdef = class(tfloatdef)
- end;
- tcpufloatdefclass = class of tcpufloatdef;
- { tcpuprocvardef }
- tcpuprocvardef = class(tprocvardef)
- function create_functype: TWasmFuncType;
- function is_pushleftright: boolean; override;
- end;
- tcpuprocvardefclass = class of tcpuprocvardef;
- { tcpuprocdef }
- tcpuprocdef = class(tprocdef)
- frame_pointer_ref,
- base_pointer_ref: treference;
- { generated assembler code; used by WebAssembly backend so it can afterwards
- easily write out all methods grouped per class }
- exprasmlist : TAsmList;
- destructor destroy; override;
- function create_functype: TWasmFuncType;
- function is_pushleftright: boolean; override;
- end;
- tcpuprocdefclass = class of tcpuprocdef;
- tcpustringdef = class(tstringdef)
- end;
- tcpustringdefclass = class of tcpustringdef;
- tcpuenumdef = class(tenumdef)
- end;
- tcpuenumdefclass = class of tcpuenumdef;
- tcpusetdef = class(tsetdef)
- end;
- tcpusetdefclass = class of tcpusetdef;
- { syms }
- tcpulabelsym = class(tlabelsym)
- end;
- tcpulabelsymclass = class of tcpulabelsym;
- tcpuunitsym = class(tunitsym)
- end;
- tcpuunitsymclass = class of tcpuunitsym;
- tcpuprogramparasym = class(tprogramparasym)
- end;
- tcpuprogramparasymclass = class(tprogramparasym);
- tcpunamespacesym = class(tnamespacesym)
- end;
- tcpunamespacesymclass = class of tcpunamespacesym;
- { tcpuprocsym }
- tcpuprocsym = class(tprocsym)
- end;
- tcpuprocsymclass = class of tcpuprocsym;
- tcputypesym = class(ttypesym)
- end;
- tcpuypesymclass = class of tcputypesym;
- tcpufieldvarsym = class(tfieldvarsym)
- end;
- tcpufieldvarsymclass = class of tcpufieldvarsym;
- tcpulocalvarsym = class(tlocalvarsym)
- end;
- tcpulocalvarsymclass = class of tcpulocalvarsym;
- tcpuparavarsym = class(tparavarsym)
- end;
- tcpuparavarsymclass = class of tcpuparavarsym;
- tcpustaticvarsym = class(tstaticvarsym)
- end;
- tcpustaticvarsymclass = class of tcpustaticvarsym;
- tcpuabsolutevarsym = class(tabsolutevarsym)
- end;
- tcpuabsolutevarsymclass = class of tcpuabsolutevarsym;
- tcpupropertysym = class(tpropertysym)
- end;
- tcpupropertysymclass = class of tcpupropertysym;
- tcpuconstsym = class(tconstsym)
- end;
- tcpuconstsymclass = class of tcpuconstsym;
- tcpuenumsym = class(tenumsym)
- end;
- tcpuenumsymclass = class of tcpuenumsym;
- tcpusyssym = class(tsyssym)
- end;
- tcpusyssymclass = class of tcpusyssym;
- const
- pbestrealtype : ^tdef = @s64floattype;
- implementation
- uses
- verbose,cutils,cclasses,globals,cgbase,
- symconst,symbase,symtable,symcreat,wasmdef,
- pdecsub,pparautl,paramgr,
- // high-level code generator is needed to get access to type index for ncall
- hlcgobj,hlcgcpu,
- tgcpu
- ;
- {****************************************************************************
- tcpuproptertysym
- ****************************************************************************}
- {****************************************************************************
- tcpuenumdef
- ****************************************************************************}
- {****************************************************************************
- tcpuprocdef
- ****************************************************************************}
- function create_functype_common(pd: tabstractprocdef): TWasmFuncType;
- var
- i: Integer;
- prm: tcpuparavarsym;
- bt: TWasmBasicType;
- begin
- pd.init_paraloc_info(callerside);
- result:=TWasmFuncType.Create([],[]);
- if Assigned(pd.paras) and (pd.paras.Count>0) then
- begin
- for i:=0 to pd.paras.Count-1 do
- begin
- prm := tcpuparavarsym(pd.paras[i]);
- case prm.paraloc[callerside].Size of
- OS_8..OS_32, OS_S8..OS_S32:
- result.add_param(wbt_i32);
- OS_64, OS_S64:
- result.add_param(wbt_i64);
- OS_F32:
- result.add_param(wbt_f32);
- OS_F64:
- result.add_param(wbt_f64);
- else
- begin
- {$ifdef EXTDEBUG}
- Writeln('Unsupported caller side parameter type: ', prm.paraloc[callerside].Size);
- {$endif EXTDEBUG}
- // unsupported calleeside parameter type
- Internalerror(2019093001);
- end;
- end;
- end;
- end;
- if Assigned(pd.returndef) and (pd.returndef.size>0) and
- not paramanager.ret_in_param(pd.returndef,pd) then
- begin
- if not defToWasmBasic(pd.returndef,bt) then
- bt:=wbt_i32;
- case bt of
- wbt_i64:
- result.add_result(wbt_i64);
- wbt_f32:
- result.add_result(wbt_f32);
- wbt_f64:
- result.add_result(wbt_f64);
- else
- result.add_result(wbt_i32);
- end;
- end;
- end;
- destructor tcpuprocdef.destroy;
- begin
- exprasmlist.free;
- inherited destroy;
- end;
- function tcpuprocdef.create_functype: TWasmFuncType;
- begin
- Result:=create_functype_common(self);
- end;
- function tcpuprocdef.is_pushleftright: boolean;
- begin
- Result:=true;
- end;
- {****************************************************************************
- tcpuprocvardef
- ****************************************************************************}
- function tcpuprocvardef.create_functype: TWasmFuncType;
- begin
- Result:=create_functype_common(Self);
- end;
- function tcpuprocvardef.is_pushleftright: boolean;
- begin
- Result:=true;
- end;
- {****************************************************************************
- tcpuprocsym
- ****************************************************************************}
- {****************************************************************************
- tcpustaticvarsym
- ****************************************************************************}
- {****************************************************************************
- tcpufieldvarsym
- ****************************************************************************}
- initialization
- { used tdef classes }
- cfiledef:=tcpufiledef;
- cvariantdef:=tcpuvariantdef;
- cformaldef:=tcpuformaldef;
- cforwarddef:=tcpuforwarddef;
- cundefineddef:=tcpuundefineddef;
- cerrordef:=tcpuerrordef;
- cpointerdef:=tcpupointerdef;
- crecorddef:=tcpurecorddef;
- cimplementedinterface:=tcpuimplementedinterface;
- cobjectdef:=tcpuobjectdef;
- cclassrefdef:=tcpuclassrefdef;
- carraydef:=tcpuarraydef;
- corddef:=tcpuorddef;
- cfloatdef:=tcpufloatdef;
- cprocvardef:=tcpuprocvardef;
- cprocdef:=tcpuprocdef;
- cstringdef:=tcpustringdef;
- cenumdef:=tcpuenumdef;
- csetdef:=tcpusetdef;
- { used tsym classes }
- clabelsym:=tcpulabelsym;
- cunitsym:=tcpuunitsym;
- cprogramparasym:=tcpuprogramparasym;
- cnamespacesym:=tcpunamespacesym;
- cprocsym:=tcpuprocsym;
- ctypesym:=tcputypesym;
- cfieldvarsym:=tcpufieldvarsym;
- clocalvarsym:=tcpulocalvarsym;
- cparavarsym:=tcpuparavarsym;
- cstaticvarsym:=tcpustaticvarsym;
- cabsolutevarsym:=tcpuabsolutevarsym;
- cpropertysym:=tcpupropertysym;
- cconstsym:=tcpuconstsym;
- cenumsym:=tcpuenumsym;
- csyssym:=tcpusyssym;
- end.
|