# HG changeset patch # User lost # Date 1230866853 0 # Node ID 37aec845aef34ebf938d38a31efba9e5fc210d81 # Parent c0ff62e5ad3915c73db70542fdc30b2a588384ce Added relative addressing handler diff -r c0ff62e5ad39 -r 37aec845aef3 src/Makefile.am --- a/src/Makefile.am Fri Jan 02 03:17:26 2009 +0000 +++ b/src/Makefile.am Fri Jan 02 03:27:33 2009 +0000 @@ -1,3 +1,3 @@ bin_PROGRAMS = lwasm -lwasm_SOURCES = main.c expr.c pass1.c pass2.c util.c instab.c parse.c lwasm.c insn_inh.c insn_rtor.c insn_rlist.c +lwasm_SOURCES = main.c expr.c pass1.c pass2.c util.c instab.c parse.c lwasm.c insn_inh.c insn_rtor.c insn_rlist.c insn_rel.c EXTRA_DIST = instab.h lwasm.h expr.h util.h diff -r c0ff62e5ad39 -r 37aec845aef3 src/insn_rel.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/insn_rel.c Fri Jan 02 03:27:33 2009 +0000 @@ -0,0 +1,80 @@ +/* +insn_rel.c +Copyright © 2008 William Astle + +This file is part of LWASM. + +LWASM is free software: you can redistribute it and/or modify it under the +terms of the GNU General Public License as published by the Free Software +Foundation, either version 3 of the License, or (at your option) any later +version. + +This program 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 General Public License for +more details. + +You should have received a copy of the GNU General Public License along with +this program. If not, see . +*/ + +/* +for handling relative mode instructions +*/ + +#define __insn_inh_c_seen__ + +#include + +#include "expr.h" +#include "lwasm.h" +#include "instab.h" + +OPFUNC(insn_rel8) +{ + lwasm_expr_stack_t *s; + int v; + + lwasm_emitop(as, l, instab[opnum].ops[0]); + + s = lwasm_expr_eval(*p, NULL); + if (!s) + { + register_error(as, l, 1, "Bad operand"); + lwasm_emitop(as, l, 0); + return; + } + if (lwasm_expr_is_constant(s)) + register_error(as, l, 2, "Incomplete reference"); + v = lwasm_expr_get_value(s); + v -= as -> addr + 1; + if (v < -128 || v > 127) + register_error(as, l, 2, "Byte overflow"); + lwasm_emit(as, l, v & 0xff); + + lwasm_expr_stack_free(s); +} + +OPFUNC(insn_rel16) +{ + lwasm_expr_stack_t *s; + int v; + + lwasm_emitop(as, l, instab[opnum].ops[0]); + + s = lwasm_expr_eval(*p, NULL); + if (!s) + { + register_error(as, l, 1, "Bad operand"); + lwasm_emitop(as, l, 0); + return; + } + if (lwasm_expr_is_constant(s)) + register_error(as, l, 2, "Incomplete reference"); + v = lwasm_expr_get_value(s); + v -= as -> addr + 2; + lwasm_emit(as, l, (v >> 8) & 0xff); + lwasm_emit(as, l, v & 0xff); + + lwasm_expr_stack_free(s); +}