thorium-mirror/arm/third_party/libaom/BUILD.gn
Alexander Frick de53b3932b fix mac
2024-10-27 15:08:16 -05:00

413 lines
13 KiB
Text

# Copyright 2024 The Chromium Authors and Alex313031
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
import("//build/buildflag_header.gni")
import("//build/config/android/config.gni")
import("//build/config/arm.gni")
import("//testing/libfuzzer/fuzzer_test.gni")
import("//testing/test.gni")
import("//third_party/libaom/libaom_srcs.gni")
import("//third_party/libaom/libaom_test_srcs.gni")
import("//third_party/libaom/options.gni")
import("//third_party/nasm/nasm_assemble.gni")
buildflag_header("libaom_buildflags") {
header = "libaom_buildflags.h"
flags = [ "ENABLE_LIBAOM=$enable_libaom" ]
}
# Sets the architecture name for building libaom.
if (current_cpu == "x86") {
cpu_arch_full = "ia32"
} else if (current_cpu == "x64") {
if (is_msan) {
# TODO(johannkoenig): Check if MSAN builds pass. libaom is favoring
# intrinsics over assembly.
cpu_arch_full = "generic"
} else {
cpu_arch_full = "x64"
}
} else if (current_cpu == "arm") {
if (arm_use_neon) {
cpu_arch_full = "arm-neon"
} else if (is_android) {
cpu_arch_full = "arm-neon-cpu-detect"
} else {
cpu_arch_full = "arm"
}
} else if (current_cpu == "arm64") {
cpu_arch_full = "arm64-cpu-detect"
} else if (current_cpu == "riscv64") {
cpu_arch_full = "generic"
} else if (current_cpu == "loong64") {
cpu_arch_full = "generic"
} else {
cpu_arch_full = current_cpu
}
if (is_nacl) {
platform_include_dir = "source/config/linux/generic"
} else {
if (is_posix || is_fuchsia) {
# Should cover linux, fuchsia, mac, and ios.
os_category = "linux"
} else { # This should only match windows.
os_category = current_os
}
platform_include_dir = "source/config/$os_category/$cpu_arch_full"
}
libaom_include_dirs = [
"source/config",
"source/libaom",
platform_include_dir,
]
# Private configuration used in building libaom.
config("libaom_config") {
include_dirs = libaom_include_dirs
}
# This config is applied to targets that depend on libaom.
config("libaom_public_config") {
include_dirs = [
# libaom_public_config does not have "source/config" (which gives access to
# the private header config/aom_version.h) because code outside the libaom
# library should use the aom_codec_version*() functions and macros declared
# in the public header aom_codec.h.
"source/libaom",
platform_include_dir,
]
}
if (current_cpu == "x86" || (current_cpu == "x64" && !is_msan)) {
nasm_assemble("libaom_nasm") {
sources = aom_dsp_common_asm_sse2
sources += aom_dsp_common_asm_ssse3
sources += aom_ports_asm_x86
sources += aom_av1_encoder_asm_sse2
sources += aom_dsp_encoder_asm_sse2
sources += aom_dsp_encoder_asm_ssse3
if (current_cpu == "x64") {
sources += aom_av1_encoder_asm_ssse3_x86_64
sources += aom_dsp_encoder_asm_sse2_x86_64
sources += aom_dsp_encoder_asm_ssse3_x86_64
}
defines = [ "CHROMIUM" ]
include_dirs = libaom_include_dirs
}
# The following targets are deliberately source_set rather than
# static_library. The :libaom target exposes these intrinsic implementations
# via global function pointer symbols, which hides the object dependency at
# link time. On Mac, this results in undefined references to the intrinsic
# symbols.
# TODO(aomedia:3511): Re-enable this build flag
# //build/config/compiler:default_init_stack_vars is removed from all libaom
# targets. It introduces -ftrivial-auto-var-init=pattern compiler flag and
# causes a huge performance issue (over 13% slowdown for AV1 real-time
# encoder) with initializing local variables on the stack.
source_set("libaom_intrinsics_sse2") {
# TODO(jianj): Align this with libvpx as this is not used there.
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (!is_win || is_clang) {
cflags = [ "-msse2" ]
}
sources = aom_av1_common_intrin_sse2
sources += aom_dsp_common_intrin_sse2
sources += aom_av1_encoder_intrin_sse2
sources += aom_dsp_encoder_intrin_sse2
}
source_set("libaom_intrinsics_sse3") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (!is_win || is_clang) {
cflags = [ "-msse3" ]
}
sources = aom_av1_encoder_intrin_sse3
}
source_set("libaom_intrinsics_ssse3") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (!is_win || is_clang) {
cflags = [ "-mssse3" ]
}
sources = aom_av1_common_intrin_ssse3
sources += aom_av1_encoder_intrin_ssse3
sources += aom_dsp_common_intrin_ssse3
sources += aom_dsp_encoder_intrin_ssse3
if (current_cpu == "x86") {
sources += aom_av1_common_intrin_ssse3_x86
}
}
source_set("libaom_intrinsics_sse4_1") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (!is_win || is_clang) {
cflags = [ "-msse4.1" ]
}
sources = aom_av1_common_intrin_sse4_1
sources += aom_dsp_common_intrin_sse4_1
sources += aom_av1_encoder_intrin_sse4_1
sources += aom_dsp_encoder_intrin_sse4_1
}
source_set("libaom_intrinsics_sse4_2") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (!is_win || is_clang) {
cflags = [ "-msse4.2" ]
}
sources = aom_av1_encoder_intrin_sse4_2
}
source_set("libaom_intrinsics_avx") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (is_win) {
cflags = [ "/arch:AVX" ]
} else {
cflags = [ "-mavx" ]
}
sources = aom_dsp_encoder_intrin_avx
}
source_set("libaom_intrinsics_avx2") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
if (is_win) {
cflags = [ "/arch:AVX2" ]
} else {
cflags = [ "-mavx2" ]
}
sources = aom_av1_common_intrin_avx2
sources += aom_dsp_common_intrin_avx2
sources += aom_av1_encoder_intrin_avx2
sources += aom_dsp_encoder_intrin_avx2
}
}
if (current_cpu == "arm64" || cpu_arch_full == "arm-neon" ||
cpu_arch_full == "arm-neon-cpu-detect") {
source_set("libaom_intrinsics_neon") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
if (current_cpu == "arm") {
configs -= [ "//build/config/compiler:compiler_arm_fpu" ]
cflags = [ "-mfpu=neon" ]
}
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
sources = aom_av1_common_intrin_neon
sources += aom_dsp_common_intrin_neon
sources += aom_av1_encoder_intrin_neon
sources += aom_dsp_encoder_intrin_neon
}
}
if (current_cpu == "arm64") {
source_set("libaom_intrinsics_arm_crc32") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs += [ "//build/config/compiler:march_crc" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
sources = aom_av1_encoder_intrin_arm_crc32
}
source_set("libaom_intrinsics_neon_dotprod") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs += [ "//build/config/compiler:march_dotprod" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
sources = aom_av1_common_intrin_neon_dotprod
sources += aom_dsp_common_intrin_neon_dotprod
sources += aom_dsp_encoder_intrin_neon_dotprod
}
source_set("libaom_intrinsics_neon_i8mm") {
check_includes = false
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs += [ "//build/config/compiler:march_i8mm" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
sources = aom_av1_common_intrin_neon_i8mm
sources += aom_dsp_common_intrin_neon_i8mm
}
}
static_library("libaom") {
check_includes = false
if (!is_debug && is_win) {
configs -= [ "//build/config/compiler:default_optimization" ]
configs += [ "//build/config/compiler:optimize_max" ]
}
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
configs -= [ "//build/config/compiler:default_init_stack_vars" ]
sources = aom_av1_common_sources
sources += aom_dsp_common_sources
sources += aom_mem_sources
sources += aom_rtcd_sources
sources += aom_scale_sources
sources += aom_sources
sources += aom_util_sources
sources += aom_av1_encoder_sources
sources += aom_dsp_encoder_sources
if (use_fuzzing_engine) {
# Note this is inherited from OSS-Fuzz where the fuzzers were being run
# with a 2 GB total allocation limit.
if (is_msan) {
defines = [ "AOM_MAX_ALLOCABLE_MEMORY=536870912" ]
} else {
defines = [ "AOM_MAX_ALLOCABLE_MEMORY=1073741824" ]
}
# Also enable DO_RANGE_CHECK_CLAMP to suppress the noise of integer
# overflows in the transform functions.
defines += [ "DO_RANGE_CHECK_CLAMP=1" ]
}
deps = []
if (current_cpu == "x86" || (current_cpu == "x64" && !is_msan)) {
deps += [
":libaom_intrinsics_avx",
":libaom_intrinsics_avx2",
":libaom_intrinsics_sse2",
":libaom_intrinsics_sse3",
":libaom_intrinsics_sse4_1",
":libaom_intrinsics_sse4_2",
":libaom_intrinsics_ssse3",
":libaom_nasm",
]
}
if (current_cpu == "arm64" || cpu_arch_full == "arm-neon" ||
cpu_arch_full == "arm-neon-cpu-detect") {
deps += [ ":libaom_intrinsics_neon" ]
}
if (current_cpu == "arm64") {
# This is needed by all arm boards due to aom_arm_cpu_caps()
sources += [ "source/libaom/aom_ports/aarch64_cpudetect.c" ]
deps += [
":libaom_intrinsics_arm_crc32",
":libaom_intrinsics_neon_dotprod",
":libaom_intrinsics_neon_i8mm",
]
}
if (current_cpu == "arm") {
# This is needed by all arm boards due to aom_arm_cpu_caps()
sources += [ "source/libaom/aom_ports/aarch32_cpudetect.c" ]
}
if (is_android) {
deps += [ "//third_party/cpu_features:ndk_compat" ]
}
public_configs = [ ":libaom_public_config" ]
public_deps = [ ":libaom_buildflags" ]
}
static_library("libaomrc") {
if (!is_debug && is_win) {
configs -= [ "//build/config/compiler:default_optimization" ]
configs += [ "//build/config/compiler:optimize_max" ]
}
sources = [
"//third_party/libaom/source/libaom/av1/ratectrl_rtc.cc",
"//third_party/libaom/source/libaom/av1/ratectrl_rtc.h",
]
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [ "//build/config/compiler:no_chromium_code" ]
configs += [ ":libaom_config" ]
public_configs = [ ":libaom_public_config" ]
public_deps = [ ":libaom" ]
}
test("av1_encoder_fuzz_test") {
sources = [ "fuzz/av1_encoder_fuzz_test.cc" ]
fuzztests = [
"AV1EncodeFuzzTest.AV1EncodeSucceeds",
"AV1EncodeFuzzTest.AV1EncodeArbitraryCallSequenceSucceeds",
]
deps = [
":libaom",
"//third_party/fuzztest:fuzztest_gtest_main",
]
}
config("test_libaom_config") {
include_dirs = [ "//third_party/libaom/source/libaom/third_party/libwebm" ]
}
test("test_libaom") {
sources = aom_libwebm_sources
sources += aom_webm_encoder_sources
sources += aom_common_app_util_sources
sources += aom_encoder_app_util_sources
sources += aom_unit_test_common_sources
sources += aom_unit_test_encoder_sources
sources += aom_unit_test_wrapper_sources
sources += [ "source/gen_src/usage_exit.c" ]
deps = [
":libaom",
"//testing/gtest",
]
defines = [ "CHROMIUM" ]
if (is_android) {
use_raw_android_executable = true
defines += [ "LIBAOM_TEST_DATA_PATH=/data/local/tmp/chromium_tests_root/third_party/libaom/testdata" ]
data = [ "testdata/" ]
} else {
defines += [ string_join("",
[
"LIBAOM_TEST_DATA_PATH=",
rebase_path("testdata", root_build_dir),
]) ]
}
configs -= [ "//build/config/compiler:chromium_code" ]
configs += [
"//build/config/compiler:no_chromium_code",
":libaom_config",
":test_libaom_config",
]
}