工作与兴趣的叠加,断断续续学习kernel有一年多了。入门的书看了几本(LLD、LKD、LVMM),各种文档、blog也有留意,kernel代码看了不少。现在来看,这种零散的学习可以帮助入门,当是想要做到master的水平,还是需要和工作结合,一块块的深入学习。
举个例子,两个月前, 调试secure-os 接口,在spinlock使用上纠结了一个多星期。 spin_lock 和spin_lock_irqsave的细微差异,不是看看blog,查查LKD就能理解透彻的。spinlock 实现是architecture dependent,在ARM上依赖ldrex /strex 指令,保证对指定地址memory bus访问的atomic (住:kernel 中所有atomic访问都是依赖这个feature实现,包括atomic/kref etc )。结合ARM spec 和kernel task 调度基本概念,就能明白spinlock是怎么一回事。
spinlock : preempt_disable --->>> atomic decrements lock value --->>> enter critical region
spinlock_irq : local_irq_disable --- >>> preempt_disable --->>> atomic decrements lock value --->>> enter critical region
spinlock_irqsave save cpu irq flag ---->>> local_irq_disable --- >>> preempt_disable --->>> atomic decrements lock value --->>> enter critical region
保护的对象是一个readl/writel 的接口,它能在kernel任何状态调用,包括irq handler, softirq,且是SMP并行,无疑spin_lock_irqsave 是正确的选择,这次的研究把内核lock来龙去脉摸透了。
这里举这个例子,想要说的是抓住每一点,研究透彻,点滴积累,就能有常足的进步,这也是自己写这个博客的目的。