therubyracer 0.5.0-x86-linux → 0.11.0beta5-x86-linux

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of therubyracer might be problematic. Click here for more details.

Files changed (721) hide show
  1. data/.gitignore +23 -11
  2. data/.travis.yml +10 -0
  3. data/Changelog.md +242 -0
  4. data/Gemfile +16 -0
  5. data/README.md +185 -0
  6. data/Rakefile +42 -51
  7. data/benchmarks.rb +217 -0
  8. data/ext/v8/accessor.cc +181 -0
  9. data/ext/v8/array.cc +26 -0
  10. data/ext/v8/backref.cc +56 -0
  11. data/ext/v8/build.rb +52 -0
  12. data/ext/v8/constants.cc +34 -0
  13. data/ext/v8/constraints.cc +52 -0
  14. data/ext/v8/context.cc +130 -0
  15. data/ext/v8/date.cc +18 -0
  16. data/ext/v8/exception.cc +38 -0
  17. data/ext/v8/extconf.rb +16 -29
  18. data/ext/v8/external.cc +43 -0
  19. data/ext/v8/function.cc +58 -0
  20. data/ext/v8/gc.cc +43 -0
  21. data/ext/v8/handles.cc +34 -0
  22. data/ext/v8/heap.cc +31 -0
  23. data/ext/v8/init.cc +39 -0
  24. data/ext/v8/init.so +0 -0
  25. data/ext/v8/invocation.cc +86 -0
  26. data/ext/v8/locker.cc +77 -0
  27. data/ext/v8/message.cc +51 -0
  28. data/ext/v8/object.cc +334 -0
  29. data/ext/v8/primitive.cc +8 -0
  30. data/ext/v8/rr.cc +83 -0
  31. data/ext/v8/rr.h +883 -0
  32. data/ext/v8/script.cc +80 -0
  33. data/ext/v8/signature.cc +18 -0
  34. data/ext/v8/stack.cc +75 -0
  35. data/ext/v8/string.cc +47 -0
  36. data/ext/v8/template.cc +175 -0
  37. data/ext/v8/trycatch.cc +86 -0
  38. data/ext/v8/v8.cc +87 -0
  39. data/ext/v8/value.cc +239 -0
  40. data/lib/v8.rb +30 -9
  41. data/lib/v8/access.rb +5 -0
  42. data/lib/v8/access/indices.rb +40 -0
  43. data/lib/v8/access/invocation.rb +47 -0
  44. data/lib/v8/access/names.rb +65 -0
  45. data/lib/v8/array.rb +26 -0
  46. data/lib/v8/context.rb +217 -75
  47. data/lib/v8/conversion.rb +35 -0
  48. data/lib/v8/conversion/array.rb +11 -0
  49. data/lib/v8/conversion/class.rb +120 -0
  50. data/lib/v8/conversion/code.rb +38 -0
  51. data/lib/v8/conversion/fundamental.rb +11 -0
  52. data/lib/v8/conversion/hash.rb +11 -0
  53. data/lib/v8/conversion/indentity.rb +31 -0
  54. data/lib/v8/conversion/method.rb +26 -0
  55. data/lib/v8/conversion/object.rb +28 -0
  56. data/lib/v8/conversion/primitive.rb +7 -0
  57. data/lib/v8/conversion/proc.rb +5 -0
  58. data/lib/v8/conversion/reference.rb +16 -0
  59. data/lib/v8/conversion/string.rb +12 -0
  60. data/lib/v8/conversion/symbol.rb +7 -0
  61. data/lib/v8/conversion/time.rb +13 -0
  62. data/lib/v8/error.rb +25 -0
  63. data/lib/v8/error/protect.rb +20 -0
  64. data/lib/v8/error/try.rb +15 -0
  65. data/lib/v8/function.rb +28 -0
  66. data/lib/v8/object.rb +69 -28
  67. data/lib/v8/util/weakcell.rb +29 -0
  68. data/lib/v8/version.rb +3 -0
  69. data/spec/c/array_spec.rb +17 -0
  70. data/spec/c/constants_spec.rb +20 -0
  71. data/spec/c/exception_spec.rb +26 -0
  72. data/spec/c/external_spec.rb +9 -0
  73. data/spec/c/function_spec.rb +46 -0
  74. data/spec/c/handles_spec.rb +35 -0
  75. data/spec/c/locker_spec.rb +38 -0
  76. data/spec/c/object_spec.rb +46 -0
  77. data/spec/c/script_spec.rb +28 -0
  78. data/spec/c/string_spec.rb +16 -0
  79. data/spec/c/template_spec.rb +30 -0
  80. data/spec/c/trycatch_spec.rb +51 -0
  81. data/spec/mem/blunt_spec.rb +42 -0
  82. data/spec/redjs_spec.rb +10 -0
  83. data/spec/spec_helper.rb +43 -12
  84. data/spec/threading_spec.rb +52 -0
  85. data/spec/v8/context_spec.rb +19 -0
  86. data/spec/v8/conversion_spec.rb +9 -0
  87. data/spec/v8/error_spec.rb +21 -0
  88. data/spec/v8/function_spec.rb +9 -0
  89. data/spec/v8/object_spec.rb +15 -0
  90. data/thefrontside.png +0 -0
  91. data/therubyracer.gemspec +15 -676
  92. metadata +146 -680
  93. data/.gitmodules +0 -3
  94. data/Doxyfile +0 -1514
  95. data/History.txt +0 -51
  96. data/README.rdoc +0 -158
  97. data/docs/data_conversion.txt +0 -18
  98. data/ext/v8/callbacks.cpp +0 -160
  99. data/ext/v8/callbacks.h +0 -14
  100. data/ext/v8/convert_ruby.cpp +0 -8
  101. data/ext/v8/convert_ruby.h +0 -99
  102. data/ext/v8/convert_string.cpp +0 -10
  103. data/ext/v8/convert_string.h +0 -73
  104. data/ext/v8/convert_v8.cpp +0 -9
  105. data/ext/v8/convert_v8.h +0 -121
  106. data/ext/v8/converters.cpp +0 -83
  107. data/ext/v8/converters.h +0 -23
  108. data/ext/v8/upstream/2.0.6/.gitignore +0 -26
  109. data/ext/v8/upstream/2.0.6/AUTHORS +0 -23
  110. data/ext/v8/upstream/2.0.6/ChangeLog +0 -1479
  111. data/ext/v8/upstream/2.0.6/LICENSE +0 -55
  112. data/ext/v8/upstream/2.0.6/SConstruct +0 -1028
  113. data/ext/v8/upstream/2.0.6/include/v8-debug.h +0 -275
  114. data/ext/v8/upstream/2.0.6/include/v8.h +0 -3236
  115. data/ext/v8/upstream/2.0.6/src/SConscript +0 -283
  116. data/ext/v8/upstream/2.0.6/src/accessors.cc +0 -695
  117. data/ext/v8/upstream/2.0.6/src/accessors.h +0 -114
  118. data/ext/v8/upstream/2.0.6/src/allocation.cc +0 -198
  119. data/ext/v8/upstream/2.0.6/src/allocation.h +0 -169
  120. data/ext/v8/upstream/2.0.6/src/api.cc +0 -3831
  121. data/ext/v8/upstream/2.0.6/src/api.h +0 -479
  122. data/ext/v8/upstream/2.0.6/src/apinatives.js +0 -110
  123. data/ext/v8/upstream/2.0.6/src/apiutils.h +0 -69
  124. data/ext/v8/upstream/2.0.6/src/arguments.h +0 -97
  125. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm-inl.h +0 -277
  126. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.cc +0 -1821
  127. data/ext/v8/upstream/2.0.6/src/arm/assembler-arm.h +0 -1027
  128. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2-inl.h +0 -267
  129. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.cc +0 -1821
  130. data/ext/v8/upstream/2.0.6/src/arm/assembler-thumb2.h +0 -1027
  131. data/ext/v8/upstream/2.0.6/src/arm/builtins-arm.cc +0 -1271
  132. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm-inl.h +0 -74
  133. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.cc +0 -6682
  134. data/ext/v8/upstream/2.0.6/src/arm/codegen-arm.h +0 -535
  135. data/ext/v8/upstream/2.0.6/src/arm/constants-arm.cc +0 -112
  136. data/ext/v8/upstream/2.0.6/src/arm/constants-arm.h +0 -347
  137. data/ext/v8/upstream/2.0.6/src/arm/cpu-arm.cc +0 -132
  138. data/ext/v8/upstream/2.0.6/src/arm/debug-arm.cc +0 -213
  139. data/ext/v8/upstream/2.0.6/src/arm/disasm-arm.cc +0 -1166
  140. data/ext/v8/upstream/2.0.6/src/arm/fast-codegen-arm.cc +0 -1698
  141. data/ext/v8/upstream/2.0.6/src/arm/frames-arm.cc +0 -123
  142. data/ext/v8/upstream/2.0.6/src/arm/frames-arm.h +0 -162
  143. data/ext/v8/upstream/2.0.6/src/arm/ic-arm.cc +0 -849
  144. data/ext/v8/upstream/2.0.6/src/arm/jump-target-arm.cc +0 -238
  145. data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.cc +0 -1259
  146. data/ext/v8/upstream/2.0.6/src/arm/macro-assembler-arm.h +0 -423
  147. data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.cc +0 -1266
  148. data/ext/v8/upstream/2.0.6/src/arm/regexp-macro-assembler-arm.h +0 -282
  149. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm-inl.h +0 -103
  150. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.cc +0 -59
  151. data/ext/v8/upstream/2.0.6/src/arm/register-allocator-arm.h +0 -43
  152. data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.cc +0 -2264
  153. data/ext/v8/upstream/2.0.6/src/arm/simulator-arm.h +0 -306
  154. data/ext/v8/upstream/2.0.6/src/arm/stub-cache-arm.cc +0 -1516
  155. data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.cc +0 -412
  156. data/ext/v8/upstream/2.0.6/src/arm/virtual-frame-arm.h +0 -532
  157. data/ext/v8/upstream/2.0.6/src/array.js +0 -1154
  158. data/ext/v8/upstream/2.0.6/src/assembler.cc +0 -772
  159. data/ext/v8/upstream/2.0.6/src/assembler.h +0 -525
  160. data/ext/v8/upstream/2.0.6/src/ast.cc +0 -512
  161. data/ext/v8/upstream/2.0.6/src/ast.h +0 -1820
  162. data/ext/v8/upstream/2.0.6/src/bootstrapper.cc +0 -1680
  163. data/ext/v8/upstream/2.0.6/src/bootstrapper.h +0 -103
  164. data/ext/v8/upstream/2.0.6/src/builtins.cc +0 -851
  165. data/ext/v8/upstream/2.0.6/src/builtins.h +0 -245
  166. data/ext/v8/upstream/2.0.6/src/bytecodes-irregexp.h +0 -104
  167. data/ext/v8/upstream/2.0.6/src/char-predicates-inl.h +0 -86
  168. data/ext/v8/upstream/2.0.6/src/char-predicates.h +0 -65
  169. data/ext/v8/upstream/2.0.6/src/checks.cc +0 -100
  170. data/ext/v8/upstream/2.0.6/src/checks.h +0 -284
  171. data/ext/v8/upstream/2.0.6/src/code-stubs.cc +0 -164
  172. data/ext/v8/upstream/2.0.6/src/code-stubs.h +0 -164
  173. data/ext/v8/upstream/2.0.6/src/code.h +0 -68
  174. data/ext/v8/upstream/2.0.6/src/codegen-inl.h +0 -88
  175. data/ext/v8/upstream/2.0.6/src/codegen.cc +0 -504
  176. data/ext/v8/upstream/2.0.6/src/codegen.h +0 -522
  177. data/ext/v8/upstream/2.0.6/src/compilation-cache.cc +0 -490
  178. data/ext/v8/upstream/2.0.6/src/compilation-cache.h +0 -98
  179. data/ext/v8/upstream/2.0.6/src/compiler.cc +0 -1132
  180. data/ext/v8/upstream/2.0.6/src/compiler.h +0 -107
  181. data/ext/v8/upstream/2.0.6/src/contexts.cc +0 -256
  182. data/ext/v8/upstream/2.0.6/src/contexts.h +0 -345
  183. data/ext/v8/upstream/2.0.6/src/conversions-inl.h +0 -95
  184. data/ext/v8/upstream/2.0.6/src/conversions.cc +0 -709
  185. data/ext/v8/upstream/2.0.6/src/conversions.h +0 -118
  186. data/ext/v8/upstream/2.0.6/src/counters.cc +0 -78
  187. data/ext/v8/upstream/2.0.6/src/counters.h +0 -239
  188. data/ext/v8/upstream/2.0.6/src/cpu.h +0 -65
  189. data/ext/v8/upstream/2.0.6/src/d8-debug.cc +0 -345
  190. data/ext/v8/upstream/2.0.6/src/d8-debug.h +0 -155
  191. data/ext/v8/upstream/2.0.6/src/d8-posix.cc +0 -675
  192. data/ext/v8/upstream/2.0.6/src/d8-readline.cc +0 -128
  193. data/ext/v8/upstream/2.0.6/src/d8-windows.cc +0 -42
  194. data/ext/v8/upstream/2.0.6/src/d8.cc +0 -776
  195. data/ext/v8/upstream/2.0.6/src/d8.h +0 -225
  196. data/ext/v8/upstream/2.0.6/src/d8.js +0 -1625
  197. data/ext/v8/upstream/2.0.6/src/date-delay.js +0 -1138
  198. data/ext/v8/upstream/2.0.6/src/dateparser-inl.h +0 -114
  199. data/ext/v8/upstream/2.0.6/src/dateparser.cc +0 -186
  200. data/ext/v8/upstream/2.0.6/src/dateparser.h +0 -240
  201. data/ext/v8/upstream/2.0.6/src/debug-agent.cc +0 -425
  202. data/ext/v8/upstream/2.0.6/src/debug-agent.h +0 -129
  203. data/ext/v8/upstream/2.0.6/src/debug-delay.js +0 -2073
  204. data/ext/v8/upstream/2.0.6/src/debug.cc +0 -2751
  205. data/ext/v8/upstream/2.0.6/src/debug.h +0 -866
  206. data/ext/v8/upstream/2.0.6/src/disasm.h +0 -77
  207. data/ext/v8/upstream/2.0.6/src/disassembler.cc +0 -318
  208. data/ext/v8/upstream/2.0.6/src/disassembler.h +0 -56
  209. data/ext/v8/upstream/2.0.6/src/dtoa-config.c +0 -91
  210. data/ext/v8/upstream/2.0.6/src/execution.cc +0 -701
  211. data/ext/v8/upstream/2.0.6/src/execution.h +0 -312
  212. data/ext/v8/upstream/2.0.6/src/factory.cc +0 -957
  213. data/ext/v8/upstream/2.0.6/src/factory.h +0 -393
  214. data/ext/v8/upstream/2.0.6/src/fast-codegen.cc +0 -725
  215. data/ext/v8/upstream/2.0.6/src/fast-codegen.h +0 -371
  216. data/ext/v8/upstream/2.0.6/src/flag-definitions.h +0 -426
  217. data/ext/v8/upstream/2.0.6/src/flags.cc +0 -555
  218. data/ext/v8/upstream/2.0.6/src/flags.h +0 -81
  219. data/ext/v8/upstream/2.0.6/src/frame-element.cc +0 -45
  220. data/ext/v8/upstream/2.0.6/src/frame-element.h +0 -235
  221. data/ext/v8/upstream/2.0.6/src/frames-inl.h +0 -215
  222. data/ext/v8/upstream/2.0.6/src/frames.cc +0 -749
  223. data/ext/v8/upstream/2.0.6/src/frames.h +0 -659
  224. data/ext/v8/upstream/2.0.6/src/func-name-inferrer.cc +0 -76
  225. data/ext/v8/upstream/2.0.6/src/func-name-inferrer.h +0 -135
  226. data/ext/v8/upstream/2.0.6/src/global-handles.cc +0 -516
  227. data/ext/v8/upstream/2.0.6/src/global-handles.h +0 -180
  228. data/ext/v8/upstream/2.0.6/src/globals.h +0 -608
  229. data/ext/v8/upstream/2.0.6/src/handles-inl.h +0 -76
  230. data/ext/v8/upstream/2.0.6/src/handles.cc +0 -811
  231. data/ext/v8/upstream/2.0.6/src/handles.h +0 -367
  232. data/ext/v8/upstream/2.0.6/src/hashmap.cc +0 -226
  233. data/ext/v8/upstream/2.0.6/src/hashmap.h +0 -120
  234. data/ext/v8/upstream/2.0.6/src/heap-inl.h +0 -407
  235. data/ext/v8/upstream/2.0.6/src/heap-profiler.cc +0 -695
  236. data/ext/v8/upstream/2.0.6/src/heap-profiler.h +0 -277
  237. data/ext/v8/upstream/2.0.6/src/heap.cc +0 -4204
  238. data/ext/v8/upstream/2.0.6/src/heap.h +0 -1704
  239. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32-inl.h +0 -325
  240. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.cc +0 -2375
  241. data/ext/v8/upstream/2.0.6/src/ia32/assembler-ia32.h +0 -914
  242. data/ext/v8/upstream/2.0.6/src/ia32/builtins-ia32.cc +0 -1222
  243. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32-inl.h +0 -46
  244. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.cc +0 -9770
  245. data/ext/v8/upstream/2.0.6/src/ia32/codegen-ia32.h +0 -834
  246. data/ext/v8/upstream/2.0.6/src/ia32/cpu-ia32.cc +0 -79
  247. data/ext/v8/upstream/2.0.6/src/ia32/debug-ia32.cc +0 -208
  248. data/ext/v8/upstream/2.0.6/src/ia32/disasm-ia32.cc +0 -1357
  249. data/ext/v8/upstream/2.0.6/src/ia32/fast-codegen-ia32.cc +0 -1813
  250. data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.cc +0 -111
  251. data/ext/v8/upstream/2.0.6/src/ia32/frames-ia32.h +0 -135
  252. data/ext/v8/upstream/2.0.6/src/ia32/ic-ia32.cc +0 -1490
  253. data/ext/v8/upstream/2.0.6/src/ia32/jump-target-ia32.cc +0 -432
  254. data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.cc +0 -1517
  255. data/ext/v8/upstream/2.0.6/src/ia32/macro-assembler-ia32.h +0 -528
  256. data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.cc +0 -1219
  257. data/ext/v8/upstream/2.0.6/src/ia32/regexp-macro-assembler-ia32.h +0 -230
  258. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32-inl.h +0 -82
  259. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.cc +0 -99
  260. data/ext/v8/upstream/2.0.6/src/ia32/register-allocator-ia32.h +0 -43
  261. data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.cc +0 -30
  262. data/ext/v8/upstream/2.0.6/src/ia32/simulator-ia32.h +0 -62
  263. data/ext/v8/upstream/2.0.6/src/ia32/stub-cache-ia32.cc +0 -1961
  264. data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.cc +0 -1105
  265. data/ext/v8/upstream/2.0.6/src/ia32/virtual-frame-ia32.h +0 -580
  266. data/ext/v8/upstream/2.0.6/src/ic-inl.h +0 -93
  267. data/ext/v8/upstream/2.0.6/src/ic.cc +0 -1426
  268. data/ext/v8/upstream/2.0.6/src/ic.h +0 -443
  269. data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.cc +0 -646
  270. data/ext/v8/upstream/2.0.6/src/interpreter-irregexp.h +0 -48
  271. data/ext/v8/upstream/2.0.6/src/json-delay.js +0 -254
  272. data/ext/v8/upstream/2.0.6/src/jsregexp.cc +0 -5234
  273. data/ext/v8/upstream/2.0.6/src/jsregexp.h +0 -1439
  274. data/ext/v8/upstream/2.0.6/src/jump-target-inl.h +0 -49
  275. data/ext/v8/upstream/2.0.6/src/jump-target.cc +0 -383
  276. data/ext/v8/upstream/2.0.6/src/jump-target.h +0 -280
  277. data/ext/v8/upstream/2.0.6/src/list-inl.h +0 -166
  278. data/ext/v8/upstream/2.0.6/src/list.h +0 -158
  279. data/ext/v8/upstream/2.0.6/src/log-inl.h +0 -126
  280. data/ext/v8/upstream/2.0.6/src/log-utils.cc +0 -503
  281. data/ext/v8/upstream/2.0.6/src/log-utils.h +0 -292
  282. data/ext/v8/upstream/2.0.6/src/log.cc +0 -1457
  283. data/ext/v8/upstream/2.0.6/src/log.h +0 -371
  284. data/ext/v8/upstream/2.0.6/src/macro-assembler.h +0 -93
  285. data/ext/v8/upstream/2.0.6/src/macros.py +0 -137
  286. data/ext/v8/upstream/2.0.6/src/mark-compact.cc +0 -2007
  287. data/ext/v8/upstream/2.0.6/src/mark-compact.h +0 -442
  288. data/ext/v8/upstream/2.0.6/src/math.js +0 -263
  289. data/ext/v8/upstream/2.0.6/src/memory.h +0 -74
  290. data/ext/v8/upstream/2.0.6/src/messages.cc +0 -177
  291. data/ext/v8/upstream/2.0.6/src/messages.h +0 -112
  292. data/ext/v8/upstream/2.0.6/src/messages.js +0 -937
  293. data/ext/v8/upstream/2.0.6/src/mirror-delay.js +0 -2332
  294. data/ext/v8/upstream/2.0.6/src/mksnapshot.cc +0 -169
  295. data/ext/v8/upstream/2.0.6/src/natives.h +0 -63
  296. data/ext/v8/upstream/2.0.6/src/objects-debug.cc +0 -1317
  297. data/ext/v8/upstream/2.0.6/src/objects-inl.h +0 -3044
  298. data/ext/v8/upstream/2.0.6/src/objects.cc +0 -8306
  299. data/ext/v8/upstream/2.0.6/src/objects.h +0 -4960
  300. data/ext/v8/upstream/2.0.6/src/oprofile-agent.cc +0 -116
  301. data/ext/v8/upstream/2.0.6/src/oprofile-agent.h +0 -69
  302. data/ext/v8/upstream/2.0.6/src/parser.cc +0 -4810
  303. data/ext/v8/upstream/2.0.6/src/parser.h +0 -195
  304. data/ext/v8/upstream/2.0.6/src/platform-freebsd.cc +0 -645
  305. data/ext/v8/upstream/2.0.6/src/platform-linux.cc +0 -808
  306. data/ext/v8/upstream/2.0.6/src/platform-macos.cc +0 -643
  307. data/ext/v8/upstream/2.0.6/src/platform-nullos.cc +0 -454
  308. data/ext/v8/upstream/2.0.6/src/platform-openbsd.cc +0 -597
  309. data/ext/v8/upstream/2.0.6/src/platform-posix.cc +0 -380
  310. data/ext/v8/upstream/2.0.6/src/platform-win32.cc +0 -1908
  311. data/ext/v8/upstream/2.0.6/src/platform.h +0 -556
  312. data/ext/v8/upstream/2.0.6/src/prettyprinter.cc +0 -1511
  313. data/ext/v8/upstream/2.0.6/src/prettyprinter.h +0 -219
  314. data/ext/v8/upstream/2.0.6/src/property.cc +0 -96
  315. data/ext/v8/upstream/2.0.6/src/property.h +0 -327
  316. data/ext/v8/upstream/2.0.6/src/regexp-delay.js +0 -406
  317. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp-inl.h +0 -78
  318. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.cc +0 -464
  319. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-irregexp.h +0 -141
  320. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.cc +0 -356
  321. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler-tracer.h +0 -103
  322. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.cc +0 -240
  323. data/ext/v8/upstream/2.0.6/src/regexp-macro-assembler.h +0 -220
  324. data/ext/v8/upstream/2.0.6/src/regexp-stack.cc +0 -103
  325. data/ext/v8/upstream/2.0.6/src/regexp-stack.h +0 -123
  326. data/ext/v8/upstream/2.0.6/src/register-allocator-inl.h +0 -74
  327. data/ext/v8/upstream/2.0.6/src/register-allocator.cc +0 -100
  328. data/ext/v8/upstream/2.0.6/src/register-allocator.h +0 -295
  329. data/ext/v8/upstream/2.0.6/src/rewriter.cc +0 -855
  330. data/ext/v8/upstream/2.0.6/src/rewriter.h +0 -54
  331. data/ext/v8/upstream/2.0.6/src/runtime.cc +0 -8163
  332. data/ext/v8/upstream/2.0.6/src/runtime.h +0 -432
  333. data/ext/v8/upstream/2.0.6/src/runtime.js +0 -626
  334. data/ext/v8/upstream/2.0.6/src/scanner.cc +0 -1098
  335. data/ext/v8/upstream/2.0.6/src/scanner.h +0 -425
  336. data/ext/v8/upstream/2.0.6/src/scopeinfo.cc +0 -649
  337. data/ext/v8/upstream/2.0.6/src/scopeinfo.h +0 -236
  338. data/ext/v8/upstream/2.0.6/src/scopes.cc +0 -963
  339. data/ext/v8/upstream/2.0.6/src/scopes.h +0 -401
  340. data/ext/v8/upstream/2.0.6/src/serialize.cc +0 -1260
  341. data/ext/v8/upstream/2.0.6/src/serialize.h +0 -404
  342. data/ext/v8/upstream/2.0.6/src/shell.h +0 -55
  343. data/ext/v8/upstream/2.0.6/src/simulator.h +0 -41
  344. data/ext/v8/upstream/2.0.6/src/smart-pointer.h +0 -109
  345. data/ext/v8/upstream/2.0.6/src/snapshot-common.cc +0 -97
  346. data/ext/v8/upstream/2.0.6/src/snapshot-empty.cc +0 -40
  347. data/ext/v8/upstream/2.0.6/src/snapshot.h +0 -59
  348. data/ext/v8/upstream/2.0.6/src/spaces-inl.h +0 -372
  349. data/ext/v8/upstream/2.0.6/src/spaces.cc +0 -2864
  350. data/ext/v8/upstream/2.0.6/src/spaces.h +0 -2072
  351. data/ext/v8/upstream/2.0.6/src/string-stream.cc +0 -584
  352. data/ext/v8/upstream/2.0.6/src/string-stream.h +0 -189
  353. data/ext/v8/upstream/2.0.6/src/string.js +0 -901
  354. data/ext/v8/upstream/2.0.6/src/stub-cache.cc +0 -1108
  355. data/ext/v8/upstream/2.0.6/src/stub-cache.h +0 -578
  356. data/ext/v8/upstream/2.0.6/src/third_party/dtoa/COPYING +0 -15
  357. data/ext/v8/upstream/2.0.6/src/third_party/dtoa/dtoa.c +0 -3330
  358. data/ext/v8/upstream/2.0.6/src/third_party/valgrind/valgrind.h +0 -3925
  359. data/ext/v8/upstream/2.0.6/src/token.cc +0 -56
  360. data/ext/v8/upstream/2.0.6/src/token.h +0 -270
  361. data/ext/v8/upstream/2.0.6/src/top.cc +0 -991
  362. data/ext/v8/upstream/2.0.6/src/top.h +0 -459
  363. data/ext/v8/upstream/2.0.6/src/unicode-inl.h +0 -238
  364. data/ext/v8/upstream/2.0.6/src/unicode.cc +0 -749
  365. data/ext/v8/upstream/2.0.6/src/unicode.h +0 -279
  366. data/ext/v8/upstream/2.0.6/src/uri.js +0 -415
  367. data/ext/v8/upstream/2.0.6/src/usage-analyzer.cc +0 -426
  368. data/ext/v8/upstream/2.0.6/src/usage-analyzer.h +0 -40
  369. data/ext/v8/upstream/2.0.6/src/utils.cc +0 -322
  370. data/ext/v8/upstream/2.0.6/src/utils.h +0 -592
  371. data/ext/v8/upstream/2.0.6/src/v8-counters.cc +0 -55
  372. data/ext/v8/upstream/2.0.6/src/v8-counters.h +0 -198
  373. data/ext/v8/upstream/2.0.6/src/v8.cc +0 -193
  374. data/ext/v8/upstream/2.0.6/src/v8.h +0 -119
  375. data/ext/v8/upstream/2.0.6/src/v8natives.js +0 -846
  376. data/ext/v8/upstream/2.0.6/src/v8threads.cc +0 -450
  377. data/ext/v8/upstream/2.0.6/src/v8threads.h +0 -144
  378. data/ext/v8/upstream/2.0.6/src/variables.cc +0 -163
  379. data/ext/v8/upstream/2.0.6/src/variables.h +0 -235
  380. data/ext/v8/upstream/2.0.6/src/version.cc +0 -88
  381. data/ext/v8/upstream/2.0.6/src/version.h +0 -64
  382. data/ext/v8/upstream/2.0.6/src/virtual-frame.cc +0 -381
  383. data/ext/v8/upstream/2.0.6/src/virtual-frame.h +0 -44
  384. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64-inl.h +0 -352
  385. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.cc +0 -2539
  386. data/ext/v8/upstream/2.0.6/src/x64/assembler-x64.h +0 -1399
  387. data/ext/v8/upstream/2.0.6/src/x64/builtins-x64.cc +0 -1255
  388. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64-inl.h +0 -46
  389. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.cc +0 -8223
  390. data/ext/v8/upstream/2.0.6/src/x64/codegen-x64.h +0 -785
  391. data/ext/v8/upstream/2.0.6/src/x64/cpu-x64.cc +0 -79
  392. data/ext/v8/upstream/2.0.6/src/x64/debug-x64.cc +0 -202
  393. data/ext/v8/upstream/2.0.6/src/x64/disasm-x64.cc +0 -1596
  394. data/ext/v8/upstream/2.0.6/src/x64/fast-codegen-x64.cc +0 -1820
  395. data/ext/v8/upstream/2.0.6/src/x64/frames-x64.cc +0 -109
  396. data/ext/v8/upstream/2.0.6/src/x64/frames-x64.h +0 -121
  397. data/ext/v8/upstream/2.0.6/src/x64/ic-x64.cc +0 -1392
  398. data/ext/v8/upstream/2.0.6/src/x64/jump-target-x64.cc +0 -432
  399. data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.cc +0 -2409
  400. data/ext/v8/upstream/2.0.6/src/x64/macro-assembler-x64.h +0 -765
  401. data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.cc +0 -1337
  402. data/ext/v8/upstream/2.0.6/src/x64/regexp-macro-assembler-x64.h +0 -295
  403. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64-inl.h +0 -86
  404. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.cc +0 -84
  405. data/ext/v8/upstream/2.0.6/src/x64/register-allocator-x64.h +0 -43
  406. data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.cc +0 -27
  407. data/ext/v8/upstream/2.0.6/src/x64/simulator-x64.h +0 -63
  408. data/ext/v8/upstream/2.0.6/src/x64/stub-cache-x64.cc +0 -1884
  409. data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.cc +0 -1089
  410. data/ext/v8/upstream/2.0.6/src/x64/virtual-frame-x64.h +0 -560
  411. data/ext/v8/upstream/2.0.6/src/zone-inl.h +0 -297
  412. data/ext/v8/upstream/2.0.6/src/zone.cc +0 -193
  413. data/ext/v8/upstream/2.0.6/src/zone.h +0 -305
  414. data/ext/v8/upstream/2.0.6/tools/codemap.js +0 -258
  415. data/ext/v8/upstream/2.0.6/tools/consarray.js +0 -93
  416. data/ext/v8/upstream/2.0.6/tools/csvparser.js +0 -98
  417. data/ext/v8/upstream/2.0.6/tools/gyp/v8.gyp +0 -620
  418. data/ext/v8/upstream/2.0.6/tools/js2c.py +0 -376
  419. data/ext/v8/upstream/2.0.6/tools/jsmin.py +0 -280
  420. data/ext/v8/upstream/2.0.6/tools/linux-tick-processor +0 -24
  421. data/ext/v8/upstream/2.0.6/tools/linux-tick-processor.py +0 -78
  422. data/ext/v8/upstream/2.0.6/tools/logreader.js +0 -320
  423. data/ext/v8/upstream/2.0.6/tools/mac-nm +0 -18
  424. data/ext/v8/upstream/2.0.6/tools/mac-tick-processor +0 -6
  425. data/ext/v8/upstream/2.0.6/tools/oprofile/annotate +0 -7
  426. data/ext/v8/upstream/2.0.6/tools/oprofile/common +0 -19
  427. data/ext/v8/upstream/2.0.6/tools/oprofile/dump +0 -7
  428. data/ext/v8/upstream/2.0.6/tools/oprofile/report +0 -7
  429. data/ext/v8/upstream/2.0.6/tools/oprofile/reset +0 -7
  430. data/ext/v8/upstream/2.0.6/tools/oprofile/run +0 -14
  431. data/ext/v8/upstream/2.0.6/tools/oprofile/shutdown +0 -7
  432. data/ext/v8/upstream/2.0.6/tools/oprofile/start +0 -7
  433. data/ext/v8/upstream/2.0.6/tools/presubmit.py +0 -299
  434. data/ext/v8/upstream/2.0.6/tools/process-heap-prof.py +0 -120
  435. data/ext/v8/upstream/2.0.6/tools/profile.js +0 -621
  436. data/ext/v8/upstream/2.0.6/tools/profile_view.js +0 -224
  437. data/ext/v8/upstream/2.0.6/tools/run-valgrind.py +0 -77
  438. data/ext/v8/upstream/2.0.6/tools/splaytree.js +0 -322
  439. data/ext/v8/upstream/2.0.6/tools/splaytree.py +0 -226
  440. data/ext/v8/upstream/2.0.6/tools/stats-viewer.py +0 -456
  441. data/ext/v8/upstream/2.0.6/tools/test.py +0 -1370
  442. data/ext/v8/upstream/2.0.6/tools/tickprocessor-driver.js +0 -53
  443. data/ext/v8/upstream/2.0.6/tools/tickprocessor.js +0 -731
  444. data/ext/v8/upstream/2.0.6/tools/tickprocessor.py +0 -535
  445. data/ext/v8/upstream/2.0.6/tools/utils.py +0 -82
  446. data/ext/v8/upstream/2.0.6/tools/visual_studio/README.txt +0 -71
  447. data/ext/v8/upstream/2.0.6/tools/visual_studio/arm.vsprops +0 -14
  448. data/ext/v8/upstream/2.0.6/tools/visual_studio/common.vsprops +0 -35
  449. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8.vcproj +0 -199
  450. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_arm.vcproj +0 -199
  451. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8_x64.vcproj +0 -201
  452. data/ext/v8/upstream/2.0.6/tools/visual_studio/d8js2c.cmd +0 -6
  453. data/ext/v8/upstream/2.0.6/tools/visual_studio/debug.vsprops +0 -17
  454. data/ext/v8/upstream/2.0.6/tools/visual_studio/ia32.vsprops +0 -13
  455. data/ext/v8/upstream/2.0.6/tools/visual_studio/js2c.cmd +0 -6
  456. data/ext/v8/upstream/2.0.6/tools/visual_studio/release.vsprops +0 -24
  457. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.sln +0 -101
  458. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8.vcproj +0 -223
  459. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.sln +0 -74
  460. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_arm.vcproj +0 -223
  461. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base.vcproj +0 -971
  462. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_arm.vcproj +0 -983
  463. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_base_x64.vcproj +0 -959
  464. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest.vcproj +0 -255
  465. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_arm.vcproj +0 -243
  466. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_cctest_x64.vcproj +0 -257
  467. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot.vcproj +0 -151
  468. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -151
  469. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample.vcproj +0 -151
  470. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_arm.vcproj +0 -151
  471. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_process_sample_x64.vcproj +0 -151
  472. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample.vcproj +0 -151
  473. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -151
  474. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -153
  475. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot.vcproj +0 -142
  476. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc.vcproj +0 -92
  477. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -92
  478. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_snapshot_x64.vcproj +0 -142
  479. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.sln +0 -101
  480. data/ext/v8/upstream/2.0.6/tools/visual_studio/v8_x64.vcproj +0 -223
  481. data/ext/v8/upstream/2.0.6/tools/visual_studio/x64.vsprops +0 -13
  482. data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.bat +0 -5
  483. data/ext/v8/upstream/2.0.6/tools/windows-tick-processor.py +0 -137
  484. data/ext/v8/upstream/Makefile +0 -32
  485. data/ext/v8/upstream/fpic-on-linux-amd64.patch +0 -13
  486. data/ext/v8/upstream/no-strict-aliasing.patch +0 -13
  487. data/ext/v8/upstream/scons/CHANGES.txt +0 -5183
  488. data/ext/v8/upstream/scons/LICENSE.txt +0 -20
  489. data/ext/v8/upstream/scons/MANIFEST +0 -202
  490. data/ext/v8/upstream/scons/PKG-INFO +0 -13
  491. data/ext/v8/upstream/scons/README.txt +0 -273
  492. data/ext/v8/upstream/scons/RELEASE.txt +0 -1040
  493. data/ext/v8/upstream/scons/engine/SCons/Action.py +0 -1256
  494. data/ext/v8/upstream/scons/engine/SCons/Builder.py +0 -868
  495. data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +0 -217
  496. data/ext/v8/upstream/scons/engine/SCons/Conftest.py +0 -794
  497. data/ext/v8/upstream/scons/engine/SCons/Debug.py +0 -237
  498. data/ext/v8/upstream/scons/engine/SCons/Defaults.py +0 -485
  499. data/ext/v8/upstream/scons/engine/SCons/Environment.py +0 -2327
  500. data/ext/v8/upstream/scons/engine/SCons/Errors.py +0 -207
  501. data/ext/v8/upstream/scons/engine/SCons/Executor.py +0 -636
  502. data/ext/v8/upstream/scons/engine/SCons/Job.py +0 -435
  503. data/ext/v8/upstream/scons/engine/SCons/Memoize.py +0 -292
  504. data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +0 -153
  505. data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +0 -3220
  506. data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +0 -128
  507. data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +0 -1341
  508. data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +0 -50
  509. data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +0 -50
  510. data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +0 -50
  511. data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +0 -50
  512. data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +0 -76
  513. data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +0 -74
  514. data/ext/v8/upstream/scons/engine/SCons/PathList.py +0 -232
  515. data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +0 -236
  516. data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +0 -70
  517. data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +0 -55
  518. data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +0 -46
  519. data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +0 -46
  520. data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +0 -44
  521. data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +0 -58
  522. data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +0 -264
  523. data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +0 -50
  524. data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +0 -386
  525. data/ext/v8/upstream/scons/engine/SCons/SConf.py +0 -1038
  526. data/ext/v8/upstream/scons/engine/SCons/SConsign.py +0 -381
  527. data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +0 -132
  528. data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +0 -74
  529. data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +0 -111
  530. data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +0 -320
  531. data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +0 -48
  532. data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +0 -378
  533. data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +0 -103
  534. data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +0 -55
  535. data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +0 -415
  536. data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +0 -386
  537. data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +0 -1360
  538. data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +0 -944
  539. data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +0 -642
  540. data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +0 -414
  541. data/ext/v8/upstream/scons/engine/SCons/Sig.py +0 -63
  542. data/ext/v8/upstream/scons/engine/SCons/Subst.py +0 -911
  543. data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +0 -1030
  544. data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +0 -61
  545. data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +0 -65
  546. data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +0 -73
  547. data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +0 -247
  548. data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +0 -324
  549. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +0 -56
  550. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +0 -61
  551. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +0 -210
  552. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +0 -84
  553. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +0 -321
  554. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +0 -367
  555. data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +0 -497
  556. data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +0 -104
  557. data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +0 -138
  558. data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +0 -64
  559. data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +0 -64
  560. data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +0 -71
  561. data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +0 -675
  562. data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +0 -82
  563. data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +0 -74
  564. data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +0 -80
  565. data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +0 -76
  566. data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +0 -71
  567. data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +0 -63
  568. data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +0 -78
  569. data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +0 -82
  570. data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +0 -99
  571. data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +0 -114
  572. data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +0 -58
  573. data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +0 -50
  574. data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +0 -224
  575. data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +0 -64
  576. data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +0 -125
  577. data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +0 -94
  578. data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +0 -62
  579. data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +0 -62
  580. data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +0 -63
  581. data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +0 -98
  582. data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +0 -63
  583. data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +0 -90
  584. data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +0 -73
  585. data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +0 -53
  586. data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +0 -80
  587. data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +0 -64
  588. data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +0 -63
  589. data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +0 -81
  590. data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +0 -85
  591. data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +0 -53
  592. data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +0 -77
  593. data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +0 -59
  594. data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +0 -52
  595. data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +0 -72
  596. data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +0 -90
  597. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +0 -59
  598. data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +0 -60
  599. data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +0 -229
  600. data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +0 -490
  601. data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +0 -71
  602. data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +0 -110
  603. data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +0 -234
  604. data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +0 -138
  605. data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +0 -79
  606. data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +0 -99
  607. data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +0 -121
  608. data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +0 -112
  609. data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +0 -63
  610. data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +0 -77
  611. data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +0 -90
  612. data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +0 -159
  613. data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +0 -64
  614. data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +0 -266
  615. data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +0 -50
  616. data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +0 -269
  617. data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +0 -1439
  618. data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +0 -208
  619. data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +0 -107
  620. data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +0 -72
  621. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +0 -314
  622. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +0 -185
  623. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +0 -526
  624. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +0 -367
  625. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +0 -43
  626. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +0 -43
  627. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +0 -43
  628. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +0 -44
  629. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +0 -44
  630. data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +0 -44
  631. data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +0 -78
  632. data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +0 -83
  633. data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +0 -108
  634. data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +0 -336
  635. data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +0 -121
  636. data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +0 -70
  637. data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +0 -132
  638. data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +0 -68
  639. data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +0 -58
  640. data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +0 -53
  641. data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +0 -63
  642. data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +0 -67
  643. data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +0 -142
  644. data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +0 -58
  645. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +0 -63
  646. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +0 -64
  647. data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +0 -64
  648. data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +0 -77
  649. data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +0 -186
  650. data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +0 -73
  651. data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +0 -805
  652. data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +0 -175
  653. data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +0 -53
  654. data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +0 -100
  655. data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +0 -131
  656. data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +0 -100
  657. data/ext/v8/upstream/scons/engine/SCons/Util.py +0 -1645
  658. data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +0 -91
  659. data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +0 -107
  660. data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +0 -139
  661. data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +0 -109
  662. data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +0 -147
  663. data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +0 -317
  664. data/ext/v8/upstream/scons/engine/SCons/Warnings.py +0 -228
  665. data/ext/v8/upstream/scons/engine/SCons/__init__.py +0 -49
  666. data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +0 -302
  667. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +0 -98
  668. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +0 -91
  669. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +0 -124
  670. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +0 -1725
  671. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +0 -583
  672. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +0 -176
  673. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +0 -325
  674. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +0 -1296
  675. data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +0 -382
  676. data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +0 -187
  677. data/ext/v8/upstream/scons/engine/SCons/cpp.py +0 -598
  678. data/ext/v8/upstream/scons/engine/SCons/dblite.py +0 -248
  679. data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +0 -77
  680. data/ext/v8/upstream/scons/os_spawnv_fix.diff +0 -83
  681. data/ext/v8/upstream/scons/scons-time.1 +0 -1017
  682. data/ext/v8/upstream/scons/scons.1 +0 -15179
  683. data/ext/v8/upstream/scons/sconsign.1 +0 -208
  684. data/ext/v8/upstream/scons/script/scons +0 -184
  685. data/ext/v8/upstream/scons/script/scons-time +0 -1529
  686. data/ext/v8/upstream/scons/script/scons.bat +0 -31
  687. data/ext/v8/upstream/scons/script/sconsign +0 -508
  688. data/ext/v8/upstream/scons/setup.cfg +0 -6
  689. data/ext/v8/upstream/scons/setup.py +0 -427
  690. data/ext/v8/v8.cpp +0 -89
  691. data/ext/v8/v8_cxt.cpp +0 -92
  692. data/ext/v8/v8_cxt.h +0 -20
  693. data/ext/v8/v8_func.cpp +0 -10
  694. data/ext/v8/v8_func.h +0 -11
  695. data/ext/v8/v8_msg.cpp +0 -54
  696. data/ext/v8/v8_msg.h +0 -18
  697. data/ext/v8/v8_obj.cpp +0 -52
  698. data/ext/v8/v8_obj.h +0 -13
  699. data/ext/v8/v8_ref.cpp +0 -26
  700. data/ext/v8/v8_ref.h +0 -31
  701. data/ext/v8/v8_script.cpp +0 -20
  702. data/ext/v8/v8_script.h +0 -8
  703. data/ext/v8/v8_standalone.cpp +0 -69
  704. data/ext/v8/v8_standalone.h +0 -31
  705. data/ext/v8/v8_str.cpp +0 -17
  706. data/ext/v8/v8_str.h +0 -9
  707. data/ext/v8/v8_template.cpp +0 -53
  708. data/ext/v8/v8_template.h +0 -13
  709. data/lib/v8/to.rb +0 -33
  710. data/lib/v8/v8.so +0 -0
  711. data/script/console +0 -10
  712. data/script/destroy +0 -14
  713. data/script/generate +0 -14
  714. data/spec/ext/cxt_spec.rb +0 -25
  715. data/spec/ext/obj_spec.rb +0 -13
  716. data/spec/redjs/jsapi_spec.rb +0 -405
  717. data/spec/redjs/tap.rb +0 -8
  718. data/spec/redjs_helper.rb +0 -3
  719. data/spec/spec.opts +0 -1
  720. data/spec/v8/to_spec.rb +0 -15
  721. data/tasks/rspec.rake +0 -21
@@ -1,1399 +0,0 @@
1
- // Copyright (c) 1994-2006 Sun Microsystems Inc.
2
- // All Rights Reserved.
3
- //
4
- // Redistribution and use in source and binary forms, with or without
5
- // modification, are permitted provided that the following conditions are
6
- // met:
7
- //
8
- // - Redistributions of source code must retain the above copyright notice,
9
- // this list of conditions and the following disclaimer.
10
- //
11
- // - Redistribution in binary form must reproduce the above copyright
12
- // notice, this list of conditions and the following disclaimer in the
13
- // documentation and/or other materials provided with the distribution.
14
- //
15
- // - Neither the name of Sun Microsystems or the names of contributors may
16
- // be used to endorse or promote products derived from this software without
17
- // specific prior written permission.
18
- //
19
- // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
20
- // IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21
- // THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22
- // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
23
- // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24
- // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25
- // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
26
- // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
27
- // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28
- // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29
- // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
-
31
- // The original source code covered by the above license above has been
32
- // modified significantly by Google Inc.
33
- // Copyright 2006-2009 the V8 project authors. All rights reserved.
34
-
35
- // A lightweight X64 Assembler.
36
-
37
- #ifndef V8_X64_ASSEMBLER_X64_H_
38
- #define V8_X64_ASSEMBLER_X64_H_
39
-
40
- #include "serialize.h"
41
-
42
- namespace v8 {
43
- namespace internal {
44
-
45
- // Utility functions
46
-
47
- // Test whether a 64-bit value is in a specific range.
48
- static inline bool is_uint32(int64_t x) {
49
- static const int64_t kUInt32Mask = V8_INT64_C(0xffffffff);
50
- return x == (x & kUInt32Mask);
51
- }
52
-
53
- static inline bool is_int32(int64_t x) {
54
- static const int64_t kMinIntValue = V8_INT64_C(-0x80000000);
55
- return is_uint32(x - kMinIntValue);
56
- }
57
-
58
- static inline bool uint_is_int32(uint64_t x) {
59
- static const uint64_t kMaxIntValue = V8_UINT64_C(0x80000000);
60
- return x < kMaxIntValue;
61
- }
62
-
63
- static inline bool is_uint32(uint64_t x) {
64
- static const uint64_t kMaxUIntValue = V8_UINT64_C(0x100000000);
65
- return x < kMaxUIntValue;
66
- }
67
-
68
- // CPU Registers.
69
- //
70
- // 1) We would prefer to use an enum, but enum values are assignment-
71
- // compatible with int, which has caused code-generation bugs.
72
- //
73
- // 2) We would prefer to use a class instead of a struct but we don't like
74
- // the register initialization to depend on the particular initialization
75
- // order (which appears to be different on OS X, Linux, and Windows for the
76
- // installed versions of C++ we tried). Using a struct permits C-style
77
- // "initialization". Also, the Register objects cannot be const as this
78
- // forces initialization stubs in MSVC, making us dependent on initialization
79
- // order.
80
- //
81
- // 3) By not using an enum, we are possibly preventing the compiler from
82
- // doing certain constant folds, which may significantly reduce the
83
- // code generated for some assembly instructions (because they boil down
84
- // to a few constants). If this is a problem, we could change the code
85
- // such that we use an enum in optimized mode, and the struct in debug
86
- // mode. This way we get the compile-time error checking in debug mode
87
- // and best performance in optimized code.
88
- //
89
-
90
- struct Register {
91
- static Register toRegister(int code) {
92
- Register r = { code };
93
- return r;
94
- }
95
- bool is_valid() const { return 0 <= code_ && code_ < 16; }
96
- bool is(Register reg) const { return code_ == reg.code_; }
97
- int code() const {
98
- ASSERT(is_valid());
99
- return code_;
100
- }
101
- int bit() const {
102
- return 1 << code_;
103
- }
104
-
105
- // Return the high bit of the register code as a 0 or 1. Used often
106
- // when constructing the REX prefix byte.
107
- int high_bit() const {
108
- return code_ >> 3;
109
- }
110
- // Return the 3 low bits of the register code. Used when encoding registers
111
- // in modR/M, SIB, and opcode bytes.
112
- int low_bits() const {
113
- return code_ & 0x7;
114
- }
115
-
116
- // (unfortunately we can't make this private in a struct when initializing
117
- // by assignment.)
118
- int code_;
119
- };
120
-
121
- extern Register rax;
122
- extern Register rcx;
123
- extern Register rdx;
124
- extern Register rbx;
125
- extern Register rsp;
126
- extern Register rbp;
127
- extern Register rsi;
128
- extern Register rdi;
129
- extern Register r8;
130
- extern Register r9;
131
- extern Register r10;
132
- extern Register r11;
133
- extern Register r12;
134
- extern Register r13;
135
- extern Register r14;
136
- extern Register r15;
137
- extern Register no_reg;
138
-
139
-
140
- struct MMXRegister {
141
- bool is_valid() const { return 0 <= code_ && code_ < 2; }
142
- int code() const {
143
- ASSERT(is_valid());
144
- return code_;
145
- }
146
-
147
- int code_;
148
- };
149
-
150
- extern MMXRegister mm0;
151
- extern MMXRegister mm1;
152
- extern MMXRegister mm2;
153
- extern MMXRegister mm3;
154
- extern MMXRegister mm4;
155
- extern MMXRegister mm5;
156
- extern MMXRegister mm6;
157
- extern MMXRegister mm7;
158
- extern MMXRegister mm8;
159
- extern MMXRegister mm9;
160
- extern MMXRegister mm10;
161
- extern MMXRegister mm11;
162
- extern MMXRegister mm12;
163
- extern MMXRegister mm13;
164
- extern MMXRegister mm14;
165
- extern MMXRegister mm15;
166
-
167
-
168
- struct XMMRegister {
169
- bool is_valid() const { return 0 <= code_ && code_ < 16; }
170
- int code() const {
171
- ASSERT(is_valid());
172
- return code_;
173
- }
174
-
175
- // Return the high bit of the register code as a 0 or 1. Used often
176
- // when constructing the REX prefix byte.
177
- int high_bit() const {
178
- return code_ >> 3;
179
- }
180
- // Return the 3 low bits of the register code. Used when encoding registers
181
- // in modR/M, SIB, and opcode bytes.
182
- int low_bits() const {
183
- return code_ & 0x7;
184
- }
185
-
186
- int code_;
187
- };
188
-
189
- extern XMMRegister xmm0;
190
- extern XMMRegister xmm1;
191
- extern XMMRegister xmm2;
192
- extern XMMRegister xmm3;
193
- extern XMMRegister xmm4;
194
- extern XMMRegister xmm5;
195
- extern XMMRegister xmm6;
196
- extern XMMRegister xmm7;
197
- extern XMMRegister xmm8;
198
- extern XMMRegister xmm9;
199
- extern XMMRegister xmm10;
200
- extern XMMRegister xmm11;
201
- extern XMMRegister xmm12;
202
- extern XMMRegister xmm13;
203
- extern XMMRegister xmm14;
204
- extern XMMRegister xmm15;
205
-
206
- enum Condition {
207
- // any value < 0 is considered no_condition
208
- no_condition = -1,
209
-
210
- overflow = 0,
211
- no_overflow = 1,
212
- below = 2,
213
- above_equal = 3,
214
- equal = 4,
215
- not_equal = 5,
216
- below_equal = 6,
217
- above = 7,
218
- negative = 8,
219
- positive = 9,
220
- parity_even = 10,
221
- parity_odd = 11,
222
- less = 12,
223
- greater_equal = 13,
224
- less_equal = 14,
225
- greater = 15,
226
-
227
- // Fake conditions that are handled by the
228
- // opcodes using them.
229
- always = 16,
230
- never = 17,
231
- // aliases
232
- carry = below,
233
- not_carry = above_equal,
234
- zero = equal,
235
- not_zero = not_equal,
236
- sign = negative,
237
- not_sign = positive,
238
- last_condition = greater
239
- };
240
-
241
-
242
- // Returns the equivalent of !cc.
243
- // Negation of the default no_condition (-1) results in a non-default
244
- // no_condition value (-2). As long as tests for no_condition check
245
- // for condition < 0, this will work as expected.
246
- inline Condition NegateCondition(Condition cc);
247
-
248
- // Corresponds to transposing the operands of a comparison.
249
- inline Condition ReverseCondition(Condition cc) {
250
- switch (cc) {
251
- case below:
252
- return above;
253
- case above:
254
- return below;
255
- case above_equal:
256
- return below_equal;
257
- case below_equal:
258
- return above_equal;
259
- case less:
260
- return greater;
261
- case greater:
262
- return less;
263
- case greater_equal:
264
- return less_equal;
265
- case less_equal:
266
- return greater_equal;
267
- default:
268
- return cc;
269
- };
270
- }
271
-
272
- enum Hint {
273
- no_hint = 0,
274
- not_taken = 0x2e,
275
- taken = 0x3e
276
- };
277
-
278
- // The result of negating a hint is as if the corresponding condition
279
- // were negated by NegateCondition. That is, no_hint is mapped to
280
- // itself and not_taken and taken are mapped to each other.
281
- inline Hint NegateHint(Hint hint) {
282
- return (hint == no_hint)
283
- ? no_hint
284
- : ((hint == not_taken) ? taken : not_taken);
285
- }
286
-
287
-
288
- // -----------------------------------------------------------------------------
289
- // Machine instruction Immediates
290
-
291
- class Immediate BASE_EMBEDDED {
292
- public:
293
- explicit Immediate(int32_t value) : value_(value) {}
294
-
295
- private:
296
- int32_t value_;
297
-
298
- friend class Assembler;
299
- };
300
-
301
-
302
- // -----------------------------------------------------------------------------
303
- // Machine instruction Operands
304
-
305
- enum ScaleFactor {
306
- times_1 = 0,
307
- times_2 = 1,
308
- times_4 = 2,
309
- times_8 = 3,
310
- times_int_size = times_4,
311
- times_half_pointer_size = times_4,
312
- times_pointer_size = times_8
313
- };
314
-
315
-
316
- class Operand BASE_EMBEDDED {
317
- public:
318
- // [base + disp/r]
319
- Operand(Register base, int32_t disp);
320
-
321
- // [base + index*scale + disp/r]
322
- Operand(Register base,
323
- Register index,
324
- ScaleFactor scale,
325
- int32_t disp);
326
-
327
- // [index*scale + disp/r]
328
- Operand(Register index,
329
- ScaleFactor scale,
330
- int32_t disp);
331
-
332
- private:
333
- byte rex_;
334
- byte buf_[10];
335
- // The number of bytes in buf_.
336
- unsigned int len_;
337
- RelocInfo::Mode rmode_;
338
-
339
- // Set the ModR/M byte without an encoded 'reg' register. The
340
- // register is encoded later as part of the emit_operand operation.
341
- // set_modrm can be called before or after set_sib and set_disp*.
342
- inline void set_modrm(int mod, Register rm);
343
-
344
- // Set the SIB byte if one is needed. Sets the length to 2 rather than 1.
345
- inline void set_sib(ScaleFactor scale, Register index, Register base);
346
-
347
- // Adds operand displacement fields (offsets added to the memory address).
348
- // Needs to be called after set_sib, not before it.
349
- inline void set_disp8(int disp);
350
- inline void set_disp32(int disp);
351
-
352
- friend class Assembler;
353
- };
354
-
355
-
356
- // CpuFeatures keeps track of which features are supported by the target CPU.
357
- // Supported features must be enabled by a Scope before use.
358
- // Example:
359
- // if (CpuFeatures::IsSupported(SSE3)) {
360
- // CpuFeatures::Scope fscope(SSE3);
361
- // // Generate SSE3 floating point code.
362
- // } else {
363
- // // Generate standard x87 or SSE2 floating point code.
364
- // }
365
- class CpuFeatures : public AllStatic {
366
- public:
367
- // Detect features of the target CPU. Set safe defaults if the serializer
368
- // is enabled (snapshots must be portable).
369
- static void Probe();
370
- // Check whether a feature is supported by the target CPU.
371
- static bool IsSupported(CpuFeature f) {
372
- if (f == SSE2 && !FLAG_enable_sse2) return false;
373
- if (f == SSE3 && !FLAG_enable_sse3) return false;
374
- if (f == CMOV && !FLAG_enable_cmov) return false;
375
- if (f == RDTSC && !FLAG_enable_rdtsc) return false;
376
- if (f == SAHF && !FLAG_enable_sahf) return false;
377
- return (supported_ & (V8_UINT64_C(1) << f)) != 0;
378
- }
379
- // Check whether a feature is currently enabled.
380
- static bool IsEnabled(CpuFeature f) {
381
- return (enabled_ & (V8_UINT64_C(1) << f)) != 0;
382
- }
383
- // Enable a specified feature within a scope.
384
- class Scope BASE_EMBEDDED {
385
- #ifdef DEBUG
386
- public:
387
- explicit Scope(CpuFeature f) {
388
- uint64_t mask = (V8_UINT64_C(1) << f);
389
- ASSERT(CpuFeatures::IsSupported(f));
390
- ASSERT(!Serializer::enabled() || (found_by_runtime_probing_ & mask) == 0);
391
- old_enabled_ = CpuFeatures::enabled_;
392
- CpuFeatures::enabled_ |= mask;
393
- }
394
- ~Scope() { CpuFeatures::enabled_ = old_enabled_; }
395
- private:
396
- uint64_t old_enabled_;
397
- #else
398
- public:
399
- explicit Scope(CpuFeature f) {}
400
- #endif
401
- };
402
- private:
403
- // Safe defaults include SSE2 and CMOV for X64. It is always available, if
404
- // anyone checks, but they shouldn't need to check.
405
- static const uint64_t kDefaultCpuFeatures = (1 << SSE2 | 1 << CMOV);
406
- static uint64_t supported_;
407
- static uint64_t enabled_;
408
- static uint64_t found_by_runtime_probing_;
409
- };
410
-
411
-
412
- class Assembler : public Malloced {
413
- private:
414
- // We check before assembling an instruction that there is sufficient
415
- // space to write an instruction and its relocation information.
416
- // The relocation writer's position must be kGap bytes above the end of
417
- // the generated instructions. This leaves enough space for the
418
- // longest possible x64 instruction, 15 bytes, and the longest possible
419
- // relocation information encoding, RelocInfoWriter::kMaxLength == 16.
420
- // (There is a 15 byte limit on x64 instruction length that rules out some
421
- // otherwise valid instructions.)
422
- // This allows for a single, fast space check per instruction.
423
- static const int kGap = 32;
424
-
425
- public:
426
- // Create an assembler. Instructions and relocation information are emitted
427
- // into a buffer, with the instructions starting from the beginning and the
428
- // relocation information starting from the end of the buffer. See CodeDesc
429
- // for a detailed comment on the layout (globals.h).
430
- //
431
- // If the provided buffer is NULL, the assembler allocates and grows its own
432
- // buffer, and buffer_size determines the initial buffer size. The buffer is
433
- // owned by the assembler and deallocated upon destruction of the assembler.
434
- //
435
- // If the provided buffer is not NULL, the assembler uses the provided buffer
436
- // for code generation and assumes its size to be buffer_size. If the buffer
437
- // is too small, a fatal error occurs. No deallocation of the buffer is done
438
- // upon destruction of the assembler.
439
- Assembler(void* buffer, int buffer_size);
440
- ~Assembler();
441
-
442
- // GetCode emits any pending (non-emitted) code and fills the descriptor
443
- // desc. GetCode() is idempotent; it returns the same result if no other
444
- // Assembler functions are invoked in between GetCode() calls.
445
- void GetCode(CodeDesc* desc);
446
-
447
- // Read/Modify the code target in the relative branch/call instruction at pc.
448
- // On the x64 architecture, we use relative jumps with a 32-bit displacement
449
- // to jump to other Code objects in the Code space in the heap.
450
- // Jumps to C functions are done indirectly through a 64-bit register holding
451
- // the absolute address of the target.
452
- // These functions convert between absolute Addresses of Code objects and
453
- // the relative displacements stored in the code.
454
- static inline Address target_address_at(Address pc);
455
- static inline void set_target_address_at(Address pc, Address target);
456
-
457
- // This sets the branch destination (which is in the instruction on x64).
458
- // This is for calls and branches within generated code.
459
- inline static void set_target_at(Address instruction_payload,
460
- Address target) {
461
- set_target_address_at(instruction_payload, target);
462
- }
463
-
464
- // This sets the branch destination (which is a load instruction on x64).
465
- // This is for calls and branches to runtime code.
466
- inline static void set_external_target_at(Address instruction_payload,
467
- Address target) {
468
- *reinterpret_cast<Address*>(instruction_payload) = target;
469
- }
470
-
471
- inline Handle<Object> code_target_object_handle_at(Address pc);
472
- // Number of bytes taken up by the branch target in the code.
473
- static const int kCallTargetSize = 4; // Use 32-bit displacement.
474
- static const int kExternalTargetSize = 8; // Use 64-bit absolute.
475
- // Distance between the address of the code target in the call instruction
476
- // and the return address pushed on the stack.
477
- static const int kCallTargetAddressOffset = 4; // Use 32-bit displacement.
478
- // Distance between the start of the JS return sequence and where the
479
- // 32-bit displacement of a near call would be, relative to the pushed
480
- // return address. TODO: Use return sequence length instead.
481
- // Should equal Debug::kX64JSReturnSequenceLength - kCallTargetAddressOffset;
482
- static const int kPatchReturnSequenceAddressOffset = 13 - 4;
483
- // TODO(X64): Rename this, removing the "Real", after changing the above.
484
- static const int kRealPatchReturnSequenceAddressOffset = 2;
485
-
486
- // The x64 JS return sequence is padded with int3 to make it large
487
- // enough to hold a call instruction when the debugger patches it.
488
- static const int kCallInstructionLength = 13;
489
- static const int kJSReturnSequenceLength = 13;
490
-
491
- // ---------------------------------------------------------------------------
492
- // Code generation
493
- //
494
- // Function names correspond one-to-one to x64 instruction mnemonics.
495
- // Unless specified otherwise, instructions operate on 64-bit operands.
496
- //
497
- // If we need versions of an assembly instruction that operate on different
498
- // width arguments, we add a single-letter suffix specifying the width.
499
- // This is done for the following instructions: mov, cmp, inc, dec,
500
- // add, sub, and test.
501
- // There are no versions of these instructions without the suffix.
502
- // - Instructions on 8-bit (byte) operands/registers have a trailing 'b'.
503
- // - Instructions on 16-bit (word) operands/registers have a trailing 'w'.
504
- // - Instructions on 32-bit (doubleword) operands/registers use 'l'.
505
- // - Instructions on 64-bit (quadword) operands/registers use 'q'.
506
- //
507
- // Some mnemonics, such as "and", are the same as C++ keywords.
508
- // Naming conflicts with C++ keywords are resolved by adding a trailing '_'.
509
-
510
- // Insert the smallest number of nop instructions
511
- // possible to align the pc offset to a multiple
512
- // of m. m must be a power of 2.
513
- void Align(int m);
514
-
515
- // Stack
516
- void pushfq();
517
- void popfq();
518
-
519
- void push(Immediate value);
520
- void push(Register src);
521
- void push(const Operand& src);
522
- void push(Label* label, RelocInfo::Mode relocation_mode);
523
-
524
- void pop(Register dst);
525
- void pop(const Operand& dst);
526
-
527
- void enter(Immediate size);
528
- void leave();
529
-
530
- // Moves
531
- void movb(Register dst, const Operand& src);
532
- void movb(Register dst, Immediate imm);
533
- void movb(const Operand& dst, Register src);
534
-
535
- // Move the low 16 bits of a 64-bit register value to a 16-bit
536
- // memory location.
537
- void movw(const Operand& dst, Register src);
538
-
539
- void movl(Register dst, Register src);
540
- void movl(Register dst, const Operand& src);
541
- void movl(const Operand& dst, Register src);
542
- void movl(const Operand& dst, Immediate imm);
543
- // Load a 32-bit immediate value, zero-extended to 64 bits.
544
- void movl(Register dst, Immediate imm32);
545
-
546
- // Move 64 bit register value to 64-bit memory location.
547
- void movq(const Operand& dst, Register src);
548
- // Move 64 bit memory location to 64-bit register value.
549
- void movq(Register dst, const Operand& src);
550
- void movq(Register dst, Register src);
551
- // Sign extends immediate 32-bit value to 64 bits.
552
- void movq(Register dst, Immediate x);
553
- // Move the offset of the label location relative to the current
554
- // position (after the move) to the destination.
555
- void movl(const Operand& dst, Label* src);
556
-
557
- // Move sign extended immediate to memory location.
558
- void movq(const Operand& dst, Immediate value);
559
- // New x64 instructions to load a 64-bit immediate into a register.
560
- // All 64-bit immediates must have a relocation mode.
561
- void movq(Register dst, void* ptr, RelocInfo::Mode rmode);
562
- void movq(Register dst, int64_t value, RelocInfo::Mode rmode);
563
- void movq(Register dst, const char* s, RelocInfo::Mode rmode);
564
- // Moves the address of the external reference into the register.
565
- void movq(Register dst, ExternalReference ext);
566
- void movq(Register dst, Handle<Object> handle, RelocInfo::Mode rmode);
567
-
568
- void movsxbq(Register dst, const Operand& src);
569
- void movsxwq(Register dst, const Operand& src);
570
- void movsxlq(Register dst, Register src);
571
- void movsxlq(Register dst, const Operand& src);
572
- void movzxbq(Register dst, const Operand& src);
573
- void movzxbl(Register dst, const Operand& src);
574
- void movzxwq(Register dst, const Operand& src);
575
- void movzxwl(Register dst, const Operand& src);
576
-
577
- // New x64 instruction to load from an immediate 64-bit pointer into RAX.
578
- void load_rax(void* ptr, RelocInfo::Mode rmode);
579
- void load_rax(ExternalReference ext);
580
-
581
- // Conditional moves.
582
- void cmovq(Condition cc, Register dst, Register src);
583
- void cmovq(Condition cc, Register dst, const Operand& src);
584
- void cmovl(Condition cc, Register dst, Register src);
585
- void cmovl(Condition cc, Register dst, const Operand& src);
586
-
587
- // Exchange two registers
588
- void xchg(Register dst, Register src);
589
-
590
- // Arithmetics
591
- void addl(Register dst, Register src) {
592
- if (dst.low_bits() == 4) { // Forces SIB byte.
593
- arithmetic_op_32(0x01, src, dst);
594
- } else {
595
- arithmetic_op_32(0x03, dst, src);
596
- }
597
- }
598
-
599
- void addl(Register dst, Immediate src) {
600
- immediate_arithmetic_op_32(0x0, dst, src);
601
- }
602
-
603
- void addl(Register dst, const Operand& src) {
604
- arithmetic_op_32(0x03, dst, src);
605
- }
606
-
607
- void addl(const Operand& dst, Immediate src) {
608
- immediate_arithmetic_op_32(0x0, dst, src);
609
- }
610
-
611
- void addq(Register dst, Register src) {
612
- arithmetic_op(0x03, dst, src);
613
- }
614
-
615
- void addq(Register dst, const Operand& src) {
616
- arithmetic_op(0x03, dst, src);
617
- }
618
-
619
- void addq(const Operand& dst, Register src) {
620
- arithmetic_op(0x01, src, dst);
621
- }
622
-
623
- void addq(Register dst, Immediate src) {
624
- immediate_arithmetic_op(0x0, dst, src);
625
- }
626
-
627
- void addq(const Operand& dst, Immediate src) {
628
- immediate_arithmetic_op(0x0, dst, src);
629
- }
630
-
631
- void cmpb(Register dst, Immediate src) {
632
- immediate_arithmetic_op_8(0x7, dst, src);
633
- }
634
-
635
- void cmpb_al(Immediate src);
636
-
637
- void cmpb(Register dst, Register src) {
638
- arithmetic_op(0x3A, dst, src);
639
- }
640
-
641
- void cmpb(Register dst, const Operand& src) {
642
- arithmetic_op(0x3A, dst, src);
643
- }
644
-
645
- void cmpb(const Operand& dst, Register src) {
646
- arithmetic_op(0x38, src, dst);
647
- }
648
-
649
- void cmpb(const Operand& dst, Immediate src) {
650
- immediate_arithmetic_op_8(0x7, dst, src);
651
- }
652
-
653
- void cmpw(const Operand& dst, Immediate src) {
654
- immediate_arithmetic_op_16(0x7, dst, src);
655
- }
656
-
657
- void cmpw(Register dst, Immediate src) {
658
- immediate_arithmetic_op_16(0x7, dst, src);
659
- }
660
-
661
- void cmpw(Register dst, const Operand& src) {
662
- arithmetic_op_16(0x3B, dst, src);
663
- }
664
-
665
- void cmpw(Register dst, Register src) {
666
- arithmetic_op_16(0x3B, dst, src);
667
- }
668
-
669
- void cmpw(const Operand& dst, Register src) {
670
- arithmetic_op_16(0x39, src, dst);
671
- }
672
-
673
- void cmpl(Register dst, Register src) {
674
- arithmetic_op_32(0x3B, dst, src);
675
- }
676
-
677
- void cmpl(Register dst, const Operand& src) {
678
- arithmetic_op_32(0x3B, dst, src);
679
- }
680
-
681
- void cmpl(const Operand& dst, Register src) {
682
- arithmetic_op_32(0x39, src, dst);
683
- }
684
-
685
- void cmpl(Register dst, Immediate src) {
686
- immediate_arithmetic_op_32(0x7, dst, src);
687
- }
688
-
689
- void cmpl(const Operand& dst, Immediate src) {
690
- immediate_arithmetic_op_32(0x7, dst, src);
691
- }
692
-
693
- void cmpq(Register dst, Register src) {
694
- arithmetic_op(0x3B, dst, src);
695
- }
696
-
697
- void cmpq(Register dst, const Operand& src) {
698
- arithmetic_op(0x3B, dst, src);
699
- }
700
-
701
- void cmpq(const Operand& dst, Register src) {
702
- arithmetic_op(0x39, src, dst);
703
- }
704
-
705
- void cmpq(Register dst, Immediate src) {
706
- immediate_arithmetic_op(0x7, dst, src);
707
- }
708
-
709
- void cmpq(const Operand& dst, Immediate src) {
710
- immediate_arithmetic_op(0x7, dst, src);
711
- }
712
-
713
- void and_(Register dst, Register src) {
714
- arithmetic_op(0x23, dst, src);
715
- }
716
-
717
- void and_(Register dst, const Operand& src) {
718
- arithmetic_op(0x23, dst, src);
719
- }
720
-
721
- void and_(const Operand& dst, Register src) {
722
- arithmetic_op(0x21, src, dst);
723
- }
724
-
725
- void and_(Register dst, Immediate src) {
726
- immediate_arithmetic_op(0x4, dst, src);
727
- }
728
-
729
- void and_(const Operand& dst, Immediate src) {
730
- immediate_arithmetic_op(0x4, dst, src);
731
- }
732
-
733
- void andl(Register dst, Immediate src) {
734
- immediate_arithmetic_op_32(0x4, dst, src);
735
- }
736
-
737
- void andl(Register dst, Register src) {
738
- arithmetic_op_32(0x23, dst, src);
739
- }
740
-
741
-
742
- void decq(Register dst);
743
- void decq(const Operand& dst);
744
- void decl(Register dst);
745
- void decl(const Operand& dst);
746
- void decb(Register dst);
747
- void decb(const Operand& dst);
748
-
749
- // Sign-extends rax into rdx:rax.
750
- void cqo();
751
- // Sign-extends eax into edx:eax.
752
- void cdq();
753
-
754
- // Divide rdx:rax by src. Quotient in rax, remainder in rdx.
755
- void idivq(Register src);
756
- // Divide edx:eax by lower 32 bits of src. Quotient in eax, rem. in edx.
757
- void idivl(Register src);
758
-
759
- // Signed multiply instructions.
760
- void imul(Register src); // rdx:rax = rax * src.
761
- void imul(Register dst, Register src); // dst = dst * src.
762
- void imul(Register dst, const Operand& src); // dst = dst * src.
763
- void imul(Register dst, Register src, Immediate imm); // dst = src * imm.
764
- // Multiply 32 bit registers
765
- void imull(Register dst, Register src); // dst = dst * src.
766
-
767
- void incq(Register dst);
768
- void incq(const Operand& dst);
769
- void incl(const Operand& dst);
770
-
771
- void lea(Register dst, const Operand& src);
772
-
773
- // Multiply rax by src, put the result in rdx:rax.
774
- void mul(Register src);
775
-
776
- void neg(Register dst);
777
- void neg(const Operand& dst);
778
- void negl(Register dst);
779
-
780
- void not_(Register dst);
781
- void not_(const Operand& dst);
782
-
783
- void or_(Register dst, Register src) {
784
- arithmetic_op(0x0B, dst, src);
785
- }
786
-
787
- void orl(Register dst, Register src) {
788
- arithmetic_op_32(0x0B, dst, src);
789
- }
790
-
791
- void or_(Register dst, const Operand& src) {
792
- arithmetic_op(0x0B, dst, src);
793
- }
794
-
795
- void or_(const Operand& dst, Register src) {
796
- arithmetic_op(0x09, src, dst);
797
- }
798
-
799
- void or_(Register dst, Immediate src) {
800
- immediate_arithmetic_op(0x1, dst, src);
801
- }
802
-
803
- void orl(Register dst, Immediate src) {
804
- immediate_arithmetic_op_32(0x1, dst, src);
805
- }
806
-
807
- void or_(const Operand& dst, Immediate src) {
808
- immediate_arithmetic_op(0x1, dst, src);
809
- }
810
-
811
- void orl(const Operand& dst, Immediate src) {
812
- immediate_arithmetic_op_32(0x1, dst, src);
813
- }
814
-
815
-
816
- void rcl(Register dst, Immediate imm8) {
817
- shift(dst, imm8, 0x2);
818
- }
819
-
820
- void rol(Register dst, Immediate imm8) {
821
- shift(dst, imm8, 0x0);
822
- }
823
-
824
- void rcr(Register dst, Immediate imm8) {
825
- shift(dst, imm8, 0x3);
826
- }
827
-
828
- void ror(Register dst, Immediate imm8) {
829
- shift(dst, imm8, 0x1);
830
- }
831
-
832
- // Shifts dst:src left by cl bits, affecting only dst.
833
- void shld(Register dst, Register src);
834
-
835
- // Shifts src:dst right by cl bits, affecting only dst.
836
- void shrd(Register dst, Register src);
837
-
838
- // Shifts dst right, duplicating sign bit, by shift_amount bits.
839
- // Shifting by 1 is handled efficiently.
840
- void sar(Register dst, Immediate shift_amount) {
841
- shift(dst, shift_amount, 0x7);
842
- }
843
-
844
- // Shifts dst right, duplicating sign bit, by shift_amount bits.
845
- // Shifting by 1 is handled efficiently.
846
- void sarl(Register dst, Immediate shift_amount) {
847
- shift_32(dst, shift_amount, 0x7);
848
- }
849
-
850
- // Shifts dst right, duplicating sign bit, by cl % 64 bits.
851
- void sar_cl(Register dst) {
852
- shift(dst, 0x7);
853
- }
854
-
855
- // Shifts dst right, duplicating sign bit, by cl % 64 bits.
856
- void sarl_cl(Register dst) {
857
- shift_32(dst, 0x7);
858
- }
859
-
860
- void shl(Register dst, Immediate shift_amount) {
861
- shift(dst, shift_amount, 0x4);
862
- }
863
-
864
- void shl_cl(Register dst) {
865
- shift(dst, 0x4);
866
- }
867
-
868
- void shll_cl(Register dst) {
869
- shift_32(dst, 0x4);
870
- }
871
-
872
- void shll(Register dst, Immediate shift_amount) {
873
- shift_32(dst, shift_amount, 0x4);
874
- }
875
-
876
- void shr(Register dst, Immediate shift_amount) {
877
- shift(dst, shift_amount, 0x5);
878
- }
879
-
880
- void shr_cl(Register dst) {
881
- shift(dst, 0x5);
882
- }
883
-
884
- void shrl_cl(Register dst) {
885
- shift_32(dst, 0x5);
886
- }
887
-
888
- void shrl(Register dst, Immediate shift_amount) {
889
- shift_32(dst, shift_amount, 0x5);
890
- }
891
-
892
- void store_rax(void* dst, RelocInfo::Mode mode);
893
- void store_rax(ExternalReference ref);
894
-
895
- void subq(Register dst, Register src) {
896
- arithmetic_op(0x2B, dst, src);
897
- }
898
-
899
- void subq(Register dst, const Operand& src) {
900
- arithmetic_op(0x2B, dst, src);
901
- }
902
-
903
- void subq(const Operand& dst, Register src) {
904
- arithmetic_op(0x29, src, dst);
905
- }
906
-
907
- void subq(Register dst, Immediate src) {
908
- immediate_arithmetic_op(0x5, dst, src);
909
- }
910
-
911
- void subq(const Operand& dst, Immediate src) {
912
- immediate_arithmetic_op(0x5, dst, src);
913
- }
914
-
915
- void subl(Register dst, Register src) {
916
- arithmetic_op_32(0x2B, dst, src);
917
- }
918
-
919
- void subl(const Operand& dst, Immediate src) {
920
- immediate_arithmetic_op_32(0x5, dst, src);
921
- }
922
-
923
- void subl(Register dst, Immediate src) {
924
- immediate_arithmetic_op_32(0x5, dst, src);
925
- }
926
-
927
- void subb(Register dst, Immediate src) {
928
- immediate_arithmetic_op_8(0x5, dst, src);
929
- }
930
-
931
- void testb(Register dst, Register src);
932
- void testb(Register reg, Immediate mask);
933
- void testb(const Operand& op, Immediate mask);
934
- void testl(Register dst, Register src);
935
- void testl(Register reg, Immediate mask);
936
- void testl(const Operand& op, Immediate mask);
937
- void testq(const Operand& op, Register reg);
938
- void testq(Register dst, Register src);
939
- void testq(Register dst, Immediate mask);
940
-
941
- void xor_(Register dst, Register src) {
942
- if (dst.code() == src.code()) {
943
- arithmetic_op_32(0x33, dst, src);
944
- } else {
945
- arithmetic_op(0x33, dst, src);
946
- }
947
- }
948
-
949
- void xorl(Register dst, Register src) {
950
- arithmetic_op_32(0x33, dst, src);
951
- }
952
-
953
- void xor_(Register dst, const Operand& src) {
954
- arithmetic_op(0x33, dst, src);
955
- }
956
-
957
- void xor_(const Operand& dst, Register src) {
958
- arithmetic_op(0x31, src, dst);
959
- }
960
-
961
- void xor_(Register dst, Immediate src) {
962
- immediate_arithmetic_op(0x6, dst, src);
963
- }
964
-
965
- void xor_(const Operand& dst, Immediate src) {
966
- immediate_arithmetic_op(0x6, dst, src);
967
- }
968
-
969
- // Bit operations.
970
- void bt(const Operand& dst, Register src);
971
- void bts(const Operand& dst, Register src);
972
-
973
- // Miscellaneous
974
- void clc();
975
- void cpuid();
976
- void hlt();
977
- void int3();
978
- void nop();
979
- void nop(int n);
980
- void rdtsc();
981
- void ret(int imm16);
982
- void setcc(Condition cc, Register reg);
983
-
984
- // Label operations & relative jumps (PPUM Appendix D)
985
- //
986
- // Takes a branch opcode (cc) and a label (L) and generates
987
- // either a backward branch or a forward branch and links it
988
- // to the label fixup chain. Usage:
989
- //
990
- // Label L; // unbound label
991
- // j(cc, &L); // forward branch to unbound label
992
- // bind(&L); // bind label to the current pc
993
- // j(cc, &L); // backward branch to bound label
994
- // bind(&L); // illegal: a label may be bound only once
995
- //
996
- // Note: The same Label can be used for forward and backward branches
997
- // but it may be bound only once.
998
-
999
- void bind(Label* L); // binds an unbound label L to the current code position
1000
-
1001
- // Calls
1002
- // Call near relative 32-bit displacement, relative to next instruction.
1003
- void call(Label* L);
1004
- void call(Handle<Code> target, RelocInfo::Mode rmode);
1005
-
1006
- // Call near absolute indirect, address in register
1007
- void call(Register adr);
1008
-
1009
- // Call near indirect
1010
- void call(const Operand& operand);
1011
-
1012
- // Jumps
1013
- // Jump short or near relative.
1014
- // Use a 32-bit signed displacement.
1015
- void jmp(Label* L); // unconditional jump to L
1016
- void jmp(Handle<Code> target, RelocInfo::Mode rmode);
1017
-
1018
- // Jump near absolute indirect (r64)
1019
- void jmp(Register adr);
1020
-
1021
- // Jump near absolute indirect (m64)
1022
- void jmp(const Operand& src);
1023
-
1024
- // Conditional jumps
1025
- void j(Condition cc, Label* L);
1026
- void j(Condition cc, Handle<Code> target, RelocInfo::Mode rmode);
1027
-
1028
- // Floating-point operations
1029
- void fld(int i);
1030
-
1031
- void fld1();
1032
- void fldz();
1033
-
1034
- void fld_s(const Operand& adr);
1035
- void fld_d(const Operand& adr);
1036
-
1037
- void fstp_s(const Operand& adr);
1038
- void fstp_d(const Operand& adr);
1039
- void fstp(int index);
1040
-
1041
- void fild_s(const Operand& adr);
1042
- void fild_d(const Operand& adr);
1043
-
1044
- void fist_s(const Operand& adr);
1045
-
1046
- void fistp_s(const Operand& adr);
1047
- void fistp_d(const Operand& adr);
1048
-
1049
- void fisttp_s(const Operand& adr);
1050
-
1051
- void fabs();
1052
- void fchs();
1053
-
1054
- void fadd(int i);
1055
- void fsub(int i);
1056
- void fmul(int i);
1057
- void fdiv(int i);
1058
-
1059
- void fisub_s(const Operand& adr);
1060
-
1061
- void faddp(int i = 1);
1062
- void fsubp(int i = 1);
1063
- void fsubrp(int i = 1);
1064
- void fmulp(int i = 1);
1065
- void fdivp(int i = 1);
1066
- void fprem();
1067
- void fprem1();
1068
-
1069
- void fxch(int i = 1);
1070
- void fincstp();
1071
- void ffree(int i = 0);
1072
-
1073
- void ftst();
1074
- void fucomp(int i);
1075
- void fucompp();
1076
- void fucomi(int i);
1077
- void fucomip();
1078
-
1079
- void fcompp();
1080
- void fnstsw_ax();
1081
- void fwait();
1082
- void fnclex();
1083
-
1084
- void fsin();
1085
- void fcos();
1086
-
1087
- void frndint();
1088
-
1089
- void sahf();
1090
-
1091
- // SSE2 instructions
1092
- void movsd(const Operand& dst, XMMRegister src);
1093
- void movsd(XMMRegister src, XMMRegister dst);
1094
- void movsd(XMMRegister src, const Operand& dst);
1095
-
1096
- void cvttss2si(Register dst, const Operand& src);
1097
- void cvttsd2si(Register dst, const Operand& src);
1098
-
1099
- void cvtlsi2sd(XMMRegister dst, const Operand& src);
1100
- void cvtlsi2sd(XMMRegister dst, Register src);
1101
- void cvtqsi2sd(XMMRegister dst, const Operand& src);
1102
- void cvtqsi2sd(XMMRegister dst, Register src);
1103
-
1104
- void addsd(XMMRegister dst, XMMRegister src);
1105
- void subsd(XMMRegister dst, XMMRegister src);
1106
- void mulsd(XMMRegister dst, XMMRegister src);
1107
- void divsd(XMMRegister dst, XMMRegister src);
1108
-
1109
-
1110
- void emit_sse_operand(XMMRegister dst, XMMRegister src);
1111
- void emit_sse_operand(XMMRegister reg, const Operand& adr);
1112
- void emit_sse_operand(XMMRegister dst, Register src);
1113
-
1114
- // Use either movsd or movlpd.
1115
- // void movdbl(XMMRegister dst, const Operand& src);
1116
- // void movdbl(const Operand& dst, XMMRegister src);
1117
-
1118
- // Debugging
1119
- void Print();
1120
-
1121
- // Check the code size generated from label to here.
1122
- int SizeOfCodeGeneratedSince(Label* l) { return pc_offset() - l->pos(); }
1123
-
1124
- // Mark address of the ExitJSFrame code.
1125
- void RecordJSReturn();
1126
-
1127
- // Record a comment relocation entry that can be used by a disassembler.
1128
- // Use --debug_code to enable.
1129
- void RecordComment(const char* msg);
1130
-
1131
- void RecordPosition(int pos);
1132
- void RecordStatementPosition(int pos);
1133
- void WriteRecordedPositions();
1134
-
1135
- int pc_offset() const { return static_cast<int>(pc_ - buffer_); }
1136
- int current_statement_position() const { return current_statement_position_; }
1137
- int current_position() const { return current_position_; }
1138
-
1139
- // Check if there is less than kGap bytes available in the buffer.
1140
- // If this is the case, we need to grow the buffer before emitting
1141
- // an instruction or relocation information.
1142
- inline bool buffer_overflow() const {
1143
- return pc_ >= reloc_info_writer.pos() - kGap;
1144
- }
1145
-
1146
- // Get the number of bytes available in the buffer.
1147
- inline int available_space() const {
1148
- return static_cast<int>(reloc_info_writer.pos() - pc_);
1149
- }
1150
-
1151
- // Avoid overflows for displacements etc.
1152
- static const int kMaximalBufferSize = 512*MB;
1153
- static const int kMinimalBufferSize = 4*KB;
1154
-
1155
- protected:
1156
- // void movsd(XMMRegister dst, const Operand& src);
1157
- // void movsd(const Operand& dst, XMMRegister src);
1158
-
1159
- // void emit_sse_operand(XMMRegister reg, const Operand& adr);
1160
- // void emit_sse_operand(XMMRegister dst, XMMRegister src);
1161
-
1162
-
1163
- private:
1164
- byte* addr_at(int pos) { return buffer_ + pos; }
1165
- byte byte_at(int pos) { return buffer_[pos]; }
1166
- uint32_t long_at(int pos) {
1167
- return *reinterpret_cast<uint32_t*>(addr_at(pos));
1168
- }
1169
- void long_at_put(int pos, uint32_t x) {
1170
- *reinterpret_cast<uint32_t*>(addr_at(pos)) = x;
1171
- }
1172
-
1173
- // code emission
1174
- void GrowBuffer();
1175
-
1176
- void emit(byte x) { *pc_++ = x; }
1177
- inline void emitl(uint32_t x);
1178
- inline void emitq(uint64_t x, RelocInfo::Mode rmode);
1179
- inline void emitw(uint16_t x);
1180
- inline void emit_code_target(Handle<Code> target, RelocInfo::Mode rmode);
1181
- void emit(Immediate x) { emitl(x.value_); }
1182
-
1183
- // Emits a REX prefix that encodes a 64-bit operand size and
1184
- // the top bit of both register codes.
1185
- // High bit of reg goes to REX.R, high bit of rm_reg goes to REX.B.
1186
- // REX.W is set.
1187
- inline void emit_rex_64(Register reg, Register rm_reg);
1188
- inline void emit_rex_64(XMMRegister reg, Register rm_reg);
1189
-
1190
- // Emits a REX prefix that encodes a 64-bit operand size and
1191
- // the top bit of the destination, index, and base register codes.
1192
- // The high bit of reg is used for REX.R, the high bit of op's base
1193
- // register is used for REX.B, and the high bit of op's index register
1194
- // is used for REX.X. REX.W is set.
1195
- inline void emit_rex_64(Register reg, const Operand& op);
1196
- inline void emit_rex_64(XMMRegister reg, const Operand& op);
1197
-
1198
- // Emits a REX prefix that encodes a 64-bit operand size and
1199
- // the top bit of the register code.
1200
- // The high bit of register is used for REX.B.
1201
- // REX.W is set and REX.R and REX.X are clear.
1202
- inline void emit_rex_64(Register rm_reg);
1203
-
1204
- // Emits a REX prefix that encodes a 64-bit operand size and
1205
- // the top bit of the index and base register codes.
1206
- // The high bit of op's base register is used for REX.B, and the high
1207
- // bit of op's index register is used for REX.X.
1208
- // REX.W is set and REX.R clear.
1209
- inline void emit_rex_64(const Operand& op);
1210
-
1211
- // Emit a REX prefix that only sets REX.W to choose a 64-bit operand size.
1212
- void emit_rex_64() { emit(0x48); }
1213
-
1214
- // High bit of reg goes to REX.R, high bit of rm_reg goes to REX.B.
1215
- // REX.W is clear.
1216
- inline void emit_rex_32(Register reg, Register rm_reg);
1217
-
1218
- // The high bit of reg is used for REX.R, the high bit of op's base
1219
- // register is used for REX.B, and the high bit of op's index register
1220
- // is used for REX.X. REX.W is cleared.
1221
- inline void emit_rex_32(Register reg, const Operand& op);
1222
-
1223
- // High bit of rm_reg goes to REX.B.
1224
- // REX.W, REX.R and REX.X are clear.
1225
- inline void emit_rex_32(Register rm_reg);
1226
-
1227
- // High bit of base goes to REX.B and high bit of index to REX.X.
1228
- // REX.W and REX.R are clear.
1229
- inline void emit_rex_32(const Operand& op);
1230
-
1231
- // High bit of reg goes to REX.R, high bit of rm_reg goes to REX.B.
1232
- // REX.W is cleared. If no REX bits are set, no byte is emitted.
1233
- inline void emit_optional_rex_32(Register reg, Register rm_reg);
1234
-
1235
- // The high bit of reg is used for REX.R, the high bit of op's base
1236
- // register is used for REX.B, and the high bit of op's index register
1237
- // is used for REX.X. REX.W is cleared. If no REX bits are set, nothing
1238
- // is emitted.
1239
- inline void emit_optional_rex_32(Register reg, const Operand& op);
1240
-
1241
- // As for emit_optional_rex_32(Register, Register), except that
1242
- // the registers are XMM registers.
1243
- inline void emit_optional_rex_32(XMMRegister reg, XMMRegister base);
1244
-
1245
- // As for emit_optional_rex_32(Register, Register), except that
1246
- // the registers are XMM registers.
1247
- inline void emit_optional_rex_32(XMMRegister reg, Register base);
1248
-
1249
- // As for emit_optional_rex_32(Register, const Operand&), except that
1250
- // the register is an XMM register.
1251
- inline void emit_optional_rex_32(XMMRegister reg, const Operand& op);
1252
-
1253
- // Optionally do as emit_rex_32(Register) if the register number has
1254
- // the high bit set.
1255
- inline void emit_optional_rex_32(Register rm_reg);
1256
-
1257
- // Optionally do as emit_rex_32(const Operand&) if the operand register
1258
- // numbers have a high bit set.
1259
- inline void emit_optional_rex_32(const Operand& op);
1260
-
1261
-
1262
- // Emit the ModR/M byte, and optionally the SIB byte and
1263
- // 1- or 4-byte offset for a memory operand. Also encodes
1264
- // the second operand of the operation, a register or operation
1265
- // subcode, into the reg field of the ModR/M byte.
1266
- void emit_operand(Register reg, const Operand& adr) {
1267
- emit_operand(reg.low_bits(), adr);
1268
- }
1269
-
1270
- // Emit the ModR/M byte, and optionally the SIB byte and
1271
- // 1- or 4-byte offset for a memory operand. Also used to encode
1272
- // a three-bit opcode extension into the ModR/M byte.
1273
- void emit_operand(int rm, const Operand& adr);
1274
-
1275
- // Emit a ModR/M byte with registers coded in the reg and rm_reg fields.
1276
- void emit_modrm(Register reg, Register rm_reg) {
1277
- emit(0xC0 | reg.low_bits() << 3 | rm_reg.low_bits());
1278
- }
1279
-
1280
- // Emit a ModR/M byte with an operation subcode in the reg field and
1281
- // a register in the rm_reg field.
1282
- void emit_modrm(int code, Register rm_reg) {
1283
- ASSERT(is_uint3(code));
1284
- emit(0xC0 | code << 3 | rm_reg.low_bits());
1285
- }
1286
-
1287
- // Emit the code-object-relative offset of the label's position
1288
- inline void emit_code_relative_offset(Label* label);
1289
-
1290
- // Emit machine code for one of the operations ADD, ADC, SUB, SBC,
1291
- // AND, OR, XOR, or CMP. The encodings of these operations are all
1292
- // similar, differing just in the opcode or in the reg field of the
1293
- // ModR/M byte.
1294
- void arithmetic_op_16(byte opcode, Register reg, Register rm_reg);
1295
- void arithmetic_op_16(byte opcode, Register reg, const Operand& rm_reg);
1296
- void arithmetic_op_32(byte opcode, Register reg, Register rm_reg);
1297
- void arithmetic_op_32(byte opcode, Register reg, const Operand& rm_reg);
1298
- void arithmetic_op(byte opcode, Register reg, Register rm_reg);
1299
- void arithmetic_op(byte opcode, Register reg, const Operand& rm_reg);
1300
- void immediate_arithmetic_op(byte subcode, Register dst, Immediate src);
1301
- void immediate_arithmetic_op(byte subcode, const Operand& dst, Immediate src);
1302
- // Operate on a byte in memory or register.
1303
- void immediate_arithmetic_op_8(byte subcode,
1304
- Register dst,
1305
- Immediate src);
1306
- void immediate_arithmetic_op_8(byte subcode,
1307
- const Operand& dst,
1308
- Immediate src);
1309
- // Operate on a word in memory or register.
1310
- void immediate_arithmetic_op_16(byte subcode,
1311
- Register dst,
1312
- Immediate src);
1313
- void immediate_arithmetic_op_16(byte subcode,
1314
- const Operand& dst,
1315
- Immediate src);
1316
- // Operate on a 32-bit word in memory or register.
1317
- void immediate_arithmetic_op_32(byte subcode,
1318
- Register dst,
1319
- Immediate src);
1320
- void immediate_arithmetic_op_32(byte subcode,
1321
- const Operand& dst,
1322
- Immediate src);
1323
-
1324
- // Emit machine code for a shift operation.
1325
- void shift(Register dst, Immediate shift_amount, int subcode);
1326
- void shift_32(Register dst, Immediate shift_amount, int subcode);
1327
- // Shift dst by cl % 64 bits.
1328
- void shift(Register dst, int subcode);
1329
- void shift_32(Register dst, int subcode);
1330
-
1331
- void emit_farith(int b1, int b2, int i);
1332
-
1333
- // labels
1334
- // void print(Label* L);
1335
- void bind_to(Label* L, int pos);
1336
- void link_to(Label* L, Label* appendix);
1337
-
1338
- // record reloc info for current pc_
1339
- void RecordRelocInfo(RelocInfo::Mode rmode, intptr_t data = 0);
1340
-
1341
- friend class CodePatcher;
1342
- friend class EnsureSpace;
1343
- friend class RegExpMacroAssemblerX64;
1344
-
1345
- // Code buffer:
1346
- // The buffer into which code and relocation info are generated.
1347
- byte* buffer_;
1348
- int buffer_size_;
1349
- // True if the assembler owns the buffer, false if buffer is external.
1350
- bool own_buffer_;
1351
- // A previously allocated buffer of kMinimalBufferSize bytes, or NULL.
1352
- static byte* spare_buffer_;
1353
-
1354
- // code generation
1355
- byte* pc_; // the program counter; moves forward
1356
- RelocInfoWriter reloc_info_writer;
1357
-
1358
- List< Handle<Code> > code_targets_;
1359
- // push-pop elimination
1360
- byte* last_pc_;
1361
-
1362
- // source position information
1363
- int current_statement_position_;
1364
- int current_position_;
1365
- int written_statement_position_;
1366
- int written_position_;
1367
- };
1368
-
1369
-
1370
- // Helper class that ensures that there is enough space for generating
1371
- // instructions and relocation information. The constructor makes
1372
- // sure that there is enough space and (in debug mode) the destructor
1373
- // checks that we did not generate too much.
1374
- class EnsureSpace BASE_EMBEDDED {
1375
- public:
1376
- explicit EnsureSpace(Assembler* assembler) : assembler_(assembler) {
1377
- if (assembler_->buffer_overflow()) assembler_->GrowBuffer();
1378
- #ifdef DEBUG
1379
- space_before_ = assembler_->available_space();
1380
- #endif
1381
- }
1382
-
1383
- #ifdef DEBUG
1384
- ~EnsureSpace() {
1385
- int bytes_generated = space_before_ - assembler_->available_space();
1386
- ASSERT(bytes_generated < assembler_->kGap);
1387
- }
1388
- #endif
1389
-
1390
- private:
1391
- Assembler* assembler_;
1392
- #ifdef DEBUG
1393
- int space_before_;
1394
- #endif
1395
- };
1396
-
1397
- } } // namespace v8::internal
1398
-
1399
- #endif // V8_X64_ASSEMBLER_X64_H_