aboutsummaryrefslogtreecommitdiff
path: root/bfd/mach-o-arm.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2021-10-24 18:36:03 +1030
committerAlan Modra <amodra@gmail.com>2021-10-24 21:45:23 +1030
commite02812494254b70fec6fa432f7f668956711133b (patch)
tree93c3d1af179f189c659dd2dca287b92b6367c4b4 /bfd/mach-o-arm.c
parent3f9661f12a42583c91655bc5c5b60542bcaed4e2 (diff)
downloadgdb-e02812494254b70fec6fa432f7f668956711133b.zip
gdb-e02812494254b70fec6fa432f7f668956711133b.tar.gz
gdb-e02812494254b70fec6fa432f7f668956711133b.tar.bz2
asan: arm-darwin: buffer overflow
PR 21813 * mach-o-arm.c (bfd_mach_o_arm_canonicalize_one_reloc): Sanity check PAIR reloc in other branch of condition as was done for PR21813. Formatting. Delete debug printf.
Diffstat (limited to 'bfd/mach-o-arm.c')
-rw-r--r--bfd/mach-o-arm.c39
1 files changed, 21 insertions, 18 deletions
diff --git a/bfd/mach-o-arm.c b/bfd/mach-o-arm.c
index 094eac6..9f1a104 100644
--- a/bfd/mach-o-arm.c
+++ b/bfd/mach-o-arm.c
@@ -156,10 +156,7 @@ bfd_mach_o_arm_canonicalize_one_reloc (bfd * abfd,
bfd_mach_o_reloc_info reloc;
if (!bfd_mach_o_pre_canonicalize_one_reloc (abfd, raw, &reloc, res, syms))
- {
-fprintf (stderr, "ARm 1\n");
return false;
- }
if (reloc.r_scattered)
{
@@ -169,9 +166,9 @@ fprintf (stderr, "ARm 1\n");
/* PR 21813: Check for a corrupt PAIR reloc at the start. */
if (res == res_base)
{
- _bfd_error_handler (_("\
-malformed mach-o ARM reloc pair: reloc is first reloc"));
- return false;
+ _bfd_error_handler (_("malformed mach-o ARM reloc pair: "
+ "reloc is first reloc"));
+ return false;
}
if (reloc.r_length == 2)
{
@@ -185,8 +182,8 @@ malformed mach-o ARM reloc pair: reloc is first reloc"));
res->address = res[-1].address;
return true;
}
- _bfd_error_handler (_("\
-malformed mach-o ARM reloc pair: invalid length: %d"), reloc.r_length);
+ _bfd_error_handler (_("malformed mach-o ARM reloc pair: "
+ "invalid length: %d"), reloc.r_length);
return false;
case BFD_MACH_O_ARM_RELOC_SECTDIFF:
@@ -200,8 +197,8 @@ malformed mach-o ARM reloc pair: invalid length: %d"), reloc.r_length);
res->howto = &arm_howto_table[8];
return true;
}
- _bfd_error_handler (_("\
-malformed mach-o ARM sectdiff reloc: invalid length: %d"), reloc.r_length);
+ _bfd_error_handler (_("malformed mach-o ARM sectdiff reloc: "
+ "invalid length: %d"), reloc.r_length);
return false;
case BFD_MACH_O_ARM_RELOC_LOCAL_SECTDIFF:
@@ -215,8 +212,8 @@ malformed mach-o ARM sectdiff reloc: invalid length: %d"), reloc.r_length);
res->howto = &arm_howto_table[9];
return true;
}
- _bfd_error_handler (_("\
-malformed mach-o ARM local sectdiff reloc: invalid length: %d"),
+ _bfd_error_handler (_("malformed mach-o ARM local sectdiff reloc: "
+ "invalid length: %d"),
reloc.r_length);
return false;
@@ -230,8 +227,8 @@ malformed mach-o ARM local sectdiff reloc: invalid length: %d"),
res->howto = &arm_howto_table[14];
return true;
}
- _bfd_error_handler (_("\
-malformed mach-o ARM half sectdiff reloc: invalid length: %d"),
+ _bfd_error_handler (_("malformed mach-o ARM half sectdiff reloc: "
+ "invalid length: %d"),
reloc.r_length);
return false;
@@ -262,8 +259,8 @@ malformed mach-o ARM half sectdiff reloc: invalid length: %d"),
res->howto = &arm_howto_table[3];
return true;
default:
- _bfd_error_handler (_("\
-malformed mach-o ARM vanilla reloc: invalid length: %d (pcrel: %d)"),
+ _bfd_error_handler (_("malformed mach-o ARM vanilla reloc: "
+ "invalid length: %d (pcrel: %d)"),
reloc.r_length, reloc.r_pcrel);
return false;
}
@@ -299,6 +296,12 @@ malformed mach-o ARM vanilla reloc: invalid length: %d (pcrel: %d)"),
break;
case BFD_MACH_O_ARM_RELOC_PAIR:
+ if (res == res_base)
+ {
+ _bfd_error_handler (_("malformed mach-o ARM reloc pair: "
+ "reloc is first reloc"));
+ return false;
+ }
if (res[-1].howto == &arm_howto_table[12]
&& reloc.r_length == 0)
{
@@ -326,8 +329,8 @@ malformed mach-o ARM vanilla reloc: invalid length: %d (pcrel: %d)"),
}
}
- _bfd_error_handler (_("\
-malformed mach-o ARM reloc: unknown reloc type: %d"), reloc.r_length);
+ _bfd_error_handler (_("malformed mach-o ARM reloc: "
+ "unknown reloc type: %d"), reloc.r_length);
return false;
}