OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_CALAYER_MAC_H_ | 5 #ifndef CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_CALAYER_MAC_H_ |
6 #define CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_CALAYER_MAC_H_ | 6 #define CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_CALAYER_MAC_H_ |
7 | 7 |
8 #include "base/mac/scoped_nsobject.h" | 8 #include "base/mac/scoped_nsobject.h" |
9 #include "content/common/gpu/image_transport_surface_fbo_mac.h" | 9 #include "content/common/gpu/image_transport_surface_fbo_mac.h" |
10 #include "ui/base/cocoa/remote_layer_api.h" | 10 #include "ui/base/cocoa/remote_layer_api.h" |
(...skipping 13 matching lines...) Expand all Loading... |
24 | 24 |
25 // ImageTransportSurfaceFBO::StorageProvider implementation: | 25 // ImageTransportSurfaceFBO::StorageProvider implementation: |
26 virtual gfx::Size GetRoundedSize(gfx::Size size) override; | 26 virtual gfx::Size GetRoundedSize(gfx::Size size) override; |
27 virtual bool AllocateColorBufferStorage( | 27 virtual bool AllocateColorBufferStorage( |
28 CGLContextObj context, GLuint texture, | 28 CGLContextObj context, GLuint texture, |
29 gfx::Size pixel_size, float scale_factor) override; | 29 gfx::Size pixel_size, float scale_factor) override; |
30 virtual void FreeColorBufferStorage() override; | 30 virtual void FreeColorBufferStorage() override; |
31 virtual void SwapBuffers(const gfx::Size& size, float scale_factor) override; | 31 virtual void SwapBuffers(const gfx::Size& size, float scale_factor) override; |
32 virtual void WillWriteToBackbuffer() override; | 32 virtual void WillWriteToBackbuffer() override; |
33 virtual void DiscardBackbuffer() override; | 33 virtual void DiscardBackbuffer() override; |
34 virtual void SwapBuffersAckedByBrowser() override; | 34 virtual void SwapBuffersAckedByBrowser(bool disable_throttling) override; |
35 | 35 |
36 // Interface to ImageTransportLayer: | 36 // Interface to ImageTransportLayer: |
37 CGLContextObj LayerShareGroupContext(); | 37 CGLContextObj LayerShareGroupContext(); |
38 bool LayerCanDraw(); | 38 bool LayerCanDraw(); |
39 void LayerDoDraw(); | 39 void LayerDoDraw(); |
40 void LayerResetStorageProvider(); | 40 void LayerResetStorageProvider(); |
41 | 41 |
42 private: | 42 private: |
43 void DrawWithVsyncDisabled(); | 43 void DrawImmediatelyAndUnblockBrowser(); |
44 void SendPendingSwapToBrowserAfterFrameDrawn(); | 44 |
| 45 // The browser will be blocked while there is a frame that was sent to it but |
| 46 // hasn't drawn yet. This call will un-block the browser. |
| 47 void UnblockBrowserIfNeeded(); |
45 | 48 |
46 ImageTransportSurfaceFBO* transport_surface_; | 49 ImageTransportSurfaceFBO* transport_surface_; |
47 | 50 |
48 // Used to determine if we should use setNeedsDisplay or setAsynchronous to | 51 // Used to determine if we should use setNeedsDisplay or setAsynchronous to |
49 // animate. | 52 // animate. |
50 const bool gpu_vsync_disabled_; | 53 const bool gpu_vsync_disabled_; |
51 | 54 |
| 55 // Used also to determine if we should wait for CoreAnimation to call our |
| 56 // drawInCGLContext, or if we should force it with displayIfNeeded. |
| 57 bool throttling_disabled_; |
| 58 |
52 // Set when a new swap occurs, and un-set when |layer_| draws that frame. | 59 // Set when a new swap occurs, and un-set when |layer_| draws that frame. |
53 bool has_pending_draw_; | 60 bool has_pending_draw_; |
54 | 61 |
55 // A counter that is incremented whenever LayerCanDraw returns false. If this | 62 // A counter that is incremented whenever LayerCanDraw returns false. If this |
56 // reaches a threshold, then |layer_| is switched to synchronous drawing to | 63 // reaches a threshold, then |layer_| is switched to synchronous drawing to |
57 // save CPU work. | 64 // save CPU work. |
58 uint32 can_draw_returned_false_count_; | 65 uint32 can_draw_returned_false_count_; |
59 | 66 |
60 // The texture with the pixels to draw, and the share group it is allocated | 67 // The texture with the pixels to draw, and the share group it is allocated |
61 // in. | 68 // in. |
62 base::ScopedTypeRef<CGLContextObj> share_group_context_; | 69 base::ScopedTypeRef<CGLContextObj> share_group_context_; |
63 GLuint fbo_texture_; | 70 GLuint fbo_texture_; |
64 gfx::Size fbo_pixel_size_; | 71 gfx::Size fbo_pixel_size_; |
65 float fbo_scale_factor_; | 72 float fbo_scale_factor_; |
66 | 73 |
67 // The CALayer that the current frame is being drawn into. | 74 // The CALayer that the current frame is being drawn into. |
68 base::scoped_nsobject<CAContext> context_; | 75 base::scoped_nsobject<CAContext> context_; |
69 base::scoped_nsobject<ImageTransportLayer> layer_; | 76 base::scoped_nsobject<ImageTransportLayer> layer_; |
70 | 77 |
71 base::WeakPtrFactory<CALayerStorageProvider> weak_factory_; | 78 // Weak factory against which a timeout task for forcing a draw is created. |
| 79 base::WeakPtrFactory<CALayerStorageProvider> pending_draw_weak_factory_; |
| 80 |
72 DISALLOW_COPY_AND_ASSIGN(CALayerStorageProvider); | 81 DISALLOW_COPY_AND_ASSIGN(CALayerStorageProvider); |
73 }; | 82 }; |
74 | 83 |
75 } // namespace content | 84 } // namespace content |
76 | 85 |
77 #endif // CONTENT_COMMON_GPU_IMAGE_TRANSPORT_CALAYER_MAC_H_ | 86 #endif // CONTENT_COMMON_GPU_IMAGE_TRANSPORT_CALAYER_MAC_H_ |
OLD | NEW |