1# Component-based Startup 2## Overview 3### Function Introduction 4This subsystem provides the following functions: 5- Builds four basic component images and provides component-based directories, including: 6 - System component: **system** 7 - Common product configuration component: **sys_prod** 8 - Chipset component: **chipset** 9 - Hardware configuration component: **chip_prod** 10- Ensures that system parameters and startup scripts can be scanned and initialized by component priority. 11- Independently compiles and builds the **system** component and **chipset** component. 12 13### Basic Concepts 14- Basic Components 15 16 **system**: serves as the file system mount point, and functions as a platform service irrelevant to the chipset and hardware. 17 **sys_prod**: extends and customizes capabilities of the **system** component, bears product-level differentiated capabilities, and stores product-related configuration files. 18 **chipset**: serves as the file system mount point, and offers unified hardware abstraction services for the **system** component. Same chipset platforms can use the same **chipset** component. 19 **chip_prod**: offers specific hardware capabilities of a peripheral board and product-level differentiated hardware configurations, as well as chipset-related configuration files. 20 21- Component-based compilation and building 22 23 Use **target_cpu** to specify the instruction set of the **system** component. Use **inherit** to inherit the common component set such as **base**, **headless**, and **rich**. Use **subsystems** to define more components for a specific product type. 24 25- System parameters and startup scripts scanned and initialized by component priority 26 27 System parameters and startup scripts include the CFG configuration file, PARAM file, sandbox JSON configuration file, and module plugin library file of a service. The following are related files that are in ascending order in terms of priority: **/system**, **/chipset**, **/sys_prod**, and **/chip_prod**. A file with a higher priority replaces and updates the configuration file with a lower priority. 28 29 30### Constraints 31Standard and small systems support component-based compilation and building. System parameters and startup scripts are scanned and initialized by component priority. 32 33## How to Develop 34### When to Use 35Component-based startup enables vendors and hardware platforms to quickly develop products through modular combination. The following uses RK3568 as an example to illustrate component-based startup in detail. 36 37### Building and Compiling RK3568 Based on Components 38The **//vendor/hihope/rk3568/config.json** configuration file implements components required for building the product: 39 40 { 41 "product_name": "rk3568", 42 "device_company": "rockchip", 43 ... 44 "target_cpu": "arm", 45 ... 46 "inherit": [ "productdefine/common/inherit/rich.json", "productdefine/common/inherit/chipset_common.json" ], 47 "subsystems": [ 48 { 49 "subsystem": "security", 50 "components": [ 51 { 52 "component": "selinux", 53 "features": [] 54 } 55 ] 56 } 57 ... 58 } 59 60The example above indicates the product name, chipset vendor, supported instruction set, and more. **inherit** indicates the dependent common components, and **subsystems** indicates other components. 61The following illustrates the configuration of the **system** component in the **//productdefine/common/inherit/rich.json** file. The **system** component can also include **base.json** (list of minimal components that all products must contain) and **headless.json** (list of minimal components with which products having no UI allow for application installation and management). 62 63 { 64 "version": "3.0", 65 "subsystems": [ 66 { 67 "subsystem": "arkui", 68 "components": [ 69 { 70 "component": "ace_engine", 71 "features": [] 72 }, 73 { 74 "component": "napi", 75 "features": [] 76 } 77 ] 78 }, 79 { 80 "subsystem": "account", 81 "components": [ 82 { 83 "component": "os_account", 84 "features": [] 85 } 86 ] 87 }, 88 ... 89 } 90 91### Scanning and Initializing System Parameters by Priority 92The following are CFG files of a service, which are in ascending order in terms of priority: **/system/etc**, **/system/etc/init**, and **/chipset/etc**. A file with a higher priority replaces and updates the configuration file with a lower priority. The following uses **/system/etc/init/camera_service.cfg** as an example: 93 94 { 95 "services" : [{ 96 "name" : "camera_service", 97 "path" : ["/system/bin/sa_main", "/system/profile/camera_service.xml"], 98 "uid" : "cameraserver", 99 "gid" : ["system", "shell"], 100 "secon" : "u:r:camera_service:s0", 101 "permission" : ["ohos.permission.GET_SENSITIVE_PERMISSIONS"], 102 "permission_acls" : ["ohos.permission.GET_SENSITIVE_PERMISSIONS"] 103 }] 104 } 105 106**/chipset/etc/camera_B_service.cfg** exists at the same time. 107 108 { 109 "services" : [{ 110 "name" : "camera_service", 111 "path" : ["/system/bin/sa_main", "/system/profile/camera_B_service.xml"], 112 "uid" : "cameraserver", 113 "gid" : ["system", "shell"], 114 "secon" : "u:r:camera_service:s0", 115 "permission" : ["ohos.permission.GET_SENSITIVE_PERMISSIONS"], 116 "permission_acls" : ["ohos.permission.GET_SENSITIVE_PERMISSIONS"], 117 "disabled" : 1 118 }] 119 } 120 121Based on the priority requirement, the **path** attribute of the **camera_service** service will be replaced by **["/system/bin/sa_main", "/system/profile/camera_B_service.xml"]** that has a higher priority, and the **disabled** attribute is added. 122