在内核环境中,常用的内存分配函数主要有kmalloc、kzalloc和vmalloc这三个。既然这三函数都能在内核申请空间,那么这三个函数有什么区别呢?如何选用呢?kmalloc首先是kmalloc,其函数原型为///include/linux/slab.hvoid*kmalloc(size_tsize,gfp_tflags)函数的特点:申请的内存虚拟地址和物理地址都是连续的,允许申请的内存大小较小,具体的数值限制由平台和配置决定,具体可见kmalloc允许申请的内存大小。常用的内存分配方法flags:GFP_ATOMIC--表明分配内存的过程是原子的,不会被高优先级的进程或者中断打断GFP_
RISC-V内核中科蓝讯BT8922开发BT8922GPIO配置GPIO输出控制优化加速简化普通GPIO配置简化后的GPIO配置自定义LEDxm配置文件脚本解释音频文件更新替换软件开关机串口功能高速串口配置UART0调试端口修改音频导出音频测试源码修改调整音频路径调整MIC设置DAC输出通道设置代码量统计充电检测入仓关机功能BLE开发指南BLE使能FOAT功能BT蓝牙名称及配置修改硬件算法支持FFT变换基础数学计算程序下载更新注意事项芯片框架简述1、框架总述2、com区和bank区com区(公共区):bank区(也称为flash区):3、开发时需要注意:4、函数放入com区的写法BT8922G
出身寒微,不是耻辱。能屈能伸,方为丈夫。文章目录一、缓冲区(语言级:IO流缓冲,内核级:块缓冲)1.观察一个现象2.理解缓冲区存在的意义(节省进程IO数据的时间)3.语言级缓冲区的刷新策略(三种策略,两种特殊情况)4.语言级缓冲区在哪里?(C语言FILE结构体里包含fd和语言级缓冲区)5.用已学知识来解释刚开始的现象(系统调用没有语言级缓冲区,缓冲区刷新就是对数据修改,什么数据被修改就拷贝什么数据,所以写时拷贝后就会出现两份语言级缓冲区的数据。)6.自己写一份代码来模拟封装C语言缓冲区(加深对于C语言缓冲区和内核缓冲区的理解)7.用户级缓冲区和内核级缓冲区的联系(用户级缓冲区在structFI
出身寒微,不是耻辱。能屈能伸,方为丈夫。文章目录一、缓冲区(语言级:IO流缓冲,内核级:块缓冲)1.观察一个现象2.理解缓冲区存在的意义(节省进程IO数据的时间)3.语言级缓冲区的刷新策略(三种策略,两种特殊情况)4.语言级缓冲区在哪里?(C语言FILE结构体里包含fd和语言级缓冲区)5.用已学知识来解释刚开始的现象(系统调用没有语言级缓冲区,缓冲区刷新就是对数据修改,什么数据被修改就拷贝什么数据,所以写时拷贝后就会出现两份语言级缓冲区的数据。)6.自己写一份代码来模拟封装C语言缓冲区(加深对于C语言缓冲区和内核缓冲区的理解)7.用户级缓冲区和内核级缓冲区的联系(用户级缓冲区在structFI
简介近期在阅读鸿蒙liteOS_a,由于是初次探索内核的奥秘。将一些阅读的心得进行分享。希望能在作为笔记的同时,也能帮助更多人学习。感谢图灵大佬的注释项目,使我能够更加快速的理解。https://weharmony.github.io/核心模块核心模块位于:kernel->base->core其中包括:los_bitmap.c用于位操作,改变标志位。los_process.c用于控制并发、并行、单核多进程、多核多线程的管理los_sortlik.c用于排序los_swtmr.c用于定时器los_sys.c用于时间管理,转换秒与毫秒,了解当前系统运行时间los_task.c用于任务状态管理,一个
1,系统版本说明:ARM鲲鹏920 cat/etc/lsb-releaseDISTRIB_ID=UbuntuDISTRIB_RELEASE=18.04DISTRIB_CODENAME=bionicDISTRIB_DESCRIPTION="Ubuntu18.04.5LTS"2,将source.list中的deb-src打开#默认注释了源码镜像以提高aptupdate速度,如有需要可自行取消注释debhttp://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/focalmainrestricteduniversemultiversedeb-srchttp://
在某些时候我们需要读写的进程可能存在虚拟内存保护机制,在该机制下用户的CR3以及MDL读写将直接失效,从而导致无法读取到正确的数据,本章我们将继续研究如何实现物理级别的寻址读写。首先,驱动中的物理页读写是指在驱动中直接读写物理内存页(而不是虚拟内存页)。这种方式的优点是它能够更快地访问内存,因为它避免了虚拟内存管理的开销,通过直接读写物理内存,驱动程序可以绕过虚拟内存的保护机制,获得对系统中内存的更高级别的访问权限。想要实现物理页读写,第一步则是需要找到UserDirectoryTableBase的实际偏移地址,你一定会问这是个什么?别着急,听我来慢慢解释;在操作系统中,每个进程都有一个KPR
目录一、预备知识1.1什么是内核模块?1.2Linux内核模块组成部分二、源码编写1.1hello.c源码编写1.2Makefile编写三、源码编译3.1make编译3.2insmod加载内核模块3.3rmmod移除内核模块3.4查看内核模块3.4.1lsmod命令3.4.2cat/proc/modules3.4.3ls/sys/module/hello/3.5dmesg查看模块输出 四、小结相关代码下载链接一、预备知识1.1什么是内核模块? Linux内核模块(LKM)是一些在启动的操作系统内核需要时可以载入内核执行的代码块,不需要时由操作系统卸载。它们扩展了操作系统内核功能却
目录一、预备知识1.1什么是内核模块?1.2Linux内核模块组成部分二、源码编写1.1hello.c源码编写1.2Makefile编写三、源码编译3.1make编译3.2insmod加载内核模块3.3rmmod移除内核模块3.4查看内核模块3.4.1lsmod命令3.4.2cat/proc/modules3.4.3ls/sys/module/hello/3.5dmesg查看模块输出 四、小结相关代码下载链接一、预备知识1.1什么是内核模块? Linux内核模块(LKM)是一些在启动的操作系统内核需要时可以载入内核执行的代码块,不需要时由操作系统卸载。它们扩展了操作系统内核功能却
让我们继续在《内核读写内存浮点数》的基础之上做一个简单的延申,如何实现多级偏移读写,其实很简单,读写函数无需改变,只是在读写之前提前做好计算工作,以此来得到一个内存偏移值,并通过调用内存写入原函数实现写出数据的目的。以读取偏移内存为例,如下代码同样来源于本人的LyMemory读写驱动项目,其中核心函数为WIN10_ReadDeviationIntMemory()该函数的主要作用是通过用户传入的基地址与偏移值,动态计算出当前的动态地址。函数首先将基地址指向要读取的变量,并将其转换为LPCVOID类型的指针。然后将指向变量值的缓冲区转换为LPVOID类型的指针。接下来,函数使用PsLookupPr