X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?p=rmac;a=blobdiff_plain;f=riscasm.c;h=3092e6e7017d4c0e0a5145baf33d3ffd2d09663a;hp=82caf808d463e07d6b4cbbce9ce7076c2b6d7ae7;hb=4cfac2b5cb4bfd58deb66f93fdc0815d6b1bef0f;hpb=4205233c8397c581b4d27ab36ab81ec896ef3dd0 diff --git a/riscasm.c b/riscasm.c index 82caf80..3092e6e 100644 --- a/riscasm.c +++ b/riscasm.c @@ -229,8 +229,8 @@ int GenerateRISCCode(int state) int indexed; // Indexed register flag uint64_t eval; // Expression value - uint16_t eattr; // Expression attributes - SYM * esym; // External symbol involved in expr. + uint16_t eattr; // Expression attributes + SYM * esym = NULL; // External symbol involved in expr. TOKEN r_expr[EXPRSIZE]; // Expression token list // Get opcode parameter and type @@ -325,8 +325,14 @@ int GenerateRISCCode(int state) } else { + if (esym && (esym->sattre & EQUATEDREG)) + return error("equated register seen for immediate value"); + + if (eattr & RISCREG) + return error("register seen for immediate value"); + if (((int)eval < reg1) || ((int)eval > reg2)) - return error("constant out of range (%d to %d", reg1, reg2); + return error("constant out of range (%d to %d)", reg1, reg2); if (parm & SUB32) reg1 = 32 - (int)eval;