tilegx-tdep.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. /* Target-dependent code for the Tilera TILE-Gx processor.
  2. Copyright (C) 2012-2022 Free Software Foundation, Inc.
  3. This file is part of GDB.
  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 3 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, see <http://www.gnu.org/licenses/>. */
  14. #ifndef TILEGX_TDEP_H
  15. #define TILEGX_TDEP_H
  16. /* TILE-Gx has 56 general purpose registers (R0 - R52, TP, SP, LR),
  17. plus 8 special general purpose registers (network and ZERO),
  18. plus 1 magic register (PC).
  19. TP (aka R53) is the thread specific data pointer.
  20. SP (aka R54) is the stack pointer.
  21. LR (aka R55) is the link register. */
  22. enum tilegx_regnum
  23. {
  24. TILEGX_R0_REGNUM,
  25. TILEGX_FIRST_EASY_REGNUM = TILEGX_R0_REGNUM,
  26. TILEGX_R1_REGNUM,
  27. TILEGX_R2_REGNUM,
  28. TILEGX_R3_REGNUM,
  29. TILEGX_R4_REGNUM,
  30. TILEGX_R5_REGNUM,
  31. TILEGX_R6_REGNUM,
  32. TILEGX_R7_REGNUM,
  33. TILEGX_R8_REGNUM,
  34. TILEGX_R9_REGNUM,
  35. TILEGX_R10_REGNUM,
  36. TILEGX_R11_REGNUM,
  37. TILEGX_R12_REGNUM,
  38. TILEGX_R13_REGNUM,
  39. TILEGX_R14_REGNUM,
  40. TILEGX_R15_REGNUM,
  41. TILEGX_R16_REGNUM,
  42. TILEGX_R17_REGNUM,
  43. TILEGX_R18_REGNUM,
  44. TILEGX_R19_REGNUM,
  45. TILEGX_R20_REGNUM,
  46. TILEGX_R21_REGNUM,
  47. TILEGX_R22_REGNUM,
  48. TILEGX_R23_REGNUM,
  49. TILEGX_R24_REGNUM,
  50. TILEGX_R25_REGNUM,
  51. TILEGX_R26_REGNUM,
  52. TILEGX_R27_REGNUM,
  53. TILEGX_R28_REGNUM,
  54. TILEGX_R29_REGNUM,
  55. TILEGX_R30_REGNUM,
  56. TILEGX_R31_REGNUM,
  57. TILEGX_R32_REGNUM,
  58. TILEGX_R33_REGNUM,
  59. TILEGX_R34_REGNUM,
  60. TILEGX_R35_REGNUM,
  61. TILEGX_R36_REGNUM,
  62. TILEGX_R37_REGNUM,
  63. TILEGX_R38_REGNUM,
  64. TILEGX_R39_REGNUM,
  65. TILEGX_R40_REGNUM,
  66. TILEGX_R41_REGNUM,
  67. TILEGX_R42_REGNUM,
  68. TILEGX_R43_REGNUM,
  69. TILEGX_R44_REGNUM,
  70. TILEGX_R45_REGNUM,
  71. TILEGX_R46_REGNUM,
  72. TILEGX_R47_REGNUM,
  73. TILEGX_R48_REGNUM,
  74. TILEGX_R49_REGNUM,
  75. TILEGX_R50_REGNUM,
  76. TILEGX_R51_REGNUM,
  77. TILEGX_R52_REGNUM,
  78. TILEGX_TP_REGNUM,
  79. TILEGX_SP_REGNUM,
  80. TILEGX_LR_REGNUM,
  81. TILEGX_SN_REGNUM,
  82. TILEGX_NUM_EASY_REGS = TILEGX_SN_REGNUM, /* 56 */
  83. TILEGX_IO0_REGNUM,
  84. TILEGX_IO1_REGNUM,
  85. TILEGX_US0_REGNUM,
  86. TILEGX_US1_REGNUM,
  87. TILEGX_US2_REGNUM,
  88. TILEGX_US3_REGNUM,
  89. TILEGX_ZERO_REGNUM,
  90. TILEGX_PC_REGNUM,
  91. TILEGX_NUM_PHYS_REGS = TILEGX_PC_REGNUM, /* 64 */
  92. TILEGX_FAULTNUM_REGNUM,
  93. TILEGX_NUM_REGS, /* 66 */
  94. };
  95. enum { tilegx_reg_size = 8 };
  96. #endif /* tilegx-tdep.h */