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

Unified Diff: chrome_frame/chrome_tab.cc

Issue 2038007: Merge 46738 - Change to a simpler upgrade scheme for Chrome Frame whereby we ... (Closed) Base URL: svn://svn.chromium.org/chrome/branches/375/src/
Patch Set: Created 10 years, 7 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome_frame/chrome_frame.gyp ('k') | chrome_frame/module_utils.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome_frame/chrome_tab.cc
===================================================================
--- chrome_frame/chrome_tab.cc (revision 46776)
+++ chrome_frame/chrome_tab.cc (working copy)
@@ -75,8 +75,7 @@
// See comments in DllGetClassObject.
-DllRedirector g_dll_redirector;
-Lock g_redirector_lock;
+LPFNGETCLASSOBJECT g_dll_get_class_object_redir_ptr = NULL;
class ChromeTabModule
: public AtlPerUserModule<CAtlDllModuleT<ChromeTabModule> > {
@@ -173,9 +172,27 @@
InitializeCrashReporting();
logging::InitLogging(NULL, logging::LOG_ONLY_TO_SYSTEM_DEBUG_LOG,
logging::LOCK_LOG_FILE, logging::DELETE_OLD_LOG_FILE);
+
+ if (!DllRedirector::RegisterAsFirstCFModule()) {
+ // We are not the first ones in, get the module who registered first.
+ HMODULE original_module = DllRedirector::GetFirstCFModule();
+ DCHECK(original_module != NULL)
+ << "Could not get first CF module handle.";
+ HMODULE this_module = reinterpret_cast<HMODULE>(&__ImageBase);
+ if (original_module != this_module) {
+ // Someone else was here first, try and get a pointer to their
+ // DllGetClassObject export:
+ g_dll_get_class_object_redir_ptr =
+ DllRedirector::GetDllGetClassObjectPtr(original_module);
+ DCHECK(g_dll_get_class_object_redir_ptr != NULL)
+ << "Found CF module with no DllGetClassObject export.";
+ }
+ }
+
// Enable ETW logging.
logging::LogEventProvider::Initialize(kChromeFrameProvider);
} else if (reason == DLL_PROCESS_DETACH) {
+ DllRedirector::UnregisterAsFirstCFModule();
g_patch_helper.UnpatchIfNeeded();
delete g_exit_manager;
g_exit_manager = NULL;
@@ -322,21 +339,10 @@
// Returns a class factory to create an object of the requested type
STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID* ppv) {
- // On first call, we scan the loaded module list to see if an older version
- // of Chrome Frame is already loaded. If it is, then we delegate all calls
- // to DllGetClassObject to it. This is to avoid having instances of
- // different versions of e.g. the BHO through an upgrade. It also prevents
- // us from repeatedly patching.
- LPFNGETCLASSOBJECT redir_ptr = NULL;
- {
- AutoLock lock(g_redirector_lock);
- g_dll_redirector.EnsureInitialized(L"npchrome_frame.dll",
- CLSID_ChromeActiveDocument);
- redir_ptr = g_dll_redirector.get_dll_get_class_object_ptr();
- }
-
- if (redir_ptr) {
- return redir_ptr(rclsid, riid, ppv);
+ // If we found another module present when we were loaded, then delegate to
+ // that:
+ if (g_dll_get_class_object_redir_ptr) {
+ return g_dll_get_class_object_redir_ptr(rclsid, riid, ppv);
} else {
g_patch_helper.InitializeAndPatchProtocolsIfNeeded();
return _AtlModule.DllGetClassObject(rclsid, riid, ppv);
« no previous file with comments | « chrome_frame/chrome_frame.gyp ('k') | chrome_frame/module_utils.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698