aboutsummaryrefslogtreecommitdiff
path: root/tests/sqrtr_d.c
blob: 06e78946b69a1d1f96c77e18d170bd24d8df8ac2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <ejit/ejit.h>
#include <assert.h>
#include "do_jit.h"

int main(int argc, char *argv[])
{
        (void)argv;
        bool do_jit = argc > 1;
        struct ejit_operand operands[1] = {
                EJIT_OPERAND_FPR(0, EJIT_TYPE(double)),
        };
        struct ejit_func *f = ejit_create_func(EJIT_TYPE(double), 1, operands);

        ejit_sqrtr_d(f, EJIT_FPR(0), EJIT_FPR(0));
        ejit_retr_d(f, EJIT_FPR(0));

        ejit_select_compile_func(f, 0, 1, EJIT_USE64(double), do_jit, true);

        assert(erfd1(f, EJIT_ARG( 0.0, double)) == 0.0);
        assert(erfd1(f, EJIT_ARG( 4.0, double)) == 2.0);
        assert(erfd1(f, EJIT_ARG(-4.0, double))
                        != erfd1(f, EJIT_ARG(-4.0, double))); // nan
}