1.引子

1.引子

天有不测风云,人有旦夕祸福。在2007年的夏天,我那可爱的电脑声卡坏了。

朋友给我推荐了一款飞利浦的外置声卡PSC805,老实说,声卡还能用外置的,的确让我觉得新鲜,它直接用USB连接,价钱也还可以。所以我去了一趟中关村买了一块外置声卡。

然而,在店家那里好好的声卡买回来之后居然连指示灯都不亮,根本没法用。不是完全不亮,一开始会亮,然后就不亮了。凭直觉,我判定这是软件的问题,因为我用的是Linux操作系统。

从指示灯这个现象来看,我估计是电源管理部分的问题,我听说Linux内核2.6.20左右在USB部分开始加入了电源管理的代码,我觉得这部分代码不够成熟,问题很多也是很正常的,只是没想到我成了试验品。

我很冷静地分析问题,首先这块声卡是使用USB接口的,供电有问题,那么应该是USB驱动部分的问题而不应该是声卡驱动的问题,声卡驱动是snd-usb-audio,查看了日志文件,实际上问题出现在这个模块被加载之前,所以可以排除声卡驱动的问题。然后我觉得问题可能出现在Linux中Hub驱动的部分,也可能出现在主机控制器驱动的部分。这下子问题稍微麻烦了一些,我完全不清楚究竟应该分析哪个部分,于是我做了一次选择,我猜测问题会在Hub驱动方面,Hub驱动也就是三千多行代码,看了看时间,一个晚上应该是能看完的,狠一狠心,真就看了起来。

引子写到这也就该结束了,大多数人也许都会觉得我最后一定通过看代码解决了问题,然后才会写下下面的这些文字,实际上不是的,我花了一夜看完了Hub驱动的代码,然而并没有发现任何异常,后来我终于知道,这个问题并不是出在Hub驱动的部分,它实际上与UHCI主机控制器的驱动代码有关,算是UHCI驱动的一个Bug。但是既然我看了Hub驱动的代码,也不妨用文字把它记录下来,就算是为了纪念这样一个夜晚吧。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章