1:orphan: 2 3.. _glossary: 4 5Glossary of Terms 6################# 7 8.. glossary:: 9 :sorted: 10 11 API 12 (Application Program Interface) A defined set of routines and protocols for 13 building application software. 14 15 application 16 The set of user-supplied files that the Zephyr build system uses 17 to build an application image for a specified board configuration. 18 It can contain application-specific code, kernel configuration settings, 19 and at least one CMakeLists.txt file. 20 The application's kernel configuration settings direct the build system 21 to create a custom kernel that makes efficient use of the board's 22 resources. 23 An application can sometimes be built for more than one type of board 24 configuration (including boards with different CPU architectures), 25 if it does not require any board-specific capabilities. 26 27 application image 28 A binary file that is loaded and executed by the board for which 29 it was built. 30 Each application image contains both the application's code and the 31 Zephyr kernel code needed to support it. They are compiled as a single, 32 fully-linked binary. 33 Once an application image is loaded onto a board, the image takes control 34 of the system, initializes it, and runs as the system's sole application. 35 Both application code and kernel code execute as privileged code 36 within a single shared address space. 37 38 architecture 39 An instruction set architecture (ISA) along with a programming model. 40 41 board 42 A target system with a defined set of devices and capabilities, 43 which can load and execute an application image. It may be an actual 44 hardware system or a simulated system running under QEMU. A board can 45 contain one or more :term:`SoCs <SoC>`. 46 The Zephyr kernel supports a :ref:`variety of boards <boards>`. 47 48 board configuration 49 A set of kernel configuration options that specify how the devices 50 present on a board are used by the kernel. 51 The Zephyr build system defines one or more board configurations 52 for each board it supports. The kernel configuration settings that are 53 specified by the build system can be over-ridden by the application, 54 if desired. 55 56 board name 57 The human-readable name of a :term:`board`. Uniquely and descriptively 58 identifies a particular system, but does not include additional 59 information that may be required to actually build a Zephyr image for it. 60 See :ref:`board_terminology` for additional details. 61 62 board qualifiers 63 The set of additional tokens, separated by a forward slash (``/``) that 64 follow the :term:`board name` (and optionally :term:`board revision`) to 65 form the :term:`board target`. The currently accepted qualifiers are 66 :term:`SoC`, :term:`CPU cluster` and :term:`variant`. 67 See :ref:`board_terminology` for additional details. 68 69 board revision 70 An optional version string that identifies a particular revision of a 71 hardware system. This is useful to avoid duplication of board files 72 whenever small changes are introduced to a hardware system. 73 See :ref:`porting_board_revisions` and :ref:`application_board_version` 74 for more information. 75 76 board target 77 The full string that can be provided to any of the Zephyr build tools to 78 compile and link an image for a particular hardware system. This string 79 uniquely identifies the combination of :term:`board name`, :term:`board 80 revision` and :term:`board qualifiers`. 81 See :ref:`board_terminology` for additional details. 82 83 CPU cluster 84 A group of one or more :term:`CPU cores <CPU core>`, all executing the same image 85 within the same address space and in a symmetrical (SMP) configuration. 86 Only :term:`CPU cores <CPU core>` of the same :term:`architecture` can be in a single 87 cluster. Multiple CPU clusters (each of one or more cores) can coexist in 88 the same :term:`SoC`. 89 90 CPU core 91 A single processing unit, with its own Program Counter, executing program 92 instructions sequentially. CPU cores are part of a :term:`CPU cluster`, 93 which can contain one or more cores. 94 95 device runtime power management 96 Device Runtime Power Management (PM) refers the capability of devices to 97 save energy independently of the system power state. Devices will keep 98 reference of their usage and will automatically be suspended or resumed. 99 This feature is enabled via the :kconfig:option:`CONFIG_PM_DEVICE_RUNTIME` 100 Kconfig option. 101 102 idle thread 103 A system thread that runs when there are no other threads ready to run. 104 105 IDT 106 (Interrupt Descriptor Table) a data structure used by the x86 107 architecture to implement an interrupt vector table. The IDT is used 108 to determine the correct response to interrupts and exceptions. 109 110 ISR 111 (Interrupt Service Routine) Also known as an interrupt handler, an ISR 112 is a callback function whose execution is triggered by a hardware 113 interrupt (or software interrupt instructions) and is used to handle 114 high-priority conditions that require interrupting the current code 115 executing on the processor. 116 117 kernel 118 The set of Zephyr-supplied files that implement the Zephyr kernel, 119 including its core services, device drivers, network stack, and so on. 120 121 power domain 122 A power domain is a collection of devices for which power is 123 applied and removed collectively in a single action. Power 124 domains are represented by :c:struct:`device`. 125 126 power gating 127 Power gating reduces power consumption by shutting off areas of an 128 integrated circuit that are not in use. 129 130 SoC 131 A `System on a chip`_, that is, an integrated circuit that contains at 132 least one :term:`CPU cluster` (in turn with at least one :term:`CPU core`), 133 as well as peripherals and memory. 134 135 SoC family 136 One or more :term:`SoCs <SoC>` or :term:`SoC series` that share enough 137 in common to consider them related and under a single family denomination. 138 139 SoC series 140 A number of different :term:`SoCs <SoC>` that share similar characteristics and 141 features, and that the vendor typically names and markets together. 142 143 subsystem 144 A subsystem refers to a logically distinct part of the operating system 145 that handles specific functionality or provides certain services. 146 147 system power state 148 System power states describe the power consumption of the system as a 149 whole. System power states are represented by :c:enum:`pm_state`. 150 151 variant 152 In the context of :term:`board qualifiers`, a variant designates a 153 particular type or configuration of a build for a combination of :term:`SoC` 154 and :term:`CPU cluster`. Common uses of the variant concept include 155 introducing both secure and non-secure builds for platforms with Trusted 156 Execution Environment support, or selecting the type of RAM used in a 157 build. 158 159 west 160 A multi-repo meta-tool developed for the Zephyr project. See :ref:`west`. 161 162 west installation 163 An obsolete term for a :term:`west workspace` used prior to west 0.7. 164 165 west manifest 166 A YAML file, usually named :file:`west.yml`, which describes projects, or 167 the Git repositories which make up a :term:`west workspace`, along with 168 additional metadata. See :ref:`west-basics` for general information 169 and :ref:`west-manifests` for details. 170 171 west manifest repository 172 The Git repository in a :term:`west workspace` which contains the 173 :term:`west manifest`. Its location is given by the :ref:`manifest.path 174 configuration option <west-config-index>`. See :ref:`west-basics`. 175 176 west project 177 Each of the entries in a :term:`west manifest`, which describe a Git 178 repository that will be cloned and managed by west when working with the 179 corresponding :term:`west manifest repository`. Note that a west project 180 is different from a :term:`zephyr module`, although many projects are also 181 modules. See :ref:`west-manifests-projects` for additional information. 182 183 west workspace 184 A folder on your system with a :file:`.west` subdirectory and a 185 :term:`west manifest repository` in it. You clone the Zephyr source code, 186 as well as that of its :term:`west projects <west project>` onto your 187 system by creating a west workspace using the ``west init`` command. See 188 :ref:`west-basics`. 189 190 XIP 191 (eXecute In Place) a method of executing programs directly from long 192 term storage rather than copying it into RAM, saving writable memory for 193 dynamic data and not the static program code. 194 195 zephyr module 196 A Git repository containing a :file:`zephyr/module.yml` file, used by the 197 Zephyr build system to integrate the source code and configuration files 198 of the module into a regular Zephyr build. Zephyr modules may be west 199 projects, but they do not have to. See :ref:`modules` for additional 200 details. 201 202.. _System on a chip: https://en.wikipedia.org/wiki/System_on_a_chip 203