blob: 12ae468594ac615cd53ba33400bcc7fe2521dfb2 [file] [log] [blame]
// Copyright 2019 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.
library zx;
@transport("Syscall")
protocol process {
/// Exits the currently running process.
/// Rights: None.
@noreturn
process_exit(struct {
retcode int64;
});
// TODO(fxbug.dev/32803): job with ZX_RIGHT_WRITE is also accepted.
/// Create a new process.
/// Rights: job must be of type ZX_OBJ_TYPE_JOB and have ZX_RIGHT_MANAGE_PROCESS.
/// Rights: Caller job policy must allow ZX_POL_NEW_PROCESS.
process_create(resource struct {
job handle:JOB;
name string;
options uint32;
}) -> (resource struct {
status status;
proc_handle handle:PROCESS;
vmar_handle handle:VMAR;
});
/// Start execution on a process.
/// Rights: handle must be of type ZX_OBJ_TYPE_PROCESS and have ZX_RIGHT_WRITE.
/// Rights: thread must be of type ZX_OBJ_TYPE_THREAD and have ZX_RIGHT_WRITE.
/// Rights: arg1 must have ZX_RIGHT_TRANSFER.
process_start(resource struct {
handle handle:PROCESS;
thread handle:THREAD;
entry vaddr;
stack vaddr;
@release
arg1 handle;
arg2 uintptr;
}) -> (struct {
status status;
});
/// Read from the given process's address space.
/// Rights: handle must be of type ZX_OBJ_TYPE_PROCESS and have ZX_RIGHT_READ and have ZX_RIGHT_WRITE.
process_read_memory(resource struct {
handle handle:PROCESS;
vaddr vaddr;
}) -> (struct {
status status;
buffer vector_void;
actual usize;
});
/// Write into the given process's address space.
/// Rights: handle must be of type ZX_OBJ_TYPE_PROCESS and have ZX_RIGHT_WRITE.
process_write_memory(resource struct {
handle handle:PROCESS;
vaddr vaddr;
buffer vector_void;
}) -> (struct {
status status;
actual usize;
});
};