gpt4 book ai didi

c - 如何在C中使用asm函数

转载 作者:行者123 更新时间:2023-11-30 19:09:09 25 4
gpt4 key购买 nike

我在开发hadoop源代码的工作中遇到了一个问题。我需要使用 asm 库中的函数。给出了API,例如:uint32_t func(uint32_t var1,const char var2,uint64_t var3)。如何在 C 程序中使用该函数并获取返回值?我总是得到对“函数名称(我想使用asm api)”的 undefined reference 。我是否需要在 C 或其他内容中添加一些典型的声明?

对于专业的 C 程序员来说,这似乎很容易,而且没有什么值得问的。但我是一名Java程序员,对ASM和C确实很陌生。我希望能高效地得到答案。谢谢。

最佳答案

让我们以 gnu 为例,gcc 和语言本身告诉我们,如果我们将函数声明为静态,那么它就不可用于其他 .c 文件。在 gnu 汇编器中,汇编语言是由汇编器定义的,而不是某种通用语言标准,标签是本地的,除非声明为全局的。

hello:
.globl there
there:

我们无法链接到 hello,但我们可以链接到那里。

然后您需要了解调用约定,您可以查找并阅读它和/或进行实验来找出它。即使您阅读它以确保您正在使用的编译器符合您正在阅读的编译器,您仍然应该进行实验,您正在使用的编译器将符合它正在使用的任何标准,而不是您希望它使用的标准,所以让你的asm匹配...

unsigned int fun ( unsigned int a, unsigned int b )
{
return((a<<2)+b);
}

给出

00000000 <fun>:
0: e0810100 add r0, r1, r0, lsl #2
4: e12fff1e bx lr

这是arm,在这种情况下,如果合适,参数将传入r0,r1,r2,r3,如果有更多参数,则转到堆栈。如果合适的话返回值在r0中,有很多异常(exception)。您可以在函数中销毁 r0-r3,但必须保留 r4(可能有一个异常(exception))。因此在本例中,r0 左移 2 并添加到 r1,因此 r0 是 a,r1 必须是 b,并且根据本实验,返回值位于 r0 中。

00000000 <fun>:
0: 0f 5f rla r15
2: 0f 5f rla r15
4: 0f 5e add r14, r15
6: 30 41 ret

使用另一个指令集 r15 似乎是 a 和 r14 b 并且在 r15 中返回答案

00000000 <_fun>:
0: 1166 mov r5, -(sp)
2: 1185 mov sp, r5
4: 1d40 0004 mov 4(r5), r0
8: 0cc0 asl r0
a: 0cc0 asl r0
c: 6d40 0006 add 6(r5), r0
10: 1585 mov (sp)+, r5
12: 0087 rts pc

还有一个指令集使用堆栈

我建议您对要在 C 中调用的 asm 函数进行原型(prototype)设计,然后对其进行编译、反汇编并从那里构建您的 asm。实际汇编它比尝试使用内联汇编要容易得多,这是一个高级主题并且非常依赖于编译器,如果您不使用内联汇编,那么它工作的机会会更大。

例如,我会利用学到的知识并创造

.globl myfun
myfun:
add r0,r1,r0, lsl #2
bx lr

然后我可以组装它并将其链接到任何想要使用两个参数调用 myfun 的人。或者我可以使用这些知识来使用这两个参数执行其他操作来创建返回值。

关于c - 如何在C中使用asm函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43656379/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com