1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-05 15:10:27 +02:00
guile/tests/sete.c
Paolo Bonzini d0d493b417 improve set* encoding for i386, add testcase
2007-08-12  Paolo Bonzini  <bonzini@gnu.org>

	* lightning/i386/core-i386.h: Improve encoding of set* instructions.
	* lightning/i386/core-64.h: Fix jit_bra_l.
	* tests/sete.c: New.
	* tests/sete.ok: New.

git-archimport-id: bonzini@gnu.org--2004b/lightning--stable--1.2--patch-56
git-archimport-id: bonzini@gnu.org--2004b/lightning--stable--1.2--patch-60
2008-01-09 15:50:14 +01:00

67 lines
2.1 KiB
C

/******************************** -*- C -*- ****************************
*
* Sample call for using arguments in GNU lightning
*
***********************************************************************/
/***********************************************************************
*
* Copyright 2000 Free Software Foundation, Inc.
* Written by Paolo Bonzini.
*
* This file is part of GNU lightning.
*
* GNU lightning is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 3, or (at your option)
* any later version.
*
* GNU lightning is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with GNU lightning; see the file COPYING.LESSER; if not, write to the
* Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301, USA.
*
***********************************************************************/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <stdio.h>
#include "lightning.h"
static char codeBuffer[1024];
typedef int (*pifii)(int, int); /* Pointer to Int Function of Int, Int */
int main()
{
pifii myFunction= (pifii) (jit_set_ip(codeBuffer).iptr);
int arg; /* offset of the argument */
jit_leaf(2);
arg = jit_arg_i();
jit_getarg_i(JIT_R0, arg);
arg = jit_arg_i();
jit_getarg_i(JIT_R1, arg);
jit_eqr_i(JIT_V0, JIT_R0, JIT_R1);
jit_movr_i(JIT_RET, JIT_V0);
jit_ret();
jit_flush_code(codeBuffer, jit_get_ip().ptr);
/* call the generated code, passing its size as argument */
#ifdef LIGHTNING_DISASSEMBLE
disassemble(stderr, codeBuffer, jit_get_ip().ptr);
#endif
#ifndef LIGHTNING_CROSS
printf("%d == %d? %s\n", 5, 4, myFunction(5, 4) ? "yes" : "no");
printf("%d == %d? %s\n", 5, 5, myFunction(5, 5) ? "yes" : "no");
#endif
return 0;
}