# Copyright (c) 2012 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. { 'variables': { 'conditions': [ ['os_posix==1', { 'asm_obj_extension': 'o', }], ['OS=="win"', { 'asm_obj_extension': 'obj', }], ['target_arch=="arm" and arm_neon==1', { 'target_arch_full': 'arm-neon', }, { 'target_arch_full': '<(target_arch)', }], # Conversion to libvpx arch names. ['target_arch=="arm" and arm_neon==1', { 'libvpx_arch': 'armv7', }], ['target_arch=="arm" and arm_neon==0', { 'libvpx_arch': 'armv6', }], ['target_arch=="ia32"', { 'libvpx_arch': 'x86', }], ['target_arch=="x64"', { 'libvpx_arch': 'x86_64', }], ['os_posix == 1 and OS != "mac"', { 'OS_CATEGORY%': 'linux', }, { 'OS_CATEGORY%': '<(OS)', }], ], # Location of the intermediate output. 'shared_generated_dir': '<(SHARED_INTERMEDIATE_DIR)/third_party/libvpx', }, 'conditions': [ # TODO(andrew): Hack to ensure we pass -msse2 to gcc on Linux for files # containing SSE intrinsics. This should be handled in the gyp generator # scripts somehow. Clang (default on Mac) doesn't require this. ['target_arch=="ia32" or target_arch=="x64"', { 'targets' : [ { 'target_name': 'libvpx_sse2', 'type': 'static_library', 'include_dirs': [ 'source/config/<(OS)/<(target_arch)', 'source/libvpx', 'source/libvpx/vp8/common', 'source/libvpx/vp8/decoder', 'source/libvpx/vp8/encoder', ], 'sources': [ 'source/libvpx/vp8/encoder/x86/denoising_sse2.c', ], 'conditions': [ ['os_posix==1 and OS!="mac"', { 'cflags': [ '-msse2', ], }], ['OS=="mac"', { 'xcode_settings': { 'OTHER_CFLAGS': [ '-msse2', ], }, }], ], }, ], }], [ 'target_arch!="arm"', { 'targets': [ { # This libvpx target contains both encoder and decoder. # Encoder is configured to be realtime only. 'target_name': 'libvpx', 'type': 'static_library', 'variables': { 'yasm_output_path': '<(SHARED_INTERMEDIATE_DIR)/third_party/libvpx', 'OS_CATEGORY%': '<(OS_CATEGORY)', 'yasm_flags': [ '-D', 'CHROMIUM', '-I', 'source/config/<(OS_CATEGORY)/<(target_arch)', '-I', 'source/libvpx', '-I', '<(shared_generated_dir)', # Generated assembly offsets ], }, 'dependencies': [ 'gen_asm_offsets', ], 'includes': [ '../yasm/yasm_compile.gypi' ], 'include_dirs': [ 'source/config/<(OS_CATEGORY)/<(target_arch)', 'source/libvpx', 'source/libvpx/vp8/common', 'source/libvpx/vp8/decoder', 'source/libvpx/vp8/encoder', '<(shared_generated_dir)', # Provides vpx_rtcd.h. ], 'direct_dependent_settings': { 'include_dirs': [ 'source/libvpx', ], }, # VS2010 does not correctly incrementally link obj files generated # from asm files. This flag disables UseLibraryDependencyInputs to # avoid this problem. 'msvs_2010_disable_uldi_when_referenced': 1, 'conditions': [ [ 'target_arch=="ia32"', { 'includes': [ 'libvpx_srcs_x86.gypi', ], 'dependencies': [ 'libvpx_sse2', ], }], [ 'target_arch=="x64"', { 'includes': [ 'libvpx_srcs_x86_64.gypi', ], 'dependencies': [ 'libvpx_sse2', ], }], ['clang == 1', { 'xcode_settings': { 'WARNING_CFLAGS': [ # libvpx heavily relies on implicit enum casting. '-Wno-conversion', # libvpx does `if ((a == b))` in some places. '-Wno-parentheses-equality', ], }, 'cflags': [ '-Wno-conversion', '-Wno-parentheses-equality', ], }], [ 'chromeos == 1', { # ChromeOS needs these files for animated WebM avatars. 'sources': [ 'source/libvpx/libmkv/EbmlIDs.h', 'source/libvpx/libmkv/EbmlWriter.c', 'source/libvpx/libmkv/EbmlWriter.h', ], }], ], }, ], }, ], # 'libvpx' target for ARM builds. [ 'target_arch=="arm" ', { 'targets': [ { # This libvpx target contains both encoder and decoder. # Encoder is configured to be realtime only. 'target_name': 'libvpx', 'type': 'static_library', 'dependencies': [ 'gen_asm_offsets', ], # Copy the script to the output folder so that we can use it with # absolute path. 'copies': [{ 'destination': '<(shared_generated_dir)', 'files': [ '<(ads2gas_script_path)', ], }], # Rule to convert .asm files to .S files. 'rules': [ { 'rule_name': 'convert_asm', 'extension': 'asm', 'inputs': [ '<(shared_generated_dir)/<(ads2gas_script)', ], 'outputs': [ '<(shared_generated_dir)/<(RULE_INPUT_ROOT).S', ], 'action': [ 'bash', '-c', 'cat <(RULE_INPUT_PATH) | perl <(shared_generated_dir)/<(ads2gas_script) > <(shared_generated_dir)/<(RULE_INPUT_ROOT).S', ], 'process_outputs_as_sources': 1, 'message': 'Convert libvpx asm file for ARM <(RULE_INPUT_PATH).', }, ], 'variables': { # Location of the assembly conversion script. 'ads2gas_script': 'ads2gas.pl', 'ads2gas_script_path': 'source/libvpx/build/make/<(ads2gas_script)', }, 'cflags': [ # We need to explicitly tell the GCC assembler to look for # .include directive files from the place where they're # generated to. '-Wa,-I, <(shared_generated_dir)/<(RULE_INPUT_ROOT).c', ], 'process_outputs_as_sources': 1, 'message': 'Generate libvpx example code <(RULE_INPUT_PATH).', }, ], 'sources': [ 'source/libvpx/examples/simple_encoder.txt', ] }, { 'target_name': 'simple_decoder', 'type': 'executable', 'dependencies': [ 'libvpx', ], # Copy the script to the output folder so that we can use it with # absolute path. 'copies': [{ 'destination': '<(shared_generated_dir)/simple_decoder', 'files': [ 'source/libvpx/examples/gen_example_code.sh', ], }], # Rule to convert .txt files to .c files. 'rules': [ { 'rule_name': 'generate_example', 'extension': 'txt', 'inputs': [ '<(shared_generated_dir)/simple_decoder/gen_example_code.sh', ], 'outputs': [ '<(shared_generated_dir)/<(RULE_INPUT_ROOT).c', ], 'action': [ 'bash', '-c', '<(shared_generated_dir)/simple_decoder/gen_example_code.sh <(RULE_INPUT_PATH) > <(shared_generated_dir)/<(RULE_INPUT_ROOT).c', ], 'process_outputs_as_sources': 1, 'message': 'Generate libvpx example code <(RULE_INPUT_PATH).', }, ], 'sources': [ 'source/libvpx/examples/simple_decoder.txt', ] }, ], } # Local Variables: # tab-width:2 # indent-tabs-mode:nil # End: # vim: set expandtab tabstop=2 shiftwidth=2: