Linux驱动开发6——DDR内存分配
1、kmalloc和kfree
#include <linux/slab.h> void *kmalloc(size_t size, int flags);
flag:
GFP_ATOMIC - 用来从中断处理和进程上下文之外的其他代码中分配内存,从不睡眠
GFP_KERNEL - 内核内存的正常分配,可以睡眠,物理地址上连续,内部调用__get_free_pages
GFP_USER - 用来为用户空间页分配内存,可以睡眠
GFP_HIGHUSER - 通GFP_USER,但是从高端内存分配 void kfree(const void *objp);
2、后备缓存
Linux内核提供了后备缓存机制,用来创建一组相同大小对象的内存池,应用在反复分配许多相同大小内存的场景,如USB和SCSI驱动等。Linux内核的缓存管理者为——slab分配器。
#include <linux/slab.h> 创建一个新的,可以驻留任意数目全部同样大小的后备缓存对象
kmem_cache_t *kmem_cache_create(
const char *name,
size_t size,
size_t offset,
unsigned long flags,
void (*constructor)(void *, kmem_cache_t *, unsigned long flags),
void (*destructor)(void *, kmem_cache_t *, unsigned long flags)
); name:名称
size:每一个后备缓存的大小
offset: 页内的第一个对象的偏移
flags:
SLAB_NO_REAP - 保护缓存在系统查找内存时被削减
SLAB_HWCACHE_ALIGN - 对齐
SLAB_CACHE_DMA - 在DMA内存区分配内存
constructor - 构造函数
deconstructor - 析构函数 一旦一个对象的缓存被创建,可以通过kmem_cache_alloc从它分配对象
void *kmem_cache_alloc(kmem_cache_t *cache, int flag); 释放对象
void kmem_cache_free(kmem_cache_t *cache, const void *obj); 卸载对象
int kmem_cache_destroy(kmem_cache_t *cache); 可以通过/proc/slabinfo节点获取后备缓存使用统计
3、内存池
Linux内核创建了一个已知的内存池(mempool)的抽象,它真实地只是一类后备缓存,尽力一直保持一个空闲内存列表给紧急时使用,通常用在不允许内存分配失败的地方。
#include <linux/mempool.h> mempool_t *mempool_create(
int min_nr,
mempool_alloc_t *alloc_fn,
mempool_free_t *free_fn,
void *pool_data
); min_nr: 内存池应当一直保留的最小数量的分配对象,实际分配和释放对象由alloc_fn和free_fn处理
alloc_fn:
typedef void *(mempool_alloc_t)(int gfp_mask, void *pool_data);
通常使用mempool_alloc_slab分配对象
free_fn:
typedef void (mempool_free_t)(void *element, void *pool_data);
通常使用mempool_free_slab释放对象
pool_data: 传递给alloc_fn和free_fn void *mempool_alloc(mempool_t *pool, int gfp_mask);
void *mempool_free(void *element, mempool_t *pool); int mempool_resize(mempool_t *pool, int new_min_nr, int gfp_mask); void mempool_destroy(mempool_t *pool);
4、get_free_page
分配页
get_zeroed_page(unsigned int flags);
__get_free_page(unsigned int flags);
__get_free_pages(unsigned int flags, unsigned int order); 释放页
void free_page(unsigned long addr);
void free_pages(unsigned long addr, unsigned long order);
5、alloc_pages
Linux页分配器的真正核心是alloc_pages_node函数
struct page *alloc_pages_node(int nid, unsigned int flags, unsigned int order); 变种函数:
struct page *alloc_page(unsigned int flags);
struct page *alloc_pages(unsigned int flags, unsigned int order); 释放页:
void __free_page(struct page *page);
void __free_pages(struct page *page, unsigned int order);
6、vmalloc和vfree
以页为单位的内存分配,在虚拟内存空间分配一块连续的内存区,但是这些页在物理内存中是不连续的。效率比较低,大部分情况下不鼓励使用。
#include <linux/vmalloc.h> void *vmalloc(unsigned long size); void vfree(void *addr);
Linux驱动开发6——DDR内存分配的更多相关文章
- Linux驱动开发7——I/O内存分配
CPU通过物理地址访问DDR和外设,DDR内存称为物理内存地址空间,外设寄存器组称为I/O内存地址空间. ARM采用统一编址,而X86采用独立编制.上一章介绍了DDR内存分配,这一章介绍I/O内存分配 ...
- 嵌入式Linux驱动开发日记
嵌入式Linux驱动开发日记 主机硬件环境 开发机:虚拟机Ubuntu12.04 内存: 1G 硬盘:80GB 目标板硬件环境 CPU: SP5V210 (开发板:QT210) SDRAM: 512M ...
- Linux 驱动开发
linux驱动开发总结(一) 基础性总结 1, linux驱动一般分为3大类: * 字符设备 * 块设备 * 网络设备 2, 开发环境构建: * 交叉工具链构建 * NFS和tftp服务器安装 3, ...
- Linux驱动开发必看详解神秘内核(完全转载)
Linux驱动开发必看详解神秘内核 完全转载-链接:http://blog.chinaunix.net/uid-21356596-id-1827434.html IT168 技术文档]在开始步入L ...
- Linux驱动开发:USB驱动之usb_skel分析
在学习了这么些天的驱动之后,个人觉得驱动就是个架构的问题,只要把架构弄清楚了 然后往里面添砖加瓦就可以了,所以似乎看起来不是太困难,但也许是是我经验不足吧,这只能算是个人浅见了 这两天在学习USB驱动 ...
- Linux驱动开发学习的一些必要步骤
1. 学会写简单的makefile 2. 编一应用程序,可以用makefile跑起来 3. 学会写驱动的makefile 4. 写一简单char驱动,makefile编译通过,可以insmod, ...
- 嵌入式linux驱动开发之点亮led(驱动编程思想之初体验)
这节我们就开始开始进行实战啦!这里顺便说一下啊,出来做开发的基础很重要啊,基础不好,迟早是要恶补的.个人深刻觉得像这种嵌入式的开发对C语言和微机接口与原理是非常依赖的,必须要有深厚的基础才能hold的 ...
- 【转】linux驱动开发的经典书籍
原文网址:http://www.cnblogs.com/xmphoenix/archive/2012/03/27/2420044.html Linux驱动学习的最大困惑在于书籍的缺乏,市面上最常见的书 ...
- Linux驱动开发 -- 打开dev_dbg()
Linux驱动开发 -- 打开dev_dbg() -- :: 分类: LINUX linux设备驱动调试,我们在内核中看到内核使用dev_dbg来控制输出信息,这个函数的实质是调用printk(KER ...
随机推荐
- ls 命令通配符(3)
使用过正则的人应该很熟悉通配符.如果非要解释的话,我找来一段: 通配符是一种特殊语句,主要有星号(*)和问号(?),用来模糊搜索文件. 当查找文件夹时,可以使用它来代替一个或多个真正字符:当不知道真正 ...
- A-问题收益率
问题: 在金融中,我们有时会用内部收益率IRR来评价项目的投资财务效益,它等于使得投资净现值NPV等于0的贴现率.换句话说,给定项目的期数T.初始现金流CF0和项目各期的现金流CF1, CF2, …, ...
- 高版本chrome不再支持window.showmodaldialog 的临时替换方案【用window.open】
接管别人的项目,因开发时用了showmodaldialog 导致最近很多用户chrome升级到最新之后 就无法弹窗了.原因是新版chrome[37+]不再支持showmodaldialog. show ...
- python之 yield --- “协程”
在编程中我们经常会用到列表,以前使用列表时需要声明和初始化,在数据量比较大的时候也需要把列表完整生产出来,例如要存放1000给数据,需要准备长度1000的列表,这样计算机就需要准备内存放置这个列表,在 ...
- 理解长短期记忆网络(LSTM NetWorks)
转自:http://www.csdn.net/article/2015-11-25/2826323 原文链接:Understanding LSTM Networks(译者/刘翔宇 审校/赵屹华 责编/ ...
- Composer\Downloader\TransportException ... Failed to enable crypto,failed to open stream: operation failed
failed to open stream: operation failed 错误详细信息: [Composer\Downloader\TransportException] The "h ...
- 排序二叉树、平衡二叉树、红黑树、B+树
一.排序二叉树(Binary Sort Tree,BST树) 二叉排序树,又叫二叉搜索树.有序二叉树(ordered binary tree)或排序二叉树(sorted binary tree). 1 ...
- Bean的生命周期与JVM**
案例: 在service里定义了一个全局变量,这类变量只能是final的.如果不是,在代码中一旦有地方给该变量进行业务赋值.当不满足赋值条件时变量仍然保留上次的赋值的值. 这是因为Bean没有销毁. ...
- CTF Jarvisoj Web(session.upload_progress.name php 上传进度)
Jarvisoj Web 题目地址:http://web.jarvisoj.com:32784/index.php <?php //A webshell is wait for you ini_ ...
- 查看jar包内容
查看jar包内容 查看jar包内容的基本命令: jar tf jar-file 参数解释: The t option indicates that you want to view the table ...