|
我试着写一些 SIMD,主要用于学习目的。我知道 Go 可以链接程序集,但我不能让它正常工作。
9 a$ F+ b6 z" v$ p( M这是我能做的最简单的例子(逐元素向量乘法):
0 ^; {, K5 ?4 V6 H# r/ Cvec_amd64.s(注:实际文件下有一条空白线,RET否则会导致错误)
6 D( J7 o) _( I- x/ }+ M) B* c// func mul(v1,v2 Vec4) Vec4TEXT .mul(SB),4,$0-48 MOVUPS v1 0(FP), X0 MOVUPS v2 16(FP),X1 MULPS X1,X0 / also tried ret 32 since I've seen some places do that MOVUPS X0,toReturn 32(FP) RET" Z! o) ]: F( @
vec.go
7 C" m% Z! ~9 mpackage simdtype Vec4 [4]float32func (v1 Vec4) Mul(v2 Vec4) Vec4 { return Vec4{v1[0] * v2[0],v1[1] * v2[1],v1[2] * v2[2],v1[3] * v2[3]}}func mul(v1,v2 Vec4) Vec4
$ a5 }4 c7 {! q$ l9 Q, P; q+ k simd_test.go
5 S/ h& v$ z# v: @) @% M6 V* |9 {
9 n) f2 _1 l/ U# g- package simdimport "testing")func TestMul(t *testing.T) v1 := Vec4{1,2,3,4}v2 := Vec4{5,6,7,8}res := v1.Mul(v2) res2 := mul(v1,v2) / Placeholder until I get it to compile if res != res2 t.Fatalf("Expected %v; got %v",res,res2) }code]当我试着操作的时候go test出现错误:[code]# testmainsimd.TestMul: call to external function simd.mulsimd.TestMul: undefined: simd.mul
# ^2 E$ Y1 b9 K 该go env命令报告我GOHOSTARCH要amd64和我的围棋版本是1.3.为了确认这不是一个导致问题的架构,我发现了另一个使用程序集的包,并删除了它_amd64.s除所有程序集文件外,其测试运行良好。
- S+ E) ^ m. a我还试图将其更改为导出的标志符,以防止奇怪,但没有骰子。我想我非常密切地遵循了 包中的模板math/big,所以希望这是我遗漏的简单明了的东西。
3 K, ~( k" A5 S我知道 Go 至少在尝试如果我在 .s 将语法错误引入文件中,建筑工具会抱怨。
5 q. G; |; A' P9 q! q编辑:
& ?! [' U4 s+ H- C+ a6 E. I* Z$ `9 U要清楚,go build但是go test会导致错误。
' r! G& g$ S3 P3 z; ?% F , I" f5 o3 h0 J$ T2 \
解决方案:
: C7 g: f3 i/ [. S8 \- f3 Y 你用错了点。
5 {- q: l* S; K% pTEXT .mul(SB),4,$0-48
" q) o* A, j, f4 B 写
0 j; a! T. L1 t; L/ tTEXT ·mul(SB),4,$0-481 D# P* {/ f. T, i4 I0 N" t/ _
一切正常。 |
|