linux内核驱动调试bug解读

在这里我是根据自己的项目来解读bug的,不一定适合其他人


1、之前使用NF_STOLEN,在外网运行的服务器还是可以收到udp调试工具发到外网服务器的udp数据包,一直很纳闷,中间在路由器上已经把udp数据包给截获了,理论上应该是收不到的,后来发现是在过滤数据包的时候过滤条件限制错了,所以发往外网的数据包成了漏网之鱼。

之前是if(in->name!=NULL)&&(0!=strcmp(in->name, "br-lan", 6)) 改成: if(in->name!=NULL)就可以了


2、实验验证printk打印太多会导致路由器崩溃


3、在路由器上卸载驱动时如果报错: "segment fault" 一般时exit()模块释放资源不正确,例如有的变量没有申请内存但是却在退出的时候释放内存


4、本项目的队列大小不是影响路由器崩溃的原因,因为我用1000*2048 和 10*2048 效果路由器的反应是一样的


5、之前认为钩到的数据包打印出来偏移错误,后来比对用wireshark捕获的数据包和在路由器上dmesg出来的是一样的,

      那么偏移为什么会出错呢,是因为钩到的udp包是外网发往内网,但是却误认为是内网发送到外网的udp,这两个udp 的payload很相似

猜你喜欢

转载自blog.csdn.net/manmanmanli/article/details/78131310