X7ROOT File Manager
Current Path:
/opt/golang/1.22.0/src/math
opt
/
golang
/
1.22.0
/
src
/
math
/
π
..
π
abs.go
(366 B)
π
acos_s390x.s
(3.73 KB)
π
acosh.go
(1.71 KB)
π
acosh_s390x.s
(4.32 KB)
π
all_test.go
(86.77 KB)
π
arith_s390x.go
(3.73 KB)
π
arith_s390x_test.go
(10.78 KB)
π
asin.go
(1.09 KB)
π
asin_s390x.s
(4.16 KB)
π
asinh.go
(1.92 KB)
π
asinh_s390x.s
(5.74 KB)
π
atan.go
(3.03 KB)
π
atan2.go
(1.52 KB)
π
atan2_s390x.s
(6.93 KB)
π
atan_s390x.s
(3.69 KB)
π
atanh.go
(1.99 KB)
π
atanh_s390x.s
(5.06 KB)
π
big
π
bits
π
bits.go
(1.87 KB)
π
cbrt.go
(2.31 KB)
π
cbrt_s390x.s
(4.89 KB)
π
cmplx
π
const.go
(2.76 KB)
π
const_test.go
(1.29 KB)
π
copysign.go
(396 B)
π
cosh_s390x.s
(5.59 KB)
π
dim.go
(1.87 KB)
π
dim_amd64.s
(1.92 KB)
π
dim_arm64.s
(963 B)
π
dim_asm.go
(344 B)
π
dim_noasm.go
(410 B)
π
dim_riscv64.s
(1.16 KB)
π
dim_s390x.s
(1.97 KB)
π
erf.go
(11.51 KB)
π
erf_s390x.s
(8.5 KB)
π
erfc_s390x.s
(14.4 KB)
π
erfinv.go
(3.37 KB)
π
example_test.go
(3.75 KB)
π
exp.go
(5.38 KB)
π
exp2_asm.go
(252 B)
π
exp2_noasm.go
(284 B)
π
exp_amd64.go
(261 B)
π
exp_amd64.s
(4.24 KB)
π
exp_arm64.s
(5.36 KB)
π
exp_asm.go
(268 B)
π
exp_noasm.go
(302 B)
π
exp_s390x.s
(4.65 KB)
π
expm1.go
(7.91 KB)
π
expm1_s390x.s
(5.29 KB)
π
export_s390x_test.go
(732 B)
π
export_test.go
(357 B)
π
floor.go
(3.29 KB)
π
floor_386.s
(1.47 KB)
π
floor_amd64.s
(2 KB)
π
floor_arm64.s
(573 B)
π
floor_asm.go
(431 B)
π
floor_noasm.go
(531 B)
π
floor_ppc64x.s
(499 B)
π
floor_s390x.s
(579 B)
π
floor_wasm.s
(459 B)
π
fma.go
(4.61 KB)
π
frexp.go
(929 B)
π
gamma.go
(5.53 KB)
π
huge_test.go
(2.91 KB)
π
hypot.go
(850 B)
π
hypot_386.s
(1.81 KB)
π
hypot_amd64.s
(1.05 KB)
π
hypot_asm.go
(264 B)
π
hypot_noasm.go
(297 B)
π
j0.go
(13.6 KB)
π
j1.go
(13.3 KB)
π
jn.go
(7.18 KB)
π
ldexp.go
(1.05 KB)
π
lgamma.go
(11.03 KB)
π
log.go
(3.86 KB)
π
log10.go
(873 B)
π
log10_s390x.s
(4.73 KB)
π
log1p.go
(6.34 KB)
π
log1p_s390x.s
(5.15 KB)
π
log_amd64.s
(3.66 KB)
π
log_asm.go
(259 B)
π
log_s390x.s
(4.31 KB)
π
log_stub.go
(292 B)
π
logb.go
(1021 B)
π
mod.go
(903 B)
π
modf.go
(913 B)
π
modf_arm64.s
(447 B)
π
modf_asm.go
(292 B)
π
modf_noasm.go
(326 B)
π
modf_ppc64x.s
(416 B)
π
nextafter.go
(1.21 KB)
π
pow.go
(3.65 KB)
π
pow10.go
(1.24 KB)
π
pow_s390x.s
(16.27 KB)
π
rand
π
remainder.go
(2.04 KB)
π
signbit.go
(302 B)
π
sin.go
(6.35 KB)
π
sin_s390x.s
(8.57 KB)
π
sincos.go
(1.76 KB)
π
sinh.go
(1.69 KB)
π
sinh_s390x.s
(5.98 KB)
π
sqrt.go
(4.75 KB)
π
stubs.go
(2.57 KB)
π
stubs_s390x.s
(12.38 KB)
π
tan.go
(3.68 KB)
π
tan_s390x.s
(2.72 KB)
π
tanh.go
(2.66 KB)
π
tanh_s390x.s
(4.57 KB)
π
trig_reduce.go
(3.34 KB)
π
unsafe.go
(1.27 KB)
Editing: sinh_s390x.s
// Copyright 2016 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. #include "textflag.h" // Constants DATA sinhrodataL21<>+0(SB)/8, $0.231904681384629956E-16 DATA sinhrodataL21<>+8(SB)/8, $0.693147180559945286E+00 DATA sinhrodataL21<>+16(SB)/8, $704.E0 GLOBL sinhrodataL21<>+0(SB), RODATA, $24 DATA sinhrlog2<>+0(SB)/8, $0x3ff7154760000000 GLOBL sinhrlog2<>+0(SB), RODATA, $8 DATA sinhxinf<>+0(SB)/8, $0x7ff0000000000000 GLOBL sinhxinf<>+0(SB), RODATA, $8 DATA sinhxinit<>+0(SB)/8, $0x3ffb504f333f9de6 GLOBL sinhxinit<>+0(SB), RODATA, $8 DATA sinhxlim1<>+0(SB)/8, $800.E0 GLOBL sinhxlim1<>+0(SB), RODATA, $8 DATA sinhxadd<>+0(SB)/8, $0xc3200001610007fb GLOBL sinhxadd<>+0(SB), RODATA, $8 DATA sinhx4ff<>+0(SB)/8, $0x4ff0000000000000 GLOBL sinhx4ff<>+0(SB), RODATA, $8 // Minimax polynomial approximations DATA sinhe0<>+0(SB)/8, $0.11715728752538099300E+01 GLOBL sinhe0<>+0(SB), RODATA, $8 DATA sinhe1<>+0(SB)/8, $0.11715728752538099300E+01 GLOBL sinhe1<>+0(SB), RODATA, $8 DATA sinhe2<>+0(SB)/8, $0.58578643762688526692E+00 GLOBL sinhe2<>+0(SB), RODATA, $8 DATA sinhe3<>+0(SB)/8, $0.19526214587563004497E+00 GLOBL sinhe3<>+0(SB), RODATA, $8 DATA sinhe4<>+0(SB)/8, $0.48815536475176217404E-01 GLOBL sinhe4<>+0(SB), RODATA, $8 DATA sinhe5<>+0(SB)/8, $0.97631072948627397816E-02 GLOBL sinhe5<>+0(SB), RODATA, $8 DATA sinhe6<>+0(SB)/8, $0.16271839297756073153E-02 GLOBL sinhe6<>+0(SB), RODATA, $8 DATA sinhe7<>+0(SB)/8, $0.23245485387271142509E-03 GLOBL sinhe7<>+0(SB), RODATA, $8 DATA sinhe8<>+0(SB)/8, $0.29080955860869629131E-04 GLOBL sinhe8<>+0(SB), RODATA, $8 DATA sinhe9<>+0(SB)/8, $0.32311267157667725278E-05 GLOBL sinhe9<>+0(SB), RODATA, $8 // Sinh returns the hyperbolic sine of the argument. // // Special cases are: // Sinh(Β±0) = Β±0 // Sinh(Β±Inf) = Β±Inf // Sinh(NaN) = NaN // The algorithm used is minimax polynomial approximation // with coefficients determined with a Remez exchange algorithm. TEXT Β·sinhAsm(SB),NOSPLIT,$0-16 FMOVD x+0(FP), F0 //special case Sinh(Β±0) = Β±0 FMOVD $(0.0), F1 FCMPU F0, F1 BEQ sinhIsZero //special case Sinh(Β±Inf) = Β±Inf FMOVD $1.797693134862315708145274237317043567981e+308, F1 FCMPU F1, F0 BLEU sinhIsInf FMOVD $-1.797693134862315708145274237317043567981e+308, F1 FCMPU F1, F0 BGT sinhIsInf MOVD $sinhrodataL21<>+0(SB), R5 LTDBR F0, F0 MOVD sinhxinit<>+0(SB), R1 FMOVD F0, F4 MOVD R1, R3 BLTU L19 FMOVD F0, F2 L2: WORD $0xED205010 //cdb %f2,.L22-.L21(%r5) BYTE $0x00 BYTE $0x19 BGE L15 //jnl .L15 BVS L15 WFCEDBS V2, V2, V0 BEQ L20 L12: FMOVD F4, F0 FMOVD F0, ret+8(FP) RET L15: WFCEDBS V2, V2, V0 BVS L12 MOVD $sinhxlim1<>+0(SB), R2 FMOVD 0(R2), F0 WFCHDBS V0, V2, V0 BEQ L6 WFCHEDBS V4, V2, V6 MOVD $sinhxinf<>+0(SB), R1 FMOVD 0(R1), F0 BNE LEXITTAGsinh WFCHDBS V2, V4, V2 BNE L16 FNEG F0, F0 FMOVD F0, ret+8(FP) RET L19: FNEG F0, F2 BR L2 L6: MOVD $sinhxadd<>+0(SB), R2 FMOVD 0(R2), F0 MOVD sinhrlog2<>+0(SB), R2 LDGR R2, F6 WFMSDB V4, V6, V0, V16 FMOVD sinhrodataL21<>+8(SB), F6 WFADB V0, V16, V0 FMOVD sinhrodataL21<>+0(SB), F3 WFMSDB V0, V6, V4, V6 MOVD $sinhe9<>+0(SB), R2 WFMADB V0, V3, V6, V0 FMOVD 0(R2), F1 MOVD $sinhe7<>+0(SB), R2 WFMDB V0, V0, V6 FMOVD 0(R2), F5 MOVD $sinhe8<>+0(SB), R2 FMOVD 0(R2), F3 MOVD $sinhe6<>+0(SB), R2 WFMADB V6, V1, V5, V1 FMOVD 0(R2), F5 MOVD $sinhe5<>+0(SB), R2 FMOVD 0(R2), F7 MOVD $sinhe3<>+0(SB), R2 WFMADB V6, V3, V5, V3 FMOVD 0(R2), F5 MOVD $sinhe4<>+0(SB), R2 WFMADB V6, V7, V5, V7 FMOVD 0(R2), F5 MOVD $sinhe2<>+0(SB), R2 VLEG $0, 0(R2), V20 WFMDB V6, V6, V18 WFMADB V6, V5, V20, V5 WFMADB V1, V18, V7, V1 FNEG F0, F0 WFMADB V3, V18, V5, V3 MOVD $sinhe1<>+0(SB), R3 WFCEDBS V2, V4, V2 FMOVD 0(R3), F5 MOVD $sinhe0<>+0(SB), R3 WFMADB V6, V1, V5, V1 FMOVD 0(R3), F5 VLGVG $0, V16, R2 WFMADB V6, V3, V5, V6 RLL $3, R2, R2 RISBGN $0, $15, $48, R2, R1 BEQ L9 WFMSDB V0, V1, V6, V0 MOVD $sinhx4ff<>+0(SB), R3 FNEG F0, F0 FMOVD 0(R3), F2 FMUL F2, F0 ANDW $0xFFFF, R2 WORD $0xA53FEFB6 //llill %r3,61366 SUBW R2, R3, R2 RISBGN $0, $15, $48, R2, R1 LDGR R1, F2 FMUL F2, F0 FMOVD F0, ret+8(FP) RET L20: MOVD $sinhxadd<>+0(SB), R2 FMOVD 0(R2), F2 MOVD sinhrlog2<>+0(SB), R2 LDGR R2, F0 WFMSDB V4, V0, V2, V6 FMOVD sinhrodataL21<>+8(SB), F0 FADD F6, F2 MOVD $sinhe9<>+0(SB), R2 FMSUB F0, F2, F4 FMOVD 0(R2), F1 FMOVD sinhrodataL21<>+0(SB), F3 MOVD $sinhe7<>+0(SB), R2 FMADD F3, F2, F4 FMOVD 0(R2), F0 MOVD $sinhe8<>+0(SB), R2 WFMDB V4, V4, V2 FMOVD 0(R2), F3 MOVD $sinhe6<>+0(SB), R2 FMOVD 0(R2), F5 LGDR F6, R2 RLL $3, R2, R2 RISBGN $0, $15, $48, R2, R1 WFMADB V2, V1, V0, V1 LDGR R1, F0 MOVD $sinhe5<>+0(SB), R1 WFMADB V2, V3, V5, V3 FMOVD 0(R1), F5 MOVD $sinhe3<>+0(SB), R1 FMOVD 0(R1), F6 WFMDB V2, V2, V7 WFMADB V2, V5, V6, V5 WORD $0xA7487FB6 //lhi %r4,32694 FNEG F4, F4 ANDW $0xFFFF, R2 SUBW R2, R4, R2 RISBGN $0, $15, $48, R2, R3 LDGR R3, F6 WFADB V0, V6, V16 MOVD $sinhe4<>+0(SB), R1 WFMADB V1, V7, V5, V1 WFMDB V4, V16, V4 FMOVD 0(R1), F5 MOVD $sinhe2<>+0(SB), R1 VLEG $0, 0(R1), V16 MOVD $sinhe1<>+0(SB), R1 WFMADB V2, V5, V16, V5 VLEG $0, 0(R1), V16 WFMADB V3, V7, V5, V3 WFMADB V2, V1, V16, V1 FSUB F6, F0 FMUL F1, F4 MOVD $sinhe0<>+0(SB), R1 FMOVD 0(R1), F6 WFMADB V2, V3, V6, V2 WFMADB V0, V2, V4, V0 FMOVD F0, ret+8(FP) RET L9: WFMADB V0, V1, V6, V0 MOVD $sinhx4ff<>+0(SB), R3 FMOVD 0(R3), F2 FMUL F2, F0 WORD $0xA72AF000 //ahi %r2,-4096 RISBGN $0, $15, $48, R2, R1 LDGR R1, F2 FMUL F2, F0 FMOVD F0, ret+8(FP) RET L16: FMOVD F0, ret+8(FP) RET LEXITTAGsinh: sinhIsInf: sinhIsZero: FMOVD F0, ret+8(FP) RET
Upload File
Create Folder