mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-03 14:21:30 +00:00 
			
		
		
		
	When LiveVariables is adding implicit-def to model "partial dead", add the earlyclobber marker if the superreg def has it.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@84153 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		@@ -323,10 +323,21 @@ bool LiveVariables::HandlePhysRegKill(unsigned Reg, MachineInstr *MI) {
 | 
				
			|||||||
      // The last partial def kills the register.
 | 
					      // The last partial def kills the register.
 | 
				
			||||||
      LastPartDef->addOperand(MachineOperand::CreateReg(Reg, false/*IsDef*/,
 | 
					      LastPartDef->addOperand(MachineOperand::CreateReg(Reg, false/*IsDef*/,
 | 
				
			||||||
                                                true/*IsImp*/, true/*IsKill*/));
 | 
					                                                true/*IsImp*/, true/*IsKill*/));
 | 
				
			||||||
    else
 | 
					    else {
 | 
				
			||||||
 | 
					      MachineOperand *MO =
 | 
				
			||||||
 | 
					        LastRefOrPartRef->findRegisterDefOperand(Reg, false, TRI);
 | 
				
			||||||
 | 
					      bool NeedEC = MO->isEarlyClobber() && MO->getReg() != Reg;
 | 
				
			||||||
      // If the last reference is the last def, then it's not used at all.
 | 
					      // If the last reference is the last def, then it's not used at all.
 | 
				
			||||||
      // That is, unless we are currently processing the last reference itself.
 | 
					      // That is, unless we are currently processing the last reference itself.
 | 
				
			||||||
      LastRefOrPartRef->addRegisterDead(Reg, TRI, true);
 | 
					      LastRefOrPartRef->addRegisterDead(Reg, TRI, true);
 | 
				
			||||||
 | 
					      if (NeedEC) {
 | 
				
			||||||
 | 
					        // If we are adding a subreg def and the superreg def is marked early
 | 
				
			||||||
 | 
					        // clobber, add an early clobber marker to the subreg def.
 | 
				
			||||||
 | 
					        MO = LastRefOrPartRef->findRegisterDefOperand(Reg);
 | 
				
			||||||
 | 
					        if (MO)
 | 
				
			||||||
 | 
					          MO->setIsEarlyClobber();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  } else if (!PhysRegUse[Reg]) {
 | 
					  } else if (!PhysRegUse[Reg]) {
 | 
				
			||||||
    // Partial uses. Mark register def dead and add implicit def of
 | 
					    // Partial uses. Mark register def dead and add implicit def of
 | 
				
			||||||
    // sub-registers which are used.
 | 
					    // sub-registers which are used.
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										15
									
								
								test/CodeGen/X86/2009-10-14-LiveVariablesBug.ll
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								test/CodeGen/X86/2009-10-14-LiveVariablesBug.ll
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,15 @@
 | 
				
			|||||||
 | 
					; RUN: llc < %s -mtriple=i386-apple-darwin
 | 
				
			||||||
 | 
					; rdar://7299435
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@i = internal global i32 0                        ; <i32*> [#uses=1]
 | 
				
			||||||
 | 
					@llvm.used = appending global [1 x i8*] [i8* bitcast (void (i16)* @foo to i8*)], section "llvm.metadata" ; <[1 x i8*]*> [#uses=0]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define void @foo(i16 signext %source) nounwind ssp {
 | 
				
			||||||
 | 
					entry:
 | 
				
			||||||
 | 
					  %source_addr = alloca i16, align 2              ; <i16*> [#uses=2]
 | 
				
			||||||
 | 
					  store i16 %source, i16* %source_addr
 | 
				
			||||||
 | 
					  store i32 4, i32* @i, align 4
 | 
				
			||||||
 | 
					  call void asm sideeffect "# top of block", "~{dirflag},~{fpsr},~{flags},~{edi},~{esi},~{edx},~{ecx},~{eax}"() nounwind
 | 
				
			||||||
 | 
					  %asmtmp = call i16 asm sideeffect "movw $1, $0", "=={ax},*m,~{dirflag},~{fpsr},~{flags},~{memory}"(i16* %source_addr) nounwind ; <i16> [#uses=0]
 | 
				
			||||||
 | 
					  ret void
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user