|  | ; RUN: llc < %s | FileCheck %s -check-prefix=NOIPRA | 
|  | ; RUN: llc -enable-ipra < %s | FileCheck %s | 
|  |  | 
|  | target triple = "x86_64--" | 
|  |  | 
|  | define internal void @foo() norecurse { | 
|  | ; When IPRA is not enabled R15 will be saved by foo as it is callee saved reg. | 
|  | ; NOIPRA-LABEL: foo: | 
|  | ; NOIPRA: pushq	%r15 | 
|  | ; When IPRA is enabled none register should be saved as foo() is local function | 
|  | ; so we optimize it to save no registers. | 
|  | ; CHECK-LABEL: foo: | 
|  | ; CHECK-NOT: pushq %r15 | 
|  | call void asm sideeffect "movl	%r14d, %r15d", "~{r15}"() | 
|  | ret void | 
|  | } | 
|  |  | 
|  | define void @bar(i32 %X) { | 
|  | call void asm sideeffect "movl  %r12d, $0", "{r15}~{r12}"(i32 %X) | 
|  | ; As R15 is clobbered by foo() when IPRA is enabled value of R15 should be | 
|  | ; saved if register containing orignal value is also getting clobbered | 
|  | ; and reloaded after foo(), here original value is loaded back into R15D after | 
|  | ; call to foo. | 
|  | call void @foo() | 
|  | ; CHECK-LABEL: bar: | 
|  | ; CHECK: callq foo | 
|  | ; CHECK-NEXT: movl  %eax, %r15d | 
|  | call void asm sideeffect "movl  $0, %r12d", "{r15}~{r12}"(i32 %X) | 
|  | ret void | 
|  | } |