| // 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 |