具体现象:源码位置NativeDaemonConnector.java(查看VOLD的TAG)
02-10 01:21:02.340: E/VoldConnector(11051): got -1 reading with start = 0
02-10 01:21:02.340: E/VoldConnector(11051): closing stream for vold
02-10 01:21:02.340: E/VoldConnector(11051): Communications error: java.io.IOException: No such file or directory
02-10 01:21:02.340: E/VoldConnector(11051): Error in NativeDaemonConnector: java.io.IOException: No such file or directory
分析:在不做任何程序上的修改的情况下,插入USB无线网卡是没有问题的。目前打印机和无线网卡都是没有上报信息的,这就排除了上报消息的原因了。目前的区别是DEVTYPE,前者是无,后者是有的。
查看所有error时找出了问题所在:
NetlinkEvent::FindParam(): Parameter ‘DEVTYPE‘ not found
果真是之前的假设问题,在获取DEVTYPE时出的问题。
以下就是如何在内核的usb打印机驱动中添加DEVTYPE的问题,花费了一下午的时间以下的diff文件:
diff --git a/kernel/drivers/usb/class/usblp.c b/kernel/drivers/usb/cl index 9eca405..b528437 100755 --- a/kernel/drivers/usb/class/usblp.c +++ b/kernel/drivers/usb/class/usblp.c @@ -1046,8 +1046,13 @@ static const struct file_operations usblp_fops .llseek = noop_llseek, }; +static struct device_type printer_type = { + .name = "printer", +}; + static char *usblp_devnode(struct device *dev, mode_t *mode) { + dev->type=&printer_type; return kasprintf(GFP_KERNEL, "usb/%s", dev_name(dev)); } @@ -1072,6 +1077,7 @@ static ssize_t usblp_show_ieee1284_id(struct de static DEVICE_ATTR(ieee1284_id, S_IRUGO, usblp_show_ieee1284_id, NUL + static int usblp_probe(struct usb_interface *intf, const struct usb_device_id *id) { @@ -1079,6 +1085,8 @@ static int usblp_probe(struct usb_interface *in struct usblp *usblp; int protocol; int retval; + //dev->children[0]->dev.type=&printer_type; + //dev->dev.type=&printer_type; /* Malloc and start initializing usblp structure so we can us * directly. */注:注释的那两条是测试的过但是不成功的方法。
这里点名感谢一下《Linux驱动》群中的LinuxDrv群主。一步步指点着添加成功了。如下图: