Return address register should be marked as "result" for the JMPL instruction
authorVikram S. Adve <vadve@cs.uiuc.edu>
Sat, 28 Sep 2002 17:00:15 +0000 (17:00 +0000)
committerVikram S. Adve <vadve@cs.uiuc.edu>
Sat, 28 Sep 2002 17:00:15 +0000 (17:00 +0000)
since it is defined by the instruction.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3966 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/SparcV9/SparcV9Instr.def

index 50afe2205d9ffcf72b4fbf3e2e595a9863c521e2..486a5ccbc86bce06e117ffca6a2e1f703c0a1482 100644 (file)
@@ -426,11 +426,12 @@ I(STD,    "std",  3, -1, B12, true , 0, 0,  SPARC_ST,  M_FLOAT_FLAG | M_STORE_FLA
 I(STFSR,  "st",         3, -1, B12, true , 0, 0,  SPARC_ST,  M_FLOAT_FLAG | M_STORE_FLAG)
 I(STXFSR, "stx",       3, -1, B12, true , 0, 0,  SPARC_ST,  M_FLOAT_FLAG | M_STORE_FLAG)
 
-// Call, Return and "Jump and link".
+// Call, Return and "Jump and link".  Operand (2) for JMPL is marked as
+// a "result" because JMPL stores the return address for the call in it.
 // Latency includes the delay slot.
 I(CALL  , "call",      1, -1, B29, true , 1, 2,  SPARC_CTI,  M_BRANCH_FLAG | M_CALL_FLAG)
-I(JMPLCALL, "jmpl",    3, -1, B12, true , 1, 2,  SPARC_CTI,  M_BRANCH_FLAG | M_CALL_FLAG )
-I(JMPLRET, "jmpl",     3, -1, B12, true , 1, 2,  SPARC_CTI,  M_BRANCH_FLAG | M_RET_FLAG)
+I(JMPLCALL, "jmpl",    3,  2, B12, true , 1, 2,  SPARC_CTI,  M_BRANCH_FLAG | M_CALL_FLAG )
+I(JMPLRET, "jmpl",     3,  2, B12, true , 1, 2,  SPARC_CTI,  M_BRANCH_FLAG | M_RET_FLAG)
 I(RETURN, "return",    2, -1,   0, false, 1, 2,  SPARC_CTI,  M_BRANCH_FLAG | M_RET_FLAG)
 
 // SAVE and restore instructions