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

Side by Side Diff: third_party/WebKit/Source/modules/webgl/WebGLRenderingContextBase.cpp

Issue 1914233006: Implement offscreenCanvas.getContext('webgl') on a worker thread (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address kbr@'s comments, and limit maxGLActiveContexts=4 per worker thread Created 4 years, 7 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) 2009 Apple Inc. All rights reserved. 2 * Copyright (C) 2009 Apple 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
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
59 #include "modules/webgl/OESTextureHalfFloatLinear.h" 59 #include "modules/webgl/OESTextureHalfFloatLinear.h"
60 #include "modules/webgl/OESVertexArrayObject.h" 60 #include "modules/webgl/OESVertexArrayObject.h"
61 #include "modules/webgl/WebGLActiveInfo.h" 61 #include "modules/webgl/WebGLActiveInfo.h"
62 #include "modules/webgl/WebGLBuffer.h" 62 #include "modules/webgl/WebGLBuffer.h"
63 #include "modules/webgl/WebGLCompressedTextureASTC.h" 63 #include "modules/webgl/WebGLCompressedTextureASTC.h"
64 #include "modules/webgl/WebGLCompressedTextureATC.h" 64 #include "modules/webgl/WebGLCompressedTextureATC.h"
65 #include "modules/webgl/WebGLCompressedTextureETC1.h" 65 #include "modules/webgl/WebGLCompressedTextureETC1.h"
66 #include "modules/webgl/WebGLCompressedTexturePVRTC.h" 66 #include "modules/webgl/WebGLCompressedTexturePVRTC.h"
67 #include "modules/webgl/WebGLCompressedTextureS3TC.h" 67 #include "modules/webgl/WebGLCompressedTextureS3TC.h"
68 #include "modules/webgl/WebGLContextAttributeHelpers.h" 68 #include "modules/webgl/WebGLContextAttributeHelpers.h"
69 #include "modules/webgl/WebGLContextAttributes.h"
70 #include "modules/webgl/WebGLContextEvent.h" 69 #include "modules/webgl/WebGLContextEvent.h"
71 #include "modules/webgl/WebGLContextGroup.h" 70 #include "modules/webgl/WebGLContextGroup.h"
72 #include "modules/webgl/WebGLDebugRendererInfo.h" 71 #include "modules/webgl/WebGLDebugRendererInfo.h"
73 #include "modules/webgl/WebGLDebugShaders.h" 72 #include "modules/webgl/WebGLDebugShaders.h"
74 #include "modules/webgl/WebGLDepthTexture.h" 73 #include "modules/webgl/WebGLDepthTexture.h"
75 #include "modules/webgl/WebGLDrawBuffers.h" 74 #include "modules/webgl/WebGLDrawBuffers.h"
76 #include "modules/webgl/WebGLFramebuffer.h" 75 #include "modules/webgl/WebGLFramebuffer.h"
77 #include "modules/webgl/WebGLLoseContext.h" 76 #include "modules/webgl/WebGLLoseContext.h"
78 #include "modules/webgl/WebGLProgram.h" 77 #include "modules/webgl/WebGLProgram.h"
79 #include "modules/webgl/WebGLRenderbuffer.h" 78 #include "modules/webgl/WebGLRenderbuffer.h"
80 #include "modules/webgl/WebGLShader.h" 79 #include "modules/webgl/WebGLShader.h"
81 #include "modules/webgl/WebGLShaderPrecisionFormat.h" 80 #include "modules/webgl/WebGLShaderPrecisionFormat.h"
82 #include "modules/webgl/WebGLTexture.h"
83 #include "modules/webgl/WebGLUniformLocation.h" 81 #include "modules/webgl/WebGLUniformLocation.h"
84 #include "modules/webgl/WebGLVertexArrayObject.h" 82 #include "modules/webgl/WebGLVertexArrayObject.h"
85 #include "modules/webgl/WebGLVertexArrayObjectOES.h" 83 #include "modules/webgl/WebGLVertexArrayObjectOES.h"
86 #include "platform/CheckedInt.h" 84 #include "platform/CheckedInt.h"
87 #include "platform/RuntimeEnabledFeatures.h" 85 #include "platform/RuntimeEnabledFeatures.h"
86 #include "platform/ThreadSafeFunctional.h"
87 #include "platform/WaitableEvent.h"
88 #include "platform/geometry/IntSize.h" 88 #include "platform/geometry/IntSize.h"
89 #include "platform/graphics/GraphicsContext.h" 89 #include "platform/graphics/GraphicsContext.h"
90 #include "platform/graphics/UnacceleratedImageBufferSurface.h" 90 #include "platform/graphics/UnacceleratedImageBufferSurface.h"
91 #include "platform/graphics/gpu/AcceleratedImageBufferSurface.h" 91 #include "platform/graphics/gpu/AcceleratedImageBufferSurface.h"
92 #include "platform/graphics/gpu/DrawingBuffer.h"
93 #include "public/platform/Platform.h" 92 #include "public/platform/Platform.h"
94 #include "public/platform/WebGraphicsContext3DProvider.h"
95 #include "public/platform/functional/WebFunction.h" 93 #include "public/platform/functional/WebFunction.h"
96 #include "wtf/Functional.h" 94 #include "wtf/Functional.h"
97 #include "wtf/PassOwnPtr.h" 95 #include "wtf/PassOwnPtr.h"
98 #include "wtf/text/StringBuilder.h" 96 #include "wtf/text/StringBuilder.h"
99 #include "wtf/text/StringUTF8Adaptor.h" 97 #include "wtf/text/StringUTF8Adaptor.h"
100 #include "wtf/typed_arrays/ArrayBufferContents.h" 98 #include "wtf/typed_arrays/ArrayBufferContents.h"
101 99
102 #include <memory> 100 #include <memory>
103 101
104 namespace blink { 102 namespace blink {
105 103
106 namespace { 104 namespace {
107 105
108 const double secondsBetweenRestoreAttempts = 1.0; 106 const double secondsBetweenRestoreAttempts = 1.0;
109 const int maxGLErrorsAllowedToConsole = 256; 107 const int maxGLErrorsAllowedToConsole = 256;
110 const unsigned maxGLActiveContexts = 16; 108 const unsigned maxGLActiveContexts = 16;
109 const unsigned maxGLActiveContextsOnWorker = 4;
111 110
112 using WebGLRenderingContextBaseSet = PersistentHeapHashSet<WeakMember<WebGLRende ringContextBase>>; 111 using WebGLRenderingContextBaseSet = PersistentHeapHashSet<WeakMember<WebGLRende ringContextBase>>;
113 WebGLRenderingContextBaseSet& activeContexts() 112 WebGLRenderingContextBaseSet& activeContexts()
114 { 113 {
115 DEFINE_STATIC_LOCAL(WebGLRenderingContextBaseSet, activeContexts, ()); 114 DEFINE_THREAD_SAFE_STATIC_LOCAL(ThreadSpecific<WebGLRenderingContextBaseSet> , activeContexts, new ThreadSpecific<WebGLRenderingContextBaseSet>());
116 return activeContexts; 115 if (!activeContexts.isSet())
116 activeContexts->registerAsStaticReference();
117 return *activeContexts;
117 } 118 }
118 119
119 using WebGLRenderingContextBaseMap = PersistentHeapHashMap<WeakMember<WebGLRende ringContextBase>, int>; 120 using WebGLRenderingContextBaseMap = PersistentHeapHashMap<WeakMember<WebGLRende ringContextBase>, int>;
120 WebGLRenderingContextBaseMap& forciblyEvictedContexts() 121 WebGLRenderingContextBaseMap& forciblyEvictedContexts()
121 { 122 {
122 DEFINE_STATIC_LOCAL(WebGLRenderingContextBaseMap, forciblyEvictedContexts, ( )); 123 DEFINE_THREAD_SAFE_STATIC_LOCAL(ThreadSpecific<WebGLRenderingContextBaseMap> , forciblyEvictedContexts, new ThreadSpecific<WebGLRenderingContextBaseMap>());
123 return forciblyEvictedContexts; 124 if (!forciblyEvictedContexts.isSet())
125 forciblyEvictedContexts->registerAsStaticReference();
126 return *forciblyEvictedContexts;
124 } 127 }
125 128
126 } // namespace 129 } // namespace
127 130
128 ScopedRGBEmulationColorMask::ScopedRGBEmulationColorMask(gpu::gles2::GLES2Interf ace* contextGL, GLboolean* colorMask, DrawingBuffer* drawingBuffer) 131 ScopedRGBEmulationColorMask::ScopedRGBEmulationColorMask(gpu::gles2::GLES2Interf ace* contextGL, GLboolean* colorMask, DrawingBuffer* drawingBuffer)
129 : m_contextGL(contextGL) 132 : m_contextGL(contextGL)
130 , m_requiresEmulation(drawingBuffer->requiresAlphaChannelToBePreserved()) 133 , m_requiresEmulation(drawingBuffer->requiresAlphaChannelToBePreserved())
131 { 134 {
132 if (m_requiresEmulation) { 135 if (m_requiresEmulation) {
133 memcpy(m_colorMask, colorMask, 4 * sizeof(GLboolean)); 136 memcpy(m_colorMask, colorMask, 4 * sizeof(GLboolean));
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
183 candidate = context; 186 candidate = context;
184 generation = forciblyEvictedContexts().get(context); 187 generation = forciblyEvictedContexts().get(context);
185 } 188 }
186 } 189 }
187 190
188 return candidate; 191 return candidate;
189 } 192 }
190 193
191 void WebGLRenderingContextBase::activateContext(WebGLRenderingContextBase* conte xt) 194 void WebGLRenderingContextBase::activateContext(WebGLRenderingContextBase* conte xt)
192 { 195 {
196 unsigned maxGLContexts;
sof 2016/05/07 07:21:42 Could you create a local method for this next to w
197 if (isMainThread())
198 maxGLContexts = maxGLActiveContexts;
199 else
200 maxGLContexts = maxGLActiveContextsOnWorker;
193 unsigned removedContexts = 0; 201 unsigned removedContexts = 0;
194 while (activeContexts().size() >= maxGLActiveContexts && removedContexts < m axGLActiveContexts) { 202 while (activeContexts().size() >= maxGLContexts && removedContexts < maxGLCo ntexts) {
195 forciblyLoseOldestContext("WARNING: Too many active WebGL contexts. Olde st context will be lost."); 203 forciblyLoseOldestContext("WARNING: Too many active WebGL contexts. Olde st context will be lost.");
196 removedContexts++; 204 removedContexts++;
197 } 205 }
198 206
199 ASSERT(!context->isContextLost()); 207 ASSERT(!context->isContextLost());
200 activeContexts().add(context); 208 activeContexts().add(context);
201 } 209 }
202 210
203 void WebGLRenderingContextBase::deactivateContext(WebGLRenderingContextBase* con text) 211 void WebGLRenderingContextBase::deactivateContext(WebGLRenderingContextBase* con text)
204 { 212 {
(...skipping 11 matching lines...) Expand all
216 forciblyEvictedContexts().remove(context); 224 forciblyEvictedContexts().remove(context);
217 } 225 }
218 226
219 void WebGLRenderingContextBase::willDestroyContext(WebGLRenderingContextBase* co ntext) 227 void WebGLRenderingContextBase::willDestroyContext(WebGLRenderingContextBase* co ntext)
220 { 228 {
221 // These two sets keep weak references to their contexts; 229 // These two sets keep weak references to their contexts;
222 // verify that the GC already removed the |context| entries. 230 // verify that the GC already removed the |context| entries.
223 ASSERT(!forciblyEvictedContexts().contains(context)); 231 ASSERT(!forciblyEvictedContexts().contains(context));
224 ASSERT(!activeContexts().contains(context)); 232 ASSERT(!activeContexts().contains(context));
225 233
234 unsigned maxGLContexts;
235 if (isMainThread())
236 maxGLContexts = maxGLActiveContexts;
237 else
238 maxGLContexts = maxGLActiveContextsOnWorker;
226 // Try to re-enable the oldest inactive contexts. 239 // Try to re-enable the oldest inactive contexts.
227 while (activeContexts().size() < maxGLActiveContexts && forciblyEvictedConte xts().size()) { 240 while (activeContexts().size() < maxGLContexts && forciblyEvictedContexts(). size()) {
228 WebGLRenderingContextBase* evictedContext = oldestEvictedContext(); 241 WebGLRenderingContextBase* evictedContext = oldestEvictedContext();
229 if (!evictedContext->m_restoreAllowed) { 242 if (!evictedContext->m_restoreAllowed) {
230 forciblyEvictedContexts().remove(evictedContext); 243 forciblyEvictedContexts().remove(evictedContext);
231 continue; 244 continue;
232 } 245 }
233 246
234 IntSize desiredSize = DrawingBuffer::adjustSize(evictedContext->clampedC anvasSize(), IntSize(), evictedContext->m_maxTextureSize); 247 IntSize desiredSize = DrawingBuffer::adjustSize(evictedContext->clampedC anvasSize(), IntSize(), evictedContext->m_maxTextureSize);
235 248
236 // If there's room in the pixel budget for this context, restore it. 249 // If there's room in the pixel budget for this context, restore it.
237 if (!desiredSize.isEmpty()) { 250 if (!desiredSize.isEmpty()) {
(...skipping 275 matching lines...) Expand 10 before | Expand all | Expand 10 after
513 formatWebGLStatusString("Sandboxed", info.sandboxed ? "yes" : "no", statusMe ssage); 526 formatWebGLStatusString("Sandboxed", info.sandboxed ? "yes" : "no", statusMe ssage);
514 formatWebGLStatusString("Optimus", info.optimus ? "yes" : "no", statusMessag e); 527 formatWebGLStatusString("Optimus", info.optimus ? "yes" : "no", statusMessag e);
515 formatWebGLStatusString("AMD switchable", info.amdSwitchable ? "yes" : "no", statusMessage); 528 formatWebGLStatusString("AMD switchable", info.amdSwitchable ? "yes" : "no", statusMessage);
516 formatWebGLStatusString("Reset notification strategy", String::format("0x%04 x", info.resetNotificationStrategy).utf8().data(), statusMessage); 529 formatWebGLStatusString("Reset notification strategy", String::format("0x%04 x", info.resetNotificationStrategy).utf8().data(), statusMessage);
517 formatWebGLStatusString("GPU process crash count", String::number(info.proce ssCrashCount).utf8().data(), statusMessage); 530 formatWebGLStatusString("GPU process crash count", String::number(info.proce ssCrashCount).utf8().data(), statusMessage);
518 formatWebGLStatusString("ErrorMessage", info.errorMessage.utf8().data(), sta tusMessage); 531 formatWebGLStatusString("ErrorMessage", info.errorMessage.utf8().data(), sta tusMessage);
519 statusMessage.append("."); 532 statusMessage.append(".");
520 return statusMessage; 533 return statusMessage;
521 } 534 }
522 535
523 static PassOwnPtr<WebGraphicsContext3DProvider> createWebGraphicsContext3DProvid erInternal(HTMLCanvasElement* canvas, ScriptState* scriptState, WebGLContextAttr ibutes attributes, unsigned webGLVersion) 536 void WebGLRenderingContextBase::createContextProviderOnMainThread(WebGLRendering ContextBase::ContextProviderCreationInfo* creationInfo, WaitableEvent* waitableE vent)
537 {
538 ASSERT(isMainThread());
539 Platform::GraphicsInfo glInfo = creationInfo->glInfo();
540 OwnPtr<WebGraphicsContext3DProvider> provider = adoptPtr(Platform::current() ->createOffscreenGraphicsContext3DProvider(
541 creationInfo->contextAttributes(), creationInfo->scriptState()->getExecu tionContext()->url(), 0, &glInfo, Platform::DoNotBindToCurrentThread));
542 creationInfo->setContextProvider(provider.release());
543 waitableEvent->signal();
544 }
545
546 PassOwnPtr<WebGraphicsContext3DProvider> WebGLRenderingContextBase::createContex tProviderInternal(HTMLCanvasElement* canvas, ScriptState* scriptState, WebGLCont extAttributes attributes, unsigned webGLVersion)
524 { 547 {
525 Platform::ContextAttributes contextAttributes = toPlatformContextAttributes( attributes, webGLVersion); 548 Platform::ContextAttributes contextAttributes = toPlatformContextAttributes( attributes, webGLVersion);
526 Platform::GraphicsInfo glInfo; 549 Platform::GraphicsInfo glInfo;
527 OwnPtr<WebGraphicsContext3DProvider> contextProvider; 550 OwnPtr<WebGraphicsContext3DProvider> contextProvider;
528 if (canvas) { 551 if (canvas) {
529 contextProvider = adoptPtr(Platform::current()->createOffscreenGraphicsC ontext3DProvider( 552 contextProvider = adoptPtr(Platform::current()->createOffscreenGraphicsC ontext3DProvider(
530 contextAttributes, canvas->document().topDocument().url(), 0, &glInf o)); 553 contextAttributes, canvas->document().topDocument().url(), 0, &glInf o, Platform::BindToCurrentThread));
531 } else { 554 } else {
532 contextProvider = adoptPtr(Platform::current()->createOffscreenGraphicsC ontext3DProvider( 555 if (isMainThread()) {
533 contextAttributes, scriptState->getExecutionContext()->url(), 0, &gl Info)); 556 contextProvider = adoptPtr(Platform::current()->createOffscreenGraph icsContext3DProvider(
557 contextAttributes, scriptState->getExecutionContext()->url(), 0, &glInfo, Platform::BindToCurrentThread));
558 } else {
559 WaitableEvent waitableEvent;
sof 2016/05/07 07:21:42 Could you abstract this out as createContextProvid
xidachen 2016/05/07 17:07:48 Yes, it is definitely a future work to make this a
560 WebTaskRunner* taskRunner = Platform::current()->mainThread()->getWe bTaskRunner();
561 OwnPtr<WebGLRenderingContextBase::ContextProviderCreationInfo> creat ionInfo = adoptPtr(new WebGLRenderingContextBase::ContextProviderCreationInfo(co ntextAttributes, glInfo, scriptState));
562 taskRunner->postTask(BLINK_FROM_HERE, threadSafeBind(&createContextP roviderOnMainThread, AllowCrossThreadAccess(creationInfo.get()), AllowCrossThrea dAccess(&waitableEvent)));
563 waitableEvent.wait();
564 contextProvider = creationInfo->releaseContextProvider();
565 if (!contextProvider->BindToCurrentThread())
566 return nullptr;
567 }
534 } 568 }
535 if (!contextProvider || shouldFailContextCreationForTesting) { 569 if (!contextProvider || shouldFailContextCreationForTesting) {
536 shouldFailContextCreationForTesting = false; 570 shouldFailContextCreationForTesting = false;
537 if (canvas) 571 if (canvas)
538 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webg lcontextcreationerror, false, true, extractWebGLContextCreationError(glInfo))); 572 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webg lcontextcreationerror, false, true, extractWebGLContextCreationError(glInfo)));
539 return nullptr; 573 return nullptr;
540 } 574 }
541 gpu::gles2::GLES2Interface* gl = contextProvider->contextGL(); 575 gpu::gles2::GLES2Interface* gl = contextProvider->contextGL();
542 if (!String(gl->GetString(GL_EXTENSIONS)).contains("GL_OES_packed_depth_sten cil")) { 576 if (!String(gl->GetString(GL_EXTENSIONS)).contains("GL_OES_packed_depth_sten cil")) {
543 if (canvas) 577 if (canvas)
544 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webg lcontextcreationerror, false, true, "OES_packed_depth_stencil support is require d.")); 578 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webg lcontextcreationerror, false, true, "OES_packed_depth_stencil support is require d."));
545 return nullptr; 579 return nullptr;
546 } 580 }
547
548 return contextProvider.release(); 581 return contextProvider.release();
549 } 582 }
550 583
551 PassOwnPtr<WebGraphicsContext3DProvider> WebGLRenderingContextBase::createWebGra phicsContext3DProvider(HTMLCanvasElement* canvas, WebGLContextAttributes attribu tes, unsigned webGLVersion) 584 PassOwnPtr<WebGraphicsContext3DProvider> WebGLRenderingContextBase::createWebGra phicsContext3DProvider(HTMLCanvasElement* canvas, WebGLContextAttributes attribu tes, unsigned webGLVersion)
552 { 585 {
553 Document& document = canvas->document(); 586 Document& document = canvas->document();
554 LocalFrame* frame = document.frame(); 587 LocalFrame* frame = document.frame();
555 if (!frame) { 588 if (!frame) {
556 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webglcon textcreationerror, false, true, "Web page was not allowed to create a WebGL cont ext.")); 589 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webglcon textcreationerror, false, true, "Web page was not allowed to create a WebGL cont ext."));
557 return nullptr; 590 return nullptr;
558 } 591 }
559 Settings* settings = frame->settings(); 592 Settings* settings = frame->settings();
560 593
561 // The FrameLoaderClient might block creation of a new WebGL context despite the page settings; in 594 // The FrameLoaderClient might block creation of a new WebGL context despite the page settings; in
562 // particular, if WebGL contexts were lost one or more times via the GL_ARB_ robustness extension. 595 // particular, if WebGL contexts were lost one or more times via the GL_ARB_ robustness extension.
563 if (!frame->loader().client()->allowWebGL(settings && settings->webGLEnabled ())) { 596 if (!frame->loader().client()->allowWebGL(settings && settings->webGLEnabled ())) {
564 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webglcon textcreationerror, false, true, "Web page was not allowed to create a WebGL cont ext.")); 597 canvas->dispatchEvent(WebGLContextEvent::create(EventTypeNames::webglcon textcreationerror, false, true, "Web page was not allowed to create a WebGL cont ext."));
565 return nullptr; 598 return nullptr;
566 } 599 }
567 600
568 return createWebGraphicsContext3DProviderInternal(canvas, nullptr, attribute s, webGLVersion); 601 return createContextProviderInternal(canvas, nullptr, attributes, webGLVersi on);
569 } 602 }
570 603
571 PassOwnPtr<WebGraphicsContext3DProvider> WebGLRenderingContextBase::createWebGra phicsContext3DProvider(ScriptState* scriptState, WebGLContextAttributes attribut es, unsigned webGLVersion) 604 PassOwnPtr<WebGraphicsContext3DProvider> WebGLRenderingContextBase::createWebGra phicsContext3DProvider(ScriptState* scriptState, WebGLContextAttributes attribut es, unsigned webGLVersion)
572 { 605 {
573 return createWebGraphicsContext3DProviderInternal(nullptr, scriptState, attr ibutes, webGLVersion); 606 return createContextProviderInternal(nullptr, scriptState, attributes, webGL Version);
574 } 607 }
575 608
576 void WebGLRenderingContextBase::forceNextWebGLContextCreationToFail() 609 void WebGLRenderingContextBase::forceNextWebGLContextCreationToFail()
577 { 610 {
578 shouldFailContextCreationForTesting = true; 611 shouldFailContextCreationForTesting = true;
579 } 612 }
580 613
581 namespace { 614 namespace {
582 615
583 // ES2 enums 616 // ES2 enums
(...skipping 493 matching lines...) Expand 10 before | Expand all | Expand 10 after
1077 tracker->loseExtension(true); 1110 tracker->loseExtension(true);
1078 } 1111 }
1079 m_extensions.clear(); 1112 m_extensions.clear();
1080 1113
1081 // Context must be removed from the group prior to the destruction of the 1114 // Context must be removed from the group prior to the destruction of the
1082 // GL context, otherwise shared objects may not be properly deleted. 1115 // GL context, otherwise shared objects may not be properly deleted.
1083 m_contextGroup->removeContext(this); 1116 m_contextGroup->removeContext(this);
1084 1117
1085 destroyContext(); 1118 destroyContext();
1086 1119
1120 if (activeContexts().contains(this))
1121 activeContexts().remove(this);
1122 if (forciblyEvictedContexts().contains(this))
1123 forciblyEvictedContexts().remove(this);
1124
1087 willDestroyContext(this); 1125 willDestroyContext(this);
1088 } 1126 }
1089 1127
1090 void WebGLRenderingContextBase::destroyContext() 1128 void WebGLRenderingContextBase::destroyContext()
1091 { 1129 {
1092 if (!drawingBuffer()) 1130 if (!drawingBuffer())
1093 return; 1131 return;
1094 1132
1095 m_extensionsUtil.clear(); 1133 m_extensionsUtil.clear();
1096 1134
(...skipping 4864 matching lines...) Expand 10 before | Expand all | Expand 10 after
5961 5999
5962 // If the context was lost due to RealLostContext, we need to destroy the ol d DrawingBuffer before creating new DrawingBuffer to ensure resource budget enou gh. 6000 // If the context was lost due to RealLostContext, we need to destroy the ol d DrawingBuffer before creating new DrawingBuffer to ensure resource budget enou gh.
5963 if (drawingBuffer()) { 6001 if (drawingBuffer()) {
5964 m_drawingBuffer->beginDestruction(); 6002 m_drawingBuffer->beginDestruction();
5965 m_drawingBuffer.clear(); 6003 m_drawingBuffer.clear();
5966 } 6004 }
5967 6005
5968 Platform::ContextAttributes attributes = toPlatformContextAttributes(m_reque stedAttributes, version()); 6006 Platform::ContextAttributes attributes = toPlatformContextAttributes(m_reque stedAttributes, version());
5969 Platform::GraphicsInfo glInfo; 6007 Platform::GraphicsInfo glInfo;
5970 OwnPtr<WebGraphicsContext3DProvider> contextProvider = adoptPtr(Platform::cu rrent()->createOffscreenGraphicsContext3DProvider( 6008 OwnPtr<WebGraphicsContext3DProvider> contextProvider = adoptPtr(Platform::cu rrent()->createOffscreenGraphicsContext3DProvider(
5971 attributes, canvas()->document().topDocument().url(), 0, &glInfo)); 6009 attributes, canvas()->document().topDocument().url(), 0, &glInfo, Platfo rm::BindToCurrentThread));
5972 RefPtr<DrawingBuffer> buffer; 6010 RefPtr<DrawingBuffer> buffer;
5973 if (contextProvider) { 6011 if (contextProvider) {
5974 // Construct a new drawing buffer with the new GL context. 6012 // Construct a new drawing buffer with the new GL context.
5975 buffer = createDrawingBuffer(contextProvider.release()); 6013 buffer = createDrawingBuffer(contextProvider.release());
5976 // If DrawingBuffer::create() fails to allocate a fbo, |drawingBuffer| i s set to null. 6014 // If DrawingBuffer::create() fails to allocate a fbo, |drawingBuffer| i s set to null.
5977 } 6015 }
5978 if (!buffer) { 6016 if (!buffer) {
5979 if (m_contextLostMode == RealLostContext) { 6017 if (m_contextLostMode == RealLostContext) {
5980 m_restoreTimer.startOneShot(secondsBetweenRestoreAttempts, BLINK_FRO M_HERE); 6018 m_restoreTimer.startOneShot(secondsBetweenRestoreAttempts, BLINK_FRO M_HERE);
5981 } else { 6019 } else {
(...skipping 324 matching lines...) Expand 10 before | Expand all | Expand 10 after
6306 contextGL()->PixelStorei(GL_UNPACK_ALIGNMENT, 1); 6344 contextGL()->PixelStorei(GL_UNPACK_ALIGNMENT, 1);
6307 } 6345 }
6308 6346
6309 void WebGLRenderingContextBase::restoreUnpackParameters() 6347 void WebGLRenderingContextBase::restoreUnpackParameters()
6310 { 6348 {
6311 if (m_unpackAlignment != 1) 6349 if (m_unpackAlignment != 1)
6312 contextGL()->PixelStorei(GL_UNPACK_ALIGNMENT, m_unpackAlignment); 6350 contextGL()->PixelStorei(GL_UNPACK_ALIGNMENT, m_unpackAlignment);
6313 } 6351 }
6314 6352
6315 } // namespace blink 6353 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698