blob: 2c4c09be750de853e6ec3e1ca261f6b6d816f715 [file] [log] [blame] [view]
<!--
Copyright 2023 The Fuchsia Authors. All rights reserved.
Use of this source code is governed by a BSD-style license that can be
found in the LICENSE file.
DO NOT EDIT. Generated from FIDL library zx by zither, a Fuchsia platform tool.
See //docs/reference/syscalls/README.md#documentation-generation for
regeneration instructions.
-->
# zx_vmo_write
## Summary
Write bytes to the VMO.
## Declaration
```c
#include <zircon/syscalls.h>
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 [virtual memory
object](/docs/reference/kernel_objects/vm_object.md) (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
or [*buffer*, *buffer* + *buffer_size*) is
not readable.
`ZX_ERR_NOT_FOUND` *buffer* address does not map to address in address space.
`ZX_ERR_NO_MEMORY` Failure to allocate system memory to complete write.
`ZX_ERR_OUT_OF_RANGE` *offset* + *buffer_size* is greater than the size of
the VMO.
`ZX_ERR_BAD_STATE` VMO has been marked uncached and is not directly writable.
## See also
- [`zx_vmo_create()`]
- [`zx_vmo_create_child()`]
- [`zx_vmo_get_size()`]
- [`zx_vmo_op_range()`]
- [`zx_vmo_read()`]
- [`zx_vmo_set_cache_policy()`]
- [`zx_vmo_set_size()`]
[`zx_vmo_create()`]: vmo_create.md
[`zx_vmo_create_child()`]: vmo_create_child.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