libv8 3.3.10.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (700) hide show
  1. data/.gitignore +8 -0
  2. data/.gitmodules +3 -0
  3. data/Gemfile +4 -0
  4. data/README.md +44 -0
  5. data/Rakefile +73 -0
  6. data/ext/libv8/extconf.rb +9 -0
  7. data/lib/libv8.rb +15 -0
  8. data/lib/libv8/Makefile +38 -0
  9. data/lib/libv8/detect_cpu.rb +27 -0
  10. data/lib/libv8/fpic-on-linux-amd64.patch +13 -0
  11. data/lib/libv8/scons/CHANGES.txt +5334 -0
  12. data/lib/libv8/scons/LICENSE.txt +20 -0
  13. data/lib/libv8/scons/MANIFEST +199 -0
  14. data/lib/libv8/scons/PKG-INFO +13 -0
  15. data/lib/libv8/scons/README.txt +243 -0
  16. data/lib/libv8/scons/RELEASE.txt +98 -0
  17. data/lib/libv8/scons/engine/SCons/Action.py +1241 -0
  18. data/lib/libv8/scons/engine/SCons/Builder.py +877 -0
  19. data/lib/libv8/scons/engine/SCons/CacheDir.py +216 -0
  20. data/lib/libv8/scons/engine/SCons/Conftest.py +793 -0
  21. data/lib/libv8/scons/engine/SCons/Debug.py +220 -0
  22. data/lib/libv8/scons/engine/SCons/Defaults.py +480 -0
  23. data/lib/libv8/scons/engine/SCons/Environment.py +2318 -0
  24. data/lib/libv8/scons/engine/SCons/Errors.py +205 -0
  25. data/lib/libv8/scons/engine/SCons/Executor.py +633 -0
  26. data/lib/libv8/scons/engine/SCons/Job.py +435 -0
  27. data/lib/libv8/scons/engine/SCons/Memoize.py +244 -0
  28. data/lib/libv8/scons/engine/SCons/Node/Alias.py +152 -0
  29. data/lib/libv8/scons/engine/SCons/Node/FS.py +3142 -0
  30. data/lib/libv8/scons/engine/SCons/Node/Python.py +128 -0
  31. data/lib/libv8/scons/engine/SCons/Node/__init__.py +1328 -0
  32. data/lib/libv8/scons/engine/SCons/Options/BoolOption.py +50 -0
  33. data/lib/libv8/scons/engine/SCons/Options/EnumOption.py +50 -0
  34. data/lib/libv8/scons/engine/SCons/Options/ListOption.py +50 -0
  35. data/lib/libv8/scons/engine/SCons/Options/PackageOption.py +50 -0
  36. data/lib/libv8/scons/engine/SCons/Options/PathOption.py +76 -0
  37. data/lib/libv8/scons/engine/SCons/Options/__init__.py +67 -0
  38. data/lib/libv8/scons/engine/SCons/PathList.py +231 -0
  39. data/lib/libv8/scons/engine/SCons/Platform/__init__.py +241 -0
  40. data/lib/libv8/scons/engine/SCons/Platform/aix.py +69 -0
  41. data/lib/libv8/scons/engine/SCons/Platform/cygwin.py +55 -0
  42. data/lib/libv8/scons/engine/SCons/Platform/darwin.py +46 -0
  43. data/lib/libv8/scons/engine/SCons/Platform/hpux.py +46 -0
  44. data/lib/libv8/scons/engine/SCons/Platform/irix.py +44 -0
  45. data/lib/libv8/scons/engine/SCons/Platform/os2.py +58 -0
  46. data/lib/libv8/scons/engine/SCons/Platform/posix.py +263 -0
  47. data/lib/libv8/scons/engine/SCons/Platform/sunos.py +50 -0
  48. data/lib/libv8/scons/engine/SCons/Platform/win32.py +385 -0
  49. data/lib/libv8/scons/engine/SCons/SConf.py +1030 -0
  50. data/lib/libv8/scons/engine/SCons/SConsign.py +383 -0
  51. data/lib/libv8/scons/engine/SCons/Scanner/C.py +132 -0
  52. data/lib/libv8/scons/engine/SCons/Scanner/D.py +73 -0
  53. data/lib/libv8/scons/engine/SCons/Scanner/Dir.py +109 -0
  54. data/lib/libv8/scons/engine/SCons/Scanner/Fortran.py +316 -0
  55. data/lib/libv8/scons/engine/SCons/Scanner/IDL.py +48 -0
  56. data/lib/libv8/scons/engine/SCons/Scanner/LaTeX.py +384 -0
  57. data/lib/libv8/scons/engine/SCons/Scanner/Prog.py +101 -0
  58. data/lib/libv8/scons/engine/SCons/Scanner/RC.py +55 -0
  59. data/lib/libv8/scons/engine/SCons/Scanner/__init__.py +413 -0
  60. data/lib/libv8/scons/engine/SCons/Script/Interactive.py +384 -0
  61. data/lib/libv8/scons/engine/SCons/Script/Main.py +1334 -0
  62. data/lib/libv8/scons/engine/SCons/Script/SConsOptions.py +939 -0
  63. data/lib/libv8/scons/engine/SCons/Script/SConscript.py +640 -0
  64. data/lib/libv8/scons/engine/SCons/Script/__init__.py +412 -0
  65. data/lib/libv8/scons/engine/SCons/Sig.py +63 -0
  66. data/lib/libv8/scons/engine/SCons/Subst.py +904 -0
  67. data/lib/libv8/scons/engine/SCons/Taskmaster.py +1017 -0
  68. data/lib/libv8/scons/engine/SCons/Tool/386asm.py +61 -0
  69. data/lib/libv8/scons/engine/SCons/Tool/BitKeeper.py +67 -0
  70. data/lib/libv8/scons/engine/SCons/Tool/CVS.py +73 -0
  71. data/lib/libv8/scons/engine/SCons/Tool/FortranCommon.py +246 -0
  72. data/lib/libv8/scons/engine/SCons/Tool/JavaCommon.py +323 -0
  73. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/__init__.py +56 -0
  74. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/arch.py +61 -0
  75. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/common.py +240 -0
  76. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/netframework.py +82 -0
  77. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/sdk.py +391 -0
  78. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/vc.py +456 -0
  79. data/lib/libv8/scons/engine/SCons/Tool/MSCommon/vs.py +499 -0
  80. data/lib/libv8/scons/engine/SCons/Tool/Perforce.py +103 -0
  81. data/lib/libv8/scons/engine/SCons/Tool/PharLapCommon.py +137 -0
  82. data/lib/libv8/scons/engine/SCons/Tool/RCS.py +64 -0
  83. data/lib/libv8/scons/engine/SCons/Tool/SCCS.py +64 -0
  84. data/lib/libv8/scons/engine/SCons/Tool/Subversion.py +71 -0
  85. data/lib/libv8/scons/engine/SCons/Tool/__init__.py +681 -0
  86. data/lib/libv8/scons/engine/SCons/Tool/aixc++.py +82 -0
  87. data/lib/libv8/scons/engine/SCons/Tool/aixcc.py +74 -0
  88. data/lib/libv8/scons/engine/SCons/Tool/aixf77.py +80 -0
  89. data/lib/libv8/scons/engine/SCons/Tool/aixlink.py +76 -0
  90. data/lib/libv8/scons/engine/SCons/Tool/applelink.py +71 -0
  91. data/lib/libv8/scons/engine/SCons/Tool/ar.py +63 -0
  92. data/lib/libv8/scons/engine/SCons/Tool/as.py +78 -0
  93. data/lib/libv8/scons/engine/SCons/Tool/bcc32.py +81 -0
  94. data/lib/libv8/scons/engine/SCons/Tool/c++.py +99 -0
  95. data/lib/libv8/scons/engine/SCons/Tool/cc.py +102 -0
  96. data/lib/libv8/scons/engine/SCons/Tool/cvf.py +58 -0
  97. data/lib/libv8/scons/engine/SCons/Tool/default.py +50 -0
  98. data/lib/libv8/scons/engine/SCons/Tool/dmd.py +223 -0
  99. data/lib/libv8/scons/engine/SCons/Tool/dvi.py +64 -0
  100. data/lib/libv8/scons/engine/SCons/Tool/dvipdf.py +124 -0
  101. data/lib/libv8/scons/engine/SCons/Tool/dvips.py +94 -0
  102. data/lib/libv8/scons/engine/SCons/Tool/f77.py +62 -0
  103. data/lib/libv8/scons/engine/SCons/Tool/f90.py +62 -0
  104. data/lib/libv8/scons/engine/SCons/Tool/f95.py +63 -0
  105. data/lib/libv8/scons/engine/SCons/Tool/filesystem.py +98 -0
  106. data/lib/libv8/scons/engine/SCons/Tool/fortran.py +62 -0
  107. data/lib/libv8/scons/engine/SCons/Tool/g++.py +90 -0
  108. data/lib/libv8/scons/engine/SCons/Tool/g77.py +73 -0
  109. data/lib/libv8/scons/engine/SCons/Tool/gas.py +53 -0
  110. data/lib/libv8/scons/engine/SCons/Tool/gcc.py +80 -0
  111. data/lib/libv8/scons/engine/SCons/Tool/gfortran.py +64 -0
  112. data/lib/libv8/scons/engine/SCons/Tool/gnulink.py +63 -0
  113. data/lib/libv8/scons/engine/SCons/Tool/gs.py +81 -0
  114. data/lib/libv8/scons/engine/SCons/Tool/hpc++.py +84 -0
  115. data/lib/libv8/scons/engine/SCons/Tool/hpcc.py +53 -0
  116. data/lib/libv8/scons/engine/SCons/Tool/hplink.py +77 -0
  117. data/lib/libv8/scons/engine/SCons/Tool/icc.py +59 -0
  118. data/lib/libv8/scons/engine/SCons/Tool/icl.py +52 -0
  119. data/lib/libv8/scons/engine/SCons/Tool/ifl.py +72 -0
  120. data/lib/libv8/scons/engine/SCons/Tool/ifort.py +88 -0
  121. data/lib/libv8/scons/engine/SCons/Tool/ilink.py +59 -0
  122. data/lib/libv8/scons/engine/SCons/Tool/ilink32.py +60 -0
  123. data/lib/libv8/scons/engine/SCons/Tool/install.py +229 -0
  124. data/lib/libv8/scons/engine/SCons/Tool/intelc.py +482 -0
  125. data/lib/libv8/scons/engine/SCons/Tool/ipkg.py +67 -0
  126. data/lib/libv8/scons/engine/SCons/Tool/jar.py +110 -0
  127. data/lib/libv8/scons/engine/SCons/Tool/javac.py +230 -0
  128. data/lib/libv8/scons/engine/SCons/Tool/javah.py +137 -0
  129. data/lib/libv8/scons/engine/SCons/Tool/latex.py +79 -0
  130. data/lib/libv8/scons/engine/SCons/Tool/lex.py +97 -0
  131. data/lib/libv8/scons/engine/SCons/Tool/link.py +121 -0
  132. data/lib/libv8/scons/engine/SCons/Tool/linkloc.py +112 -0
  133. data/lib/libv8/scons/engine/SCons/Tool/m4.py +63 -0
  134. data/lib/libv8/scons/engine/SCons/Tool/masm.py +77 -0
  135. data/lib/libv8/scons/engine/SCons/Tool/midl.py +88 -0
  136. data/lib/libv8/scons/engine/SCons/Tool/mingw.py +158 -0
  137. data/lib/libv8/scons/engine/SCons/Tool/mslib.py +64 -0
  138. data/lib/libv8/scons/engine/SCons/Tool/mslink.py +266 -0
  139. data/lib/libv8/scons/engine/SCons/Tool/mssdk.py +50 -0
  140. data/lib/libv8/scons/engine/SCons/Tool/msvc.py +268 -0
  141. data/lib/libv8/scons/engine/SCons/Tool/msvs.py +1388 -0
  142. data/lib/libv8/scons/engine/SCons/Tool/mwcc.py +207 -0
  143. data/lib/libv8/scons/engine/SCons/Tool/mwld.py +107 -0
  144. data/lib/libv8/scons/engine/SCons/Tool/nasm.py +72 -0
  145. data/lib/libv8/scons/engine/SCons/Tool/packaging/__init__.py +312 -0
  146. data/lib/libv8/scons/engine/SCons/Tool/packaging/ipk.py +185 -0
  147. data/lib/libv8/scons/engine/SCons/Tool/packaging/msi.py +527 -0
  148. data/lib/libv8/scons/engine/SCons/Tool/packaging/rpm.py +365 -0
  149. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_tarbz2.py +43 -0
  150. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_targz.py +43 -0
  151. data/lib/libv8/scons/engine/SCons/Tool/packaging/src_zip.py +43 -0
  152. data/lib/libv8/scons/engine/SCons/Tool/packaging/tarbz2.py +44 -0
  153. data/lib/libv8/scons/engine/SCons/Tool/packaging/targz.py +44 -0
  154. data/lib/libv8/scons/engine/SCons/Tool/packaging/zip.py +44 -0
  155. data/lib/libv8/scons/engine/SCons/Tool/pdf.py +78 -0
  156. data/lib/libv8/scons/engine/SCons/Tool/pdflatex.py +83 -0
  157. data/lib/libv8/scons/engine/SCons/Tool/pdftex.py +108 -0
  158. data/lib/libv8/scons/engine/SCons/Tool/qt.py +336 -0
  159. data/lib/libv8/scons/engine/SCons/Tool/rmic.py +120 -0
  160. data/lib/libv8/scons/engine/SCons/Tool/rpcgen.py +70 -0
  161. data/lib/libv8/scons/engine/SCons/Tool/rpm.py +132 -0
  162. data/lib/libv8/scons/engine/SCons/Tool/sgiar.py +68 -0
  163. data/lib/libv8/scons/engine/SCons/Tool/sgic++.py +58 -0
  164. data/lib/libv8/scons/engine/SCons/Tool/sgicc.py +53 -0
  165. data/lib/libv8/scons/engine/SCons/Tool/sgilink.py +63 -0
  166. data/lib/libv8/scons/engine/SCons/Tool/sunar.py +67 -0
  167. data/lib/libv8/scons/engine/SCons/Tool/sunc++.py +142 -0
  168. data/lib/libv8/scons/engine/SCons/Tool/suncc.py +58 -0
  169. data/lib/libv8/scons/engine/SCons/Tool/sunf77.py +63 -0
  170. data/lib/libv8/scons/engine/SCons/Tool/sunf90.py +64 -0
  171. data/lib/libv8/scons/engine/SCons/Tool/sunf95.py +64 -0
  172. data/lib/libv8/scons/engine/SCons/Tool/sunlink.py +77 -0
  173. data/lib/libv8/scons/engine/SCons/Tool/swig.py +182 -0
  174. data/lib/libv8/scons/engine/SCons/Tool/tar.py +73 -0
  175. data/lib/libv8/scons/engine/SCons/Tool/tex.py +813 -0
  176. data/lib/libv8/scons/engine/SCons/Tool/textfile.py +175 -0
  177. data/lib/libv8/scons/engine/SCons/Tool/tlib.py +53 -0
  178. data/lib/libv8/scons/engine/SCons/Tool/wix.py +99 -0
  179. data/lib/libv8/scons/engine/SCons/Tool/yacc.py +130 -0
  180. data/lib/libv8/scons/engine/SCons/Tool/zip.py +99 -0
  181. data/lib/libv8/scons/engine/SCons/Util.py +1492 -0
  182. data/lib/libv8/scons/engine/SCons/Variables/BoolVariable.py +89 -0
  183. data/lib/libv8/scons/engine/SCons/Variables/EnumVariable.py +103 -0
  184. data/lib/libv8/scons/engine/SCons/Variables/ListVariable.py +135 -0
  185. data/lib/libv8/scons/engine/SCons/Variables/PackageVariable.py +106 -0
  186. data/lib/libv8/scons/engine/SCons/Variables/PathVariable.py +147 -0
  187. data/lib/libv8/scons/engine/SCons/Variables/__init__.py +312 -0
  188. data/lib/libv8/scons/engine/SCons/Warnings.py +246 -0
  189. data/lib/libv8/scons/engine/SCons/__init__.py +49 -0
  190. data/lib/libv8/scons/engine/SCons/compat/__init__.py +237 -0
  191. data/lib/libv8/scons/engine/SCons/compat/_scons_builtins.py +150 -0
  192. data/lib/libv8/scons/engine/SCons/compat/_scons_collections.py +45 -0
  193. data/lib/libv8/scons/engine/SCons/compat/_scons_dbm.py +45 -0
  194. data/lib/libv8/scons/engine/SCons/compat/_scons_hashlib.py +76 -0
  195. data/lib/libv8/scons/engine/SCons/compat/_scons_io.py +45 -0
  196. data/lib/libv8/scons/engine/SCons/compat/_scons_sets.py +563 -0
  197. data/lib/libv8/scons/engine/SCons/compat/_scons_subprocess.py +1281 -0
  198. data/lib/libv8/scons/engine/SCons/cpp.py +589 -0
  199. data/lib/libv8/scons/engine/SCons/dblite.py +251 -0
  200. data/lib/libv8/scons/engine/SCons/exitfuncs.py +77 -0
  201. data/lib/libv8/scons/os_spawnv_fix.diff +83 -0
  202. data/lib/libv8/scons/scons-time.1 +1017 -0
  203. data/lib/libv8/scons/scons.1 +15219 -0
  204. data/lib/libv8/scons/sconsign.1 +208 -0
  205. data/lib/libv8/scons/script/scons +196 -0
  206. data/lib/libv8/scons/script/scons-time +1544 -0
  207. data/lib/libv8/scons/script/scons.bat +31 -0
  208. data/lib/libv8/scons/script/sconsign +513 -0
  209. data/lib/libv8/scons/setup.cfg +6 -0
  210. data/lib/libv8/scons/setup.py +425 -0
  211. data/lib/libv8/v8/.gitignore +35 -0
  212. data/lib/libv8/v8/AUTHORS +44 -0
  213. data/lib/libv8/v8/ChangeLog +2839 -0
  214. data/lib/libv8/v8/LICENSE +52 -0
  215. data/lib/libv8/v8/LICENSE.strongtalk +29 -0
  216. data/lib/libv8/v8/LICENSE.v8 +26 -0
  217. data/lib/libv8/v8/LICENSE.valgrind +45 -0
  218. data/lib/libv8/v8/SConstruct +1478 -0
  219. data/lib/libv8/v8/build/README.txt +49 -0
  220. data/lib/libv8/v8/build/all.gyp +18 -0
  221. data/lib/libv8/v8/build/armu.gypi +32 -0
  222. data/lib/libv8/v8/build/common.gypi +144 -0
  223. data/lib/libv8/v8/build/gyp_v8 +145 -0
  224. data/lib/libv8/v8/include/v8-debug.h +395 -0
  225. data/lib/libv8/v8/include/v8-preparser.h +117 -0
  226. data/lib/libv8/v8/include/v8-profiler.h +505 -0
  227. data/lib/libv8/v8/include/v8-testing.h +104 -0
  228. data/lib/libv8/v8/include/v8.h +4124 -0
  229. data/lib/libv8/v8/include/v8stdint.h +53 -0
  230. data/lib/libv8/v8/preparser/SConscript +38 -0
  231. data/lib/libv8/v8/preparser/preparser-process.cc +379 -0
  232. data/lib/libv8/v8/src/SConscript +368 -0
  233. data/lib/libv8/v8/src/accessors.cc +767 -0
  234. data/lib/libv8/v8/src/accessors.h +123 -0
  235. data/lib/libv8/v8/src/allocation-inl.h +49 -0
  236. data/lib/libv8/v8/src/allocation.cc +122 -0
  237. data/lib/libv8/v8/src/allocation.h +143 -0
  238. data/lib/libv8/v8/src/api.cc +5845 -0
  239. data/lib/libv8/v8/src/api.h +574 -0
  240. data/lib/libv8/v8/src/apinatives.js +110 -0
  241. data/lib/libv8/v8/src/apiutils.h +73 -0
  242. data/lib/libv8/v8/src/arguments.h +118 -0
  243. data/lib/libv8/v8/src/arm/assembler-arm-inl.h +353 -0
  244. data/lib/libv8/v8/src/arm/assembler-arm.cc +2661 -0
  245. data/lib/libv8/v8/src/arm/assembler-arm.h +1375 -0
  246. data/lib/libv8/v8/src/arm/builtins-arm.cc +1658 -0
  247. data/lib/libv8/v8/src/arm/code-stubs-arm.cc +6398 -0
  248. data/lib/libv8/v8/src/arm/code-stubs-arm.h +673 -0
  249. data/lib/libv8/v8/src/arm/codegen-arm.cc +52 -0
  250. data/lib/libv8/v8/src/arm/codegen-arm.h +91 -0
  251. data/lib/libv8/v8/src/arm/constants-arm.cc +152 -0
  252. data/lib/libv8/v8/src/arm/constants-arm.h +775 -0
  253. data/lib/libv8/v8/src/arm/cpu-arm.cc +120 -0
  254. data/lib/libv8/v8/src/arm/debug-arm.cc +317 -0
  255. data/lib/libv8/v8/src/arm/deoptimizer-arm.cc +754 -0
  256. data/lib/libv8/v8/src/arm/disasm-arm.cc +1506 -0
  257. data/lib/libv8/v8/src/arm/frames-arm.cc +45 -0
  258. data/lib/libv8/v8/src/arm/frames-arm.h +168 -0
  259. data/lib/libv8/v8/src/arm/full-codegen-arm.cc +4375 -0
  260. data/lib/libv8/v8/src/arm/ic-arm.cc +1562 -0
  261. data/lib/libv8/v8/src/arm/lithium-arm.cc +2206 -0
  262. data/lib/libv8/v8/src/arm/lithium-arm.h +2348 -0
  263. data/lib/libv8/v8/src/arm/lithium-codegen-arm.cc +4526 -0
  264. data/lib/libv8/v8/src/arm/lithium-codegen-arm.h +403 -0
  265. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.cc +305 -0
  266. data/lib/libv8/v8/src/arm/lithium-gap-resolver-arm.h +84 -0
  267. data/lib/libv8/v8/src/arm/macro-assembler-arm.cc +3163 -0
  268. data/lib/libv8/v8/src/arm/macro-assembler-arm.h +1126 -0
  269. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.cc +1287 -0
  270. data/lib/libv8/v8/src/arm/regexp-macro-assembler-arm.h +253 -0
  271. data/lib/libv8/v8/src/arm/simulator-arm.cc +3424 -0
  272. data/lib/libv8/v8/src/arm/simulator-arm.h +431 -0
  273. data/lib/libv8/v8/src/arm/stub-cache-arm.cc +4243 -0
  274. data/lib/libv8/v8/src/array.js +1366 -0
  275. data/lib/libv8/v8/src/assembler.cc +1207 -0
  276. data/lib/libv8/v8/src/assembler.h +858 -0
  277. data/lib/libv8/v8/src/ast-inl.h +112 -0
  278. data/lib/libv8/v8/src/ast.cc +1146 -0
  279. data/lib/libv8/v8/src/ast.h +2188 -0
  280. data/lib/libv8/v8/src/atomicops.h +167 -0
  281. data/lib/libv8/v8/src/atomicops_internals_arm_gcc.h +145 -0
  282. data/lib/libv8/v8/src/atomicops_internals_mips_gcc.h +169 -0
  283. data/lib/libv8/v8/src/atomicops_internals_x86_gcc.cc +133 -0
  284. data/lib/libv8/v8/src/atomicops_internals_x86_gcc.h +287 -0
  285. data/lib/libv8/v8/src/atomicops_internals_x86_macosx.h +301 -0
  286. data/lib/libv8/v8/src/atomicops_internals_x86_msvc.h +203 -0
  287. data/lib/libv8/v8/src/bignum-dtoa.cc +655 -0
  288. data/lib/libv8/v8/src/bignum-dtoa.h +81 -0
  289. data/lib/libv8/v8/src/bignum.cc +768 -0
  290. data/lib/libv8/v8/src/bignum.h +140 -0
  291. data/lib/libv8/v8/src/bootstrapper.cc +2184 -0
  292. data/lib/libv8/v8/src/bootstrapper.h +188 -0
  293. data/lib/libv8/v8/src/builtins.cc +1707 -0
  294. data/lib/libv8/v8/src/builtins.h +371 -0
  295. data/lib/libv8/v8/src/bytecodes-irregexp.h +105 -0
  296. data/lib/libv8/v8/src/cached-powers.cc +177 -0
  297. data/lib/libv8/v8/src/cached-powers.h +65 -0
  298. data/lib/libv8/v8/src/char-predicates-inl.h +94 -0
  299. data/lib/libv8/v8/src/char-predicates.h +67 -0
  300. data/lib/libv8/v8/src/checks.cc +110 -0
  301. data/lib/libv8/v8/src/checks.h +296 -0
  302. data/lib/libv8/v8/src/circular-queue-inl.h +53 -0
  303. data/lib/libv8/v8/src/circular-queue.cc +122 -0
  304. data/lib/libv8/v8/src/circular-queue.h +103 -0
  305. data/lib/libv8/v8/src/code-stubs.cc +267 -0
  306. data/lib/libv8/v8/src/code-stubs.h +1011 -0
  307. data/lib/libv8/v8/src/code.h +70 -0
  308. data/lib/libv8/v8/src/codegen.cc +231 -0
  309. data/lib/libv8/v8/src/codegen.h +84 -0
  310. data/lib/libv8/v8/src/compilation-cache.cc +540 -0
  311. data/lib/libv8/v8/src/compilation-cache.h +287 -0
  312. data/lib/libv8/v8/src/compiler.cc +786 -0
  313. data/lib/libv8/v8/src/compiler.h +312 -0
  314. data/lib/libv8/v8/src/contexts.cc +347 -0
  315. data/lib/libv8/v8/src/contexts.h +391 -0
  316. data/lib/libv8/v8/src/conversions-inl.h +106 -0
  317. data/lib/libv8/v8/src/conversions.cc +1131 -0
  318. data/lib/libv8/v8/src/conversions.h +135 -0
  319. data/lib/libv8/v8/src/counters.cc +93 -0
  320. data/lib/libv8/v8/src/counters.h +254 -0
  321. data/lib/libv8/v8/src/cpu-profiler-inl.h +101 -0
  322. data/lib/libv8/v8/src/cpu-profiler.cc +609 -0
  323. data/lib/libv8/v8/src/cpu-profiler.h +302 -0
  324. data/lib/libv8/v8/src/cpu.h +69 -0
  325. data/lib/libv8/v8/src/d8-debug.cc +367 -0
  326. data/lib/libv8/v8/src/d8-debug.h +158 -0
  327. data/lib/libv8/v8/src/d8-posix.cc +695 -0
  328. data/lib/libv8/v8/src/d8-readline.cc +130 -0
  329. data/lib/libv8/v8/src/d8-windows.cc +42 -0
  330. data/lib/libv8/v8/src/d8.cc +803 -0
  331. data/lib/libv8/v8/src/d8.gyp +91 -0
  332. data/lib/libv8/v8/src/d8.h +235 -0
  333. data/lib/libv8/v8/src/d8.js +2798 -0
  334. data/lib/libv8/v8/src/data-flow.cc +66 -0
  335. data/lib/libv8/v8/src/data-flow.h +205 -0
  336. data/lib/libv8/v8/src/date.js +1103 -0
  337. data/lib/libv8/v8/src/dateparser-inl.h +127 -0
  338. data/lib/libv8/v8/src/dateparser.cc +178 -0
  339. data/lib/libv8/v8/src/dateparser.h +266 -0
  340. data/lib/libv8/v8/src/debug-agent.cc +447 -0
  341. data/lib/libv8/v8/src/debug-agent.h +129 -0
  342. data/lib/libv8/v8/src/debug-debugger.js +2569 -0
  343. data/lib/libv8/v8/src/debug.cc +3165 -0
  344. data/lib/libv8/v8/src/debug.h +1057 -0
  345. data/lib/libv8/v8/src/deoptimizer.cc +1256 -0
  346. data/lib/libv8/v8/src/deoptimizer.h +602 -0
  347. data/lib/libv8/v8/src/disasm.h +80 -0
  348. data/lib/libv8/v8/src/disassembler.cc +343 -0
  349. data/lib/libv8/v8/src/disassembler.h +58 -0
  350. data/lib/libv8/v8/src/diy-fp.cc +58 -0
  351. data/lib/libv8/v8/src/diy-fp.h +117 -0
  352. data/lib/libv8/v8/src/double.h +238 -0
  353. data/lib/libv8/v8/src/dtoa.cc +103 -0
  354. data/lib/libv8/v8/src/dtoa.h +85 -0
  355. data/lib/libv8/v8/src/execution.cc +849 -0
  356. data/lib/libv8/v8/src/execution.h +297 -0
  357. data/lib/libv8/v8/src/extensions/experimental/break-iterator.cc +250 -0
  358. data/lib/libv8/v8/src/extensions/experimental/break-iterator.h +89 -0
  359. data/lib/libv8/v8/src/extensions/experimental/collator.cc +218 -0
  360. data/lib/libv8/v8/src/extensions/experimental/collator.h +69 -0
  361. data/lib/libv8/v8/src/extensions/experimental/experimental.gyp +94 -0
  362. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.cc +78 -0
  363. data/lib/libv8/v8/src/extensions/experimental/i18n-extension.h +54 -0
  364. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.cc +112 -0
  365. data/lib/libv8/v8/src/extensions/experimental/i18n-locale.h +60 -0
  366. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.cc +43 -0
  367. data/lib/libv8/v8/src/extensions/experimental/i18n-utils.h +49 -0
  368. data/lib/libv8/v8/src/extensions/experimental/i18n.js +180 -0
  369. data/lib/libv8/v8/src/extensions/experimental/language-matcher.cc +251 -0
  370. data/lib/libv8/v8/src/extensions/experimental/language-matcher.h +95 -0
  371. data/lib/libv8/v8/src/extensions/externalize-string-extension.cc +141 -0
  372. data/lib/libv8/v8/src/extensions/externalize-string-extension.h +50 -0
  373. data/lib/libv8/v8/src/extensions/gc-extension.cc +58 -0
  374. data/lib/libv8/v8/src/extensions/gc-extension.h +49 -0
  375. data/lib/libv8/v8/src/factory.cc +1222 -0
  376. data/lib/libv8/v8/src/factory.h +442 -0
  377. data/lib/libv8/v8/src/fast-dtoa.cc +736 -0
  378. data/lib/libv8/v8/src/fast-dtoa.h +83 -0
  379. data/lib/libv8/v8/src/fixed-dtoa.cc +405 -0
  380. data/lib/libv8/v8/src/fixed-dtoa.h +55 -0
  381. data/lib/libv8/v8/src/flag-definitions.h +560 -0
  382. data/lib/libv8/v8/src/flags.cc +551 -0
  383. data/lib/libv8/v8/src/flags.h +79 -0
  384. data/lib/libv8/v8/src/frames-inl.h +247 -0
  385. data/lib/libv8/v8/src/frames.cc +1243 -0
  386. data/lib/libv8/v8/src/frames.h +870 -0
  387. data/lib/libv8/v8/src/full-codegen.cc +1374 -0
  388. data/lib/libv8/v8/src/full-codegen.h +771 -0
  389. data/lib/libv8/v8/src/func-name-inferrer.cc +92 -0
  390. data/lib/libv8/v8/src/func-name-inferrer.h +111 -0
  391. data/lib/libv8/v8/src/gdb-jit.cc +1555 -0
  392. data/lib/libv8/v8/src/gdb-jit.h +143 -0
  393. data/lib/libv8/v8/src/global-handles.cc +665 -0
  394. data/lib/libv8/v8/src/global-handles.h +284 -0
  395. data/lib/libv8/v8/src/globals.h +325 -0
  396. data/lib/libv8/v8/src/handles-inl.h +177 -0
  397. data/lib/libv8/v8/src/handles.cc +987 -0
  398. data/lib/libv8/v8/src/handles.h +382 -0
  399. data/lib/libv8/v8/src/hashmap.cc +230 -0
  400. data/lib/libv8/v8/src/hashmap.h +123 -0
  401. data/lib/libv8/v8/src/heap-inl.h +704 -0
  402. data/lib/libv8/v8/src/heap-profiler.cc +1173 -0
  403. data/lib/libv8/v8/src/heap-profiler.h +397 -0
  404. data/lib/libv8/v8/src/heap.cc +5930 -0
  405. data/lib/libv8/v8/src/heap.h +2268 -0
  406. data/lib/libv8/v8/src/hydrogen-instructions.cc +1769 -0
  407. data/lib/libv8/v8/src/hydrogen-instructions.h +3971 -0
  408. data/lib/libv8/v8/src/hydrogen.cc +6239 -0
  409. data/lib/libv8/v8/src/hydrogen.h +1202 -0
  410. data/lib/libv8/v8/src/ia32/assembler-ia32-inl.h +446 -0
  411. data/lib/libv8/v8/src/ia32/assembler-ia32.cc +2487 -0
  412. data/lib/libv8/v8/src/ia32/assembler-ia32.h +1144 -0
  413. data/lib/libv8/v8/src/ia32/builtins-ia32.cc +1621 -0
  414. data/lib/libv8/v8/src/ia32/code-stubs-ia32.cc +6198 -0
  415. data/lib/libv8/v8/src/ia32/code-stubs-ia32.h +517 -0
  416. data/lib/libv8/v8/src/ia32/codegen-ia32.cc +265 -0
  417. data/lib/libv8/v8/src/ia32/codegen-ia32.h +79 -0
  418. data/lib/libv8/v8/src/ia32/cpu-ia32.cc +88 -0
  419. data/lib/libv8/v8/src/ia32/debug-ia32.cc +312 -0
  420. data/lib/libv8/v8/src/ia32/deoptimizer-ia32.cc +774 -0
  421. data/lib/libv8/v8/src/ia32/disasm-ia32.cc +1628 -0
  422. data/lib/libv8/v8/src/ia32/frames-ia32.cc +45 -0
  423. data/lib/libv8/v8/src/ia32/frames-ia32.h +142 -0
  424. data/lib/libv8/v8/src/ia32/full-codegen-ia32.cc +4338 -0
  425. data/lib/libv8/v8/src/ia32/ic-ia32.cc +1597 -0
  426. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.cc +4461 -0
  427. data/lib/libv8/v8/src/ia32/lithium-codegen-ia32.h +375 -0
  428. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.cc +475 -0
  429. data/lib/libv8/v8/src/ia32/lithium-gap-resolver-ia32.h +110 -0
  430. data/lib/libv8/v8/src/ia32/lithium-ia32.cc +2261 -0
  431. data/lib/libv8/v8/src/ia32/lithium-ia32.h +2396 -0
  432. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.cc +2136 -0
  433. data/lib/libv8/v8/src/ia32/macro-assembler-ia32.h +775 -0
  434. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.cc +1263 -0
  435. data/lib/libv8/v8/src/ia32/regexp-macro-assembler-ia32.h +216 -0
  436. data/lib/libv8/v8/src/ia32/simulator-ia32.cc +30 -0
  437. data/lib/libv8/v8/src/ia32/simulator-ia32.h +74 -0
  438. data/lib/libv8/v8/src/ia32/stub-cache-ia32.cc +3847 -0
  439. data/lib/libv8/v8/src/ic-inl.h +130 -0
  440. data/lib/libv8/v8/src/ic.cc +2577 -0
  441. data/lib/libv8/v8/src/ic.h +736 -0
  442. data/lib/libv8/v8/src/inspector.cc +63 -0
  443. data/lib/libv8/v8/src/inspector.h +62 -0
  444. data/lib/libv8/v8/src/interpreter-irregexp.cc +659 -0
  445. data/lib/libv8/v8/src/interpreter-irregexp.h +49 -0
  446. data/lib/libv8/v8/src/isolate-inl.h +50 -0
  447. data/lib/libv8/v8/src/isolate.cc +1869 -0
  448. data/lib/libv8/v8/src/isolate.h +1382 -0
  449. data/lib/libv8/v8/src/json-parser.cc +504 -0
  450. data/lib/libv8/v8/src/json-parser.h +161 -0
  451. data/lib/libv8/v8/src/json.js +342 -0
  452. data/lib/libv8/v8/src/jsregexp.cc +5385 -0
  453. data/lib/libv8/v8/src/jsregexp.h +1492 -0
  454. data/lib/libv8/v8/src/list-inl.h +212 -0
  455. data/lib/libv8/v8/src/list.h +174 -0
  456. data/lib/libv8/v8/src/lithium-allocator-inl.h +142 -0
  457. data/lib/libv8/v8/src/lithium-allocator.cc +2123 -0
  458. data/lib/libv8/v8/src/lithium-allocator.h +630 -0
  459. data/lib/libv8/v8/src/lithium.cc +190 -0
  460. data/lib/libv8/v8/src/lithium.h +597 -0
  461. data/lib/libv8/v8/src/liveedit-debugger.js +1082 -0
  462. data/lib/libv8/v8/src/liveedit.cc +1691 -0
  463. data/lib/libv8/v8/src/liveedit.h +180 -0
  464. data/lib/libv8/v8/src/liveobjectlist-inl.h +126 -0
  465. data/lib/libv8/v8/src/liveobjectlist.cc +2589 -0
  466. data/lib/libv8/v8/src/liveobjectlist.h +322 -0
  467. data/lib/libv8/v8/src/log-inl.h +59 -0
  468. data/lib/libv8/v8/src/log-utils.cc +428 -0
  469. data/lib/libv8/v8/src/log-utils.h +231 -0
  470. data/lib/libv8/v8/src/log.cc +1993 -0
  471. data/lib/libv8/v8/src/log.h +476 -0
  472. data/lib/libv8/v8/src/macro-assembler.h +120 -0
  473. data/lib/libv8/v8/src/macros.py +178 -0
  474. data/lib/libv8/v8/src/mark-compact.cc +3143 -0
  475. data/lib/libv8/v8/src/mark-compact.h +506 -0
  476. data/lib/libv8/v8/src/math.js +264 -0
  477. data/lib/libv8/v8/src/messages.cc +179 -0
  478. data/lib/libv8/v8/src/messages.h +113 -0
  479. data/lib/libv8/v8/src/messages.js +1096 -0
  480. data/lib/libv8/v8/src/mips/assembler-mips-inl.h +312 -0
  481. data/lib/libv8/v8/src/mips/assembler-mips.cc +1960 -0
  482. data/lib/libv8/v8/src/mips/assembler-mips.h +1138 -0
  483. data/lib/libv8/v8/src/mips/builtins-mips.cc +1628 -0
  484. data/lib/libv8/v8/src/mips/code-stubs-mips.cc +6656 -0
  485. data/lib/libv8/v8/src/mips/code-stubs-mips.h +682 -0
  486. data/lib/libv8/v8/src/mips/codegen-mips.cc +52 -0
  487. data/lib/libv8/v8/src/mips/codegen-mips.h +98 -0
  488. data/lib/libv8/v8/src/mips/constants-mips.cc +352 -0
  489. data/lib/libv8/v8/src/mips/constants-mips.h +739 -0
  490. data/lib/libv8/v8/src/mips/cpu-mips.cc +96 -0
  491. data/lib/libv8/v8/src/mips/debug-mips.cc +308 -0
  492. data/lib/libv8/v8/src/mips/deoptimizer-mips.cc +91 -0
  493. data/lib/libv8/v8/src/mips/disasm-mips.cc +1050 -0
  494. data/lib/libv8/v8/src/mips/frames-mips.cc +47 -0
  495. data/lib/libv8/v8/src/mips/frames-mips.h +219 -0
  496. data/lib/libv8/v8/src/mips/full-codegen-mips.cc +4388 -0
  497. data/lib/libv8/v8/src/mips/ic-mips.cc +1580 -0
  498. data/lib/libv8/v8/src/mips/lithium-codegen-mips.h +65 -0
  499. data/lib/libv8/v8/src/mips/lithium-mips.h +307 -0
  500. data/lib/libv8/v8/src/mips/macro-assembler-mips.cc +4056 -0
  501. data/lib/libv8/v8/src/mips/macro-assembler-mips.h +1214 -0
  502. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.cc +1251 -0
  503. data/lib/libv8/v8/src/mips/regexp-macro-assembler-mips.h +252 -0
  504. data/lib/libv8/v8/src/mips/simulator-mips.cc +2621 -0
  505. data/lib/libv8/v8/src/mips/simulator-mips.h +401 -0
  506. data/lib/libv8/v8/src/mips/stub-cache-mips.cc +4285 -0
  507. data/lib/libv8/v8/src/mirror-debugger.js +2382 -0
  508. data/lib/libv8/v8/src/mksnapshot.cc +328 -0
  509. data/lib/libv8/v8/src/natives.h +64 -0
  510. data/lib/libv8/v8/src/objects-debug.cc +738 -0
  511. data/lib/libv8/v8/src/objects-inl.h +4323 -0
  512. data/lib/libv8/v8/src/objects-printer.cc +829 -0
  513. data/lib/libv8/v8/src/objects-visiting.cc +148 -0
  514. data/lib/libv8/v8/src/objects-visiting.h +424 -0
  515. data/lib/libv8/v8/src/objects.cc +10585 -0
  516. data/lib/libv8/v8/src/objects.h +6838 -0
  517. data/lib/libv8/v8/src/parser.cc +4997 -0
  518. data/lib/libv8/v8/src/parser.h +765 -0
  519. data/lib/libv8/v8/src/platform-cygwin.cc +779 -0
  520. data/lib/libv8/v8/src/platform-freebsd.cc +826 -0
  521. data/lib/libv8/v8/src/platform-linux.cc +1149 -0
  522. data/lib/libv8/v8/src/platform-macos.cc +830 -0
  523. data/lib/libv8/v8/src/platform-nullos.cc +479 -0
  524. data/lib/libv8/v8/src/platform-openbsd.cc +640 -0
  525. data/lib/libv8/v8/src/platform-posix.cc +424 -0
  526. data/lib/libv8/v8/src/platform-solaris.cc +762 -0
  527. data/lib/libv8/v8/src/platform-tls-mac.h +62 -0
  528. data/lib/libv8/v8/src/platform-tls-win32.h +62 -0
  529. data/lib/libv8/v8/src/platform-tls.h +50 -0
  530. data/lib/libv8/v8/src/platform-win32.cc +2021 -0
  531. data/lib/libv8/v8/src/platform.h +667 -0
  532. data/lib/libv8/v8/src/preparse-data-format.h +62 -0
  533. data/lib/libv8/v8/src/preparse-data.cc +183 -0
  534. data/lib/libv8/v8/src/preparse-data.h +225 -0
  535. data/lib/libv8/v8/src/preparser-api.cc +220 -0
  536. data/lib/libv8/v8/src/preparser.cc +1450 -0
  537. data/lib/libv8/v8/src/preparser.h +493 -0
  538. data/lib/libv8/v8/src/prettyprinter.cc +1493 -0
  539. data/lib/libv8/v8/src/prettyprinter.h +223 -0
  540. data/lib/libv8/v8/src/profile-generator-inl.h +128 -0
  541. data/lib/libv8/v8/src/profile-generator.cc +3098 -0
  542. data/lib/libv8/v8/src/profile-generator.h +1126 -0
  543. data/lib/libv8/v8/src/property.cc +105 -0
  544. data/lib/libv8/v8/src/property.h +365 -0
  545. data/lib/libv8/v8/src/proxy.js +83 -0
  546. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp-inl.h +78 -0
  547. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp.cc +471 -0
  548. data/lib/libv8/v8/src/regexp-macro-assembler-irregexp.h +142 -0
  549. data/lib/libv8/v8/src/regexp-macro-assembler-tracer.cc +373 -0
  550. data/lib/libv8/v8/src/regexp-macro-assembler-tracer.h +104 -0
  551. data/lib/libv8/v8/src/regexp-macro-assembler.cc +267 -0
  552. data/lib/libv8/v8/src/regexp-macro-assembler.h +243 -0
  553. data/lib/libv8/v8/src/regexp-stack.cc +111 -0
  554. data/lib/libv8/v8/src/regexp-stack.h +147 -0
  555. data/lib/libv8/v8/src/regexp.js +483 -0
  556. data/lib/libv8/v8/src/rewriter.cc +360 -0
  557. data/lib/libv8/v8/src/rewriter.h +50 -0
  558. data/lib/libv8/v8/src/runtime-profiler.cc +489 -0
  559. data/lib/libv8/v8/src/runtime-profiler.h +201 -0
  560. data/lib/libv8/v8/src/runtime.cc +12227 -0
  561. data/lib/libv8/v8/src/runtime.h +652 -0
  562. data/lib/libv8/v8/src/runtime.js +649 -0
  563. data/lib/libv8/v8/src/safepoint-table.cc +256 -0
  564. data/lib/libv8/v8/src/safepoint-table.h +270 -0
  565. data/lib/libv8/v8/src/scanner-base.cc +952 -0
  566. data/lib/libv8/v8/src/scanner-base.h +670 -0
  567. data/lib/libv8/v8/src/scanner.cc +345 -0
  568. data/lib/libv8/v8/src/scanner.h +146 -0
  569. data/lib/libv8/v8/src/scopeinfo.cc +646 -0
  570. data/lib/libv8/v8/src/scopeinfo.h +254 -0
  571. data/lib/libv8/v8/src/scopes.cc +1150 -0
  572. data/lib/libv8/v8/src/scopes.h +507 -0
  573. data/lib/libv8/v8/src/serialize.cc +1574 -0
  574. data/lib/libv8/v8/src/serialize.h +589 -0
  575. data/lib/libv8/v8/src/shell.h +55 -0
  576. data/lib/libv8/v8/src/simulator.h +43 -0
  577. data/lib/libv8/v8/src/small-pointer-list.h +163 -0
  578. data/lib/libv8/v8/src/smart-pointer.h +109 -0
  579. data/lib/libv8/v8/src/snapshot-common.cc +83 -0
  580. data/lib/libv8/v8/src/snapshot-empty.cc +54 -0
  581. data/lib/libv8/v8/src/snapshot.h +91 -0
  582. data/lib/libv8/v8/src/spaces-inl.h +529 -0
  583. data/lib/libv8/v8/src/spaces.cc +3145 -0
  584. data/lib/libv8/v8/src/spaces.h +2369 -0
  585. data/lib/libv8/v8/src/splay-tree-inl.h +310 -0
  586. data/lib/libv8/v8/src/splay-tree.h +205 -0
  587. data/lib/libv8/v8/src/string-search.cc +41 -0
  588. data/lib/libv8/v8/src/string-search.h +568 -0
  589. data/lib/libv8/v8/src/string-stream.cc +592 -0
  590. data/lib/libv8/v8/src/string-stream.h +191 -0
  591. data/lib/libv8/v8/src/string.js +994 -0
  592. data/lib/libv8/v8/src/strtod.cc +440 -0
  593. data/lib/libv8/v8/src/strtod.h +40 -0
  594. data/lib/libv8/v8/src/stub-cache.cc +1965 -0
  595. data/lib/libv8/v8/src/stub-cache.h +924 -0
  596. data/lib/libv8/v8/src/third_party/valgrind/valgrind.h +3925 -0
  597. data/lib/libv8/v8/src/token.cc +63 -0
  598. data/lib/libv8/v8/src/token.h +288 -0
  599. data/lib/libv8/v8/src/type-info.cc +507 -0
  600. data/lib/libv8/v8/src/type-info.h +272 -0
  601. data/lib/libv8/v8/src/unbound-queue-inl.h +95 -0
  602. data/lib/libv8/v8/src/unbound-queue.h +69 -0
  603. data/lib/libv8/v8/src/unicode-inl.h +238 -0
  604. data/lib/libv8/v8/src/unicode.cc +1624 -0
  605. data/lib/libv8/v8/src/unicode.h +280 -0
  606. data/lib/libv8/v8/src/uri.js +408 -0
  607. data/lib/libv8/v8/src/utils-inl.h +48 -0
  608. data/lib/libv8/v8/src/utils.cc +371 -0
  609. data/lib/libv8/v8/src/utils.h +800 -0
  610. data/lib/libv8/v8/src/v8-counters.cc +62 -0
  611. data/lib/libv8/v8/src/v8-counters.h +314 -0
  612. data/lib/libv8/v8/src/v8.cc +213 -0
  613. data/lib/libv8/v8/src/v8.h +131 -0
  614. data/lib/libv8/v8/src/v8checks.h +64 -0
  615. data/lib/libv8/v8/src/v8dll-main.cc +44 -0
  616. data/lib/libv8/v8/src/v8globals.h +512 -0
  617. data/lib/libv8/v8/src/v8memory.h +82 -0
  618. data/lib/libv8/v8/src/v8natives.js +1310 -0
  619. data/lib/libv8/v8/src/v8preparserdll-main.cc +39 -0
  620. data/lib/libv8/v8/src/v8threads.cc +464 -0
  621. data/lib/libv8/v8/src/v8threads.h +165 -0
  622. data/lib/libv8/v8/src/v8utils.h +319 -0
  623. data/lib/libv8/v8/src/variables.cc +114 -0
  624. data/lib/libv8/v8/src/variables.h +167 -0
  625. data/lib/libv8/v8/src/version.cc +116 -0
  626. data/lib/libv8/v8/src/version.h +68 -0
  627. data/lib/libv8/v8/src/vm-state-inl.h +138 -0
  628. data/lib/libv8/v8/src/vm-state.h +71 -0
  629. data/lib/libv8/v8/src/win32-headers.h +96 -0
  630. data/lib/libv8/v8/src/x64/assembler-x64-inl.h +462 -0
  631. data/lib/libv8/v8/src/x64/assembler-x64.cc +3027 -0
  632. data/lib/libv8/v8/src/x64/assembler-x64.h +1633 -0
  633. data/lib/libv8/v8/src/x64/builtins-x64.cc +1520 -0
  634. data/lib/libv8/v8/src/x64/code-stubs-x64.cc +5132 -0
  635. data/lib/libv8/v8/src/x64/code-stubs-x64.h +514 -0
  636. data/lib/libv8/v8/src/x64/codegen-x64.cc +146 -0
  637. data/lib/libv8/v8/src/x64/codegen-x64.h +76 -0
  638. data/lib/libv8/v8/src/x64/cpu-x64.cc +88 -0
  639. data/lib/libv8/v8/src/x64/debug-x64.cc +319 -0
  640. data/lib/libv8/v8/src/x64/deoptimizer-x64.cc +815 -0
  641. data/lib/libv8/v8/src/x64/disasm-x64.cc +1832 -0
  642. data/lib/libv8/v8/src/x64/frames-x64.cc +45 -0
  643. data/lib/libv8/v8/src/x64/frames-x64.h +130 -0
  644. data/lib/libv8/v8/src/x64/full-codegen-x64.cc +4318 -0
  645. data/lib/libv8/v8/src/x64/ic-x64.cc +1608 -0
  646. data/lib/libv8/v8/src/x64/lithium-codegen-x64.cc +4267 -0
  647. data/lib/libv8/v8/src/x64/lithium-codegen-x64.h +367 -0
  648. data/lib/libv8/v8/src/x64/lithium-gap-resolver-x64.cc +320 -0
  649. data/lib/libv8/v8/src/x64/lithium-gap-resolver-x64.h +74 -0
  650. data/lib/libv8/v8/src/x64/lithium-x64.cc +2202 -0
  651. data/lib/libv8/v8/src/x64/lithium-x64.h +2333 -0
  652. data/lib/libv8/v8/src/x64/macro-assembler-x64.cc +3745 -0
  653. data/lib/libv8/v8/src/x64/macro-assembler-x64.h +1290 -0
  654. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.cc +1398 -0
  655. data/lib/libv8/v8/src/x64/regexp-macro-assembler-x64.h +282 -0
  656. data/lib/libv8/v8/src/x64/simulator-x64.cc +27 -0
  657. data/lib/libv8/v8/src/x64/simulator-x64.h +72 -0
  658. data/lib/libv8/v8/src/x64/stub-cache-x64.cc +3610 -0
  659. data/lib/libv8/v8/src/zone-inl.h +140 -0
  660. data/lib/libv8/v8/src/zone.cc +196 -0
  661. data/lib/libv8/v8/src/zone.h +240 -0
  662. data/lib/libv8/v8/tools/codemap.js +265 -0
  663. data/lib/libv8/v8/tools/consarray.js +93 -0
  664. data/lib/libv8/v8/tools/csvparser.js +78 -0
  665. data/lib/libv8/v8/tools/disasm.py +92 -0
  666. data/lib/libv8/v8/tools/freebsd-tick-processor +10 -0
  667. data/lib/libv8/v8/tools/gc-nvp-trace-processor.py +342 -0
  668. data/lib/libv8/v8/tools/gcmole/README +62 -0
  669. data/lib/libv8/v8/tools/gcmole/gccause.lua +60 -0
  670. data/lib/libv8/v8/tools/gcmole/gcmole.cc +1261 -0
  671. data/lib/libv8/v8/tools/gcmole/gcmole.lua +378 -0
  672. data/lib/libv8/v8/tools/generate-ten-powers.scm +286 -0
  673. data/lib/libv8/v8/tools/grokdump.py +841 -0
  674. data/lib/libv8/v8/tools/gyp/v8.gyp +995 -0
  675. data/lib/libv8/v8/tools/js2c.py +364 -0
  676. data/lib/libv8/v8/tools/jsmin.py +280 -0
  677. data/lib/libv8/v8/tools/linux-tick-processor +35 -0
  678. data/lib/libv8/v8/tools/ll_prof.py +942 -0
  679. data/lib/libv8/v8/tools/logreader.js +185 -0
  680. data/lib/libv8/v8/tools/mac-nm +18 -0
  681. data/lib/libv8/v8/tools/mac-tick-processor +6 -0
  682. data/lib/libv8/v8/tools/oom_dump/README +31 -0
  683. data/lib/libv8/v8/tools/oom_dump/SConstruct +42 -0
  684. data/lib/libv8/v8/tools/oom_dump/oom_dump.cc +288 -0
  685. data/lib/libv8/v8/tools/presubmit.py +305 -0
  686. data/lib/libv8/v8/tools/process-heap-prof.py +120 -0
  687. data/lib/libv8/v8/tools/profile.js +751 -0
  688. data/lib/libv8/v8/tools/profile_view.js +219 -0
  689. data/lib/libv8/v8/tools/run-valgrind.py +77 -0
  690. data/lib/libv8/v8/tools/splaytree.js +316 -0
  691. data/lib/libv8/v8/tools/stats-viewer.py +468 -0
  692. data/lib/libv8/v8/tools/test.py +1510 -0
  693. data/lib/libv8/v8/tools/tickprocessor-driver.js +59 -0
  694. data/lib/libv8/v8/tools/tickprocessor.js +877 -0
  695. data/lib/libv8/v8/tools/utils.py +96 -0
  696. data/lib/libv8/v8/tools/visual_studio/README.txt +12 -0
  697. data/lib/libv8/v8/tools/windows-tick-processor.bat +30 -0
  698. data/lib/libv8/version.rb +4 -0
  699. data/libv8.gemspec +31 -0
  700. metadata +800 -0
@@ -0,0 +1,1256 @@
1
+ // Copyright 2010 the V8 project authors. All rights reserved.
2
+ // Redistribution and use in source and binary forms, with or without
3
+ // modification, are permitted provided that the following conditions are
4
+ // met:
5
+ //
6
+ // * Redistributions of source code must retain the above copyright
7
+ // notice, this list of conditions and the following disclaimer.
8
+ // * Redistributions in binary form must reproduce the above
9
+ // copyright notice, this list of conditions and the following
10
+ // disclaimer in the documentation and/or other materials provided
11
+ // with the distribution.
12
+ // * Neither the name of Google Inc. nor the names of its
13
+ // contributors may be used to endorse or promote products derived
14
+ // from this software without specific prior written permission.
15
+ //
16
+ // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17
+ // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18
+ // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19
+ // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20
+ // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21
+ // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22
+ // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23
+ // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
+ // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25
+ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26
+ // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
+
28
+ #include "v8.h"
29
+
30
+ #include "codegen.h"
31
+ #include "deoptimizer.h"
32
+ #include "disasm.h"
33
+ #include "full-codegen.h"
34
+ #include "global-handles.h"
35
+ #include "macro-assembler.h"
36
+ #include "prettyprinter.h"
37
+
38
+
39
+ namespace v8 {
40
+ namespace internal {
41
+
42
+ DeoptimizerData::DeoptimizerData() {
43
+ eager_deoptimization_entry_code_ = NULL;
44
+ lazy_deoptimization_entry_code_ = NULL;
45
+ current_ = NULL;
46
+ deoptimizing_code_list_ = NULL;
47
+ }
48
+
49
+
50
+ DeoptimizerData::~DeoptimizerData() {
51
+ if (eager_deoptimization_entry_code_ != NULL) {
52
+ eager_deoptimization_entry_code_->Free(EXECUTABLE);
53
+ eager_deoptimization_entry_code_ = NULL;
54
+ }
55
+ if (lazy_deoptimization_entry_code_ != NULL) {
56
+ lazy_deoptimization_entry_code_->Free(EXECUTABLE);
57
+ lazy_deoptimization_entry_code_ = NULL;
58
+ }
59
+ }
60
+
61
+ Deoptimizer* Deoptimizer::New(JSFunction* function,
62
+ BailoutType type,
63
+ unsigned bailout_id,
64
+ Address from,
65
+ int fp_to_sp_delta,
66
+ Isolate* isolate) {
67
+ ASSERT(isolate == Isolate::Current());
68
+ Deoptimizer* deoptimizer = new Deoptimizer(isolate,
69
+ function,
70
+ type,
71
+ bailout_id,
72
+ from,
73
+ fp_to_sp_delta);
74
+ ASSERT(isolate->deoptimizer_data()->current_ == NULL);
75
+ isolate->deoptimizer_data()->current_ = deoptimizer;
76
+ return deoptimizer;
77
+ }
78
+
79
+
80
+ Deoptimizer* Deoptimizer::Grab(Isolate* isolate) {
81
+ ASSERT(isolate == Isolate::Current());
82
+ Deoptimizer* result = isolate->deoptimizer_data()->current_;
83
+ ASSERT(result != NULL);
84
+ result->DeleteFrameDescriptions();
85
+ isolate->deoptimizer_data()->current_ = NULL;
86
+ return result;
87
+ }
88
+
89
+
90
+ void Deoptimizer::GenerateDeoptimizationEntries(MacroAssembler* masm,
91
+ int count,
92
+ BailoutType type) {
93
+ TableEntryGenerator generator(masm, type, count);
94
+ generator.Generate();
95
+ }
96
+
97
+
98
+ class DeoptimizingVisitor : public OptimizedFunctionVisitor {
99
+ public:
100
+ virtual void EnterContext(Context* context) {
101
+ if (FLAG_trace_deopt) {
102
+ PrintF("[deoptimize context: %" V8PRIxPTR "]\n",
103
+ reinterpret_cast<intptr_t>(context));
104
+ }
105
+ }
106
+
107
+ virtual void VisitFunction(JSFunction* function) {
108
+ Deoptimizer::DeoptimizeFunction(function);
109
+ }
110
+
111
+ virtual void LeaveContext(Context* context) {
112
+ context->ClearOptimizedFunctions();
113
+ }
114
+ };
115
+
116
+
117
+ void Deoptimizer::DeoptimizeAll() {
118
+ AssertNoAllocation no_allocation;
119
+
120
+ if (FLAG_trace_deopt) {
121
+ PrintF("[deoptimize all contexts]\n");
122
+ }
123
+
124
+ DeoptimizingVisitor visitor;
125
+ VisitAllOptimizedFunctions(&visitor);
126
+ }
127
+
128
+
129
+ void Deoptimizer::DeoptimizeGlobalObject(JSObject* object) {
130
+ AssertNoAllocation no_allocation;
131
+
132
+ DeoptimizingVisitor visitor;
133
+ VisitAllOptimizedFunctionsForGlobalObject(object, &visitor);
134
+ }
135
+
136
+
137
+ void Deoptimizer::VisitAllOptimizedFunctionsForContext(
138
+ Context* context, OptimizedFunctionVisitor* visitor) {
139
+ AssertNoAllocation no_allocation;
140
+
141
+ ASSERT(context->IsGlobalContext());
142
+
143
+ visitor->EnterContext(context);
144
+ // Run through the list of optimized functions and deoptimize them.
145
+ Object* element = context->OptimizedFunctionsListHead();
146
+ while (!element->IsUndefined()) {
147
+ JSFunction* element_function = JSFunction::cast(element);
148
+ // Get the next link before deoptimizing as deoptimizing will clear the
149
+ // next link.
150
+ element = element_function->next_function_link();
151
+ visitor->VisitFunction(element_function);
152
+ }
153
+ visitor->LeaveContext(context);
154
+ }
155
+
156
+
157
+ void Deoptimizer::VisitAllOptimizedFunctionsForGlobalObject(
158
+ JSObject* object, OptimizedFunctionVisitor* visitor) {
159
+ AssertNoAllocation no_allocation;
160
+
161
+ if (object->IsJSGlobalProxy()) {
162
+ Object* proto = object->GetPrototype();
163
+ ASSERT(proto->IsJSGlobalObject());
164
+ VisitAllOptimizedFunctionsForContext(
165
+ GlobalObject::cast(proto)->global_context(), visitor);
166
+ } else if (object->IsGlobalObject()) {
167
+ VisitAllOptimizedFunctionsForContext(
168
+ GlobalObject::cast(object)->global_context(), visitor);
169
+ }
170
+ }
171
+
172
+
173
+ void Deoptimizer::VisitAllOptimizedFunctions(
174
+ OptimizedFunctionVisitor* visitor) {
175
+ AssertNoAllocation no_allocation;
176
+
177
+ // Run through the list of all global contexts and deoptimize.
178
+ Object* global = Isolate::Current()->heap()->global_contexts_list();
179
+ while (!global->IsUndefined()) {
180
+ VisitAllOptimizedFunctionsForGlobalObject(Context::cast(global)->global(),
181
+ visitor);
182
+ global = Context::cast(global)->get(Context::NEXT_CONTEXT_LINK);
183
+ }
184
+ }
185
+
186
+
187
+ void Deoptimizer::HandleWeakDeoptimizedCode(
188
+ v8::Persistent<v8::Value> obj, void* data) {
189
+ DeoptimizingCodeListNode* node =
190
+ reinterpret_cast<DeoptimizingCodeListNode*>(data);
191
+ RemoveDeoptimizingCode(*node->code());
192
+ #ifdef DEBUG
193
+ node = Isolate::Current()->deoptimizer_data()->deoptimizing_code_list_;
194
+ while (node != NULL) {
195
+ ASSERT(node != reinterpret_cast<DeoptimizingCodeListNode*>(data));
196
+ node = node->next();
197
+ }
198
+ #endif
199
+ }
200
+
201
+
202
+ void Deoptimizer::ComputeOutputFrames(Deoptimizer* deoptimizer) {
203
+ deoptimizer->DoComputeOutputFrames();
204
+ }
205
+
206
+
207
+ Deoptimizer::Deoptimizer(Isolate* isolate,
208
+ JSFunction* function,
209
+ BailoutType type,
210
+ unsigned bailout_id,
211
+ Address from,
212
+ int fp_to_sp_delta)
213
+ : isolate_(isolate),
214
+ function_(function),
215
+ bailout_id_(bailout_id),
216
+ bailout_type_(type),
217
+ from_(from),
218
+ fp_to_sp_delta_(fp_to_sp_delta),
219
+ output_count_(0),
220
+ output_(NULL),
221
+ deferred_heap_numbers_(0) {
222
+ if (FLAG_trace_deopt && type != OSR) {
223
+ PrintF("**** DEOPT: ");
224
+ function->PrintName();
225
+ PrintF(" at bailout #%u, address 0x%" V8PRIxPTR ", frame size %d\n",
226
+ bailout_id,
227
+ reinterpret_cast<intptr_t>(from),
228
+ fp_to_sp_delta - (2 * kPointerSize));
229
+ } else if (FLAG_trace_osr && type == OSR) {
230
+ PrintF("**** OSR: ");
231
+ function->PrintName();
232
+ PrintF(" at ast id #%u, address 0x%" V8PRIxPTR ", frame size %d\n",
233
+ bailout_id,
234
+ reinterpret_cast<intptr_t>(from),
235
+ fp_to_sp_delta - (2 * kPointerSize));
236
+ }
237
+ // Find the optimized code.
238
+ if (type == EAGER) {
239
+ ASSERT(from == NULL);
240
+ optimized_code_ = function_->code();
241
+ } else if (type == LAZY) {
242
+ optimized_code_ = FindDeoptimizingCodeFromAddress(from);
243
+ ASSERT(optimized_code_ != NULL);
244
+ } else if (type == OSR) {
245
+ // The function has already been optimized and we're transitioning
246
+ // from the unoptimized shared version to the optimized one in the
247
+ // function. The return address (from) points to unoptimized code.
248
+ optimized_code_ = function_->code();
249
+ ASSERT(optimized_code_->kind() == Code::OPTIMIZED_FUNCTION);
250
+ ASSERT(!optimized_code_->contains(from));
251
+ }
252
+ ASSERT(HEAP->allow_allocation(false));
253
+ unsigned size = ComputeInputFrameSize();
254
+ input_ = new(size) FrameDescription(size, function);
255
+ }
256
+
257
+
258
+ Deoptimizer::~Deoptimizer() {
259
+ ASSERT(input_ == NULL && output_ == NULL);
260
+ }
261
+
262
+
263
+ void Deoptimizer::DeleteFrameDescriptions() {
264
+ delete input_;
265
+ for (int i = 0; i < output_count_; ++i) {
266
+ if (output_[i] != input_) delete output_[i];
267
+ }
268
+ delete[] output_;
269
+ input_ = NULL;
270
+ output_ = NULL;
271
+ ASSERT(!HEAP->allow_allocation(true));
272
+ }
273
+
274
+
275
+ Address Deoptimizer::GetDeoptimizationEntry(int id, BailoutType type) {
276
+ ASSERT(id >= 0);
277
+ if (id >= kNumberOfEntries) return NULL;
278
+ LargeObjectChunk* base = NULL;
279
+ DeoptimizerData* data = Isolate::Current()->deoptimizer_data();
280
+ if (type == EAGER) {
281
+ if (data->eager_deoptimization_entry_code_ == NULL) {
282
+ data->eager_deoptimization_entry_code_ = CreateCode(type);
283
+ }
284
+ base = data->eager_deoptimization_entry_code_;
285
+ } else {
286
+ if (data->lazy_deoptimization_entry_code_ == NULL) {
287
+ data->lazy_deoptimization_entry_code_ = CreateCode(type);
288
+ }
289
+ base = data->lazy_deoptimization_entry_code_;
290
+ }
291
+ return
292
+ static_cast<Address>(base->GetStartAddress()) + (id * table_entry_size_);
293
+ }
294
+
295
+
296
+ int Deoptimizer::GetDeoptimizationId(Address addr, BailoutType type) {
297
+ LargeObjectChunk* base = NULL;
298
+ DeoptimizerData* data = Isolate::Current()->deoptimizer_data();
299
+ if (type == EAGER) {
300
+ base = data->eager_deoptimization_entry_code_;
301
+ } else {
302
+ base = data->lazy_deoptimization_entry_code_;
303
+ }
304
+ if (base == NULL ||
305
+ addr < base->GetStartAddress() ||
306
+ addr >= base->GetStartAddress() +
307
+ (kNumberOfEntries * table_entry_size_)) {
308
+ return kNotDeoptimizationEntry;
309
+ }
310
+ ASSERT_EQ(0,
311
+ static_cast<int>(addr - base->GetStartAddress()) % table_entry_size_);
312
+ return static_cast<int>(addr - base->GetStartAddress()) / table_entry_size_;
313
+ }
314
+
315
+
316
+ int Deoptimizer::GetOutputInfo(DeoptimizationOutputData* data,
317
+ unsigned id,
318
+ SharedFunctionInfo* shared) {
319
+ // TODO(kasperl): For now, we do a simple linear search for the PC
320
+ // offset associated with the given node id. This should probably be
321
+ // changed to a binary search.
322
+ int length = data->DeoptPoints();
323
+ Smi* smi_id = Smi::FromInt(id);
324
+ for (int i = 0; i < length; i++) {
325
+ if (data->AstId(i) == smi_id) {
326
+ return data->PcAndState(i)->value();
327
+ }
328
+ }
329
+ PrintF("[couldn't find pc offset for node=%u]\n", id);
330
+ PrintF("[method: %s]\n", *shared->DebugName()->ToCString());
331
+ // Print the source code if available.
332
+ HeapStringAllocator string_allocator;
333
+ StringStream stream(&string_allocator);
334
+ shared->SourceCodePrint(&stream, -1);
335
+ PrintF("[source:\n%s\n]", *stream.ToCString());
336
+
337
+ UNREACHABLE();
338
+ return -1;
339
+ }
340
+
341
+
342
+ int Deoptimizer::GetDeoptimizedCodeCount(Isolate* isolate) {
343
+ int length = 0;
344
+ DeoptimizingCodeListNode* node =
345
+ isolate->deoptimizer_data()->deoptimizing_code_list_;
346
+ while (node != NULL) {
347
+ length++;
348
+ node = node->next();
349
+ }
350
+ return length;
351
+ }
352
+
353
+
354
+ void Deoptimizer::DoComputeOutputFrames() {
355
+ if (bailout_type_ == OSR) {
356
+ DoComputeOsrOutputFrame();
357
+ return;
358
+ }
359
+
360
+ // Print some helpful diagnostic information.
361
+ int64_t start = OS::Ticks();
362
+ if (FLAG_trace_deopt) {
363
+ PrintF("[deoptimizing%s: begin 0x%08" V8PRIxPTR " ",
364
+ (bailout_type_ == LAZY ? " (lazy)" : ""),
365
+ reinterpret_cast<intptr_t>(function_));
366
+ function_->PrintName();
367
+ PrintF(" @%d]\n", bailout_id_);
368
+ }
369
+
370
+ // Determine basic deoptimization information. The optimized frame is
371
+ // described by the input data.
372
+ DeoptimizationInputData* input_data =
373
+ DeoptimizationInputData::cast(optimized_code_->deoptimization_data());
374
+ unsigned node_id = input_data->AstId(bailout_id_)->value();
375
+ ByteArray* translations = input_data->TranslationByteArray();
376
+ unsigned translation_index =
377
+ input_data->TranslationIndex(bailout_id_)->value();
378
+
379
+ // Do the input frame to output frame(s) translation.
380
+ TranslationIterator iterator(translations, translation_index);
381
+ Translation::Opcode opcode =
382
+ static_cast<Translation::Opcode>(iterator.Next());
383
+ ASSERT(Translation::BEGIN == opcode);
384
+ USE(opcode);
385
+ // Read the number of output frames and allocate an array for their
386
+ // descriptions.
387
+ int count = iterator.Next();
388
+ ASSERT(output_ == NULL);
389
+ output_ = new FrameDescription*[count];
390
+ for (int i = 0; i < count; ++i) {
391
+ output_[i] = NULL;
392
+ }
393
+ output_count_ = count;
394
+
395
+ // Translate each output frame.
396
+ for (int i = 0; i < count; ++i) {
397
+ DoComputeFrame(&iterator, i);
398
+ }
399
+
400
+ // Print some helpful diagnostic information.
401
+ if (FLAG_trace_deopt) {
402
+ double ms = static_cast<double>(OS::Ticks() - start) / 1000;
403
+ int index = output_count_ - 1; // Index of the topmost frame.
404
+ JSFunction* function = output_[index]->GetFunction();
405
+ PrintF("[deoptimizing: end 0x%08" V8PRIxPTR " ",
406
+ reinterpret_cast<intptr_t>(function));
407
+ function->PrintName();
408
+ PrintF(" => node=%u, pc=0x%08" V8PRIxPTR ", state=%s, took %0.3f ms]\n",
409
+ node_id,
410
+ output_[index]->GetPc(),
411
+ FullCodeGenerator::State2String(
412
+ static_cast<FullCodeGenerator::State>(
413
+ output_[index]->GetState()->value())),
414
+ ms);
415
+ }
416
+ }
417
+
418
+
419
+ void Deoptimizer::MaterializeHeapNumbers() {
420
+ for (int i = 0; i < deferred_heap_numbers_.length(); i++) {
421
+ HeapNumberMaterializationDescriptor d = deferred_heap_numbers_[i];
422
+ Handle<Object> num = isolate_->factory()->NewNumber(d.value());
423
+ if (FLAG_trace_deopt) {
424
+ PrintF("Materializing a new heap number %p [%e] in slot %p\n",
425
+ reinterpret_cast<void*>(*num),
426
+ d.value(),
427
+ d.slot_address());
428
+ }
429
+
430
+ Memory::Object_at(d.slot_address()) = *num;
431
+ }
432
+ }
433
+
434
+
435
+ void Deoptimizer::DoTranslateCommand(TranslationIterator* iterator,
436
+ int frame_index,
437
+ unsigned output_offset) {
438
+ disasm::NameConverter converter;
439
+ // A GC-safe temporary placeholder that we can put in the output frame.
440
+ const intptr_t kPlaceholder = reinterpret_cast<intptr_t>(Smi::FromInt(0));
441
+
442
+ // Ignore commands marked as duplicate and act on the first non-duplicate.
443
+ Translation::Opcode opcode =
444
+ static_cast<Translation::Opcode>(iterator->Next());
445
+ while (opcode == Translation::DUPLICATE) {
446
+ opcode = static_cast<Translation::Opcode>(iterator->Next());
447
+ iterator->Skip(Translation::NumberOfOperandsFor(opcode));
448
+ opcode = static_cast<Translation::Opcode>(iterator->Next());
449
+ }
450
+
451
+ switch (opcode) {
452
+ case Translation::BEGIN:
453
+ case Translation::FRAME:
454
+ case Translation::DUPLICATE:
455
+ UNREACHABLE();
456
+ return;
457
+
458
+ case Translation::REGISTER: {
459
+ int input_reg = iterator->Next();
460
+ intptr_t input_value = input_->GetRegister(input_reg);
461
+ if (FLAG_trace_deopt) {
462
+ PrintF(
463
+ " 0x%08" V8PRIxPTR ": [top + %d] <- 0x%08" V8PRIxPTR " ; %s\n",
464
+ output_[frame_index]->GetTop() + output_offset,
465
+ output_offset,
466
+ input_value,
467
+ converter.NameOfCPURegister(input_reg));
468
+ }
469
+ output_[frame_index]->SetFrameSlot(output_offset, input_value);
470
+ return;
471
+ }
472
+
473
+ case Translation::INT32_REGISTER: {
474
+ int input_reg = iterator->Next();
475
+ intptr_t value = input_->GetRegister(input_reg);
476
+ bool is_smi = Smi::IsValid(value);
477
+ if (FLAG_trace_deopt) {
478
+ PrintF(
479
+ " 0x%08" V8PRIxPTR ": [top + %d] <- %" V8PRIdPTR " ; %s (%s)\n",
480
+ output_[frame_index]->GetTop() + output_offset,
481
+ output_offset,
482
+ value,
483
+ converter.NameOfCPURegister(input_reg),
484
+ is_smi ? "smi" : "heap number");
485
+ }
486
+ if (is_smi) {
487
+ intptr_t tagged_value =
488
+ reinterpret_cast<intptr_t>(Smi::FromInt(static_cast<int>(value)));
489
+ output_[frame_index]->SetFrameSlot(output_offset, tagged_value);
490
+ } else {
491
+ // We save the untagged value on the side and store a GC-safe
492
+ // temporary placeholder in the frame.
493
+ AddDoubleValue(output_[frame_index]->GetTop() + output_offset,
494
+ static_cast<double>(static_cast<int32_t>(value)));
495
+ output_[frame_index]->SetFrameSlot(output_offset, kPlaceholder);
496
+ }
497
+ return;
498
+ }
499
+
500
+ case Translation::DOUBLE_REGISTER: {
501
+ int input_reg = iterator->Next();
502
+ double value = input_->GetDoubleRegister(input_reg);
503
+ if (FLAG_trace_deopt) {
504
+ PrintF(" 0x%08" V8PRIxPTR ": [top + %d] <- %e ; %s\n",
505
+ output_[frame_index]->GetTop() + output_offset,
506
+ output_offset,
507
+ value,
508
+ DoubleRegister::AllocationIndexToString(input_reg));
509
+ }
510
+ // We save the untagged value on the side and store a GC-safe
511
+ // temporary placeholder in the frame.
512
+ AddDoubleValue(output_[frame_index]->GetTop() + output_offset, value);
513
+ output_[frame_index]->SetFrameSlot(output_offset, kPlaceholder);
514
+ return;
515
+ }
516
+
517
+ case Translation::STACK_SLOT: {
518
+ int input_slot_index = iterator->Next();
519
+ unsigned input_offset =
520
+ input_->GetOffsetFromSlotIndex(this, input_slot_index);
521
+ intptr_t input_value = input_->GetFrameSlot(input_offset);
522
+ if (FLAG_trace_deopt) {
523
+ PrintF(" 0x%08" V8PRIxPTR ": ",
524
+ output_[frame_index]->GetTop() + output_offset);
525
+ PrintF("[top + %d] <- 0x%08" V8PRIxPTR " ; [esp + %d]\n",
526
+ output_offset,
527
+ input_value,
528
+ input_offset);
529
+ }
530
+ output_[frame_index]->SetFrameSlot(output_offset, input_value);
531
+ return;
532
+ }
533
+
534
+ case Translation::INT32_STACK_SLOT: {
535
+ int input_slot_index = iterator->Next();
536
+ unsigned input_offset =
537
+ input_->GetOffsetFromSlotIndex(this, input_slot_index);
538
+ intptr_t value = input_->GetFrameSlot(input_offset);
539
+ bool is_smi = Smi::IsValid(value);
540
+ if (FLAG_trace_deopt) {
541
+ PrintF(" 0x%08" V8PRIxPTR ": ",
542
+ output_[frame_index]->GetTop() + output_offset);
543
+ PrintF("[top + %d] <- %" V8PRIdPTR " ; [esp + %d] (%s)\n",
544
+ output_offset,
545
+ value,
546
+ input_offset,
547
+ is_smi ? "smi" : "heap number");
548
+ }
549
+ if (is_smi) {
550
+ intptr_t tagged_value =
551
+ reinterpret_cast<intptr_t>(Smi::FromInt(static_cast<int>(value)));
552
+ output_[frame_index]->SetFrameSlot(output_offset, tagged_value);
553
+ } else {
554
+ // We save the untagged value on the side and store a GC-safe
555
+ // temporary placeholder in the frame.
556
+ AddDoubleValue(output_[frame_index]->GetTop() + output_offset,
557
+ static_cast<double>(static_cast<int32_t>(value)));
558
+ output_[frame_index]->SetFrameSlot(output_offset, kPlaceholder);
559
+ }
560
+ return;
561
+ }
562
+
563
+ case Translation::DOUBLE_STACK_SLOT: {
564
+ int input_slot_index = iterator->Next();
565
+ unsigned input_offset =
566
+ input_->GetOffsetFromSlotIndex(this, input_slot_index);
567
+ double value = input_->GetDoubleFrameSlot(input_offset);
568
+ if (FLAG_trace_deopt) {
569
+ PrintF(" 0x%08" V8PRIxPTR ": [top + %d] <- %e ; [esp + %d]\n",
570
+ output_[frame_index]->GetTop() + output_offset,
571
+ output_offset,
572
+ value,
573
+ input_offset);
574
+ }
575
+ // We save the untagged value on the side and store a GC-safe
576
+ // temporary placeholder in the frame.
577
+ AddDoubleValue(output_[frame_index]->GetTop() + output_offset, value);
578
+ output_[frame_index]->SetFrameSlot(output_offset, kPlaceholder);
579
+ return;
580
+ }
581
+
582
+ case Translation::LITERAL: {
583
+ Object* literal = ComputeLiteral(iterator->Next());
584
+ if (FLAG_trace_deopt) {
585
+ PrintF(" 0x%08" V8PRIxPTR ": [top + %d] <- ",
586
+ output_[frame_index]->GetTop() + output_offset,
587
+ output_offset);
588
+ literal->ShortPrint();
589
+ PrintF(" ; literal\n");
590
+ }
591
+ intptr_t value = reinterpret_cast<intptr_t>(literal);
592
+ output_[frame_index]->SetFrameSlot(output_offset, value);
593
+ return;
594
+ }
595
+
596
+ case Translation::ARGUMENTS_OBJECT: {
597
+ // Use the arguments marker value as a sentinel and fill in the arguments
598
+ // object after the deoptimized frame is built.
599
+ ASSERT(frame_index == 0); // Only supported for first frame.
600
+ if (FLAG_trace_deopt) {
601
+ PrintF(" 0x%08" V8PRIxPTR ": [top + %d] <- ",
602
+ output_[frame_index]->GetTop() + output_offset,
603
+ output_offset);
604
+ isolate_->heap()->arguments_marker()->ShortPrint();
605
+ PrintF(" ; arguments object\n");
606
+ }
607
+ intptr_t value = reinterpret_cast<intptr_t>(
608
+ isolate_->heap()->arguments_marker());
609
+ output_[frame_index]->SetFrameSlot(output_offset, value);
610
+ return;
611
+ }
612
+ }
613
+ }
614
+
615
+
616
+ bool Deoptimizer::DoOsrTranslateCommand(TranslationIterator* iterator,
617
+ int* input_offset) {
618
+ disasm::NameConverter converter;
619
+ FrameDescription* output = output_[0];
620
+
621
+ // The input values are all part of the unoptimized frame so they
622
+ // are all tagged pointers.
623
+ uintptr_t input_value = input_->GetFrameSlot(*input_offset);
624
+ Object* input_object = reinterpret_cast<Object*>(input_value);
625
+
626
+ Translation::Opcode opcode =
627
+ static_cast<Translation::Opcode>(iterator->Next());
628
+ bool duplicate = (opcode == Translation::DUPLICATE);
629
+ if (duplicate) {
630
+ opcode = static_cast<Translation::Opcode>(iterator->Next());
631
+ }
632
+
633
+ switch (opcode) {
634
+ case Translation::BEGIN:
635
+ case Translation::FRAME:
636
+ case Translation::DUPLICATE:
637
+ UNREACHABLE(); // Malformed input.
638
+ return false;
639
+
640
+ case Translation::REGISTER: {
641
+ int output_reg = iterator->Next();
642
+ if (FLAG_trace_osr) {
643
+ PrintF(" %s <- 0x%08" V8PRIxPTR " ; [sp + %d]\n",
644
+ converter.NameOfCPURegister(output_reg),
645
+ input_value,
646
+ *input_offset);
647
+ }
648
+ output->SetRegister(output_reg, input_value);
649
+ break;
650
+ }
651
+
652
+ case Translation::INT32_REGISTER: {
653
+ // Abort OSR if we don't have a number.
654
+ if (!input_object->IsNumber()) return false;
655
+
656
+ int output_reg = iterator->Next();
657
+ int int32_value = input_object->IsSmi()
658
+ ? Smi::cast(input_object)->value()
659
+ : FastD2I(input_object->Number());
660
+ // Abort the translation if the conversion lost information.
661
+ if (!input_object->IsSmi() &&
662
+ FastI2D(int32_value) != input_object->Number()) {
663
+ if (FLAG_trace_osr) {
664
+ PrintF("**** %g could not be converted to int32 ****\n",
665
+ input_object->Number());
666
+ }
667
+ return false;
668
+ }
669
+ if (FLAG_trace_osr) {
670
+ PrintF(" %s <- %d (int32) ; [sp + %d]\n",
671
+ converter.NameOfCPURegister(output_reg),
672
+ int32_value,
673
+ *input_offset);
674
+ }
675
+ output->SetRegister(output_reg, int32_value);
676
+ break;
677
+ }
678
+
679
+ case Translation::DOUBLE_REGISTER: {
680
+ // Abort OSR if we don't have a number.
681
+ if (!input_object->IsNumber()) return false;
682
+
683
+ int output_reg = iterator->Next();
684
+ double double_value = input_object->Number();
685
+ if (FLAG_trace_osr) {
686
+ PrintF(" %s <- %g (double) ; [sp + %d]\n",
687
+ DoubleRegister::AllocationIndexToString(output_reg),
688
+ double_value,
689
+ *input_offset);
690
+ }
691
+ output->SetDoubleRegister(output_reg, double_value);
692
+ break;
693
+ }
694
+
695
+ case Translation::STACK_SLOT: {
696
+ int output_index = iterator->Next();
697
+ unsigned output_offset =
698
+ output->GetOffsetFromSlotIndex(this, output_index);
699
+ if (FLAG_trace_osr) {
700
+ PrintF(" [sp + %d] <- 0x%08" V8PRIxPTR " ; [sp + %d]\n",
701
+ output_offset,
702
+ input_value,
703
+ *input_offset);
704
+ }
705
+ output->SetFrameSlot(output_offset, input_value);
706
+ break;
707
+ }
708
+
709
+ case Translation::INT32_STACK_SLOT: {
710
+ // Abort OSR if we don't have a number.
711
+ if (!input_object->IsNumber()) return false;
712
+
713
+ int output_index = iterator->Next();
714
+ unsigned output_offset =
715
+ output->GetOffsetFromSlotIndex(this, output_index);
716
+ int int32_value = input_object->IsSmi()
717
+ ? Smi::cast(input_object)->value()
718
+ : DoubleToInt32(input_object->Number());
719
+ // Abort the translation if the conversion lost information.
720
+ if (!input_object->IsSmi() &&
721
+ FastI2D(int32_value) != input_object->Number()) {
722
+ if (FLAG_trace_osr) {
723
+ PrintF("**** %g could not be converted to int32 ****\n",
724
+ input_object->Number());
725
+ }
726
+ return false;
727
+ }
728
+ if (FLAG_trace_osr) {
729
+ PrintF(" [sp + %d] <- %d (int32) ; [sp + %d]\n",
730
+ output_offset,
731
+ int32_value,
732
+ *input_offset);
733
+ }
734
+ output->SetFrameSlot(output_offset, int32_value);
735
+ break;
736
+ }
737
+
738
+ case Translation::DOUBLE_STACK_SLOT: {
739
+ static const int kLowerOffset = 0 * kPointerSize;
740
+ static const int kUpperOffset = 1 * kPointerSize;
741
+
742
+ // Abort OSR if we don't have a number.
743
+ if (!input_object->IsNumber()) return false;
744
+
745
+ int output_index = iterator->Next();
746
+ unsigned output_offset =
747
+ output->GetOffsetFromSlotIndex(this, output_index);
748
+ double double_value = input_object->Number();
749
+ uint64_t int_value = BitCast<uint64_t, double>(double_value);
750
+ int32_t lower = static_cast<int32_t>(int_value);
751
+ int32_t upper = static_cast<int32_t>(int_value >> kBitsPerInt);
752
+ if (FLAG_trace_osr) {
753
+ PrintF(" [sp + %d] <- 0x%08x (upper bits of %g) ; [sp + %d]\n",
754
+ output_offset + kUpperOffset,
755
+ upper,
756
+ double_value,
757
+ *input_offset);
758
+ PrintF(" [sp + %d] <- 0x%08x (lower bits of %g) ; [sp + %d]\n",
759
+ output_offset + kLowerOffset,
760
+ lower,
761
+ double_value,
762
+ *input_offset);
763
+ }
764
+ output->SetFrameSlot(output_offset + kLowerOffset, lower);
765
+ output->SetFrameSlot(output_offset + kUpperOffset, upper);
766
+ break;
767
+ }
768
+
769
+ case Translation::LITERAL: {
770
+ // Just ignore non-materialized literals.
771
+ iterator->Next();
772
+ break;
773
+ }
774
+
775
+ case Translation::ARGUMENTS_OBJECT: {
776
+ // Optimized code assumes that the argument object has not been
777
+ // materialized and so bypasses it when doing arguments access.
778
+ // We should have bailed out before starting the frame
779
+ // translation.
780
+ UNREACHABLE();
781
+ return false;
782
+ }
783
+ }
784
+
785
+ if (!duplicate) *input_offset -= kPointerSize;
786
+ return true;
787
+ }
788
+
789
+
790
+ void Deoptimizer::PatchStackCheckCode(Code* unoptimized_code,
791
+ Code* check_code,
792
+ Code* replacement_code) {
793
+ // Iterate over the stack check table and patch every stack check
794
+ // call to an unconditional call to the replacement code.
795
+ ASSERT(unoptimized_code->kind() == Code::FUNCTION);
796
+ Address stack_check_cursor = unoptimized_code->instruction_start() +
797
+ unoptimized_code->stack_check_table_offset();
798
+ uint32_t table_length = Memory::uint32_at(stack_check_cursor);
799
+ stack_check_cursor += kIntSize;
800
+ for (uint32_t i = 0; i < table_length; ++i) {
801
+ uint32_t pc_offset = Memory::uint32_at(stack_check_cursor + kIntSize);
802
+ Address pc_after = unoptimized_code->instruction_start() + pc_offset;
803
+ PatchStackCheckCodeAt(pc_after, check_code, replacement_code);
804
+ stack_check_cursor += 2 * kIntSize;
805
+ }
806
+ }
807
+
808
+
809
+ void Deoptimizer::RevertStackCheckCode(Code* unoptimized_code,
810
+ Code* check_code,
811
+ Code* replacement_code) {
812
+ // Iterate over the stack check table and revert the patched
813
+ // stack check calls.
814
+ ASSERT(unoptimized_code->kind() == Code::FUNCTION);
815
+ Address stack_check_cursor = unoptimized_code->instruction_start() +
816
+ unoptimized_code->stack_check_table_offset();
817
+ uint32_t table_length = Memory::uint32_at(stack_check_cursor);
818
+ stack_check_cursor += kIntSize;
819
+ for (uint32_t i = 0; i < table_length; ++i) {
820
+ uint32_t pc_offset = Memory::uint32_at(stack_check_cursor + kIntSize);
821
+ Address pc_after = unoptimized_code->instruction_start() + pc_offset;
822
+ RevertStackCheckCodeAt(pc_after, check_code, replacement_code);
823
+ stack_check_cursor += 2 * kIntSize;
824
+ }
825
+ }
826
+
827
+
828
+ unsigned Deoptimizer::ComputeInputFrameSize() const {
829
+ unsigned fixed_size = ComputeFixedSize(function_);
830
+ // The fp-to-sp delta already takes the context and the function
831
+ // into account so we have to avoid double counting them (-2).
832
+ unsigned result = fixed_size + fp_to_sp_delta_ - (2 * kPointerSize);
833
+ #ifdef DEBUG
834
+ if (bailout_type_ == OSR) {
835
+ // TODO(kasperl): It would be nice if we could verify that the
836
+ // size matches with the stack height we can compute based on the
837
+ // environment at the OSR entry. The code for that his built into
838
+ // the DoComputeOsrOutputFrame function for now.
839
+ } else {
840
+ unsigned stack_slots = optimized_code_->stack_slots();
841
+ unsigned outgoing_size = ComputeOutgoingArgumentSize();
842
+ ASSERT(result == fixed_size + (stack_slots * kPointerSize) + outgoing_size);
843
+ }
844
+ #endif
845
+ return result;
846
+ }
847
+
848
+
849
+ unsigned Deoptimizer::ComputeFixedSize(JSFunction* function) const {
850
+ // The fixed part of the frame consists of the return address, frame
851
+ // pointer, function, context, and all the incoming arguments.
852
+ static const unsigned kFixedSlotSize = 4 * kPointerSize;
853
+ return ComputeIncomingArgumentSize(function) + kFixedSlotSize;
854
+ }
855
+
856
+
857
+ unsigned Deoptimizer::ComputeIncomingArgumentSize(JSFunction* function) const {
858
+ // The incoming arguments is the values for formal parameters and
859
+ // the receiver. Every slot contains a pointer.
860
+ unsigned arguments = function->shared()->formal_parameter_count() + 1;
861
+ return arguments * kPointerSize;
862
+ }
863
+
864
+
865
+ unsigned Deoptimizer::ComputeOutgoingArgumentSize() const {
866
+ DeoptimizationInputData* data = DeoptimizationInputData::cast(
867
+ optimized_code_->deoptimization_data());
868
+ unsigned height = data->ArgumentsStackHeight(bailout_id_)->value();
869
+ return height * kPointerSize;
870
+ }
871
+
872
+
873
+ Object* Deoptimizer::ComputeLiteral(int index) const {
874
+ DeoptimizationInputData* data = DeoptimizationInputData::cast(
875
+ optimized_code_->deoptimization_data());
876
+ FixedArray* literals = data->LiteralArray();
877
+ return literals->get(index);
878
+ }
879
+
880
+
881
+ void Deoptimizer::AddDoubleValue(intptr_t slot_address,
882
+ double value) {
883
+ HeapNumberMaterializationDescriptor value_desc(
884
+ reinterpret_cast<Address>(slot_address), value);
885
+ deferred_heap_numbers_.Add(value_desc);
886
+ }
887
+
888
+
889
+ LargeObjectChunk* Deoptimizer::CreateCode(BailoutType type) {
890
+ // We cannot run this if the serializer is enabled because this will
891
+ // cause us to emit relocation information for the external
892
+ // references. This is fine because the deoptimizer's code section
893
+ // isn't meant to be serialized at all.
894
+ ASSERT(!Serializer::enabled());
895
+
896
+ MacroAssembler masm(Isolate::Current(), NULL, 16 * KB);
897
+ masm.set_emit_debug_code(false);
898
+ GenerateDeoptimizationEntries(&masm, kNumberOfEntries, type);
899
+ CodeDesc desc;
900
+ masm.GetCode(&desc);
901
+ ASSERT(desc.reloc_size == 0);
902
+
903
+ LargeObjectChunk* chunk = LargeObjectChunk::New(desc.instr_size, EXECUTABLE);
904
+ memcpy(chunk->GetStartAddress(), desc.buffer, desc.instr_size);
905
+ CPU::FlushICache(chunk->GetStartAddress(), desc.instr_size);
906
+ return chunk;
907
+ }
908
+
909
+
910
+ Code* Deoptimizer::FindDeoptimizingCodeFromAddress(Address addr) {
911
+ DeoptimizingCodeListNode* node =
912
+ Isolate::Current()->deoptimizer_data()->deoptimizing_code_list_;
913
+ while (node != NULL) {
914
+ if (node->code()->contains(addr)) return *node->code();
915
+ node = node->next();
916
+ }
917
+ return NULL;
918
+ }
919
+
920
+
921
+ void Deoptimizer::RemoveDeoptimizingCode(Code* code) {
922
+ DeoptimizerData* data = Isolate::Current()->deoptimizer_data();
923
+ ASSERT(data->deoptimizing_code_list_ != NULL);
924
+ // Run through the code objects to find this one and remove it.
925
+ DeoptimizingCodeListNode* prev = NULL;
926
+ DeoptimizingCodeListNode* current = data->deoptimizing_code_list_;
927
+ while (current != NULL) {
928
+ if (*current->code() == code) {
929
+ // Unlink from list. If prev is NULL we are looking at the first element.
930
+ if (prev == NULL) {
931
+ data->deoptimizing_code_list_ = current->next();
932
+ } else {
933
+ prev->set_next(current->next());
934
+ }
935
+ delete current;
936
+ return;
937
+ }
938
+ // Move to next in list.
939
+ prev = current;
940
+ current = current->next();
941
+ }
942
+ // Deoptimizing code is removed through weak callback. Each object is expected
943
+ // to be removed once and only once.
944
+ UNREACHABLE();
945
+ }
946
+
947
+
948
+ FrameDescription::FrameDescription(uint32_t frame_size,
949
+ JSFunction* function)
950
+ : frame_size_(frame_size),
951
+ function_(function),
952
+ top_(kZapUint32),
953
+ pc_(kZapUint32),
954
+ fp_(kZapUint32) {
955
+ // Zap all the registers.
956
+ for (int r = 0; r < Register::kNumRegisters; r++) {
957
+ SetRegister(r, kZapUint32);
958
+ }
959
+
960
+ // Zap all the slots.
961
+ for (unsigned o = 0; o < frame_size; o += kPointerSize) {
962
+ SetFrameSlot(o, kZapUint32);
963
+ }
964
+ }
965
+
966
+
967
+ unsigned FrameDescription::GetOffsetFromSlotIndex(Deoptimizer* deoptimizer,
968
+ int slot_index) {
969
+ if (slot_index >= 0) {
970
+ // Local or spill slots. Skip the fixed part of the frame
971
+ // including all arguments.
972
+ unsigned base = static_cast<unsigned>(
973
+ GetFrameSize() - deoptimizer->ComputeFixedSize(GetFunction()));
974
+ return base - ((slot_index + 1) * kPointerSize);
975
+ } else {
976
+ // Incoming parameter.
977
+ unsigned base = static_cast<unsigned>(GetFrameSize() -
978
+ deoptimizer->ComputeIncomingArgumentSize(GetFunction()));
979
+ return base - ((slot_index + 1) * kPointerSize);
980
+ }
981
+ }
982
+
983
+
984
+ void TranslationBuffer::Add(int32_t value) {
985
+ // Encode the sign bit in the least significant bit.
986
+ bool is_negative = (value < 0);
987
+ uint32_t bits = ((is_negative ? -value : value) << 1) |
988
+ static_cast<int32_t>(is_negative);
989
+ // Encode the individual bytes using the least significant bit of
990
+ // each byte to indicate whether or not more bytes follow.
991
+ do {
992
+ uint32_t next = bits >> 7;
993
+ contents_.Add(((bits << 1) & 0xFF) | (next != 0));
994
+ bits = next;
995
+ } while (bits != 0);
996
+ }
997
+
998
+
999
+ int32_t TranslationIterator::Next() {
1000
+ ASSERT(HasNext());
1001
+ // Run through the bytes until we reach one with a least significant
1002
+ // bit of zero (marks the end).
1003
+ uint32_t bits = 0;
1004
+ for (int i = 0; true; i += 7) {
1005
+ uint8_t next = buffer_->get(index_++);
1006
+ bits |= (next >> 1) << i;
1007
+ if ((next & 1) == 0) break;
1008
+ }
1009
+ // The bits encode the sign in the least significant bit.
1010
+ bool is_negative = (bits & 1) == 1;
1011
+ int32_t result = bits >> 1;
1012
+ return is_negative ? -result : result;
1013
+ }
1014
+
1015
+
1016
+ Handle<ByteArray> TranslationBuffer::CreateByteArray() {
1017
+ int length = contents_.length();
1018
+ Handle<ByteArray> result =
1019
+ Isolate::Current()->factory()->NewByteArray(length, TENURED);
1020
+ memcpy(result->GetDataStartAddress(), contents_.ToVector().start(), length);
1021
+ return result;
1022
+ }
1023
+
1024
+
1025
+ void Translation::BeginFrame(int node_id, int literal_id, unsigned height) {
1026
+ buffer_->Add(FRAME);
1027
+ buffer_->Add(node_id);
1028
+ buffer_->Add(literal_id);
1029
+ buffer_->Add(height);
1030
+ }
1031
+
1032
+
1033
+ void Translation::StoreRegister(Register reg) {
1034
+ buffer_->Add(REGISTER);
1035
+ buffer_->Add(reg.code());
1036
+ }
1037
+
1038
+
1039
+ void Translation::StoreInt32Register(Register reg) {
1040
+ buffer_->Add(INT32_REGISTER);
1041
+ buffer_->Add(reg.code());
1042
+ }
1043
+
1044
+
1045
+ void Translation::StoreDoubleRegister(DoubleRegister reg) {
1046
+ buffer_->Add(DOUBLE_REGISTER);
1047
+ buffer_->Add(DoubleRegister::ToAllocationIndex(reg));
1048
+ }
1049
+
1050
+
1051
+ void Translation::StoreStackSlot(int index) {
1052
+ buffer_->Add(STACK_SLOT);
1053
+ buffer_->Add(index);
1054
+ }
1055
+
1056
+
1057
+ void Translation::StoreInt32StackSlot(int index) {
1058
+ buffer_->Add(INT32_STACK_SLOT);
1059
+ buffer_->Add(index);
1060
+ }
1061
+
1062
+
1063
+ void Translation::StoreDoubleStackSlot(int index) {
1064
+ buffer_->Add(DOUBLE_STACK_SLOT);
1065
+ buffer_->Add(index);
1066
+ }
1067
+
1068
+
1069
+ void Translation::StoreLiteral(int literal_id) {
1070
+ buffer_->Add(LITERAL);
1071
+ buffer_->Add(literal_id);
1072
+ }
1073
+
1074
+
1075
+ void Translation::StoreArgumentsObject() {
1076
+ buffer_->Add(ARGUMENTS_OBJECT);
1077
+ }
1078
+
1079
+
1080
+ void Translation::MarkDuplicate() {
1081
+ buffer_->Add(DUPLICATE);
1082
+ }
1083
+
1084
+
1085
+ int Translation::NumberOfOperandsFor(Opcode opcode) {
1086
+ switch (opcode) {
1087
+ case ARGUMENTS_OBJECT:
1088
+ case DUPLICATE:
1089
+ return 0;
1090
+ case BEGIN:
1091
+ case REGISTER:
1092
+ case INT32_REGISTER:
1093
+ case DOUBLE_REGISTER:
1094
+ case STACK_SLOT:
1095
+ case INT32_STACK_SLOT:
1096
+ case DOUBLE_STACK_SLOT:
1097
+ case LITERAL:
1098
+ return 1;
1099
+ case FRAME:
1100
+ return 3;
1101
+ }
1102
+ UNREACHABLE();
1103
+ return -1;
1104
+ }
1105
+
1106
+
1107
+ #ifdef OBJECT_PRINT
1108
+
1109
+ const char* Translation::StringFor(Opcode opcode) {
1110
+ switch (opcode) {
1111
+ case BEGIN:
1112
+ return "BEGIN";
1113
+ case FRAME:
1114
+ return "FRAME";
1115
+ case REGISTER:
1116
+ return "REGISTER";
1117
+ case INT32_REGISTER:
1118
+ return "INT32_REGISTER";
1119
+ case DOUBLE_REGISTER:
1120
+ return "DOUBLE_REGISTER";
1121
+ case STACK_SLOT:
1122
+ return "STACK_SLOT";
1123
+ case INT32_STACK_SLOT:
1124
+ return "INT32_STACK_SLOT";
1125
+ case DOUBLE_STACK_SLOT:
1126
+ return "DOUBLE_STACK_SLOT";
1127
+ case LITERAL:
1128
+ return "LITERAL";
1129
+ case ARGUMENTS_OBJECT:
1130
+ return "ARGUMENTS_OBJECT";
1131
+ case DUPLICATE:
1132
+ return "DUPLICATE";
1133
+ }
1134
+ UNREACHABLE();
1135
+ return "";
1136
+ }
1137
+
1138
+ #endif
1139
+
1140
+
1141
+ DeoptimizingCodeListNode::DeoptimizingCodeListNode(Code* code): next_(NULL) {
1142
+ GlobalHandles* global_handles = Isolate::Current()->global_handles();
1143
+ // Globalize the code object and make it weak.
1144
+ code_ = Handle<Code>::cast(global_handles->Create(code));
1145
+ global_handles->MakeWeak(reinterpret_cast<Object**>(code_.location()),
1146
+ this,
1147
+ Deoptimizer::HandleWeakDeoptimizedCode);
1148
+ }
1149
+
1150
+
1151
+ DeoptimizingCodeListNode::~DeoptimizingCodeListNode() {
1152
+ GlobalHandles* global_handles = Isolate::Current()->global_handles();
1153
+ global_handles->Destroy(reinterpret_cast<Object**>(code_.location()));
1154
+ }
1155
+
1156
+
1157
+ // We can't intermix stack decoding and allocations because
1158
+ // deoptimization infrastracture is not GC safe.
1159
+ // Thus we build a temporary structure in malloced space.
1160
+ SlotRef SlotRef::ComputeSlotForNextArgument(TranslationIterator* iterator,
1161
+ DeoptimizationInputData* data,
1162
+ JavaScriptFrame* frame) {
1163
+ Translation::Opcode opcode =
1164
+ static_cast<Translation::Opcode>(iterator->Next());
1165
+
1166
+ switch (opcode) {
1167
+ case Translation::BEGIN:
1168
+ case Translation::FRAME:
1169
+ // Peeled off before getting here.
1170
+ break;
1171
+
1172
+ case Translation::ARGUMENTS_OBJECT:
1173
+ // This can be only emitted for local slots not for argument slots.
1174
+ break;
1175
+
1176
+ case Translation::REGISTER:
1177
+ case Translation::INT32_REGISTER:
1178
+ case Translation::DOUBLE_REGISTER:
1179
+ case Translation::DUPLICATE:
1180
+ // We are at safepoint which corresponds to call. All registers are
1181
+ // saved by caller so there would be no live registers at this
1182
+ // point. Thus these translation commands should not be used.
1183
+ break;
1184
+
1185
+ case Translation::STACK_SLOT: {
1186
+ int slot_index = iterator->Next();
1187
+ Address slot_addr = SlotAddress(frame, slot_index);
1188
+ return SlotRef(slot_addr, SlotRef::TAGGED);
1189
+ }
1190
+
1191
+ case Translation::INT32_STACK_SLOT: {
1192
+ int slot_index = iterator->Next();
1193
+ Address slot_addr = SlotAddress(frame, slot_index);
1194
+ return SlotRef(slot_addr, SlotRef::INT32);
1195
+ }
1196
+
1197
+ case Translation::DOUBLE_STACK_SLOT: {
1198
+ int slot_index = iterator->Next();
1199
+ Address slot_addr = SlotAddress(frame, slot_index);
1200
+ return SlotRef(slot_addr, SlotRef::DOUBLE);
1201
+ }
1202
+
1203
+ case Translation::LITERAL: {
1204
+ int literal_index = iterator->Next();
1205
+ return SlotRef(data->LiteralArray()->get(literal_index));
1206
+ }
1207
+ }
1208
+
1209
+ UNREACHABLE();
1210
+ return SlotRef();
1211
+ }
1212
+
1213
+
1214
+ void SlotRef::ComputeSlotMappingForArguments(JavaScriptFrame* frame,
1215
+ int inlined_frame_index,
1216
+ Vector<SlotRef>* args_slots) {
1217
+ AssertNoAllocation no_gc;
1218
+ int deopt_index = AstNode::kNoNumber;
1219
+ DeoptimizationInputData* data =
1220
+ static_cast<OptimizedFrame*>(frame)->GetDeoptimizationData(&deopt_index);
1221
+ TranslationIterator it(data->TranslationByteArray(),
1222
+ data->TranslationIndex(deopt_index)->value());
1223
+ Translation::Opcode opcode = static_cast<Translation::Opcode>(it.Next());
1224
+ ASSERT(opcode == Translation::BEGIN);
1225
+ int frame_count = it.Next();
1226
+ USE(frame_count);
1227
+ ASSERT(frame_count > inlined_frame_index);
1228
+ int frames_to_skip = inlined_frame_index;
1229
+ while (true) {
1230
+ opcode = static_cast<Translation::Opcode>(it.Next());
1231
+ // Skip over operands to advance to the next opcode.
1232
+ it.Skip(Translation::NumberOfOperandsFor(opcode));
1233
+ if (opcode == Translation::FRAME) {
1234
+ if (frames_to_skip == 0) {
1235
+ // We reached the frame corresponding to the inlined function
1236
+ // in question. Process the translation commands for the
1237
+ // arguments.
1238
+ //
1239
+ // Skip the translation command for the receiver.
1240
+ it.Skip(Translation::NumberOfOperandsFor(
1241
+ static_cast<Translation::Opcode>(it.Next())));
1242
+ // Compute slots for arguments.
1243
+ for (int i = 0; i < args_slots->length(); ++i) {
1244
+ (*args_slots)[i] = ComputeSlotForNextArgument(&it, data, frame);
1245
+ }
1246
+ return;
1247
+ }
1248
+ frames_to_skip--;
1249
+ }
1250
+ }
1251
+
1252
+ UNREACHABLE();
1253
+ }
1254
+
1255
+
1256
+ } } // namespace v8::internal