summaryrefslogtreecommitdiffstats
path: root/chrome_frame/bind_context_info.h
diff options
context:
space:
mode:
authorananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-08-02 17:10:57 +0000
committerananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-08-02 17:10:57 +0000
commit5aef0faed81f398c426a245d5c9828e39679d3a7 (patch)
tree52e6f3df896eda04fcc120e30e1750a1e94c2dae /chrome_frame/bind_context_info.h
parentc32d6697f54f96a4483301232870b5ec15d14e7c (diff)
downloadchromium_src-5aef0faed81f398c426a245d5c9828e39679d3a7.zip
chromium_src-5aef0faed81f398c426a245d5c9828e39679d3a7.tar.gz
chromium_src-5aef0faed81f398c426a245d5c9828e39679d3a7.tar.bz2
Fix a crash in ChromeFrame full tab mode while processing the attach external tab request, which comes in during window open.
We create a ProtData object instance which is mapped to the protocol with a NULL read function pointer which was used to indicate if this is a dummy request. It appears that there are cases where we may receive a StartEx call with a reused protocol pointer. which basically causes a crash in the context of IInternetProtocolSink::ReportData which internally calls IInternetProtocol::LockRequest, which crashes as the transaction never started. Fix is to invalidate the protdata mapping if the protdata has not been destroyed yet, but the underlying Transaction has been destroyed. This can happen if the original bind context has not yet been destroyed Fixes bug http://code.google.com/p/chromium/issues/detail?id=50814 Bug=50814,50956 Test=Subsequent CL. Review URL: http://codereview.chromium.org/3078010 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@54553 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome_frame/bind_context_info.h')
-rw-r--r--chrome_frame/bind_context_info.h4
1 files changed, 4 insertions, 0 deletions
diff --git a/chrome_frame/bind_context_info.h b/chrome_frame/bind_context_info.h
index 1778604..4b08505 100644
--- a/chrome_frame/bind_context_info.h
+++ b/chrome_frame/bind_context_info.h
@@ -89,6 +89,10 @@ class __declspec(uuid("00000000-0000-0000-0000-000000000000")) BindContextInfo
return prot_data_;
}
+ bool has_prot_data() const {
+ return prot_data_.get() != NULL;
+ }
+
protected:
STDMETHOD(GetCppObject)(void** me) {
DCHECK(me);