DAT模块简介

转自:http://blog.sina.com.cn/s/blog_48fc29af0100ncdu.html

DAT模块函数在DM642的EDMA操作中用于搬运数据。DAT_busy()函数用于检测EDMA数据传输过程是否已经结束,定义如下:Uint32 DAT_busy(Uint32 ID);

DAT_busy()函数如果返回一个非零值,则表明数据传输过程(DAT_copy()操作或DAT_fill()操作)正在进行,其他操作需要等待,如果该函数返回零,则表明数据传输过程已经完成,可以执行其他操作了。DAT_busy()函数的使用方法如下:

DAT_open(DAT_CHAANY,DAT_PRI_LOW,0);//打开数据传输通道

Transferid=DAT_copy(src,dst,len);//数据copy,返回通道值

while(DAT_busy(transferid));//等待数据copy过程完成

 

DAT_copy()函数把源数据区中的数据转移到目标数据区中,它的定义如下:

Uint32 DAT_copy(void *src , void *dst , Uint16 byteCnt);

src表示源数据区起始地址指针,

dst表示目标数据区起始指针,

byteCnt为被搬运数据的长度,单位为字节,

该函数返回数据搬运通道的ID值,供DAT_busy()等函数调用。

DM642的L2的EDMA数据总线为64位,要求数据以8字节为单位进行对其,所以bateCnt应为8的倍数,byteCnt为0时,数据搬运的结果是随机的。函数的使用方法是:

 

 

DAT_open()函数用于打开一个DAT通道,该函数具有如下的定义:

Uint32 DAT_open(int chaNum, int priority, Uint32 flags);

chaNum是为EDMA操作分配的数据通道,取DAT_CHAANY、DAT_CHA0、DAT_CHA1、DAT_CHA2、DAT_CHA3中的一个,priority变量规定了该通道的优先级,priority取DAT_PRI_LOW(低优先级)、DAT_PRI_HIGH(高优先级)中的一个,

flags为标志位,明确数据操作的方式,如一维数据操作、二维数据操作等,对于二维数据操作flags应为DAT_OPEN_2D。

与DAT_open()函数想对应的是DAT_close()函数,DAT_close()函数用于关闭已打开的DAT通道。

 

 

 

 


CSLAPI int DAT_open(int chaNum, int priority, Uint32 flags);
CSLAPI void DAT_close();

CSLAPI Uint32 DAT_copy(void *src , void *dst , Uint16 byteCnt);
CSLAPI Uint32 DAT_fill(void *dst , Uint16 byteCnt, Uint32 *value);
CSLAPI void   DAT_wait(Uint32 id);
CSLAPI int    DAT_busy(Uint32 id);

CSLAPI Uint32 DAT_copy2d(Uint32 type, void *src, void *dst, Uint16 lineLen, Uint16 lineCnt, Uint16 linePitch);


IDECL void DAT_setPriority(int priority);



DAT_open         Opens the DAT module

●函数    Uint32   DAT_open(

                            int chaNum,

                           int priority, 优先级

                                   Uint32 flags

                        );

●参数        chaNum  指定分配那个DMA通道,必须是下面其中之一:

DAT_CHAANY

DAT_CHA0

DAT_CHA1

DAT_CHA2

DAT_CHA3

priority 指定DMA通道的优先级必须是下面其中之一

DAT_PRI_LOW

DAT_PRI_HIGH

flags   各种各样的打开标志

DAT_OPEN_2D

●返回值      success   如果失败返回0,如果成功返回非零值,失败的原因如下:

 DAT模块已经打开,

需要的资源没有被分派。

●描述             

这个函数打开DAT模块,而且必须在调用其它DAT API 函数之前被调用,

ChaNum 参数指定了哪个DMA通道被DAT模块单独的打开,对于带有EDMA的设备,ChaNum 参数被忽略,原因是快速使用的DMA并不具有一个和它匹配的通道,对具有DMA的设备,ChaNum指定了将要使用哪个DMA通道,

 DAT_PRI_LOW设置DMA通道的CPU优先级 DAT_PRI_HIGH 设置DMA通道的DMA优先级,DAT_PRI_LOW设置 LOW priority ,DAT_PRI_HIGH 设置HIGH priority,一旦 DAT 模块被打开,任何被分配的资源,例如一个DMA通道,仍然被分配,你可以调用 DAT_close() 来释放这些资源,如果,准备通过DAT_copy2d 来进行2Dde传输, DAT_OPEN_2D 标志必须被指定,对具有DMA接口的设备指定这个标志, 将要导致一个全局重载计数寄存器和一个全局索引寄存器的分配这些全局寄存器在调用DAT_close()时将被释放,

注意:对具有EDMA的设备,DAT模块使用EDMA寄存器来提交传输请求,而且将使用通道中断挂起寄存器(CIPR),中断并不被使能 ,但是CIPR中的中断标志要用到, DAT模块使用完成码的1到4来计算一个在CIPR 寄存器中的掩码0x00000001E ,在具有EDMA的设备上使用DAT模块的用户必须避免使用完成码1到4。

使用任何有效的DMA通道来打开DAT模块的例子,

DAT_open(DAT_CHAANY,DAT_PRI_LOW,0);

用高优先级模式使用DMA通道2打开DAT模块,使用:

DAT_open(DAT_CHA2,DAT_PRI_HIGH,0);

使用2D拷贝打开DAT模块,使用:

DAT_open (DAT_CHAANY, DAT_PRI_HIGH, DAT_OPEN_2D);

DAT_copy                   Copies a linear block of data from Src to Dst using DMA or

                                    EDMA hardware

                          Uint32 DAT_copy(
                                                                void *src,
                                                                 void *dst,
                                                                Uint16 byteCnt
                                                                               );

Arguments

                     void *src                 是一个源地址指针,

                     void *dst                  是目的地址指针,

                     Uint16 byteCnt     是一个无符号16位数,用来计算你要copy的byte数,这个值是以字节计算的。Return Value       xfrId    Transfer ID 

 函数的返回值是一个传输通道的标号(xfrId    Transfer ID),一般用作句柄

  描述:

用CSL的DAT之前好像也得先设置好DMA或EDMA的参数,DAT可以自动选择DMA或EDMA的方式和通道,但是具体传输时还是要用到DMA和EDMA的参数,所以即使是用DAT来传输数据,也不能回避掉DMA/EDMA的设置。



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/462537.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P2237 [USACO14FEB]自动完成Auto-complete

题意大概就是:给出n个字符串,有m个询问:每次给出字符串s,整数k,问在所有以s为前缀的字符串中,字典序第k大的,是那n个串中的第几个。 我一开始做的时候忽略了一个问题:就是对于两个串…

HP-UX的终端TERM要设置成什么,才能输入中文呢?

再问一下,HP-UX的终端TERM要设置成什么,才能输入中文呢? 我试了,可以了,谢谢!非常感谢!/etc/profile中export LANGzh_CN.hp15CNstty cs8stty -istripstty -parenb怎么要设置这么多呀?我单独只设置stty -istrip也可以了,想请教你为什么要设置那么多??谢谢! 网址&#xff1a…

【SDOI 2011】Paint 染色

http://www.zybbs.org/JudgeOnline/problem.php?id2243 题目大意&#xff1a;给你一棵树&#xff0c;节点有颜色&#xff0c;要求可以查询某路径中连续颜色段的数目和修改某一段路径的颜色。 两次拉实之后查询和修改即可。 #include <iostream> #include <cstdio>…

部署Windows Server Update Services 4.0

在 Windows Server 2012 中&#xff0c;WSUS 是可安装以管理和分配更新的服务器角色。WSUS 服务器可以作为组织内其他 WSUS 服务器的更新源。充当更新源的 WSUS 服务器被称为上游服务器。在 WSUS 实现过程中&#xff0c;网络中必须至少有一台 WSUS 服务器连接到 Microsoft 更新…

克罗谈投资策略09

第七章 把注意力集中在长期趋势上&#xff08;2&#xff09; 我接到很多交易者寄来的信和打来的电话&#xff0c;谈论投机交易的各个层面。但是其中匹兹堡一位专业交易者1984年8月所写的一封信&#xff0c;跟上面所说的主题有特别的关联&#xff1a; 大家都说在目前的市场情况下…

dedecms织梦最新0day

拿webshell的方法如下&#xff1a; 网传的都是说要知道后台才能利用&#xff0c;但不用&#xff0c;只要 plus 目录存在&#xff0c;服务器能外连&#xff0c;就能拿shell. 前题条件&#xff0c;必须准备好自己的dede数据库&#xff0c;然后插入数据&#xff1a; insert into d…

JSP注释方法

<html><head><title>注释</title></head><body><!-- --> 这些是显示注释&#xff0c;不在页面中显示&#xff0c;但可以在客户端HTML源文件中看到&#xff0c;会被JSP引擎解释<!--例如&#xff1a;本文件加载日期为<%new …

《统计学习方法》(李航)读书笔记(转)

《统计学习方法》(李航)读书笔记(转) http://www.cnblogs.com/limitlessun/p/8611103.html#_label4阅读目录 知识点感知机k近邻法朴素贝叶斯决策树logistic回归和最大熵模型支持向量机提升方法EM算法隐马尔可夫模型(HMM)统计学习方法总结神经网络K-MeansBaggingApriori降维方法…

Windows 关闭进程例子

HANDLE handle CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);PROCESSENTRY32* info new PROCESSENTRY32;info->dwSize sizeof(PROCESSENTRY32);if(Process32First(handle,info)){if(GetLastError()ERROR_NO_MORE_FILES){TRACE("进程查找初始化失败&#xff01;&…

【转】Linux/ubuntu下apache+svn安装配置

Author:gaojinbo Time:2010-8-30 优点&#xff1a; 可以通过apache记录svn操作相关日志 环境&#xff1a; ubuntu 10.04.1 lts 64bit apache2.2 1.安装相关包 apt-get install apache2 libapache2-svn subversion cronolog 2.建立一个svn库 mkdir -p /www/svn/ svnadmin create…

SVN源码

SVN源码&#xff1a;http://code.google.com/p/tortoisesvn/source/browse/

html奇淫技巧 2 教你如何进行图文环绕布局 原创

在群里无意看到了盆友想要布局一个图文环绕的布局&#xff0c;问有没有什么办法实现&#xff0c;上网查了下&#xff0c;都感觉忽悠人的。 js 方面学的不怎么好&#xff0c;但是页面这块是不服输的。 于是就进行了研究&#xff0c;需求如下&#xff1a; 起先看到这张需求我是有…

Lync与Exchange 2013 UM集成:Lync Server配置

在完成了对Exchange的UM功能进行配置之后&#xff0c;我们要把UM的功能与Lync做集成的话还需要在Lync这边做一些配置。首先我们打开Lync前端服务器&#xff0c;然后打开核心组件安装目录下的Support文件夹&#xff0c;然后双击OcsUmUtil。打开之后我们单击加载数据&#xff0c;…

Windows下安装配置SubVersion的简明步骤

Windows下安装配置SubVersion的简明步骤 [使用的安装程序和文档说明] svn-1.4.0-setup.exe&#xff1a;Subversion服务端1.4.0安装程序&#xff1b; SubService.rar: SubServe服务Windows辅助工具; TortoiseSVN-1.4.0.7501-win32-svn-1.4.0.msi: 推荐使用的一个Windows资源管理…

LINUX-关机 (系统的关机、重启以及登出 )

shutdown -h now 关闭系统(1) init 0 关闭系统(2) telinit 0 关闭系统(3) shutdown -h hours:minutes & 按预定时间关闭系统 shutdown -c 取消按预定时间关闭系统 shutdown -r now 重启(1) reboot 重启(2) logout 注销 转载于:https://www.cnblogs.com/a-ant/p/10896448.ht…

在ubuntu中为程序添加图标快捷键

2019独角兽企业重金招聘Python工程师标准>>> 比如我在我的ubuntu上安装了javaEE eclipse&#xff0c;这个软件直接解压就可以用&#xff0c;这时在导航栏里没有对应图标&#xff0c;在左上角的软件中心中也没有图标&#xff0c;每次启动它得用命令来启动&#xff0c…

django--通过model拿到字段对象

import os os.environ.setdefault("DJANGO_SETTINGS_MODULE", "autoserver.settings")import django django.setup()from repository import modelsclsmodels.Disk #拿到所有的字段对象 for i in cls._meta.fields:print(i.name,i.verbose_name)#字段的名字…

FTP 和HTTP

http://zhidao.baidu.com/question/4917179.html FTP下载和HTTP下载有何不同&#xff1f; 互联网上有很多可以下载各种各样好用工具的站点。在这些站点下载文件时&#xff0c;您是否因需要选择“HTTP下载”和“FTP下载”而感到过不知所措呢&#xff1f;两者间究竟有什么区别呢&…

更改消息存储的位置

2019独角兽企业重金招聘Python工程师标准>>> 更改消息存储的位置 将消息存储位置更改为另一目录或文件系统。 开始之前 记录部署至要配置的集群的 IBM Lotus Connections 功能部件。 关于此任务 集群成员多于一个节点时&#xff0c;消息存储必须对集群中位于相同物…

【原创】StreamInsight查询系列(三)——基本查询操作之过滤

上篇博文介绍了如何在LINQPad中输出StreamInsight查询结果。这篇文章将主要介绍StreamInsight基础查询操作中的过滤部分。 测试数据准备 为了方便测试查询&#xff0c;我们首先准备一个静态的测试数据源&#xff1a;var weatherData new[] {new { Timestamp new DateTime(201…