1 // Copyright 2015 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 // This file contains the default suppressions for LeakSanitizer.
6 // You can also pass additional suppressions via LSAN_OPTIONS:
7 // LSAN_OPTIONS=suppressions=/path/to/suppressions. Please refer to
8 // http://dev.chromium.org/developers/testing/leaksanitizer for more info.
10 #if defined(LEAK_SANITIZER)
12 // Please make sure the code below declares a single string variable
13 // kLSanDefaultSuppressions which contains LSan suppressions delimited by
14 // newlines. See http://dev.chromium.org/developers/testing/leaksanitizer
15 // for the instructions on writing suppressions.
16 char kLSanDefaultSuppressions
[] =
17 // Intentional leak used as sanity test for Valgrind/memcheck.
18 "leak:base::ToolsSanityTest_MemoryLeak_Test::TestBody\n"
20 // ================ Leaks in third-party code ================
22 // False positives in libfontconfig. http://crbug.com/39050
23 "leak:libfontconfig\n"
25 // Leaks in Nvidia's libGL.
28 // A small leak in V8. http://crbug.com/46571#c9
29 "leak:blink::V8GCController::collectGarbage\n"
31 // TODO(earthdok): revisit NSS suppressions after the switch to BoringSSL
32 // NSS leaks in CertDatabaseNSSTest tests. http://crbug.com/51988
33 "leak:net::NSSCertDatabase::ImportFromPKCS12\n"
34 "leak:net::NSSCertDatabase::ListCerts\n"
35 "leak:net::NSSCertDatabase::DeleteCertAndKey\n"
36 "leak:crypto::ScopedTestNSSDB::ScopedTestNSSDB\n"
37 // Another leak due to not shutting down NSS properly. http://crbug.com/124445
38 "leak:error_get_my_stack\n"
39 // The NSS suppressions above will not fire when the fast stack unwinder is
40 // used, because it can't unwind through NSS libraries. Apply blanket
41 // suppressions for now.
48 // XRandR has several one time leaks.
51 // xrandr leak. http://crbug.com/119677
52 "leak:XRRFindDisplay\n"
54 // Suppressions for objects which can be owned by the V8 heap. This is a
55 // temporary workaround until LeakSanitizer supports the V8 heap.
56 // Those should only fire in (browser)tests. If you see one of them in Chrome,
57 // then it's a real leak.
58 // http://crbug.com/328552
59 "leak:WTF::StringImpl::createUninitialized\n"
60 "leak:WTF::StringImpl::create8BitIfPossible\n"
61 "leak:blink::MouseEvent::create\n"
62 "leak:blink::*::*GetterCallback\n"
63 "leak:blink::CSSComputedStyleDeclaration::create\n"
64 "leak:blink::V8PerIsolateData::ensureDomInJSContext\n"
65 "leak:gin/object_template_builder.h\n"
66 "leak:gin::internal::Dispatcher\n"
67 "leak:blink::LocalDOMWindow::getComputedStyle\n"
68 // This should really be RemoteDOMWindow::create, but symbolization is
69 // weird in release builds. https://crbug.com/484760
70 "leak:blink::RemoteFrame::create\n"
71 // Likewise, this should really be blink::WindowProxy::initializeIfNeeded.
72 // https://crbug.com/484760
73 "leak:blink::WindowProxy::createContext\n"
75 // http://crbug.com/356785
76 "leak:content::RenderViewImplTest_DecideNavigationPolicyForWebUI_Test::TestBody\n"
78 // ================ Leaks in Chromium code ================
79 // PLEASE DO NOT ADD SUPPRESSIONS FOR NEW LEAKS.
80 // Instead, commits that introduce memory leaks should be reverted. Suppressing
81 // the leak is acceptable in some cases when reverting is impossible, i.e. when
82 // enabling leak detection for the first time for a test target with
83 // pre-existing leaks.
85 // Small test-only leak in ppapi_unittests. http://crbug.com/258113
86 "leak:ppapi::proxy::PPP_Instance_Private_ProxyTest_PPPInstancePrivate_Test\n"
88 // http://crbug.com/322671
89 "leak:content::SpeechRecognitionBrowserTest::SetUpOnMainThread\n"
91 // http://crbug.com/355641
92 "leak:TrayAccessibilityTest\n"
94 // http://crbug.com/354644
95 "leak:CertificateViewerUITest::ShowModalCertificateViewer\n"
97 // http://crbug.com/356306
98 "leak:content::SetProcessTitleFromCommandLine\n"
100 // http://crbug.com/506433
101 "leak:blink::ResourceFetcher::garbageCollectDocumentResources\n"
103 // PLEASE READ ABOVE BEFORE ADDING NEW SUPPRESSIONS.
105 // End of suppressions.
106 ; // Please keep this semicolon.
108 #endif // LEAK_SANITIZER