映射Linux内存管理:DMA

linux内存管理  时间:2021-01-15  阅读:()

Linux内存管理 DMA

说起DMA我们并不陌生但是实际编程中去用的人不多吧最多就是网卡驱动里的环形buffer再有就是设备的dma下面我们就分析分析.DMA用来在设备内存和内存之间直接数据交互。而无需cpu

干预

内核为了方便驱动的开发 已经提供了几个dma函数接口。dma跟硬件架构相关所以l inux关于硬件部分已经给屏蔽了有兴趣的可以深入跟踪学习.按照l inux内核对dma层的架构设计各平台dma 缓冲区映射之间的差异由内核定义的一个dma操作集include/l inux/dma-mapping.h:

来统一屏蔽实现的差异.不同差异主要来来自cache的问题Cache与dma同步问题这里不深入讨论.

另外一个常用的函数是Dma_set_mask 为了通知内核设备能够寻址的范围很多时候设备能够寻址的范围有限。

Dma映射可以分为三类

1.一致性dma映射dma_al loc_coherent 问题驱动使用的buffer 不是自身申请的而是其他模块 当驱动模块主动分配一个Dma缓冲区并且dma生存期和模块一样时

参数说明

1这个函数的返回值是缓冲的一个内核虚拟地址,它可被驱动使用

2第三个参数dma_handle 其间相关的物理地址在dma_handle中返

2.流式dma映射dma_map_single通常用于把内核一段buffer映射返回物理地址.如果驱动模块需要使用从别的模块传进来的虚拟地址空间作为dma缓冲区保证地址的线性cache一致性一致性api接口sync_single_for_cpu

3.分散/聚集映射scatter/gather map

Dma_map_sgs

有时候我们还需要1.回弹缓冲区bouncebuffer 当cpu侧物理地址不适合设备的dma操作的时候

2.DmA内存池一般dma映射都是单个page的整数倍如果驱动程序需要更小的一致性映射的dma缓冲区可以使用。类似于slab机制Dma_pool_create

下面我们就那网卡驱动的例子说说dma的具体应用参考l inux kernel e1000网卡drivers/net/ethernet/intel/e1000/*Ring buffer

Dma不能为高端内存一般为32默认低端内存 由于设备能够访问的地址范围有限。 设备使用物理地址而代码使用虚拟地址。

就看看如何发送数据包 e1000_main.c:e1000_xmit_frame:关于帧的发送流程这里不多说.

经过上次邻居子系统后数据帧已经到达驱动数据放在skb指定的内存里.看代码tx_ring=adapter->tx_ring;//获取发送的ring buffer

接着我们看关键代码 count=e1000_tx_map(adapter, tx_ring, skb,

first,max_per_txd,nr_frags,mss);

它做了什么呢

默认数据报文没有分片或者碎片什么的。 那么进入第一个whi le(len)

获取buffer_info=&am p;tx_ring->buffer_info[i];然后调用dma_map_single进行流式映射.即把skb->data(虚拟地址)和b uffer_i nfo->d m a 物理地址对应起来.操作两个地址等于操作同一片区域。

回到主发送函数

调用e1000_tx_queue把数据发送出去

我们看到它把刚才dma_map_singe里的映射赋值了tx_desc->buffer_addr=cpu_to_le64(buffer_info->dma);说明发送的时候是根据发送描述符来发送的。

然后操作寄存器 writel(i,hw->hw_addr+tx_ring->tdt);那么网卡就会自动读取tx desc然后把数据发送出去。

总结下流程 1. l inuxos会调用网卡的start_xmit  函数。在e1000里对应的函数是e1000_xmit_frame,2.e1000_xmit_frame又会调用e1000_tx_queue(adapter, tx_ring, tx_flags,count) 。 这里的tx_queue指的是发送Descriptor的queue。 3.e1000_tx_queue在检查了一些参数后最终调用writel(i,hw->hw_addr+tx_ring->tdt)。 这里的tx_ring->tdt中的tdt全写为tx_descriptor_tai l 。从网卡的开发手册中可以查到如果写了descriptor

tai l 那么网卡就会自动读取descriptor,然后把包发送出去。descroptor的主要内容是addr pointer和length。前者是要发送的包的起始物理地址。后者是包的长度。有了这些硬件就可以通过dma来读取包并发出去了。其他网卡也基本会用descriptor的结构。

虽然流程明白了但是还有几个点 1. tx_ring在哪初始化 2.网卡到底是如何操作映射的dma地址的把数据发送出去的txring在e1000_open的时候 调用

我们看它建立了一致性dma映射.desc是结构指针它的结构跟网卡寄存器结构有关 e1000_hw.h

我们稍微屡一下

那么网卡又是如何和dma地址关联的呢?

很明显它把dma地址写入了网卡dma寄存器。所以dma还需要网卡硬件的支持才行.

当然e1000这个网卡驱动还是相当的复杂,不过它把一致性映射和流式映射都用上了。

HoRain Cloud:国内特价物理机服务器,镇江机房,内地5线BGP接入,月付499元起

horain怎么样?horain cloud是一家2019年成立的国人主机商家,隶属于北京辰帆科技有限公司,horain持有增值电信业务经营许可证(B1-20203595),与中国电信天翼云、腾讯云、华为云、UCloud、AWS等签署渠道合作协议,主要提企业和个人提供云服务器,目前商家推出了几款特价物理机,都是在内地,性价比不错,其中有目前性能比较强悍的AMD+NVMe系列。点击进入:horain...

Hosteons - 限时洛杉矶/达拉斯/纽约 免费升级至10G带宽 低至年$21

Hosteons,一家海外主机商成立于2018年,在之前还没有介绍和接触这个主机商,今天是有在LEB上看到有官方发送的活动主要是针对LEB的用户提供的洛杉矶、达拉斯和纽约三个机房的方案,最低年付21美元,其特点主要在于可以从1G带宽升级至10G,而且是免费的,是不是很吸引人?本来这次活动是仅仅在LEB留言提交账单ID才可以,这个感觉有点麻烦。不过看到老龚同学有拿到识别优惠码,于是就一并来分享给有需...

HyperVMart:加拿大vps,2核/3G/25G NVMe/G口不限流量/季付$10.97,免费Windows系统

hypervmart怎么样?hypervmart是一家成立了很多年的英国主机商家,上一次分享他家还是在2年前,商家销售虚拟主机、独立服务器和VPS,VPS采用Hyper-V虚拟架构,这一点从他家的域名上也可以看出来。目前商家针对VPS有一个75折的优惠,而且VPS显示的地区为加拿大,但是商家提供的测速地址为荷兰和英国,他家的优势就是给到G口不限流量,硬盘为NVMe固态硬盘,这个配置用来跑跑数据非常...

linux内存管理为你推荐
虚拟空间租赁虚拟主机租用价格多少钱一年php虚拟主机免费的国内的php虚拟主机有吗域名注册公司找家正规的中文域名注册公司独立ip主机有用过独立IP主机吗广东虚拟主机如果营业执照上的注册地址是属于广东地区对客户的虚拟主机或者域名的地有没有限制?免费虚拟主机申请谁有1年免费的虚拟主机申请地址吖?虚拟主机申请个人虚拟主机怎么申请?虚拟空间免费试用那位给我介绍个可以试用三天的虚拟空间。北京虚拟主机北京的虚拟主机提供商哪个经济实惠?深圳虚拟主机深圳市虚拟主机深圳双线虚拟主机深圳主机合租深圳合租主机空推荐有哪?
什么是域名解析 申请免费域名 ipage cybermonday 西安电信测速 linode日本 国外主机 highfrequency 香港机房 dropbox网盘 免费ddos防火墙 台湾谷歌网址 创梦 域名转向 国外免费全能空间 什么是服务器托管 傲盾官网 四核服务器 万网空间购买 美国独立日 更多