| Index: tools/nacl-run.py | 
| diff --git a/tools/android-run.py b/tools/nacl-run.py | 
| similarity index 57% | 
| copy from tools/android-run.py | 
| copy to tools/nacl-run.py | 
| index 1693c5b064b9008a29a50140b9c521312f213fb5..135172caf90f2c73e61fdfbc68760f0ac7e28db2 100755 | 
| --- a/tools/android-run.py | 
| +++ b/tools/nacl-run.py | 
| @@ -1,6 +1,6 @@ | 
| #!/usr/bin/env python | 
| # | 
| -# Copyright 2012 the V8 project authors. All rights reserved. | 
| +# Copyright 2013 the V8 project authors. All rights reserved. | 
| # Redistribution and use in source and binary forms, with or without | 
| # modification, are permitted provided that the following conditions are | 
| # met: | 
| @@ -27,13 +27,8 @@ | 
| # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
| # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
|  | 
| -# This script executes the passed command line on Android device | 
| -# using 'adb shell' command. Unfortunately, 'adb shell' always | 
| -# returns exit code 0, ignoring the exit code of executed command. | 
| -# Since we need to return non-zero exit code if the command failed, | 
| -# we augment the passed command line with exit code checking statement | 
| -# and output special error string in case of non-zero exit code. | 
| -# Then we parse the output of 'adb shell' and look for that error string. | 
| +# This script executes the passed command line using the Native Client | 
| +# 'sel_ldr' container. It is derived from android-run.py. | 
|  | 
| import os | 
| from os.path import join, dirname, abspath | 
| @@ -83,26 +78,73 @@ def WriteToTemporaryFile(data): | 
| tmp_file.close() | 
| return fname | 
|  | 
| +def GetNaClArchFromNexe(nexe): | 
| +  try: | 
| +    p = subprocess.Popen(['file', nexe], stdout=subprocess.PIPE) | 
| +    out, err = p.communicate() | 
| +    lines = out.split('\n') | 
| +    if lines[0].find(": ELF 32-bit LSB executable, Intel 80386") > 0: | 
| +      return "x86_32" | 
| +    if lines[0].find(": ELF 64-bit LSB executable, x86-64") > 0: | 
| +      return "x86_64" | 
| +  except: | 
| +    print 'file ' + sys.argv[1] + ' failed' | 
| +  return None | 
| + | 
| +def GetNaClResources(nexe): | 
| +  nacl_sdk_dir = os.environ["NACL_SDK_ROOT"] | 
| +  nacl_arch = GetNaClArchFromNexe(nexe) | 
| +  if sys.platform.startswith("linux"): | 
| +    platform = "linux" | 
| +  elif sys.platform == "darwin": | 
| +    platform = "mac" | 
| +  else: | 
| +    print("NaCl V8 testing is supported on Linux and MacOS only.") | 
| +    sys.exit(1) | 
| + | 
| +  if nacl_arch is "x86_64": | 
| +    toolchain = platform + "_x86_glibc" | 
| +    sel_ldr = "sel_ldr_x86_64" | 
| +    irt = "irt_core_x86_64.nexe" | 
| +    libdir = "lib64" | 
| +  elif nacl_arch is "x86_32": | 
| +    toolchain = platform + "_x86_glibc" | 
| +    sel_ldr = "sel_ldr_x86_32" | 
| +    irt = "irt_core_x86_32.nexe" | 
| +    libdir = "lib32" | 
| +  elif nacl_arch is "arm": | 
| +    print("NaCl V8 ARM support is not ready yet.") | 
| +    sys.exit(1) | 
| +  else: | 
| +    print("Invalid nexe %s" % nexe) | 
| +    sys.exit(1) | 
| + | 
| +  nacl_sel_ldr = os.path.join(nacl_sdk_dir, "tools", sel_ldr) | 
| +  nacl_irt = os.path.join(nacl_sdk_dir, "tools", irt) | 
| +  nacl_ld_so = os.path.join(nacl_sdk_dir, "toolchain", toolchain, | 
| +                            "x86_64-nacl", libdir, "runnable-ld.so") | 
| +  nacl_lib_path = os.path.join(nacl_sdk_dir, "toolchain", toolchain, | 
| +                               "x86_64-nacl", libdir) | 
| + | 
| +  return (nacl_sdk_dir, nacl_sel_ldr, nacl_irt, nacl_ld_so, nacl_lib_path) | 
| + | 
| def Main(): | 
| if (len(sys.argv) == 1): | 
| print("Usage: %s <command-to-run-on-device>" % sys.argv[0]) | 
| return 1 | 
| -  workspace = abspath(join(dirname(sys.argv[0]), '..')) | 
| -  android_workspace = os.getenv("ANDROID_V8", "/data/local/v8") | 
| + | 
| args = [Escape(arg) for arg in sys.argv[1:]] | 
| -  script = (" ".join(args) + "\n" | 
| -            "case $? in\n" | 
| -            "  0) ;;\n" | 
| -            "  *) echo \"ANDROID: Error returned by test\";;\n" | 
| -            "esac\n") | 
| -  script = script.replace(workspace, android_workspace) | 
| -  script_file = WriteToTemporaryFile(script) | 
| -  android_script_file = android_workspace + "/" + script_file | 
| -  command =  ("adb push '%s' %s;" % (script_file, android_script_file) + | 
| -              "adb shell 'sh %s';" % android_script_file + | 
| -              "adb shell 'rm %s'" % android_script_file) | 
| + | 
| +  (nacl_sdk_dir, nacl_sel_ldr, nacl_irt, nacl_ld_so, | 
| +   nacl_lib_path) = GetNaClResources(sys.argv[1]) | 
| + | 
| +  # sel_ldr Options: | 
| +  # -c -c: disable validation (for performance) | 
| +  # -a: allow file access | 
| +  # -B <irt>: load the IRT | 
| +  command = ' '.join([nacl_sel_ldr, '-c', '-c', '-a', '-B', nacl_irt, '--', | 
| +                     nacl_ld_so, '--library-path', nacl_lib_path] + args) | 
| error_code = Execute(command) | 
| -  os.unlink(script_file) | 
| return error_code | 
|  | 
| if __name__ == '__main__': | 
|  |