# zx_vmo_write ## NAME vmo_write - write bytes to the VMO ## SYNOPSIS ``` #include zx_status_t zx_vmo_write(zx_handle_t handle, const void* buffer, uint64_t offset, size_t buffer_size); ``` ## DESCRIPTION `zx_vmo_write()` attempts to write exactly *buffer_size* bytes to a VMO at *offset*. *buffer* pointer to a user buffer to write bytes from. *buffer_size* number of bytes to attempt to write. ## RIGHTS *handle* must be of type **ZX_OBJ_TYPE_VMO** and have **ZX_RIGHT_WRITE**. ## RETURN VALUE `zx_vmo_write()` returns **ZX_OK** on success, and exactly *buffer_size* bytes will have been written from *buffer*. In the event of failure, a negative error value is returned, and the number of bytes written from *buffer* is undefined. ## ERRORS **ZX_ERR_BAD_HANDLE** *handle* is not a valid handle. **ZX_ERR_WRONG_TYPE** *handle* is not a VMO handle. **ZX_ERR_ACCESS_DENIED** *handle* does not have the **ZX_RIGHT_WRITE** right. **ZX_ERR_INVALID_ARGS** *buffer* is an invalid pointer or NULL. **ZX_ERR_NO_MEMORY** Failure to allocate system memory to complete write. **ZX_ERR_OUT_OF_RANGE** *offset* starts at or beyond the end of the VMO, or VMO is shorter than *buffer_size*. **ZX_ERR_BAD_STATE** VMO has been marked uncached and is not directly writable. ## SEE ALSO - [`zx_vmo_clone()`] - [`zx_vmo_create()`] - [`zx_vmo_get_size()`] - [`zx_vmo_op_range()`] - [`zx_vmo_read()`] - [`zx_vmo_set_cache_policy()`] - [`zx_vmo_set_size()`] [`zx_vmo_clone()`]: vmo_clone.md [`zx_vmo_create()`]: vmo_create.md [`zx_vmo_get_size()`]: vmo_get_size.md [`zx_vmo_op_range()`]: vmo_op_range.md [`zx_vmo_read()`]: vmo_read.md [`zx_vmo_set_cache_policy()`]: vmo_set_cache_policy.md [`zx_vmo_set_size()`]: vmo_set_size.md