一种android系统实现动态挂载sdcard或emmc为系统data分区的方法

一种动态实现挂载系统data分区的实现思路,即开机检测到ext4类的sd卡则挂载sdcard作为android系统的data分区,如果没有检测到sdcard就按照/etc/fstab存放的是系统中的文件系统信息挂载emmc作为系统的data分区,主要涉及到vold fs_mgr 进程的修改;

/system/core/fs_mgr/fs_mgr.c

static int mount_with_alternatives(struct fstab *fstab, int start_idx, int *end_idx, int *attempted_idx, int encryptable)
{
 
    int i, j;     //  modify auto mount sdcard for data partition feature 
    int mount_errno = 0;
    int mounted = 0;
    // modify auto mount sdcard for data partition feature 
    char *token_str[20]; 
    char str[100];    
    //end
  if (!end_idx || !attempted_idx || start_idx >= fstab->num_entries) {
      errno = EINVAL;
      if (end_idx) *end_idx = start_idx;
      if (attempted_idx) *end_idx = start_idx;
      return -1;
    }

    /* Hunt down an fstab entry for the same mount point that might succeed */
    for (i = start_idx;
         /* We required that fstab entries for the same mountpoint be consecutive */
         i < fstab->num_entries && !strcmp(fstab->recs[start_idx].mount_point, fstab->recs[i].mount_point);
         i++) {
            /*
             * Don't try to mount/encrypt the same mount point again.
             * Deal with alternate entries for the same point which are required to be all following
             * each other.
             */
            if (mounted) {
                ERROR("%s(): skipping fstab dup mountpoint=%s rec[%d].fs_type=%s already mounted as %s.\n", __func__,
                     fstab->recs[i].mount_point, i, fstab->recs[i].fs_type, fstab->recs[*attempted_idx].fs_type);
                continue;
            }
	    //modify auto mount sdcard for data partition feathure start
	    memset(str, 0, sizeof(str)/sizeof(char));
	    strncpy(str, fstab->recs[i].blk_device, strlen(fstab->recs[i].blk_device));
	    token_str[0] = strtok(str, "/");
	    for (j = 1; j < 20; j++) {
		    token_str[j] = strtok(NULL, "/");
		    if (!token_str[j]) 
			    break;
	    }
	    if(!strncmp(token_str[j-1], "userdata", strlen(token_str[j-1]))) {
	        if (!mount("/dev/block/mmcblk1p1", fstab->recs[i].mount_point, fstab->recs[i].fs_type, 
					MS_NOATIME | MS_NOEXEC | MS_NOSUID, "errors=remount-ro,nomblk_io_submit") 
				&& !umount(fstab->recs[i].mount_point)) {
			INFO("%s(): /dev/block/mmcblk1p1 try to mount/unmount(%s) succeeded\n", __func__, fstab->recs[i].mount_point);
			free(fstab->recs[i].blk_device);
			fstab->recs[i].blk_device = strdup("/dev/block/mmcblk1p1");
		}
	    } 
	    INFO("%s(): blk_device: %s,  mountpoint=%s rec[%d].fs_type=%s mounted as %s.\n", __func__,
                     fstab->recs[i].blk_device, fstab->recs[i].mount_point, i, fstab->recs[i].fs_type, fstab->recs[*attempted_idx].fs_type);
    //end
    #ifdef MTK_FSTAB_FLAGS
            if(fstab->recs[i].fs_mgr_flags & MF_RESIZE) {
                check_fs(fstab->recs[i].blk_device, fstab->recs[i].fs_type,
                         fstab->recs[i].mount_point);
                resize_fs(fstab->recs[i].blk_device, fstab->recs[i].key_loc);
            }
  #endif

修改vendor/mediatek/proprietary/hardware/fstab/platform/fstab.in文件设置data分区默认不加密

# /dev/block/platform/mtk-msdc.0/11230000.MSDC0/by-name/userdata   /data        ext4   noatime,nosuid,nodev,noauto_da_alloc,discard               wait,check,resize

/dev/block/platform/mtk-msdc.0/11230000.MSDC0/by-name/userdata   /data        ext4   noatime,nosuid,nodev,noauto_da_alloc,discard               wait,check,resize,FLAG_FDE_AUTO=/dev/block/platform/mtk-msdc.0/11230000.MSDC0/by-name/metadata,FLAG_FDE_TYPE

注意Google 要求中高端手机都必须强制性启用加密, 只有超低端的机器可以不加密, 在CTS 中有强制性审查项,需要过GMS认证的版本修改此项会影响过认证;

SD卡处理
由于sd卡和emmc读写速度存在较大差异,挂载sd卡作为data分区,android系统起来后系统性能会有一定影响,为了减少这种影响,sd卡必须选用高性能高速卡
以linux系统下gparted工具为例:
生成分区表为gpt格式的.
新加一个主分区为ext4格式.
sd卡剩余部分可以新增为fat32格式主分区作为外置TF卡使用.

包含ext4分区的sd卡做好后,可以挂在到linux系统下的目录上,对sd卡作一些操作,例如:拷贝apk,等文件到sd卡ext4分区,可以实现预置应用,文件等功能

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值