android系统开发(5)--init.rc

语法部分

actions

service

options

commandscommands

initrc的变化

initcpp

LOCAL_INIT_RC

语法部分

init.rc是一个可配置的初始化文件,在init.rc文件中一条语句通常是占据一行.单词之间是通过空格符来相隔的.如果需要在单词内使用空格,那么得使用转义字符”\”,如果在一行的末尾有一个反斜杠,那么是换行折叠符号,应该和下一行合并成一起来处理,这样做主要是为了避免一行的字符太长,与C语言中的含义是一致的。注释是以#号开头。

包含4种状态类别:Actions/Commands/Services/Options

Action和services显式声明了一个语句块,而commands和options属于最近声明的语句块。在第一个语句块之前 的commands和options会被忽略.当声明一个service或者action的时候,它将隐式声明一个section,它之后跟随的command或者option都将属于这个section,action和service不能重名,否则忽略为error。

1. actions

actions就是在某种条件下触发一系列的命令commands,通常有一个trigger,形式如:

触发器描述

on init

    sysclktz 0    

  # Mix device-specific information into the entropy pool    

   copy /proc/cmdline /dev/urandom

    copy /default.prop /dev/urandom

    # Backward compatibility.    

    symlink /system/etc /etc

    symlink /sys/kernel/debug /d

    # Link /vendor to /system/vendor for devices without a vendor partition.    

     symlink /system/vendor /vendor

    # Mount cgroup mount point for cpu accounting    

     mount cgroup none /acct cpuacct

    mkdir /acct/uid

    # Create energy-aware scheduler tuning nodes    

    mkdir /dev/stune

    mount cgroup none /dev/stune schedtune

    mkdir /dev/stune/foreground

    mkdir /dev/stune/background

    mkdir /dev/stune/top-app

    chown system system /dev/stune

    chown system system /dev/stune/foreground

2. service

service结构如下:

3. options

选项是用来修改服务的。它们影响如何及何时运行这个服务.

4. command

命令描述

4 属性(Properties) 

init程序在运行时会更新属性系统的一些属性,提供程序内部正在执行的信息.

init.rc的变化

在Android 7之前的版本中,系统Native服务,不管它们的可执行文件位于系统什么位置都定义在根分区的init.*.rc文件中。这造成init*.rc文件臃肿庞大,给维护带来了一些不便,而且其中定义的一些服务的二进制文件根本不存在。

但在Android 7.0以后,对该机制做了一些改变 。

init.cpp

/system/core/init/init.cpp中解析rc文件

可见单一的init*.rc,被拆分,服务根据其二进制文件的位置(/system,/vendor,/odm)定义到对应分区的etc/init目录中,每个服务一个rc文件。

下图为AndroidO 手机/system/etc/init目录下定义的服务

LOCAL_INIT_RC

提供一个编译宏LOCAL_INIT_RC用于将服务相关的RC文件编译到相应位置。 

例如drmserver的Android.mk中,通过LOCAL_INIT_RC将drmserver对应的drmserver.rc编译到/system/etc/init目录中。 

frameworks/av/drm/drmserver/Android.mk

LOCAL_PATH:= $(call my-dir)

include $(CLEAR_VARS)

 LOCAL_SRC_FILES:= \

    main_drmserver.cpp \

    DrmManager.cpp \

    DrmManagerService.cpp

  LOCAL_SHARED_LIBRARIES := \

    libmedia \

    libutils \

    liblog \

    libbinder \

    libdl \

    libselinux

   LOCAL_STATIC_LIBRARIES := libdrmframeworkcommon

     LOCAL_C_INCLUDES := \

    $(TOP)/frameworks/av/include \

    $(TOP)/frameworks/av/drm/libdrmframework/include \

    $(TOP)/frameworks/av/drm/libdrmframework/plugins/common/include

# Add for OMA DRM v1.0 implementation, call whitelist check api in DrmMtkUtil {@

ifeq ($(strip $(MTK_DRM_APP)),yes)

  ifeq ($(strip $(MTK_OMADRM_SUPPORT)),yes)

    LOCAL_CFLAGS += -DMTK_OMA_DRM_SUPPORT    

    LOCAL_SHARED_LIBRARIES += \

        libdrmmtkutil

    LOCAL_C_INCLUDES += \

        $(MTK_PATH_SOURCE)/frameworks/av/drm/include  

else ifeq ($(strip $(MTK_CTA_SET)),yes)

    LOCAL_CFLAGS += -DMTK_CTA_DRM_SUPPORT   

     LOCAL_SHARED_LIBRARIES += \

        libdrmmtkutil

    LOCAL_C_INCLUDES += \

        $(MTK_PATH_SOURCE)/frameworks/av/drm/

include  endifelse ifeq ($(strip $(MTK_WVDRM_SUPPORT)),yes)

    LOCAL_CFLAGS += -DMTK_WV_DRM_SUPPORT    LOCAL_SHARED_LIBRARIES += \

        libdrmmtkutil

    LOCAL_C_INCLUDES += \

        $(MTK_PATH_SOURCE)/frameworks/av/drm/include

endif

# @}

LOCAL_CFLAGS += -Wall -Wextra -Werror

LOCAL_MODULE:= drmserver

LOCAL_MODULE_TAGS := optional

LOCAL_32_BIT_ONLY := true

LOCAL_INIT_RC := drmserver.rc

include $(BUILD_EXECUTABLE)

你可能感兴趣的:(android系统开发(5)--init.rc)