[GOLD] PowerPC64 relocation overflow for -Os register save/restore funcs
authorAlan Modra <amodra@gmail.com>
Wed, 18 Aug 2021 03:13:46 +0000 (12:43 +0930)
committerAlan Modra <amodra@gmail.com>
Wed, 18 Aug 2021 04:06:57 +0000 (13:36 +0930)
Fixes a silly mistake in calculating the address of -Os out-of-line
register save/restore function copies.  Copies of these linker defined
functions are added to stub sections when the original (in
target->savres_section) can't be reached.

* powerpc.cc (Target_powerpc::Relocate::relocate): Correct address
calculation of out-of-line save/restore function copies.

gold/powerpc.cc

index 6b12ed8..11b9869 100644 (file)
@@ -11201,6 +11201,8 @@ Target_powerpc<size, big_endian>::Relocate::relocate(
                {
                  if (ent->save_res_)
                    value = (value - target->savres_section()->address()
+                            + stub_table->stub_address()
+                            + stub_table->plt_size()
                             + stub_table->branch_size());
                  else
                    {