[资料分享] TMS320C2X/C5X的存储器模式

fish001   2019-1-8 21:51 楼主
       TMS320C2X/C5X定点处理器有两种类型的存储器:程序存储器和数据存储器。在程序存储器中主要包含可执行的程序代码,在数据存储器中,则主要包含外部变量、静态变量和系统堆栈。由C程序生成的每一块程序或数据存放于存储空间的一个连续块中。
        (一)C编译器生成的块
        由TMS320C2X/C5X编译器编译生成的块共有六种,可分为两大类。在六种块中,除了具有浮点C编译器生成的五种块之外,还有一个.switch块,它是一个已初始化块,包含为 .switoh语句建立的表格。
        (二)C系统堆栈
        定点C系统堆栈的作用与浮点c编译器的C系统堆栈的作用完全相同,管理堆栈的方法也基本类似。但管理C相同堆栈所用的寄存器是不一样的。定点C编译器采用下面两个寄存器来管理这个堆栈:
        AR1——是堆栈指针(SP)。它指向堆栈的顶部。
        AR0——帧指针(FP)。指向当前帧的开始。
        激活每个函数时,都在堆栈中建立一个新的帧,以用于分配局部变量和临时变量。C环境能够自动管理这些寄存器。如果需要编写用到运行堆栈的汇编程序,必须正确使用这些寄存器。
        与浮点C编译器一样,定点C编译器的堆栈长度也由链接器确定,全局符号_STACK_SIZE的值等于堆栈长度,单位为字节,缺省值为1K字节。同样,需要改变堆栈长度时,在链接时用-stack选项,并在其后指定一个数值。
        (三)动态存储器分配
        在运行支持库中,有几个允许在运行时进行动态存储器分配的函数,如malloc、calloc、realloc,动态存储器分配的方法与浮点C编译器的动态存储器分配完全相同。
        (四)静态和全局变量的存储器分配
        在C程序中说明的每一个外部或静态变量被分配给一个唯一的连续空间。空间的地址
由链接器确定。编译器保证这些变量的空间分配在多个字中以使每个变量按字边界对准。
        (五)域/结构的对准
        编译器为结构分配空间时,它分配足够的字以包含所有的结构成员,在一组结构中,每个结构开始于字边界。
        所有的非域类型对准于字的边界。对域分配足够多的比特,相邻域组装进一个字的相邻比特,但不跨越两个字。如果一个域要跨越两个字,则整个域分配到下一个字中。

回复评论

暂无评论,赶紧抢沙发吧
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复