libv8 3.3.10.2

Sign up to get free protection for your applications and to get access to all the features.
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,52 @@
1
+ // Copyright 2011 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
+ #if defined(V8_TARGET_ARCH_ARM)
31
+
32
+ #include "codegen.h"
33
+
34
+ namespace v8 {
35
+ namespace internal {
36
+
37
+ // -------------------------------------------------------------------------
38
+ // Platform-specific RuntimeCallHelper functions.
39
+
40
+ void StubRuntimeCallHelper::BeforeCall(MacroAssembler* masm) const {
41
+ masm->EnterInternalFrame();
42
+ }
43
+
44
+
45
+ void StubRuntimeCallHelper::AfterCall(MacroAssembler* masm) const {
46
+ masm->LeaveInternalFrame();
47
+ }
48
+
49
+
50
+ } } // namespace v8::internal
51
+
52
+ #endif // V8_TARGET_ARCH_ARM
@@ -0,0 +1,91 @@
1
+ // Copyright 2011 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
+ #ifndef V8_ARM_CODEGEN_ARM_H_
29
+ #define V8_ARM_CODEGEN_ARM_H_
30
+
31
+ #include "ast.h"
32
+ #include "code-stubs-arm.h"
33
+ #include "ic-inl.h"
34
+
35
+ namespace v8 {
36
+ namespace internal {
37
+
38
+ // Forward declarations
39
+ class CompilationInfo;
40
+
41
+ enum TypeofState { INSIDE_TYPEOF, NOT_INSIDE_TYPEOF };
42
+
43
+ // -------------------------------------------------------------------------
44
+ // CodeGenerator
45
+
46
+ class CodeGenerator: public AstVisitor {
47
+ public:
48
+ static bool MakeCode(CompilationInfo* info);
49
+
50
+ // Printing of AST, etc. as requested by flags.
51
+ static void MakeCodePrologue(CompilationInfo* info);
52
+
53
+ // Allocate and install the code.
54
+ static Handle<Code> MakeCodeEpilogue(MacroAssembler* masm,
55
+ Code::Flags flags,
56
+ CompilationInfo* info);
57
+
58
+ // Print the code after compiling it.
59
+ static void PrintCode(Handle<Code> code, CompilationInfo* info);
60
+
61
+ #ifdef ENABLE_LOGGING_AND_PROFILING
62
+ static bool ShouldGenerateLog(Expression* type);
63
+ #endif
64
+
65
+ static void SetFunctionInfo(Handle<JSFunction> fun,
66
+ FunctionLiteral* lit,
67
+ bool is_toplevel,
68
+ Handle<Script> script);
69
+
70
+ static bool RecordPositions(MacroAssembler* masm,
71
+ int pos,
72
+ bool right_here = false);
73
+
74
+ // Constants related to patching of inlined load/store.
75
+ static int GetInlinedKeyedLoadInstructionsAfterPatch() {
76
+ return FLAG_debug_code ? 32 : 13;
77
+ }
78
+ static const int kInlinedKeyedStoreInstructionsAfterPatch = 8;
79
+ static int GetInlinedNamedStoreInstructionsAfterPatch() {
80
+ ASSERT(Isolate::Current()->inlined_write_barrier_size() != -1);
81
+ return Isolate::Current()->inlined_write_barrier_size() + 4;
82
+ }
83
+
84
+ private:
85
+ DISALLOW_COPY_AND_ASSIGN(CodeGenerator);
86
+ };
87
+
88
+
89
+ } } // namespace v8::internal
90
+
91
+ #endif // V8_ARM_CODEGEN_ARM_H_
@@ -0,0 +1,152 @@
1
+ // Copyright 2009 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
+ #if defined(V8_TARGET_ARCH_ARM)
31
+
32
+ #include "constants-arm.h"
33
+
34
+
35
+ namespace v8 {
36
+ namespace internal {
37
+
38
+ double Instruction::DoubleImmedVmov() const {
39
+ // Reconstruct a double from the immediate encoded in the vmov instruction.
40
+ //
41
+ // instruction: [xxxxxxxx,xxxxabcd,xxxxxxxx,xxxxefgh]
42
+ // double: [aBbbbbbb,bbcdefgh,00000000,00000000,
43
+ // 00000000,00000000,00000000,00000000]
44
+ //
45
+ // where B = ~b. Only the high 16 bits are affected.
46
+ uint64_t high16;
47
+ high16 = (Bits(17, 16) << 4) | Bits(3, 0); // xxxxxxxx,xxcdefgh.
48
+ high16 |= (0xff * Bit(18)) << 6; // xxbbbbbb,bbxxxxxx.
49
+ high16 |= (Bit(18) ^ 1) << 14; // xBxxxxxx,xxxxxxxx.
50
+ high16 |= Bit(19) << 15; // axxxxxxx,xxxxxxxx.
51
+
52
+ uint64_t imm = high16 << 48;
53
+ double d;
54
+ memcpy(&d, &imm, 8);
55
+ return d;
56
+ }
57
+
58
+
59
+ // These register names are defined in a way to match the native disassembler
60
+ // formatting. See for example the command "objdump -d <binary file>".
61
+ const char* Registers::names_[kNumRegisters] = {
62
+ "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
63
+ "r8", "r9", "r10", "fp", "ip", "sp", "lr", "pc",
64
+ };
65
+
66
+
67
+ // List of alias names which can be used when referring to ARM registers.
68
+ const Registers::RegisterAlias Registers::aliases_[] = {
69
+ {10, "sl"},
70
+ {11, "r11"},
71
+ {12, "r12"},
72
+ {13, "r13"},
73
+ {14, "r14"},
74
+ {15, "r15"},
75
+ {kNoRegister, NULL}
76
+ };
77
+
78
+
79
+ const char* Registers::Name(int reg) {
80
+ const char* result;
81
+ if ((0 <= reg) && (reg < kNumRegisters)) {
82
+ result = names_[reg];
83
+ } else {
84
+ result = "noreg";
85
+ }
86
+ return result;
87
+ }
88
+
89
+
90
+ // Support for VFP registers s0 to s31 (d0 to d15).
91
+ // Note that "sN:sM" is the same as "dN/2"
92
+ // These register names are defined in a way to match the native disassembler
93
+ // formatting. See for example the command "objdump -d <binary file>".
94
+ const char* VFPRegisters::names_[kNumVFPRegisters] = {
95
+ "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7",
96
+ "s8", "s9", "s10", "s11", "s12", "s13", "s14", "s15",
97
+ "s16", "s17", "s18", "s19", "s20", "s21", "s22", "s23",
98
+ "s24", "s25", "s26", "s27", "s28", "s29", "s30", "s31",
99
+ "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7",
100
+ "d8", "d9", "d10", "d11", "d12", "d13", "d14", "d15"
101
+ };
102
+
103
+
104
+ const char* VFPRegisters::Name(int reg, bool is_double) {
105
+ ASSERT((0 <= reg) && (reg < kNumVFPRegisters));
106
+ return names_[reg + (is_double ? kNumVFPSingleRegisters : 0)];
107
+ }
108
+
109
+
110
+ int VFPRegisters::Number(const char* name, bool* is_double) {
111
+ for (int i = 0; i < kNumVFPRegisters; i++) {
112
+ if (strcmp(names_[i], name) == 0) {
113
+ if (i < kNumVFPSingleRegisters) {
114
+ *is_double = false;
115
+ return i;
116
+ } else {
117
+ *is_double = true;
118
+ return i - kNumVFPSingleRegisters;
119
+ }
120
+ }
121
+ }
122
+
123
+ // No register with the requested name found.
124
+ return kNoRegister;
125
+ }
126
+
127
+
128
+ int Registers::Number(const char* name) {
129
+ // Look through the canonical names.
130
+ for (int i = 0; i < kNumRegisters; i++) {
131
+ if (strcmp(names_[i], name) == 0) {
132
+ return i;
133
+ }
134
+ }
135
+
136
+ // Look through the alias names.
137
+ int i = 0;
138
+ while (aliases_[i].reg != kNoRegister) {
139
+ if (strcmp(aliases_[i].name, name) == 0) {
140
+ return aliases_[i].reg;
141
+ }
142
+ i++;
143
+ }
144
+
145
+ // No register with the requested name found.
146
+ return kNoRegister;
147
+ }
148
+
149
+
150
+ } } // namespace v8::internal
151
+
152
+ #endif // V8_TARGET_ARCH_ARM
@@ -0,0 +1,775 @@
1
+ // Copyright 2011 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
+ #ifndef V8_ARM_CONSTANTS_ARM_H_
29
+ #define V8_ARM_CONSTANTS_ARM_H_
30
+
31
+ // ARM EABI is required.
32
+ #if defined(__arm__) && !defined(__ARM_EABI__)
33
+ #error ARM EABI support is required.
34
+ #endif
35
+
36
+ // This means that interwork-compatible jump instructions are generated. We
37
+ // want to generate them on the simulator too so it makes snapshots that can
38
+ // be used on real hardware.
39
+ #if defined(__THUMB_INTERWORK__) || !defined(__arm__)
40
+ # define USE_THUMB_INTERWORK 1
41
+ #endif
42
+
43
+ #if defined(__ARM_ARCH_7A__) || \
44
+ defined(__ARM_ARCH_7R__) || \
45
+ defined(__ARM_ARCH_7__)
46
+ # define CAN_USE_ARMV7_INSTRUCTIONS 1
47
+ #endif
48
+
49
+ #if defined(__ARM_ARCH_6__) || \
50
+ defined(__ARM_ARCH_6J__) || \
51
+ defined(__ARM_ARCH_6K__) || \
52
+ defined(__ARM_ARCH_6Z__) || \
53
+ defined(__ARM_ARCH_6ZK__) || \
54
+ defined(__ARM_ARCH_6T2__) || \
55
+ defined(CAN_USE_ARMV7_INSTRUCTIONS)
56
+ # define CAN_USE_ARMV6_INSTRUCTIONS 1
57
+ #endif
58
+
59
+ #if defined(__ARM_ARCH_5T__) || \
60
+ defined(__ARM_ARCH_5TE__) || \
61
+ defined(CAN_USE_ARMV6_INSTRUCTIONS)
62
+ # define CAN_USE_ARMV5_INSTRUCTIONS 1
63
+ # define CAN_USE_THUMB_INSTRUCTIONS 1
64
+ #endif
65
+
66
+ // Simulator should support ARM5 instructions and unaligned access by default.
67
+ #if !defined(__arm__)
68
+ # define CAN_USE_ARMV5_INSTRUCTIONS 1
69
+ # define CAN_USE_THUMB_INSTRUCTIONS 1
70
+
71
+ # ifndef CAN_USE_UNALIGNED_ACCESSES
72
+ # define CAN_USE_UNALIGNED_ACCESSES 1
73
+ # endif
74
+
75
+ #endif
76
+
77
+ #if CAN_USE_UNALIGNED_ACCESSES
78
+ #define V8_TARGET_CAN_READ_UNALIGNED 1
79
+ #endif
80
+
81
+ // Using blx may yield better code, so use it when required or when available
82
+ #if defined(USE_THUMB_INTERWORK) || defined(CAN_USE_ARMV5_INSTRUCTIONS)
83
+ #define USE_BLX 1
84
+ #endif
85
+
86
+ namespace v8 {
87
+ namespace internal {
88
+
89
+ // Constant pool marker.
90
+ static const int kConstantPoolMarkerMask = 0xffe00000;
91
+ static const int kConstantPoolMarker = 0x0c000000;
92
+ static const int kConstantPoolLengthMask = 0x001ffff;
93
+
94
+ // Number of registers in normal ARM mode.
95
+ static const int kNumRegisters = 16;
96
+
97
+ // VFP support.
98
+ static const int kNumVFPSingleRegisters = 32;
99
+ static const int kNumVFPDoubleRegisters = 16;
100
+ static const int kNumVFPRegisters =
101
+ kNumVFPSingleRegisters + kNumVFPDoubleRegisters;
102
+
103
+ // PC is register 15.
104
+ static const int kPCRegister = 15;
105
+ static const int kNoRegister = -1;
106
+
107
+ // -----------------------------------------------------------------------------
108
+ // Conditions.
109
+
110
+ // Defines constants and accessor classes to assemble, disassemble and
111
+ // simulate ARM instructions.
112
+ //
113
+ // Section references in the code refer to the "ARM Architecture Reference
114
+ // Manual" from July 2005 (available at http://www.arm.com/miscPDFs/14128.pdf)
115
+ //
116
+ // Constants for specific fields are defined in their respective named enums.
117
+ // General constants are in an anonymous enum in class Instr.
118
+
119
+ // Values for the condition field as defined in section A3.2
120
+ enum Condition {
121
+ kNoCondition = -1,
122
+
123
+ eq = 0 << 28, // Z set Equal.
124
+ ne = 1 << 28, // Z clear Not equal.
125
+ cs = 2 << 28, // C set Unsigned higher or same.
126
+ cc = 3 << 28, // C clear Unsigned lower.
127
+ mi = 4 << 28, // N set Negative.
128
+ pl = 5 << 28, // N clear Positive or zero.
129
+ vs = 6 << 28, // V set Overflow.
130
+ vc = 7 << 28, // V clear No overflow.
131
+ hi = 8 << 28, // C set, Z clear Unsigned higher.
132
+ ls = 9 << 28, // C clear or Z set Unsigned lower or same.
133
+ ge = 10 << 28, // N == V Greater or equal.
134
+ lt = 11 << 28, // N != V Less than.
135
+ gt = 12 << 28, // Z clear, N == V Greater than.
136
+ le = 13 << 28, // Z set or N != V Less then or equal
137
+ al = 14 << 28, // Always.
138
+
139
+ kSpecialCondition = 15 << 28, // Special condition (refer to section A3.2.1).
140
+ kNumberOfConditions = 16,
141
+
142
+ // Aliases.
143
+ hs = cs, // C set Unsigned higher or same.
144
+ lo = cc // C clear Unsigned lower.
145
+ };
146
+
147
+
148
+ inline Condition NegateCondition(Condition cond) {
149
+ ASSERT(cond != al);
150
+ return static_cast<Condition>(cond ^ ne);
151
+ }
152
+
153
+
154
+ // Corresponds to transposing the operands of a comparison.
155
+ inline Condition ReverseCondition(Condition cond) {
156
+ switch (cond) {
157
+ case lo:
158
+ return hi;
159
+ case hi:
160
+ return lo;
161
+ case hs:
162
+ return ls;
163
+ case ls:
164
+ return hs;
165
+ case lt:
166
+ return gt;
167
+ case gt:
168
+ return lt;
169
+ case ge:
170
+ return le;
171
+ case le:
172
+ return ge;
173
+ default:
174
+ return cond;
175
+ };
176
+ }
177
+
178
+
179
+ // -----------------------------------------------------------------------------
180
+ // Instructions encoding.
181
+
182
+ // Instr is merely used by the Assembler to distinguish 32bit integers
183
+ // representing instructions from usual 32 bit values.
184
+ // Instruction objects are pointers to 32bit values, and provide methods to
185
+ // access the various ISA fields.
186
+ typedef int32_t Instr;
187
+
188
+
189
+ // Opcodes for Data-processing instructions (instructions with a type 0 and 1)
190
+ // as defined in section A3.4
191
+ enum Opcode {
192
+ AND = 0 << 21, // Logical AND.
193
+ EOR = 1 << 21, // Logical Exclusive OR.
194
+ SUB = 2 << 21, // Subtract.
195
+ RSB = 3 << 21, // Reverse Subtract.
196
+ ADD = 4 << 21, // Add.
197
+ ADC = 5 << 21, // Add with Carry.
198
+ SBC = 6 << 21, // Subtract with Carry.
199
+ RSC = 7 << 21, // Reverse Subtract with Carry.
200
+ TST = 8 << 21, // Test.
201
+ TEQ = 9 << 21, // Test Equivalence.
202
+ CMP = 10 << 21, // Compare.
203
+ CMN = 11 << 21, // Compare Negated.
204
+ ORR = 12 << 21, // Logical (inclusive) OR.
205
+ MOV = 13 << 21, // Move.
206
+ BIC = 14 << 21, // Bit Clear.
207
+ MVN = 15 << 21 // Move Not.
208
+ };
209
+
210
+
211
+ // The bits for bit 7-4 for some type 0 miscellaneous instructions.
212
+ enum MiscInstructionsBits74 {
213
+ // With bits 22-21 01.
214
+ BX = 1 << 4,
215
+ BXJ = 2 << 4,
216
+ BLX = 3 << 4,
217
+ BKPT = 7 << 4,
218
+
219
+ // With bits 22-21 11.
220
+ CLZ = 1 << 4
221
+ };
222
+
223
+
224
+ // Instruction encoding bits and masks.
225
+ enum {
226
+ H = 1 << 5, // Halfword (or byte).
227
+ S6 = 1 << 6, // Signed (or unsigned).
228
+ L = 1 << 20, // Load (or store).
229
+ S = 1 << 20, // Set condition code (or leave unchanged).
230
+ W = 1 << 21, // Writeback base register (or leave unchanged).
231
+ A = 1 << 21, // Accumulate in multiply instruction (or not).
232
+ B = 1 << 22, // Unsigned byte (or word).
233
+ N = 1 << 22, // Long (or short).
234
+ U = 1 << 23, // Positive (or negative) offset/index.
235
+ P = 1 << 24, // Offset/pre-indexed addressing (or post-indexed addressing).
236
+ I = 1 << 25, // Immediate shifter operand (or not).
237
+
238
+ B4 = 1 << 4,
239
+ B5 = 1 << 5,
240
+ B6 = 1 << 6,
241
+ B7 = 1 << 7,
242
+ B8 = 1 << 8,
243
+ B9 = 1 << 9,
244
+ B12 = 1 << 12,
245
+ B16 = 1 << 16,
246
+ B18 = 1 << 18,
247
+ B19 = 1 << 19,
248
+ B20 = 1 << 20,
249
+ B21 = 1 << 21,
250
+ B22 = 1 << 22,
251
+ B23 = 1 << 23,
252
+ B24 = 1 << 24,
253
+ B25 = 1 << 25,
254
+ B26 = 1 << 26,
255
+ B27 = 1 << 27,
256
+ B28 = 1 << 28,
257
+
258
+ // Instruction bit masks.
259
+ kCondMask = 15 << 28,
260
+ kALUMask = 0x6f << 21,
261
+ kRdMask = 15 << 12, // In str instruction.
262
+ kCoprocessorMask = 15 << 8,
263
+ kOpCodeMask = 15 << 21, // In data-processing instructions.
264
+ kImm24Mask = (1 << 24) - 1,
265
+ kOff12Mask = (1 << 12) - 1
266
+ };
267
+
268
+
269
+ // -----------------------------------------------------------------------------
270
+ // Addressing modes and instruction variants.
271
+
272
+ // Condition code updating mode.
273
+ enum SBit {
274
+ SetCC = 1 << 20, // Set condition code.
275
+ LeaveCC = 0 << 20 // Leave condition code unchanged.
276
+ };
277
+
278
+
279
+ // Status register selection.
280
+ enum SRegister {
281
+ CPSR = 0 << 22,
282
+ SPSR = 1 << 22
283
+ };
284
+
285
+
286
+ // Shifter types for Data-processing operands as defined in section A5.1.2.
287
+ enum ShiftOp {
288
+ LSL = 0 << 5, // Logical shift left.
289
+ LSR = 1 << 5, // Logical shift right.
290
+ ASR = 2 << 5, // Arithmetic shift right.
291
+ ROR = 3 << 5, // Rotate right.
292
+
293
+ // RRX is encoded as ROR with shift_imm == 0.
294
+ // Use a special code to make the distinction. The RRX ShiftOp is only used
295
+ // as an argument, and will never actually be encoded. The Assembler will
296
+ // detect it and emit the correct ROR shift operand with shift_imm == 0.
297
+ RRX = -1,
298
+ kNumberOfShifts = 4
299
+ };
300
+
301
+
302
+ // Status register fields.
303
+ enum SRegisterField {
304
+ CPSR_c = CPSR | 1 << 16,
305
+ CPSR_x = CPSR | 1 << 17,
306
+ CPSR_s = CPSR | 1 << 18,
307
+ CPSR_f = CPSR | 1 << 19,
308
+ SPSR_c = SPSR | 1 << 16,
309
+ SPSR_x = SPSR | 1 << 17,
310
+ SPSR_s = SPSR | 1 << 18,
311
+ SPSR_f = SPSR | 1 << 19
312
+ };
313
+
314
+ // Status register field mask (or'ed SRegisterField enum values).
315
+ typedef uint32_t SRegisterFieldMask;
316
+
317
+
318
+ // Memory operand addressing mode.
319
+ enum AddrMode {
320
+ // Bit encoding P U W.
321
+ Offset = (8|4|0) << 21, // Offset (without writeback to base).
322
+ PreIndex = (8|4|1) << 21, // Pre-indexed addressing with writeback.
323
+ PostIndex = (0|4|0) << 21, // Post-indexed addressing with writeback.
324
+ NegOffset = (8|0|0) << 21, // Negative offset (without writeback to base).
325
+ NegPreIndex = (8|0|1) << 21, // Negative pre-indexed with writeback.
326
+ NegPostIndex = (0|0|0) << 21 // Negative post-indexed with writeback.
327
+ };
328
+
329
+
330
+ // Load/store multiple addressing mode.
331
+ enum BlockAddrMode {
332
+ // Bit encoding P U W .
333
+ da = (0|0|0) << 21, // Decrement after.
334
+ ia = (0|4|0) << 21, // Increment after.
335
+ db = (8|0|0) << 21, // Decrement before.
336
+ ib = (8|4|0) << 21, // Increment before.
337
+ da_w = (0|0|1) << 21, // Decrement after with writeback to base.
338
+ ia_w = (0|4|1) << 21, // Increment after with writeback to base.
339
+ db_w = (8|0|1) << 21, // Decrement before with writeback to base.
340
+ ib_w = (8|4|1) << 21, // Increment before with writeback to base.
341
+
342
+ // Alias modes for comparison when writeback does not matter.
343
+ da_x = (0|0|0) << 21, // Decrement after.
344
+ ia_x = (0|4|0) << 21, // Increment after.
345
+ db_x = (8|0|0) << 21, // Decrement before.
346
+ ib_x = (8|4|0) << 21, // Increment before.
347
+
348
+ kBlockAddrModeMask = (8|4|1) << 21
349
+ };
350
+
351
+
352
+ // Coprocessor load/store operand size.
353
+ enum LFlag {
354
+ Long = 1 << 22, // Long load/store coprocessor.
355
+ Short = 0 << 22 // Short load/store coprocessor.
356
+ };
357
+
358
+
359
+ // -----------------------------------------------------------------------------
360
+ // Supervisor Call (svc) specific support.
361
+
362
+ // Special Software Interrupt codes when used in the presence of the ARM
363
+ // simulator.
364
+ // svc (formerly swi) provides a 24bit immediate value. Use bits 22:0 for
365
+ // standard SoftwareInterrupCode. Bit 23 is reserved for the stop feature.
366
+ enum SoftwareInterruptCodes {
367
+ // transition to C code
368
+ kCallRtRedirected= 0x10,
369
+ // break point
370
+ kBreakpoint= 0x20,
371
+ // stop
372
+ kStopCode = 1 << 23
373
+ };
374
+ static const uint32_t kStopCodeMask = kStopCode - 1;
375
+ static const uint32_t kMaxStopCode = kStopCode - 1;
376
+ static const int32_t kDefaultStopCode = -1;
377
+
378
+
379
+ // Type of VFP register. Determines register encoding.
380
+ enum VFPRegPrecision {
381
+ kSinglePrecision = 0,
382
+ kDoublePrecision = 1
383
+ };
384
+
385
+
386
+ // VFP FPSCR constants.
387
+ enum VFPConversionMode {
388
+ kFPSCRRounding = 0,
389
+ kDefaultRoundToZero = 1
390
+ };
391
+
392
+ // This mask does not include the "inexact" or "input denormal" cumulative
393
+ // exceptions flags, because we usually don't want to check for it.
394
+ static const uint32_t kVFPExceptionMask = 0xf;
395
+ static const uint32_t kVFPInvalidOpExceptionBit = 1 << 0;
396
+ static const uint32_t kVFPOverflowExceptionBit = 1 << 2;
397
+ static const uint32_t kVFPUnderflowExceptionBit = 1 << 3;
398
+ static const uint32_t kVFPInexactExceptionBit = 1 << 4;
399
+ static const uint32_t kVFPFlushToZeroMask = 1 << 24;
400
+
401
+ static const uint32_t kVFPNConditionFlagBit = 1 << 31;
402
+ static const uint32_t kVFPZConditionFlagBit = 1 << 30;
403
+ static const uint32_t kVFPCConditionFlagBit = 1 << 29;
404
+ static const uint32_t kVFPVConditionFlagBit = 1 << 28;
405
+
406
+
407
+ // VFP rounding modes. See ARM DDI 0406B Page A2-29.
408
+ enum VFPRoundingMode {
409
+ RN = 0 << 22, // Round to Nearest.
410
+ RP = 1 << 22, // Round towards Plus Infinity.
411
+ RM = 2 << 22, // Round towards Minus Infinity.
412
+ RZ = 3 << 22, // Round towards zero.
413
+
414
+ // Aliases.
415
+ kRoundToNearest = RN,
416
+ kRoundToPlusInf = RP,
417
+ kRoundToMinusInf = RM,
418
+ kRoundToZero = RZ
419
+ };
420
+
421
+ static const uint32_t kVFPRoundingModeMask = 3 << 22;
422
+
423
+ enum CheckForInexactConversion {
424
+ kCheckForInexactConversion,
425
+ kDontCheckForInexactConversion
426
+ };
427
+
428
+ // -----------------------------------------------------------------------------
429
+ // Hints.
430
+
431
+ // Branch hints are not used on the ARM. They are defined so that they can
432
+ // appear in shared function signatures, but will be ignored in ARM
433
+ // implementations.
434
+ enum Hint { no_hint };
435
+
436
+ // Hints are not used on the arm. Negating is trivial.
437
+ inline Hint NegateHint(Hint ignored) { return no_hint; }
438
+
439
+
440
+ // -----------------------------------------------------------------------------
441
+ // Specific instructions, constants, and masks.
442
+ // These constants are declared in assembler-arm.cc, as they use named registers
443
+ // and other constants.
444
+
445
+
446
+ // add(sp, sp, 4) instruction (aka Pop())
447
+ extern const Instr kPopInstruction;
448
+
449
+ // str(r, MemOperand(sp, 4, NegPreIndex), al) instruction (aka push(r))
450
+ // register r is not encoded.
451
+ extern const Instr kPushRegPattern;
452
+
453
+ // ldr(r, MemOperand(sp, 4, PostIndex), al) instruction (aka pop(r))
454
+ // register r is not encoded.
455
+ extern const Instr kPopRegPattern;
456
+
457
+ // mov lr, pc
458
+ extern const Instr kMovLrPc;
459
+ // ldr rd, [pc, #offset]
460
+ extern const Instr kLdrPCMask;
461
+ extern const Instr kLdrPCPattern;
462
+ // blxcc rm
463
+ extern const Instr kBlxRegMask;
464
+
465
+ extern const Instr kBlxRegPattern;
466
+
467
+ extern const Instr kMovMvnMask;
468
+ extern const Instr kMovMvnPattern;
469
+ extern const Instr kMovMvnFlip;
470
+ extern const Instr kMovLeaveCCMask;
471
+ extern const Instr kMovLeaveCCPattern;
472
+ extern const Instr kMovwMask;
473
+ extern const Instr kMovwPattern;
474
+ extern const Instr kMovwLeaveCCFlip;
475
+ extern const Instr kCmpCmnMask;
476
+ extern const Instr kCmpCmnPattern;
477
+ extern const Instr kCmpCmnFlip;
478
+ extern const Instr kAddSubFlip;
479
+ extern const Instr kAndBicFlip;
480
+
481
+ // A mask for the Rd register for push, pop, ldr, str instructions.
482
+ extern const Instr kLdrRegFpOffsetPattern;
483
+
484
+ extern const Instr kStrRegFpOffsetPattern;
485
+
486
+ extern const Instr kLdrRegFpNegOffsetPattern;
487
+
488
+ extern const Instr kStrRegFpNegOffsetPattern;
489
+
490
+ extern const Instr kLdrStrInstrTypeMask;
491
+ extern const Instr kLdrStrInstrArgumentMask;
492
+ extern const Instr kLdrStrOffsetMask;
493
+
494
+
495
+ // -----------------------------------------------------------------------------
496
+ // Instruction abstraction.
497
+
498
+ // The class Instruction enables access to individual fields defined in the ARM
499
+ // architecture instruction set encoding as described in figure A3-1.
500
+ // Note that the Assembler uses typedef int32_t Instr.
501
+ //
502
+ // Example: Test whether the instruction at ptr does set the condition code
503
+ // bits.
504
+ //
505
+ // bool InstructionSetsConditionCodes(byte* ptr) {
506
+ // Instruction* instr = Instruction::At(ptr);
507
+ // int type = instr->TypeValue();
508
+ // return ((type == 0) || (type == 1)) && instr->HasS();
509
+ // }
510
+ //
511
+ class Instruction {
512
+ public:
513
+ enum {
514
+ kInstrSize = 4,
515
+ kInstrSizeLog2 = 2,
516
+ kPCReadOffset = 8
517
+ };
518
+
519
+ // Helper macro to define static accessors.
520
+ // We use the cast to char* trick to bypass the strict anti-aliasing rules.
521
+ #define DECLARE_STATIC_TYPED_ACCESSOR(return_type, Name) \
522
+ static inline return_type Name(Instr instr) { \
523
+ char* temp = reinterpret_cast<char*>(&instr); \
524
+ return reinterpret_cast<Instruction*>(temp)->Name(); \
525
+ }
526
+
527
+ #define DECLARE_STATIC_ACCESSOR(Name) DECLARE_STATIC_TYPED_ACCESSOR(int, Name)
528
+
529
+ // Get the raw instruction bits.
530
+ inline Instr InstructionBits() const {
531
+ return *reinterpret_cast<const Instr*>(this);
532
+ }
533
+
534
+ // Set the raw instruction bits to value.
535
+ inline void SetInstructionBits(Instr value) {
536
+ *reinterpret_cast<Instr*>(this) = value;
537
+ }
538
+
539
+ // Read one particular bit out of the instruction bits.
540
+ inline int Bit(int nr) const {
541
+ return (InstructionBits() >> nr) & 1;
542
+ }
543
+
544
+ // Read a bit field's value out of the instruction bits.
545
+ inline int Bits(int hi, int lo) const {
546
+ return (InstructionBits() >> lo) & ((2 << (hi - lo)) - 1);
547
+ }
548
+
549
+ // Read a bit field out of the instruction bits.
550
+ inline int BitField(int hi, int lo) const {
551
+ return InstructionBits() & (((2 << (hi - lo)) - 1) << lo);
552
+ }
553
+
554
+ // Static support.
555
+
556
+ // Read one particular bit out of the instruction bits.
557
+ static inline int Bit(Instr instr, int nr) {
558
+ return (instr >> nr) & 1;
559
+ }
560
+
561
+ // Read the value of a bit field out of the instruction bits.
562
+ static inline int Bits(Instr instr, int hi, int lo) {
563
+ return (instr >> lo) & ((2 << (hi - lo)) - 1);
564
+ }
565
+
566
+
567
+ // Read a bit field out of the instruction bits.
568
+ static inline int BitField(Instr instr, int hi, int lo) {
569
+ return instr & (((2 << (hi - lo)) - 1) << lo);
570
+ }
571
+
572
+
573
+ // Accessors for the different named fields used in the ARM encoding.
574
+ // The naming of these accessor corresponds to figure A3-1.
575
+ //
576
+ // Two kind of accessors are declared:
577
+ // - <Name>Field() will return the raw field, ie the field's bits at their
578
+ // original place in the instruction encoding.
579
+ // eg. if instr is the 'addgt r0, r1, r2' instruction, encoded as 0xC0810002
580
+ // ConditionField(instr) will return 0xC0000000.
581
+ // - <Name>Value() will return the field value, shifted back to bit 0.
582
+ // eg. if instr is the 'addgt r0, r1, r2' instruction, encoded as 0xC0810002
583
+ // ConditionField(instr) will return 0xC.
584
+
585
+
586
+ // Generally applicable fields
587
+ inline Condition ConditionValue() const {
588
+ return static_cast<Condition>(Bits(31, 28));
589
+ }
590
+ inline Condition ConditionField() const {
591
+ return static_cast<Condition>(BitField(31, 28));
592
+ }
593
+ DECLARE_STATIC_TYPED_ACCESSOR(Condition, ConditionValue);
594
+ DECLARE_STATIC_TYPED_ACCESSOR(Condition, ConditionField);
595
+
596
+ inline int TypeValue() const { return Bits(27, 25); }
597
+
598
+ inline int RnValue() const { return Bits(19, 16); }
599
+ DECLARE_STATIC_ACCESSOR(RnValue);
600
+ inline int RdValue() const { return Bits(15, 12); }
601
+ DECLARE_STATIC_ACCESSOR(RdValue);
602
+
603
+ inline int CoprocessorValue() const { return Bits(11, 8); }
604
+ // Support for VFP.
605
+ // Vn(19-16) | Vd(15-12) | Vm(3-0)
606
+ inline int VnValue() const { return Bits(19, 16); }
607
+ inline int VmValue() const { return Bits(3, 0); }
608
+ inline int VdValue() const { return Bits(15, 12); }
609
+ inline int NValue() const { return Bit(7); }
610
+ inline int MValue() const { return Bit(5); }
611
+ inline int DValue() const { return Bit(22); }
612
+ inline int RtValue() const { return Bits(15, 12); }
613
+ inline int PValue() const { return Bit(24); }
614
+ inline int UValue() const { return Bit(23); }
615
+ inline int Opc1Value() const { return (Bit(23) << 2) | Bits(21, 20); }
616
+ inline int Opc2Value() const { return Bits(19, 16); }
617
+ inline int Opc3Value() const { return Bits(7, 6); }
618
+ inline int SzValue() const { return Bit(8); }
619
+ inline int VLValue() const { return Bit(20); }
620
+ inline int VCValue() const { return Bit(8); }
621
+ inline int VAValue() const { return Bits(23, 21); }
622
+ inline int VBValue() const { return Bits(6, 5); }
623
+ inline int VFPNRegValue(VFPRegPrecision pre) {
624
+ return VFPGlueRegValue(pre, 16, 7);
625
+ }
626
+ inline int VFPMRegValue(VFPRegPrecision pre) {
627
+ return VFPGlueRegValue(pre, 0, 5);
628
+ }
629
+ inline int VFPDRegValue(VFPRegPrecision pre) {
630
+ return VFPGlueRegValue(pre, 12, 22);
631
+ }
632
+
633
+ // Fields used in Data processing instructions
634
+ inline int OpcodeValue() const {
635
+ return static_cast<Opcode>(Bits(24, 21));
636
+ }
637
+ inline Opcode OpcodeField() const {
638
+ return static_cast<Opcode>(BitField(24, 21));
639
+ }
640
+ inline int SValue() const { return Bit(20); }
641
+ // with register
642
+ inline int RmValue() const { return Bits(3, 0); }
643
+ DECLARE_STATIC_ACCESSOR(RmValue);
644
+ inline int ShiftValue() const { return static_cast<ShiftOp>(Bits(6, 5)); }
645
+ inline ShiftOp ShiftField() const {
646
+ return static_cast<ShiftOp>(BitField(6, 5));
647
+ }
648
+ inline int RegShiftValue() const { return Bit(4); }
649
+ inline int RsValue() const { return Bits(11, 8); }
650
+ inline int ShiftAmountValue() const { return Bits(11, 7); }
651
+ // with immediate
652
+ inline int RotateValue() const { return Bits(11, 8); }
653
+ inline int Immed8Value() const { return Bits(7, 0); }
654
+ inline int Immed4Value() const { return Bits(19, 16); }
655
+ inline int ImmedMovwMovtValue() const {
656
+ return Immed4Value() << 12 | Offset12Value(); }
657
+
658
+ // Fields used in Load/Store instructions
659
+ inline int PUValue() const { return Bits(24, 23); }
660
+ inline int PUField() const { return BitField(24, 23); }
661
+ inline int BValue() const { return Bit(22); }
662
+ inline int WValue() const { return Bit(21); }
663
+ inline int LValue() const { return Bit(20); }
664
+ // with register uses same fields as Data processing instructions above
665
+ // with immediate
666
+ inline int Offset12Value() const { return Bits(11, 0); }
667
+ // multiple
668
+ inline int RlistValue() const { return Bits(15, 0); }
669
+ // extra loads and stores
670
+ inline int SignValue() const { return Bit(6); }
671
+ inline int HValue() const { return Bit(5); }
672
+ inline int ImmedHValue() const { return Bits(11, 8); }
673
+ inline int ImmedLValue() const { return Bits(3, 0); }
674
+
675
+ // Fields used in Branch instructions
676
+ inline int LinkValue() const { return Bit(24); }
677
+ inline int SImmed24Value() const { return ((InstructionBits() << 8) >> 8); }
678
+
679
+ // Fields used in Software interrupt instructions
680
+ inline SoftwareInterruptCodes SvcValue() const {
681
+ return static_cast<SoftwareInterruptCodes>(Bits(23, 0));
682
+ }
683
+
684
+ // Test for special encodings of type 0 instructions (extra loads and stores,
685
+ // as well as multiplications).
686
+ inline bool IsSpecialType0() const { return (Bit(7) == 1) && (Bit(4) == 1); }
687
+
688
+ // Test for miscellaneous instructions encodings of type 0 instructions.
689
+ inline bool IsMiscType0() const { return (Bit(24) == 1)
690
+ && (Bit(23) == 0)
691
+ && (Bit(20) == 0)
692
+ && ((Bit(7) == 0)); }
693
+
694
+ // Test for a stop instruction.
695
+ inline bool IsStop() const {
696
+ return (TypeValue() == 7) && (Bit(24) == 1) && (SvcValue() >= kStopCode);
697
+ }
698
+
699
+ // Special accessors that test for existence of a value.
700
+ inline bool HasS() const { return SValue() == 1; }
701
+ inline bool HasB() const { return BValue() == 1; }
702
+ inline bool HasW() const { return WValue() == 1; }
703
+ inline bool HasL() const { return LValue() == 1; }
704
+ inline bool HasU() const { return UValue() == 1; }
705
+ inline bool HasSign() const { return SignValue() == 1; }
706
+ inline bool HasH() const { return HValue() == 1; }
707
+ inline bool HasLink() const { return LinkValue() == 1; }
708
+
709
+ // Decoding the double immediate in the vmov instruction.
710
+ double DoubleImmedVmov() const;
711
+
712
+ // Instructions are read of out a code stream. The only way to get a
713
+ // reference to an instruction is to convert a pointer. There is no way
714
+ // to allocate or create instances of class Instruction.
715
+ // Use the At(pc) function to create references to Instruction.
716
+ static Instruction* At(byte* pc) {
717
+ return reinterpret_cast<Instruction*>(pc);
718
+ }
719
+
720
+
721
+ private:
722
+ // Join split register codes, depending on single or double precision.
723
+ // four_bit is the position of the least-significant bit of the four
724
+ // bit specifier. one_bit is the position of the additional single bit
725
+ // specifier.
726
+ inline int VFPGlueRegValue(VFPRegPrecision pre, int four_bit, int one_bit) {
727
+ if (pre == kSinglePrecision) {
728
+ return (Bits(four_bit + 3, four_bit) << 1) | Bit(one_bit);
729
+ }
730
+ return (Bit(one_bit) << 4) | Bits(four_bit + 3, four_bit);
731
+ }
732
+
733
+ // We need to prevent the creation of instances of class Instruction.
734
+ DISALLOW_IMPLICIT_CONSTRUCTORS(Instruction);
735
+ };
736
+
737
+
738
+ // Helper functions for converting between register numbers and names.
739
+ class Registers {
740
+ public:
741
+ // Return the name of the register.
742
+ static const char* Name(int reg);
743
+
744
+ // Lookup the register number for the name provided.
745
+ static int Number(const char* name);
746
+
747
+ struct RegisterAlias {
748
+ int reg;
749
+ const char* name;
750
+ };
751
+
752
+ private:
753
+ static const char* names_[kNumRegisters];
754
+ static const RegisterAlias aliases_[];
755
+ };
756
+
757
+ // Helper functions for converting between VFP register numbers and names.
758
+ class VFPRegisters {
759
+ public:
760
+ // Return the name of the register.
761
+ static const char* Name(int reg, bool is_double);
762
+
763
+ // Lookup the register number for the name provided.
764
+ // Set flag pointed by is_double to true if register
765
+ // is double-precision.
766
+ static int Number(const char* name, bool* is_double);
767
+
768
+ private:
769
+ static const char* names_[kNumVFPRegisters];
770
+ };
771
+
772
+
773
+ } } // namespace v8::internal
774
+
775
+ #endif // V8_ARM_CONSTANTS_ARM_H_