aboutsummaryrefslogtreecommitdiff
path: root/tests/mulr_d.c
blob: 4416cd18a22a9b1ac7358cae3827a43ae9c4c03a (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
24
25
26
27
28
29
#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[2] = {
		EJIT_OPERAND_FPR(0, EJIT_TYPE(double)),
		EJIT_OPERAND_FPR(1, EJIT_TYPE(double))
	};
	struct ejit_func *f = ejit_create_func(EJIT_TYPE(double), 2, operands);

	ejit_mulr_d(f, EJIT_FPR(0), EJIT_FPR(0), EJIT_FPR(1));
	ejit_retr_d(f, EJIT_FPR(0));

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

	assert(erfd2(f,
				EJIT_ARG(-0.5f, double),
				EJIT_ARG(0.50f, double)) == -0.25f);

	assert(erfd2(f,
				EJIT_ARG(0.25f, double),
				EJIT_ARG(0.75f, double)) == 0.1875f);

	ejit_destroy_func(f);
}