|
寄存器规则
与浮点C编译器一样,在定点c编译器中也定义了严格的寄存器使用规则。这些规则对于编写汇编语言与C语言的接口非常重要。如果编写的汇编程序不符合寄存器使用规则,则C环境将被破坏。
C编译器使用寄存器的方法在使用和不使用优化器时是不一样的。因为优化器需要使用额外的寄存器作为寄存器变量以提高程序的运行效率。但函数调用时保护寄存器的规则在使用和不使用优化器时是一样的。下面我们来介绍定点C编译器使用寄存器的规则。
(一)特定寄存器
定点C环境中保留了三个寄存器:AR0、AR1、AR2, 它们的作用如下:
AR0——帧指针
AR1——堆栈指针
AR2——局部变量指针(用于计算局部变量的地址)
(二)寄存器使用
汇编用于函数中,可以使用辅助寄存器、T寄存器和P寄存器、各种状态寄存器,在使用时必须符合下列规则:
1. 辅助寄存器(ARP和AR0 ~ AR7)
函数进入和返回时,ARP必须为1,也就是说当前的辅助寄存器为AR1。函数执行时可以是其它值。
AR0和AR1可以在函数执行过程中修改,但它们必须恢复。
AR2、AR3、AR4和AR5可以自由使用,也就是说,在函数执行过程中可以修改,也不必恢复。
AR6和AR7用作寄存器变量。如果在函数中被修改,必须加以保护和恢复。
2. 状态寄存器
在C编译器中,始终假定PM状态位为0。如果函数改变PM值,则在函数返回时必须将PM重新设置为0。在TMS320C5X中,TRM位必须保持为0,硬件复位时TRM为0。对其它状态位既可以修改,也不必恢复。如DP、C、FSM、HM、INTM、OV、OVM、SXM、TC、TXM、CNF、FO和XF等。
3. 其它寄存器
累加器ACC可以自由使用,不必保护和恢复。ACC可以用来返回整数、指针和浮点值、P和T寄存器也可以自由使用。
(三)寄存器变量
在一个函数中,定点C编译器可以自由使用多至两个寄存器变量。如果要在函数中使用寄存器变量,则应在函数的参数表或函数的第一块中定义。否则,作为一般的变量处理。编译器用AR6和AR7作为寄存器变量,其中AR6分配给第一个寄存器变量,AR7分配给第二个寄存器变量。由于在运行时建立一个寄存器变量约需4个指令周期,因此,只有当一个变量访问2次以上,使用寄存器变量的效果才能明显地体现出来。
|
|