zoukankan      html  css  js  c++  java
  • Linux驱动之内存访问

    <背景>
    内存会以分页方式组织内存,而且每页大小和计算机体系结构有关系,Linux中每个页都有对应的struct page{}
    与之对应。
                                        
     

    <分配连续的内存>

    a:void *kmalloc(int count,int flags)函数用于从zone_normal区域返回连续内存的分配的地址。
            参数分析:
                    count:分配内存的大小
                    flags:分配内存的方式
                            GPF_KERNEL:进程上下文用来分配内存,内存不够时会导致进程睡眠。
                            GPF_ATOMIC:中断上下文用来分配内存,不会导致进程睡眠,内存不足时候会返回错误。
    注意:kmalloc()函数分配的内存空间会保留原来的数据,所以在内存分配成功后必须进行相应的清零操作,否则会导致意想不到的问题。
    b:void *vmalloc(unsigned long count)
            参数分析:
                    count:分配内存的大小
    注意:vmalloc()常用来分配较大的内存空间,但是消耗的时间更长,并且不能再中断上下文中使用。用该函数分配的内存返回的虚拟地址是连续,但是实际的物理地址不是连续的,因此不能用来分配DM空间。
  • 相关阅读:
    SQLServer多表连接查询
    SQLServer基本查询
    SQLServer索引
    SQLServer之数据类型
    设计模式小结
    SQL跨项目查询语法
    利用CountDownLatch和Semaphore测试案例
    JUC包下Semaphore学习笔记
    JUC包下CountDownLatch学习笔记
    JUC包下CyclicBarrier学习笔记
  • 原文地址:https://www.cnblogs.com/big-devil/p/8589471.html
Copyright © 2011-2022 走看看