1 # Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
5 # There's a couple key GYP variables that control how FFmpeg is built:
7 # Controls whether we build the Chromium or Google Chrome version of
8 # FFmpeg. The Google Chrome version contains additional codecs.
9 # Typical values are Chromium, Chrome, ChromiumOS, and ChromeOS.
11 # When set to zero will build Chromium against Chrome's FFmpeg headers, but
12 # not build ffmpegsumo itself. Users are expected to build and provide
13 # their own version of ffmpegsumo. Default value is 1.
19 # Since we are not often debugging FFmpeg, and performance is
20 # unacceptable without optimization, freeze the optimizations to -O2.
21 # If someone really wants -O1 , they can change these in their checkout.
22 # If you want -O0, see the Gotchas in README.Chromium for why that
24 'release_optimize': '2',
25 'debug_optimize': '2',
26 'mac_debug_optimization': '2',
27 # In addition to the above reasons, /Od optimization won't remove symbols
28 # that are under "if (0)" style sections. Which lead to link time errors
29 # when for example it tries to link an ARM symbol on X86.
30 'win_debug_Optimization': '2',
31 # Run time checks are incompatible with any level of optimizations.
32 'win_debug_RuntimeChecks': '0',
35 # Setting the optimizations to 'speed' or to 'max' results in a lot of
36 # unresolved symbols. The only supported mode is 'size' (see
44 # Make sure asm_sources is always defined even if an arch doesn't have any
45 # asm sources (e.g. mips or x86 with forcefully disabled asm).
49 # Allow overriding the selection of which FFmpeg binaries to copy via an
50 # environment variable. Affects the ffmpeg_binaries target.
52 ['target_arch == "arm" and arm_version == 7 and arm_neon == 1', {
53 # Need a separate config for arm+neon vs arm
54 'ffmpeg_config%': 'arm-neon',
56 'ffmpeg_config%': '<(target_arch)',
58 ['OS == "mac" or OS == "win" or OS == "openbsd"', {
59 'os_config%': '<(OS)',
60 }, { # all other Unix OS's use the linux config
63 # MemorySanitizer doesn't like assembly code.
64 'os_config%': 'linux-noasm',
66 'os_config%': 'linux',
71 'ffmpeg_branding%': '<(branding)OS',
72 }, { # otherwise, assume Chrome/Chromium.
73 'ffmpeg_branding%': '<(branding)',
77 'build_ffmpegsumo%': 1,
79 # Locations for generated artifacts.
80 'shared_generated_dir': '<(SHARED_INTERMEDIATE_DIR)/third_party/ffmpeg',
82 # Stub generator script and signatures of all functions used by Chrome.
83 'generate_stubs_script': '../../tools/generate_stubs/generate_stubs.py',
84 'sig_files': ['chromium/ffmpegsumo.sigs'],
85 'extra_header': 'chromium/ffmpeg_stub_headers.fragment',
88 ['target_arch != "arm" and os_config != "linux-noasm"', {
91 'target_name': 'ffmpeg_yasm',
92 'type': 'static_library',
94 'ffmpeg_generated.gypi',
95 '../yasm/yasm_compile.gypi',
99 # XCode doesn't want to link a pure assembly target and will fail
100 # to link when it creates an empty file list. So add a dummy file
101 # keep the linker happy. See http://crbug.com/157073
105 # Path to platform configuration files.
106 'platform_config_root': 'chromium/config/<(ffmpeg_branding)/<(os_config)/<(ffmpeg_config)',
109 ['target_arch == "ia32"', {
120 # Necessary to ensure symbols end up with a _ prefix; added by
121 # yasm_compile.gypi for Windows, but not Mac.
128 '>@(more_yasm_flags)',
129 '-I', '<(platform_config_root)',
130 '-I', 'libavcodec/x86/',
131 '-I', 'libavutil/x86/',
133 # Disable warnings, prevents log spam for things we won't fix.
137 'yasm_output_path': '<(shared_generated_dir)/yasm'
142 ['build_ffmpegsumo != 0', {
144 'ffmpeg_generated.gypi',
147 # Path to platform configuration files.
148 'platform_config_root': 'chromium/config/<(ffmpeg_branding)/<(os_config)/<(ffmpeg_config)',
152 'target_name': 'ffmpegsumo',
153 'type': 'loadable_module',
156 '<(platform_config_root)/config.h',
157 '<(platform_config_root)/libavutil/avconfig.h',
160 '<(platform_config_root)',
165 '_POSIX_C_SOURCE=200112',
168 # Disable deprecated features which generate spammy warnings.
169 'FF_API_PIX_FMT_DESC=0',
170 'FF_API_OLD_DECODE_AUDIO=0',
171 'FF_API_DESTRUCT_PACKET=0',
172 'FF_API_GET_BUFFER=0',
175 'clang_warning_flags': [
176 '-Wno-absolute-value',
177 # ffmpeg uses its own deprecated functions.
178 '-Wno-deprecated-declarations',
179 # ffmpeg doesn't care about pointer constness.
180 '-Wno-incompatible-pointer-types',
181 # ffmpeg doesn't follow usual parentheses conventions.
183 # ffmpeg doesn't care about pointer signedness.
185 # ffmpeg doesn't believe in exhaustive switch statements.
191 '-fomit-frame-pointer',
192 # ffmpeg uses its own deprecated functions.
193 '-Wno-deprecated-declarations',
196 ['target_arch != "arm" and target_arch != "mipsel" and os_config != "linux-noasm"', {
203 # gcc doesn't have flags for specific warnings, so disable them
208 ['target_arch == "ia32"', {
209 # Turn off valgrind build option that breaks ffmpeg builds.
211 '-fno-omit-frame-pointer',
213 'debug_extra_cflags!': [
214 '-fno-omit-frame-pointer',
216 'release_extra_cflags!': [
217 '-fno-omit-frame-pointer',
219 }], # target_arch == "ia32"
220 ['target_arch == "arm"', {
221 # TODO(ihf): See the long comment in build_ffmpeg.sh
222 # We want to be consistent with CrOS and have configured
223 # ffmpeg for thumb. Protect yourself from -marm.
232 # On arm we use gcc to compile the assembly.
246 ['arm_float_abi == "hard"', {
257 ['target_arch == "mipsel"', {
262 }], # target_arch == "mipsel"
263 ['os_posix == 1 and OS != "mac"', {
267 # BUG(ihf): ffmpeg compiles with this define. But according to
268 # ajwong: I wouldn't change _FILE_OFFSET_BITS. That's a scary change
269 # cause it affects the default length of off_t, and fpos_t,
270 # which can cause strange problems if the loading code doesn't
271 # have it set and you start passing FILE*s or file descriptors
272 # between symbol contexts.
273 # '_FILE_OFFSET_BITS=64',
280 '-fno-tree-vectorize',
283 # Ensure the symbols are exported.
285 # TODO(ajwong): Manually tag the API that we use to be
287 '-fvisibility=hidden',
292 '-L<(shared_generated_dir)',
298 }], # os_posix == 1 and OS != "mac"
299 ['OS == "openbsd"', {
300 # OpenBSD's gcc (4.2.1) does not support this flag
310 ['mac_breakpad == 1', {
312 # A real .dSYM is needed for dump_syms to operate on.
316 ['target_arch != "x64"', {
317 # -read_only_relocs cannot be used with x86_64
320 # This is needed because even though FFmpeg now builds
321 # with -fPIC, it's not quite a complete PIC build, only
322 # partial :( Thus we need to instruct the linker to allow
323 # relocations for read-only segments for this target to be
324 # able to generated the shared library on Mac.
326 # This makes Mark sad, but he's okay with it since it is
327 # isolated to this module. When Mark finds this in the
328 # future, and has forgotten this conversation, this
329 # comment should remind him that the world is still nice
330 # and butterflies still exist...as do rainbows, sunshine,
331 # tulips, etc., etc...but not kittens. Those went away
333 '-Wl,-read_only_relocs,suppress',
340 '$(SDKROOT)/usr/lib/libz.dylib',
344 'GCC_SYMBOLS_PRIVATE_EXTERN': 'NO', # No -fvisibility=hidden
345 'DYLIB_INSTALL_NAME_BASE': '@loader_path',
346 'LIBRARY_SEARCH_PATHS': [
347 '<(shared_generated_dir)'
353 '<(shared_generated_dir)/ffmpegsumo.def',
356 'chromium/include/win',
358 # TODO(dalecurtis): We should fix these. http://crbug.com/154421
359 'msvs_disabled_warnings': [
360 4996, 4018, 4090, 4305, 4133, 4146, 4554, 4028, 4334, 4101, 4102,
361 4116, 4307, 4273, 4005, 4056, 4756,
364 ['clang == 1 or (OS == "win" and (MSVS_VERSION == "2013" or MSVS_VERSION == "2013e"))', {
371 'strtod=avpriv_strtod',
372 'snprintf=avpriv_snprintf',
373 '_snprintf=avpriv_snprintf',
374 'vsnprintf=avpriv_vsnprintf',
377 ['target_arch == "x64"', {
378 # TODO(wolenetz): We should fix this. http://crbug.com/171009
379 'msvs_disabled_warnings' : [
385 # Ignore warnings about a local symbol being inefficiently imported,
386 # upstream is working on a fix.
388 'AdditionalOptions': ['/ignore:4049', '/ignore:4217'],
393 'action_name': 'generate_def',
395 '<(generate_stubs_script)',
399 '<(shared_generated_dir)/ffmpegsumo.def',
402 '<(generate_stubs_script)',
403 '-i', '<(INTERMEDIATE_DIR)',
404 '-o', '<(shared_generated_dir)',
406 '-m', 'ffmpegsumo.dll',
409 'message': 'Generating FFmpeg export definitions',
420 'target_name': 'ffmpeg',
422 # Files needed for stub generation rules.
426 '__STDC_CONSTANT_MACROS', # FFmpeg uses INT64_C.
428 'hard_dependency': 1,
430 # Do not fear the massive conditional blocks! They do the following:
431 # 1) Use the Window stub generator on Windows
432 # 2) Else, use the POSIX stub generator on non-Windows
435 'msvs_guid': 'D7A94F58-576A-45D9-A45F-EB87C63ABBB0',
438 ['target_arch == "x64"', {
439 'outfile_type': 'windows_lib_x64',
440 }, { # else, generate x86 stub library
441 'outfile_type': 'windows_lib',
444 'output_dir': '<(PRODUCT_DIR)/lib',
445 'intermediate_dir': '<(INTERMEDIATE_DIR)',
449 # Adds C99 types for Visual C++.
450 'chromium/include/win/inttypes.h',
455 'direct_dependent_settings': {
457 '<(platform_config_root)',
458 'chromium/include/win',
463 '<(output_dir)/ffmpegsumo.lib',
476 'rule_name': 'generate_libs',
479 '<(generate_stubs_script)',
483 '<(output_dir)/<(RULE_INPUT_ROOT).lib',
485 'action': ['python', '<(generate_stubs_script)',
486 '-i', '<(intermediate_dir)',
487 '-o', '<(output_dir)',
488 '-t', '<(outfile_type)',
489 '<@(RULE_INPUT_PATH)',
491 'message': 'Generating FFmpeg import libraries',
494 }, { # else OS != "win", use POSIX stub generator
496 'outfile_type': 'posix_stubs',
497 'stubs_filename_root': 'ffmpeg_stubs',
498 'project_path': 'third_party/ffmpeg',
499 'intermediate_dir': '<(INTERMEDIATE_DIR)',
500 'output_root': '<(SHARED_INTERMEDIATE_DIR)/ffmpeg',
501 'platform_config_root': 'chromium/config/<(ffmpeg_branding)/<(os_config)/<(ffmpeg_config)'
506 'type': '<(component)',
509 '../..', # The chromium 'src' directory.
510 '<(platform_config_root)',
514 # Required for the logging done in the stubs generator.
515 '../../base/base.gyp:base',
517 'direct_dependent_settings': {
519 '__STDC_CONSTANT_MACROS', # FFmpeg uses INT64_C.
523 '../..', # The chromium 'src' directory.
524 '<(platform_config_root)',
530 'action_name': 'generate_stubs',
532 '<(generate_stubs_script)',
537 '<(intermediate_dir)/<(stubs_filename_root).cc',
538 '<(output_root)/<(project_path)/<(stubs_filename_root).h',
541 '<(generate_stubs_script)',
542 '-i', '<(intermediate_dir)',
543 '-o', '<(output_root)/<(project_path)',
544 '-t', '<(outfile_type)',
545 '-e', '<(extra_header)',
546 '-s', '<(stubs_filename_root)',
547 '-p', '<(project_path)',
550 'process_outputs_as_sources': 1,
551 'message': 'Generating FFmpeg stubs for dynamic loading',
555 # Linux/Solaris need libdl for dlopen() and friends.
556 ['OS == "linux" or OS == "solaris"', {
563 ['component == "shared_library"', {
564 'cflags!': ['-fvisibility=hidden'],
566 'GCC_SYMBOLS_PRIVATE_EXTERN': 'NO', # no -fvisibility=hidden
569 ['build_ffmpegsumo != 0', {