Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1)

Side by Side Diff: third_party/WebKit/Source/platform/graphics/Canvas2DLayerBridgeTest.cpp

Issue 2101823002: Revert of Make 2D canvas disable gpu acceleration when getImageData is called (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2011 Google Inc. All rights reserved. 2 * Copyright (C) 2011 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * 12 *
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND AN Y 13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND AN Y
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 15 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
16 * DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR AN Y 16 * DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR AN Y
17 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 17 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
18 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 18 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
19 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND O N 19 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND O N
20 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 20 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 21 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
22 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 22 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23 */ 23 */
24 24
25 #include "platform/graphics/Canvas2DLayerBridge.h" 25 #include "platform/graphics/Canvas2DLayerBridge.h"
26 26
27 #include "SkSurface.h" 27 #include "SkSurface.h"
28 #include "gpu/command_buffer/client/gles2_interface.h"
29 #include "gpu/command_buffer/common/capabilities.h"
28 #include "platform/ThreadSafeFunctional.h" 30 #include "platform/ThreadSafeFunctional.h"
29 #include "platform/WaitableEvent.h" 31 #include "platform/WaitableEvent.h"
30 #include "platform/graphics/ImageBuffer.h" 32 #include "platform/graphics/ImageBuffer.h"
31 #include "platform/graphics/UnacceleratedImageBufferSurface.h" 33 #include "platform/graphics/UnacceleratedImageBufferSurface.h"
32 #include "platform/graphics/test/FakeGLES2Interface.h" 34 #include "platform/graphics/test/FakeGLES2Interface.h"
33 #include "platform/graphics/test/FakeWebGraphicsContext3DProvider.h"
34 #include "public/platform/Platform.h" 35 #include "public/platform/Platform.h"
35 #include "public/platform/WebExternalBitmap.h" 36 #include "public/platform/WebExternalBitmap.h"
37 #include "public/platform/WebGraphicsContext3DProvider.h"
36 #include "public/platform/WebScheduler.h" 38 #include "public/platform/WebScheduler.h"
37 #include "public/platform/WebTaskRunner.h" 39 #include "public/platform/WebTaskRunner.h"
38 #include "public/platform/WebThread.h" 40 #include "public/platform/WebThread.h"
39 #include "public/platform/WebTraceLocation.h" 41 #include "public/platform/WebTraceLocation.h"
40 #include "public/platform/functional/WebFunction.h" 42 #include "public/platform/functional/WebFunction.h"
41 #include "skia/ext/texture_handle.h" 43 #include "skia/ext/texture_handle.h"
42 #include "testing/gmock/include/gmock/gmock.h" 44 #include "testing/gmock/include/gmock/gmock.h"
43 #include "testing/gtest/include/gtest/gtest.h" 45 #include "testing/gtest/include/gtest/gtest.h"
44 #include "third_party/skia/include/core/SkCanvas.h" 46 #include "third_party/skia/include/core/SkCanvas.h"
47 #include "third_party/skia/include/gpu/GrContext.h"
48 #include "third_party/skia/include/gpu/gl/GrGLInterface.h"
45 #include "third_party/skia/include/gpu/gl/GrGLTypes.h" 49 #include "third_party/skia/include/gpu/gl/GrGLTypes.h"
46 #include "wtf/PtrUtil.h" 50 #include "wtf/PtrUtil.h"
47 #include "wtf/RefPtr.h" 51 #include "wtf/RefPtr.h"
48 #include <memory> 52 #include <memory>
49 53
50 using testing::AnyNumber; 54 using testing::AnyNumber;
51 using testing::AtLeast; 55 using testing::AtLeast;
52 using testing::InSequence; 56 using testing::InSequence;
53 using testing::Return; 57 using testing::Return;
54 using testing::Test; 58 using testing::Test;
55 using testing::_; 59 using testing::_;
56 60
57 namespace blink { 61 namespace blink {
58 62
59 namespace { 63 namespace {
60 64
65 class FakeWebGraphicsContext3DProvider : public WebGraphicsContext3DProvider {
66 public:
67 FakeWebGraphicsContext3DProvider(gpu::gles2::GLES2Interface* gl)
68 : m_gl(gl)
69 {
70 RefPtr<const GrGLInterface> glInterface = adoptRef(GrGLCreateNullInterfa ce());
71 m_grContext = adoptRef(GrContext::Create(kOpenGL_GrBackend, reinterpret_ cast<GrBackendContext>(glInterface.get())));
72 }
73
74 GrContext* grContext() override
75 {
76 return m_grContext.get();
77 }
78
79 gpu::Capabilities getCapabilities()
80 {
81 return gpu::Capabilities();
82 }
83
84 gpu::gles2::GLES2Interface* contextGL() override
85 {
86 return m_gl;
87 }
88
89 bool bindToCurrentThread() override { return false; }
90
91 void setLostContextCallback(WebClosure) override {}
92 void setErrorMessageCallback(WebFunction<void(const char*, int32_t id)>) {}
93
94 private:
95 gpu::gles2::GLES2Interface* m_gl;
96 RefPtr<GrContext> m_grContext;
97 };
98
61 class Canvas2DLayerBridgePtr { 99 class Canvas2DLayerBridgePtr {
62 public: 100 public:
63 Canvas2DLayerBridgePtr() { } 101 Canvas2DLayerBridgePtr() { }
64 Canvas2DLayerBridgePtr(PassRefPtr<Canvas2DLayerBridge> layerBridge) 102 Canvas2DLayerBridgePtr(PassRefPtr<Canvas2DLayerBridge> layerBridge)
65 : m_layerBridge(layerBridge) { } 103 : m_layerBridge(layerBridge) { }
66 104
67 ~Canvas2DLayerBridgePtr() 105 ~Canvas2DLayerBridgePtr()
68 { 106 {
69 clear(); 107 clear();
70 } 108 }
(...skipping 984 matching lines...) Expand 10 before | Expand all | Expand 10 after
1055 // Test prepareMailbox while background rendering 1093 // Test prepareMailbox while background rendering
1056 WebExternalTextureMailbox mailbox; 1094 WebExternalTextureMailbox mailbox;
1057 EXPECT_FALSE(bridge->prepareMailbox(&mailbox, 0)); 1095 EXPECT_FALSE(bridge->prepareMailbox(&mailbox, 0));
1058 EXPECT_TRUE(bridge->checkSurfaceValid()); 1096 EXPECT_TRUE(bridge->checkSurfaceValid());
1059 1097
1060 // Tear down the bridge on the thread so that 'bridge' can go out of scope 1098 // Tear down the bridge on the thread so that 'bridge' can go out of scope
1061 // without crashing due to thread checks 1099 // without crashing due to thread checks
1062 postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge); 1100 postAndWaitDestroyBridgeTask(BLINK_FROM_HERE, testThread.get(), &bridge);
1063 } 1101 }
1064 1102
1103
1065 } // namespace blink 1104 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698