Home | History | Annotate | Download | only in docs
      1 # Deprecated Builds
      2 
      3 Older documentation on build configs which are no longer supported.
      4 
      5 ## Pre-requisites
      6 
      7 You'll need to have depot tools installed: https://www.chromium.org/developers/how-tos/install-depot-tools
      8 Refer to chromium instructions for each platform for other prerequisites.
      9 
     10 ## Getting the Code
     11 
     12 Create a working directory, enter it, and run:
     13 
     14     gclient config https://chromium.googlesource.com/libyuv/libyuv
     15     gclient sync
     16 
     17 
     18 Then you'll get a .gclient file like:
     19 
     20     solutions = [
     21       { "name"        : "libyuv",
     22         "url"         : "https://chromium.googlesource.com/libyuv/libyuv",
     23         "deps_file"   : "DEPS",
     24         "managed"     : True,
     25         "custom_deps" : {
     26         },
     27         "safesync_url": "",
     28       },
     29     ];
     30 
     31 
     32 For iOS add `;target_os=['ios'];` to your OSX .gclient and run `GYP_DEFINES="OS=ios" gclient sync.`
     33 
     34 Browse the Git reprository: https://chromium.googlesource.com/libyuv/libyuv/+/master
     35 
     36 ### Android
     37 For Android add `;target_os=['android'];` to your Linux .gclient
     38 
     39 
     40     solutions = [
     41       { "name"        : "libyuv",
     42         "url"         : "https://chromium.googlesource.com/libyuv/libyuv",
     43         "deps_file"   : "DEPS",
     44         "managed"     : True,
     45         "custom_deps" : {
     46         },
     47         "safesync_url": "",
     48       },
     49     ];
     50     target_os = ["android", "unix"];
     51 
     52 Then run:
     53 
     54     export GYP_DEFINES="OS=android"
     55     gclient sync
     56 
     57 Caveat: Theres an error with Google Play services updates.  If you get the error "Your version of the Google Play services library is not up to date", run the following:
     58 
     59     cd chromium/src
     60     ./build/android/play_services/update.py download
     61     cd ../..
     62 
     63 For Windows the gclient sync must be done from an Administrator command prompt.
     64 
     65 The sync will generate native build files for your environment using gyp (Windows: Visual Studio, OSX: XCode, Linux: make). This generation can also be forced manually: `gclient runhooks`
     66 
     67 To get just the source (not buildable):
     68 
     69     git clone https://chromium.googlesource.com/libyuv/libyuv
     70 
     71 
     72 ## Building the Library and Unittests
     73 
     74 ### Windows
     75 
     76     set GYP_DEFINES=target_arch=ia32
     77     call python gyp_libyuv -fninja -G msvs_version=2013
     78     ninja -j7 -C out\Release
     79     ninja -j7 -C out\Debug
     80 
     81     set GYP_DEFINES=target_arch=x64
     82     call python gyp_libyuv -fninja -G msvs_version=2013
     83     ninja -C out\Debug_x64
     84     ninja -C out\Release_x64
     85 
     86 #### Building with clangcl
     87     set GYP_DEFINES=clang=1 target_arch=ia32
     88     call python tools\clang\scripts\update.py
     89     call python gyp_libyuv -fninja libyuv_test.gyp
     90     ninja -C out\Debug
     91     ninja -C out\Release
     92 
     93 ### OSX
     94 
     95 Clang 64 bit shown. Remove `clang=1` for GCC and change x64 to ia32 for 32 bit.
     96 
     97     GYP_DEFINES="clang=1 target_arch=x64" ./gyp_libyuv
     98     ninja -j7 -C out/Debug
     99     ninja -j7 -C out/Release
    100 
    101     GYP_DEFINES="clang=1 target_arch=ia32" ./gyp_libyuv
    102     ninja -j7 -C out/Debug
    103     ninja -j7 -C out/Release
    104 
    105 ### iOS
    106 http://www.chromium.org/developers/how-tos/build-instructions-ios
    107 
    108 Add to .gclient last line: `target_os=['ios'];`
    109 
    110 armv7
    111 
    112     GYP_DEFINES="OS=ios target_arch=armv7 target_subarch=arm32" GYP_CROSSCOMPILE=1 GYP_GENERATOR_FLAGS="output_dir=out_ios" ./gyp_libyuv
    113     ninja -j7 -C out_ios/Debug-iphoneos libyuv_unittest
    114     ninja -j7 -C out_ios/Release-iphoneos libyuv_unittest
    115 
    116 arm64
    117 
    118     GYP_DEFINES="OS=ios target_arch=arm64 target_subarch=arm64" GYP_CROSSCOMPILE=1 GYP_GENERATOR_FLAGS="output_dir=out_ios" ./gyp_libyuv
    119     ninja -j7 -C out_ios/Debug-iphoneos libyuv_unittest
    120     ninja -j7 -C out_ios/Release-iphoneos libyuv_unittest
    121 
    122 both armv7 and arm64 (fat)
    123 
    124     GYP_DEFINES="OS=ios target_arch=armv7 target_subarch=both" GYP_CROSSCOMPILE=1 GYP_GENERATOR_FLAGS="output_dir=out_ios" ./gyp_libyuv
    125     ninja -j7 -C out_ios/Debug-iphoneos libyuv_unittest
    126     ninja -j7 -C out_ios/Release-iphoneos libyuv_unittest
    127 
    128 simulator
    129 
    130     GYP_DEFINES="OS=ios target_arch=ia32 target_subarch=arm32" GYP_CROSSCOMPILE=1 GYP_GENERATOR_FLAGS="output_dir=out_sim" ./gyp_libyuv
    131     ninja -j7 -C out_sim/Debug-iphonesimulator libyuv_unittest
    132     ninja -j7 -C out_sim/Release-iphonesimulator libyuv_unittest
    133 
    134 ### Android
    135 https://code.google.com/p/chromium/wiki/AndroidBuildInstructions
    136 
    137 Add to .gclient last line: `target_os=['android'];`
    138 
    139 armv7
    140 
    141     GYP_DEFINES="OS=android" GYP_CROSSCOMPILE=1 ./gyp_libyuv
    142     ninja -j7 -C out/Debug yuv_unittest_apk
    143     ninja -j7 -C out/Release yuv_unittest_apk
    144 
    145 arm64
    146 
    147     GYP_DEFINES="OS=android target_arch=arm64 target_subarch=arm64" GYP_CROSSCOMPILE=1 ./gyp_libyuv
    148     ninja -j7 -C out/Debug yuv_unittest_apk
    149     ninja -j7 -C out/Release yuv_unittest_apk
    150 
    151 ia32
    152 
    153     GYP_DEFINES="OS=android target_arch=ia32" GYP_CROSSCOMPILE=1 ./gyp_libyuv
    154     ninja -j7 -C out/Debug yuv_unittest_apk
    155     ninja -j7 -C out/Release yuv_unittest_apk
    156 
    157     GYP_DEFINES="OS=android target_arch=ia32 android_full_debug=1" GYP_CROSSCOMPILE=1 ./gyp_libyuv
    158     ninja -j7 -C out/Debug yuv_unittest_apk
    159 
    160 mipsel
    161 
    162     GYP_DEFINES="OS=android target_arch=mipsel" GYP_CROSSCOMPILE=1 ./gyp_libyuv
    163     ninja -j7 -C out/Debug yuv_unittest_apk
    164     ninja -j7 -C out/Release yuv_unittest_apk
    165 
    166 arm32 disassembly:
    167 
    168     third_party/android_tools/ndk/toolchains/arm-linux-androideabi-4.9/prebuilt/linux-x86_64/bin/arm-linux-androideabi-objdump -d out/Release/obj/source/libyuv.row_neon.o
    169 
    170 arm64 disassembly:
    171 
    172     third_party/android_tools/ndk/toolchains/aarch64-linux-android-4.9/prebuilt/linux-x86_64/bin/aarch64-linux-android-objdump -d out/Release/obj/source/libyuv.row_neon64.o
    173 
    174 Running tests:
    175 
    176     build/android/test_runner.py gtest -s libyuv_unittest -t 7200 --verbose --release --gtest_filter=*
    177 
    178 Running test as benchmark:
    179 
    180     build/android/test_runner.py gtest -s libyuv_unittest -t 7200 --verbose --release --gtest_filter=* -a "--libyuv_width=1280 --libyuv_height=720 --libyuv_repeat=999 --libyuv_flags=-1"
    181 
    182 Running test with C code:
    183 
    184     build/android/test_runner.py gtest -s libyuv_unittest -t 7200 --verbose --release --gtest_filter=* -a "--libyuv_width=1280 --libyuv_height=720 --libyuv_repeat=999 --libyuv_flags=1 --libyuv_cpu_info=1"
    185 
    186 #### Building with GN
    187 
    188     gn gen out/Release "--args=is_debug=false target_cpu=\"x86\""
    189     gn gen out/Debug "--args=is_debug=true target_cpu=\"x86\""
    190     ninja -C out/Release
    191     ninja -C out/Debug
    192 
    193 ### Building Offical with GN
    194 
    195     gn gen out/Official "--args=is_debug=false is_official_build=true is_chrome_branded=true"
    196     ninja -C out/Official
    197 
    198 #### Building mips with GN
    199 
    200 mipsel
    201     gn gen out/Default "--args=is_debug=false target_cpu=\"mipsel\" target_os = \"android\" mips_arch_variant = \"r6\" mips_use_msa = true is_component_build = true is_clang = false"
    202     ninja -C out/Default
    203 
    204 mips64el
    205     gn gen out/Default "--args=is_debug=false target_cpu=\"mips64el\" target_os = \"android\" mips_arch_variant = \"r6\" mips_use_msa = true is_component_build = true is_clang = false"
    206     ninja -C out/Default
    207 
    208 ### Linux
    209 
    210     GYP_DEFINES="target_arch=x64" ./gyp_libyuv
    211     ninja -j7 -C out/Debug
    212     ninja -j7 -C out/Release
    213 
    214     GYP_DEFINES="target_arch=ia32" ./gyp_libyuv
    215     ninja -j7 -C out/Debug
    216     ninja -j7 -C out/Release
    217 
    218 #### CentOS
    219 
    220 On CentOS 32 bit the following work around allows a sync:
    221 
    222     export GYP_DEFINES="host_arch=ia32"
    223     gclient sync
    224 
    225 ### Windows Shared Library
    226 
    227 Modify libyuv.gyp from 'static_library' to 'shared_library', and add 'LIBYUV_BUILDING_SHARED_LIBRARY' to 'defines'.
    228 
    229     gclient runhooks
    230 
    231 After this command follow the building the library instructions above.
    232 
    233 If you get a compile error for atlthunk.lib on Windows, read http://www.chromium.org/developers/how-tos/build-instructions-windows
    234 
    235 
    236 ### Build targets
    237 
    238     ninja -C out/Debug libyuv
    239     ninja -C out/Debug libyuv_unittest
    240     ninja -C out/Debug compare
    241     ninja -C out/Debug yuvconvert
    242     ninja -C out/Debug psnr
    243     ninja -C out/Debug cpuid
    244 
    245 
    246 ## Building the Library with make
    247 
    248 ### Linux
    249 
    250     make -j7 V=1 -f linux.mk
    251     make -j7 V=1 -f linux.mk clean
    252     make -j7 V=1 -f linux.mk CXX=clang++
    253 
    254 ## Building the Library with cmake
    255 
    256 Install cmake: http://www.cmake.org/
    257 
    258 Default debug build:
    259 
    260     mkdir out
    261     cd out
    262     cmake ..
    263     cmake --build .
    264 
    265 Release build/install
    266 
    267     mkdir out
    268     cd out
    269     cmake -DCMAKE_INSTALL_PREFIX="/usr/lib" -DCMAKE_BUILD_TYPE="Release" ..
    270     cmake --build . --config Release
    271     sudo cmake --build . --target install --config Release
    272 
    273 ### Windows 8 Phone
    274 
    275 Pre-requisite:
    276 
    277 * Install Visual Studio 2012 and Arm to your environment.<br>
    278 
    279 Then:
    280 
    281     call "c:\Program Files (x86)\Microsoft Visual Studio 11.0\VC\bin\x86_arm\vcvarsx86_arm.bat"
    282 
    283 or with Visual Studio 2013:
    284 
    285     call "c:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\bin\x86_arm\vcvarsx86_arm.bat"
    286     nmake /f winarm.mk clean
    287     nmake /f winarm.mk
    288 
    289 ### Windows Shared Library
    290 
    291 Modify libyuv.gyp from 'static_library' to 'shared_library', and add 'LIBYUV_BUILDING_SHARED_LIBRARY' to 'defines'. Then run this.
    292 
    293     gclient runhooks
    294 
    295 After this command follow the building the library instructions above.
    296 
    297 If you get a compile error for atlthunk.lib on Windows, read http://www.chromium.org/developers/how-tos/build-instructions-windows
    298 
    299 ### 64 bit Windows
    300 
    301     set GYP_DEFINES=target_arch=x64
    302     gclient runhooks V=1
    303 
    304 ### ARM Linux
    305 
    306     export GYP_DEFINES="target_arch=arm"
    307     export CROSSTOOL=`<path>`/arm-none-linux-gnueabi
    308     export CXX=$CROSSTOOL-g++
    309     export CC=$CROSSTOOL-gcc
    310     export AR=$CROSSTOOL-ar
    311     export AS=$CROSSTOOL-as
    312     export RANLIB=$CROSSTOOL-ranlib
    313     gclient runhooks
    314 
    315 ## Running Unittests
    316 
    317 ### Windows
    318 
    319     out\Release\libyuv_unittest.exe --gtest_catch_exceptions=0 --gtest_filter="*"
    320 
    321 ### OSX
    322 
    323     out/Release/libyuv_unittest --gtest_filter="*"
    324 
    325 ### Linux
    326 
    327     out/Release/libyuv_unittest --gtest_filter="*"
    328 
    329 Replace --gtest_filter="*" with specific unittest to run.  May include wildcards. e.g.
    330 
    331     out/Release/libyuv_unittest --gtest_filter=libyuvTest.I420ToARGB_Opt
    332 
    333 ## CPU Emulator tools
    334 
    335 ### Intel SDE (Software Development Emulator)
    336 
    337 Pre-requisite: Install IntelSDE for Windows: http://software.intel.com/en-us/articles/intel-software-development-emulator
    338 
    339 Then run:
    340 
    341     c:\intelsde\sde -hsw -- out\release\libyuv_unittest.exe --gtest_filter=*
    342 
    343 
    344 ## Memory tools
    345 
    346 ### Running Dr Memory memcheck for Windows
    347 
    348 Pre-requisite: Install Dr Memory for Windows and add it to your path: http://www.drmemory.org/docs/page_install_windows.html
    349 
    350     set GYP_DEFINES=build_for_tool=drmemory target_arch=ia32
    351     call python gyp_libyuv -fninja -G msvs_version=2013
    352     ninja -C out\Debug
    353     drmemory out\Debug\libyuv_unittest.exe --gtest_catch_exceptions=0 --gtest_filter=*
    354 
    355 ### Running UBSan
    356 
    357 See Chromium instructions for sanitizers: https://www.chromium.org/developers/testing/undefinedbehaviorsanitizer
    358 
    359 Sanitizers available: TSan, MSan, ASan, UBSan, LSan
    360 
    361     GYP_DEFINES='ubsan=1' gclient runhooks
    362     ninja -C out/Release
    363 
    364 ### Running Valgrind memcheck
    365 
    366 Memory errors and race conditions can be found by running tests under special memory tools. [Valgrind] [1] is an instrumentation framework for building dynamic analysis tools. Various tests and profilers are built upon it to find memory handling errors and memory leaks, for instance.
    367 
    368 [1]: http://valgrind.org
    369 
    370     solutions = [
    371       { "name"        : "libyuv",
    372         "url"         : "https://chromium.googlesource.com/libyuv/libyuv",
    373         "deps_file"   : "DEPS",
    374         "managed"     : True,
    375         "custom_deps" : {
    376            "libyuv/chromium/src/third_party/valgrind": "https://chromium.googlesource.com/chromium/deps/valgrind/binaries",
    377         },
    378         "safesync_url": "",
    379       },
    380     ]
    381 
    382 Then run:
    383 
    384     GYP_DEFINES="clang=0 target_arch=x64 build_for_tool=memcheck" python gyp_libyuv
    385     ninja -C out/Debug
    386     valgrind out/Debug/libyuv_unittest
    387 
    388 
    389 For more information, see http://www.chromium.org/developers/how-tos/using-valgrind
    390 
    391 ### Running Thread Sanitizer (TSan)
    392 
    393     GYP_DEFINES="clang=0 target_arch=x64 build_for_tool=tsan" python gyp_libyuv
    394     ninja -C out/Debug
    395     valgrind out/Debug/libyuv_unittest
    396 
    397 For more info, see http://www.chromium.org/developers/how-tos/using-valgrind/threadsanitizer
    398 
    399 ### Running Address Sanitizer (ASan)
    400 
    401     GYP_DEFINES="clang=0 target_arch=x64 build_for_tool=asan" python gyp_libyuv
    402     ninja -C out/Debug
    403     valgrind out/Debug/libyuv_unittest
    404 
    405 For more info, see http://dev.chromium.org/developers/testing/addresssanitizer
    406 
    407 ## Benchmarking
    408 
    409 The unittests can be used to benchmark.
    410 
    411 ### Windows
    412 
    413     set LIBYUV_WIDTH=1280
    414     set LIBYUV_HEIGHT=720
    415     set LIBYUV_REPEAT=999
    416     set LIBYUV_FLAGS=-1
    417     out\Release\libyuv_unittest.exe --gtest_filter=*I420ToARGB_Opt
    418 
    419 
    420 ### Linux and Mac
    421 
    422     LIBYUV_WIDTH=1280 LIBYUV_HEIGHT=720 LIBYUV_REPEAT=1000 out/Release/libyuv_unittest --gtest_filter=*I420ToARGB_Opt
    423 
    424     libyuvTest.I420ToARGB_Opt (547 ms)
    425 
    426 Indicates 0.547 ms/frame for 1280 x 720.
    427 
    428 ## Making a change
    429 
    430     gclient sync
    431     git checkout -b mycl -t origin/master
    432     git pull
    433     <edit files>
    434     git add -u
    435     git commit -m "my change"
    436     git cl lint
    437     git cl try
    438     git cl upload -r a-reviewer (a] chomium.org -s
    439     <once approved..>
    440     git cl land
    441