blob: f8bb86107150acc83ced1632cdb94537adf2324d [file] [log] [blame] [view] [edit]
# zx_vmo_op_range
## NAME
vmo_op_range - perform an operation on a range of a VMO
## SYNOPSIS
```
#include <zircon/syscalls.h>
zx_status_t zx_vmo_op_range(zx_handle_t handle, uint32_t op,
uint64_t offset, uint64_t size,
void* buffer, size_t buffer_size);
```
## DESCRIPTION
**vmo_op_range()** performs cache and memory operations against pages held by the VMO.
*offset* byte offset specifying the starting location for *op* in the VMO's held memory.
*size* length, in bytes, to perform the operation on.
*op* the operation to perform:
*buffer* and *buffer_size* are currently unused.
**ZX_VMO_OP_COMMIT** - Commit *size* bytes worth of pages starting at byte *offset* for the VMO.
More information can be found in the [vm object documentation](../objects/vm_object.md).
Requires the *ZX_RIGHT_WRITE* right.
**ZX_VMO_OP_DECOMMIT** - Release a range of pages previously committed to the VMO from *offset* to *offset*+*size*.
Requires the *ZX_RIGHT_WRITE* right.
**ZX_VMO_OP_LOCK** - Presently unsupported.
**ZX_VMO_OP_UNLOCK** - Presently unsupported.
**ZX_VMO_OP_CACHE_SYNC** - Performs a cache sync operation.
Requires the *ZX_RIGHT_READ* right.
**ZX_VMO_OP_CACHE_INVALIDATE** - Performs a cache invalidation operation.
Requires the *ZX_RIGHT_WRITE* right.
**ZX_VMO_OP_CACHE_CLEAN** - Performs a cache clean operation.
Requires the *ZX_RIGHT_READ* right.
**ZX_VMO_OP_CACHE_CLEAN_INVALIDATE** - Performs cache clean and invalidate operations together.
Requires the *ZX_RIGHT_READ* right.
## RIGHTS
TODO(ZX-2399)
## RETURN VALUE
**vmo_op_range**() returns **ZX_OK** on success. In the event of failure, a negative error
value is returned.
## ERRORS
**ZX_ERR_BAD_HANDLE** *handle* is not a valid handle.
**ZX_ERR_OUT_OF_RANGE** An invalid memory range specified by *offset* and *size*.
**ZX_ERR_NO_MEMORY** Allocations to commit pages for *ZX_VMO_OP_COMMIT* failed.
**ZX_ERR_WRONG_TYPE** *handle* is not a VMO handle.
**ZX_ERR_ACCESS_DENIED** *handle* does not have sufficient rights to perform the operation.
**ZX_ERR_INVALID_ARGS** *out* is an invalid pointer, *op* is not a valid
operation, or *size* is zero and *op* is a cache operation.
**ZX_ERR_NOT_SUPPORTED** *op* was *ZX_VMO_OP_LOCK* or *ZX_VMO_OP_UNLOCK*, or
*op* was *ZX_VMO_OP_DECOMMIT* and the underlying VMO does not allow decommiting.
## SEE ALSO
[vmo_create](vmo_create.md),
[vmo_clone](vmo_clone.md),
[vmo_read](vmo_read.md),
[vmo_write](vmo_write.md),
[vmo_get_size](vmo_get_size.md),
[vmo_set_size](vmo_set_size.md),
[vmo_op_range](vmo_op_range.md).