FTxxxx系列------Unable to handle kernel NULL pointer

log如下:

    5.930865] (CPU:0-pid:1:swapper/0)Unable to handle kernel NULL pointer dereference at virtual address 0000000c
[ 5.940886] (CPU:0-pid:1:swapper/0)pgd = ffffffc001bd6000
[ 5.946243] (CPU:0-pid:1:swapper/0)[0000000c] *pgd=00000000eec18003[ 5.952333] (CPU:0-pid:1:swapper/0), *pud=00000000eec18003[ 5.957615] (CPU:0-pid:1:swapper/0), *pmd=00000000eec19003[ 5.962923] (CPU:0-pid:1:swapper/0), *pte=006000000b000707[ 5.968204] (CPU:0-pid:1:swapper/0)
[ 5.971695] (CPU:0-pid:1:swapper/0)Internal error: Oops: 96000045 [#1] PREEMPT SMP
[ 5.979232] (CPU:0-pid:1:swapper/0)Modules linked in:[ 5.984091] (CPU:0-pid:1:swapper/0)
[ 5.987567] (CPU:0-pid:1:swapper/0)CPU: 0 PID: 1 Comm: swapper/0 Not tainted 3.18.20-gf749edab-dirty #73
[ 5.997025] (CPU:0-pid:1:swapper/0)Hardware name: Qualcomm Technologies, Inc. MSM8937-PMI8950 MTP (DT)
[ 6.006315] (CPU:0-pid:1:swapper/0)task: ffffffc06ed20000 ti: ffffffc06ed1c000 task.ti: ffffffc06ed1c000
[ 6.015780] (CPU:0-pid:1:swapper/0)PC is at ftxxxx_ts_probe+0x90/0xfb8
[ 6.022288] (CPU:0-pid:1:swapper/0)LR is at ftxxxx_ts_probe+0x8c/0xfb8


代码如下:

unsigned char uc_reg_value;
unsigned char uc_reg_addr;
//extern char asus_lcd_id[2];
//touch_control=1

printk("[Focal][Touch] FTxxxx probe process Start !\n");
/*get some register information */
/* uc_reg_addr = FTXXXX_REG_FW_VER;
err = ftxxxx_i2c_Read(client, &uc_reg_addr, 1, &uc_reg_value, 1);
printk("[Focal][Touch] matt-failure\n");
if (err < 0)
{
printk("[Focal][Touch] return \n");
ftxxxx_ts->init_success = 0;
kfree(pdata);
kfree(input_dev);
printk("[Focal][Touch] return 1\n");
return 1;
}
else {
ftxxxx_ts->init_success = 1;
// printk("hjptest--->[Focal][Touch] Firmware version = 0x%x\n", uc_reg_value);
}*/


最后发现是因为ftxxxx_ts这个结构体是在后面才init的而我提前用了init_success这个成员变量,浪费半天时间。。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"unable to handle kernel null pointer dereference at virtual address"是一个内核错误信息,意味着操作系统内核在处理时遇到了一个空指针解引用错误。空指针解引用错误是指当程序试图引用一个空指针(即指向空的内存地址)时发生的错误。 这种错误通常发生在程序访问或者操作指针指向的内存空间之前没有进行有效的判空处理。在操作系统内核中,这个错误特别严重,因为操作系统的内核负责管理整个计算机的硬件和软件资源,任何内核错误都可能导致系统崩溃或者异常。 解决这个问题需要审查出错的代码,找到导致空指针解引用错误的原因。一般来说,这种错误可能出现在以下情况下: 1. 未初始化指针:确保在使用指针之前已经正确初始化,给指针分配了有效的内存空间。 2. 未对指针进行有效的判空处理:在对指针进行解引用操作之前,应该先检查指针是否为空,防止出现空指针解引用错误。 3. 内存越界访问:确保在访问指针所指向的内存空间时,没有超出该空间的边界。 修复空指针解引用错误需要仔细检查代码并进行调试,以找到错误的根本原因。然后,根据具体情况,可以采取一些措施,如添加有效的判空处理、初始化指针、检查内存边界等,以防止类似的错误再次发生。这样能够保证系统的稳定性和可靠性。在开发过程中,遵循良好的编码规范和使用可靠的调试工具也能够帮助我们尽早发现和解决空指针解引用错误。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值