第4章C55x处理器的软件设计课件.ppt
《第4章C55x处理器的软件设计课件.ppt》由会员分享,可在线阅读,更多相关《第4章C55x处理器的软件设计课件.ppt(103页珍藏版)》请在三一办公上搜索。
1、第4章 C55x处理器的软件设计,内容提要 C55x系列处理器应用灵活、处理能力强大,为开发、使用提供了一个很好的硬件平台,要使这个平台更好的发挥作用,高效、方便的软件设计是不可或缺的。程序的主体框架和对实时性要求不高的部分采用C/C+语言,而算法实现采用汇编语言,这样能够充分发挥二者的优点,解决易读性和效率之间的矛盾。同时也改善了软件的移植性,在软件移植时不用改变程序的主体框架,只要为处理器提供相应的算法即可。本章主要介绍了C55x处理器的程序基本结构,C语言编程以及优化,C语言与汇编语言的混合编程,通用目标文件格式,最后对C55x处理器的数字信号处理库和图像、视频处理库进行了介绍。,202
2、3/1/11,1,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 内容提要 2022/9/2,第4章 C55x处理器的软件设计,4.1 C55x处理器程序基本结构4.2 C语言程序开发及优化4.3 C语言与汇编语言的混合编程4.4 通用目标文件格式4.5 C55x处理器的数字信号处理库和图像、视频处理库,2023/1/11,2,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1 C55x处理器程,第4章 C55x处理器的软件设计,C55x处理器软件开发流程,2023/1/11,3,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 C55x处理器软件开
3、发流程,第4章 C55x处理器的软件设计,汇编器:是把汇编源代码转换成机器语言。,汇编器:是把汇编源代码转换成机器语言。,链接器:则将多个目标文件结合成一个可执行文件。,归档器:可以把一组文件归档为一个库,供用户使用。,如果用户只用汇编语言编写程序,则将跳过C编译器而直接通过汇编器生成目标文件。,2023/1/11,4,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 汇编器:是把汇,第4章 C55x处理器的软件设计,4.1 C55x处理器程序基本结构,根据任务调度的方式不同,C55x处理器程序大体可以分为两类:(1)由程序自己完成任务调度 程序运行效率高,对硬件中断响应快,程序运
4、行稳定,适合于任务较为单一,实时性较强的应用;(2)由嵌入式操作系统完成任务调度 但如果要利用处理器同时完成多个任务,应用嵌入式操作系统是十分有必要的,这是因为嵌入式操作系统可以将应用分解为多个任务,简化了应用系统软件设计,更为重要的是良好的多任务设计有助于提高系统的稳定性和可靠性。,2023/1/11,5,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1 C55x处理器程序,第4章 C55x处理器的软件设计,4.1.1 自我调度程序的基本结构,虽然嵌入式操作系统已经发展得较为成熟,但通过程序自身完成任务调度仍然保持着旺盛的生命力,这是因为这种方式适合于DSP这种需要对大量
5、实时数据完成顺序处理的应用。下面给出自我调度程序的基本结构。,中断程序1;中断程序m;Main()DSP_INT();/DSP初始化For(;)/主循环if(条件1)/判断条件1处理模块1;/条件满足运行处理模块1;if(条件n)/判断条件n处理模块n;/条件满足运行处理模块n;,2023/1/11,6,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.1 自我调度程序的,第4章 C55x处理器的软件设计,初始化部分通常完成DSP软、硬件的初始化设置,启动系 统硬件,使能DSP中断,启动DMA传送等工作。主循环部分是程序的主体,将由它完成数据输入、处理和输出等工作。主循环由
6、条件判断和处理模块组成,当满足条件时运行处理模块,不满足条件则自动跳到下一个判断条件。中断程序通常不进行数据处理,只通过设置判断标志来影响主循环部分的运行。,自我调度程序通常由中断程序部分、初始化部分和主循环部分组成:,4.1.1 自我调度程序的基本结构,2023/1/11,7,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 初始化部分通常完,第4章 C55x处理器的软件设计,为了满足实时运行的要求,自我调度程序的主循环部分必须将处理时延限制在最大可接受时延内,具体来说就是运行主循环的所有分支的时间总和必须小于最大可接受时延,如果不能满足这一条件,则在最坏情况下,会造成处理数据的
7、不连续,而无法实现数据的实时处理。,当所编写的程序没有满足上述条件时,则需要对处理流程进行修改,或修改处理算法以满足条件。,4.1.1 自我调度程序的基本结构,2023/1/11,8,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 为了满足实时运行的,第4章 C55x处理器的软件设计,在数字信号处理器中运行的操作系统必须满足系统实时性要求,而操作系统的实时方式可以分成两种硬实时方式和软实时方式。,软实时系统由软件来进行任务的切换,而硬实时系统则按照固定时钟节拍切换任务。软实时系统使各个任务尽快运行,而不要求限定某个任务在多长时间内完成;硬实时系统中各任务不仅要执行无误,而且要准时
8、。,4.1.2 应用嵌入式操作系统,嵌入式实时操作系统的作用就是合理调度、分配任务的运行,使各个任务正确、及时地执行。,2023/1/11,9,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 在数字信号处理器中,第4章 C55x处理器的软件设计,嵌入式操作系统的核心是操作系统内核,在多任务系统中,内核负责管理各个任务,为每个任务分配CPU时间,负责任务间的通信和任务切换。根据其重要程度的不同系统中每个任务被赋予一定的优先级,内核将根据任务的优先级进行任务调度。基于优先级的内核可以分成不可剥夺型和可剥夺型两种类型。,4.1.2 应用嵌入式操作系统,2023/1/11,10,DSP原
9、理及应用原理及应用,第4章 C55x处理器的软件设计 嵌入式操作系统的核,第4章 C55x处理器的软件设计,1.不可剥夺型内核,不可剥夺型内核要求每个任务主动放弃CPU使用权,这种任务的调度方法也可以叫做合作型多任务,每个任务相互合作,共享一个CPU。,不可剥夺型内核中的异步事件由中断服务来处理,中断服务可以使一个高优先级的任务由挂起态变为就绪态;但在中断服务之后,CPU的使用权还给原来被中断的任务,直到该任务主动放弃CPU的使用权,一个高优先级的任务才能进入运行态。,4.1.2 应用嵌入式操作系统,2023/1/11,11,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 1.不
10、可剥夺型内核,第4章 C55x处理器的软件设计,这种内核的优点是响应中断快,采用不可剥夺型内核允许任务使用不可重入函数,每个任务调用不可重入型函数不必担心其他任务可能使用该函数而造成数据破坏。使用不可剥夺型内核时,任务的响应时间取决于最长任务的执行时间。使用该内核很少需要使用信号量保护共享数据,这是因为正在运行的任务不必担心其他任务抢占CPU;但如果任务使用共享设备时,还应使用互斥型信号量。,4.1.2 应用嵌入式操作系统,1.不可剥夺型内核,2023/1/11,12,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 这种内核的优点是响,第4章 C55x处理器的软件设计,不可剥夺型
11、内核的缺点是响应时间具有不确定性,无法确定最高优先级的任务何时能够获得CPU的使用权。,2.可剥夺型内核,可剥夺型内核运行时,一旦具有最高优先级的任务就绪,就总能得到CPU的使用权。当有一个具有更高优先权的任务进入就绪态时,当前运行的任务将被挂起,更高级的任务立刻得到CPU的使用权。,1.不可剥夺型内核,4.1.2 应用嵌入式操作系统,2023/1/11,13,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 不可剥夺型内核的缺,第4章 C55x处理器的软件设计,如果是中断服务子程序使一个高优先级的任务进入就绪状态,中断完成后,被中断的任务被挂起,开始运行更高级的任务。使用可剥夺型
12、内核可以随时执行最高级任务,这使得任务的响应时间得以最优化。使用可剥夺内核要求应用程序不应直接使用不可重入函数,如果要使用则应满足互斥条件。,4.1.2 应用嵌入式操作系统,2.可剥夺型内核,2023/1/11,14,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 如果是中断服务子程,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,内核的主要工作是完成任务的调度,任务也可称作线程,是一个简单的程序,该程序认为CPU完全属于自己。操作系统要求把系统所要完成的工作分解为多个任务,每个任务都是应用的一部分。任务都被赋予一定的优先级,并拥有自己的一套CPU寄存器和堆栈空
13、间。,2023/1/11,15,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,任务是一个无限循环,它必须处于下列5个状态之一:,休眠状态是任务驻留在内存之中,但并没有被系统内核所调用;就绪状态是任务已经准备好,但由于该任务的优先级比正在运行的任务的 优先级低,还暂时不能运行;运行状态是任务拥有CPU的使用权,正在运行;挂起状态是任务正在等待某一个事件的发生以结束目前的等待(如等待外设的I/O操作、等待共享资源、等待定时或超时信息等事件);发生中断时,CPU进入中断服务程序,而暂时不能运
14、行当前的任务,任务就进入了被中断态。,2023/1/11,16,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,操作系统需要在多个任务之间转换和调度,这是因为CPU在某一时刻只能为一个任务提供服务,CPU必须为一系列任务轮流服务。多任务运行可以使CPU的利用率达到最高,并使应用程序模块化,使用多任务可以使程序更容易设计和维护。,当任务从当前任务切换到另一个任务时,必须保存正在执行的任务的当前状态。所谓“任务的当前状态”即CPU寄存器中的所有内容;这些内容被保存在任务自己的堆栈中,以备任务
15、下次执行时恢复当前状态。在保存完当前任务后,要把下一个任务的当前状态装入CPU寄存器,并开始下一个任务的运行,这一过程叫做“任务切换”。,2023/1/11,17,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,每个任务都有其优先级,任务越重要,被赋予的优先级应越高。如果程序执行过程中任务的优先级不变,则称为静态优先级;反之则称为动态优先级。,所谓“任务管理”就是在内核的控制下任务在五种状态之间切换。,2023/1/11,18,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计
16、 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,不同任务之间有可能会使用共同的资源,当它们同时使用共享资源时有可能发生错误,嵌入式操作系统提供了信号量这一约定机制,通过该机制可以控制共享资源的使用权,或标志某一事件的发生,也可以用来为两个任务同步。信号量有两种类型二进制型和计数器型,实际上二进制型可以看作一个只有一位的计数器型信号量。,2023/1/11,19,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,信号量可以看作一把钥匙。当任务要
17、运行时首先要取得这把钥匙。如果信号量已经被其他任务占用,那么该任务只好挂起并等待信号量被当前使用者释放。,2023/1/11,20,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,任务要使用信号量,首先要对信号量进行初始化。如果任务要得到信号量,首先要执行“等待”操作。如果该信号量有效(信号量的值大于0),则该信号量值减1,任务得以继续执行。如果信号量的值为0,等待信号量的任务就被列入等待信号量任务表。,2023/1/11,21,DSP原理及应用原理及应用,第4章 C55x处理器的软件设
18、计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,如果等待时间超过某一设定值,该信号量还无效,那么等待信号量的任务自动进入就绪状态并准备运行,并向系统报一个“超时错误”信息。,4.1.2 应用嵌入式操作系统,2023/1/11,22,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 如果等待时间超过某,第4章 C55x处理器的软件设计,实际上,等待该信号量的任务可能有多个。在嵌入式操作系统中通常依照优先级来决定由哪个任务取得信号量。,任务还可以释放信号量。,如果有任务等待该信号量,那么就会有一个任务进入就绪状态,信号量的值不增加。,如果这时没有任务等待信号量,则信号
19、量的值加1。,4.1.2 应用嵌入式操作系统,2023/1/11,23,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 实际上,等,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,两个任务之间可以利用信号量来取得同步,这种同步可以分成两类单向同步和双向同步。所谓“单向同步”是指任务用一个信号量触发另一个任务。,单向同步,2023/1/11,24,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,当两个任务需要相互同步对方,这时就要用到双向同步。,两个任务的双向同步,4.1.2 应用嵌入式操
20、作系统,2023/1/11,25,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 当两个任务需要相互,第4章 C55x处理器的软件设计,4.1.2 应用嵌入式操作系统,任务之间的通信可以通过两个途径:全局变量或消息。使用全局变量必须保证任务或中断服务子程序,在使用该变量时没有其他的任务或中断服务子程序访问该变量。另外,如果任务没有其他机制通知其变量已经被修改了,任务就只能周期性地查询该变量的值。要避免这种情况,可以考虑使用消息邮箱或消息队列。,2023/1/11,26,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器
21、的软件设计,4.1.2 应用嵌入式操作系统,消息邮箱是一个任务或一个中断程序。通过一个指针型变量把一个消息(指针)放到邮箱之中,而一个或多个任务通过内核服务可以接收到这个消息。内核可以提供下列邮箱服务:初始化邮箱内的消息;将消息放入邮箱;等待消息进入邮箱;从邮箱中取得消息。,2023/1/11,27,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.1.2 应用嵌入式操作,第4章 C55x处理器的软件设计,消息队列则是任务或中断程序把一个消息指针放到消息队列之中,而一个或多个任务通过内核服务从消息队列中接收消息。内核提供消息队列服务如下:消息队列初始化,即将消息队列清空;将一个
22、消息放到消息队列之中;等待消息到来;得到消息。,4.1.2 应用嵌入式操作系统,2023/1/11,28,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 消息队列则是任务或,第4章 C55x处理器的软件设计,TMS320C55x处理器为C语言开发提供了一系列工具,包括:优化C/C+编译器、链接器和归档器。并支持混合编程。C语言的优点在于程序可读性强。,4.2 C语言程序开发及优化,2023/1/11,29,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 TMS320C55,第4章 C55x处理器的软件设计,4.2.1 C语言中的数据类型,C55x支持下列数据类型包括
23、字符、定点数、浮点数、指针等。,4.2 C语言程序开发及优化,2023/1/11,30,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 4.2.1 C语言中的数,第4章 C55x处理器的软件设计,char,unsigned char,pointers(数据指针),小存储器模式,16位,0 xFFFF,2023/1/11,31,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 char,unsigne,第4章 C55x处理器的软件设计,指针分为程序指针和数据指针两种,其区别在于程序指针寻址是按字节寻址,而数据指针以字为单位进行寻址。,2023/1/11,32,DSP原理
24、及应用原理及应用,第4章 C55x处理器的软件设计 类 型长 度内,第4章 C55x处理器的软件设计,C55x处理器包含数据空间和I/O空间,为了在C/C+中对I/O空间进行寻址,编译器给出了关键字ioport,以支持I/O寻址模式。,ioport关键字可以用在数组、结构、联合以及枚举类型当中。,当用在数组中时,ioport可以作为数组中的元素;在结构中使用ioport,只能是指向ioport数据的指针而不能直接作为结构的成员。,4.2 C语言程序开发及优化,4.2.2 对I/O空间进行寻址,2023/1/11,33,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 C55x处,第
25、4章 C55x处理器的软件设计,ioport类型只能用来声明全局或静态变量,如果在本地变量中使用ioport类型,则变量必须用指针声明。接下来给出指针声明ioport类型的例子:,void foo(void)ioport int i;/*无效的声明*/ioport int*j;/*有效声明*/,应当注意声明ioport类型的指针只有16位,这是因为I/O空间是16位寻址,而不受大/小存储器模式的限制。,4.2.2 对I/O空间进行寻址,2023/1/11,34,DSP原理及应用原理及应用,第4章 C55x处理器的软件设计 ioport类型只,第4章 C55x处理器的软件设计,在printf()
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C55x 处理器 软件设计 课件
链接地址:https://www.31ppt.com/p-2109133.html