admin管理员组文章数量:1567271
这几天测试的时候发现个很奇怪的问题 如果将TF卡插到读卡里然后在插到板子上 热插拔后都可以挂载上 但是使用U盘只有第一次插上去的时候能挂载上 拔下来后 在插上就挂载不上了 驱动里可以识别到U盘已经插入 研究了MountService和Vold 最后通过查看/proc/mounts文件发现 U盘第一次插上后是正常挂载 但是拔掉后没有卸载 多么纠结的事件 主要涉及文件system/vold/DirectVolume.cpp
分析log发现 拔掉带有TF卡的读卡器时 状态是这样的
4(Mounted) -> 5(Unmounting)
5(Unmounting) -> 1(Idle-Unmounted)
1(Idle-Unmounted) -> 0(No-Media)
而U盘拔掉状态是这样的
4(Mounted) ->0(No-Media)
拔掉带有TF卡的读卡器时最后执行了这样两个函数
先执行了
handlePartitionRemoved
然后执行了
handleDiskRemoved
拔掉U盘时最后执行了函数只执行了
handleDiskRemoved
而卸载的函数是在handlePartitionRemoved里执行的所以修改handleDiskRemoved函数
修改后如下
void DirectVolume::handleDiskRemoved(const char *devpath, NetlinkEvent *evt) {
int major = atoi(evt->findParam("MAJOR"));
int minor = atoi(evt->findParam("MINOR"));
char msg[255];
SLOGD("Volume %s %s disk %d:%d removed\n", getLabel(), getMountpoint(), major, minor);
snprintf(msg, sizeof(msg), "Volume %s %s disk removed (%d:%d)",
getLabel(), getMountpoint(), major, minor);
mVm->getBroadcaster()->sendBroadcast(ResponseCode::VolumeDiskRemoved,
msg, false);
if(getState() == Volume::State_Mounted) {//add by hclydao for udisk
if (Volume::unmountVol(true, false)) {
SLOGE("Failed to unmount volume on bad removal (%s)",
strerror(errno));
// XXX: At this point we're screwed for now
} else {
SLOGD("Crisis averted");
}
}
setState(Volume::State_NoMedia);
}
增加了中间的这个判断
if(getState() == Volume::State_Mounted) {//add by hclydao for udisk
if (Volume::unmountVol(true, false)) {
SLOGE("Failed to unmount volume on bad removal (%s)",
strerror(errno));
// XXX: At this point we're screwed for now
} else {
SLOGD("Crisis averted");
}
}
重新编译vold 然后push到板子 重启 就可以了
初步测试是没问题了
版权声明:本文标题:android4.0 U盘热插拔后挂载不上bug解决 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1727575692a1121600.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论