GPUQueue: writeBuffer() method
        
        
          Limited availability
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is not Baseline because it does not work in some of the most widely-used browsers.
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
Note: This feature is available in Web Workers.
The writeBuffer() method of the
GPUQueue interface writes a provided data source into a given GPUBuffer.
This is a convenience function, which provides an alternative to setting buffer data via buffer mapping and buffer-to-buffer copies. It lets the user agent determine the most efficient way to copy the data over.
Syntax
writeBuffer(buffer, bufferOffset, data, dataOffset, size)
Parameters
- buffer
- 
A GPUBufferobject representing the buffer to write data to.
- bufferOffset
- 
A number representing the offset, in bytes, to start writing the data at inside the GPUBuffer.
- data
- 
An object representing the data source to write into the GPUBuffer. This can be anArrayBuffer,TypedArray, orDataView.
- dataOffsetOptional
- 
A number representing the offset to start writing the data from inside the data source. This value is a number of elements if datais aTypedArray, and a number of bytes if not. If omitted,dataOffsetdefaults to 0.
- sizeOptional
- 
A number representing the size of the content to write from datatobuffer. This value is a number of elements ifdatais aTypedArray, and a number of bytes if not. If omitted,sizewill be equal to the overall size ofdata, minusdataOffset.
Return value
None (Undefined).
Exceptions
- OperationError- DOMException
- 
The method throws an OperationErrorif the following criteria are not met:- The size of datais equal to or greater than 0.
- dataOffsetis equal to or smaller than the size of- data.
- The size of data(when converted to bytes, in the case ofTypedArrays) is a multiple of 4.
 
- The size of 
Validation
The following criteria must be met when calling writeBuffer(), otherwise a GPUValidationError is generated and the GPUQueue becomes invalid:
- bufferis available for use, i.e., not unavailable (- GPUBuffers are unavailable if they are currently mapped) or destroyed (with the- GPUBuffer.destroy()method).
- The buffer'sGPUBuffer.usageincludes theGPUBufferUsage.COPY_DSTflag.
- bufferOffset, when converted to bytes, is a multiple of 4.
- The size of data-dataOffset+bufferOffset, when converted to bytes, is equal to or less than thebuffer'sGPUBuffer.size.
Examples
In our basic render demo, we define some vertex data in a Float32Array that we'll use to draw a triangle:
const vertices = new Float32Array([
  0.0, 0.6, 0, 1, 1, 0, 0, 1, -0.5, -0.6, 0, 1, 0, 1, 0, 1, 0.5, -0.6, 0, 1, 0,
  0, 1, 1,
]);
To use this data in a render pipeline, we need to put it into a GPUBuffer. First we'll create the buffer:
const vertexBuffer = device.createBuffer({
  size: vertices.byteLength, // make it big enough to store vertices in
  usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST,
});
To get the data into the buffer we can use writeBuffer():
device.queue.writeBuffer(vertexBuffer, 0, vertices, 0, vertices.length);
Specifications
| Specification | 
|---|
| WebGPU> # dom-gpuqueue-writebuffer> | 
Browser compatibility
Loading…
See also
- The WebGPU API