无法使用clang交叉编译到SPARC

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

#include  #include  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.4.2版本(2014年6月)开始,llvm缺少能够为sparc目标生成目标文件所需的代码。 旧版本(1.x和2.x)支持它,但是llvm发布目标文件的框架在那时还不太成熟。 当前框架推出时,看起来他们没有迁移所有平台。

文档似乎暗示llvm / gcc的组合已知可行,但我认为该表是基于llvm的早期版本制表的,当它们具有用于发出目标文件的不太成熟的框架时。

对于发送目标文件的支持已添加到修订版r198533中的SVN主干( 此主题讨论了提交),但正如您在3.4.2最终版本中所见 , r198533中添加的文件和更改不存在。


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

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

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 ++调用时的行为相同。