MIPS - 在汇编代码中调用C函数

时间:2016-05-02 11:07:14

标签: c assembly mips

我正在尝试从程序集文件中调用C文件中声明的函数,但是我得到了一个"非法指令"错误。

我的C代码:

#include <stdio.h>

int BubbleSort(int *v){
    return 13;
}

int Run(int *, int *);


int main(){
    int vetor[] = {1, 3, 5, 4, 10}, numTrocas = 0, res = 0;
    numTrocas = Run(vetor, &res);   
    printf("numTrocas= %d\nf= %d\n", numTrocas, res);
    return 0;
}

我的汇编代码:

.data 
.text 
.globl Run

Run:
    addi $sp,$sp,-8
    sw $ra,0($sp)
    sw $a0,4($sp)
    move $t4, $a1 #$t4 = $a1; address of variable res in C file
    move $t6, $a0 #$t6 = address of the first vector element

    lw $a0, ($t6)
    add $t6, $t6, 4
    lw $a1, ($t6)
    add $t6, $t6, 4
    lw $a2, ($t6)
    add $t6, $t6, 4
    lw $a3, ($t6)
    add $t6, $t6, 4
    lw $t3, ($t6)
    jal PolyCalc

    lw $a0,4($sp)
    jal BubbleSort #-> Illegal Instruction

    lw $ra, 0($sp)
    addi $sp, $sp, 8 
    jr $ra

PolyCalc: #This function calculates the result of the expression 5(V[0] + V[1])(V[2] − 3xV[3]xV[4])
    li $s0,5             #$s0 = 5
    li $s1,3             #$s1 = 3
    add $t1,$a0,$a1      #t1=(x1+x2)
    mul $t1,$t1,$s0      #t1=5*(x1+x2)
    mul $t2,$a3,$t3      #$t2 = x4*x5
    mul $t2,$t2,$s1      #$t2 = 3*x4*x5
    sub $t2,$a2,$t2      #$t2 = (x3-3x4*x5)
    mul $t1,$t1,$t2      
    sw $t1, ($t4) #Save the result on the address of $t4
    jr $ra

当我评论jal BubbleSort行并在$ v0中添加一个随机值作为BubbleSort函数的返回时,我停止得到该错误并且该程序正常工作。

有人可以在我的代码中找到错误吗? 感谢

2 个答案:

答案 0 :(得分:2)

为了更好地衡量,在你的asm文件中,你应该添加:

.extern BubbleSort

然后,jal BubbleSort应该正确重新定位。

但是,链接器可能会将它放在[{1}}的[有限]范围内太远,因此您可能必须将其替换为:

jal

答案 1 :(得分:-1)

您遇到的错误是因为汇编代码无法找到名为BubbleSort的标签来跳转。我认为你应该采用不同的方法。您可以使用asm函数在C中嵌入汇编代码。

类似的东西:

#include <stdio.h>

int BubbleSort(int *v){
    asm("lw $a0, ($t6)"
    "lw $a1, ($t6)");
}

int Run(int *, int *);


int main(){
    int vetor[] = {1, 3, 5, 4, 10}, numTrocas = 0, res = 0;
    numTrocas = Run(vetor, &res);   
    printf("numTrocas= %d\nf= %d\n", numTrocas, res);
    return 0;
}

您可以在GCC文档中找到有关此功能的更多信息:https://gcc.gnu.org/onlinedocs/gcc/Extended-Asm.html