Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(112)

Side by Side Diff: chrome_elf/blacklist/blacklist.h

Issue 133923002: Use a Finch Experiment to control the Browser Blacklist (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Fix unittests Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « chrome_elf/blacklist.gypi ('k') | chrome_elf/blacklist/blacklist.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_ELF_BLACKLIST_BLACKLIST_H_ 5 #ifndef CHROME_ELF_BLACKLIST_BLACKLIST_H_
6 #define CHROME_ELF_BLACKLIST_BLACKLIST_H_ 6 #define CHROME_ELF_BLACKLIST_BLACKLIST_H_
7 7
8 namespace blacklist { 8 namespace blacklist {
9 9
10 // Max size of the DLL blacklist. 10 // Max size of the DLL blacklist.
11 const int kTroublesomeDllsMaxCount = 64; 11 const int kTroublesomeDllsMaxCount = 64;
12 12
13 // The DLL blacklist. 13 // The DLL blacklist.
14 extern const wchar_t* g_troublesome_dlls[kTroublesomeDllsMaxCount]; 14 extern const wchar_t* g_troublesome_dlls[kTroublesomeDllsMaxCount];
15 15
16 // Cursor to the current last element in the blacklist. 16 // Cursor to the current last element in the blacklist.
17 extern int g_troublesome_dlls_cur_index; 17 extern int g_troublesome_dlls_cur_index;
18 18
19 // The registry path of the blacklist beacon. Exposed here for testing. 19 // The registry path of the blacklist beacon.
20 extern const wchar_t kRegistryBeaconPath[]; 20 extern const wchar_t kRegistryBeaconPath[];
21 21
22 // Attempts to create a beacon in the current user's registry hive. 22 // The properties for the blacklist beacon.
23 // If the beacon already exists or any other error occurs when creating the 23 extern const wchar_t kBeaconVersion[];
24 // beacon, returns false. Otherwise returns true. 24 extern const wchar_t kBeaconState[];
25
26 // The states for the blacklist setup code.
27 enum BlacklistState {
28 BLACKLIST_DISABLED = 0,
29 BLACKLIST_ENABLED,
30 // The blacklist setup code is running. If this is still set at startup,
31 // it means the last setup crashed.
32 BLACKLIST_SETUP_RUNNING,
33 // Always keep this at the end.
34 BLACKLIST_STATE_MAX,
35 };
36
37 // Attempts to leave a beacon in the current user's registry hive.
38 // If the blacklist beacon doesn't say it is enabled or there are any other
39 // errors when creating the beacon, returns false. Otherwise returns true.
25 // The intent of the beacon is to act as an extra failure mode protection 40 // The intent of the beacon is to act as an extra failure mode protection
26 // whereby if Chrome for some reason fails to start during blacklist setup, 41 // whereby if Chrome for some reason fails to start during blacklist setup,
27 // it will skip blacklisting on the subsequent run. 42 // it will skip blacklisting on the subsequent run.
28 bool CreateBeacon(); 43 bool LeaveSetupBeacon();
29 44
30 // Looks for the beacon that CreateBeacon() creates and attempts to delete it. 45 // Looks for the beacon that LeaveSetupBeacon() creates and resets it to
31 // Returns true if the beacon was found and deleted. 46 // to show the setup was successful.
32 bool ClearBeacon(); 47 // Returns true if the beacon was successfully set to BLACKLIST_ENABLED.
48 bool ResetBeacon();
33 49
34 // Adds the given dll name to the blacklist. Returns true if the dll name is in 50 // Adds the given dll name to the blacklist. Returns true if the dll name is in
35 // the blacklist when this returns, false on error. Note that this will copy 51 // the blacklist when this returns, false on error. Note that this will copy
36 // |dll_name| and will leak it on exit if the string is not subsequently removed 52 // |dll_name| and will leak it on exit if the string is not subsequently removed
37 // using RemoveDllFromBlacklist. 53 // using RemoveDllFromBlacklist.
38 extern "C" bool AddDllToBlacklist(const wchar_t* dll_name); 54 extern "C" bool AddDllToBlacklist(const wchar_t* dll_name);
39 55
40 // Removes the given dll name from the blacklist. Returns true if it was 56 // Removes the given dll name from the blacklist. Returns true if it was
41 // removed, false on error. 57 // removed, false on error.
42 extern "C" bool RemoveDllFromBlacklist(const wchar_t* dll_name); 58 extern "C" bool RemoveDllFromBlacklist(const wchar_t* dll_name);
43 59
44 // Initializes the DLL blacklist in the current process. This should be called 60 // Initializes the DLL blacklist in the current process. This should be called
45 // before any undesirable DLLs might be loaded. If |force| is set to true, then 61 // before any undesirable DLLs might be loaded. If |force| is set to true, then
46 // initialization will take place even if a beacon is present. This is useful 62 // initialization will take place even if a beacon is present. This is useful
47 // for tests. 63 // for tests.
48 bool Initialize(bool force); 64 bool Initialize(bool force);
49 65
50 } // namespace blacklist 66 } // namespace blacklist
51 67
52 #endif // CHROME_ELF_BLACKLIST_BLACKLIST_H_ 68 #endif // CHROME_ELF_BLACKLIST_BLACKLIST_H_
OLDNEW
« no previous file with comments | « chrome_elf/blacklist.gypi ('k') | chrome_elf/blacklist/blacklist.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698