安卓挂载tf卡到自定义目录

为兼容旧固件,本文介绍如何通过修改Android系统Vold可执行文件,实现TF卡自动映射到自定义路径的功能。具体步骤涉及在PublicVolume.cpp中添加链接函数,并在编译后推送至设备。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求

最近有个需求,为了兼容之前的固件,需要把tf卡映射到指定路径.然后通过查询资料,最简单的方法就是在挂载的时候进行一个链接操作.实际只需要修改vold可执行文件就可以了.

修改方法

只需要修改如下文件
在这里插入图片描述
PublicVolume.cpp中修改如下:

status_t PublicVolume::doMount() {
    // TODO: expand to support mounting other filesystems
    readMetadata();
	LOG(ERROR) << getId() << "  filesystem " << mFsType;
	.
	.
	.
	.
	.
	.
	/* Modify by arunboy 20191128 */
	/*在return前面添加一个链接函数*/
    linkExternal();
	
    return OK;
}

/* Modify by arunboy 20191128 */
void PublicVolume::linkExternal() {
    std::string source(getPath());
	
    std::string target("/mnt/media");//自定义的链接路径
	
    if (TEMP_FAILURE_RETRY(unlink(target.c_str()))) {
        if (errno != ENOENT) {
            LOG(VERBOSE) << "Failed to unlink " << target.c_str() << strerror(errno);
        }
    }
	
    LOG(DEBUG) << "Linking " << source << " to " << target;
    if (TEMP_FAILURE_RETRY(symlink(source.c_str(), target.c_str()))) {
		LOG(ERROR) << "Failed to link " << source.c_str() << " to "
			<< target.c_str() <<  strerror(errno);
    }
}

编译会报错 需要在PublicVolume.h中声明一下这个函数.然后push到机器里面就可以,每次插入的时候会链接到指定的路径下面.如果文件存在,则会链接失败.

笔记

有一个切换tf卡和内部存储的顺序的地方记录一下.
framework/base/core/java/android/os/Environment.java

@@ -83,10 +85,25 @@ public class Environment {
             final StorageVolume[] volumes = StorageManager.getVolumeList(mUserId,
                     StorageManager.FLAG_FOR_WRITE);
             final File[] files = new File[volumes.length];
+                       /* Modify by arunboy 20191128 */
+                       //final File[] files_changer = new File[1];
+
             for (int i = 0; i < volumes.length; i++) {
                 files[i] = volumes[i].getPathFile();
             }
-            return files;
+
+                       /* Modify by arunboy 20191128 */
+                       /*if (PropertiesStringParser.checkMatch(
+                             SystemProperties.get("custom.exchange.storage", "dummy"),
+                             SystemProperties.get("custom.client.id", "YMYG"))) {
+                  if(volumes.length == 2) {
+                                       files_changer[0] = files[0];
+                                       files[0] = files[1];
+                                       files[1] = files_changer[0];
+                               }
+                   }*/
+
+                       return files;
         }


### OpenHarmony系统中挂载TF的方法 在OpenHarmony系统中,挂载TF的过程涉及到硬件初始化、驱动加载以及文件系统的配置等多个方面。以下是具体实现方法: #### 1. 硬件初始化与驱动加载 为了使TF能够被识别并正常工作,需要确保设备树(Device Tree)已正确配置,并且内核支持相应的MMC/SD控制器驱动程序。 - **设备树配置** 设备树应定义MMC控制器的相关参数,例如时钟频率、引脚分配等。如果目标平台为RK3568,则需确认其设备树节点是否包含`mmc`或`sdc`相关内容[^4]。 - **编译选项设置** 使用`make kernel_menuconfig`命令进入内核配置界面,启用以下功能模块以支持SD/MMC操作: - `CONFIG_MMC=y`: 启用通用MMC子系统支持。 - `CONFIG_SDHCI=y`: 启用Secure Digital Host Controller Interface (SDHCI)标准的支持。 - `CONFIG_NEW_LEDS=y`: 如果需要LED指示灯反馈,也可以一并开启此选项[^2]。 #### 2. 文件系统准备 完成上述步骤后,还需创建用于挂载的目标目录,并通过`mount`指令绑定实际分区至指定位置。 - 创建挂载点:假设希望将数据存放在根目录下的`data`文件夹里,则先执行如下命令建立相应结构; ```bash mkdir -p /mnt/tfcard ``` - 实施挂载动作前,可通过`dmesg | grep mmc`查看当前插入状态及可用块设备名称(通常表现为`/dev/mmcblkX`, X代表序号)。之后利用下面语法完成最终关联: ```bash mount /dev/mmcblk1p1 /mnt/tfcard ``` 注意替换其中的具体路径名以适配实际情况[^5]。 #### 3. 自动化处理机制构建 对于频繁使用的场景来说,手动输入这些繁琐的操作显然不够友好高效;因此推荐采用fstab方式来简化流程——编辑/etc/fstab文档,在末尾追加类似这样的条目即可达成目的: ``` /dev/mmcblk1p1 /mnt/tfcard auto rw,user,sync,noauto 0 0 ``` 这样以后每次重启或者重新插拔存储介质都会按照预设规则自动完成对应的任务而无需额外干预了[^1]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值