1# LiteIPC 2 3 4## Basic Concepts 5 6LiteIPC is a new inter-process communication (IPC) mechanism provided by the OpenHarmony LiteOS-A kernel. Different from the traditional System V IPC, LiteIPC is designed for Remote Procedure Call (RPC). In addition, it provides APIs for the upper layer through device files, not through traditional API functions. 7 8LiteIPC has two important concepts: ServiceManager and Service. The entire system can have one ServiceManager and multiple Services. 9 10ServiceManager provides the following functions: 11 12- Registers and deregisters services. 13 14- Manages the access permission of services. Only authorized tasks can send IPC messages to the service. 15 16 17## Working Principles 18 19ServiceManager registers the task that needs to receive IPC messages as a Service, and sets the access permission for the Service task (specifies the tasks that can send IPC messages to the Service). 20 21LiteIPC maintains an IPC message queue for each Service task in kernel mode. The message queue provides the upper-layer user-mode programs with the read operation (receiving IPC messages) and the write operations (sending IPC messages) through LiteIPC device files. 22 23 24## Development Guidelines 25 26 27### Available APIs 28 29 **Table 1** APIs of the LiteIPC module (applicable to LiteOS-A only) 30 31| Category | API Description | 32| ------------- | ------------------------------------------------------------ | 33| Module initialization | **OsLiteIpcInit**: initializes the LiteIPC module. | 34| IPC message memory pool| - **LiteIpcPoolInit**: initializes the IPC message memory pool of a process.<br>- **LiteIpcPoolReInit**: reinitializes the IPC message memory pool of a process.<br>- **LiteIpcPoolDelete**: releases the IPC message memory pool of a process. | 35| Service management | **LiteIpcRemoveServiceHandle**: deletes a service. | 36 37> **NOTE**<br> 38> The APIs of the LiteIPC module are dedicated for LiteOS-A internal use only. 39