无法使用clang交叉编译到SPARC

时间:2013-10-01 14:27:19

标签: c++ c clang sparc llvm-clang

所以情况就是这样:我需要能够从Linux机器(在Ubuntu上,它的价值)编译二进制文件,它们能够从SPARC服务器运行。我正在尝试编译的程序非常简单:

#include <stdio.h>
#include <stdlib.h>

int main() {
    printf("Testing the SPARC program...");
    return EXIT_SUCCESS;
}

我已经尝试了许多不同的编译行来使它工作,但遗憾的是似乎没有任何工作。

我尝试了传统的方法:

 clang -target sparc blah.c -o blahsparc

但这不起作用,有一堆汇编程序失败:

 /tmp/blah-519e77.s: Assembler messages:
 /tmp/blah-519e77.s:7: Error: unknown pseudo-op: '.register'
 /tmp/blah-519e77.s:8: Error: unknown pseudo-op: '.register'
 /tmp/blah-519e77.s:9: Error: unknown pseudo-op: '.register'
 /tmp/blah-519e77.s:10: Error: unknown pseudo-op: '.register'
 /tmp/blah-519e77.s:11: Error: no such instruction: 'save %sp,-240,%sp'
 /tmp/blah-519e77.s:12: Error: no such instruction: 'st %g0, [%fp+2043]'
 ...
 clang: error: assembler (via gcc) command failed with exit code 1 (use -v to see invocation)

我也试过这个:

clang -cc1 -triple "sparc-unknown-Linux" blah.c -o blahsparc

抱怨丢失的标题,所以不使用-cc1,而是使用-Xclang:

clang -Xclang -triple -Xclang "sparc-unknown-Linux" blah.c -o blahsparc

但是,由于“错误:未知目标CPU'x86-64'”,这也会失败。 我不知道在哪里继续这个。我也尝试过使用crosstool-ng而且收效甚微。

3 个答案:

答案 0 :(得分:4)

自3.4.2版本(2014年6月)起,llvm缺少能够为sparc目标生成目标文件所需的代码。旧版本(1.x和2.x)支持它,但是llvm用于发出目标文件的框架在那时还不太成熟。当前框架推出时,看起来他们没有迁移所有平台。

documentation似乎暗示llvm / gcc的组合已知有效,但我认为该表是基于llvm的早期版本制表的,当它们有一个不太成熟的发送目标文件的框架时

支持发送对象文件已添加到修订版r198533的SVN中继中(this thread讨论了提交),但正如您在3.4.2 final release中看到的那样,文件&amp; r198533中添加的更改不存在。


顺便说一句,clang目前在sparc solaris中不起作用(一般不确定sparc)。解析器似乎无法解析模板;我得到了coredumps&amp;类似。我大约一周左右遇到thread讨论sparc / solaris clang中的对齐问题,这可能是clang尚未在此平台上使用的原因之一。

答案 1 :(得分:3)

如果你需要一个在Ubuntu机器上运行的Sparc的交叉编译器,我所知道的最简单的方法是使用Buildroot。 Here's a small tutorial关于如何获取交叉编译器并在Sparc模拟器上测试生成的可执行文件。

答案 2 :(得分:3)

LLVM 3.6.2现在对sparc有一些支持......我能够在我的T2000上构建llvm 3.6.2和clang 3.6.2-r100。我还没有获得C ++支持,但我已经构建了像htop这样复杂的C应用程序。

我确实使用gcc 5.2编译LLVM但是我的低版本应该也可以工作,尽管我建议至少gcc 4.9并且不低于gcc 4.7。

在编译过程中出现了gentoo崩溃的LLVM,但我可以通过移植到llvm ebuilds的portage目录并手动重新启动构建来恢复它:

cd  /usr/portage/*/llvm/
ebuild llvm-3.6.2.ebuild merge

我必须覆盖一些默认编译器:

CC="clang -target sparc-unknown-linux-gnu" 
CXX="clang++ -target sparc-unknown-linux-gnu" 
CFLAGS="-O2 -pipe"
CXXFLAGS="${CFLAGS}"

我不知道你是否能够使用它来构建x86机器......虽然clang应该能够做到这一点。但最糟糕的情况是你可能能够在qemu-system-sparc64 vm或者你可以在ebay上找到便宜的一些真正的硬件上实现这一点(T5xxx硬件价格下降且刀片价格便宜)

我最近更新到了clang 3.8(尚未发布),除了上面的选项之外,我还能通过传递-lstdc ++来编译c ++应用程序。我相信当gcc作为gcc而不是g ++调用时,这与gcc的行为相同。

相关问题