Common buffer operations for most v1 buffer interfaces used in Metal This implementation treats: Ignores STATIC and DYNAMIC bit in buffers Lack of WRITE_ONLY and DISCARDABLE buffer puts it in slowest path.
More...
|
| | MetalHardwareBufferCommon (size_t sizeBytes, Usage usage, bool useShadowBuffer, uint16 alignment, MetalDevice *device) |
| |
| virtual | ~MetalHardwareBufferCommon () |
| |
| void | _notifyDeviceStalled () |
| |
| void | _updateFromShadow (void) override |
| | Updates the real buffer from the shadow buffer, if required. More...
|
| |
| void | copyData (HardwareBuffer &srcBuffer, size_t srcOffset, size_t dstOffset, size_t length, bool discardWholeBuffer=false) override |
| | Copy data from another buffer into this one. More...
|
| |
| id< MTLBuffer > | getBufferName (size_t &outOffset) |
| | Returns the actual API buffer, but first sets mLastFrameUsed as we assume you're calling this function to use the buffer in the GPU. More...
|
| |
| void * | lockImpl (size_t offset, size_t length, LockOptions options) override |
| | Internal implementation of lock() More...
|
| |
| void | readData (size_t offset, size_t length, void *pDest) override |
| | Reads data from the buffer and places it in the memory pointed to by pDest. More...
|
| |
| void | unlockImpl () override |
| | Internal implementation of unlock() More...
|
| |
| void | writeData (size_t offset, size_t length, const void *pSource, bool discardWholeBuffer=false) override |
| | Writes data to the buffer from an area of system memory; note that you must ensure that your buffer is big enough. More...
|
| |
| void | writeDataImpl (size_t offset, size_t length, const void *pSource, bool discardWholeBuffer) |
| |
| | HardwareBuffer (Usage usage, bool systemMemory, bool useShadowBuffer) |
| | Constructor, to be called by HardwareBufferManager only. More...
|
| |
| virtual | ~HardwareBuffer () |
| |
| template<typename T > |
| T * | _getImpl () |
| |
| void | copyData (HardwareBuffer &srcBuffer) |
| | Copy all data from another buffer into this one. More...
|
| |
| size_t | getSizeInBytes (void) const |
| | Returns the size of this buffer in bytes. More...
|
| |
| Usage | getUsage (void) const |
| | Returns the Usage flags with which this buffer was created. More...
|
| |
| bool | hasShadowBuffer (void) const |
| | Returns whether this buffer has a system memory shadow for quicker reading. More...
|
| |
| bool | isLocked (void) const |
| | Returns whether or not this buffer is currently locked. More...
|
| |
| bool | isSystemMemory (void) const |
| | Returns whether this buffer is held in system memory. More...
|
| |
| void * | lock (LockOptions options) |
| | This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More...
|
| |
| virtual void * | lock (size_t offset, size_t length, LockOptions options) |
| | Lock the buffer for (potentially) reading / writing. More...
|
| |
| void | suppressHardwareUpdate (bool suppress) |
| | Pass true to suppress hardware upload of shadow buffer changes. More...
|
| |
| void | unlock (void) |
| | Releases the lock on this buffer. More...
|
| |
Common buffer operations for most v1 buffer interfaces used in Metal This implementation treats: Ignores STATIC and DYNAMIC bit in buffers Lack of WRITE_ONLY and DISCARDABLE buffer puts it in slowest path.
Puts WRITE_ONLY in device memory and uses staging buffers to avoid blocking. Use WRITE_ONLY when possible.