summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--assemble.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/assemble.c b/assemble.c
index 4ff9e25..9184800 100644
--- a/assemble.c
+++ b/assemble.c
@@ -2426,6 +2426,12 @@ static enum ea_type process_ea(operand *input, ea *output, int bits,
input->type |= MEMORY;
}
+ if (bits == 64 &&
+ !(IP_REL & ~input->type) && (eaflags & EAF_MIB)) {
+ nasm_error(ERR_NONFATAL, "RIP-relative addressing is prohibited for mib.");
+ return -1;
+ }
+
if (eaflags & EAF_BYTEOFFS ||
(eaflags & EAF_WORDOFFS &&
input->disp_size != (addrbits != 16 ? 32 : 16))) {