linux驱动基础及注意事项

本文介绍了嵌入式系统中的内存管理方法,包括kmalloc、dma_alloc_coherent及ioremap_nocache函数的用途与限制;探讨了自旋锁(spinlock)与互斥锁(mutex)的区别;并讲解了中断下半部机制、同步机制、原子操作及其应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.      内存分配

a.  函数dma_alloc_coherent() 分配实地址和虚地址

b.  函数kmalloc() 只返回虚地址。一般kmalloc最大只能分配128K-1616个字节是被页描述符结构占用了。

c.  函数ioremap_nocache IO实地址映射成虚地址,一般寄存器空间映射为虚地址都采用此函数

d.  kmalloc/dma_alloc_coherent 函数都有参数GFP_*

其中, GFP_KERNEL 内核内存的通常分配方法,可能引起睡眠。

     GFP_ATOMIC 用于在中断处理例程或者其他运行于进程上下文之外的代码中分配内存,不会睡眠。

     GFP_* LDD3第八章kmalloc函数的内幕。

2.      kmalloc/kfree的使用

a.  kmalloc函数返回的是虚拟地址,它分配的内存在物理上是连续的。

b.  kmalloc()函数本身是基于slab实现的,slab是为分配小内存提供的一种高效机制。

驱动中,建议不要频繁采用kmalloc/kfree机制,如果频繁使用,导致后果就是memfree内存大量减少,引起各种内存分配异常。

3.      spinlockmutex

a.  spinlock 为自旋锁,上下文中不能睡眠,一般在中断服务程序中使用。

b.  mutex为互斥锁,保护的内容可以引起睡眠。

4.      中断下半部机制

a.  一般有两种模式:

1) tasklet:内部不允许采用睡眠函数。

2) 工作队列work queue:允许睡眠函数

5.      同步机制

a.  wait_for_completion/complete函数,参数比较简单,无需任何唤醒条件。

b.  wait_for_interruptible/wakeup函数,参数灵活,要保证参数条件符合时,才能唤醒。

6.      原子操作/原子位操作

a.  atomic_read/atomic_set/atomic_add/atomic_sub 等函数。

b.  set_bit/clear_bit/test_and_set_bit 等函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值