OSDN Git Service

Use existing information.
authorJim Laskey <jlaskey@mac.com>
Mon, 10 Apr 2006 23:09:19 +0000 (23:09 +0000)
committerJim Laskey <jlaskey@mac.com>
Mon, 10 Apr 2006 23:09:19 +0000 (23:09 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@27574 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Target/MRegisterInfo.h
lib/CodeGen/DwarfWriter.cpp
lib/Target/MRegisterInfo.cpp

index 00d9d6b..064a1b5 100644 (file)
@@ -359,11 +359,6 @@ public:
   /// address can be found.
   virtual unsigned getRARegister() const = 0;
                             
-  /// getStackDirection - This method should return the factor by which stacks
-  /// grow.  The tyical value is -4 which is the grows negatively in 4 byte
-  /// increments.
-  virtual int getStackDirection() const;
-  
   /// getLocation - This method should return the actual location of a frame
   /// variable given the frame index.  The location is returned in ML.
   /// Subclasses should override this method for special handling of frame
index fb4c65d..bb41dc0 100644 (file)
@@ -25,6 +25,7 @@
 #include "llvm/Support/Mangler.h"
 #include "llvm/Target/MRegisterInfo.h"
 #include "llvm/Target/TargetMachine.h"
+#include "llvm/Target/TargetFrameInfo.h"
 
 #include <iostream>
 
@@ -1829,8 +1830,13 @@ void DwarfWriter::EmitFrameMoves(const char *BaseLabel, unsigned BaseLabelID,
           EmitULEB128Bytes(RI->getDwarfRegNum(Src.getRegister()));
           EOL("Register");
         }
-          
-        EmitULEB128Bytes(Src.getOffset() / RI->getStackDirection());
+        
+        int stackGrowth =
+            Asm->TM.getFrameInfo()->getStackGrowthDirection() ==
+              TargetFrameInfo::StackGrowsUp ?
+            AddressSize : -AddressSize;
+        
+        EmitULEB128Bytes(Src.getOffset() / stackGrowth);
         EOL("Offset");
       } else {
       }
@@ -2049,6 +2055,11 @@ void DwarfWriter::EmitDebugLines() const {
 /// EmitInitialDebugFrame - Emit common frame info into a debug frame section.
 ///
 void DwarfWriter::EmitInitialDebugFrame() {
+  int stackGrowth =
+      Asm->TM.getFrameInfo()->getStackGrowthDirection() ==
+        TargetFrameInfo::StackGrowsUp ?
+      AddressSize : -AddressSize;
+
   // Start the dwarf frame section.
   Asm->SwitchSection(DwarfFrameSection, 0);
 
@@ -2061,7 +2072,7 @@ void DwarfWriter::EmitInitialDebugFrame() {
   EmitInt8(DW_CIE_VERSION); EOL("CIE Version");
   EmitString("");  EOL("CIE Augmentation");
   EmitULEB128Bytes(1); EOL("CIE Code Alignment Factor");
-  EmitSLEB128Bytes(RI->getStackDirection()); EOL("CIE Data Alignment Factor");   
+  EmitSLEB128Bytes(stackGrowth); EOL("CIE Data Alignment Factor");   
   EmitInt8(RI->getDwarfRegNum(RI->getRARegister())); EOL("CIE RA Column");
   
   std::vector<MachineMove *> Moves;
index 4ddfe9f..920bb5d 100644 (file)
@@ -44,13 +44,6 @@ std::vector<bool> MRegisterInfo::getAllocatableSet(MachineFunction &MF) const {
   return Allocatable;
 }
 
-/// getStackDirection - This method should return the factor by which stacks
-/// grow.  The tyical value is -4 which is the grows negatively in 4 byte
-/// increments.
-int MRegisterInfo::getStackDirection() const {
-  return -sizeof(int32_t);
-}
-
 /// getLocation - This method should return the actual location of a frame
 /// variable given the frame index.  The location is returned in ML.
 /// Subclasses should override this method for special handling of frame