LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 1742|回复: 0

Linux常用的调试手段printk的应用场合以及关于local_irq_save的疑问

[复制链接]
发表于 2010-6-3 15:55:37 | 显示全部楼层 |阅读模式
1 printk的使用场合
  在驱动中可以调用吗,会不会出问题?
  printk是可重入的吗?
  这个函数是阻塞的吗?
  它的输出时在文件里面的,那不会很慢吗?还是说有后台进程负责写入,它写入的是缓存
2 local_irq_save和local_irq_disable
  什么时候需要保存当前环境,中断打断会自动恢复环境吧.
  进程打断也是.
  那为什么还需要save?为了回到自己之前的环境?
  local_irq_save是不是没有必要了.
3 local_irq_disable和local_irq_disable _bh
  local_irq_disable是不是就已经disable bh了?
  但是我看了内核有的代码在local_irq_disable之后,还local_irq_disable _bh,
  那就是说前者关硬中断,并没有关软中断?硬中断关了软中断怎么还可能得到调度呢?
4 spin_lock spin_lock_irq spin_lock_bh
  这些函数的应用场合

相关
1 printk
仔细看了下Printk的源码,/kernel/printk.c,里面使用了logbuf_lock,来保护static char printk_buf[1024].之后放入输出缓冲.
在要输出的时候尝试直接输出到控制台,如果取不到就直接返回.
那这个函数还是可能阻塞的,就是忙等锁.单cpu不会,smp就会了.是这样吗?
2 local_irq_save
是不是怕自己的处理破坏了别人的环境?或者是这段代码之前代码的环境?
4 spin_lock
考虑因素:和谁争资源?其它cpu?使用spin_lock;底半操作?bh;中断?irq
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表