linux内核编程-作业

sample

/

SRCU中实验一下是否可以睡眠

老师证明是可行的

但是我的机器上面会出问题,rmmod的时候

记得在rcu的时候,也是会在rmmod的时候出问题。

难道是死锁?

检查:

a.打开CONFIG_LOCKDEP

  死锁等一些锁非法情况的检查,debug功能

http://bbs.chinaunix.net/thread-3629019-1-1.htm

b.临界区的局部变量

memcpy()如果引发PAGE——FAULT的时候就会睡眠
表现在访问用户空间内存的时候
临时变量 在栈里头。

应该是局部变量 我把临界区里局部变量的声明删除之后就不再出现死锁了
所以 我把临时变量的内存memcpy到kmalloc申请的内存的时候 发生了睡眠


/

SRCU中实验一下是否可以睡眠

老师证明是可行的

但是我的机器上面会出问题,rmmod的时候

记得在rcu的时候,也是会在rmmod的时候出问题。

难道是死锁?

检查:

a.打开CONFIG_LOCKDEP

  死锁等一些锁非法情况的检查,debug功能

http://bbs.chinaunix.net/thread-3629019-1-1.htm

b.临界区的局部变量

memcpy()如果引发PAGE——FAULT的时候就会睡眠
表现在访问用户空间内存的时候
临时变量 在栈里头。

应该是局部变量 我把临界区里局部变量的声明删除之后就不再出现死锁了
所以 我把临时变量的内存memcpy到kmalloc申请的内存的时候 发生了睡眠


/

SRCU中实验一下是否可以睡眠

老师证明是可行的

但是我的机器上面会出问题,rmmod的时候

记得在rcu的时候,也是会在rmmod的时候出问题。

难道是死锁?

检查:

a.打开CONFIG_LOCKDEP

  死锁等一些锁非法情况的检查,debug功能

http://bbs.chinaunix.net/thread-3629019-1-1.htm

b.临界区的局部变量

memcpy()如果引发PAGE——FAULT的时候就会睡眠
表现在访问用户空间内存的时候
临时变量 在栈里头。

应该是局部变量 我把临界区里局部变量的声明删除之后就不再出现死锁了
所以 我把临时变量的内存memcpy到kmalloc申请的内存的时候 发生了睡眠

乖小孩(348367782) 2014/3/24 21:28:02
内存访问越界呢?  会引起睡眠么?  会不会是memcpy访问的内存地址超过了kmalloc申请的地址空间
eric(754112496) 2014/3/24 21:29:03
KMALLOC不会, 用VMALLOC的会

乖小孩(348367782) 2014/3/24 21:30:20
那我没辙了 也不知道是什么原因 莫名其妙的就好了

/

excercises

ex1:ringbuffer.ko

助教-窝头(464519091) 2014/3/24 21:31:34
我看一篇博客写了用户态的ringbuffer 
助教-窝头(464519091) 2014/3/24 21:32:11
老师 内核不是有kfifo.h和kfifo.c吗?
eric(754112496) 2014/3/24 21:32:42
可以借签哈
乖小孩(348367782) 2014/3/24 21:32:48
我直接找伪基的ringbuffer条目。。。
助教-窝头(464519091) 2014/3/24 21:32:55
哦 
eric(754112496) 2014/3/24 21:33:00
其实,我只是为了让你们熟悉锁的用法哈
不要考虑的那么复杂
chuck_huang(200950329) 2014/3/24 21:33:22
kfifo.h和kfifo.c 貌似已经很少用了吧。
助教-窝头(464519091) 2014/3/24 21:34:00
老师 那个提示提到的内核线程和作业有什么联系呢?
eric(754112496) 2014/3/24 21:34:07
似乎在TTY里有用
要使用多线程来验证你写的RINGBUFFER
助教-窝头(464519091) 2014/3/24 21:34:36
kfifo在网络处理数据包用的多
乖小孩(348367782) 2014/3/24 21:35:02
代码找不到了。。。
只有改完的代码了
助教-窝头(464519091) 2014/3/24 21:35:59
老师 多线程我想到的是用用户态的NPTL 
那个库
eric(754112496) 2014/3/24 21:36:38
呃, 这个作业是用来训练 模块编写,以及锁的使用的
助教-窝头(464519091) 2014/3/24 21:37:21
哦 是不是多线程的应用程序不能用NPTL库?
eric(754112496) 2014/3/24 21:37:34
不能用在内核
chuck_huang(200950329) 2014/3/24 21:38:09
kfifo在网络处理数据包用的多

嗯,但是我记得之前好像在什么地方看到说快要废弃了,难道记错了。。。
助教-窝头(464519091) 2014/3/24 21:38:21
内核态怎么实现多线程呢?我有点忘了
eric(754112496) 2014/3/24 21:38:35
其实有一个更强大的RING——BUFFER
在FTRACE里面
允许LOCKLESS 多个读多个写
也可以用在中断中
助教-窝头(464519091) 2014/3/24 21:39:21
老师ftrace是调试用得吧
eric(754112496) 2014/3/24 21:39:27

eric(754112496) 2014/3/24 21:42:23
是FTRACE里面那个
但代码比较有挑战性
助教-窝头(464519091) 2014/3/24 21:42:38
老师 内核态多线程咋弄的?
哦 
eric(754112496) 2014/3/24 21:42:52
我给的那几个接口哈
助教-窝头(464519091) 2014/3/24 21:43:09
我琢磨一下
乖小孩(348367782) 2014/3/24 21:43:28
在临界区内代码发生错误 完了是不是就死锁了 一直无法执行unlock操作
助教-窝头(464519091) 2014/3/24 21:43:33
老师kdump你常用吗?
助教-窝头(464519091) 2014/3/24 21:44:24
刚才看您又提及了
是用来分析内核崩溃的原因?
ftrace的源代码多吗?
助教-窝头(464519091) 2014/3/24 21:47:01
比如说自旋锁嵌套调用 就会使内核hang住
watchdog会检测 然后kernel 崩溃
乖小孩(348367782) 2014/3/24 21:48:04
这个倒没有 
助教-窝头(464519091) 2014/3/24 21:49:51
如果配置了kdump 会出发内核崩溃转存 切换到捕获内核 收集崩溃内核上下文将其保存一个vmcore, 
乖小孩(348367782) 2014/3/24 21:50:03
找到问题了  kmalloc申请的内存小 造成了越界访问
chuck_huang(200950329) 2014/3/24 21:50:59
@eric 其实我想问一下,你们KVM如何调试啊,那些log你们是直接输出的还是保存到存储介质上去的啊
chuck_huang(200950329) 2014/3/24 21:52:17
那你没有crash么?
助教-窝头(464519091) 2014/3/24 21:52:21
我觉得设计者两种机制都会提供
有呀 用crash工具分析vmcore呀
乖小孩(348367782) 2014/3/24 21:53:46
我也是刚知道kdump
chuck_huang(200950329) 2014/3/24 21:54:01
我觉得设计者两种机制都会提供。
直接输出的是透uart?打到别的电脑上?
咯岂不是要两台电脑?
助教-窝头(464519091) 2014/3/24 21:54:15
我这几天在搞kdump
可以这样
保存到NFS服务器上
助教-窝头(464519091) 2014/3/24 21:55:51
保存日志应该方法很多 有网络哈
chuck_huang(200950329) 2014/3/24 21:55:57
还是麻烦。
直接看比较效率
助教-窝头(464519091) 2014/3/24 21:56:58
有一种你说的在console中可以看的工具
chuck_huang(200950329) 2014/3/24 21:58:16
你说得是minicom 和 kermit 这些么?
乖小孩(348367782) 2014/3/24 22:01:05
给大神们跪了 你们说的我都没听过
十一郎<ruanyingmin@qq.com> 2014/3/24 22:01:59
@乖小孩   配置都不会难得。。。
淡定
乖小孩(348367782) 2014/3/24 22:02:57
只是感觉了解的东西太少了
chuck_huang(200950329) 2014/3/24 22:03:23
越学会觉得懂得越少,正常情况。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值