免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1971 | 回复: 5

[网络子系统] 协议栈调试问题 [复制链接]

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
发表于 2014-01-09 22:49 |显示全部楼层
本帖最后由 duoniK 于 2014-01-10 15:40 编辑

要对 skb中线性区的数据进行修改。
目标是tcp_write_xmit调用的发送队列中的 skb
以下是自己做的修改
static int tcp_write_xmit(struct sock *sk, unsigned int mss_now, int nonagle,
                          int push_one, gfp_t gfp)
{
        struct tcp_sock *tp = tcp_sk(sk);
        struct sk_buff *skb;
        unsigned int tso_segs, sent_pkts;
        int cwnd_quota;
        int result;
        //添加如下
        unsigned int time = 0;
        unsigned int Length;
        char buffer[1500] = {0};
        .....
           while ((skb = tcp_send_head(sk))) {
                unsigned int limit;
               
                //添加如下
                Length = skb->end - skb->data;
                memcpy(buffer, skb->data, Length);
                printk("time is %d\n", ++time);
                printk("buffer is %s\n", buffer);
                ...
          }
想问下 为什么添加了以上 printk 代码之后,调用TCP协议就卡住了呢? 是应为 memcpy 太耗时了么?

论坛徽章:
0
发表于 2014-01-09 23:31 |显示全部楼层
memcpy(skb->data, buffer, Length);  参数顺序

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
发表于 2014-01-10 08:43 |显示全部楼层
duoniK 发表于 2014-01-09 22:49
要对 skb中线性区的数据进行修改。
目标是tcp_write_xmit调用的发送队列中的 skb
以下是自己做的修改

printk过于频繁也很容易导致挂死,需要限制使用频率。

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
发表于 2014-01-10 15:41 |显示全部楼层
低级错误,谢谢 回复 2# kkddkkdd11


   

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
发表于 2014-01-10 17:17 |显示全部楼层
目前的问题是,通过ssh传输文件时,能打印出发送的数据。通过socket编程传输 小数据时 没有 打印数据。这是什么情况?
tcp_write_xmit是 唯一的发送出口啊回复 3# humjb_1983


   

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
发表于 2014-01-10 17:28 |显示全部楼层
duoniK 发表于 2014-01-10 17:17
目前的问题是,通过ssh传输文件时,能打印出发送的数据。通过socket编程传输 小数据时 没有 打印数据。这是 ...

可以在更底层的点,打一下堆栈,就明白了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP