Blame SOURCES/dyninst-11.0.0-aarch64.patch

51da26
rhbz1993578
51da26
51da26
commit 874a73ea4 (HEAD -> master, upstream/master)
51da26
Author: Stan Cox <scox@redhat.com>
51da26
Date:   Mon Nov 1 14:24:07 2021 -0400
51da26
51da26
    Don't overflow aarch64 float register vector when setting used regs. (#1127)
51da26
    
51da26
    Do not include the subtype when setting a float register as a used register if the registerSlot vector would be exceeded, e.g. for a value like 0x400 (Q_REG/register 0).
51da26
51da26
--- dyninst-11.0.0/dyninstAPI/src/inst-aarch64.C.orig
51da26
+++ dyninst-11.0.0/dyninstAPI/src/inst-aarch64.C
51da26
@@ -551,8 +551,13 @@ bool EmitterAARCH64::clobberAllFuncCall(registerSpace *rs,
51da26
             rs->GPRs()[*itr]->beenUsed = true;
51da26
 
51da26
         std::set<Register> *fpRegs = callee->ifunc()->usedFPRs();
51da26
-        for(std::set<Register>::iterator itr = fpRegs->begin(); itr != fpRegs->end(); itr++)
51da26
-            rs->FPRs()[*itr]->beenUsed = true;
51da26
+        for(std::set<Register>::iterator itr = fpRegs->begin(); itr != fpRegs->end(); itr++) {
51da26
+            if (*itr <= rs->FPRs().size())
51da26
+              rs->FPRs()[*itr]->beenUsed = true;
51da26
+            else
51da26
+              // parse_func::calcUsedRegs includes the subtype; we only want the regno
51da26
+              rs->FPRs()[*itr & 0xff]->beenUsed = true;
51da26
+        }
51da26
     } else {
51da26
         for(int idx = 0; idx < rs->numGPRs(); idx++)
51da26
             rs->GPRs()[idx]->beenUsed = true;
51da26
commit b2c892f55
51da26
Author: Stan Cox <scox@redhat.com>
51da26
Date:   Tue Oct 26 17:43:14 2021 -0400
51da26
51da26
    Load callee's address when the callee and caller are in the same module (#1056)
51da26
    
51da26
    If the callee and caller are in the same module and pic is not
51da26
    required then the callee's address can be loaded directly without
51da26
    using a relocation.
51da26
51da26
--- dyninst-11.0.0/dyninstAPI/src/inst-aarch64.C.orig
51da26
+++ dyninst-11.0.0/dyninstAPI/src/inst-aarch64.C
51da26
@@ -651,12 +651,14 @@ Register EmitterAARCH64::emitCall(opCode op,
51da26
 
51da26
     assert(gen.rs());
51da26
 
51da26
-    //Address of function to call in scratch register
51da26
+    // Address of function to call in scratch register
51da26
     Register scratch = gen.rs()->getScratchRegister(gen);
51da26
     assert(scratch != REG_NULL && "cannot get a scratch register");
51da26
     gen.markRegDefined(scratch);
51da26
 
51da26
-    if (gen.addrSpace()->edit() != NULL) {
51da26
+    if (gen.addrSpace()->edit() != NULL
51da26
+	&& (gen.func()->obj() != callee->obj()
51da26
+	    || gen.addrSpace()->needsPIC())) {
51da26
         // gen.as.edit() checks if we are in rewriter mode
51da26
         Address dest = getInterModuleFuncAddr(callee, gen);
51da26
 
51da26
@@ -666,7 +668,6 @@ Register EmitterAARCH64::emitCall(opCode op,
51da26
         instruction insn;
51da26
         insn.clear();
51da26
         INSN_SET(insn, 31, 31, 0);
51da26
-        //INSN_SET(insn, 29, 30, disp & 0x3);
51da26
         INSN_SET(insn, 28, 28, 1);
51da26
         INSN_SET(insn, 5, 23, disp >> 2);
51da26
         INSN_SET(insn, 0, 4, scratch);