怎样才能让gccgo产生矢量化代码?

pao*_*osi 20 vectorization go gccgo

我试图说服gccgo没有成功矢量化以下片段:

package foo

func Sum(v []float32) float32 {
    var sum float32 = 0
    for _, x := range v {
        sum += x
    }
    return sum
} 
Run Code Online (Sandbox Code Playgroud)

我正在验证由以下内容生成的程序集:

$ gccgo -O3 -ffast-math -march=native -S test.go
Run Code Online (Sandbox Code Playgroud)

gccgo版本是:

$ gccgo --version
gccgo (Ubuntu 4.9-20140406-0ubuntu1) 4.9.0 20140405 (experimental) [trunk revision 209157]
Run Code Online (Sandbox Code Playgroud)

是不是gccgo应该能够对这段代码进行矢量化?具有相同gcc选项的等效C代码完全使用AVX指令进行矢量化...

UPDATE

在这里你有相应的C例子:

#include <stdlib.h>

float sum(float *v, size_t n) {
    size_t i;
    float sum = 0;
    for(i = 0; i < n; i++) {
        sum += v[i];
    }
    return sum;
}
Run Code Online (Sandbox Code Playgroud)

编译:

$ gcc -O3 -ffast-math -march=native -S test.c
Run Code Online (Sandbox Code Playgroud)

小智 1

为什么不直接使用 gcc 构建 .so 或 .a 并从 go 调用 c 函数呢?