问题描述
我是一个业余爱好者,喜欢在 Go 中运行我自己的程序,而且随着至强融核处理器的老化,它们也变得非常便宜。太便宜了,我可以从 2015/16 年开始以 制造一台双插槽机器
我想知道我是否可以在这些上运行 Go 程序。据我所知,this thread 表示它们不会运行(并尝试使用 gccgo),但它表示它不会运行,因为它部分运行在 x87 ISA 上。令人困惑的是,在 Go 发行说明 they say they're dropping x87 support in 1.16 中,暗示过去支持它。我在其他线程中看到所有程序都将在兼容层上运行,但这是一个非常慢的层,只能访问 cpu 缓存的一小部分。
我觉得我越来越远离我的元素;我想知道使用 Xeon Phi 的人是否知道它是否会运行 Go 代码?或者只是一般情况下,在启动 Ubuntu(或 FreeBSD,something that I've seen done and is listed in motherboard specs)之后,哪些事情不会起作用,哪些会起作用?
我感谢所有帮助!
解决方法
您将骑士登陆的担忧基于这句关于骑士角落的引用:
The Knight's Corner 处理器基于 x86-64 基础,是的,但实际上它有自己的浮点指令集——没有 x87、没有 AVX、没有 SSE、没有 MMX...哦,然后当 Knight's Landing (KNL) 出来时,你可以把所有这些都扔掉。
“扔掉所有这些”是指所有的担忧和不兼容。 KNL 基于 Silvermont,完全兼容 x86-64(包括 x87、SSE 和 SSE2,用于两种标准的 FP 数学方法)。它还支持 AVX-512F、AVX-512ER 和 a few other AVX-512 extensions,以及 AVX 和 AVX2 以及 SSE,最高可达 SSE4.2。很像 Skylake 服务器 CPU,除了一组不同的 AVX-512 扩展。
这样做的目的正是为了解决您所担心的问题:因此任何遗留二进制文件都可以在 KNL 上运行。为了从中获得良好的性能,您希望在执行繁重工作的循环中运行使用 AVX-512 向量化的代码,但是 Linux 发行版的其余部分中的所有周围代码和其他程序或任何可以正常运行的程序使用任何 x87 和/或 SSE 的沼泽标准代码。
Knight's Corner(第一代商用至强融核)在基于 P5-Pentium 的内核中拥有自己的 AVX-512 变体/前身,没有其他 FP 硬件。
Knight's Landing(第二代商用至强融核)基于 Silvermont,带有 AVX-512,是第一个可以充当“主机”处理器(可启动)而不仅仅是协处理器的产品。
>这种“主机”模式是包含足够的硬件来解码和执行 x87 和 SSE 的另一个原因:如果您在 KNL 上运行整个系统,您更有可能希望为非-性能敏感的任务,不仅仅是专门为它编译的二进制文件。
不过,它的 x87 性能并不是很好:就像每 2 个时钟 (https://agner.org/optimize) 一个标量 fmul
。与 2-per-clock SSE mulsd
(0.5c 接收吞吐量)。其他 SSE/AVX 数学运算的吞吐量为 0.5c,包括 AVX-512 vfma132ps zmm
在一条指令中执行 16 次单精度融合乘加运算。
所以希望 Go 的编译器不会大量使用 x87。在 64 位模式下(C 编译器及其数学库使用)进行标量数学的正常方法是 SSE,在 XMM 寄存器中。 x86-64 C 编译器仅将 x87 用于 long double
之类的类型。
是:
至强融核是由英特尔设计和制造的一系列 x86 众核处理器。它旨在用于超级计算机、服务器和高端工作站。其架构允许使用标准编程语言和应用程序编程接口 (API),例如... 另见https://en.wikipedia.org/wiki/Xeon_Phi
如果您可以在 x86 处理器上进行编译,那么您将能够在英特尔制造的特定 x86 处理器上进行编译。
至强不是安腾 :)
在这样的系统上你也可以编译 go 你只需要提供一个合适的 c 编译器......
是什么让您认为否则您将无法编译继续说... Atari 或 Arduino?
如果你能详细说明一下,也许我可以进一步改进我糟糕的答案。