sample
/
SRCU中实验一下是否可以睡眠
老师证明是可行的
但是我的机器上面会出问题,rmmod的时候
记得在rcu的时候,也是会在rmmod的时候出问题。
难道是死锁?
检查:
a.打开CONFIG_LOCKDEP
死锁等一些锁非法情况的检查,debug功能
http://bbs.chinaunix.net/thread-3629019-1-1.htm
b.临界区的局部变量
表现在访问用户空间内存的时候
)
/
SRCU中实验一下是否可以睡眠
老师证明是可行的
但是我的机器上面会出问题,rmmod的时候
记得在rcu的时候,也是会在rmmod的时候出问题。
难道是死锁?
检查:
a.打开CONFIG_LOCKDEP
死锁等一些锁非法情况的检查,debug功能
http://bbs.chinaunix.net/thread-3629019-1-1.htm
b.临界区的局部变量
表现在访问用户空间内存的时候
)
/
SRCU中实验一下是否可以睡眠
老师证明是可行的
但是我的机器上面会出问题,rmmod的时候
记得在rcu的时候,也是会在rmmod的时候出问题。
难道是死锁?
检查:
a.打开CONFIG_LOCKDEP
死锁等一些锁非法情况的检查,debug功能
http://bbs.chinaunix.net/thread-3629019-1-1.htm
b.临界区的局部变量
表现在访问用户空间内存的时候
)
内存访问越界呢? 会引起睡眠么? 会不会是memcpy访问的内存地址超过了kmalloc申请的地址空间
eric(754112496) 2014/3/24 21:29:03
KMALLOC不会, 用VMALLOC的会
那我没辙了 也不知道是什么原因 莫名其妙的就好了
/
excercises
ex1:ringbuffer.ko
我看一篇博客写了用户态的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
嗯
是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操作
老师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申请的内存小 造成了越界访问
@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
越学会觉得懂得越少,正常情况。