首页 > 代码库 > android4.0 U盘热插拔后挂载不上bug解决
android4.0 U盘热插拔后挂载不上bug解决
这几天测试的时候发现个很奇怪的问题 如果将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解决
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。