- 1、本文档共76页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
dsp第四讲--第3章C_C程序编写基础
第3章 C/C++程序编写基础;3.1 C/C++编辑器概述;3.1.1 C/C++语言的主要特征 ;3.1.2 输出文件 ;3.1.3 编译器接口 ; 2.灵活的汇编语言接口 ;3.1.4 编译器操作 ;2.代码优化 ;3.1.5 编译器工具 ;3.2 TMS320X28xx的C/C++编程; 传统的C/C++编程访问处理器的硬件寄存器主要采用#define宏的方式。
为了说明宏定义方法,下面以SCI接口的编程为例进行介绍。课本表3.1给出了SCI-A和SCI-B的寄存器文件及相关的地址。;1.SCI-A寄存器 ;寄存器名称;/******************************************************
*采用宏定义的方法定义的头文件
******************************************************/
#define Uint16 unsigned int
#define Uint32 unsigned long
#define SCICCRA (volatile Uint16*)0x7050 //0x7050 SCI-A通信控制寄存器
#define SCICTL1A (volatile Uint16*)0x7051//0x7051 SCI-A控制寄存器1
#define SCIHBAUDA(volatile Uint16*)0x7052//0x7052 SCI-A波特率设置寄存器,高位
#define SCILBAUDA(volatile Uint16 * )0x7053// 0x7053 SCI-A波特率设置寄存器,低位
。
。
。; 在编程过程中,上述的每一个宏定义都可以用作指向寄存器的指针,直接访问相关的寄存器。;缺点:;3.2.3 位定义和寄存器文件结构方法 ;(2)位区定义
位区定义可以为寄存器内的特定功能位分配一个相关的名字和相应的宽度,允许采用位区定义的名字直接操作寄存器中的某些位。例如,可以直接利用状态寄存器的位定义的名字直接读取状态寄存器中相应的位。; 以SCI的操作为例,介绍寄存器文件结构和位区定义的使用,在使用过程中主要完成下列操作:
① 为SCI的使用创建新的数据类型;
② 将寄存器文件结构变量映射到使用的第一个寄存器地址;
③ 为指定的SCI寄存器增加位区定义;
④ 为访问位区或整个寄存器增加共同体定义;
⑤ 重新编写寄存器文件结构体类型,使其包含位区定义和共同体定义。; 1.定义寄存器文件结构 ;[例3.3] SCI寄存器文件结构定义 ; 在例3.3中创建了一个新的结构体struct SCI_ REGS,而未定义任何相关变量。例3.4中给出了结构体变量的定义方法,在C281x处理器中有2个SCI通信接口,因此在编程过程中定义寄存器结构体变量可以采用例3.4中的方式。 ; 2.寄存器文件结构的空间分配 ;在C语言中“# pragma DATA_SECTION”的编程方式如下:
#pragma DATA_SECTION (symbol,“section name”)
在C++语言中“# pragma DATA_SECTION”的编程方式如下:
#pragma DATA SECTION (section name); 例3.5 采用“# pragma DATA_SECTION”将变量SciaRegs和ScibRegs分配到名字为SciaRegsFile和ScibRegsFile的数据段。然后这两个数据段直接映射到SCI寄存器所占的存储空间。; 例3.5 采用“# pragma DATA_SECTION”将变量SciaRegs和ScibRegs分配到名字为SciaRegsFile和ScibRegsFile的数据段。然后这两个数据段直接映射到SCI寄存器所占的存储空间。; 可以采用上述方法将每个外设的寄存器变量分配到数据段。链接命令文件会将每个数据文件直接映射到相应的存储空间。课本表3.1给出了SCI-A寄存器映射到起始地址为0x7050的存储空间。使用分配好的数据段,变量SciaRegs将会分配到起始地址为0x7050的存储空间。相
您可能关注的文档
最近下载
- 市场营销原理(第13版) 科特勒 课件 中文版.ppt
- 陕西省全省性社会团体章程示范文本(陕西省2022版).pdf VIP
- 2025学年高一下学期期中考试物理试卷 Word版含答案 .pdf VIP
- 2023高考语文新课标I卷现代文阅读II《给儿子》小说精读及试题详解.docx
- 2025年许昌电气职业学院单招职业适应性测试题库往年题考.docx VIP
- 寿盒(骨灰盒)供应及售后服务方案.pdf VIP
- 适老化全场景技术规范 第2部分:既有居住建筑适老化改造技术标准 .pdf VIP
- 生态系统多样性及保护.pptx VIP
- (高清版)ZT 0331-2020 地热资源评价方法及估算规程.pdf VIP
- T∕CBMCA 057.1-2024 适老化全场景技术规范 第1部分:居住建筑适老化基本要求.pdf
文档评论(0)