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内存分配的更多相关文章

  1. Linux驱动开发7——I/O内存分配

    CPU通过物理地址访问DDR和外设,DDR内存称为物理内存地址空间,外设寄存器组称为I/O内存地址空间. ARM采用统一编址,而X86采用独立编制.上一章介绍了DDR内存分配,这一章介绍I/O内存分配 ...

  2. 嵌入式Linux驱动开发日记

    嵌入式Linux驱动开发日记 主机硬件环境 开发机:虚拟机Ubuntu12.04 内存: 1G 硬盘:80GB 目标板硬件环境 CPU: SP5V210 (开发板:QT210) SDRAM: 512M ...

  3. Linux 驱动开发

    linux驱动开发总结(一) 基础性总结 1, linux驱动一般分为3大类: * 字符设备 * 块设备 * 网络设备 2, 开发环境构建: * 交叉工具链构建 * NFS和tftp服务器安装 3, ...

  4. Linux驱动开发必看详解神秘内核(完全转载)

    Linux驱动开发必看详解神秘内核 完全转载-链接:http://blog.chinaunix.net/uid-21356596-id-1827434.html   IT168 技术文档]在开始步入L ...

  5. Linux驱动开发:USB驱动之usb_skel分析

    在学习了这么些天的驱动之后,个人觉得驱动就是个架构的问题,只要把架构弄清楚了 然后往里面添砖加瓦就可以了,所以似乎看起来不是太困难,但也许是是我经验不足吧,这只能算是个人浅见了 这两天在学习USB驱动 ...

  6. Linux驱动开发学习的一些必要步骤

      1. 学会写简单的makefile 2. 编一应用程序,可以用makefile跑起来 3. 学会写驱动的makefile 4. 写一简单char驱动,makefile编译通过,可以insmod, ...

  7. 嵌入式linux驱动开发之点亮led(驱动编程思想之初体验)

    这节我们就开始开始进行实战啦!这里顺便说一下啊,出来做开发的基础很重要啊,基础不好,迟早是要恶补的.个人深刻觉得像这种嵌入式的开发对C语言和微机接口与原理是非常依赖的,必须要有深厚的基础才能hold的 ...

  8. 【转】linux驱动开发的经典书籍

    原文网址:http://www.cnblogs.com/xmphoenix/archive/2012/03/27/2420044.html Linux驱动学习的最大困惑在于书籍的缺乏,市面上最常见的书 ...

  9. Linux驱动开发 -- 打开dev_dbg()

    Linux驱动开发 -- 打开dev_dbg() -- :: 分类: LINUX linux设备驱动调试,我们在内核中看到内核使用dev_dbg来控制输出信息,这个函数的实质是调用printk(KER ...

随机推荐

  1. ls 命令通配符(3)

    使用过正则的人应该很熟悉通配符.如果非要解释的话,我找来一段: 通配符是一种特殊语句,主要有星号(*)和问号(?),用来模糊搜索文件. 当查找文件夹时,可以使用它来代替一个或多个真正字符:当不知道真正 ...

  2. A-问题收益率

    问题: 在金融中,我们有时会用内部收益率IRR来评价项目的投资财务效益,它等于使得投资净现值NPV等于0的贴现率.换句话说,给定项目的期数T.初始现金流CF0和项目各期的现金流CF1, CF2, …, ...

  3. 高版本chrome不再支持window.showmodaldialog 的临时替换方案【用window.open】

    接管别人的项目,因开发时用了showmodaldialog 导致最近很多用户chrome升级到最新之后 就无法弹窗了.原因是新版chrome[37+]不再支持showmodaldialog. show ...

  4. python之 yield --- “协程”

    在编程中我们经常会用到列表,以前使用列表时需要声明和初始化,在数据量比较大的时候也需要把列表完整生产出来,例如要存放1000给数据,需要准备长度1000的列表,这样计算机就需要准备内存放置这个列表,在 ...

  5. 理解长短期记忆网络(LSTM NetWorks)

    转自:http://www.csdn.net/article/2015-11-25/2826323 原文链接:Understanding LSTM Networks(译者/刘翔宇 审校/赵屹华 责编/ ...

  6. Composer\Downloader\TransportException ... Failed to enable crypto,failed to open stream: operation failed

    failed to open stream: operation failed 错误详细信息: [Composer\Downloader\TransportException] The "h ...

  7. 排序二叉树、平衡二叉树、红黑树、B+树

    一.排序二叉树(Binary Sort Tree,BST树) 二叉排序树,又叫二叉搜索树.有序二叉树(ordered binary tree)或排序二叉树(sorted binary tree). 1 ...

  8. Bean的生命周期与JVM**

    案例: 在service里定义了一个全局变量,这类变量只能是final的.如果不是,在代码中一旦有地方给该变量进行业务赋值.当不满足赋值条件时变量仍然保留上次的赋值的值. 这是因为Bean没有销毁. ...

  9. 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_ ...

  10. 查看jar包内容

    查看jar包内容 查看jar包内容的基本命令: jar tf jar-file 参数解释: The t option indicates that you want to view the table ...