root/lib/libm/arch/amd64/e_asin.S
/*      $OpenBSD: e_asin.S,v 1.5 2018/07/03 22:43:34 mortimer Exp $ */
/*
 * Written by J.T. Conklin <jtc@NetBSD.org>.
 * Public domain.
 */

#include <machine/asm.h>

#include "abi.h"

/* asin = atan (x / sqrt(1 - x^2)) */
ENTRY(asin)
        RETGUARD_SETUP(asin, r11)
        XMM_ONE_ARG_DOUBLE_PROLOGUE
        fldl    ARG_DOUBLE_ONE          /* x */
        fld     %st(0)
        fmul    %st(0)                  /* x^2 */
        fld1
        fsubp                           /* 1 - x^2 */
        fsqrt                           /* sqrt (1 - x^2) */
        fpatan
        XMM_DOUBLE_EPILOGUE
        RETGUARD_CHECK(asin, r11)
        ret
END_STD(asin)