|  | // Copyright 2015 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. | 
|  |  | 
|  | // This file contains the default suppressions for LeakSanitizer. | 
|  | // You can also pass additional suppressions via LSAN_OPTIONS: | 
|  | // LSAN_OPTIONS=suppressions=/path/to/suppressions. Please refer to | 
|  | // http://dev.chromium.org/developers/testing/leaksanitizer for more info. | 
|  |  | 
|  | #if defined(LEAK_SANITIZER) | 
|  |  | 
|  | // Please make sure the code below declares a single string variable | 
|  | // kLSanDefaultSuppressions which contains LSan suppressions delimited by | 
|  | // newlines. See http://dev.chromium.org/developers/testing/leaksanitizer | 
|  | // for the instructions on writing suppressions. | 
|  | char kLSanDefaultSuppressions[] = | 
|  | // Intentional leak used as sanity test for Valgrind/memcheck. | 
|  | "leak:base::ToolsSanityTest_MemoryLeak_Test::TestBody\n" | 
|  |  | 
|  | // ================ Leaks in third-party code ================ | 
|  |  | 
|  | // False positives in libfontconfig. http://crbug.com/39050 | 
|  | "leak:libfontconfig\n" | 
|  | // eglibc-2.19/string/strdup.c creates false positive leak errors because of | 
|  | // the same reason as crbug.com/39050. The leak error stack trace, when | 
|  | // unwind on malloc, includes a call to libfontconfig. But the default stack | 
|  | // trace is too short in leak sanitizer bot to make the libfontconfig | 
|  | // suppression works. http://crbug.com/605286 | 
|  | "leak:__strdup\n" | 
|  |  | 
|  | // Leaks in Nvidia's libGL. | 
|  | "leak:libGL.so\n" | 
|  |  | 
|  | // TODO(eugenis): revisit NSS suppressions after the switch to BoringSSL | 
|  | // NSS leaks in CertDatabaseNSSTest tests. http://crbug.com/51988 | 
|  | "leak:net::NSSCertDatabase::ImportFromPKCS12\n" | 
|  | "leak:net::NSSCertDatabase::ListCerts\n" | 
|  | "leak:net::NSSCertDatabase::DeleteCertAndKey\n" | 
|  | "leak:crypto::ScopedTestNSSDB::ScopedTestNSSDB\n" | 
|  | // Another leak due to not shutting down NSS properly. | 
|  | // http://crbug.com/124445 | 
|  | "leak:error_get_my_stack\n" | 
|  | // The NSS suppressions above will not fire when the fast stack unwinder is | 
|  | // used, because it can't unwind through NSS libraries. Apply blanket | 
|  | // suppressions for now. | 
|  | "leak:libnssutil3\n" | 
|  | "leak:libnspr4\n" | 
|  | "leak:libnss3\n" | 
|  | "leak:libplds4\n" | 
|  | "leak:libnssckbi\n" | 
|  |  | 
|  | // XRandR has several one time leaks. | 
|  | "leak:libxrandr\n" | 
|  |  | 
|  | // xrandr leak. http://crbug.com/119677 | 
|  | "leak:XRRFindDisplay\n" | 
|  |  | 
|  | // http://crbug.com/431213, http://crbug.com/416665 | 
|  | "leak:gin/object_template_builder.h\n" | 
|  |  | 
|  | // Leaks in swrast_dri.so. http://crbug.com/540042 | 
|  | "leak:swrast_dri.so\n" | 
|  |  | 
|  | // Leak in glibc's gconv caused by fopen(..., "r,ccs=UNICODE") | 
|  | "leak:__gconv_lookup_cache\n" | 
|  |  | 
|  | // ================ Leaks in Chromium code ================ | 
|  | // PLEASE DO NOT ADD SUPPRESSIONS FOR NEW LEAKS. | 
|  | // Instead, commits that introduce memory leaks should be reverted. | 
|  | // Suppressing the leak is acceptable in some cases when reverting is | 
|  | // impossible, i.e. when enabling leak detection for the first time for a | 
|  | // test target with pre-existing leaks. | 
|  |  | 
|  | // Small test-only leak in ppapi_unittests. http://crbug.com/258113 | 
|  | "leak:ppapi::proxy::PPP_Instance_Private_ProxyTest_PPPInstancePrivate_" | 
|  | "Test\n" | 
|  |  | 
|  | // http://crbug.com/322671 | 
|  | "leak:content::SpeechRecognitionBrowserTest::SetUpOnMainThread\n" | 
|  |  | 
|  | // http://crbug.com/355641 | 
|  | "leak:TrayAccessibilityTest\n" | 
|  |  | 
|  | // http://crbug.com/354644 | 
|  | "leak:CertificateViewerUITest::ShowModalCertificateViewer\n" | 
|  |  | 
|  | // http://crbug.com/356306 | 
|  | "leak:service_manager::SetProcessTitleFromCommandLine\n" | 
|  |  | 
|  | // https://crbug.com/755670 | 
|  | "leak:third_party/yasm/\n" | 
|  |  | 
|  | // v8 leaks caused by weak ref not call | 
|  | "leak:blink::DOMWrapperWorld::Create\n" | 
|  | "leak:blink::ScriptState::Create\n" | 
|  |  | 
|  | // https://crbug.com/795148 | 
|  | "leak:third_party/fontconfig/\n" | 
|  |  | 
|  | // https://crbug.com/831667 | 
|  | "leak:gin/*_unittest.cc\n" | 
|  |  | 
|  | // PLEASE READ ABOVE BEFORE ADDING NEW SUPPRESSIONS. | 
|  |  | 
|  | // End of suppressions. | 
|  | ;  // Please keep this semicolon. | 
|  |  | 
|  | #endif  // LEAK_SANITIZER |