免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3479 | 回复: 3
打印 上一主题 下一主题

寻求解答:开发usb驱动,probe里指针跑飞 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-10-18 09:31 |只看该作者 |倒序浏览
我正在开发usb驱动,用的是万能驱动usb-skeleton.
然后模块加载,当插入该设备后,往我的probe里面走的时候
        for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i)
这个循环次数并没有附上,我打出来是0,好象是iface_desc = interface->cur_altsetting;这句赋值没有成功似的.
然后我硬把那个循环次数赋了个5,结果的确是往循环里走了,但程序就出现
BUG: unable to handle kernel NULL pointer dereference at virtual address 00000003

地址就是我的这个probe函数,请求解决.

论坛徽章:
0
2 [报告]
发表于 2011-10-13 21:19 |只看该作者
今天我也遇到这个问题了。不过我在skel_probe函数里面第一行加上 printk(KERN_DEBUG"run to skel_probe"); 结果还是一样的错误,控制台也没收到这条打印信息!!!期待高手来解答!!!

论坛徽章:
0
3 [报告]
发表于 2011-10-13 21:25 |只看该作者
# insmod usb-skeleton.ko
usbcore: registered new interface driver skeleton
/ # usb 1-1.1: new full speed USB device using s3c2410-ohci and address 3
usb 1-1.1: New USB device found, idVendor=10c4, idProduct=0000
usb 1-1.1: New USB device strings: Mfr=1, Product=2, SerialNumber=0
usb 1-1.1: Product: C8051F326 Development Board
usb 1-1.1: Manufacturer: SILICON LABORATORIES INC.
one_wire_status: 5
Unable to handle kernel NULL pointer dereference at virtual address 00000000
pgd = c0004000
[00000000] *pgd=00000000
Internal error: Oops: 17 [#1] PREEMPT
last sysfs file: /sys/kernel/ipv4/tcp_wmem_max
Modules linked in: usb_skeleton zd1211rw rt2800usb rt2800lib rt73usb rt2x00usb r
t2x00lib ath9k_htc ath9k_common mac80211 ath9k_hw ath libertas_sdio libertas cfg
80211 compat
CPU: 0    Not tainted  (2.6.36-FriendlyARM #1)
PC is at kmem_cache_alloc+0x3c/0xbc
LR is at kmem_cache_alloc+0x30/0xbc
pc : [<c01e3134>]    lr : [<c01e3128>]    psr: 60000093
sp : ce067d18  ip : c0626b0d  fp : c54a7a00
r10: bf168a04  r9 : c06dcccc  r8 : bf168a90
r7 : bf168490  r6 : 60000013  r5 : 000080d0  r4 : c06c0094
r3 : 00000000  r2 : 60000013  r1 : ffffffff  r0 : 00000000
Flags: nZCv  IRQs off  FIQs on  Mode SVC_32  ISA ARM  Segment kernel
Control: 00c5387d  Table: 5e03c008  DAC: 00000017

PC: 0xc01e30b4:
...

论坛徽章:
0
4 [报告]
发表于 2011-10-13 22:40 |只看该作者
好像是为设备分配内存里发生了错误。因为在 dev=kzalloc(sizeof(*dev),GFP_KERNEL); 这一句之前加一条打印信号可以输出,在之后也加一条打印信息就没有输出到控制台 之后就重启了 真不知道怎么搞:dizzy:只好睡觉了!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP