| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401 | {    Copyright (c) 1998-2005 by Peter Vreman and Florian Klaempfl    Convert i386ins.dat from Nasm to a .inc file for usage with    the Free pascal compiler    See the file COPYING.FPC, included in this distribution,    for details about the copyright.    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. **********************************************************************}{$mode objfpc}program mkarmins;const  Version = '0.9';var   s : string;   i : longint;    function lower(const s : string) : string;    {      return lowercased string of s    }      var         i : longint;      begin         for i:=1 to length(s) do          if s[i] in ['A'..'Z'] then           lower[i]:=char(byte(s[i])+32)          else           lower[i]:=s[i];         lower[0]:=s[0];      end;      function Replace(var s:string;const s1,s2:string):boolean;      var        i  : longint;      begin        i:=pos(s1,s);        if i>0 then         begin           Delete(s,i,length(s1));           Insert(s2,s,i);           Replace:=true;         end        else         Replace:=false;      end;function formatop(s:string):string;   const     replaces=19;     replacetab : array[1..replaces,1..2] of string[32]=(       (':',' or ot_colon'),       ('mem8','mem or ot_bits8'),       ('mem16','mem or ot_bits16'),       ('mem32','mem or ot_bits32'),       ('mem64','mem or ot_bits64'),       ('mem80','mem or ot_bits80'),       ('mem','memory'),       ('memory_offs','mem_offs'),       ('imm8','imm or ot_bits8'),       ('imm16','imm or ot_bits16'),       ('imm32','imm or ot_bits32'),       ('imm64','imm or ot_bits64'),       ('imm80','imm or ot_bits80'),       ('imm','immediate'),       ('rm8','regmem or ot_bits8'),       ('rm16','regmem or ot_bits16'),       ('rm32','regmem or ot_bits32'),       ('rm64','regmem or ot_bits64'),       ('rm80','regmem or ot_bits80')     );  var    i : longint;  begin    for i:=1to replaces do     replace(s,replacetab[i,1],replacetab[i,2]);    formatop:=s;  end;function readnumber : longint;  var     base : longint;  begin     result:=0;     if s[i]='\' then       begin          base:=8;          inc(i);          if s[i]='x' then            begin               base:=16;               inc(i);            end;       end     else       base:=10;     s[i]:=upcase(s[i]);     while s[i] in ['0'..'9','A'..'F'] do       begin          case s[i] of             '0'..'9':               result:=result*base+ord(s[i])-ord('0');             'A'..'F':               result:=result*base+ord(s[i])-ord('A')+10;          end;          inc(i);       end;  end;function tostr(l : longint) : string;  var     hs : string;  begin     str(l,hs);     tostr:=hs;  end;function readstr : string;  begin     result:='';     while (s[i] in ['0'..'9','A'..'Z','a'..'z','_']) and (i<=length(s)) do       begin          result:=result+s[i];          inc(i);       end;  end;procedure skipspace;  begin     while (s[i] in [' ',#9]) do       inc(i);  end;procedure openinc(out f:text;const fn:string);begin  writeln('creating ',fn);  assign(f,fn);  rewrite(f);  writeln(f,'{ don''t edit, this file is generated from armins.dat }');  writeln(f,'(');end;procedure closeinc(var f:text);begin  writeln(f);  writeln(f,');');  close(f);end;var   attsuffix,   hs : string;   j : longint;   firstopcode,   first : boolean;   maxinfolen,   code : byte;   insns : longint;   attsuffile,{propfile,}opfile,   nopfile,attfile,   infile,insfile : text;   { instruction fields }   skip : boolean;   {last,}   ops    : longint;   attopcode,   opcode,   codes,   flags   : string;   optypes : array[1..4] of string;begin   writeln('FPC Instruction Table Converter Version ',Version);   writeln('Based on Narm Instruction Table Converter ');   insns:=0;   maxinfolen:=0;   { open dat file }   assign(infile,'../aarch64/a64ins.dat');   { create inc files }   openinc(insfile,'a64tab.inc');   openinc(opfile,'a64op.inc');   assign(nopfile,'a64nop.inc');   openinc(attfile,'a64att.inc');   openinc(attsuffile,'a64atts.inc');   rewrite(nopfile);   writeln(nopfile,'{ don''t edit, this file is generated from a64ins.dat }');   reset(infile);   first:=true;   opcode:='';   firstopcode:=true;   while not(eof(infile)) do     begin        { handle comment }        readln(infile,s);        while (s[1]=' ') do         delete(s,1,1);        if (s='') or (s[1]=';') then          continue;        if (s[1]='[') then         begin           i:=pos(',',s);           j:=pos(']',s);           if i=0 then            begin              opcode:='A_'+Copy(s,2,j-2);              attopcode:=Copy(s,2,j-2);              { Conditional }              if (attopcode[length(attopcode)]='c') and                 (attopcode[length(attopcode)-1]='c') then                begin                  dec(byte(attopcode[0]),2);                  dec(byte(opcode[0]),2);                end;              attsuffix:='attsufNONE';            end           else            begin              opcode:='A_'+Copy(s,2,i-2);              { intel conditional }              if (opcode[length(attopcode)]='c') and                 (opcode[length(attopcode)-1]='c') then                dec(byte(opcode[0]),2);              attopcode:=Copy(s,i+1,j-i-1);              { att Suffix }              case attopcode[length(attopcode)] of                'X' :                  begin                    dec(attopcode[0]);                    attsuffix:='attsufINT';                  end;                'F' :                  begin                    dec(attopcode[0]);                    attsuffix:='attsufFPU';                  end;                'R' :                  begin                    dec(attopcode[0]);                    attsuffix:='attsufFPUint';                  end;                else                  attsuffix:='attsufNONE';              end;              { att Conditional }              if (attopcode[length(attopcode)]='C') and                 (attopcode[length(attopcode)-1]='C') then                dec(byte(attopcode[0]),2);            end;           attopcode:=Lower(attopcode);           if firstopcode then            firstopcode:=false           else            begin              writeln(opfile,',');              writeln(attfile,',');              writeln(attsuffile,',');{              writeln(propfile,','); }            end;           write(opfile,opcode);           write(attfile,'''',attopcode,'''');           write(attsuffile,attsuffix);           { read the next line which contains the Change options }           {           repeat             readln(infile,s);           until eof(infile) or ((s<>'') and (s[1]<>';'));           write(propfile,'(Ch: ',s,')');           }           continue;         end;        { we must have an opcode }        if opcode='' then         runerror(234);        { clear }        ops:=0;        optypes[1]:='';        optypes[2]:='';        optypes[3]:='';        optypes[4]:='';        codes:='';        flags:='';        skip:=false;        { ops and optypes }        i:=1;        repeat          hs:=readstr;          if (hs='void') or (hs='ignore') then            break;          inc(ops);          optypes[ops]:=optypes[ops]+'ot_'+formatop(hs);{          if s[i]=':' then            begin               inc(i);               optypes[ops]:=optypes[ops]+' or ot_'+formatop(readstr);            end;}          while s[i]='|' do            begin               inc(i);               optypes[ops]:=optypes[ops]+' or ot_'+formatop(readstr);            end;          if s[i] in [',',':'] then            inc(i)          else            break;        until false;        for j:=1 to 4-ops do          optypes[4-j+1]:='ot_none';        { codes }        skipspace;        j:=0;(*        last:=0;*)        if s[i] in ['\','0'..'9'] then          begin             while not(s[i] in [' ',#9]) do               begin                 code:=readnumber;(*                 { for some codes we want also to change the optypes, but not                   if the last byte was a 1 then this byte belongs to a direct                   copy }                 if last<>1 then                  begin                    case code of                      12,13,14 :                        optypes[code-11]:=optypes[code-11]+' or ot_signed';                    end;                  end;*)                 codes:=codes+'#'+tostr(code);(*                 last:=code;*)                 inc(j);               end;          end        else          begin            readstr;            codes:='#0';          end;        if j>maxinfolen then         maxinfolen:=j;        { flags }        skipspace;        while not(s[i] in [' ',#9,#13,#10]) and (i<=length(s)) do          begin             hs:=readstr;             if hs<>'ND' then              begin                if flags<>'' then                 flags:=flags+' or ';                flags:=flags+'if_'+lower(hs);              end;             if (s[i]=',') and (i<=length(s)) then              inc(i)             else              break;          end;        { write instruction }        if not skip then          begin            if not(first) then              writeln(insfile,',')            else              first:=false;            writeln(insfile,'  (');            writeln(insfile,'    opcode  : ',opcode,';');            writeln(insfile,'    ops     : ',ops,';');            writeln(insfile,'    optypes : (',optypes[1],',',optypes[2],',',optypes[3],',',optypes[4],');');            writeln(insfile,'    code    : ',codes,';');            writeln(insfile,'    flags   : ',flags);            write(insfile,'  )');            inc(insns);          end;     end;   close(infile);   closeinc(insfile);   closeinc(attfile);   closeinc(attsuffile);   closeinc(opfile);   writeln(nopfile,insns,';');   close(nopfile);{   closeinc(propfile); }   writeln(insns,' nodes processed (maxinfolen=',maxinfolen,')');end.
 |