From cedb54490a281d2fce83ef36f8b00bf8e08b8a53 Mon Sep 17 00:00:00 2001 From: "Charles L. Dorian" Date: Tue, 18 May 2010 22:33:50 -0700 Subject: math: amd64 versions of fdim, fmax, fmin Uses the SSE2 max, min instructions. Also shorter sqrt_amd64.s R=rsc CC=golang-dev http://codereview.appspot.com/1216042 Committer: Russ Cox --- src/pkg/math/Makefile | 1 + src/pkg/math/fdim_amd64.s | 26 ++++++++++++++++++++++++++ src/pkg/math/fdim_decl.go | 9 +++++++++ src/pkg/math/sqrt_amd64.s | 3 +-- 4 files changed, 37 insertions(+), 2 deletions(-) create mode 100644 src/pkg/math/fdim_amd64.s create mode 100644 src/pkg/math/fdim_decl.go (limited to 'src') diff --git a/src/pkg/math/Makefile b/src/pkg/math/Makefile index e8edd3505..1447fc11d 100644 --- a/src/pkg/math/Makefile +++ b/src/pkg/math/Makefile @@ -7,6 +7,7 @@ include ../../Make.$(GOARCH) TARG=math OFILES_amd64=\ + fdim_amd64.$O\ sqrt_amd64.$O\ OFILES_386=\ diff --git a/src/pkg/math/fdim_amd64.s b/src/pkg/math/fdim_amd64.s new file mode 100644 index 000000000..1f45ef8b9 --- /dev/null +++ b/src/pkg/math/fdim_amd64.s @@ -0,0 +1,26 @@ +// Copyright 2010 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// func Fdim(x, y float64) float64 +TEXT ·Fdim(SB),7,$0 + MOVSD x+0(FP), X0 + SUBSD y+8(FP), X0 + MOVSD $(0.0), X1 + MAXSD X1, X0 + MOVSD X0, r+16(FP) + RET + +// func Fmax(x, y float64) float64 +TEXT ·Fmax(SB),7,$0 + MOVSD x+0(FP), X0 + MAXSD y+8(FP), X0 + MOVSD X0, r+16(FP) + RET + +// func Fmin(x, y float64) float64 +TEXT ·Fmin(SB),7,$0 + MOVSD x+0(FP), X0 + MINSD y+8(FP), X0 + MOVSD X0, r+16(FP) + RET diff --git a/src/pkg/math/fdim_decl.go b/src/pkg/math/fdim_decl.go new file mode 100644 index 000000000..88dea3de4 --- /dev/null +++ b/src/pkg/math/fdim_decl.go @@ -0,0 +1,9 @@ +// Copyright 2010 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +package math + +func Fdim(x, y float64) float64 +func Fmax(x, y float64) float64 +func Fmin(x, y float64) float64 diff --git a/src/pkg/math/sqrt_amd64.s b/src/pkg/math/sqrt_amd64.s index e98daebf9..f5b329e70 100644 --- a/src/pkg/math/sqrt_amd64.s +++ b/src/pkg/math/sqrt_amd64.s @@ -4,7 +4,6 @@ // func Sqrt(x float64) float64 TEXT ·Sqrt(SB),7,$0 - MOVSD x+0(FP), X0 - SQRTSD X0, X0 + SQRTSD x+0(FP), X0 MOVSD X0, r+8(FP) RET -- cgit v1.2.3