ld/testsuite/

2076-02-02  H.J. Lu  <hongjiu.lu@intel.com>

	* ld-i386/pcrel16.d: Updated.
	* ld-x86-64/pcrel16.d: Likewise.

opcodes/

2076-02-02  H.J. Lu  <hongjiu.lu@intel.com>

	* i386-dis.c (OP_J): Mask to 16bit only if there is a data16
	prefix.
This commit is contained in:
H.J. Lu 2007-02-03 00:46:22 +00:00
parent 60242db2b7
commit 206717e8e5
5 changed files with 16 additions and 3 deletions

View File

@ -1,3 +1,8 @@
2076-02-02 H.J. Lu <hongjiu.lu@intel.com>
* ld-i386/pcrel16.d: Updated.
* ld-x86-64/pcrel16.d: Likewise.
2007-02-01 Alan Modra <amodra@bigpond.net.au>
* ld-scripts/default-script.exp: Add "--local-store 0:0" to

View File

@ -12,4 +12,4 @@ Disassembly of section .text:
420: cd 42[ ]+int \$0x42
422: ca 02 00[ ]+lret \$0x2
...
f065: e9 b8 13[ ]+jmp 420 <_start\+0x420>
f065: e9 b8 13[ ]+jmp 10420 <__bss_start\+0x3b8>

View File

@ -12,4 +12,4 @@ Disassembly of section .text:
420: cd 42[ ]+int \$0x42
422: ca 02 00[ ]+lret \$0x2
...
f065: e9 b8 13[ ]+jmp 420 <_start\+0x420>
f065: e9 b8 13[ ]+jmp 10420 <_start\+0x10420>

View File

@ -1,3 +1,8 @@
2076-02-02 H.J. Lu <hongjiu.lu@intel.com>
* i386-dis.c (OP_J): Mask to 16bit only if there is a data16
prefix.
2007-02-02 H.J. Lu <hongjiu.lu@intel.com>
* avr-dis.c (avr_operand): Correct PR number in comment.

View File

@ -4916,10 +4916,13 @@ OP_J (int bytemode, int sizeflag)
else
{
disp = get16 ();
if ((disp & 0x8000) != 0)
disp -= 0x10000;
/* For some reason, a data16 prefix on a jump instruction
means that the pc is masked to 16 bits after the
displacement is added! */
mask = 0xffff;
if ((prefixes & PREFIX_DATA))
mask = 0xffff;
}
used_prefixes |= (prefixes & PREFIX_DATA);
break;