DSP汇编中的结构体参数传入及使用、双条件操作
我的板子是c6740,开发中遇到几个汇编问题求教:
1. 结构体参数传入及使用
比如一个实现简单游程编码的测试程序,如下:
struct _STREAM
{
BYTE *buffer;
int size; //buffer长度
}
void encode(BYTE *pSrc, datasize, STREAM *pDstStream)
在DSP汇编中,A4接收pSrc,B4接收datasize, 问题:
--那哪个寄存器接收*pDstStream?是正常的A6接收,还是有特殊的寄存器?
--如何对结构体成员操作,如把数据存到buffer、size++等
2. 在汇编中如何写双条件判断语句啊?
如下面源程序中的!input && datasize?
while(!input && datasize)
{
numZeros++;
GetNextInput(input);
}
3.优化
如实现上面功能的汇编程序,因为程序需要一个字节一个字节去判断,然后进行操作,程序中有比较多的循环操作,
所以,在汇编中会出现比较多的NOP指令,这样程序性能会比较低吧?请问应该如何去提高程序性能呢?
[
本帖最后由 breeze505 于 2012-5-9 11:04 编辑 ]
此帖出自
小平头技术问答
* ================= LOOP PROLOG ============================ *
MV .S2 B4, B_loopcount
LDW .D1T1 *+A6[0], A_pBuffer
LDW .D1T1 *+A6[1], A_buffersize ; ====> A_buffer = size,注意A_buffer是值,不是指针
ZERO .S1 A_size
* ===================== LOOP KERNEL ============================== *
loop:
LDB .D1T1 *A4++[1], A_tmp
SUB .S2 B_loopcount, 1,B_loopcount
NOP 3
STB .D1T1 A_tmp,*A_pBuffer++[1]
ADD .S1 A_size, 1, A_size
[B_loopcount] B .S2 loop
NOP 5
*===================== LOOP EPILOG ============================== *
STW .D1T1 A_size,*A_buffersize++[1] ; ====> STW A_size, *+A6[1],注意A6才是结构体指针
NOP 1
[!B_loopcount]B .S2 B3
|| MVK .S1 1,A4 ;return 1
.end
2. 对于判断较多的代码,只能改写其算法,避免多个条件判断的情况。
你的while代码块的作用大概是:逐个读取pSrc的内容,直到读到0或者长度到达data_size;记录读取0的个数到numZeros;退出循环时input的值是pSrc的内容或者0(如果长度到达data_size)
改写后的C代码是:(未验证,仅提供思路)
input = 0;
for (; data_size > 0; data_size--) // 使用条件寄存器保存data_size
{
input = *pSrc++;
if (input != 0) // 使用条件寄存器保存input,numZeros++可以用带条件的ADD指令
{
break;
}
else
{
numZeros++;
}
}
if (data_size == 0) input = 0; // 这句代码应该是不需要了,只有data_size为0,input才未赋值,所以在开头加上初始化,需验证!
[ 本帖最后由 carrotchen 于 2012-5-10 17:16 编辑 ]
一周热门 更多>