1 /* $OpenBSD: fpu_q.h,v 1.3 2016/05/08 18:41:17 guenther Exp $ */ 2 3 /* 4 * Copyright (c) 2003 Jason L. Wright (jason@thought.net) 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 19 * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, 20 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 22 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 24 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 25 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 * POSSIBILITY OF SUCH DAMAGE. 27 */ 28 29 double _Q_qtod(long double); 30 int _Q_qtoi(long double); 31 float _Q_qtos(long double); 32 unsigned int _Q_qtou(long double); 33 long double _Q_neg(long double); 34 long double _Q_sqrt(long double); 35 long double _Q_dtoq(double); 36 long double _Q_stoq(float); 37 long double _Q_itoq(int); 38 long double _Q_utoq(unsigned int); 39 long double _Q_mul(long double, long double); 40 long double _Q_div(long double, long double); 41 long double _Q_sub(long double, long double); 42 long double _Q_add(long double, long double); 43 int _Q_feq(long double, long double); 44 int _Q_fne(long double, long double); 45 int _Q_fge(long double, long double); 46 int _Q_fgt(long double, long double); 47 int _Q_flt(long double, long double); 48 int _Q_fle(long double, long double); 49 50 void _Qp_add(long double *, long double *, long double *); 51 void _Qp_div(long double *, long double *, long double *); 52 void _Qp_mul(long double *, long double *, long double *); 53 void _Qp_sub(long double *, long double *, void *); 54 void _Qp_dtoq(long double *, double); 55 void _Qp_itoq(long double *, int); 56 void _Qp_stoq(long double *, float); 57 void _Qp_xtoq(long double *, long); 58 void _Qp_uitoq(long double *, u_int); 59 void _Qp_uxtoq(long double *, u_long); 60 double _Qp_qtod(long double *); 61 long _Qp_qtox(long double *); 62 u_long _Qp_qtoux(long double *); 63 u_int _Qp_qtoui(long double *); 64 int _Qp_qtoi(long double *); 65 float _Qp_qtos(long double *); 66 int _Qp_feq(long double *, long double *); 67 int _Qp_fge(long double *, long double *); 68 int _Qp_fle(long double *, long double *); 69 int _Qp_fgt(long double *, long double *); 70 int _Qp_flt(long double *, long double *); 71 int _Qp_fne(long double *, long double *); 72 void _Qp_sqrt(long double *, long double *); 73 74 PROTO_NORMAL(_Qp_add); 75 PROTO_NORMAL(_Qp_div); 76 PROTO_NORMAL(_Qp_dtoq); 77 PROTO_NORMAL(_Qp_feq); 78 PROTO_NORMAL(_Qp_fge); 79 PROTO_NORMAL(_Qp_fgt); 80 PROTO_NORMAL(_Qp_fle); 81 PROTO_NORMAL(_Qp_flt); 82 PROTO_NORMAL(_Qp_fne); 83 PROTO_NORMAL(_Qp_itoq); 84 PROTO_NORMAL(_Qp_mul); 85 PROTO_NORMAL(_Qp_qtod); 86 PROTO_NORMAL(_Qp_qtoi); 87 PROTO_NORMAL(_Qp_qtos); 88 PROTO_NORMAL(_Qp_qtoui); 89 PROTO_NORMAL(_Qp_sqrt); 90 PROTO_NORMAL(_Qp_stoq); 91 PROTO_NORMAL(_Qp_sub); 92 PROTO_NORMAL(_Qp_uitoq); 93