LLVM蹦床有多少空间

栏目: 服务器 · 编程工具 · 发布时间: 7年前

内容简介:是的,蹦床被用来生成一些代码“飞行”.目前还不清楚为什么你需要这些内在函数,因为它们被用来实现GCC的嵌套函数扩展(特别是当嵌套函数的地址被捕获并且函数访问封闭函数内部的东西时).找出必要的蹦床缓冲区大小和对齐方式,最好的方式是为“TRAMPOLINE_SIZE”和“TRAMPOLINE_ALIGNMENT”格式输入gcc来源.据我看到,在撰写本文时,72字节的缓冲区和16字节的对齐将足够用于所有gcc / LLVM平台.
我想知道如何在LLVM中使用 trampoline intrinsics .该文档提到了存储蹦床所需的一些存储空间,这取决于平台.我的问题是,我怎么弄清楚需要多少钱?

我发现 this example ,显然没有理由选择32个字节.如何选择好的价值?

declare void @llvm.init.trampoline(i8*, i8*, i8*);
declare i8* @llvm.adjust.trampoline(i8*);

define i32 @foo(i32* nest %ptr, i32 %val)
{
    %x = load i32* %ptr
    %sum = add i32 %x, %val
    ret i32 %sum
}

define i32 @main(i32, i8**)
{
    %closure = alloca i32
    store i32 13, i32* %closure
    %closure_ptr = bitcast i32* %closure to i8*

    %tramp_buf = alloca [32 x i8], align 4
    %tramp_ptr = getelementptr [32 x i8]* %tramp_buf, i32 0, i32 0
    call void @llvm.init.trampoline(
            i8* %tramp_ptr,
            i8* bitcast (i32 (i32*, i32)* @foo to i8*),
            i8* %closure_ptr)
    %ptr = call i8* @llvm.adjust.trampoline(i8* %tramp_ptr)
    %fp = bitcast i8* %ptr to i32(i32)*

    %val2 = call i32 %fp (i32 13)

    ; %val = call i32 @foo(i32* %closure, i32 42);

    ret i32 %val2
}

是的,蹦床被用来生成一些代码“飞行”.目前还不清楚为什么你需要这些内在函数,因为它们被用来实现GCC的嵌套函数扩展(特别是当嵌套函数的地址被捕获并且函数访问封闭函数内部的东西时).

找出必要的蹦床缓冲区大小和对齐方式,最好的方式是为“TRAMPOLINE_SIZE”和“TRAMPOLINE_ALIGNMENT”格式输入gcc来源.

据我看到,在撰写本文时,72字节的缓冲区和16字节的对齐将足够用于所有gcc / LLVM平台.

http://stackoverflow.com/questions/15509341/how-much-space-for-a-llvm-trampoline

本站文章除注明转载外,均为本站原创或编译

转载请明显位置注明出处:LLVM蹦床有多少空间


以上所述就是小编给大家介绍的《LLVM蹦床有多少空间》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

一本书读懂大数据

一本书读懂大数据

黄颖 / 吉林出版集团有限责任公司 / 2014-12-1

进入大数据时代,让数据开口说话将成为司空见惯的事情,书中将从大数据时代的前因后果讲起,全面分析大数据时代的特征、企业实践的案例、大数据的发展方向、未来的机遇和挑战等内容,展现一个客观立体、自由开放的大数据时代。一起来看看 《一本书读懂大数据》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具