2005-09-02 18:32:22 +00:00
|
|
|
; fsqrt should be generated when the fsqrt feature is enabled, but not
|
|
|
|
; otherwise.
|
|
|
|
|
2008-02-19 08:07:33 +00:00
|
|
|
; RUN: llvm-as < %s | \
|
2007-04-15 21:17:45 +00:00
|
|
|
; RUN: llc -march=ppc32 -mtriple=powerpc-apple-darwin8 -mattr=+fsqrt | \
|
|
|
|
; RUN: grep {fsqrt f1, f1}
|
2008-02-19 08:07:33 +00:00
|
|
|
; RUN: llvm-as < %s | \
|
2007-04-15 21:17:45 +00:00
|
|
|
; RUN: llc -march=ppc32 -mtriple=powerpc-apple-darwin8 -mcpu=g5 | \
|
|
|
|
; RUN: grep {fsqrt f1, f1}
|
2008-02-19 08:07:33 +00:00
|
|
|
; RUN: llvm-as < %s | \
|
2007-04-15 21:17:45 +00:00
|
|
|
; RUN: llc -march=ppc32 -mtriple=powerpc-apple-darwin8 -mattr=-fsqrt | \
|
|
|
|
; RUN: not grep {fsqrt f1, f1}
|
2008-02-19 08:07:33 +00:00
|
|
|
; RUN: llvm-as < %s | \
|
2007-04-15 21:17:45 +00:00
|
|
|
; RUN: llc -march=ppc32 -mtriple=powerpc-apple-darwin8 -mcpu=g4 | \
|
|
|
|
; RUN: not grep {fsqrt f1, f1}
|
2005-09-02 18:32:22 +00:00
|
|
|
|
2008-02-19 08:07:33 +00:00
|
|
|
declare double @llvm.sqrt.f64(double)
|
|
|
|
|
|
|
|
define double @X(double %Y) {
|
|
|
|
%Z = call double @llvm.sqrt.f64( double %Y ) ; <double> [#uses=1]
|
|
|
|
ret double %Z
|
2005-09-02 18:32:22 +00:00
|
|
|
}
|
2008-02-19 08:07:33 +00:00
|
|
|
|