| // Copyright 2016 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. |
| |
| #ifndef ZIRCON_PROCESSARGS_H_ |
| #define ZIRCON_PROCESSARGS_H_ |
| |
| #include <stdint.h> |
| #include <zircon/availability.h> |
| #include <zircon/compiler.h> |
| #include <zircon/types.h> |
| |
| __BEGIN_CDECLS |
| |
| // This is a protocol for passing state to a new process |
| // via a message in a channel. |
| |
| #define ZX_PROCARGS_PROTOCOL ((uint32_t)0x4150585du) // MXPA |
| #define ZX_PROCARGS_VERSION ((uint32_t)0x0001000u) |
| |
| typedef struct zx_proc_args zx_proc_args_t; |
| |
| struct zx_proc_args { |
| // Protocol and version identifiers to allow for |
| // different process start message protocols and |
| // versioning of the same. |
| uint32_t protocol; |
| uint32_t version; |
| |
| // Offset from start of message to handle info |
| // array, which contains one uint32_t per handle |
| // passed along with the message. |
| uint32_t handle_info_off; |
| |
| // Offset from start of message to arguments and |
| // count of arguments. Arguments are provided as |
| // a set of null-terminated utf-8 strings, one |
| // after the other. |
| uint32_t args_off; |
| uint32_t args_num; |
| |
| // Offset from start of message to environment strings and count of |
| // them. Environment entries are provided as a set of null-terminated |
| // UTF-8 strings, one after the other. Canonically each string has |
| // the form "NAME=VALUE", but nothing enforces this. |
| uint32_t environ_off; |
| uint32_t environ_num; |
| |
| // Offset from start of message to name strings and count of them. |
| // These strings are packed similar to the argument strings, |
| // but are referenced by PA_NS_* handle table entries and used |
| // to set up namespaces. |
| // |
| // Specifically: In a handle table entry with PA_HND_TYPE(info) |
| // of PA_NS_*, PA_HND_ARG(info) is an index into this name table. |
| uint32_t names_off; |
| uint32_t names_num; |
| }; |
| |
| // Handle Info entries associate a type and optional |
| // argument with each handle included in the process |
| // arguments message. |
| #define PA_HND(type, arg) (((type) & 0xFF) | (((arg) & 0xFFFF) << 16)) |
| #define PA_HND_TYPE(n) ((n) & 0xFF) |
| #define PA_HND_ARG(n) (((n) >> 16) & 0xFFFF) |
| |
| // --- Core Runtime Handles --- |
| // Used by libc init (or equivalent) and dynamic loader |
| |
| // Handle to our own process. |
| #define PA_PROC_SELF 0x01u |
| |
| // Handle to the initial thread of our own process. |
| #define PA_THREAD_SELF 0x02u |
| |
| // Handle to a job object which can be used to make child processes. |
| // |
| // The job can be the same as the one used to create this process or it can |
| // be different. |
| #define PA_JOB_DEFAULT 0x03u |
| |
| // Handle to the root of our address space |
| #define PA_VMAR_ROOT 0x04u |
| |
| // Handle to the VMAR used to load the initial program image. |
| #define PA_VMAR_LOADED 0x05u |
| |
| // --- Loader Service and VMO Handles --- |
| // Used by libc init (or equivalent) and dynamic loader |
| |
| // Service for loading shared libraries. |
| // |
| // See |fuchsia.ldsvc.Loader| for the interface definition. |
| #define PA_LDSVC_LOADER 0x10u |
| |
| // Handle to the VMO containing the ELF image of the system vDSO. This |
| // handle is duplicable, transferable, readable, and executable, but not |
| // writable. The contents of the VM object should be treated like any |
| // other general-purpose ELF file image of type ET_DYN. A process only |
| // needs this handle so that it can map the vDSO into new processes it |
| // might create or propagate it on to its children so they can do so. |
| // Each process's own vDSO was mapped in by its creator before the |
| // process started, its address passed as an argument to entry point. |
| #define PA_VMO_VDSO 0x11u |
| |
| // Handle to the VMO used to map the initial thread's stack. This |
| // handle usually has all rights. The protocol between process creator |
| // and new process is that this entire VM object has been mapped in |
| // before the process starts. The initial value for the SP register in |
| // the new process is the high edge of the mapping (assuming stacks grow |
| // downwards), adjusted down as required by the particular machine's C |
| // calling convention for function entry. Thus the new process can |
| // compute its exact stack bounds by subtracting the size reported by |
| // this VMO from the (adjusted back up) initial SP value. |
| #define PA_VMO_STACK 0x13u |
| |
| // VM object handle for the main executable file |
| #define PA_VMO_EXECUTABLE 0x14u |
| |
| // Used by kernel and userboot during startup |
| #define PA_VMO_BOOTDATA 0x1Au |
| |
| // Used by kernel and userboot during startup |
| #define PA_VMO_BOOTFS 0x1Bu |
| |
| // Used by the kernel to export debug information as a file in bootfs. When |
| // devmgr starts, it looks for handles of this type, and adds them as files in |
| // /boot/kernel/<vmo-name>. |
| #define PA_VMO_KERNEL_FILE 0x1Cu |
| |
| // Used by the ELF runner to deliver a component's structured configuration values. |
| // See fuchsia.component.runner.ComponentStartInfo/encoded_config for more information. |
| #define PA_VMO_COMPONENT_CONFIG 0x1Du |
| |
| // --- Namespace Handles --- |
| |
| // A handle which will handle OPEN requests relative |
| // to a particular path which is specified by the |
| // nametable entry referred to by the "arg" field |
| #define PA_NS_DIR 0x20u |
| |
| // --- File Descriptor Handles --- |
| |
| // A handle which will be used as a file descriptor. |
| #define PA_FD 0x30u |
| |
| // -- Lifecycle handle -- |
| // |
| // A Handle to a channel on which the process may receive lifecycle events from |
| // the ELF runner by serving the |fuchsia.process.Lifecycle| protocol. |
| #define PA_LIFECYCLE 0x3Au |
| |
| // Server endpoint for a processes' outgoing directory. |
| // https://fuchsia.dev/fuchsia-src/glossary?hl=en#outgoing-directory |
| #define PA_DIRECTORY_REQUEST 0x3Bu |
| |
| #if FUCHSIA_API_LEVEL_AT_LEAST(HEAD) |
| // A |fuchsia.component.sandbox/Dictionary| client endpoint where the process |
| // may find a dictionary that it has stowed away earlier via |
| // |fuchsia.process.Lifecycle/OnEscrow|. |
| // |
| // TODO(https://fxbug.dev/341127825): This processarg is an experimental element |
| // added as we iterate on stopping a component. It may be changed or removed. |
| // Do not depend on it unless you're one of the initial customers trying to stop |
| // your component. |
| #define PA_ESCROWED_DICTIONARY 0x3Cu |
| #endif |
| |
| // Used by devmgr and devhosts |
| #define PA_RESOURCE 0x3Fu |
| |
| // --- Clock handles --- |
| // |
| // A clock which provides access to UTC. Used by runtimes which are expected to |
| // provide access to UTC via their standard libraries. |
| // |
| #define PA_CLOCK_UTC 0x40u |
| |
| // --- Resource handles --- |
| #define PA_MMIO_RESOURCE 0x50 |
| #define PA_IRQ_RESOURCE 0x51 |
| #define PA_IOPORT_RESOURCE 0x52 |
| #define PA_SMC_RESOURCE 0x53 |
| #define PA_SYSTEM_RESOURCE 0x54 |
| |
| // --- Various --- |
| |
| // Handle types for one-off use and prototyping |
| #define PA_USER0 0xF0u |
| #define PA_USER1 0xF1u |
| #define PA_USER2 0xF2u |
| |
| __END_CDECLS |
| |
| #endif // ZIRCON_PROCESSARGS_H_ |