| OLD | NEW |
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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 CCResourceProvider_h | 5 // Temporary forwarding header |
| 6 #define CCResourceProvider_h | 6 #include "cc/resource_provider.h" |
| 7 | |
| 8 #include "base/basictypes.h" | |
| 9 #include "CCGraphicsContext.h" | |
| 10 #include "GraphicsContext3D.h" | |
| 11 #include "IntSize.h" | |
| 12 #include "SkBitmap.h" | |
| 13 #include "SkCanvas.h" | |
| 14 #include "TextureCopier.h" | |
| 15 #include <wtf/Deque.h> | |
| 16 #include <wtf/HashMap.h> | |
| 17 #include <wtf/OwnPtr.h> | |
| 18 #include <wtf/PassOwnPtr.h> | |
| 19 #include <wtf/PassRefPtr.h> | |
| 20 #include <wtf/RefPtr.h> | |
| 21 #include <wtf/Vector.h> | |
| 22 | |
| 23 namespace WebKit { | |
| 24 class WebGraphicsContext3D; | |
| 25 } | |
| 26 | |
| 27 namespace cc { | |
| 28 | |
| 29 class IntRect; | |
| 30 class LayerTextureSubImage; | |
| 31 class TextureCopier; | |
| 32 class TextureUploader; | |
| 33 | |
| 34 // Thread-safety notes: this class is not thread-safe and can only be called | |
| 35 // from the thread it was created on (in practice, the compositor thread). | |
| 36 class CCResourceProvider { | |
| 37 public: | |
| 38 typedef unsigned ResourceId; | |
| 39 typedef Vector<ResourceId> ResourceIdArray; | |
| 40 typedef HashMap<ResourceId, ResourceId> ResourceIdMap; | |
| 41 enum TextureUsageHint { TextureUsageAny, TextureUsageFramebuffer }; | |
| 42 enum ResourceType { | |
| 43 GLTexture = 1, | |
| 44 Bitmap, | |
| 45 }; | |
| 46 struct Mailbox { | |
| 47 GC3Dbyte name[64]; | |
| 48 }; | |
| 49 struct TransferableResource { | |
| 50 unsigned id; | |
| 51 GC3Denum format; | |
| 52 IntSize size; | |
| 53 Mailbox mailbox; | |
| 54 }; | |
| 55 typedef Vector<TransferableResource> TransferableResourceArray; | |
| 56 struct TransferableResourceList { | |
| 57 TransferableResourceList(); | |
| 58 ~TransferableResourceList(); | |
| 59 | |
| 60 TransferableResourceArray resources; | |
| 61 unsigned syncPoint; | |
| 62 }; | |
| 63 | |
| 64 static PassOwnPtr<CCResourceProvider> create(CCGraphicsContext*); | |
| 65 | |
| 66 virtual ~CCResourceProvider(); | |
| 67 | |
| 68 WebKit::WebGraphicsContext3D* graphicsContext3D(); | |
| 69 TextureUploader* textureUploader() const { return m_textureUploader.get(); } | |
| 70 TextureCopier* textureCopier() const { return m_textureCopier.get(); } | |
| 71 int maxTextureSize() const { return m_maxTextureSize; } | |
| 72 unsigned numResources() const { return m_resources.size(); } | |
| 73 | |
| 74 // Checks whether a resource is in use by a consumer. | |
| 75 bool inUseByConsumer(ResourceId); | |
| 76 | |
| 77 | |
| 78 // Producer interface. | |
| 79 | |
| 80 void setDefaultResourceType(ResourceType type) { m_defaultResourceType = typ
e; } | |
| 81 ResourceType defaultResourceType() const { return m_defaultResourceType; } | |
| 82 ResourceType resourceType(ResourceId); | |
| 83 | |
| 84 // Creates a resource of the default resource type. | |
| 85 ResourceId createResource(int pool, const IntSize&, GC3Denum format, Texture
UsageHint); | |
| 86 | |
| 87 // You can also explicitly create a specific resource type. | |
| 88 ResourceId createGLTexture(int pool, const IntSize&, GC3Denum format, Textur
eUsageHint); | |
| 89 ResourceId createBitmap(int pool, const IntSize&); | |
| 90 // Wraps an external texture into a GL resource. | |
| 91 ResourceId createResourceFromExternalTexture(unsigned textureId); | |
| 92 | |
| 93 void deleteResource(ResourceId); | |
| 94 | |
| 95 // Deletes all resources owned by a given pool. | |
| 96 void deleteOwnedResources(int pool); | |
| 97 | |
| 98 // Upload data from image, copying sourceRect (in image) into destRect (in t
he resource). | |
| 99 void upload(ResourceId, const uint8_t* image, const IntRect& imageRect, cons
t IntRect& sourceRect, const IntSize& destOffset); | |
| 100 | |
| 101 // Flush all context operations, kicking uploads and ensuring ordering with | |
| 102 // respect to other contexts. | |
| 103 void flush(); | |
| 104 | |
| 105 // Only flush the command buffer if supported. | |
| 106 // Returns true if the shallow flush occurred, false otherwise. | |
| 107 bool shallowFlushIfSupported(); | |
| 108 | |
| 109 // Creates accounting for a child, and associate it with a pool. Resources | |
| 110 // transfered from that child will go to that pool. Returns a child ID. | |
| 111 int createChild(int pool); | |
| 112 | |
| 113 // Destroys accounting for the child, deleting all resources from that pool. | |
| 114 void destroyChild(int child); | |
| 115 | |
| 116 // Gets the child->parent resource ID map. | |
| 117 const ResourceIdMap& getChildToParentMap(int child) const; | |
| 118 | |
| 119 // Prepares resources to be transfered to the parent, moving them to | |
| 120 // mailboxes and serializing meta-data into TransferableResources. | |
| 121 // Resources are not removed from the CCResourceProvider, but are markes as | |
| 122 // "in use". | |
| 123 TransferableResourceList prepareSendToParent(const ResourceIdArray&); | |
| 124 | |
| 125 // Prepares resources to be transfered back to the child, moving them to | |
| 126 // mailboxes and serializing meta-data into TransferableResources. | |
| 127 // Resources are removed from the CCResourceProvider. Note: the resource IDs | |
| 128 // passed are in the parent namespace and will be translated to the child | |
| 129 // namespace when returned. | |
| 130 TransferableResourceList prepareSendToChild(int child, const ResourceIdArray
&); | |
| 131 | |
| 132 // Receives resources from a child, moving them from mailboxes. Resource IDs | |
| 133 // passed are in the child namespace, and will be translated to the parent | |
| 134 // namespace, added to the child->parent map. | |
| 135 // NOTE: if the syncPoint filed in TransferableResourceList is set, this | |
| 136 // will wait on it. | |
| 137 void receiveFromChild(int child, const TransferableResourceList&); | |
| 138 | |
| 139 // Receives resources from the parent, moving them from mailboxes. Resource
IDs | |
| 140 // passed are in the child namespace. | |
| 141 // NOTE: if the syncPoint filed in TransferableResourceList is set, this | |
| 142 // will wait on it. | |
| 143 void receiveFromParent(const TransferableResourceList&); | |
| 144 | |
| 145 // Only for testing | |
| 146 size_t mailboxCount() const { return m_mailboxes.size(); } | |
| 147 | |
| 148 // The following lock classes are part of the CCResourceProvider API and are | |
| 149 // needed to read and write the resource contents. The user must ensure | |
| 150 // that they only use GL locks on GL resources, etc, and this is enforced | |
| 151 // by assertions. | |
| 152 class ScopedReadLockGL { | |
| 153 public: | |
| 154 ScopedReadLockGL(CCResourceProvider*, CCResourceProvider::ResourceId); | |
| 155 ~ScopedReadLockGL(); | |
| 156 | |
| 157 unsigned textureId() const { return m_textureId; } | |
| 158 | |
| 159 private: | |
| 160 CCResourceProvider* m_resourceProvider; | |
| 161 CCResourceProvider::ResourceId m_resourceId; | |
| 162 unsigned m_textureId; | |
| 163 | |
| 164 DISALLOW_COPY_AND_ASSIGN(ScopedReadLockGL); | |
| 165 }; | |
| 166 | |
| 167 class ScopedWriteLockGL { | |
| 168 public: | |
| 169 ScopedWriteLockGL(CCResourceProvider*, CCResourceProvider::ResourceId); | |
| 170 ~ScopedWriteLockGL(); | |
| 171 | |
| 172 unsigned textureId() const { return m_textureId; } | |
| 173 | |
| 174 private: | |
| 175 CCResourceProvider* m_resourceProvider; | |
| 176 CCResourceProvider::ResourceId m_resourceId; | |
| 177 unsigned m_textureId; | |
| 178 | |
| 179 DISALLOW_COPY_AND_ASSIGN(ScopedWriteLockGL); | |
| 180 }; | |
| 181 | |
| 182 class ScopedReadLockSoftware { | |
| 183 public: | |
| 184 ScopedReadLockSoftware(CCResourceProvider*, CCResourceProvider::Resource
Id); | |
| 185 ~ScopedReadLockSoftware(); | |
| 186 | |
| 187 const SkBitmap* skBitmap() const { return &m_skBitmap; } | |
| 188 | |
| 189 private: | |
| 190 CCResourceProvider* m_resourceProvider; | |
| 191 CCResourceProvider::ResourceId m_resourceId; | |
| 192 SkBitmap m_skBitmap; | |
| 193 | |
| 194 DISALLOW_COPY_AND_ASSIGN(ScopedReadLockSoftware); | |
| 195 }; | |
| 196 | |
| 197 class ScopedWriteLockSoftware { | |
| 198 public: | |
| 199 ScopedWriteLockSoftware(CCResourceProvider*, CCResourceProvider::Resourc
eId); | |
| 200 ~ScopedWriteLockSoftware(); | |
| 201 | |
| 202 SkCanvas* skCanvas() { return m_skCanvas.get(); } | |
| 203 | |
| 204 private: | |
| 205 CCResourceProvider* m_resourceProvider; | |
| 206 CCResourceProvider::ResourceId m_resourceId; | |
| 207 SkBitmap m_skBitmap; | |
| 208 OwnPtr<SkCanvas> m_skCanvas; | |
| 209 | |
| 210 DISALLOW_COPY_AND_ASSIGN(ScopedWriteLockSoftware); | |
| 211 }; | |
| 212 | |
| 213 private: | |
| 214 struct Resource { | |
| 215 Resource(); | |
| 216 Resource(unsigned textureId, int pool, const IntSize& size, GC3Denum for
mat); | |
| 217 Resource(uint8_t* pixels, int pool, const IntSize& size, GC3Denum format
); | |
| 218 | |
| 219 unsigned glId; | |
| 220 uint8_t* pixels; | |
| 221 int pool; | |
| 222 int lockForReadCount; | |
| 223 bool lockedForWrite; | |
| 224 bool external; | |
| 225 bool exported; | |
| 226 IntSize size; | |
| 227 GC3Denum format; | |
| 228 ResourceType type; | |
| 229 }; | |
| 230 typedef HashMap<ResourceId, Resource> ResourceMap; | |
| 231 struct Child { | |
| 232 Child(); | |
| 233 ~Child(); | |
| 234 | |
| 235 int pool; | |
| 236 ResourceIdMap childToParentMap; | |
| 237 ResourceIdMap parentToChildMap; | |
| 238 }; | |
| 239 typedef HashMap<int, Child> ChildMap; | |
| 240 | |
| 241 explicit CCResourceProvider(CCGraphicsContext*); | |
| 242 bool initialize(); | |
| 243 | |
| 244 const Resource* lockForRead(ResourceId); | |
| 245 void unlockForRead(ResourceId); | |
| 246 const Resource* lockForWrite(ResourceId); | |
| 247 void unlockForWrite(ResourceId); | |
| 248 static void populateSkBitmapWithResource(SkBitmap*, const Resource*); | |
| 249 | |
| 250 bool transferResource(WebKit::WebGraphicsContext3D*, ResourceId, Transferabl
eResource*); | |
| 251 void trimMailboxDeque(); | |
| 252 | |
| 253 CCGraphicsContext* m_context; | |
| 254 ResourceId m_nextId; | |
| 255 ResourceMap m_resources; | |
| 256 int m_nextChild; | |
| 257 ChildMap m_children; | |
| 258 | |
| 259 Deque<Mailbox> m_mailboxes; | |
| 260 | |
| 261 ResourceType m_defaultResourceType; | |
| 262 bool m_useTextureStorageExt; | |
| 263 bool m_useTextureUsageHint; | |
| 264 bool m_useShallowFlush; | |
| 265 OwnPtr<LayerTextureSubImage> m_texSubImage; | |
| 266 OwnPtr<TextureUploader> m_textureUploader; | |
| 267 OwnPtr<AcceleratedTextureCopier> m_textureCopier; | |
| 268 int m_maxTextureSize; | |
| 269 | |
| 270 DISALLOW_COPY_AND_ASSIGN(CCResourceProvider); | |
| 271 }; | |
| 272 | |
| 273 } | |
| 274 | |
| 275 #endif | |
| OLD | NEW |