Blame sysdeps/x86_64/fpu/svml_d_trig_data.S

Packit 6c4009
/* Data for vectorized sin, cos, sincos.
Packit 6c4009
   Copyright (C) 2014-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include "svml_d_trig_data.h"
Packit 6c4009
Packit 6c4009
	.section .rodata, "a"
Packit 6c4009
	.align 64
Packit 6c4009
Packit 6c4009
/* Data table for vector implementations.
Packit 6c4009
   The table may contain polynomial, reduction, lookup
Packit 6c4009
   coefficients and other constants obtained through different
Packit 6c4009
   methods of research and experimental work.
Packit 6c4009
 */
Packit 6c4009
	.globl __svml_d_trig_data
Packit 6c4009
__svml_d_trig_data:
Packit 6c4009
Packit 6c4009
/* General purpose constants:
Packit 6c4009
   absolute value mask
Packit 6c4009
 */
Packit 6c4009
double_vector __dAbsMask 0x7fffffffffffffff
Packit 6c4009
Packit 6c4009
/* working range threshold */
Packit 6c4009
double_vector __dRangeVal 0x4160000000000000
Packit 6c4009
Packit 6c4009
/* working range threshold */
Packit 6c4009
double_vector __dRangeVal_sin 0x4170000000000000
Packit 6c4009
Packit 6c4009
/* PI/2 */
Packit 6c4009
double_vector __dHalfPI 0x3ff921fb54442d18
Packit 6c4009
Packit 6c4009
/* 1/PI */
Packit 6c4009
double_vector __dInvPI 0x3fd45f306dc9c883
Packit 6c4009
Packit 6c4009
/* right-shifter constant */
Packit 6c4009
double_vector __dRShifter 0x4338000000000000
Packit 6c4009
Packit 6c4009
/* 0.0 */
Packit 6c4009
double_vector __dZero 0x0000000000000000
Packit 6c4009
Packit 6c4009
/* -0.0 */
Packit 6c4009
double_vector __lNZero 0x8000000000000000
Packit 6c4009
Packit 6c4009
/* 0.5 */
Packit 6c4009
double_vector __dOneHalf 0x3fe0000000000000
Packit 6c4009
Packit 6c4009
/* Range reduction PI-based constants:
Packit 6c4009
   PI high part
Packit 6c4009
 */
Packit 6c4009
double_vector __dPI1 0x400921fb40000000
Packit 6c4009
Packit 6c4009
/* PI mid  part 1 */
Packit 6c4009
double_vector __dPI2 0x3e84442d00000000
Packit 6c4009
Packit 6c4009
/* PI mid  part 2 */
Packit 6c4009
double_vector __dPI3 0x3d08469880000000
Packit 6c4009
Packit 6c4009
/* PI low  part */
Packit 6c4009
double_vector __dPI4 0x3b88cc51701b839a
Packit 6c4009
Packit 6c4009
/* Range reduction PI-based constants if FMA available:
Packit 6c4009
   PI high part (FMA available)
Packit 6c4009
 */
Packit 6c4009
double_vector __dPI1_FMA 0x400921fb54442d18
Packit 6c4009
Packit 6c4009
/* PI mid part  (FMA available) */
Packit 6c4009
double_vector __dPI2_FMA 0x3ca1a62633145c06
Packit 6c4009
Packit 6c4009
/* PI low part  (FMA available) */
Packit 6c4009
double_vector __dPI3_FMA 0x395c1cd129024e09
Packit 6c4009
Packit 6c4009
/* HalfPI1 */
Packit 6c4009
double_vector __dHalfPI1 0x3ff921fc00000000
Packit 6c4009
Packit 6c4009
/* HalfPI2 */
Packit 6c4009
double_vector __dHalfPI2 0xbea5777a00000000
Packit 6c4009
Packit 6c4009
/* HalfPI3 */
Packit 6c4009
double_vector __dHalfPI3 0xbd473dcc00000000
Packit 6c4009
Packit 6c4009
/* HalfPI4 */
Packit 6c4009
double_vector __dHalfPI4 0x3bf898cc51701b84
Packit 6c4009
Packit 6c4009
/* Polynomial coefficients (relative error 2^(-52.115)): */
Packit 6c4009
double_vector __dC1 0xbfc55555555554a7
Packit 6c4009
double_vector __dC2 0x3f8111111110a4a8
Packit 6c4009
double_vector __dC3 0xbf2a01a019a5b86d
Packit 6c4009
double_vector __dC4 0x3ec71de38030fea0
Packit 6c4009
double_vector __dC5 0xbe5ae63546002231
Packit 6c4009
double_vector __dC6 0x3de60e6857a2f220
Packit 6c4009
double_vector __dC7 0xbd69f0d60811aac8
Packit 6c4009
Packit 6c4009
/* Polynomial coefficients (relative error 2^(-52.115)): */
Packit 6c4009
double_vector __dC1_sin 0xbfc55555555554a8
Packit 6c4009
double_vector __dC2_sin 0x3f8111111110a573
Packit 6c4009
double_vector __dC3_sin 0xbf2a01a019a659dd
Packit 6c4009
double_vector __dC4_sin 0x3ec71de3806add1a
Packit 6c4009
double_vector __dC5_sin 0xbe5ae6355aaa4a53
Packit 6c4009
double_vector __dC6_sin 0x3de60e6bee01d83e
Packit 6c4009
double_vector __dC7_sin 0xbd69f1517e9f65f0
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
   Additional constants:
Packit 6c4009
   absolute value mask
Packit 6c4009
 */
Packit 6c4009
/* right-shifer for low accuracy version */
Packit 6c4009
double_vector __dRShifter_la 0x4330000000000000
Packit 6c4009
Packit 6c4009
/* right-shifer-1.0 for low accuracy version */
Packit 6c4009
double_vector __dRShifterm5_la 0x432fffffffffffff
Packit 6c4009
Packit 6c4009
/* right-shifer with low mask for low accuracy version */
Packit 6c4009
double_vector __dRXmax_la 0x43300000007ffffe
Packit 6c4009
Packit 6c4009
	.type	__svml_d_trig_data,@object
Packit 6c4009
	.size	__svml_d_trig_data,.-__svml_d_trig_data