DSP一点知识总结_dspalu要对要对输出数据进行溢出保护的语句_tony821224的博客-程序员秘密

技术标签: allocation  语言  汇编  编译器  filenames  存储  

第1章 DSP芯片的定点运算
1. 数据的溢出:
1> 溢出分类:
上溢(overflow):
下溢(underflow)
2>溢出的结果:
unsigned char 0 255
signed char -128 127
unsigned int 0 65535
signed int -32768 32767
上溢在圆圈上按数据逆时针移动;下溢在圆圈上顺时钟移动。
例:signed int :32767+1=-32768; -32768-1=32767
unsigned char:255+1=0; 0-1=255
3>为了避免溢出的发生,一般在DSP中可以设置溢出保护功能。当发生溢出时,自动将结果设置为最大值或最小值。

2. 定点处理器对浮点数的处理:
1> 定义变量为浮点型(float,double),用C语言抹平定点处理器和浮点处理器的区别,但是程序的代码庞大,运算速度也慢。
2> 放大若干倍表示小数。比如要表示精度为0.01的变量,放大100倍去运算,运算完成后再转化。但是这个做法比较僵硬,如要将上面的变量重新定义成0.001精度,又需要放大 1000倍,且要重新编写整个程序,考虑溢出等问题。
3> 定标法:Q格式:通过假定小数点位于哪一位的右侧,从而确定小数的精度。
Q0:小数点在第0位的后面,即我们一般采用的方法
Q15 小数点在第15位的后面,0~14位都是小数位。
转化公式:Q=(int)(F×pow(2,q))
F=(float)(Q×pow(2,-q))
3. Q格式的运算
1> 定点加减法:须转换成相同的Q格式才能加减
2> 定点乘法:不同Q格式的数据相乘,相当于Q值相加
3> 定点除法:不同Q格式的数据相除,相当于Q值相减
4> 定点左移:左移相当于Q值增加
5> 定点右移:右移相当于Q减少
4. Q格式的应用格式
实际应用中,浮点运算大都时候都是既有整数部分,也有小数部分的。所以要选择一个适当的定标格式才能更好的处理运算。一般用如下两种方法:
1> 使用时使用适中的定标,既可以表示一定的整数复位也可以表示小数复位,如对于2812的32位系统,使用Q15格式,可表示-65536.0~65535.999969482区间内的数据。
2> 全部采用小数,这样因为小数之间相乘永远是小数,永远不会溢出。取一个极限最大值(最好使用2的n次幂),转换成x/Max的小数(如果Max是取的2的n次幂,就可以使用移位代替除法)。
5. Ti的qmath.lib库说明:
见TI的文档C28x IQMath Library (SPRC087a).zip的详细说明。
TI公司给出了一个Q格式的数学库qmath.lib
注意Q格式函数使用的时序和空间要求,尽量避重就轻。
第二章 CMD文件的编写
1. COFF格式
1> 通用目标文件格式(Common Object File Format)是一种流行的二进制可执行文件格式,二进制可执行文件包括库文件(lib),目标文件(obj)最终可执行文件(out)。,现今PC机上 的Windows95和NT4.0以后的操作系统的二进制文件格式(PE)就是在COFF格式基础上的进一步扩充。
2> COFF格式:详细的COFF文件格式包括段头,可执行代码和初始化数据,可重定位信息,行号入口,符号表,字符串表等,这些属于编写操作系统和编译器人员关心范畴。而对于C只需要了解定义段和给段分配空间就可以了。
3> 采用COFF更有利于模块化编程,程序员可以自由决定愿意把哪些代码归属到哪些段,然后加以不同的处理。
2. Section目标文件中最小单位称为块。一个块就是最终在存储器映象中占据连续空间的一段代码或数据。
1> COFF目标文件包含三个默认的块:
.text可执行代码
.data已初始化数据
.bss为未初始化数据保留的空间
2> 汇编器对块的处理
未初始化块
.bss 变量存放空间
.usect 用户自定义的未初始化段
初始化块
.text 汇编指令代码
.data 常数数据(比如对变量的初始化数据)
.sect 用户自定义的已初始化段
.asect 通.sect,多了绝对地址定位功能,一般不用
3>C语言的段
未初始化块(data)
.bss 存放全局和静态变量
.ebss 长调用的.bss(超过了64K地址限制)
.stack 存放C语言的栈
.sysmem 存放C语言的堆
.esysmem 长调用的.sysmem(超过了64K地址限制)
初始化块
.text 可执行代码和常数(program)
.switch switch语句产生的常数表格(program/低64K数据空间)
.pinit Tables for global constructors (C++)(program)
.cinit 用来存放对全局和静态变量的初始化常数值(program)
.const 全局和静态的const变量初始化值和字符串常数,(data)
.econst 长.const(可定位到任何地方)(data)
3> 自定义段(C语言)
#pragma DATA_SECTION(函数名或全局变量名,"用户自定义在数据空间的段名");
#pragma CODE_SECTION(函数名或全局变量名,"用户自定义在程序空间的段名");
不能在函数体内声明。
必须在定义和使用前声明
#pragma可以阻止对未调用的函数的优化
3. 连接命令文件(CMD)
1> MEMORY指定存储空间
MEMORY
{
PAGE 0: 
name 0 [attr] : rigin = constant, length = constant 
PAGE n: 
name n [attr] : rigin = constant, length = constant 
}
PAGE n:标示存储空间,n<255;PAGE 0为程序存储空间;PAGE 1为程序存储空间
name:存储空间名称
attr:存储空间属性:只读R,只写W,可包含可执行代码X,可以被初始化I。
orgin:用来定义存储空间的起始地址
Lenth:用来定义存储空间的长度
2> SECTIONS分配段
SECTIONS
{
name : [property,property,……]
}
name:输出段的名称
property:输出段的属性:
load=allocation(强制地址或存储空间名称)同>allocation:定义输出段将会被装载到哪里。
run= allocation(强制地址或存储空间名称)同>allocation:定义输出段将会在哪里运行。
注:CMD文件中只出现一个关键字load或run时,表示两者的地址时表示两者的地址时重合的。
PAGE = n,段位于那个存储页面空间。
例:ramfuncs : LOAD = FLASHD, 
RUN = RAML0, 
LOAD_START(_RamfuncsLoadStart),
LOAD_END(_RamfuncsLoadEnd),
RUN_START(_RamfuncsRunStart),
PAGE = 0

3> 直接写编译命令
-l rts2800_ml.lib 连接系统文件rts2800_ml.lib
-o filename.out 最终生成的二进制文件命名为filename.out
-m filename.map 生成映射文件filename.map
-stack 0x200 堆栈为512字

4. .const段:
由关键字const限定的全局变量(const限定的局部变量不产生)初始化值,和出现在表达式(做指针使用,而用来初始化字符串数组变量不产生)中的字符串常数,另外数组和结构体是局部变量时,其初始值会产生.const段,而全局时不产生。
第3章 C语言环境
1.C语言软件开发过程
软件开发过程涉及编译器(compiler),汇编器(assembler),连接器(linker),归档器(archiver),建库器 (library-build utility),运行支持库(run time support library),HEX转换器(hex conversion utility),交叉引用列表器(cross reference lister),绝对列表器(absolute lister)等。其大都设置既可通过命令,也可通过ccs的project/build options设置。
1>.编译器:对C语言源代码进行编译,产生汇编语言源代码。
一步编译:cl2000 –v28 [-options] filenames [object files] [-z [link_options]]
分布编译:文法分析: 生成file.if的中间文件 ac2000 file.c
代码优化: 生成file.opt的文件 opt2000 file.if
代码生成: 生成file.asm的汇编文件 cg2000 file.opt
汇编: 生成file.obj目标文件 asm2000 file.asm
2>.汇编器:把汇编语言源文件翻译成机器语言目标文件,机器语言格式为公用目标格式(COFF)。具体命令格式如下:
asm2000 Version [input file [object file [listing file]]] [options]
3>.连接器:把多个目标文件组合成单个可执行目标模块。它一边创建可执行模块,一边完成重定位以及决定外部参考。连接器的输入是可重定位的目标文件和目标库文件.具体命令格式如下:
汇编语言:lnk2000 [options] filename1,filename2……[filenamen]
C语言:lnk2000 {-c|-cr} filenames [options] [-o name.out] [lnk.cmd] [-l libname,lib]
注: -c 运行时自动初始化变量
-cr 载入程序时自动初始化变量
options: 详见手册。
-o name.out 生成的输出文件名
lnk.cmd 连接的cmd文件名
-l libname.lib 连接的运行支持库名
例:lnk2000 –c prog1 prog2 prog3 –o prog.out rts2800.lib
4>.归档器(Archiver)
归档器Archiver可以用来对文档(Archive)或者库(library)中的文件进行分离和合并。这些文档或库可以是源文件库,也可以时目标文件库。归档器可以对库进行新建,添加,删除,替换,提取等操作,具体命令格式如下:
ar2000 [-]command [options] libname [filename0,filename1,……filenamen]
1> 此命令针对TMS320F2812而言,其他类DSP命令以及格式略有不同,可详查TI的文档。此命令所在目录在/CCS_v3.1/C2000/cgtools/bin
2> command:
@ 使用CMD文件
a (add) 向指定文档中添加指定文件
d (delete) 删除指定文档中的指定文件
r (replace) 替换指定文档中的指定文件
t (table) 列出指定文档中的文件
x (extract) 提取指定文档中的指定文件
3> options:
q(quiet) 屏蔽状态信息
s(symbol) 列出库中定义的全局符号(对命令a,r,d无效)
u 替换文件时同步更新修改日期
v(verbose) 提供详细的描叙
4> libname 指定的文档名
5> filename 文档中指定的文件名

5>. 建库器(library-build utility): 建立满足你自己要求的运行支持库.CCS中提供有rts库文件(/CCS_v3.1/C2000/cgtools/lib),并提供了对应的源程序文件 rts.src(/CCS_v3.1/C2000/cgtools/lib)。如:rts2800.lib:C/C++运行支持库; rts2800_ml.lib C/C++大内存模式运行支持库;用户可以利用归档器和建库器对rts.src中的文件进行提取,修改等操作,并重新生成自己需要的库文件。
命令的具体格式如下:
mk2000 –v28 [options] src_arch1 [-l objlib1] src_arch1 [-l objlib1]……

6>. 运行支持库(run time support library): 它包括C编译器所支持的ANSI标准运行支持函数、编译器公用程序函数、浮点运算函数和C编译器支持的I/O函数. CCS中提供有rts库文件(/CCS_v3.1/C2000/cgtools/lib),并提供了对应的源程序文件rts.src(/CCS_v3.1 /C2000/cgtools/lib)。如:rts2800.lib:C/C++运行支持库;rts2800_ml.lib C/C++大内存模式运行支持库.库文件包括标准的C/C++运行支持库函数,浮点运算程序,系统启动程序_c_int00.

7>. HEX转换器(hex conversion utility): 它把COFF目标文件转换成TI-Tagged、ASCII-hex、 Intel、 Motorola-S、或 Tektronix 等目标格式,可以把转换好的文件下载到EPROM编程器中.
hex2000 [-options] filename
-a ASCII-HEX
-i Intel
-t Ti-Tagged
-m Motorola-S
-x Tektronix

8>.交叉引用列表器(cross reference lister): 它用连接的目标文件产生参照列表文件,可显示符号及其定义,以及符号所在的源文件.
xref2000 [options] [input filename [output filename]]
options: -lxx 每页显示xx行(十进制数)
-q(quiet) 不显示提示消息
input filename obj文件
output filename 生成的xrf文件

9>.绝对列表器(absolute lister): 它输入连接后的目标文件,输出.abs文件,通过汇编.abs文件可产生含有绝对地址的列表文件。如果没有绝对列表器,这些操作将需要冗长乏味的手工操作才能完成。
abs2000 [-options] input file
options: -e 改变缺省的文件后缀名
-ea[.]asmext asm->asmtxt
-ec[.]cext c->ctxt
-eh[.]hext h->htxt
-ep[.]cppext cpp/cc/cxx ->ptxt
-fs 指定输出文件目录。如:–fs C:/ABSDIR
-q 不显示提示消息
input file .out文件
例如:abs2000 –ea s –ec csr –eh hsr hello.out生成文件hello.s(hello.asm),hello.csr(hello.c),hello.hsr(hello.h).
DSP总结3-C语言环境2
1. 用户库的创建:
1> DOS命令:使用归档器ar2000命令和汇编编译连接等命令进行手工创建。
2> CCS直接创建,在CCS中建立工程对话框的时候有一个可选择建立lib文件的选项。可直接把工程中的asm,c等文件直接整合生成一个库文件(不包括CMD文件)。
2.CCS概述
DSP芯片开发工具可分为两大类:
代码生成工具:
代码调试工具:C/汇编语言源码调试器,初学者工具DSK,软件模拟器(Simulator),评价模块EVM,软件开发系统SWDS,仿真器XDS.

3.C编译器的优化:
1>C编译器优化分为2类:
C语言通用优化:简化表达式,数据流优化,删除公共子表达式和冗余分配,优化跳转,简化控制流,优化与循环有关的变量,将循环体内计算值不变的表达式移至循环体前,运行支持库函数的行内扩展。
根据DSP芯片的特定优化:高效地使用寄存器,自动增量寄存器寻址方式,使用块重复,使用并行指令,使用延迟跳转。
2>CCS的优化选项:

4.GEL语言的使用:
GEL(General Extension Language通用扩展语言)是一种类似于C语言的一种解释性语言,它可以创建GEL函数,以扩展CCS用途。
GEL是C语言的一个子集,然而它不能声明主机变量,所有的变量必须在DSP程序中定义,存在于仿真/实际目标板中,唯一不在目标板上定义的标识符是GEL函数及其参数。
GEL函数可在任何能键入C表达式的地方调用,既可以在任何可键入C表达式的对话框中调用,也可以在其他GEL函数中调用。但不支持递归。
可以将常用的GEL函数添加到CCS的GEL菜单下,此时需要使用menuitem关键词在GEL菜单下创建一个新的下拉菜单列表(一级菜单),再使用hotmenu,dialog和slider在该菜单项中添加新的菜单项(二级菜单)。
在CCS启动是自动执行GEL函数。SETUP CCS时设置环境时设置了自动执行GEL函数。自动运行StartUp()函数。这样要求每个工程建立时都载入GEL文件。
CCS提供了一系列嵌入GEL的函数。使用这些函数,用户可以控制仿真/实际目标板的状态,访问存储器,并在输出窗口中显示结果。

5.Probe Point的应用
Probe Point只是暂时中断程序的运行,更新与之相连接的窗口,然后自动运行以后的程序。与之相连接的窗口可在Probe Point设置中设置好,然后replace。
可使用Probe Point从PC文件中导入数据,也可存储数据到PC文件中,对PC文件的格式只能使用两种:COFF程序文件(.out);CCS数据文件(.dat)。
可利用Probe Point和Break Point配合显示图形和动画。显示图形使用View->Graph->Time/Frequency,设置好跳出的对话框,可看到一块内存 的数据,可使用Probe Point将PC上的数据传给目标板,然后继续运行程序。然后可以创建断点,使图形窗口自动更新,使用Animate命令,使到达断点后更新窗口后程序自 动继续执行。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/tony821224/article/details/5134366

智能推荐

【IoT毕业设计】树莓派开发板+机智云IoT+监测机器人_iot作品csdn_gizwits_csdn的博客-程序员秘密

摘要:以小车为基底,以树莓派开发板为中心,搭载摄像头、传感器等数据采集设备,采用CC2530为传感器处理器、ZigBee技术为无线传输,实现了各节点间的通信。以ItChat微信机器人框架为基础,二次开发植入百度AI开放平台的语音技术、图灵机器人的中文环境对话技术和机智云技术,以达到使用微信客户端文本或语音输入控制与管理设备的效果,解决了家电设备之间的互联互控互通问题,同时具备一次性或周期性定时功能,使人们在享受舒适生活环境的同时实现节能。前言随着物联网技术的飞速发展,智能家居的理念已经深入人

大数据学习[02]:hadoop安装配置_happyprince的博客-程序员秘密

摘要: 主要基于三台机器之上的hadoop2.7.3的下载、安装,及相关参数配置,所遇问题,Demo等。其中配置,包含hadoop运行环境,yarn运行环境配置,目的是搭建成基于yarn之上的RM运行环境,另外,也对资源限制的情况下作了一个示范性的设置。前置有一个局域网集群,例如在虚拟机上搭建的那样[1]大数据学习前夕[01]:系统-网络-SSH安装好JDK,及环境变量配置好;例如[2]大数据

OpenCV中Mat的详解_weixin_30328063的博客-程序员秘密

每次碰到Mat都得反复查具体的用法,网上的基础讲解不多,难得看到一篇,赶快转来收藏~原文地址:http://www.opencvchina.com/thread-1039-1-1.html目标我们有多种方法可以获得从现实世界的数字图像:数码相机、扫描仪、计算机体层摄影或磁共振成像就是其中的几种。在每种情况下我们(人类)看到了什么是图像。但是,转换图像到我们的数字设备时我们的记录是图...

Android 选择图片、上传图片之PictureSelector_?attr/picture.leftback.icon_冬无雪的博客-程序员秘密

效果图:【注意】Demo已更新到最新版本,并稍作调整。(2019-07-05)之前出过一篇 Android 选择图片、上传图片之ImagePicker,这个是okgo作者出的,就一般需求来讲是够了,但是没有压缩,需要自己去搞。后来业务需求提升,页面要美,体验要好,便不是那么满足需求了,所幸在github上找到PictureSelector(然后当时没多久Matisse就开源了…可以看这里:Android 选择图片、上传图片之Matisse),也不用自己再撸一个了,下面来介绍介绍Picture

一个简约精美的登录页面(HTML+CSS)_精美登录页面_GOV_D的博客-程序员秘密

最近简单学完了HTML和CSS,想自己做个简单的登录网页试试,大佬勿喷哈哈。页面效果实现代码&lt;!DOCTYPE html&gt;&lt;html lang="en"&gt;&lt;head&gt; &lt;meta charset="UTF-8"&gt; &lt;title&gt;登录页面&lt;/title&gt; &lt;link rel="stylesheet" href="css/style.css"&gt; &lt;script src="http

Spring整合Quartz框架定时任务_quartz 框架_tanyunlong_nice的博客-程序员秘密

最近项目中经常用到队列和定时任务及线程的整合应用,涉及的场景是当多人访问系统时需要回调客户系统处理结果时,如何减少服务器压力并能处理业务需求,这里用到了队列减少服务器压力加入定时任务发送机制,使用的是Spring框架整合 Quartz框架实现的定时任务,因此学习了一下Quartz的前因后果 在此记录学习一下。一、引入      你曾经需要应用执行一个任务吗?这个任务每天或每周星期二晚上11

随便推点

caffe euclidean loss ignore label_海边的第八只螃蟹的博客-程序员秘密

如果需要在Euclidean loss层ignore掉某一类标签,caffe框架里的Euclidean loss层并没有实现这一条件,需要自己根据已有的Euclidean loss层来更改。1.了解 euclidean loss计算方式http://blog.csdn.net/seashell_9/article/details/680642942.这个版本的Eucli

使用FreeRTOS进行性能和运行时分析_foxclever的博客-程序员秘密

在MCU on Eclipse网站上看到Erich Styger在2月25日发的博文,一篇关于使用FreeRTOS进行性能和运行分析的文章,本人觉得很有启发,特将其翻译过来以备参考。当然限于个人水平,有描述不当之处恳请指正。原文网址:https://mcuoneclipse.com/2018/02/25/performance-and-runtime-analysis-with-freertos/...

Getting Started with Linux-HA (Heartbeat)_duketang的博客-程序员秘密

Getting StartedThe first thing youll need is two computers. You need not have identical hardware in both machines (or amount of memory, etc.), but if you did, it would make your life that much easier

opencv python人脸检测_Python下应用opencv 实现人脸检测功能_BPATY的博客-程序员秘密

使用OpenCV's Haar cascades作为人脸检测,因为他做好了库,我们只管使用。代码简单,除去注释,总共有效代码只有10多行。所谓库就是一个检测人脸的xml 文件,可以网上查找,下面是一个地址:https://github.com/opencv/opencv/blob/master/data/haarcascades/haarcascade_frontalface_default.xm...

详解可重入函数与不可重入函数_可重入函数和不可重入函数_物联网老王的博客-程序员秘密

详解函数的可重入性;详解可重入函数和不可重入函数;如何设计可重入的函数。

mysql主从配置指定端口_change master to master_host 端口_文进的博客-程序员秘密

步骤如下:1、修改并重启主服务器master:修改master的mysql配置文件,启用二进制日志及设置服务器id。重启mysql   #vi /etc/my.cnf       [mysqld]       log-bin=mysql-bin   //[必须]启用二进制日志       server-id=102      //[必须]服务器唯一ID,默认是1,一般取IP最后一段  servic...

推荐文章

热门文章

相关标签