aboutsummaryrefslogtreecommitdiff
path: root/tests/mulr_f.c
blob: 44d60305e6cfd0ac6d4a201e47e3defff83151ae (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
#include <ejit/ejit.h>
#include <assert.h>
#include "do_jit.h"

int main()
{
	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_f(f, EJIT_FPR(0), EJIT_FPR(0), EJIT_FPR(1));
	ejit_retr_f(f, EJIT_FPR(0));

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

	assert(erff2(f, EJIT_ARG(-0.5f, double),
	             EJIT_ARG(0.50f, double)) == -0.25f);
	assert(erff2(f, EJIT_ARG(0.25f, double),
	             EJIT_ARG(0.75f, double)) == 0.1875f);

	ejit_destroy_func(f);
}