Bug 23840

Summary: Loading kcrw.com make Safari use 100% CPU and hang
Product: WebKit Reporter: Jeff Johnson <opendarwin>
Component: New BugsAssignee: Nobody <webkit-unassigned>
Status: RESOLVED WORKSFORME    
Severity: Normal CC: bfulgham, hyatt, mrowe
Priority: P2 Keywords: InRadar
Version: 528+ (Nightly build)   
Hardware: Mac   
OS: OS X 10.5   
URL: http://www.kcrw.com/
Attachments:
Description Flags
Page source of http://www.kcrw.com/ none

Jeff Johnson
Reported 2009-02-08 23:45:02 PST
Configuration Test machines: Intel Core 2 Duo MacBook Pro, Intel Core Duo iMac Operating System: Mac OS X 10.5.6 WebKit versions: svn revision 40743 and Safari Version 3.2.1 (5525.27.1) Steps to reproduce 1. Launch Safari. 2. Select "Security" tab in Preferences window. 3. Set "Accept cookies" to "Never". 4. Check "Enable JavaScript". 5. Close Preferences window. 6. Load http://www.kcrw.com/ Expected results The page finishes loading quickly. Actual results The page never finishes loading completely. Safari starts to have high CPU usage, near 100%, and Safari eventually pinwheels. Regression The bug also occurs when cookie preferences are set to "Only from sites you navigate to". It does not occur when cookie preferences are set to "Always". Notes I emailed a gdb backtrace and a sample to Mark Rowe. I'm not attaching them here, because the files are very large. The sample was 229MB, compressed to 1.3MB! Mark can attach them to the bug if he likes. I believe that the problematic code in the page source is the following: <script language="JavaScript"> document.write('<SCRIPT LANGUAGE="JavaScript1.1" SRC="http://ad.doubleclick.net/adj/c.site147.tmus/KCRW_Home_page;sz=160x600;ord=' + ord + '?" ><\/SCRIPT>'); </script> <script> if ((!document.images && navigator.userAgent.indexOf("Mozilla/2.") >= 0) || navigator.userAgent.indexOf("WebTV")>= 0) { document.write('<A HREF="http://ad.doubleclick.net/jump/c.site147.tmus/KCRW_Home_page;sz=160x600;ord=' + ord + '?" TARGET="_blank">'); document.write('<IMG SRC="http://ad.doubleclick.net/ad/c.site147.tmus/KCRW_Home_page;sz=160x600;ord=' + ord + '?" WIDTH="160" HEIGHT="600" BORDER="0" ALT="" \/><\/A>'); } </script> If you stick in a random number and download for example http://ad.doubleclick.net/adj/c.site147.tmus/KCRW_Home_page;sz=160x600;ord=123456789? you get this: document.write('<IFRAME SRC=\"http://u.npr.org/hserver/site=NETWORK/station=KCRW/vertical=MUSIC/utype=BANNER/aamsz=160x600/ACC_RANDOM=2667518\" WIDTH=160 HEIGHT=600 NORESIZE SCROLLING=NO FRAMEBORDER=0 MARGINWIDTH=0 MARGINHEIGHT=0></IFRAME>'); The URL http://u.npr.org/hserver/site=NETWORK/station=KCRW/vertical=MUSIC/utype=BANNER/aamsz=160x600/ACC_RANDOM=2667518 seems to be the real problem. Indeed, you can get high CPU usage from Safari by just loading that page, or some random number variant of it. The source of that page is the following: <script language="JavaScript"> document.write('<SCRIPT LANGUAGE="JavaScript1.1" SRC="http://ad.doubleclick.net/adj/c.site147.tmus/nopassback;sz=160x600;ord=2667518?"><\/SCRIPT>'); </script> <script> if((!document.images && navigator.userAgent.indexOf("Mozilla/2.")>=0)||navigator.userAgent.indexOf("WebTV")>=0){ document.write('<A HREF="http://ad.doubleclick.net/jump/c.site147.tmus/nopassback;sz=160x600;ord=2667518?" TARGET="_blank">'); document.write('<IMG SRC="http://ad.doubleclick.net/ad/c.site147.tmus/nopassback;sz=160x600;ord=2667518?" WIDTH="160" HEIGHT="600" BORDER="0" ALT="" \/><\/A>'); } </script> <noscript> <a href="http://ad.doubleclick.net/jump/c.site147.tmus/nopassback;sz=160x600;ord=2667518?" target="_blank"><img src="http://ad.doubleclick.net/ad/c.site147.tmus/nopassback;sz=160x600;ord=2667518?" width="160" height="600" border="0" alt=""/></a> So what appears to be happening is that there's some kind of infinite loop, because it tries to set a cookie, that fails, the desired image is not yet displayed in the page, and so it keeps trying over and over again.
Attachments
Page source of http://www.kcrw.com/ (65.81 KB, text/html)
2009-02-08 23:49 PST, Jeff Johnson
no flags
Jeff Johnson
Comment 1 2009-02-08 23:49:55 PST
Mark Rowe (bdash)
Comment 2 2009-02-08 23:54:17 PST
Mark Rowe (bdash)
Comment 3 2009-02-21 00:47:58 PST
Does this still happen after installing the recent Mac OS X security update?
Jeff Johnson
Comment 4 2009-02-21 10:10:53 PST
(In reply to comment #3) > Does this still happen after installing the recent Mac OS X security update? Yes, it still occurs after installing Security Update 2009-001. It appears from the bom file that there weren't any changes to either WebKit or Safari in that security update.
Mark Rowe (bdash)
Comment 5 2009-02-21 11:28:23 PST
There were changes to CFNetwork related to cookies that I had thought could explain why you were able to reproduce this problem while I was unable (I had an early version of the security update installed back when we were discussing this on IRC).
Jeff Johnson
Comment 6 2009-02-21 12:51:22 PST
(In reply to comment #5) > There were changes to CFNetwork related to cookies that I had thought could > explain why you were able to reproduce this problem while I was unable (I had > an early version of the security update installed back when we were discussing > this on IRC). Got it. I can provide more information if needed to reproduce.
Brady Eidson
Comment 7 2009-02-23 18:45:41 PST
I can't reproduce this either. Mark, do you have the spin log?
Note You need to log in before you can comment on or make changes to this bug.