Linux上USB移植错误解决笔记
在内核目录下先配置支持USB设备,无论你是什么设备,这一步都是必须的,USB驱动和其他的驱动不同,它分为USB设备驱动,另外还有USB-Host主机控制器的驱动,配置如下:
Device Drivers --->
SCSI device support --->
<*> SCSI device support
<*> SCSI disk support
以上是为了支持U盘挂载,U盘在Linux中被识别为SCSI设备。
Device Drivers --->
<*> USB Monitor
<*> OHCI HCD support
[*] USB device filesystem (DEPRECATED)
[*] USB device class-devices (DEPRECATED)
[*] Dynamic USB minor allocation
这就可以了,这几项是必须选的,因为这里面的OHCI HCD是主机控制器的驱动,不选的话,就算你USB设备驱动写出来了,也无法被主机识别。
接下来再选一下HID设备:
[*] HID Devices --->
这个可以自主的选择,我关注的是主机控制器的驱动:
直接编译内核,烧写,启动,弹出错误,插入USB设备:
usb 1-1: device descriptor read/64, error -62
usb 1-1: device descriptor read/64, error -62
usb 1-1: new full speed USB device using s3c2410-ohci and address 3
usb 1-1: device descriptor read/64, error -62
usb 1-1: device descriptor read/64, error -62
usb 1-1: new full speed USB device using s3c2410-ohci and address 4
usb 1-1: device not accepting address 4, error -62
usb 1-1: new full speed USB device using s3c2410-ohci and address 5
usb 1-1: device not accepting address 5, error -62
hub 1-0:1.0: unable to enumerate USB device on port 1
最后一句的意思是,设备枚举失败,error -62的意思时超时错误。从这里可以看出,系统应该是识别到了USB设备,但是设备却无法工作,而且可以断定是USB主机控制器的错误。的确如此,百度一下,网上说这是时钟错误,也就是USB是时钟没有起来,对于2440,USB时钟需要工作在48M。修改内核源码:
添加时钟初始化的代码,这个网上有很多版本,自己随意去找一个,无非就是给UPLLCON寄存器写个数值进去。这里我就不详细介绍了,但是我不知道为什么,我在内核中添加时钟初始化代码,就是写入UPLLCON寄存器,写入了0x00038022,这是配置USB时钟为48M的数值,但是很不幸,写入是成功的,我把这个寄存器的值重新读出来,printk了一下,也是对的。编译,下载,测试,照样出错。
也就是说USB时钟还是不工作。遇到这种情况,看数据手册去,手册上说配置PLL的时候,有MPLLCON和UPLLCON两个寄存器,要先配置UPLLCON,再配置MPLLCON寄存器,而MPLLCON在哪配置的呢,原来是这样,也就是说我们配置顺序不对,所以在内核中配置UPLLCON会失败,那我们就去改改u-boot代码吧,在u-boot的start.S中添加UPLLCON的配置,也就三行代码:
ldr r0,= 0x4c0000008;
ldr r1,=0x000038022;
str r1, [r0]
这三句要加在MPLLCON之前,同时在两次配置之间至少要起个nop指令的间隔,这是数据手册要求的。
重新烧写u-boot,启动内核,插入USB无线鼠标,奇迹出现了,
usb 1-1: new low speed USB device using s3c2410-ohci and address 3
usb 1-1: New USB device found, idVendor=1bcf, idProduct=05ca
usb 1-1: New USB device strings: Mfr=0, Product=2, SerialNumber=0
usb 1-1: Product: 2.4GHz 2way RF Receiver
usb 1-1: configuration #1 chosen from 1 choice
input: 2.4GHz 2way RF Receiver as /class/input/input1
generic-usb 0003:1BCF:05CA.0001: input,hidraw0: USB HID v1.00 Keyboard [2.4GHz 2way RF Receiver] on usb-s3c24xx-1/input0
input: 2.4GHz 2way RF Receiver as /class/input/input2
generic-usb 0003:1BCF:05CA.0002: input,hiddev0,hidraw1: USB HID v1.00 Mouse [2.4GHz 2way RF Receiver] on usb-s3c24xx-1/input1
识别出来了,OK,移植成功。之前在内核源码部分改了将近一天,但是还是不行。不知道有些人为什么改内核源码却成功了,唯一的解释就是内核的版本不同,可能会有一些差异,所以在这里我的建议是你先改内核源码,这个网上有很多介绍,如果改完了不行,就用我这里介绍的改u-boot的源码,你可以仔细阅读一些数据手册。
我做这个移植,搞了将近两天,我从来没有想到问题是在bootloader上面,因为现在在准备考研阶段,也就是没事随便搞搞,今天上午,差点就放弃了,去看考研书去了。当初要是放弃了,真的,那么昨天的一天真就白花了,浪费了一天还啥都没搞明白,所以又坚持了一下,总算搞定了,所以凡事都要不要轻言放弃,想放弃的时候想想当初为何走到这一步……
PS:我们的荣誉不是在于永远成功,而是在于失败和绝望时能找到重新站起来的希望,勇敢的面对困难战胜困难。
冰雪王爵.obj
2014年6月10日