request_firmware 的用法,struct firmware,内核,固件,usb

【转帖请注明出处:blog.csdn.net/lanmanck】

 

网上有许多说明,ldd3也有:http://www.deansys.com/doc/ldd3/ch14s08.html。

对于刚使用的人来说,上面都说的笼统,说了等于没说,我总结一下:

1、request_firmware在内核使用,需要文件系统支持,就是说,启动的时候如果在驱动里面的probe函数调用request_firmware ,那么系统将等待30s左右,因为文件系统还没有挂载,当然找不到固件了,所以最好在中断里面启动tasklet,然后request_firmware 。如果不想等待,就用request_firmware_nowait,好像是这样写的。

 

2、那么用户层怎么用?这是初学者最易迷惑的,网上的基本都没有讲到。

实际上这个分x86和嵌入式,比如arm,平台。x86的用到了udev,我没有试。我说说arm平台的,用的是busybox的mdev。

比如你要请求固件 fw.hex,那么必须在文件系统中导出环境变量,比如 export FIRMWARE=/lib/firmware,而且目录/lib/firmware不能少,因为busybox要用到。然后把固件fw.hex放到/lib/firmware目录下即可。内核request_firmware的时候,busybox就知道去FIRMWARE找了。这实际上用到了mdev的热插拔功能:

echo /sbin/mdev > /proc/sys/kernel/hotplug

 

3、对linux来讲,所谓的固件什么也不是,他只是按fopen()返回二进制文件给你,看看busybox的处理就知道了。所以你的文件随便定义,比如一个mp3文件,你也可以称为固件:request_firmware("xxx.mp3"),那么你文件系统里面也要有这个xxx.mp3文件,只不过系统给你返回二进制数据,具体的处理要在内核进行。

 

讲到这大家应该都会用了,不对请指正。

你可能感兴趣的:(linux,struct,嵌入式,平台,X86)