diff lwasm/insn_indexed.c @ 481:62720ac9e28d

Exclude extended indirect from operandsizewarning pragma Constant indirect addressing is only available in "extended" variety (16 bits) so make sure no warning appears when plain extended indirect addressing is used.
author William Astle <lost@l-w.ca>
date Wed, 12 Dec 2018 21:18:20 -0700
parents 2c1c5dd84024
children
line wrap: on
line diff
--- a/lwasm/insn_indexed.c	Wed Dec 12 21:17:21 2018 -0700
+++ b/lwasm/insn_indexed.c	Wed Dec 12 21:18:20 2018 -0700
@@ -800,7 +800,8 @@
 			lwasm_register_error(as, l, E_EXPRESSION_NOT_RESOLVED);
 		}
 	}
-	else if (l -> lint == 2 && CURPRAGMA(l, PRAGMA_OPERANDSIZE) && (l -> pb != 0xAF && l -> pb != 0xB0))
+	// note that extended indirect (post byte 0x9f) can only be 16 bits
+	else if (l -> lint == 2 && CURPRAGMA(l, PRAGMA_OPERANDSIZE) && (l -> pb != 0xAF && l -> pb != 0xB0 && l -> pb != 0x9f))
 	{
 		int offs;
 		e = lwasm_fetch_expr(l, 0);