当前位置:  技术问答>linux和unix

linux内核里面频繁分配和释放空间造成的系统奔溃

    来源: 互联网  发布时间:2017-03-12

    本文导语:  各位大侠们:你们好: 我最近在在tcp.c(netipv4)文件的int tcp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,size_t size)函数中加了一段代码(红色部分),奔溃信息在最后!我分析了一下是不是我在linux内核...

各位大侠们:你们好:
我最近在在tcp.c(netipv4)文件的int tcp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,size_t size)函数中加了一段代码(红色部分),奔溃信息在最后!我分析了一下是不是我在linux内核里面频繁分配和释放空间造成的系统奔溃!
忘高手织一条生路!!谢谢啦!!
int tcp_sendmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg,
size_t size)
{
struct iovec *iov;
struct tcp_sock *tp = tcp_sk(sk);
struct sk_buff *skb;
int iovlen, flags;
int mss_now, size_goal;
int sg, err, copied;
long timeo;
/*2012 8 23 mouchange*/
char *mouiov;
char *duiov;
int duiov_len;
struct crypto_comp *tfm;
int mouflag=0;
int ret;
struct iovec *mdiov;


lock_sock(sk);

flags = msg->msg_flags;
timeo = sock_sndtimeo(sk, flags & MSG_DONTWAIT);

/* Wait for a connection to finish. */
if ((1 sk_socket->flags);

mss_now = tcp_send_mss(sk, &size_goal, flags);

/* Ok commence sending. */
iovlen = msg->msg_iovlen;
iov = msg->msg_iov;
copied = 0;

err = -EPIPE;
if (sk->sk_err || (sk->sk_shutdown & SEND_SHUTDOWN))
goto out_err;

sg = sk->sk_route_caps & NETIF_F_SG;
/*2012 8 23 mouchange*/
if(iov->iov_len>2000)
{
mdiov=iov;

     if((mouiov=kmalloc(iov->iov_len, GFP_KERNEL)))
printk(KERN_INFO " tcp_sendmsg 2012 8 23 mouiov=kmalloc is Successn");
else
        printk(KERN_INFO " tcp_sendmsg 2012 8 23 mouiov=kmalloc is unSuccessn");
printk(KERN_INFO " tcp_sendmsg 2012 8 23 mouiov=kmalloc is %dn",ksize(mouiov));

if((duiov=kmalloc(iov->iov_len, GFP_KERNEL)))
printk(KERN_INFO " tcp_sendmsg 2012 8 23 duiov=kmalloc is Successn");
else
        printk(KERN_INFO " tcp_sendmsg 2012 8 23 duiov=kmalloc is unSuccessn");
printk(KERN_INFO " tcp_sendmsg 2012 8 23 duiov=kmalloc is %dn",ksize(duiov));

if(copy_from_user(mouiov,iov->iov_base,iov->iov_len))
printk(KERN_INFO " tcp_sendmsg 2012 8 23 copy_from_user is UnSuccessn");
else
        printk(KERN_INFO " tcp_sendmsg 2012 8 23 copy_from_user is Successn");

tfm = crypto_alloc_comp("deflate",0,0);
if(IS_ERR(tfm)) {
printk("failed to load transform for deflate !n");
release_sock(sk);
return 0;
}
ret = crypto_comp_compress(tfm,mouiov,iov->iov_len,duiov,&duiov_len);
if(ret) {
printk("failed to compress !n");
release_sock(sk);
//return copied;
return 0;
      }
printk(KERN_INFO " tcp_sendmsg iov->iov_len %d unSuccessn",iov->iov_len);
printk(KERN_INFO " tcp_sendmsg duiov_len %d unSuccessn",duiov_len);
iov->iov_base=duiov;
iov->iov_len=duiov_len;
crypto_free_comp(tfm);
kfree(mouiov);
mouflag=1;
}

while (--iovlen >= 0) {
size_t seglen = iov->iov_len;
unsigned char __user *from = iov->iov_base;
奔溃信息:
Aug 30 20:02:00 ubuntu kernel: [  266.030039] lftp: page allocation failure: order:4, mode:0x40d0
Aug 30 20:02:00 ubuntu kernel: [  266.030046] Pid: 1416, comm: lftp Not tainted 3.1.4 #15
Aug 30 20:02:00 ubuntu kernel: [  266.030050] Call Trace:
Aug 30 20:02:00 ubuntu kernel: [  266.030063]  [] warn_alloc_failed+0x97/0xf0
Aug 30 20:02:00 ubuntu kernel: [  266.030070]  [] __alloc_pages_nodemask+0x3dc/0x660
Aug 30 20:02:00 ubuntu kernel: [  266.030077]  [] __get_free_pages+0x1c/0x30
Aug 30 20:02:00 ubuntu kernel: [  266.030084]  [] kmalloc_order_trace+0x27/0x90
Aug 30 20:02:00 ubuntu kernel: [  266.030093]  [] ? tcp_established_options+0x30/0xb0
Aug 30 20:02:00 ubuntu kernel: [  266.030099]  [] __kmalloc+0x158/0x1b0
Aug 30 20:02:00 ubuntu kernel: [  266.030106]  [] ? tcp_send_mss+0x20/0xe0
Aug 30 20:02:00 ubuntu kernel: [  266.030112]  [] tcp_sendmsg+0xe3/0xae0
Aug 30 20:02:00 ubuntu kernel: [  266.030118]  [] ? get_page_from_freelist+0x258/0x4d0
Aug 30 20:02:00 ubuntu kernel: [  266.030126]  [] inet_sendmsg+0x47/0xb0
Aug 30 20:02:00 ubuntu kernel: [  266.030133]  [] sock_aio_write+0x14e/0x160
Aug 30 20:02:Aug 30 20:04:43 ubuntu kernel: imklog 4.2.0, log source = /proc/kmsg started.
Aug 30 20:04:43 ubuntu rsyslogd: [origin software="rsyslogd" swVersion="4.2.0" x-pid="648" x-info="http://www.rsyslog.com"] (re)start
Aug 30 20:04:43 ubuntu rsyslogd: rsyslogd's groupid changed to 103
Aug 30 20:04:43 ubuntu rsyslogd: rsyslogd's userid changed to 101
Aug 30 20:04:43 ubuntu rsyslogd-2039: Could no open output file '/dev/xconsole' [try http://www.rsyslog.com/e/2039 ]
Aug 30 20:04:43 ubuntu kernel: [    0.000000] Initializing cgroup subsys cpuset

|
lz在应用空间编程时,栈内存 和 堆内存 的生命周期了解否?
这里是内核态编程,对程序员要求更高,
栈内存能自动回收,kmalloc申请的,你不kfree,那就只有等到关机了

|
你的kmalloc和kfree个数有差异,kmalloc更多,会造成内存泄漏

此外,你这里的直接原因是kmalloc的大小超过了kmalloc的限制,kmalloc最大只能申请2M还是4M记不清了

你应该学习和选用更合理的设计,比如内存池

|
楼上说的很对,好好设计一下吧

    
 
 

您可能感兴趣的文章:

  • Linux内核中影响tcp三次握手的一些协议配置
  • 我想学习linux桌面编程,那么有没有必要学习linux的内核以及内核的相关编程呢?
  • TCP协议四次断连过程介绍及Linux内核协议栈中相关设置项
  • 现有linux内核中共享内存机制如何移植到linux0.11内核中
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • 读懂 Linux 内核代码不难,难的是读懂 Linux 内核代码背后的哲学!
  • linux内核中的likely宏和unlikely宏介绍及用法
  • Linux中内核线程不访问内核态地址空间?
  • Linux下c/c++开发之程序崩溃(Segment fault)时内核转储文件(core dump)生成设置方法
  • linux为什么要升级内核?升级内核有何作用?
  • 请问linux中如何判断内核是否已经启动。(在内核中写程序)
  • 《Linux内核情景分析》值得推荐的内核学习参考两用资料
  • *******是不是对内核模块编程然后再重新编译内核就可以把此模块整合到linux系统中
  • Linux 编译内核之后 没办法选择内核版本
  • 想看linux内核源代码,另外手头上有一本《unix环境高级编程》,需要先把《unix环境高级编程》看完之后再看内核吗?
  • 请问重新编译LINUX内核是否能将没有用的外设的驱动程序删除并减少内核占有内存的资源?请好心人仕指教!
  • Linux内核工具包 TOMOYO Linux
  • 请问:构建嵌入式linux环境时,“Linux内核的移植”是达到什么目的啊?
  • 求教,Linux下键盘输入的所有数据都会经过Linux内核吗???
  • 高深问题:有了linux内核源代码如何做成一个linux操作系统
  • linux内核编译一定要在linux环境下么?
  • linux内核分配内存,及管理?
  • 问个LINUX内存分配的问题。
  • linux c 多线程问题任务分配问题
  • Linux 如何获得分配内存的起始地址
  • linux下具体分配组的访问目录
  • 请教Linux内存分配策略与Windows有何异同?
  • Linux下服务器端的线程分配
  • 偶托管了一管台linux主机,想分配一个用户出来自已用,请问该怎么做?
  • 我在linux下用GPRS拨号上网,拨号分配到的IP是10.98.*.*时为何访问不了公网呢?
  • 关于Linux内存分配函数的几点问题
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux/Centos/Ubuntu清除系统缓存释放内存命令介绍
  • LINUX源码释放磁盘页面的问题
  • linux下如何释放ip和重新自动获得ip
  • 在Linux上用C语言编写的函数里面申请了一块内存,并且返回这块内存,最终它需要释放吗?
  • linux 资源紧张,如何查看并释放?
  • linux下信号量的释放的问题
  • linux中用killall命令杀死进程的时候会释放掉该进程所占有的内存吗?
  • 关于端口绑定(linux为服务端,windows为客户端)后无法立即释放的问题
  • 在linux下,进程非正常退出时,怎样释放掉已经生成的资源?
  • 为什么linux下进程结束后,需要使用wait或者waitpid释放资源?
  • Linux上手动释放Swap内存
  • linux怎么无法释放磁盘空间?
  • 在Linux上用C语言作了一个程序,程序中申请(malloc)了很大的内存,但是没free,当程序运行结束后,内存是否自动释放?
  • red linux 8.0被占用的内存无法释放是怎么回事?
  • 关于redhat Linux ,g++下stl库map内存释放的问题
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在没有linux的盘,只有DOS启动盘)
  • Linux Kernel 'sctp_v6_xmit()'函数信息泄露漏洞
  • unix/linux知识 iis7站长之家
  • linux c下利用srand和rand函数生成随机字符串
  • 在windows中的VMware装了个linux,主板有两个串口,能做windows和linux的串口通信测试么,怎么测试这两个串口在linux是有效


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3