应用案例系统

样例系统包括:

AXI bus master: 一个DMAC,两个ARM处理器

一个AXI互联模块,两个AMBA协议桥组件

PrimeCell slaves: 一个动态内存控制器DMC,一个静态内存控制器SMC,一个timer,一个GPIO,一个通用异步收发器UART

AXI互联模块使每个bus master能够访问slaves。ARM处理器能够访问DMAC的APB接口,通过使用合适的AXI to APB桥实现。

DMAC特性

用于灵活编程DMA传输的指令集

一个AXI master接口,用于执行DMA传输

双APB slave接口,设计给安全态和非安全态,用于访问DMAC内部寄存器

支持TrusZone技术

支持多种传输类型:

memory to memory

memory to peripheral

peripheral to memory

scatter-gather

可配置的RTL,使得DMAC能够按照应用需要优化

每个DMA channel都有可编程的安全状态

使用中断输出信号来通知不同DMA事件的发生

DMAC可配置特性

AXI 数据总线宽度

active AXI读事务的数量

active AXI写事务的数量

同时active的DMA channel数量

内部数据buffer的深度

指令缓存的行数,以及一行包含多少word

读指令队列的深度

写指令队列的深度

外设请求接口的数量

中断输出信号的数量

功能概览

DMAC包含一个指令处理模块,可以执行代码控制DMA传输。程序代码存放在一块系统内存上,DMAC可以使用AXI接口访问代码。DMAC内部有一个cache缓存指令,其行长和深度都可配。

最大可配置8个DMA channel,每个channel可以支持DMA操作的单独并发线程。另外还有一个单独单独DMA管理线程,可以用来初始化DMA channel线程。每个AXI时钟周期DMAC执行一条指令。

DMAC使用可变长指令(1-6 bytes)。每个DMA channel有一个独立的PC寄存器。当一个线程要从一个地址中取指时,cache执行查找。cache hit时cache立即返回数据,否则线程会停住,DMAC使用AXI接口做cache line fill。如果指令大于4 bytes或超过了cachel line的最后位置,cache会执行多个cache访问来获取指令。

双APB接口,一个用于secure状态,一个用于Non-secure状态。可以使用APB接口访问状态寄存器,也可以直接在DMAC里执行指令。

PL330 DMAC驱动不同之处

PL330 的DMAC驱动和普通的DMAC驱动的不同的地方主要是:
        1) PL330 DMAC有自己的特殊指令集,1-6个字节不定长,主要包括

DMAMOV/DMALD/DMAST/DMAGO
        2) PL330 DMAC驱动需要:
             申请一块指令buffer,在buffer里面存放DMAC的指令数据,完成DMA功能。
             执行 DMAGO 指令,让channel的 pc指针指向指令buffer,从 buffer 取值执行。
           (DMAGO 指令的本身的执行,是通过写 S5PV210 芯片的 DBGCMD/DBGINST0/DBGINST1 这3个寄存器实现的)

PL330 DMAC笔记(1) - 简介相关推荐

  1. python编程入门到实践笔记习题_Python编程从入门到实践笔记——列表简介

    python编程从入门到实践笔记--列表简介 #coding=utf-8 #列表--我的理解等于c语言和java中的数组 bicycles = ["trek","cann ...

  2. 读书笔记-TCP简介

    @(Network)[tcp, congestion control] 读书笔记-TCP简介 本文主要记录阅读linuxtcp文章,其第二章中主要介绍了TCP拥塞控制的基础和一些发展历程,这里作为整理 ...

  3. 咸鱼笔记—git简介

    咸鱼笔记-git简介 git简介 git的两大特点 安装与配置 创建一个版本库 新手刚接触python,跟着教程学的,仅供参考.欢迎各路大神指点. 学习版本: Django 1.8. Python 3 ...

  4. OptiX资料学习笔记1——简介

    OptiX资料学习笔记1--简介 OptiX引擎的现状 目前有三种开源的API支持NVIDIA的光线追踪功能,分别为: DirectX Raytracing (DXR) DX的光线追踪API Vulk ...

  5. (swing读书笔记)JTable简介(下)

    (swing读书笔记)JTable简介(下) by cszhao1980 六.Row 最初,JTable没有提供任何"Row"相关的类来控制Row,与Row相关的大量操作直接坐落在 ...

  6. (swing读书笔记)JTree简介(下)

    (swing读书笔记)JTree简介(下) By cszhao1980 六.TreeCellRenderer 通过JTable一样,JTree也使用一个接口定义它的单元绘制器,该接口仅有一个方法: C ...

  7. (swing读书笔记)JTree简介(中)

    (swing读书笔记)JTree简介(中) By cszhao1980 三.TreeModel(树模型) 同JTable相比,TreeModel接口显得不那么重要.这是Tree的特殊性造成的--Tre ...

  8. (swing读书笔记)JTable简介(中)

    (swing读书笔记)JTable简介(中) by cszhao1980 五.TableCellRenderer JTable将Cell的绘制工作委托给CellRenderer来完成--如果我们没有显 ...

  9. (swing读书笔记)JTable简介(上)

    (swing读书笔记)JTable简介(上) by cszhao1980 JTable是Swing中最复杂的组件之一.在JTable周围,环绕着JTableHeader.TableModel.Tabl ...

  10. (swing读书笔记)JTree简介(上)

    (swing读书笔记)JTree简介(上) By cszhao1980 同JTable类似,JTree也是一个负责的组件,其周围也有大量附属接口.类,如下图所示: 一.TreeNode(树节点) Tr ...

最新文章

  1. 长波通信、中波通信、短波通信、超短波通信与微波通信介绍
  2. Json返回结果为null属性不显示解决方法
  3. 企消互动广告:网络时代广告活动的创新形式——兼谈杜丽反败为胜对企业的启示...
  4. soap php 分开类,PHP SoapClient类型映射的行为有所不同
  5. 数据结构特性解析 (二) ArrayList
  6. MAP/REDUCE:Google和Nutch实现异同及其他
  7. 补码、无符号数减法运算
  8. 人工智能红利渗透与爆发
  9. error while loading shared libraries: xxx.so.x错误
  10. caffe图像分类教程_跟我上手深度学习: 五分钟尝试第一个深度学习(Caffe)训练和图像分类(详细图文步骤)...
  11. [转】Python--遍历列表时删除元素的正确做法
  12. springmvc 控制器 读取properties文件
  13. (转载)北京理工大学:《Python语言程序设计》____笔记整理
  14. 北京大学肖臻老师《区块链技术与应用》ETH笔记 - 8.0 ETH挖矿难度的调整
  15. 硬件设计—数字电路常用设计准则
  16. python会员折扣_Python——潜在会员用户预测
  17. python期末试题汇总
  18. JAVA初级游戏项目(大鱼吃小鱼)
  19. 巴西柔术_案例研究:巴西国家医疗体系
  20. 智慧工地核心产品——未冲洗抓拍

热门文章

  1. 故障恢复控制台的启动方法
  2. SpringBoot中Redis报错:NOAUTH Authentication required.; nested exception is redis.clients.jedis.exceptio
  3. Iphone 苹果手机HEIC照片格式 win10电脑打开 解决方案
  4. 路由器密码重置(不是适用于所有有些启动顺序数字不一样)
  5. 计算机网络里的DHCP是什么,路由器设置中的dhcp是什么意思?
  6. 小白也可以开发闲鱼自动化工具(自动找爆款)
  7. unity3d 怎么生成网页版_急求unity3D动画简易版制作步骤?
  8. css3 背景模糊属性 背景滤镜 backdrop-filter
  9. 云计算中的Server Consolidation
  10. PIXHAWK飞控固件及代码基础介绍