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

Unified Diff: cc/resources/graphic_buffer.h

Issue 13135004: android_webview: changes to support Android GraphicBuffers (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Incorporate code reviews Created 7 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/cc.gyp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/resources/graphic_buffer.h
diff --git a/cc/resources/graphic_buffer.h b/cc/resources/graphic_buffer.h
new file mode 100644
index 0000000000000000000000000000000000000000..72887461dc891764742eca5a20d15bef9f04baea
--- /dev/null
+++ b/cc/resources/graphic_buffer.h
@@ -0,0 +1,58 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CC_RESOURCES_GRAPHIC_BUFFER_H_
+#define CC_RESOURCES_GRAPHIC_BUFFER_H_
+
+#include "base/basictypes.h"
+#include "base/callback.h"
+#include "base/memory/scoped_ptr.h"
+
+namespace gfx {
+class Size;
+}
+
+namespace cc {
+
+// Interface for creating and accessing a zero-copy buffer such as GraphicBuffer
+// of Android framework.
+//
+// THREADING CONSIDERATIONS:
+//
+// It is legal for several different threads to lock a buffer from
+// read access, none of the threads are blocked.
+// However, locking a buffer simultaneously for write or read/write is
+// undefined, but:
+// - shall not result in termination of the process
+// - shall not block the caller
+// It is acceptable to return an error or to leave the buffer's content
+// into an indeterminate state.
+class GraphicBuffer {
+ public:
+ // The factory is set by the ContentRendererClient::GetGraphicBufferFactory()
+ // method.
+ typedef base::Callback<scoped_ptr<cc::GraphicBuffer>(const gfx::Size&)>
jamesr 2013/04/03 03:14:38 gfx::Size should be passed by value, not const ref
kaanb 2013/04/03 04:39:53 Done.
+ Factory;
jamesr 2013/04/03 03:14:38 call this Create, not Factory
kaanb 2013/04/03 04:39:53 Done.
+ virtual ~GraphicBuffer() {}
+
+ // Locks the buffer for the usage specified so the client
jamesr 2013/04/03 03:14:38 if these are analogous to map/unmap in other parts
kaanb 2013/04/03 04:39:53 Done.
+ // can read or write the bitmap data in |*vaddr| subsequently.
+ // This call may block, for instance if the h/w needs
+ // to finish rendering or if CPU caches need to be synchronized.
+ // Returns true on success, false on failure.
jamesr 2013/04/03 03:14:38 returning a bool on this API is useless unless the
kaanb 2013/04/03 04:39:53 Done.
+ virtual bool LockForRead(void** vaddr) = 0;
jamesr 2013/04/03 03:14:38 LockForRead() isn't used at all in the big patch a
kaanb 2013/04/03 04:39:53 Done.
kaanb 2013/04/03 04:39:53 Done.
+ virtual bool LockForWrite(void** vaddr) = 0;
+ // Unlocks the buffer. Returns true on success, false otherwise.
jamesr 2013/04/03 03:14:38 leave a blank line between functions. how could u
kaanb 2013/04/03 04:39:53 Done.
+ virtual bool Unlock() = 0;
+ // Returns the size of the buffer
jamesr 2013/04/03 03:14:38 do you need a size getter? whoever allocates this
kaanb 2013/04/03 04:39:53 Done.
+ virtual gfx::Size GetSize() = 0;
+ // Returns the native pointer for the graphic buffer.
+ virtual void* GetNativeBuffer() = 0;
+ // Returns the stride for the graphic buffer.
+ virtual uint32 GetStride() = 0;
+};
+
+} // namespace cc
+
+#endif // CC_RESOURCES_GRAPHIC_BUFFER_H_
« no previous file with comments | « cc/cc.gyp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698