itcpugas.pas 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. {
  2. Copyright (c) 1998-2002 by Florian Klaempfl
  3. This unit contains the Xtensa GAS instruction tables
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 2 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  15. ****************************************************************************
  16. }
  17. unit itcpugas;
  18. {$i fpcdefs.inc}
  19. interface
  20. uses
  21. cpubase,cgbase;
  22. const
  23. { Standard opcode string table (for each tasmop enumeration). The
  24. opcode strings should conform to the names as defined by the
  25. processor manufacturer.
  26. }
  27. gas_op2str : op2strtable = {$i xtensaatt.inc}
  28. function gas_regnum_search(const s:string):Tregister;
  29. function gas_regname(r:Tregister):string;
  30. implementation
  31. uses
  32. rgbase;
  33. const
  34. gas_regname_table : TRegNameTable = (
  35. {$i rxtensastd.inc}
  36. );
  37. gas_regname_index : array[tregisterindex] of tregisterindex = (
  38. {$i rxtensasri.inc}
  39. );
  40. function gas_regnum_search(const s:string):Tregister;
  41. begin
  42. result:=regnumber_table[findreg_by_name_table(s, gas_regname_table, gas_regname_index)];
  43. end;
  44. function gas_regname(r:Tregister):string;
  45. var
  46. p : tregisterindex;
  47. begin
  48. p:=findreg_by_number(r);
  49. if p<>0 then
  50. result:=gas_regname_table[p]
  51. else
  52. result:=generic_regname(r);
  53. end;
  54. end.