设计主要是android10平台,参考了android 9 code
修改的主要文件
Changes to be committed:
modified: build/make/core/Makefile
modified: build/make/core/config.mk
modified: build/make/core/envsetup.mk
modified: build/make/core/main.mk
modified: build/make/tools/allmake.sh
modified: build/make/tools/releasetools/build_image.py
modified: device/autochips/ac8257/init.ac8257.rc
modified: device/autochips/ac8257_demo/BoardConfig.mk
modified: device/autochips/build/build/tools/ptgen/AC8257/partition_table_AC8257_emmc.csv
modified: device/autochips/sepolicy/bsp/non_plat/device.te
modified: device/autochips/sepolicy/bsp/non_plat/file.te
modified: device/autochips/sepolicy/bsp/non_plat/file_contexts
modified: device/autochips/sepolicy/bsp/non_plat/fsck.te
modified: device/autochips/sepolicy/bsp/non_plat/init.te
modified: device/autochips/sepolicy/bsp/non_plat/system_app.te
modified: system/core/rootdir/Android.mk
modified: vendor/mediatek/proprietary/hardware/fstab/ac8257/fstab.in.ac8257
1、分区表中添加分区(这里添加三个分区):
device/autochips/build/build/tools/ptgen/AC8257/partition_table_AC8257_emmc.csv

2、添加flashtool下载时需要的cpuinfo.img、resources.img和ivres.img三个文件的生成,主要修改以下文件
build/make/core/Makefile
build/make/core/config.mk
build/make/core/envsetup.mk
build/make/core/main.mk
build/make/tools/allmake.sh
build/make/tools/releasetools/build_image.py
system/core/rootdir/Android.mk
device/autochips/ac8257_demo/BoardConfig.mk
2.1)在build/make/core/Makefile 文件中添加如下:
$(if $(BOARD_AVMIMAGE_PARTITION_SIZE),$(hide) echo "avm_size=$(BOARD_AVMIMAGE_PARTITION_SIZE)" >> $(1))
+$(if $(BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE),$(hide) echo "resources_fs_type=$(BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE)" >> $(1))
+$(if $(BOARD_RESOURCESIMAGE_PARTITION_SIZE),$(hide) echo "resources_size=$(BOARD_RESOURCESIMAGE_PARTITION_SIZE)" >> $(1))
+$(if $(BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE),$(hide) echo "ivres_fs_type=$(BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE)" >> $(1))
+$(if $(BOARD_IVRESIMAGE_PARTITION_SIZE),$(hide) echo "ivres_size=$(BOARD_IVRESIMAGE_PARTITION_SIZE)" >> $(1))
+$(if $(BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE),$(hide) echo "cpuinfo_fs_type=$(BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE)" >> $(1))
+$(if $(BOARD_CPUINFOIMAGE_PARTITION_SIZE),$(hide) echo "cpuinfo_size=$(BOARD_CPUINFOIMAGE_PARTITION_SIZE)" >> $(1))
$(if $(BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE),$(hide) echo "vendor_fs_type=$(BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE)" >> $(1))
---------------------------------------------------
lse # BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE
# we need to ignore the broken cache link when doing the rsync
IGNORE_CACHE_LINK := --exclude=cache
endif # BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE
+#-----add by zhaojr
+# -----------------------------------------------------------------
+# cpuinfo partition image
+ifdef BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE
+INTERNAL_CPUINFOIMAGE_FILES := \
+ $(filter $(TARGET_OUT_CPUINFO)/%,$(ALL_DEFAULT_INSTALLED_MODULES))
+
+cpuinfoimage_intermediates := \
+ $(call intermediates-dir-for,PACKAGING,cpuinfo)
+BUILT_CPUINFOIMAGE_TARGET := $(PRODUCT_OUT)/cpuinfo.img
+define build-cpuinfoimage-target
+ $(call pretty,"Target cpuinfo fs image: $(INSTALLED_CPUINFOIMAGE_TARGET)")
+ @mkdir -p $(TARGET_OUT_CPUINFO)
+ @mkdir -p $(cpuinfoimage_intermediates) && rm -rf +$(cpuinfoimage_intermediates)/cpuinfo_image_info.txt
+ $(call generate-userimage-prop-dictionary, +$(cpuinfoimage_intermediates)/cpuinfo_image_info.txt, skip_fsck=true)
+ $(hide) PATH=$(foreach p,$(INTERNAL_USERIMAGES_BINARY_PATHS),$(p):)$$PATH \
+ build/make/tools/releasetools/build_image.py \
+ $(TARGET_OUT_CPUINFO) $(cpuinfoimage_intermediates)/cpuinfo_image_info.txt +$(INSTALLED_CPUINFOIMAGE_TARGET) $(TARGET_OUT)
+ $(hide) $(call assert-max-image-+size,$(INSTALLED_CPUINFOIMAGE_TARGET),$(BOARD_CPUINFOIMAGE_PARTITION_SIZE))
+endef
+# We just build this directly to the install location.
+INSTALLED_CPUINFOIMAGE_TARGET := $(BUILT_CPUINFOIMAGE_TARGET)
+$(INSTALLED_CPUINFOIMAGE_TARGET): $(INTERNAL_USERIMAGES_DEPS) +$(INTERNAL_CPUINFOIMAGE_FILES) $(BUILD_IMAGE_SRCS)
+ $(build-cpuinfoimage-target)
+.PHONY: cpuinfoimage-nodeps
+cpuinfoimage-nodeps: | $(INTERNAL_USERIMAGES_DEPS)
+ $(build-cpuinfoimage-target)
+else # BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE
+# we need to ignore the broken cpuinfo link when doing the rsync
+IGNORE_CPUINFO_LINK := --exclude=cpuinfo
+endif # BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE
+
+# resources partition image
+ifdef BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE
+INTERNAL_RESOURCESIMAGE_FILES := \
+ $(filter $(TARGET_OUT_RESOURCES)/%,$(ALL_DEFAULT_INSTALLED_MODULES))
+
+resourcesimage_intermediates := \
+ $(call intermediates-dir-for,PACKAGING,resources)
+BUILT_RESOURCESIMAGE_TARGET := $(PRODUCT_OUT)/resources.img
+
+define build-resourcesimage-target
+ $(call pretty,"Target resources fs image: $(INSTALLED_RESOURCESIMAGE_TARGET)")
+ @mkdir -p $(TARGET_OUT_RESOURCES)
+ @mkdir -p $(resourcesimage_intermediates) && rm -rf $(resourcesimage_intermediates)/resources_image_info.txt
+ $(call generate-userimage-prop-dictionary, $(resourcesimage_intermediates)/resources_image_info.txt, skip_fsck=true)
+ $(hide) PATH=$(foreach p,$(INTERNAL_USERIMAGES_BINARY_PATHS),$(p):)$$PATH \
+ build/make/tools/releasetools/build_image.py \
+ $(TARGET_OUT_RESOURCES) $(resourcesimage_intermediates)/resources_image_info.txt $(INSTALLED_RESOURCESIMAGE_TARGET) $(TARGET_OUT)
+ $(hide) $(call assert-max-image-size,$(INSTALLED_RESOURCESIMAGE_TARGET),$(BOARD_RESOURCESIMAGE_PARTITION_SIZE))
+endef
+
+# We just build this directly to the install location.
+INSTALLED_RESOURCESIMAGE_TARGET := $(BUILT_RESOURCESIMAGE_TARGET)
+$(INSTALLED_RESOURCESIMAGE_TARGET): $(INTERNAL_USERIMAGES_DEPS) $(INTERNAL_RESOURCESIMAGE_FILES) $(BUILD_IMAGE_SRCS)
+ $(build-resourcesimage-target)
+
+.PHONY: resourcesimage-nodeps
+resourcesimage-nodeps: | $(INTERNAL_USERIMAGES_DEPS)
+ $(build-resourcesimage-target)
+
+else # BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE
+# we need to ignore the broken cache link when doing the rsync
+IGNORE_RESOURCES_LINK := --exclude=resources
+endif # BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE
+
+# ivres partition image
+ifdef BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE
+INTERNAL_IVRESIMAGE_FILES := \
+ $(filter $(TARGET_OUT_IVRES)/%,$(ALL_DEFAULT_INSTALLED_MODULES))
+
+ivresimage_intermediates := \
+ $(call intermediates-dir-for,PACKAGING,ivres)
+BUILT_IVRESIMAGE_TARGET := $(PRODUCT_OUT)/ivres.img
+
+define build-ivresimage-target
+ $(call pretty,"Target ivres fs image: $(INSTALLED_IVRESIMAGE_TARGET)")
+ @mkdir -p $(TARGET_OUT_IVRES)
+ @mkdir -p $(ivresimage_intermediates) && rm -rf $(ivresimage_intermediates)/ivres_image_info.txt
+ $(call generate-userimage-prop-dictionary, $(ivresimage_intermediates)/ivres_image_info.txt, skip_fsck=true)
+ $(hide) PATH=$(foreach p,$(INTERNAL_USERIMAGES_BINARY_PATHS),$(p):)$$PATH \
+ build/make/tools/releasetools/build_image.py \
+ $(TARGET_OUT_IVRES) $(ivresimage_intermediates)/ivres_image_info.txt $(INSTALLED_IVRESIMAGE_TARGET) $(TARGET_OUT)
+ $(hide) $(call assert-max-image-size,$(INSTALLED_IVRESIMAGE_TARGET),$(BOARD_IVRESIMAGE_PARTITION_SIZE))
+endef
+
+# We just build this directly to the install location.
+INSTALLED_IVRESIMAGE_TARGET := $(BUILT_IVRESIMAGE_TARGET)
+$(INSTALLED_IVRESIMAGE_TARGET): $(INTERNAL_USERIMAGES_DEPS) $(INTERNAL_IVRESIMAGE_FILES) $(BUILD_IMAGE_SRCS)
+ $(build-ivresimage-target)
+
+.PHONY: ivresimage-nodeps
+ivresimage-nodeps: | $(INTERNAL_USERIMAGES_DEPS)
+ $(build-ivresimage-target)
+
+else # BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE
+# we need to ignore the broken ivres link when doing the rsync
+IGNORE_IVRES_LINK := --exclude=ivres
+endif # BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE
+#-----end add by zhaojr
+
# -----------------------------------------------------------------
# system_other partition image
ifeq ($(BOARD_USES_SYSTEM_OTHER_ODEX),true)
BOARD_USES_SYSTEM_OTHER := true
---------------------------------------------------
$(BUILT_TARGET_FILES_PACKAGE): \
$(INSTALLED_BOOTIMAGE_TARGET) \
$(MTK_BOOTIMAGE_TARGET) \
$(INSTALLED_RADIOIMAGE_TARGET) \
$(INSTALLED_RECOVERYIMAGE_TARGET) \
$(FULL_SYSTEMIMAGE_DEPS) \
$(INSTALLED_USERDATAIMAGE_TARGET) \
$(INSTALLED_CACHEIMAGE_TARGET) \
+ $(INSTALLED_CPUINFOIMAGE_TARGET) \
+ $(INSTALLED_RESOURCESIMAGE_TARGET) \
+ $(INSTALLED_IVRESIMAGE_TARGET) \
$(INSTALLED_INTSDIMAGE_TARGET) \
2.2) build/make/core/config.mk文件修改
dont_bother_goals := out \
snod systemimage-nodeps \
stnod systemtarball-nodeps \
userdataimage-nodeps userdatatarball-nodeps \
cacheimage-nodeps \
+ resourcesimage-nodeps \
+ ivresimage-nodeps \
+ cpuinfoimage-nodeps \
bptimage-nodeps \
2.3)build/make/core/envsetup.mk文件的修改
$(TARGET_2ND_ARCH_VAR_PREFIX)TARGET_OUT_VENDOR_NATIVE_TESTS := $(TARGET_OUT_DATA)/nativetest$(TARGET_VENDOR_TEST_SUFFIX)
$(TARGET_2ND_ARCH_VAR_PREFIX)TARGET_OUT_VENDOR_METRIC_TESTS := $(TARGET_OUT_DATA)/benchmarktest$(TARGET_VENDOR_TEST_SUFFIX)
endif
TARGET_OUT_INTSD := $(PRODUCT_OUT)/intsd
TARGET_OUT_AVM := $(PRODUCT_OUT)/avm
TARGET_OUT_CACHE := $(PRODUCT_OUT)/cache
+TARGET_OUT_RESOURCES := $(PRODUCT_OUT)/resources
+TARGET_OUT_IVRES := $(PRODUCT_OUT)/ivres
+TARGET_OUT_CPUINFO := $(PRODUCT_OUT)/cpuinfo
TARGET_OUT_VENDOR := $(PRODUCT_OUT)/$(TARGET_COPY_OUT_VENDOR)
ifneq ($(filter address,$(SANITIZE_TARGET)),)
2.4)build/make/core/main.mk文件的修改
.PHONY: cacheimage
cacheimage: $(INSTALLED_CACHEIMAGE_TARGET)
+.PHONY: resourcesimage
+resourcesimage: $(INSTALLED_RESOURCESIMAGE_TARGET)
+.PHONY: ivres
+ivresimage: $(INSTALLED_IVRESIMAGE_TARGET)
+.PHONY: cpuinfoimage
+cpuinfoimage: $(INSTALLED_CPUINFOIMAGE_TARGET)
.PHONY: intsdimage
intsdimage: $(INSTALLED_INTSDIMAGE_TARGET)
.PHONY: avmimage
avmimage: $(INSTALLED_AVMIMAGE_TARGET)
--------------------------------------------
# Build files and then package it into the rom formats
.PHONY: droidcore
droidcore: files \
systemimage \
$(INSTALLED_BOOTIMAGE_TARGET) \
$(MTK_BOOTIMAGE_TARGET) \
$(INSTALLED_RECOVERYIMAGE_TARGET) \
$(INSTALLED_INTSDIMAGE_TARGET) \
$(INSTALLED_AVMIMAGE_TARGET) \
$(INSTALLED_VBMETAIMAGE_TARGET) \
$(INSTALLED_USERDATAIMAGE_TARGET) \
$(INSTALLED_CACHEIMAGE_TARGET) \
+ $(INSTALLED_RESOURCESIMAGE_TARGET) \
+ $(INSTALLED_IVRESIMAGE_TARGET) \
+ $(INSTALLED_CPUINFOIMAGE_TARGET) \
$(INSTALLED_BPTIMAGE_TARGET) \
2.5)build/make/tools/allmake.sh文件的修改
IMAGES="*_Android_scatter.txt resources.img ivres.img cpuinfo.img arm2.img
添加resources.img ivres.img cpuinfo.img文件拷贝
因我打算做的android10, 这里与源码可能有冲突,需要仔细看
vim ./releasetools/add_img_to_target_files.py +770
"IMAGES/boot.img", "boot.img", OPTIONS.input_tmp, "BOOT") -->这里参考如何添加
2.6)build/make/tools/releasetools/build_image.py 文件的修改
elif mount_point == "cache":
copy_prop("cache_fs_type", "fs_type")
copy_prop("cache_size", "partition_size")
+ elif mount_point == "cpuinfo":
+ copy_prop("cpuinfo_fs_type", "fs_type")
+ copy_prop("cpuinfo_size", "partition_size")
+ elif mount_point == "resources":
+ copy_prop("resources_fs_type", "fs_type")
+ copy_prop("resources_size", "partition_size")
+ elif mount_point == "ivres":
+ copy_prop("ivres_fs_type", "fs_type")
+ copy_prop("ivres_size", "partition_size")
elif mount_point == "intsd":
copy_prop("intsd_fs_type", "fs_type")
copy_prop("intsd_size", "partition_size")
elif mount_point == "avm":
copy_prop("avm_fs_type", "fs_type")
copy_prop("avm_size", "partition_size")
--------
elif image_filename == "cache.img":
mount_point = "cache"
+ elif image_filename == "cpuinfo.img":
+ mount_point = "cpuinfo"
+ elif image_filename == "resources.img":
+ mount_point = "resources"
+ elif image_filename == "ivres.img":
+ mount_point = "ivres"
elif image_filename == "intsd.img":
mount_point = "intsd"
elif image_filename == "avm.img":
mount_point = "avm"
2.7 system/core/rootdir/Android.mk 文件的修改
ifdef BOARD_CACHEIMAGE_FILE_SYSTEM_TYPE
LOCAL_POST_INSTALL_CMD += ; mkdir -p $(TARGET_ROOT_OUT)/cache
else
LOCAL_POST_INSTALL_CMD += ; ln -sf /data/cache $(TARGET_ROOT_OUT)/cache
endif
+###add by zhaojr#####
+ifdef BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE
+ LOCAL_POST_INSTALL_CMD += ; mkdir -p $(TARGET_ROOT_OUT)/cpuinfo
+endif
+ifdef BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE
+ LOCAL_POST_INSTALL_CMD += ; mkdir -p $(TARGET_ROOT_OUT)/resources
+endif
+ifdef BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE
+ LOCAL_POST_INSTALL_CMD += ; mkdir -p $(TARGET_ROOT_OUT)/ivres
+endif
+####end add by zhaojr####
ifdef BOARD_ROOT_EXTRA_SYMLINKS
2.8 device/autochips/ac8257_demo/BoardConfig.mk 文件的修改
# Create avm partition
#ifeq ($(strip $(ATC_AVM_SUPPORT)),yes)
BOARD_AVMIMAGE_FILE_SYSTEM_TYPE := ext4
#endif
+#add by zhaojr resources ivres cpuinfo
+BOARD_CPUINFOIMAGE_FILE_SYSTEM_TYPE := ext4
+BOARD_RESOURCESIMAGE_FILE_SYSTEM_TYPE := ext4
+BOARD_IVRESIMAGE_FILE_SYSTEM_TYPE := ext4
+#end by zhaojr
3、修改fstab文件添加分区的挂载和系统启动时挂载权限
修改:vendor/mediatek/proprietary/hardware/fstab/ac8257/fstab.in.ac8257
DEVPATH(protect1) /mnt/vendor/protect_f ext4 FS_FLAG_COMMIT FSMGR_FLAG_FMT
DEVPATH(protect2) /mnt/vendor/protect_s ext4 FS_FLAG_COMMIT FSMGR_FLAG_FMT
DEVPATH(nvdata) /mnt/vendor/nvdata ext4 FS_FLAG_DISCARD FSMGR_FLAG_FMT
DEVPATH(nvcfg) /mnt/vendor/nvcfg ext4 FS_FLAG_COMMIT FSMGR_FLAG_FMT
+DEVPATH(cpuinfo) /cpuinfo ext4 FS_FLAG_COMMIT FSMGR_FLAG_FMT
+DEVPATH(resources) /resources ext4 FS_FLAG_COMMIT FSMGR_FLAG_FMT
+DEVPATH(ivres) /ivres ext4 FS_FLAG_COMMIT FSMGR_FLAG_FMT
修改:device/autochips/ac8257/init.ac8257.rc
on post-fs-data
........................
................................
#Create flash folder
mkdir /data/vendor/flash
chown root system /data/vendor/flash
chmod 0771 /data/vendor/flash
#add by zhaojr
+ # We chown/chmod /cpuinfo again so because mount is run as root + defaults
+ chown system system /cpuinfo
+ chmod 0771 /cpuinfo
+ # We chown/chmod /resources again so because mount is run as root + defaults
+ chown system system /resources
+ chmod 0771 /resources
+ # We chown/chmod /ivres again so because mount is run as root + defaults
+ chown system system /ivres
+ chmod 0771 /ivres
+ #end add by zhaojr
#Create NDD mount point
mkdir /data/vendor/camera_dump
chown root system /data/vendor/camera_dump
chmod 0771 /data/vendor/camera_dump
4、添加挂载分区的selinux权限,否则系统启动无法挂载
device/autochips/sepolicy/bsp/non_plat/device.te
device/autochips/sepolicy/bsp/non_plat/file.te
device/autochips/sepolicy/bsp/non_plat/file_contexts
device/autochips/sepolicy/bsp/non_plat/fsck.te
device/autochips/sepolicy/bsp/non_plat/init.te
device/autochips/sepolicy/bsp/non_plat/system_app.te
4.1 定义设备块文件
device/autochips/sepolicy/bsp/non_plat/device.te
# add by zhaojr
# Purpose: Add cpuinfo partition sepolicy
type cpuinfo_device, dev_type;
type cpuinfo_block_device, dev_type;
# Purpose: Add resources partition sepolicy
type resources_device, dev_type;
type resources_block_device, dev_type;
# Purpose: Add ivres partition sepolicy
type ivres_device, dev_type;
type ivres_block_device, dev_type;
# end add by zhaojr
4.2 定义文件类型
device/autochips/sepolicy/bsp/non_plat/file.te
# add by zhaojr
# Date : 2019/05/27
# Operation : Migration
# Purpose: Add cpuinfo partition sepolicy
type cpuinfo_file, file_type, data_file_type;
# Date : 2019/05/27
# Operation : Migration
# Purpose: Add resources partition sepolicy
type resources_file, file_type, data_file_type;
# Date : 2019/05/27
# Operation : Migration
# Purpose: Add ivres partition sepolicy
type ivres_file, file_type, data_file_type;
#end add by zhaojr
4.3 添加分区生成和挂载目录的访问权限
device/autochips/sepolicy/bsp/non_plat/file_contexts
# add for avm partition
/dev/block/platform/bootdevice/by-name/avm u:object_r:avm_block_device:s0
/avm(/.*)? u:object_r:avm_file:s0
# add by zhaojr
# add for cpuinfo partition
/dev/block/platform/bootdevice/by-name/cpuinfo u:object_r:cpuinfo_block_device:s0
/cpuinfo(/.*)? u:object_r:cpuinfo_file:s0
# add for resources partition
/dev/block/platform/bootdevice/by-name/resources u:object_r:resources_block_device:s0
/resources(/.*)? u:object_r:resources_file:s0
# add for ivres partition
/dev/block/platform/bootdevice/by-name/ivres u:object_r:ivres_block_device:s0
/ivres(/.*)? u:object_r:ivres_file:s0
# end add by zhaojr
# add for backcar partition
/data/vendor/backcar(/.*)? u:object_r:backcar_file:s0
4.4 添加fsck访问分区的权限
device/autochips/sepolicy/bsp/non_plat/fsck.te
#============= fsck ==============
allow fsck sysfs_fs_ext4_features:dir search;
allow fsck avm_block_device:blk_file rw_file_perms;
#add by zhaojr
allow fsck cpuinfo_block_device:blk_file rw_file_perms;
allow fsck resources_block_device:blk_file rw_file_perms;
allow fsck ivres_block_device:blk_file rw_file_perms;
#end add by zhaojr
4.5 添加init和system进程访问的权限
device/autochips/sepolicy/bsp/non_plat/init.te
# for avm partition
allow init avm_block_device:blk_file relabelto;
allow init avm_file:dir mounton;
#add by zhaojr
# for cpuinfo partition
allow init cpuinfo_block_device:blk_file relabelto;
allow init cpuinfo_file:dir mounton;
# for resources partition
allow init resources_block_device:blk_file relabelto;
allow init resources_file:dir mounton;
# for ivres partition
allow init ivres_block_device:blk_file relabelto;
allow init ivres_file:dir mounton;
#end add by zhaojr
# for backcar partition
allow init backcar_file:dir mounton;
device/autochips/sepolicy/bsp/non_plat/system_app.te
# for avm partition access
allow system_app avm_file:file { getattr unlink open read write create };
allow system_app avm_file:dir rw_dir_perms;
allow system_app atc_cem_prop:file { getattr open };
allow system_app atccam_prop:file { getattr open };
allow system_app hal_fastavm_daemon:fd use;
#add by zhaojr for partition system access
# for cpuinfo partition access
allow system_app cpuinfo_file:file { getattr unlink open read write create };
allow system_app cpuinfo_file:dir rw_dir_perms;
# for resources partition access
allow system_app resources_file:file { getattr unlink open read write create };
allow system_app resources_file:dir rw_dir_perms;
# for ivres partition access
allow system_app ivres_file:file { getattr unlink open read write create };
allow system_app ivres_file:dir rw_dir_perms;
#end add by zhaojr for partition system access
# Date: 2019/05/27
# Purpose: Allow app to get atc_backcar_prop
# Package: app
get_prop(system_app, atc_backcar_prop);
全部修改完成后,全编译系统,然后烧录即可。
参考文章,主要目前还没有设备,无法调试,记录学习,准备工作
REF:
https://blog.csdn.net/jinron10/article/details/109239465
网友评论