Title: [88849] branches/chromium/742

Diff

Copied: branches/chromium/742/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions-expected.txt (from rev 87171, trunk/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions-expected.txt) (0 => 88849)


--- branches/chromium/742/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions-expected.txt	                        (rev 0)
+++ branches/chromium/742/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions-expected.txt	2011-06-14 20:41:34 UTC (rev 88849)
@@ -0,0 +1 @@
+PASS!

Copied: branches/chromium/742/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions.html (from rev 87171, trunk/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions.html) (0 => 88849)


--- branches/chromium/742/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions.html	                        (rev 0)
+++ branches/chromium/742/LayoutTests/fast/canvas/canvas-getImageData-largeNonintegralDimensions.html	2011-06-14 20:41:34 UTC (rev 88849)
@@ -0,0 +1,11 @@
+<html>
+PASS!
+<script>
+if (window.layoutTestController)
+    window.layoutTestController.dumpAsText();
+
+var canvas = document.createElement("canvas");
+var ctx = canvas.getContext("2d");
+ctx.getImageData(100.5, 2147483647.5, -2048.5, -2048.5);
+</script>
+</html>

Modified: branches/chromium/742/Source/WebCore/html/HTMLCanvasElement.cpp (88848 => 88849)


--- branches/chromium/742/Source/WebCore/html/HTMLCanvasElement.cpp	2011-06-14 20:36:57 UTC (rev 88848)
+++ branches/chromium/742/Source/WebCore/html/HTMLCanvasElement.cpp	2011-06-14 20:41:34 UTC (rev 88849)
@@ -371,17 +371,21 @@
 
 IntRect HTMLCanvasElement::convertLogicalToDevice(const FloatRect& logicalRect) const
 {
-    float left = floorf(logicalRect.x() * m_pageScaleFactor);
-    float top = floorf(logicalRect.y() * m_pageScaleFactor);
-    float right = ceilf(logicalRect.maxX() * m_pageScaleFactor);
-    float bottom = ceilf(logicalRect.maxY() * m_pageScaleFactor);
-    
+    // Prevent under/overflow by ensuring the rect's bounds stay within integer-expressible range
+    int left = clampToInteger(floorf(logicalRect.x() * m_pageScaleFactor));
+    int top = clampToInteger(floorf(logicalRect.y() * m_pageScaleFactor));
+    int right = clampToInteger(ceilf(logicalRect.maxX() * m_pageScaleFactor));
+    int bottom = clampToInteger(ceilf(logicalRect.maxY() * m_pageScaleFactor));
+
     return IntRect(IntPoint(left, top), convertToValidDeviceSize(right - left, bottom - top));
 }
 
 IntSize HTMLCanvasElement::convertLogicalToDevice(const FloatSize& logicalSize) const
 {
-    return convertToValidDeviceSize(logicalSize.width() * m_pageScaleFactor, logicalSize.height() * m_pageScaleFactor);
+    // Prevent overflow by ensuring the rect's bounds stay within integer-expressible range
+    float width = clampToInteger(ceilf(logicalSize.width() * m_pageScaleFactor));
+    float height = clampToInteger(ceilf(logicalSize.height() * m_pageScaleFactor));
+    return convertToValidDeviceSize(width, height);
 }
 
 IntSize HTMLCanvasElement::convertToValidDeviceSize(float width, float height) const

Modified: branches/chromium/742/Source/WebCore/html/canvas/CanvasRenderingContext2D.cpp (88848 => 88849)


--- branches/chromium/742/Source/WebCore/html/canvas/CanvasRenderingContext2D.cpp	2011-06-14 20:36:57 UTC (rev 88848)
+++ branches/chromium/742/Source/WebCore/html/canvas/CanvasRenderingContext2D.cpp	2011-06-14 20:41:34 UTC (rev 88849)
@@ -1632,6 +1632,10 @@
     if (scaledSize.height() < 1)
         scaledSize.setHeight(1);
 
+    float area = 4.0f * scaledSize.width() * scaledSize.height();
+    if (area > static_cast<float>(std::numeric_limits<int>::max()))
+        return 0;
+
     return createEmptyImageData(scaledSize);
 }
 
@@ -1668,7 +1672,12 @@
     ImageBuffer* buffer = canvas()->buffer();
     if (!buffer)
         return createEmptyImageData(scaledRect.size());
-    return ImageData::create(scaledRect.size(), buffer->getUnmultipliedImageData(scaledRect));
+
+    RefPtr<ByteArray> byteArray = buffer->getUnmultipliedImageData(scaledRect);
+    if (!byteArray)
+        return 0;
+
+    return ImageData::create(scaledRect.size(), byteArray.release());
 }
 
 void CanvasRenderingContext2D::putImageData(ImageData* data, float dx, float dy, ExceptionCode& ec)

Modified: branches/chromium/742/Source/WebCore/platform/graphics/cg/ImageBufferDataCG.cpp (88848 => 88849)


--- branches/chromium/742/Source/WebCore/platform/graphics/cg/ImageBufferDataCG.cpp	2011-06-14 20:36:57 UTC (rev 88848)
+++ branches/chromium/742/Source/WebCore/platform/graphics/cg/ImageBufferDataCG.cpp	2011-06-14 20:41:34 UTC (rev 88849)
@@ -110,6 +110,10 @@
 
 PassRefPtr<ByteArray> ImageBufferData::getData(const IntRect& rect, const IntSize& size, bool accelerateRendering, bool unmultiplied) const
 {
+    float area = 4.0f * rect.width() * rect.height();
+    if (area > static_cast<float>(std::numeric_limits<int>::max()))
+        return 0;
+
     RefPtr<ByteArray> result = ByteArray::create(rect.width() * rect.height() * 4);
     unsigned char* data = ""
     
_______________________________________________
webkit-changes mailing list
webkit-changes@lists.webkit.org
http://lists.webkit.org/mailman/listinfo.cgi/webkit-changes

Reply via email to