RPA Toolkit
72cf1a96314419da2ee1c6b065f0547f506c51b9
[rpatk.git] / testrpa2 / rpavm-matchchr.c
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <sys/types.h>
4 #include <sys/stat.h>
5 #include <sys/types.h>
6 #include <fcntl.h>
7 #include <unistd.h>
8 #include <sys/mman.h>
9 #include "rmem.h"
10 #include "rpacompiler.h"
11 #include "rpastat.h"
12 #include "common.h"
13
14
15 void code_rpa_matchchr(rpa_compiler_t *co, rpastat_t *stat)
16 {
17         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
18         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_NAN, DA, XX, XX, 'a'));
19         VMTEST_REG(co->cg, 0, 1, "RPA_MATCHCHR_NAN 'a'");
20         VMTEST_STATUS(co->cg, 0, "RPA_MATCHCHR_NAN STATUS");
21
22         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
23         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_NAN, DA, XX, XX, 'b'));
24         VMTEST_REG(co->cg, 0, -1, "RPA_MATCHCHR_NAN 'b'");
25         VMTEST_STATUS(co->cg, RVM_STATUS_N, "RPA_MATCHCHR_NAN STATUS");
26
27         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
28         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_OPT, DA, XX, XX, 'a'));
29         VMTEST_REG(co->cg, 0, 1, "RPA_MATCHCHR_OPT 'a'");
30         VMTEST_STATUS(co->cg, 0, "RPA_MATCHCHR_OPT STATUS");
31
32         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
33         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_OPT, DA, XX, XX, 'b'));
34         VMTEST_REG(co->cg, 0, 0, "RPA_MATCHCHR_OPT 'b'");
35         VMTEST_STATUS(co->cg, RVM_STATUS_Z, "RPA_MATCHCHR_OPT STATUS");
36
37
38         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
39         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_MOP, DA, XX, XX, 'a'));
40         VMTEST_REG(co->cg, 0, 3, "RPA_MATCHCHR_MOP 'a'");
41         VMTEST_STATUS(co->cg, 0, "RPA_MATCHCHR_MOP STATUS");
42
43         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
44         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_MOP, DA, XX, XX, 'b'));
45         VMTEST_REG(co->cg, 0, 0, "RPA_MATCHCHR_MOP 'b'");
46         VMTEST_STATUS(co->cg, RVM_STATUS_Z, "RPA_MATCHCHR_MOP STATUS");
47
48         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
49         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_MUL, DA, XX, XX, 'a'));
50         VMTEST_REG(co->cg, 0, 3, "RPA_MATCHCHR_MUL 'a'");
51         VMTEST_STATUS(co->cg, 0, "RPA_MATCHCHR_MUL STATUS");
52
53         rvm_codegen_addins(co->cg, rvm_asm(RVM_MOV, R_TOP, DA, XX, 0));
54         rvm_codegen_addins(co->cg, rvm_asm(RPA_MATCHCHR_MUL, DA, XX, XX, 'b'));
55         VMTEST_REG(co->cg, 0, -1, "RPA_MATCHCHR_MUL 'b'");
56         VMTEST_STATUS(co->cg, RVM_STATUS_N, "RPA_MATCHCHR_MUL STATUS");
57
58 }
59
60
61 int main(int argc, char *argv[])
62 {
63         rpa_compiler_t *co;
64         rpastat_t *stat;
65         ruint mainoff;
66         char teststr[] = "aaaaa";
67
68         co = rpa_compiler_create();
69         stat = rpa_stat_create(NULL, 4096);
70         rvm_cpu_addswitable(stat->cpu, "common_table", common_calltable);
71
72         rpa_stat_init(stat, teststr, teststr, teststr+3);
73
74         mainoff = rvm_codegen_addins(co->cg, rvm_asml(RVM_NOP, XX, XX, XX, -1));
75         rvm_codegen_addins(co->cg, rvm_asml(RVM_MOV, R_TOP, DA, XX, -1));
76         rvm_codegen_addins(co->cg, rvm_asml(RVM_MOV, FP, DA, XX, 0));
77         rvm_codegen_addins(co->cg, rvm_asml(RVM_MOV, SP, DA, XX, 0));
78
79
80         rvm_codegen_addins(co->cg, rvm_asm(RPA_SHIFT, XX, XX, XX, 0));
81         code_rpa_matchchr(co, stat);
82         rvm_codegen_addins(co->cg, rvm_asm(RVM_NOP, XX, XX, XX, 0xabc));
83         rvm_codegen_addins(co->cg, rvm_asm(RVM_EXT, XX, XX, XX, 0));
84
85         rvm_cpu_exec(stat->cpu, rvm_codegen_getcode(co->cg, 0), mainoff);
86
87         rpa_stat_destroy(stat);
88         rpa_compiler_destroy(co);
89
90
91         r_printf("Max alloc mem: %ld\n", r_debug_get_maxmem());
92         r_printf("Leaked mem: %ld\n", r_debug_get_allocmem());
93         return 0;
94 }