linux通过usb端口绑定到固定的串口号

我们在安卓设备上经常会用到usb转串口的设备,而usb转串口的设备生成的设备号是按usb枚举的顺序生成的,所以同一个usb设备每次开机之后生成的串口序号可能不相同,通过下面的补丁可以解决这个问题。

Index: kernel/drivers/usb/serial/usb-serial.c
===================================================================
--- kernel/drivers/usb/serial/usb-serial.c	(revision 1851)
+++ kernel/drivers/usb/serial/usb-serial.c	(working copy)
@@ -85,20 +85,74 @@
 	return port;
 }
 
-static int allocate_minors(struct usb_serial *serial, int num_ports)
+static int allocate_minors(struct usb_serial *serial, int num_ports,char * dev_name)
 {
 	struct usb_serial_port *port;
 	unsigned int i, j;
-	int minor;
+	int minor,tmpmiior;
 
 	dev_dbg(&serial->interface->dev, "%s %d\n", __func__, num_ports);
 
 	mutex_lock(&table_lock);
+printk("dev_name = %s\n",dev_name);
 	for (i = 0; i < num_ports; ++i) {
 		port = serial->port[i];
-		minor = idr_alloc(&serial_minors, port, 0, 0, GFP_KERNEL);
-		if (minor < 0)
-			goto error;
+      
+	   printk("num_ports = %d\n",num_ports);
+
+	   if(!strcmp(dev_name,"2-1.7")) //USB0
+		 {
+		 minor = idr_alloc(&serial_minors, port, 0, 4, GFP_KERNEL);
+			 if (minor < 0)
+			   goto error;
+		 }
+      else
+      	{
+	   
+	   if(!strcmp(dev_name,"1-1.1")) //USB0
+	   {
+			   minor = 5;
+	   }
+		 else if(!strcmp(dev_name,"2-1.6.1")) //USB0
+		{
+				minor = 6;
+		}
+
+		else if(!strcmp(dev_name,"2-1.5.1")) //USB0
+	   {
+			   minor = 7;
+	   }
+
+		else if(!strcmp(dev_name,"2-1.4.1")) //USB0
+ 	   {
+ 			   minor = 8;
+ 	   }
+ 	   else if(!strcmp(dev_name,"2-1.3.1"))
+ 	   {
+ 			   minor = 9; 
+ 	   }
+ 	   else if(!strcmp(dev_name,"2-1.2.1"))
+ 		{
+ 				minor = 10;
+ 		}
+	    else if(!strcmp(dev_name,"2-1.1.1"))
+ 		{
+ 				minor = 11;
+ 		}
+	  
+		 tmpmiior=idr_alloc(&serial_minors, port, 5, 20, GFP_KERNEL);
+		 if (minor < 0)
+	   		goto error;
+
+	   }
+ 	/*   else if(!strcmp(dev_name,"2-1.7"))
+ 	   {
+ 				i = 7;
+ 	   }*/
+		//minor = idr_alloc(&serial_minors, port, 0, 0, GFP_KERNEL);
+		//if (minor < 0)
+		//	goto error;
+
 		port->minor = minor;
 		port->port_number = i;
 	}
@@ -1058,7 +1112,7 @@
 	 */
 	serial->disconnected = 1;
 
-	if (allocate_minors(serial, num_ports)) {
+	if (allocate_minors(serial, num_ports,dev_name(&port->serial->dev->dev))) {
 		dev_err(ddev, "No more free serial minor numbers\n");
 		goto probe_error;
 	}

后来发现以上方法有问题,串口好是改了,系统没费配到改的串口号就是手动改的串口号并不是idr_alloc 分配出来的串口号,导致去打开的时候经常打不开,终极解决方法如下:

#!/system/bin/sh

creat_tty_symlink(){
	tty0=$(ls -l /sys/class/tty/$1)
	hastty=$(ls  /sys/class/tty*)
	#goal="2-1.1"
	echo "parameter1 is "$1
	echo "hastty is "$hastty
	if [[ $tty0 == *"2-1.1"* ]] ; then
	     if [[ $hastty == *"ttyXRUSB1"* ]] ; then
		    echo "ttyXRUSB1 exsit"
		 else
			 echo "creat ttyXRUSB1"
			 rm  /dev/ttyXRUSB1
			 ln -s /dev/$1 /dev/ttyXRUSB1
			 chown system:system /dev/ttyXRUSB1
		 fi
		 
	elif  [[ $tty0 == *"2-1.2"* ]] ; then
	     if [[ $hastty == *"ttyXRUSB2"* ]] ; then
			echo "ttyXRUSB2 exsit"
		 else
		 echo "creat ttyXRUSB2"
			 rm  /dev/ttyXRUSB2
			 ln -s /dev/$1 /dev/ttyXRUSB2
			 chown system:system /dev/ttyXRUSB2
		 fi
	elif  [[ $tty0 == *"2-1.3"* ]] ; then 
	     if [[ $hastty == *"ttyXRUSB3"* ]] ; then
			echo "ttyXRUSB3 exsit"
		 else
			 echo "creat ttyXRUSB3"
			 rm  /dev/ttyXRUSB3
			 ln -s /dev/$1 /dev/ttyXRUSB3
			 chown system:system /dev/ttyXRUSB3
	     fi
	elif  [[ $tty0 == *"2-1.4"* ]] ; then 
		 if [[ $hastty == *"ttyXRUSB4"* ]] ; then
			echo "ttyXRUSB4 exsit"
		 else
			 echo "creat ttyXRUSB4"
			 rm  /dev/ttyXRUSB4
			 ln -s /dev/$1  /dev/ttyXRUSB4
			 chown system:system /dev/ttyXRUSB4			 
		fi
     else
	    echo "end"
	 fi



}


while true
do
    creat_tty_symlink ttyUSB0
	sleep 1
	creat_tty_symlink ttyUSB1
	sleep 1
    creat_tty_symlink ttyUSB2
	sleep 1
	creat_tty_symlink ttyUSB3
	sleep 1
	creat_tty_symlink ttyUSB4
	sleep 2
done

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术求索者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值