diff options
author | Ken Raeburn <raeburn@cygnus> | 1997-09-15 16:43:43 +0000 |
---|---|---|
committer | Ken Raeburn <raeburn@cygnus> | 1997-09-15 16:43:43 +0000 |
commit | 2199f848c07c4d752c3ab0fd83a510157270c30f (patch) | |
tree | d64f4f2a3cd04d801cd251e36122d7e19f0a3c66 /bfd | |
parent | 00c6b5b387e79174a0ed3b5caca5c0eca4488a40 (diff) | |
download | binutils-2199f848c07c4d752c3ab0fd83a510157270c30f.zip binutils-2199f848c07c4d752c3ab0fd83a510157270c30f.tar.gz binutils-2199f848c07c4d752c3ab0fd83a510157270c30f.tar.bz2 |
merge from d30v-970225-branch
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 21 | ||||
-rw-r--r-- | bfd/bfd-in2.h | 28 | ||||
-rw-r--r-- | bfd/libbfd.h | 4 | ||||
-rw-r--r-- | bfd/reloc.c | 28 |
4 files changed, 75 insertions, 6 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 0352425..7531a36 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,24 @@ +start-sanitize-d30v +Mon Sep 15 11:27:36 1997 Ken Raeburn <raeburn@cygnus.com> + + Merged changes from Martin Hunt: + + * elf32-d30v.c (bfd_elf_d30v_reloc): Change pc-relative relocs + over 2^32 bytes to be absolute. Needed because D30V PC doesn't + necessarily wrap. + + * reloc.c, elf32-d30v.c (BFD_RELOC_D30V_9_PCREL, + BFD_RELOC_D30V_9_PCREL_R): New relocs. + + * elf32-d30v.c (bfd_elf_d30v_reloc_21): New function. + Do 15 and 21 bit pc-relative relocations. + * reloc.c (BFD_RELOC_D30V_15_PCREL_R, BFD_RELOC_D30V_21_PCREL_R): + New relocations. + + * elf32-d30v.c (bfd_elf_d30v_reloc): Addend needs to be + added to the relocation, not or'd. + +end-sanitize-d30v Wed Sep 10 15:17:25 1997 Nick Clifton <nickc@cygnus.com> * elf32-v850.c (v850_elf_reloc): Remove spurious error message. diff --git a/bfd/bfd-in2.h b/bfd/bfd-in2.h index daaeef0..4d0ac33 100644 --- a/bfd/bfd-in2.h +++ b/bfd/bfd-in2.h @@ -1885,16 +1885,30 @@ assumed to be 0. */ This is a 6-bit absolute reloc. */ BFD_RELOC_D30V_6, -/* Mitsubishi D30V relocs. -This is a 12-bit absolute reloc with the +/* This is a 6-bit pc-relative reloc with +the right 3 bits assumed to be 0. */ + BFD_RELOC_D30V_9_PCREL, + +/* This is a 6-bit pc-relative reloc with +the right 3 bits assumed to be 0. Same +as the previous reloc but on the right side +of the container. */ + BFD_RELOC_D30V_9_PCREL_R, + +/* This is a 12-bit absolute reloc with the right 3 bitsassumed to be 0. */ BFD_RELOC_D30V_15, -/* Mitsubishi D30V relocs. -This is a 12-bit pc-relative reloc with +/* This is a 12-bit pc-relative reloc with the right 3 bits assumed to be 0. */ BFD_RELOC_D30V_15_PCREL, +/* This is a 12-bit pc-relative reloc with +the right 3 bits assumed to be 0. Same +as the previous reloc but on the right side +of the container. */ + BFD_RELOC_D30V_15_PCREL_R, + /* This is an 18-bit absolute reloc with the right 3 bits assumed to be 0. */ BFD_RELOC_D30V_21, @@ -1903,6 +1917,12 @@ the right 3 bits assumed to be 0. */ the right 3 bits assumed to be 0. */ BFD_RELOC_D30V_21_PCREL, +/* This is an 18-bit pc-relative reloc with +the right 3 bits assumed to be 0. Same +as the previous reloc but on the right side +of the container. */ + BFD_RELOC_D30V_21_PCREL_R, + /* This is a 32-bit absolute reloc. */ BFD_RELOC_D30V_32, diff --git a/bfd/libbfd.h b/bfd/libbfd.h index 9252032..c6f9ccc 100644 --- a/bfd/libbfd.h +++ b/bfd/libbfd.h @@ -752,10 +752,14 @@ static const char *const bfd_reloc_code_real_names[] = { "@@uninitialized@@", /* start-sanitize-d30v */ "BFD_RELOC_D30V_6", + "BFD_RELOC_D30V_9_PCREL", + "BFD_RELOC_D30V_9_PCREL_R", "BFD_RELOC_D30V_15", "BFD_RELOC_D30V_15_PCREL", + "BFD_RELOC_D30V_15_PCREL_R", "BFD_RELOC_D30V_21", "BFD_RELOC_D30V_21_PCREL", + "BFD_RELOC_D30V_21_PCREL_R", "BFD_RELOC_D30V_32", "BFD_RELOC_D30V_32_PCREL", /* end-sanitize-d30v */ diff --git a/bfd/reloc.c b/bfd/reloc.c index 1566fa6..e878ce3 100644 --- a/bfd/reloc.c +++ b/bfd/reloc.c @@ -2280,18 +2280,35 @@ ENUMDOC Mitsubishi D30V relocs. This is a 6-bit absolute reloc. ENUM + BFD_RELOC_D30V_9_PCREL +ENUMDOC + This is a 6-bit pc-relative reloc with + the right 3 bits assumed to be 0. +ENUM + BFD_RELOC_D30V_9_PCREL_R +ENUMDOC + This is a 6-bit pc-relative reloc with + the right 3 bits assumed to be 0. Same + as the previous reloc but on the right side + of the container. +ENUM BFD_RELOC_D30V_15 ENUMDOC - Mitsubishi D30V relocs. This is a 12-bit absolute reloc with the right 3 bitsassumed to be 0. ENUM BFD_RELOC_D30V_15_PCREL ENUMDOC - Mitsubishi D30V relocs. This is a 12-bit pc-relative reloc with the right 3 bits assumed to be 0. ENUM + BFD_RELOC_D30V_15_PCREL_R +ENUMDOC + This is a 12-bit pc-relative reloc with + the right 3 bits assumed to be 0. Same + as the previous reloc but on the right side + of the container. +ENUM BFD_RELOC_D30V_21 ENUMDOC This is an 18-bit absolute reloc with @@ -2302,6 +2319,13 @@ ENUMDOC This is an 18-bit pc-relative reloc with the right 3 bits assumed to be 0. ENUM + BFD_RELOC_D30V_21_PCREL_R +ENUMDOC + This is an 18-bit pc-relative reloc with + the right 3 bits assumed to be 0. Same + as the previous reloc but on the right side + of the container. +ENUM BFD_RELOC_D30V_32 ENUMDOC This is a 32-bit absolute reloc. |