Home | History | Annotate | Line # | Download | only in test_src
sljitMain.c revision 1.4.4.1
      1  1.4.4.1  skrll /*	$NetBSD: sljitMain.c,v 1.4.4.1 2016/07/09 20:25:19 skrll Exp $	*/
      2      1.4  alnsn 
      3      1.1  alnsn /*
      4      1.1  alnsn  *    Stack-less Just-In-Time compiler
      5      1.1  alnsn  *
      6      1.1  alnsn  *    Copyright 2009-2010 Zoltan Herczeg (hzmester (at) freemail.hu). All rights reserved.
      7      1.1  alnsn  *
      8      1.1  alnsn  * Redistribution and use in source and binary forms, with or without modification, are
      9      1.1  alnsn  * permitted provided that the following conditions are met:
     10      1.1  alnsn  *
     11      1.1  alnsn  *   1. Redistributions of source code must retain the above copyright notice, this list of
     12      1.1  alnsn  *      conditions and the following disclaimer.
     13      1.1  alnsn  *
     14      1.1  alnsn  *   2. Redistributions in binary form must reproduce the above copyright notice, this list
     15      1.1  alnsn  *      of conditions and the following disclaimer in the documentation and/or other materials
     16      1.1  alnsn  *      provided with the distribution.
     17      1.1  alnsn  *
     18      1.1  alnsn  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER(S) AND CONTRIBUTORS ``AS IS'' AND ANY
     19      1.1  alnsn  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     20      1.1  alnsn  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
     21      1.1  alnsn  * SHALL THE COPYRIGHT HOLDER(S) OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
     22      1.1  alnsn  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
     23      1.1  alnsn  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
     24      1.1  alnsn  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     25      1.1  alnsn  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
     26      1.1  alnsn  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     27      1.1  alnsn  */
     28      1.1  alnsn 
     29      1.1  alnsn #include "sljitLir.h"
     30      1.1  alnsn 
     31      1.1  alnsn #include <stdio.h>
     32      1.1  alnsn #include <stdlib.h>
     33      1.1  alnsn 
     34      1.3  alnsn void sljit_test(int argc, char* argv[]);
     35      1.1  alnsn 
     36      1.2  alnsn #if 0
     37  1.4.4.1  skrll void error(const char* str)
     38      1.1  alnsn {
     39      1.1  alnsn 	printf("An error occured: %s\n", str);
     40      1.1  alnsn 	exit(-1);
     41      1.1  alnsn }
     42      1.1  alnsn 
     43      1.1  alnsn union executable_code {
     44      1.1  alnsn 	void* code;
     45      1.3  alnsn 	sljit_sw (SLJIT_CALL *func)(sljit_sw* a);
     46      1.1  alnsn };
     47      1.1  alnsn typedef union executable_code executable_code;
     48      1.1  alnsn 
     49      1.1  alnsn void devel(void)
     50      1.1  alnsn {
     51      1.1  alnsn 	executable_code code;
     52      1.1  alnsn 
     53  1.4.4.1  skrll 	struct sljit_compiler *compiler = sljit_create_compiler(NULL);
     54      1.3  alnsn 	sljit_sw buf[4];
     55      1.1  alnsn 
     56      1.1  alnsn 	if (!compiler)
     57      1.1  alnsn 		error("Not enough of memory");
     58      1.1  alnsn 	buf[0] = 5;
     59      1.1  alnsn 	buf[1] = 12;
     60      1.1  alnsn 	buf[2] = 0;
     61      1.1  alnsn 	buf[3] = 0;
     62      1.1  alnsn 
     63      1.1  alnsn #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
     64      1.1  alnsn 	sljit_compiler_verbose(compiler, stdout);
     65      1.1  alnsn #endif
     66  1.4.4.1  skrll 	sljit_emit_enter(compiler, 0, 1, 4, 5, 4, 0, 2 * sizeof(sljit_sw));
     67      1.1  alnsn 
     68      1.1  alnsn 	sljit_emit_return(compiler, SLJIT_MOV, SLJIT_RETURN_REG, 0);
     69      1.1  alnsn 
     70      1.1  alnsn 	code.code = sljit_generate_code(compiler);
     71      1.1  alnsn 	sljit_free_compiler(compiler);
     72      1.1  alnsn 
     73      1.3  alnsn 	printf("Code at: %p\n", (void*)SLJIT_FUNC_OFFSET(code.code));
     74      1.1  alnsn 
     75      1.3  alnsn 	printf("Function returned with %ld\n", (long)code.func((sljit_sw*)buf));
     76      1.1  alnsn 	printf("buf[0] = %ld\n", (long)buf[0]);
     77      1.1  alnsn 	printf("buf[1] = %ld\n", (long)buf[1]);
     78      1.1  alnsn 	printf("buf[2] = %ld\n", (long)buf[2]);
     79      1.1  alnsn 	printf("buf[3] = %ld\n", (long)buf[3]);
     80      1.1  alnsn 	sljit_free_code(code.code);
     81      1.1  alnsn }
     82      1.2  alnsn #endif
     83      1.1  alnsn 
     84      1.1  alnsn int main(int argc, char* argv[])
     85      1.1  alnsn {
     86      1.1  alnsn 	/* devel(); */
     87      1.3  alnsn 	sljit_test(argc, argv);
     88      1.1  alnsn 
     89      1.1  alnsn 	return 0;
     90      1.1  alnsn }
     91