mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-11-24 14:26:09 +03:00
189 lines
6.4 KiB
Plaintext
189 lines
6.4 KiB
Plaintext
# Copyright 2015 The Native Client Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
import("//build/config/nacl/config.gni")
|
|
|
|
# Generate a nmf file
|
|
#
|
|
# Native Client Manifest (nmf) is a JSON file that tells the browser where to
|
|
# download and load Native Client application files and libraries.
|
|
#
|
|
# Variables:
|
|
# executables: .nexe/.pexe/.bc executables to generate nmf for
|
|
# lib_prefix: path to prepend to shared libraries in the nmf
|
|
# nmf: the name and the path of the output file
|
|
# nmfflags: additional flags for the nmf generator
|
|
# stage_dependencies: directory for staging libraries
|
|
template("generate_nmf") {
|
|
assert(defined(invoker.executables), "Must define executables")
|
|
assert(defined(invoker.nmf), "Must define nmf")
|
|
|
|
action(target_name) {
|
|
forward_variables_from(invoker,
|
|
[
|
|
"deps",
|
|
"data_deps",
|
|
"executables",
|
|
"lib_prefix",
|
|
"nmf",
|
|
"nmfflags",
|
|
"public_deps",
|
|
"stage_dependencies",
|
|
"testonly",
|
|
"visibility",
|
|
])
|
|
if (!defined(nmfflags)) {
|
|
nmfflags = []
|
|
}
|
|
|
|
# TODO(phosek): Remove this conditional once
|
|
# https://bugs.chromium.org/p/nativeclient/issues/detail?id=4339 is
|
|
# resolved.
|
|
if (current_cpu == "pnacl") {
|
|
objdump = rebase_path("${nacl_toolchain_bindir}/x86_64-nacl-objdump")
|
|
} else {
|
|
objdump = rebase_path("${nacl_toolprefix}objdump")
|
|
}
|
|
if (host_os == "win") {
|
|
objdump += ".exe"
|
|
}
|
|
|
|
script = "//native_client_sdk/src/tools/create_nmf.py"
|
|
inputs = [
|
|
objdump,
|
|
]
|
|
sources = executables
|
|
outputs = [
|
|
nmf,
|
|
]
|
|
if (is_nacl_glibc) {
|
|
if (defined(stage_dependencies)) {
|
|
nmfflags += [ "--stage-dependencies=" +
|
|
rebase_path(stage_dependencies, root_build_dir) ]
|
|
lib_path = stage_dependencies
|
|
} else {
|
|
lib_path = root_build_dir
|
|
}
|
|
if (defined(lib_prefix)) {
|
|
nmfflags += [ "--lib-prefix=" + lib_prefix ]
|
|
lib_path += "/${lib_prefix}"
|
|
}
|
|
|
|
# Starts empty so the code below can use += everywhere.
|
|
data = []
|
|
|
|
nmfflags +=
|
|
[ "--library-path=" + rebase_path(root_out_dir, root_build_dir) ]
|
|
|
|
# NOTE: There is no explicit dependency for the lib directory
|
|
# (lib32 and lib64 for x86/x64) created in the product directory.
|
|
# They are created as a side-effect of nmf creation.
|
|
if (current_cpu != "x86" && current_cpu != "x64") {
|
|
nmfflags +=
|
|
[ "--library-path=" +
|
|
rebase_path("${nacl_toolchain_tooldir}/lib", root_build_dir) ]
|
|
if (current_cpu == "arm") {
|
|
data += [ "${lib_path}/libarm/" ]
|
|
} else {
|
|
data += [ "${lib_path}/lib/" ]
|
|
}
|
|
} else {
|
|
# For x86-32, the lib/ directory is called lib32/ instead.
|
|
if (current_cpu == "x86") {
|
|
nmfflags +=
|
|
[ "--library-path=" +
|
|
rebase_path("${nacl_toolchain_tooldir}/lib32", root_build_dir) ]
|
|
data += [ "${lib_path}/lib32/" ]
|
|
}
|
|
|
|
# x86-32 Windows needs to build both x86-32 and x86-64 NaCl
|
|
# binaries into the same nmf covering both architectures. That
|
|
# gets handled at a higher level (see the nacl_test_data template),
|
|
# so a single generate_nmf invocation gets both x86-32 and x86-64
|
|
# nexes listed in executables.
|
|
if (current_cpu == "x64" || target_os == "win") {
|
|
# For x86-64, the lib/ directory is called lib64/ instead
|
|
# when copied by create_nmf.py.
|
|
glibc_tc = "//build/toolchain/nacl:glibc"
|
|
assert(current_toolchain == "${glibc_tc}_${current_cpu}")
|
|
if (current_cpu == "x64") {
|
|
x64_out_dir = root_out_dir
|
|
} else {
|
|
x64_out_dir = get_label_info(":${target_name}(${glibc_tc}_x64)",
|
|
"root_out_dir")
|
|
}
|
|
nmfflags += [
|
|
"--library-path=" + rebase_path(x64_out_dir, root_build_dir),
|
|
"--library-path=" +
|
|
rebase_path("${nacl_toolchain_tooldir}/lib", root_build_dir),
|
|
]
|
|
data += [ "${lib_path}/lib64/" ]
|
|
}
|
|
}
|
|
}
|
|
args = [
|
|
"--no-default-libpath",
|
|
"--objdump=" + rebase_path(objdump, root_build_dir),
|
|
"--output=" + rebase_path(nmf, root_build_dir),
|
|
] + nmfflags + rebase_path(sources, root_build_dir)
|
|
if (is_nacl_glibc && current_cpu == "arm") {
|
|
deps += [ "//native_client/src/untrusted/elf_loader:elf_loader" ]
|
|
}
|
|
}
|
|
}
|
|
|
|
# Generate a nmf file for Non-SFI tests
|
|
#
|
|
# Non-SFI tests use a different manifest format from regular Native Client and
|
|
# as such requires a different generator.
|
|
#
|
|
# Variables:
|
|
# executable: Non-SFI .nexe executable to generate nmf for
|
|
# nmf: the name and the path of the output file
|
|
# nmfflags: additional flags for the nmf generator
|
|
template("generate_nonsfi_test_nmf") {
|
|
assert(defined(invoker.executable), "Must define executable")
|
|
assert(defined(invoker.nmf), "Must define nmf")
|
|
|
|
action(target_name) {
|
|
forward_variables_from(invoker,
|
|
[
|
|
"deps",
|
|
"data_deps",
|
|
"executable",
|
|
"nmf",
|
|
"testonly",
|
|
"public_deps",
|
|
"visibility",
|
|
])
|
|
|
|
script = "//ppapi/tests/create_nonsfi_test_nmf.py"
|
|
sources = [
|
|
executable,
|
|
]
|
|
outputs = [
|
|
nmf,
|
|
]
|
|
|
|
# NOTE: We use target_cpu rather than current_cpu on purpose because
|
|
# current_cpu is always going to be pnacl for Non-SFI, but the Non-SFI
|
|
# .nexe executable is always translated to run on the target machine.
|
|
if (target_cpu == "x86") {
|
|
arch = "x86-32"
|
|
} else if (target_cpu == "x64") {
|
|
arch = "x86-64"
|
|
} else {
|
|
arch = target_cpu
|
|
}
|
|
args = [
|
|
"--program=" + rebase_path(executable, root_build_dir),
|
|
"--arch=${arch}",
|
|
"--output=" + rebase_path(nmf, root_build_dir),
|
|
]
|
|
if (defined(invoker.nmfflags)) {
|
|
args += invoker.nmfflags
|
|
}
|
|
}
|
|
}
|