From 7a705315596cf5effe01de8c3ac2535687c5663d Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Mon, 13 Jul 2020 10:18:39 -0700 Subject: x86: Remove 32-bit sign extension in offset_in_range When encoding a 32-bit offset, there is no need to sign-extend it to 64 bits since only the lower 32 bits are used. * config/tc-i386.c (offset_in_range): Remove 32-bit sign extension. --- gas/config/tc-i386.c | 8 -------- 1 file changed, 8 deletions(-) (limited to 'gas/config') diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c index 18f685c..192c5e1 100644 --- a/gas/config/tc-i386.c +++ b/gas/config/tc-i386.c @@ -2539,14 +2539,6 @@ offset_in_range (offsetT val, int size) default: abort (); } -#ifdef BFD64 - /* If BFD64, sign extend val for 32bit address mode. */ - if (flag_code != CODE_64BIT - || i.prefix[ADDR_PREFIX]) - if ((val & ~(((addressT) 2 << 31) - 1)) == 0) - val = (val ^ ((addressT) 1 << 31)) - ((addressT) 1 << 31); -#endif - if ((val & ~mask) != 0 && (val & ~mask) != ~mask) { char buf1[40], buf2[40]; -- cgit v1.1