Title: [95479] trunk/Source/WebCore
Revision
95479
Author
cmar...@apple.com
Date
2011-09-19 14:56:23 -0700 (Mon, 19 Sep 2011)

Log Message

2011-09-19  Chris Marrin  <cmar...@apple.com>

        Crash can occur when doing a PlatformCAAnimation::copy() with no valueFunction
        https://bugs.webkit.org/show_bug.cgi?id=67510

        Reviewed by Adam Roben.
        
        Another fix to take care of one last crash when running pause-crash.html. 
        CACF can't deal with null valueFunctions, so avoid setting it when it doesn't 
        exist.
        
        This also adds logic to the Windows Hook in LayerChangesFlusher to prevent it 
        from catching the null pointer exception generated by the pause-crash.html test 
        before this bug was fixed. Windows was ignoring the exception, so the testcase 
        would appear to succeed, even though it should have crashed.

        This is a resubmission of http://trac.webkit.org/changeset/95243 with a build fix.

        * WebCore.vcproj/WebCore.vcproj:
        * platform/graphics/ca/win/LayerChangesFlusher.cpp:
        (WebCore::LayerChangesFlusher::hookCallback):
        * platform/graphics/ca/win/PlatformCAAnimationWin.cpp:
        (PlatformCAAnimation::copy):
        * platform/win/StructuredExceptionHandlerSupressor.h: Added.
        (WebCore::StructuredExceptionHandlerSupressor::StructuredExceptionHandlerSupressor):
        (WebCore::StructuredExceptionHandlerSupressor::~StructuredExceptionHandlerSupressor):

Modified Paths

Added Paths

Diff

Modified: trunk/Source/WebCore/ChangeLog (95478 => 95479)


--- trunk/Source/WebCore/ChangeLog	2011-09-19 21:51:44 UTC (rev 95478)
+++ trunk/Source/WebCore/ChangeLog	2011-09-19 21:56:23 UTC (rev 95479)
@@ -1,3 +1,30 @@
+2011-09-19  Chris Marrin  <cmar...@apple.com>
+
+        Crash can occur when doing a PlatformCAAnimation::copy() with no valueFunction
+        https://bugs.webkit.org/show_bug.cgi?id=67510
+
+        Reviewed by Adam Roben.
+        
+        Another fix to take care of one last crash when running pause-crash.html. 
+        CACF can't deal with null valueFunctions, so avoid setting it when it doesn't 
+        exist.
+        
+        This also adds logic to the Windows Hook in LayerChangesFlusher to prevent it 
+        from catching the null pointer exception generated by the pause-crash.html test 
+        before this bug was fixed. Windows was ignoring the exception, so the testcase 
+        would appear to succeed, even though it should have crashed.
+
+        This is a resubmission of http://trac.webkit.org/changeset/95243 with a build fix.
+
+        * WebCore.vcproj/WebCore.vcproj:
+        * platform/graphics/ca/win/LayerChangesFlusher.cpp:
+        (WebCore::LayerChangesFlusher::hookCallback):
+        * platform/graphics/ca/win/PlatformCAAnimationWin.cpp:
+        (PlatformCAAnimation::copy):
+        * platform/win/StructuredExceptionHandlerSupressor.h: Added.
+        (WebCore::StructuredExceptionHandlerSupressor::StructuredExceptionHandlerSupressor):
+        (WebCore::StructuredExceptionHandlerSupressor::~StructuredExceptionHandlerSupressor):
+
 2011-09-19  Ryosuke Niwa  <rn...@webkit.org>
 
         Incorrect selection with absolutely positioned div

Modified: trunk/Source/WebCore/WebCore.vcproj/WebCore.vcproj (95478 => 95479)


--- trunk/Source/WebCore/WebCore.vcproj/WebCore.vcproj	2011-09-19 21:51:44 UTC (rev 95478)
+++ trunk/Source/WebCore/WebCore.vcproj/WebCore.vcproj	2011-09-19 21:56:23 UTC (rev 95479)
@@ -27324,6 +27324,10 @@
 					RelativePath="..\platform\win\SoundWin.cpp"
 					>
 				</File>
+                <File
+                    RelativePath="..\platform\win\StructuredExceptionHandlerSupressor.h"
+                    >
+                </File>
 				<File
 					RelativePath="..\platform\win\SystemInfo.cpp"
 					>

Modified: trunk/Source/WebCore/platform/graphics/ca/win/LayerChangesFlusher.cpp (95478 => 95479)


--- trunk/Source/WebCore/platform/graphics/ca/win/LayerChangesFlusher.cpp	2011-09-19 21:51:44 UTC (rev 95478)
+++ trunk/Source/WebCore/platform/graphics/ca/win/LayerChangesFlusher.cpp	2011-09-19 21:56:23 UTC (rev 95479)
@@ -29,6 +29,7 @@
 #if USE(ACCELERATED_COMPOSITING)
 
 #include "AbstractCACFLayerTreeHost.h"
+#include "StructuredExceptionHandlerSupressor.h"
 #include <wtf/StdLibExtras.h>
 #include <wtf/Vector.h>
 
@@ -71,6 +72,9 @@
 
 LRESULT LayerChangesFlusher::hookCallback(int code, WPARAM wParam, LPARAM lParam)
 {
+    // Supress the exception handler Windows puts around all hook calls so we can 
+    // crash for debugging purposes if an exception is hit. 
+    StructuredExceptionHandlerSupressor supressor; 
     return shared().hookFired(code, wParam, lParam);
 }
 

Modified: trunk/Source/WebCore/platform/graphics/ca/win/PlatformCAAnimationWin.cpp (95478 => 95479)


--- trunk/Source/WebCore/platform/graphics/ca/win/PlatformCAAnimationWin.cpp	2011-09-19 21:51:44 UTC (rev 95478)
+++ trunk/Source/WebCore/platform/graphics/ca/win/PlatformCAAnimationWin.cpp	2011-09-19 21:56:23 UTC (rev 95479)
@@ -183,7 +183,8 @@
     animation->setRemovedOnCompletion(isRemovedOnCompletion());
     animation->setAdditive(isAdditive());
     animation->copyTimingFunctionFrom(this);
-    animation->setValueFunction(valueFunction());
+    if (valueFunction())
+        animation->setValueFunction(valueFunction());
     
     // Copy the specific Basic or Keyframe values
     if (animationType() == Keyframe) {

Added: trunk/Source/WebCore/platform/win/StructuredExceptionHandlerSupressor.h (0 => 95479)


--- trunk/Source/WebCore/platform/win/StructuredExceptionHandlerSupressor.h	                        (rev 0)
+++ trunk/Source/WebCore/platform/win/StructuredExceptionHandlerSupressor.h	2011-09-19 21:56:23 UTC (rev 95479)
@@ -0,0 +1,76 @@
+/*
+ * Copyright (C) 2011 Apple Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef StructuredExceptionHandlerSupressor_h
+#define StructuredExceptionHandlerSupressor_h
+
+namespace WebCore {
+
+#pragma warning(push)
+#pragma warning(disable: 4733) // Disable "not registered as safe handler" warning
+
+class StructuredExceptionHandlerSupressor {
+    WTF_MAKE_NONCOPYABLE(StructuredExceptionHandlerSupressor);
+public:
+    StructuredExceptionHandlerSupressor()
+    {
+        // Windows puts an __try/__except block around some calls, such as hooks.
+        // The exception handler then ignores system exceptions like invalid addresses
+        // and null pointers. This class can be used to remove this block and prevent
+        // it from catching the exception. Typically this will cause the exception to crash 
+        // which is often desirable to allow crashlogs to be recorded for debugging purposed.
+        // While this class is in scope we replace the Windows exception handler with 0xffffffff, 
+        // which indicates that the exception should not be handled.
+        //
+        // See http://www.microsoft.com/msj/0197/Exception/Exception.aspx
+
+        // Windows doesn't like assigning to member variables, so we need to get the value into
+        // a local variable and store it afterwards.
+        void* registration;
+
+        __asm mov eax, FS:[0]
+        __asm mov [registration], eax
+        __asm mov eax, 0xffffffff
+        __asm mov FS:[0], eax
+
+        m_savedExceptionRegistration = registration;
+    }
+
+    ~StructuredExceptionHandlerSupressor()
+    {
+        // Restore the exception handler
+        __asm mov eax, [m_savedExceptionRegistration]
+        __asm mov FS:[0], eax
+    }
+
+private:
+    void* m_savedExceptionRegistration;
+};
+
+#pragma warning(pop)
+
+} // namespace WebCore
+
+#endif // StructuredExceptionHandlerSupressor_h
_______________________________________________
webkit-changes mailing list
webkit-changes@lists.webkit.org
http://lists.webkit.org/mailman/listinfo.cgi/webkit-changes

Reply via email to