jit_x86.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. /*
  2. * Copyright (C) 2012, 2013 Free Software Foundation, Inc.
  3. *
  4. * This file is part of GNU lightning.
  5. *
  6. * GNU lightning is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU Lesser General Public License as published
  8. * by the Free Software Foundation; either version 3, or (at your option)
  9. * any later version.
  10. *
  11. * GNU lightning is distributed in the hope that it will be useful, but
  12. * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  13. * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
  14. * License for more details.
  15. *
  16. * Authors:
  17. * Paulo Cesar Pereira de Andrade
  18. */
  19. #ifndef _jit_x86_h
  20. #define _jit_x86_h
  21. #define JIT_HASH_CONSTS 1
  22. #define JIT_NUM_OPERANDS 2
  23. /*
  24. * Types
  25. */
  26. #define jit_sse2_p() jit_cpu.sse2
  27. #define jit_x87_reg_p(reg) ((reg) >= _ST0 && (reg) <= _ST7)
  28. #if __WORDSIZE == 32
  29. # if defined(__x86_64__)
  30. # define __X64_32 1
  31. # define __X64 1
  32. # else
  33. # define __X32 1
  34. # endif
  35. #else
  36. # define __X64 1
  37. #endif
  38. #define JIT_FP _RBP
  39. typedef enum {
  40. #if __X32
  41. # define jit_r(i) (_RAX + (i))
  42. # define jit_r_num() 3
  43. # define jit_v(i) (_RBX + (i))
  44. # define jit_v_num() 3
  45. # define jit_f(i) (jit_cpu.sse2 ? _XMM0 + (i) : _ST0 + (i))
  46. # define jit_f_num() (jit_cpu.sse2 ? 8 : 6)
  47. # define JIT_R0 _RAX
  48. # define JIT_R1 _RCX
  49. # define JIT_R2 _RDX
  50. _RAX, _RCX, _RDX,
  51. # define JIT_V0 _RBX
  52. # define JIT_V1 _RSI
  53. # define JIT_V2 _RDI
  54. _RBX, _RSI, _RDI,
  55. _RSP, _RBP,
  56. # define JIT_F0 (jit_sse2_p() ? _XMM0 : _ST0)
  57. # define JIT_F1 (jit_sse2_p() ? _XMM1 : _ST1)
  58. # define JIT_F2 (jit_sse2_p() ? _XMM2 : _ST2)
  59. # define JIT_F3 (jit_sse2_p() ? _XMM3 : _ST3)
  60. # define JIT_F4 (jit_sse2_p() ? _XMM4 : _ST4)
  61. # define JIT_F5 (jit_sse2_p() ? _XMM5 : _ST5)
  62. # define JIT_F6 (jit_sse2_p() ? _XMM6 : _ST6)
  63. # define JIT_F7 (jit_sse2_p() ? _XMM7 : _ST7)
  64. _XMM0, _XMM1, _XMM2, _XMM3, _XMM4, _XMM5, _XMM6, _XMM7,
  65. # define jit_sse_reg_p(reg) ((reg) >= _XMM0 && (reg) <= _XMM7)
  66. #else
  67. # if __CYGWIN__
  68. # define jit_r(i) (_RAX + (i))
  69. # define jit_r_num() 3
  70. # define jit_v(i) (_RBX + (i))
  71. # define jit_v_num() 7
  72. # define jit_f(index) (_XMM4 + (index))
  73. # define jit_f_num() 12
  74. # define JIT_R0 _RAX
  75. # define JIT_R1 _R10
  76. # define JIT_R2 _R11
  77. # define JIT_V0 _RBX
  78. # define JIT_V1 _RDI
  79. # define JIT_V2 _RSI
  80. # define JIT_V3 _R12
  81. # define JIT_V4 _R13
  82. # define JIT_V5 _R14
  83. # define JIT_V6 _R15
  84. /* Volatile - Return value register */
  85. _RAX,
  86. /* Volatile */
  87. _R10, _R11,
  88. /* Nonvolatile */
  89. _RBX, _RDI, _RSI,
  90. _R12, _R13, _R14, _R15,
  91. /* Volatile - Integer arguments (4 to 1) */
  92. _R9, _R8, _RDX, _RCX,
  93. /* Nonvolatile */
  94. _RSP, _RBP,
  95. # define JIT_F0 _XMM4
  96. # define JIT_F1 _XMM5
  97. # define JIT_F2 _XMM6
  98. # define JIT_F3 _XMM7
  99. # define JIT_F4 _XMM8
  100. # define JIT_F5 _XMM9
  101. # define JIT_F6 _XMM10
  102. # define JIT_F7 _XMM11
  103. # define JIT_F8 _XMM12
  104. # define JIT_F9 _XMM13
  105. # define JIT_F10 _XMM14
  106. # define JIT_F11 _XMM15
  107. /* Volatile */
  108. _XMM4, _XMM5,
  109. /* Nonvolatile */
  110. _XMM6, _XMM7, _XMM8, _XMM9, _XMM10,
  111. _XMM11, _XMM12, _XMM13, _XMM14, _XMM15,
  112. /* Volatile - FP arguments (4 to 1) */
  113. _XMM3, _XMM2, _XMM1, _XMM0,
  114. # define jit_sse_reg_p(reg) ((reg) >= _XMM4 && (reg) <= _XMM0)
  115. # else
  116. # define jit_r(i) (_RAX + (i))
  117. # define jit_r_num() 4
  118. # define jit_v(i) (_RBX + (i))
  119. # define jit_v_num() 4
  120. # define jit_f(index) (_XMM8 + (index))
  121. # define jit_f_num() 8
  122. # define JIT_R0 _RAX
  123. # define JIT_R1 _R10
  124. # define JIT_R2 _R11
  125. # define JIT_R3 _R12
  126. _RAX, _R10, _R11, _R12,
  127. # define JIT_V0 _RBX
  128. # define JIT_V1 _R13
  129. # define JIT_V2 _R14
  130. # define JIT_V3 _R15
  131. _RBX, _R13, _R14, _R15,
  132. _R9, _R8, _RCX, _RDX, _RSI, _RDI,
  133. _RSP, _RBP,
  134. # define JIT_F0 _XMM8
  135. # define JIT_F1 _XMM9
  136. # define JIT_F2 _XMM10
  137. # define JIT_F3 _XMM11
  138. # define JIT_F4 _XMM12
  139. # define JIT_F5 _XMM13
  140. # define JIT_F6 _XMM14
  141. # define JIT_F7 _XMM15
  142. _XMM8, _XMM9, _XMM10, _XMM11, _XMM12, _XMM13, _XMM14, _XMM15,
  143. _XMM7, _XMM6, _XMM5, _XMM4, _XMM3, _XMM2, _XMM1, _XMM0,
  144. # define jit_sse_reg_p(reg) ((reg) >= _XMM8 && (reg) <= _XMM0)
  145. # endif
  146. #endif
  147. _ST0, _ST1, _ST2, _ST3, _ST4, _ST5, _ST6, _ST7,
  148. # define JIT_NOREG _NOREG
  149. _NOREG,
  150. } jit_reg_t;
  151. typedef struct {
  152. /* x87 present */
  153. jit_uint32_t fpu : 1;
  154. /* cmpxchg8b instruction */
  155. jit_uint32_t cmpxchg8b : 1;
  156. /* cmov and fcmov branchless conditional mov */
  157. jit_uint32_t cmov : 1;
  158. /* mmx registers/instructions available */
  159. jit_uint32_t mmx : 1;
  160. /* sse registers/instructions available */
  161. jit_uint32_t sse : 1;
  162. /* sse2 registers/instructions available */
  163. jit_uint32_t sse2 : 1;
  164. /* sse3 instructions available */
  165. jit_uint32_t sse3 : 1;
  166. /* pcmulqdq instruction */
  167. jit_uint32_t pclmulqdq : 1;
  168. /* ssse3 suplemental sse3 instructions available */
  169. jit_uint32_t ssse3 : 1;
  170. /* fused multiply/add using ymm state */
  171. jit_uint32_t fma : 1;
  172. /* cmpxchg16b instruction */
  173. jit_uint32_t cmpxchg16b : 1;
  174. /* sse4.1 instructions available */
  175. jit_uint32_t sse4_1 : 1;
  176. /* sse4.2 instructions available */
  177. jit_uint32_t sse4_2 : 1;
  178. /* movbe instruction available */
  179. jit_uint32_t movbe : 1;
  180. /* popcnt instruction available */
  181. jit_uint32_t popcnt : 1;
  182. /* aes instructions available */
  183. jit_uint32_t aes : 1;
  184. /* avx instructions available */
  185. jit_uint32_t avx : 1;
  186. /* lahf/sahf available in 64 bits mode */
  187. jit_uint32_t lahf : 1;
  188. } jit_cpu_t;
  189. /*
  190. * Initialization
  191. */
  192. extern jit_cpu_t jit_cpu;
  193. #endif /* _jit_x86_h */