build: add attributes argument to TEXT
Brings the TEXT() function signature closer to how the directive works in assembly. Also update almost all examples to use NOSPLIT. Closes #11
This commit is contained in:
17
build/attr.go
Normal file
17
build/attr.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package build
|
||||||
|
|
||||||
|
import "github.com/mmcloughlin/avo/attr"
|
||||||
|
|
||||||
|
// TEXT and DATA attribute values included for convenience.
|
||||||
|
var (
|
||||||
|
NOPROF = attr.NOPROF
|
||||||
|
DUPOK = attr.DUPOK
|
||||||
|
NOSPLIT = attr.NOSPLIT
|
||||||
|
RODATA = attr.RODATA
|
||||||
|
NOPTR = attr.NOPTR
|
||||||
|
WRAPPER = attr.WRAPPER
|
||||||
|
NEEDCTXT = attr.NEEDCTXT
|
||||||
|
TLSBSS = attr.TLSBSS
|
||||||
|
NOFRAME = attr.NOFRAME
|
||||||
|
REFLECTMETHOD = attr.REFLECTMETHOD
|
||||||
|
)
|
||||||
@@ -15,9 +15,10 @@ import (
|
|||||||
// ctx provides a global build context.
|
// ctx provides a global build context.
|
||||||
var ctx = NewContext()
|
var ctx = NewContext()
|
||||||
|
|
||||||
// TEXT starts building a new function called name and sets its signature (see SignatureExpr).
|
// TEXT starts building a new function called name, with attributes a, and sets its signature (see SignatureExpr).
|
||||||
func TEXT(name, signature string) {
|
func TEXT(name string, a attr.Attribute, signature string) {
|
||||||
ctx.Function(name)
|
ctx.Function(name)
|
||||||
|
ctx.Attributes(a)
|
||||||
ctx.SignatureExpr(signature)
|
ctx.SignatureExpr(signature)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
// Code generated by command: go run asm.go -out add.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out add.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Add(x uint64, y uint64) uint64
|
// func Add(x uint64, y uint64) uint64
|
||||||
TEXT ·Add(SB), $0-24
|
TEXT ·Add(SB), NOSPLIT, $0-24
|
||||||
MOVQ x(FP), AX
|
MOVQ x(FP), AX
|
||||||
MOVQ y+8(FP), CX
|
MOVQ y+8(FP), CX
|
||||||
ADDQ AX, CX
|
ADDQ AX, CX
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("Add", "func(x, y uint64) uint64")
|
TEXT("Add", NOSPLIT, "func(x, y uint64) uint64")
|
||||||
Doc("Add adds x and y.")
|
Doc("Add adds x and y.")
|
||||||
x := Load(Param("x"), GP64())
|
x := Load(Param("x"), GP64())
|
||||||
y := Load(Param("y"), GP64())
|
y := Load(Param("y"), GP64())
|
||||||
|
|||||||
@@ -1,109 +1,111 @@
|
|||||||
// Code generated by command: go run asm.go -out args.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out args.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Second(x int32, y int32) int32
|
// func Second(x int32, y int32) int32
|
||||||
TEXT ·Second(SB), $0-12
|
TEXT ·Second(SB), NOSPLIT, $0-12
|
||||||
MOVL y+4(FP), AX
|
MOVL y+4(FP), AX
|
||||||
MOVL AX, ret+8(FP)
|
MOVL AX, ret+8(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func StringLen(s string) int
|
// func StringLen(s string) int
|
||||||
TEXT ·StringLen(SB), $0-24
|
TEXT ·StringLen(SB), NOSPLIT, $0-24
|
||||||
MOVQ s_len+8(FP), AX
|
MOVQ s_len+8(FP), AX
|
||||||
MOVQ AX, ret+16(FP)
|
MOVQ AX, ret+16(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func SliceLen(s []int) int
|
// func SliceLen(s []int) int
|
||||||
TEXT ·SliceLen(SB), $0-32
|
TEXT ·SliceLen(SB), NOSPLIT, $0-32
|
||||||
MOVQ s_len+8(FP), AX
|
MOVQ s_len+8(FP), AX
|
||||||
MOVQ AX, ret+24(FP)
|
MOVQ AX, ret+24(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func SliceCap(s []int) int
|
// func SliceCap(s []int) int
|
||||||
TEXT ·SliceCap(SB), $0-32
|
TEXT ·SliceCap(SB), NOSPLIT, $0-32
|
||||||
MOVQ s_cap+16(FP), AX
|
MOVQ s_cap+16(FP), AX
|
||||||
MOVQ AX, ret+24(FP)
|
MOVQ AX, ret+24(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func ArrayThree(a [7]uint64) uint64
|
// func ArrayThree(a [7]uint64) uint64
|
||||||
TEXT ·ArrayThree(SB), $0-64
|
TEXT ·ArrayThree(SB), NOSPLIT, $0-64
|
||||||
MOVQ a_3+24(FP), AX
|
MOVQ a_3+24(FP), AX
|
||||||
MOVQ AX, ret+56(FP)
|
MOVQ AX, ret+56(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldByte(s Struct) byte
|
// func FieldByte(s Struct) byte
|
||||||
TEXT ·FieldByte(SB), $0-177
|
TEXT ·FieldByte(SB), NOSPLIT, $0-177
|
||||||
MOVB s_Byte(FP), AL
|
MOVB s_Byte(FP), AL
|
||||||
MOVB AL, ret+176(FP)
|
MOVB AL, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldInt8(s Struct) int8
|
// func FieldInt8(s Struct) int8
|
||||||
TEXT ·FieldInt8(SB), $0-177
|
TEXT ·FieldInt8(SB), NOSPLIT, $0-177
|
||||||
MOVB s_Int8+1(FP), AL
|
MOVB s_Int8+1(FP), AL
|
||||||
MOVB AL, ret+176(FP)
|
MOVB AL, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldUint16(s Struct) uint16
|
// func FieldUint16(s Struct) uint16
|
||||||
TEXT ·FieldUint16(SB), $0-178
|
TEXT ·FieldUint16(SB), NOSPLIT, $0-178
|
||||||
MOVW s_Uint16+2(FP), AX
|
MOVW s_Uint16+2(FP), AX
|
||||||
MOVW AX, ret+176(FP)
|
MOVW AX, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldInt32(s Struct) int32
|
// func FieldInt32(s Struct) int32
|
||||||
TEXT ·FieldInt32(SB), $0-180
|
TEXT ·FieldInt32(SB), NOSPLIT, $0-180
|
||||||
MOVL s_Int32+4(FP), AX
|
MOVL s_Int32+4(FP), AX
|
||||||
MOVL AX, ret+176(FP)
|
MOVL AX, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldUint64(s Struct) uint64
|
// func FieldUint64(s Struct) uint64
|
||||||
TEXT ·FieldUint64(SB), $0-184
|
TEXT ·FieldUint64(SB), NOSPLIT, $0-184
|
||||||
MOVQ s_Uint64+8(FP), AX
|
MOVQ s_Uint64+8(FP), AX
|
||||||
MOVQ AX, ret+176(FP)
|
MOVQ AX, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldFloat32(s Struct) float32
|
// func FieldFloat32(s Struct) float32
|
||||||
TEXT ·FieldFloat32(SB), $0-180
|
TEXT ·FieldFloat32(SB), NOSPLIT, $0-180
|
||||||
MOVSS s_Float32+16(FP), X0
|
MOVSS s_Float32+16(FP), X0
|
||||||
MOVSS X0, ret+176(FP)
|
MOVSS X0, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldFloat64(s Struct) float64
|
// func FieldFloat64(s Struct) float64
|
||||||
TEXT ·FieldFloat64(SB), $0-184
|
TEXT ·FieldFloat64(SB), NOSPLIT, $0-184
|
||||||
MOVSD s_Float64+24(FP), X0
|
MOVSD s_Float64+24(FP), X0
|
||||||
MOVSD X0, ret+176(FP)
|
MOVSD X0, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldStringLen(s Struct) int
|
// func FieldStringLen(s Struct) int
|
||||||
TEXT ·FieldStringLen(SB), $0-184
|
TEXT ·FieldStringLen(SB), NOSPLIT, $0-184
|
||||||
MOVQ s_String_len+40(FP), AX
|
MOVQ s_String_len+40(FP), AX
|
||||||
MOVQ AX, ret+176(FP)
|
MOVQ AX, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldSliceCap(s Struct) int
|
// func FieldSliceCap(s Struct) int
|
||||||
TEXT ·FieldSliceCap(SB), $0-184
|
TEXT ·FieldSliceCap(SB), NOSPLIT, $0-184
|
||||||
MOVQ s_Slice_cap+64(FP), AX
|
MOVQ s_Slice_cap+64(FP), AX
|
||||||
MOVQ AX, ret+176(FP)
|
MOVQ AX, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldArrayTwoBTwo(s Struct) byte
|
// func FieldArrayTwoBTwo(s Struct) byte
|
||||||
TEXT ·FieldArrayTwoBTwo(SB), $0-177
|
TEXT ·FieldArrayTwoBTwo(SB), NOSPLIT, $0-177
|
||||||
MOVB s_Array_2_B_2+114(FP), AL
|
MOVB s_Array_2_B_2+114(FP), AL
|
||||||
MOVB AL, ret+176(FP)
|
MOVB AL, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldArrayOneC(s Struct) uint16
|
// func FieldArrayOneC(s Struct) uint16
|
||||||
TEXT ·FieldArrayOneC(SB), $0-178
|
TEXT ·FieldArrayOneC(SB), NOSPLIT, $0-178
|
||||||
MOVW s_Array_1_C+100(FP), AX
|
MOVW s_Array_1_C+100(FP), AX
|
||||||
MOVW AX, ret+176(FP)
|
MOVW AX, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldComplex64Imag(s Struct) float32
|
// func FieldComplex64Imag(s Struct) float32
|
||||||
TEXT ·FieldComplex64Imag(SB), $0-180
|
TEXT ·FieldComplex64Imag(SB), NOSPLIT, $0-180
|
||||||
MOVSS s_Complex64_imag+156(FP), X0
|
MOVSS s_Complex64_imag+156(FP), X0
|
||||||
MOVSS X0, ret+176(FP)
|
MOVSS X0, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func FieldComplex128Real(s Struct) float64
|
// func FieldComplex128Real(s Struct) float64
|
||||||
TEXT ·FieldComplex128Real(SB), $0-184
|
TEXT ·FieldComplex128Real(SB), NOSPLIT, $0-184
|
||||||
MOVSD s_Complex128_real+160(FP), X0
|
MOVSD s_Complex128_real+160(FP), X0
|
||||||
MOVSD X0, ret+176(FP)
|
MOVSD X0, ret+176(FP)
|
||||||
RET
|
RET
|
||||||
|
|||||||
@@ -9,92 +9,92 @@ import (
|
|||||||
func main() {
|
func main() {
|
||||||
Package("github.com/mmcloughlin/avo/examples/args")
|
Package("github.com/mmcloughlin/avo/examples/args")
|
||||||
|
|
||||||
TEXT("Second", "func(x, y int32) int32")
|
TEXT("Second", NOSPLIT, "func(x, y int32) int32")
|
||||||
y := Load(Param("y"), GP32())
|
y := Load(Param("y"), GP32())
|
||||||
Store(y, ReturnIndex(0))
|
Store(y, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("StringLen", "func(s string) int")
|
TEXT("StringLen", NOSPLIT, "func(s string) int")
|
||||||
strlen := Load(Param("s").Len(), GP64())
|
strlen := Load(Param("s").Len(), GP64())
|
||||||
Store(strlen, ReturnIndex(0))
|
Store(strlen, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("SliceLen", "func(s []int) int")
|
TEXT("SliceLen", NOSPLIT, "func(s []int) int")
|
||||||
slicelen := Load(Param("s").Len(), GP64())
|
slicelen := Load(Param("s").Len(), GP64())
|
||||||
Store(slicelen, ReturnIndex(0))
|
Store(slicelen, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("SliceCap", "func(s []int) int")
|
TEXT("SliceCap", NOSPLIT, "func(s []int) int")
|
||||||
slicecap := Load(Param("s").Cap(), GP64())
|
slicecap := Load(Param("s").Cap(), GP64())
|
||||||
Store(slicecap, ReturnIndex(0))
|
Store(slicecap, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("ArrayThree", "func(a [7]uint64) uint64")
|
TEXT("ArrayThree", NOSPLIT, "func(a [7]uint64) uint64")
|
||||||
a3 := Load(Param("a").Index(3), GP64())
|
a3 := Load(Param("a").Index(3), GP64())
|
||||||
Store(a3, ReturnIndex(0))
|
Store(a3, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldByte", "func(s Struct) byte")
|
TEXT("FieldByte", NOSPLIT, "func(s Struct) byte")
|
||||||
b := Load(Param("s").Field("Byte"), GP8())
|
b := Load(Param("s").Field("Byte"), GP8())
|
||||||
Store(b, ReturnIndex(0))
|
Store(b, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldInt8", "func(s Struct) int8")
|
TEXT("FieldInt8", NOSPLIT, "func(s Struct) int8")
|
||||||
i8 := Load(Param("s").Field("Int8"), GP8())
|
i8 := Load(Param("s").Field("Int8"), GP8())
|
||||||
Store(i8, ReturnIndex(0))
|
Store(i8, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldUint16", "func(s Struct) uint16")
|
TEXT("FieldUint16", NOSPLIT, "func(s Struct) uint16")
|
||||||
u16 := Load(Param("s").Field("Uint16"), GP16())
|
u16 := Load(Param("s").Field("Uint16"), GP16())
|
||||||
Store(u16, ReturnIndex(0))
|
Store(u16, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldInt32", "func(s Struct) int32")
|
TEXT("FieldInt32", NOSPLIT, "func(s Struct) int32")
|
||||||
i32 := Load(Param("s").Field("Int32"), GP32())
|
i32 := Load(Param("s").Field("Int32"), GP32())
|
||||||
Store(i32, ReturnIndex(0))
|
Store(i32, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldUint64", "func(s Struct) uint64")
|
TEXT("FieldUint64", NOSPLIT, "func(s Struct) uint64")
|
||||||
u64 := Load(Param("s").Field("Uint64"), GP64())
|
u64 := Load(Param("s").Field("Uint64"), GP64())
|
||||||
Store(u64, ReturnIndex(0))
|
Store(u64, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldFloat32", "func(s Struct) float32")
|
TEXT("FieldFloat32", NOSPLIT, "func(s Struct) float32")
|
||||||
f32 := Load(Param("s").Field("Float32"), XMM())
|
f32 := Load(Param("s").Field("Float32"), XMM())
|
||||||
Store(f32, ReturnIndex(0))
|
Store(f32, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldFloat64", "func(s Struct) float64")
|
TEXT("FieldFloat64", NOSPLIT, "func(s Struct) float64")
|
||||||
f64 := Load(Param("s").Field("Float64"), XMM())
|
f64 := Load(Param("s").Field("Float64"), XMM())
|
||||||
Store(f64, ReturnIndex(0))
|
Store(f64, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldStringLen", "func(s Struct) int")
|
TEXT("FieldStringLen", NOSPLIT, "func(s Struct) int")
|
||||||
l := Load(Param("s").Field("String").Len(), GP64())
|
l := Load(Param("s").Field("String").Len(), GP64())
|
||||||
Store(l, ReturnIndex(0))
|
Store(l, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldSliceCap", "func(s Struct) int")
|
TEXT("FieldSliceCap", NOSPLIT, "func(s Struct) int")
|
||||||
c := Load(Param("s").Field("Slice").Cap(), GP64())
|
c := Load(Param("s").Field("Slice").Cap(), GP64())
|
||||||
Store(c, ReturnIndex(0))
|
Store(c, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldArrayTwoBTwo", "func(s Struct) byte")
|
TEXT("FieldArrayTwoBTwo", NOSPLIT, "func(s Struct) byte")
|
||||||
b2 := Load(Param("s").Field("Array").Index(2).Field("B").Index(2), GP8())
|
b2 := Load(Param("s").Field("Array").Index(2).Field("B").Index(2), GP8())
|
||||||
Store(b2, ReturnIndex(0))
|
Store(b2, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldArrayOneC", "func(s Struct) uint16")
|
TEXT("FieldArrayOneC", NOSPLIT, "func(s Struct) uint16")
|
||||||
c1 := Load(Param("s").Field("Array").Index(1).Field("C"), GP16())
|
c1 := Load(Param("s").Field("Array").Index(1).Field("C"), GP16())
|
||||||
Store(c1, ReturnIndex(0))
|
Store(c1, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldComplex64Imag", "func(s Struct) float32")
|
TEXT("FieldComplex64Imag", NOSPLIT, "func(s Struct) float32")
|
||||||
c64i := Load(Param("s").Field("Complex64").Imag(), XMM())
|
c64i := Load(Param("s").Field("Complex64").Imag(), XMM())
|
||||||
Store(c64i, ReturnIndex(0))
|
Store(c64i, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("FieldComplex128Real", "func(s Struct) float64")
|
TEXT("FieldComplex128Real", NOSPLIT, "func(s Struct) float64")
|
||||||
c128r := Load(Param("s").Field("Complex128").Real(), XMM())
|
c128r := Load(Param("s").Field("Complex128").Real(), XMM())
|
||||||
Store(c128r, ReturnIndex(0))
|
Store(c128r, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|||||||
@@ -7,19 +7,19 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("Real", "func(z complex128) float64")
|
TEXT("Real", NOSPLIT, "func(z complex128) float64")
|
||||||
Doc("Real returns the real part of z.")
|
Doc("Real returns the real part of z.")
|
||||||
r := Load(Param("z").Real(), XMM())
|
r := Load(Param("z").Real(), XMM())
|
||||||
Store(r, ReturnIndex(0))
|
Store(r, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("Imag", "func(z complex128) float64")
|
TEXT("Imag", NOSPLIT, "func(z complex128) float64")
|
||||||
Doc("Imag returns the imaginary part of z.")
|
Doc("Imag returns the imaginary part of z.")
|
||||||
i := Load(Param("z").Imag(), XMM())
|
i := Load(Param("z").Imag(), XMM())
|
||||||
Store(i, ReturnIndex(0))
|
Store(i, ReturnIndex(0))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("Norm", "func(z complex128) float64")
|
TEXT("Norm", NOSPLIT, "func(z complex128) float64")
|
||||||
Doc("Norm returns the complex norm of z.")
|
Doc("Norm returns the complex norm of z.")
|
||||||
r = Load(Param("z").Real(), XMM())
|
r = Load(Param("z").Real(), XMM())
|
||||||
i = Load(Param("z").Imag(), XMM())
|
i = Load(Param("z").Imag(), XMM())
|
||||||
|
|||||||
@@ -1,19 +1,21 @@
|
|||||||
// Code generated by command: go run asm.go -out complex.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out complex.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Real(z complex128) float64
|
// func Real(z complex128) float64
|
||||||
TEXT ·Real(SB), $0-24
|
TEXT ·Real(SB), NOSPLIT, $0-24
|
||||||
MOVSD z_real(FP), X0
|
MOVSD z_real(FP), X0
|
||||||
MOVSD X0, ret+16(FP)
|
MOVSD X0, ret+16(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func Imag(z complex128) float64
|
// func Imag(z complex128) float64
|
||||||
TEXT ·Imag(SB), $0-24
|
TEXT ·Imag(SB), NOSPLIT, $0-24
|
||||||
MOVSD z_imag+8(FP), X0
|
MOVSD z_imag+8(FP), X0
|
||||||
MOVSD X0, ret+16(FP)
|
MOVSD X0, ret+16(FP)
|
||||||
RET
|
RET
|
||||||
|
|
||||||
// func Norm(z complex128) float64
|
// func Norm(z complex128) float64
|
||||||
TEXT ·Norm(SB), $0-24
|
TEXT ·Norm(SB), NOSPLIT, $0-24
|
||||||
MOVSD z_real(FP), X0
|
MOVSD z_real(FP), X0
|
||||||
MOVSD z_imag+8(FP), X1
|
MOVSD z_imag+8(FP), X1
|
||||||
MULSD X0, X0
|
MULSD X0, X0
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ package main
|
|||||||
import (
|
import (
|
||||||
"math"
|
"math"
|
||||||
|
|
||||||
. "github.com/mmcloughlin/avo/attr"
|
|
||||||
. "github.com/mmcloughlin/avo/build"
|
. "github.com/mmcloughlin/avo/build"
|
||||||
. "github.com/mmcloughlin/avo/operand"
|
. "github.com/mmcloughlin/avo/operand"
|
||||||
)
|
)
|
||||||
@@ -21,7 +20,7 @@ func main() {
|
|||||||
DATA(38, U8(0x66))
|
DATA(38, U8(0x66))
|
||||||
DATA(39, U8(0x77))
|
DATA(39, U8(0x77))
|
||||||
|
|
||||||
TEXT("DataAt", "func(i int) byte")
|
TEXT("DataAt", NOSPLIT, "func(i int) byte")
|
||||||
Doc("DataAt returns byte i in the 'bytes' global data section.")
|
Doc("DataAt returns byte i in the 'bytes' global data section.")
|
||||||
i := Load(Param("i"), GP64())
|
i := Load(Param("i"), GP64())
|
||||||
ptr := Mem{Base: GP64()}
|
ptr := Mem{Base: GP64()}
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ DATA bytes<>+39(SB)/1, $0x77
|
|||||||
GLOBL bytes<>(SB), RODATA|NOPTR, $40
|
GLOBL bytes<>(SB), RODATA|NOPTR, $40
|
||||||
|
|
||||||
// func DataAt(i int) byte
|
// func DataAt(i int) byte
|
||||||
TEXT ·DataAt(SB), $0-9
|
TEXT ·DataAt(SB), NOSPLIT, $0-9
|
||||||
MOVQ i(FP), AX
|
MOVQ i(FP), AX
|
||||||
LEAQ bytes<>(SB), CX
|
LEAQ bytes<>(SB), CX
|
||||||
MOVB (CX)(AX*1), AL
|
MOVB (CX)(AX*1), AL
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ import (
|
|||||||
var unroll = 6
|
var unroll = 6
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("Dot", "func(x, y []float32) float32")
|
TEXT("Dot", NOSPLIT, "func(x, y []float32) float32")
|
||||||
x := Mem{Base: Load(Param("x").Base(), GP64())}
|
x := Mem{Base: Load(Param("x").Base(), GP64())}
|
||||||
y := Mem{Base: Load(Param("y").Base(), GP64())}
|
y := Mem{Base: Load(Param("y").Base(), GP64())}
|
||||||
n := Load(Param("x").Len(), GP64())
|
n := Load(Param("x").Len(), GP64())
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
// Code generated by command: go run asm.go -out dot.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out dot.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Dot(x []float32, y []float32) float32
|
// func Dot(x []float32, y []float32) float32
|
||||||
TEXT ·Dot(SB), $0-52
|
TEXT ·Dot(SB), NOSPLIT, $0-52
|
||||||
MOVQ x_base(FP), AX
|
MOVQ x_base(FP), AX
|
||||||
MOVQ y_base+24(FP), CX
|
MOVQ y_base+24(FP), CX
|
||||||
MOVQ x_len+8(FP), DX
|
MOVQ x_len+8(FP), DX
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("Hash64", "func(data []byte) uint64")
|
TEXT("Hash64", NOSPLIT, "func(data []byte) uint64")
|
||||||
Doc("Hash64 computes the FNV-1a hash of data.")
|
Doc("Hash64 computes the FNV-1a hash of data.")
|
||||||
ptr := Load(Param("data").Base(), GP64())
|
ptr := Load(Param("data").Base(), GP64())
|
||||||
n := Load(Param("data").Len(), GP64())
|
n := Load(Param("data").Len(), GP64())
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
// Code generated by command: go run asm.go -out fnv1a.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out fnv1a.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Hash64(data []byte) uint64
|
// func Hash64(data []byte) uint64
|
||||||
TEXT ·Hash64(SB), $0-32
|
TEXT ·Hash64(SB), NOSPLIT, $0-32
|
||||||
MOVQ data_base(FP), CX
|
MOVQ data_base(FP), CX
|
||||||
MOVQ data_len+8(FP), BX
|
MOVQ data_len+8(FP), BX
|
||||||
MOVQ $0xcbf29ce484222325, AX
|
MOVQ $0xcbf29ce484222325, AX
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("EncodeInt", "func(lat, lng float64) uint64")
|
TEXT("EncodeInt", NOSPLIT, "func(lat, lng float64) uint64")
|
||||||
Doc("EncodeInt computes the 64-bit integer geohash of (lat, lng).")
|
Doc("EncodeInt computes the 64-bit integer geohash of (lat, lng).")
|
||||||
lat := Load(Param("lat"), XMM())
|
lat := Load(Param("lat"), XMM())
|
||||||
lng := Load(Param("lng"), XMM())
|
lng := Load(Param("lng"), XMM())
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
#include "textflag.h"
|
#include "textflag.h"
|
||||||
|
|
||||||
// func EncodeInt(lat float64, lng float64) uint64
|
// func EncodeInt(lat float64, lng float64) uint64
|
||||||
TEXT ·EncodeInt(SB), $0-24
|
TEXT ·EncodeInt(SB), NOSPLIT, $0-24
|
||||||
MOVSD lat(FP), X0
|
MOVSD lat(FP), X0
|
||||||
MOVSD lng+8(FP), X1
|
MOVSD lng+8(FP), X1
|
||||||
MULSD reciprocal180<>(SB), X0
|
MULSD reciprocal180<>(SB), X0
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ import (
|
|||||||
func main() {
|
func main() {
|
||||||
Package("github.com/mmcloughlin/avo/examples/returns")
|
Package("github.com/mmcloughlin/avo/examples/returns")
|
||||||
|
|
||||||
TEXT("Interval", "func(start, size uint64) (uint64, uint64)")
|
TEXT("Interval", NOSPLIT, "func(start, size uint64) (uint64, uint64)")
|
||||||
Doc(
|
Doc(
|
||||||
"Interval returns the (start, end) of an interval with the given start and size.",
|
"Interval returns the (start, end) of an interval with the given start and size.",
|
||||||
"Demonstrates multiple unnamed return values.",
|
"Demonstrates multiple unnamed return values.",
|
||||||
@@ -23,7 +23,7 @@ func main() {
|
|||||||
Store(end, ReturnIndex(1))
|
Store(end, ReturnIndex(1))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("Butterfly", "func(x0, x1 float64) (y0, y1 float64)")
|
TEXT("Butterfly", NOSPLIT, "func(x0, x1 float64) (y0, y1 float64)")
|
||||||
Doc(
|
Doc(
|
||||||
"Butterfly performs a 2-dimensional butterfly operation: computes (x0+x1, x0-x1).",
|
"Butterfly performs a 2-dimensional butterfly operation: computes (x0+x1, x0-x1).",
|
||||||
"Demonstrates multiple named return values.",
|
"Demonstrates multiple named return values.",
|
||||||
@@ -39,7 +39,7 @@ func main() {
|
|||||||
Store(y1, Return("y1"))
|
Store(y1, Return("y1"))
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("Septuple", "func(byte) [7]byte")
|
TEXT("Septuple", NOSPLIT, "func(byte) [7]byte")
|
||||||
Doc(
|
Doc(
|
||||||
"Septuple returns an array of seven of the given byte.",
|
"Septuple returns an array of seven of the given byte.",
|
||||||
"Demonstrates returning array values.",
|
"Demonstrates returning array values.",
|
||||||
@@ -50,7 +50,7 @@ func main() {
|
|||||||
}
|
}
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("CriticalLine", "func(t float64) complex128")
|
TEXT("CriticalLine", NOSPLIT, "func(t float64) complex128")
|
||||||
Doc(
|
Doc(
|
||||||
"CriticalLine returns the complex value 0.5 + it on Riemann's critical line.",
|
"CriticalLine returns the complex value 0.5 + it on Riemann's critical line.",
|
||||||
"Demonstrates returning complex values.",
|
"Demonstrates returning complex values.",
|
||||||
@@ -62,7 +62,7 @@ func main() {
|
|||||||
Store(t, ReturnIndex(0).Imag())
|
Store(t, ReturnIndex(0).Imag())
|
||||||
RET()
|
RET()
|
||||||
|
|
||||||
TEXT("NewStruct", "func(w uint16, p [2]float64, q uint64) Struct")
|
TEXT("NewStruct", NOSPLIT, "func(w uint16, p [2]float64, q uint64) Struct")
|
||||||
Doc(
|
Doc(
|
||||||
"NewStruct initializes a Struct value.",
|
"NewStruct initializes a Struct value.",
|
||||||
"Demonstrates returning struct values.",
|
"Demonstrates returning struct values.",
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
#include "textflag.h"
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Interval(start uint64, size uint64) (uint64, uint64)
|
// func Interval(start uint64, size uint64) (uint64, uint64)
|
||||||
TEXT ·Interval(SB), $0-32
|
TEXT ·Interval(SB), NOSPLIT, $0-32
|
||||||
MOVQ start(FP), AX
|
MOVQ start(FP), AX
|
||||||
MOVQ size+8(FP), CX
|
MOVQ size+8(FP), CX
|
||||||
ADDQ AX, CX
|
ADDQ AX, CX
|
||||||
@@ -12,7 +12,7 @@ TEXT ·Interval(SB), $0-32
|
|||||||
RET
|
RET
|
||||||
|
|
||||||
// func Butterfly(x0 float64, x1 float64) (y0 float64, y1 float64)
|
// func Butterfly(x0 float64, x1 float64) (y0 float64, y1 float64)
|
||||||
TEXT ·Butterfly(SB), $0-32
|
TEXT ·Butterfly(SB), NOSPLIT, $0-32
|
||||||
MOVSD x0(FP), X0
|
MOVSD x0(FP), X0
|
||||||
MOVSD x1+8(FP), X1
|
MOVSD x1+8(FP), X1
|
||||||
MOVSD X0, X2
|
MOVSD X0, X2
|
||||||
@@ -24,7 +24,7 @@ TEXT ·Butterfly(SB), $0-32
|
|||||||
RET
|
RET
|
||||||
|
|
||||||
// func Septuple(byte) [7]byte
|
// func Septuple(byte) [7]byte
|
||||||
TEXT ·Septuple(SB), $0-15
|
TEXT ·Septuple(SB), NOSPLIT, $0-15
|
||||||
MOVB arg(FP), AL
|
MOVB arg(FP), AL
|
||||||
MOVB AL, ret_0+8(FP)
|
MOVB AL, ret_0+8(FP)
|
||||||
MOVB AL, ret_1+9(FP)
|
MOVB AL, ret_1+9(FP)
|
||||||
@@ -36,7 +36,7 @@ TEXT ·Septuple(SB), $0-15
|
|||||||
RET
|
RET
|
||||||
|
|
||||||
// func CriticalLine(t float64) complex128
|
// func CriticalLine(t float64) complex128
|
||||||
TEXT ·CriticalLine(SB), $0-24
|
TEXT ·CriticalLine(SB), NOSPLIT, $0-24
|
||||||
MOVSD t(FP), X0
|
MOVSD t(FP), X0
|
||||||
MOVSD half<>(SB), X1
|
MOVSD half<>(SB), X1
|
||||||
MOVSD X1, ret_real+8(FP)
|
MOVSD X1, ret_real+8(FP)
|
||||||
@@ -47,7 +47,7 @@ DATA half<>(SB)/8, $(0.5)
|
|||||||
GLOBL half<>(SB), RODATA|NOPTR, $8
|
GLOBL half<>(SB), RODATA|NOPTR, $8
|
||||||
|
|
||||||
// func NewStruct(w uint16, p [2]float64, q uint64) Struct
|
// func NewStruct(w uint16, p [2]float64, q uint64) Struct
|
||||||
TEXT ·NewStruct(SB), $0-64
|
TEXT ·NewStruct(SB), NOSPLIT, $0-64
|
||||||
MOVW w(FP), AX
|
MOVW w(FP), AX
|
||||||
MOVSD p_0+8(FP), X0
|
MOVSD p_0+8(FP), X0
|
||||||
MOVSD p_1+16(FP), X1
|
MOVSD p_1+16(FP), X1
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("block", "func(h *[5]uint32, m []byte)")
|
TEXT("block", 0, "func(h *[5]uint32, m []byte)")
|
||||||
Doc("block SHA-1 hashes the 64-byte message m into the running state h.")
|
Doc("block SHA-1 hashes the 64-byte message m into the running state h.")
|
||||||
h := Mem{Base: Load(Param("h"), GP64())}
|
h := Mem{Base: Load(Param("h"), GP64())}
|
||||||
m := Mem{Base: Load(Param("m").Base(), GP64())}
|
m := Mem{Base: Load(Param("m").Base(), GP64())}
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ func makelabels(name string, n int) []string {
|
|||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
Package("github.com/mmcloughlin/avo/examples/stadtx")
|
Package("github.com/mmcloughlin/avo/examples/stadtx")
|
||||||
TEXT("Hash", "func(state *State, key []byte) uint64")
|
TEXT("Hash", NOSPLIT, "func(state *State, key []byte) uint64")
|
||||||
Doc("Hash computes the Stadtx hash.")
|
Doc("Hash computes the Stadtx hash.")
|
||||||
|
|
||||||
statePtr := Load(Param("state"), GP64())
|
statePtr := Load(Param("state"), GP64())
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
// Code generated by command: go run asm.go -out stadtx.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out stadtx.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Hash(state *State, key []byte) uint64
|
// func Hash(state *State, key []byte) uint64
|
||||||
TEXT ·Hash(SB), $0-40
|
TEXT ·Hash(SB), NOSPLIT, $0-40
|
||||||
MOVQ state(FP), AX
|
MOVQ state(FP), AX
|
||||||
MOVQ key_base+8(FP), CX
|
MOVQ key_base+8(FP), CX
|
||||||
MOVQ key_len+16(FP), DX
|
MOVQ key_len+16(FP), DX
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("Sum", "func(xs []uint64) uint64")
|
TEXT("Sum", NOSPLIT, "func(xs []uint64) uint64")
|
||||||
Doc("Sum returns the sum of the elements in xs.")
|
Doc("Sum returns the sum of the elements in xs.")
|
||||||
ptr := Load(Param("xs").Base(), GP64())
|
ptr := Load(Param("xs").Base(), GP64())
|
||||||
n := Load(Param("xs").Len(), GP64())
|
n := Load(Param("xs").Len(), GP64())
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
// Code generated by command: go run asm.go -out sum.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out sum.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Sum(xs []uint64) uint64
|
// func Sum(xs []uint64) uint64
|
||||||
TEXT ·Sum(SB), $0-32
|
TEXT ·Sum(SB), NOSPLIT, $0-32
|
||||||
MOVQ xs_base(FP), AX
|
MOVQ xs_base(FP), AX
|
||||||
MOVQ xs_len+8(FP), CX
|
MOVQ xs_len+8(FP), CX
|
||||||
XORQ DX, DX
|
XORQ DX, DX
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
TEXT("Split", "func(x uint64) (q uint64, l uint32, w uint16, b uint8)")
|
TEXT("Split", NOSPLIT, "func(x uint64) (q uint64, l uint32, w uint16, b uint8)")
|
||||||
Doc(
|
Doc(
|
||||||
"Split returns the low 64, 32, 16 and 8 bits of x.",
|
"Split returns the low 64, 32, 16 and 8 bits of x.",
|
||||||
"Tests the As() methods of virtual general-purpose registers.",
|
"Tests the As() methods of virtual general-purpose registers.",
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
// Code generated by command: go run asm.go -out cast.s -stubs stub.go. DO NOT EDIT.
|
// Code generated by command: go run asm.go -out cast.s -stubs stub.go. DO NOT EDIT.
|
||||||
|
|
||||||
|
#include "textflag.h"
|
||||||
|
|
||||||
// func Split(x uint64) (q uint64, l uint32, w uint16, b uint8)
|
// func Split(x uint64) (q uint64, l uint32, w uint16, b uint8)
|
||||||
TEXT ·Split(SB), $0-23
|
TEXT ·Split(SB), NOSPLIT, $0-23
|
||||||
MOVQ x(FP), AX
|
MOVQ x(FP), AX
|
||||||
MOVQ AX, q+8(FP)
|
MOVQ AX, q+8(FP)
|
||||||
MOVL AX, l+16(FP)
|
MOVL AX, l+16(FP)
|
||||||
|
|||||||
Reference in New Issue
Block a user