Bug 46187 - Add internetStatusCallback to ResourceHandleWin
Summary: Add internetStatusCallback to ResourceHandleWin
Status: RESOLVED FIXED
Alias: None
Product: WebKit
Classification: Unclassified
Component: Platform (show other bugs)
Version: 528+ (Nightly build)
Hardware: PC Windows XP
: P2 Normal
Assignee: Patrick R. Gansterer
URL:
Keywords:
Depends on:
Blocks: 43712
  Show dependency treegraph
 
Reported: 2010-09-21 08:01 PDT by Patrick R. Gansterer
Modified: 2010-09-23 08:39 PDT (History)
2 users (show)

See Also:


Attachments
Patch (4.18 KB, patch)
2010-09-21 08:34 PDT, Patrick R. Gansterer
no flags Details | Formatted Diff | Diff
Patch (removed CALLBACK in cpp) (4.27 KB, patch)
2010-09-23 06:55 PDT, Patrick R. Gansterer
no flags Details | Formatted Diff | Diff

Note You need to log in before you can comment on or make changes to this bug.
Description Patrick R. Gansterer 2010-09-21 08:01:28 PDT
see patch
Comment 1 Patrick R. Gansterer 2010-09-21 08:34:44 PDT
Created attachment 68241 [details]
Patch
Comment 2 Patrick R. Gansterer 2010-09-21 08:44:14 PDT
> WebCore/platform/network/win/ResourceHandleWin.cpp:297
>  void ResourceHandle::onRequestComplete(LPARAM lParam)
Will be changed to "bool onRequestComplete(void)" in a further patch (The file doesn't compile anyway at the moment).
Comment 3 Adam Roben (:aroben) 2010-09-23 06:46:11 PDT
Comment on attachment 68241 [details]
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=68241&action=review

> WebCore/platform/network/win/ResourceHandleWin.cpp:266
> +void CALLBACK ResourceHandle::internetStatusCallback(HINTERNET internetHandle, DWORD_PTR context, DWORD internetStatus,

No need for "CALLBACK" here. It's only needed on the declaration.

> WebCore/platform/network/win/ResourceHandleWin.cpp:279
> +    switch (internetStatus) {
> +    case INTERNET_STATUS_REDIRECT:
> +        handle->d->m_redirectUrl = String(static_cast<UChar*>(statusInformation), statusInformationLength);
> +        callOnMainThread(callOnRedirect, handle);
> +        break;
> +
> +    case INTERNET_STATUS_REQUEST_COMPLETE:
> +        callOnMainThread(callOnRequestComplete, handle);
> +        break;

What guarantees that the ResourceHandle hasn't been deleted by the time callOnRedirect/callOnRequestComplete are called on the main thread? For that matter, what guarantees that the ResourceHandle hasn't been deleted by the time internetStatusCallback is called?
Comment 4 Patrick R. Gansterer 2010-09-23 06:48:21 PDT
(In reply to comment #3)
> (From update of attachment 68241 [details])
> View in context: https://bugs.webkit.org/attachment.cgi?id=68241&action=review
> 
> > WebCore/platform/network/win/ResourceHandleWin.cpp:266
> > +void CALLBACK ResourceHandle::internetStatusCallback(HINTERNET internetHandle, DWORD_PTR context, DWORD internetStatus,
> 
> No need for "CALLBACK" here. It's only needed on the declaration.
> 
> > WebCore/platform/network/win/ResourceHandleWin.cpp:279
> > +    switch (internetStatus) {
> > +    case INTERNET_STATUS_REDIRECT:
> > +        handle->d->m_redirectUrl = String(static_cast<UChar*>(statusInformation), statusInformationLength);
> > +        callOnMainThread(callOnRedirect, handle);
> > +        break;
> > +
> > +    case INTERNET_STATUS_REQUEST_COMPLETE:
> > +        callOnMainThread(callOnRequestComplete, handle);
> > +        break;
> 
> What guarantees that the ResourceHandle hasn't been deleted by the time callOnRedirect/callOnRequestComplete are called on the main thread? For that matter, what guarantees that the ResourceHandle hasn't been deleted by the time internetStatusCallback is called?
ref() in start() will do that: http://trac.webkit.org/browser/trunk/WebCore/platform/network/win/ResourceHandleWin.cpp#L438
Comment 5 Patrick R. Gansterer 2010-09-23 06:55:01 PDT
Created attachment 68512 [details]
Patch (removed CALLBACK in cpp)
Comment 6 Adam Roben (:aroben) 2010-09-23 07:05:49 PDT
(In reply to comment #4)
> (In reply to comment #3)
> > (From update of attachment 68241 [details] [details])
> > View in context: https://bugs.webkit.org/attachment.cgi?id=68241&action=review
> > 
> > > WebCore/platform/network/win/ResourceHandleWin.cpp:266
> > > +void CALLBACK ResourceHandle::internetStatusCallback(HINTERNET internetHandle, DWORD_PTR context, DWORD internetStatus,
> > 
> > No need for "CALLBACK" here. It's only needed on the declaration.
> > 
> > > WebCore/platform/network/win/ResourceHandleWin.cpp:279
> > > +    switch (internetStatus) {
> > > +    case INTERNET_STATUS_REDIRECT:
> > > +        handle->d->m_redirectUrl = String(static_cast<UChar*>(statusInformation), statusInformationLength);
> > > +        callOnMainThread(callOnRedirect, handle);
> > > +        break;
> > > +
> > > +    case INTERNET_STATUS_REQUEST_COMPLETE:
> > > +        callOnMainThread(callOnRequestComplete, handle);
> > > +        break;
> > 
> > What guarantees that the ResourceHandle hasn't been deleted by the time callOnRedirect/callOnRequestComplete are called on the main thread? For that matter, what guarantees that the ResourceHandle hasn't been deleted by the time internetStatusCallback is called?
> ref() in start() will do that: http://trac.webkit.org/browser/trunk/WebCore/platform/network/win/ResourceHandleWin.cpp#L438

The ref() in start() will probably help, but not without knowing where the corresponding deref() happens. I see in attachment 68285 [details] that it's going to happen on onRequestComplete. But what happens if the request gets cancelled? E.g., it could get cancelled while we're inside internetStatusCallback, or between when internetStatusCallback returns and callOnRedirect is called, etc. Do we need to worry about those cases?
Comment 7 Patrick R. Gansterer 2010-09-23 07:33:04 PDT
(In reply to comment #6)
> The ref() in start() will probably help, but not without knowing where the corresponding deref() happens. I see in attachment 68285 [details] that it's going to happen on onRequestComplete. But what happens if the request gets cancelled? E.g., it could get cancelled while we're inside internetStatusCallback, or between when internetStatusCallback returns and callOnRedirect is called, etc. Do we need to worry about those cases?
A cancel() does not deref(), it will only close the handle and set it to null. deref() will happen when onRequestComplete() is called from MainThread.
see in the "complete" version: http://gitorious.org/+wincewebkit-developers/webkit/wincewebkit/blobs/wincegdi/WebCore/platform/network/win/ResourceHandleWin.cpp#line209
Comment 8 WebKit Commit Bot 2010-09-23 08:39:37 PDT
Comment on attachment 68512 [details]
Patch (removed CALLBACK in cpp)

Clearing flags on attachment: 68512

Committed r68144: <http://trac.webkit.org/changeset/68144>
Comment 9 WebKit Commit Bot 2010-09-23 08:39:42 PDT
All reviewed patches have been landed.  Closing bug.