diff options
| author | Akira Hatanaka <ahatanaka@mips.com> | 2012-08-16 03:48:05 +0000 | 
|---|---|---|
| committer | Akira Hatanaka <ahatanaka@mips.com> | 2012-08-16 03:48:05 +0000 | 
| commit | 89d50b395706d38862471b869300472eed4c6d3d (patch) | |
| tree | 98d03119e9bb3d613c90ad0f66cd54fce09db70f /llvm/lib/Target | |
| parent | 52f04a2e8f4b88b1b9f69e22d4962998dd71f90b (diff) | |
| download | bcm5719-llvm-89d50b395706d38862471b869300472eed4c6d3d.tar.gz bcm5719-llvm-89d50b395706d38862471b869300472eed4c6d3d.zip | |
Add Android ABI to Mips backend to handle functions returning vectors of four
floats.
llvm-svn: 162008
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/Mips/Mips.td | 2 | ||||
| -rw-r--r-- | llvm/lib/Target/Mips/MipsCallingConv.td | 12 | ||||
| -rw-r--r-- | llvm/lib/Target/Mips/MipsSubtarget.h | 4 | 
3 files changed, 18 insertions, 0 deletions
| diff --git a/llvm/lib/Target/Mips/Mips.td b/llvm/lib/Target/Mips/Mips.td index 8548ae0b8b5..90f7942c5b4 100644 --- a/llvm/lib/Target/Mips/Mips.td +++ b/llvm/lib/Target/Mips/Mips.td @@ -44,6 +44,8 @@ def FeatureN64         : SubtargetFeature<"n64", "MipsABI", "N64",                                  "Enable n64 ABI">;  def FeatureEABI        : SubtargetFeature<"eabi", "MipsABI", "EABI",                                  "Enable eabi ABI">; +def FeatureAndroid     : SubtargetFeature<"android", "IsAndroid", "true", +                                "Target is android">;  def FeatureVFPU        : SubtargetFeature<"vfpu", "HasVFPU",                                  "true", "Enable vector FPU instructions.">;  def FeatureSEInReg     : SubtargetFeature<"seinreg", "HasSEInReg", "true", diff --git a/llvm/lib/Target/Mips/MipsCallingConv.td b/llvm/lib/Target/Mips/MipsCallingConv.td index 8aadefdcd14..19213fa6730 100644 --- a/llvm/lib/Target/Mips/MipsCallingConv.td +++ b/llvm/lib/Target/Mips/MipsCallingConv.td @@ -145,6 +145,17 @@ def RetCC_MipsEABI : CallingConv<[  ]>;  //===----------------------------------------------------------------------===// +// Mips Android Calling Convention +//===----------------------------------------------------------------------===// + +def RetCC_MipsAndroid : CallingConv<[ +  // f32 are returned in registers F0, F2, F1, F3 +  CCIfType<[f32], CCAssignToReg<[F0, F2, F1, F3]>>, + +  CCDelegateTo<RetCC_MipsO32> +]>; + +//===----------------------------------------------------------------------===//  // Mips FastCC Calling Convention  //===----------------------------------------------------------------------===//  def CC_MipsO32_FastCC : CallingConv<[ @@ -210,6 +221,7 @@ def RetCC_Mips : CallingConv<[    CCIfSubtarget<"isABI_EABI()", CCDelegateTo<RetCC_MipsEABI>>,    CCIfSubtarget<"isABI_N32()", CCDelegateTo<RetCC_MipsN>>,    CCIfSubtarget<"isABI_N64()", CCDelegateTo<RetCC_MipsN>>, +  CCIfSubtarget<"isAndroid()", CCDelegateTo<RetCC_MipsAndroid>>,    CCDelegateTo<RetCC_MipsO32>  ]>; diff --git a/llvm/lib/Target/Mips/MipsSubtarget.h b/llvm/lib/Target/Mips/MipsSubtarget.h index 3215c44be0e..ba15362f07b 100644 --- a/llvm/lib/Target/Mips/MipsSubtarget.h +++ b/llvm/lib/Target/Mips/MipsSubtarget.h @@ -89,6 +89,9 @@ protected:    // InMips16 -- can process Mips16 instructions    bool InMips16Mode; +  // IsAndroid -- target is android +  bool IsAndroid; +    InstrItineraryData InstrItins;  public: @@ -128,6 +131,7 @@ public:    bool isNotSingleFloat() const { return !IsSingleFloat; }    bool hasVFPU() const { return HasVFPU; }    bool inMips16Mode() const { return InMips16Mode; } +  bool isAndroid() const { return IsAndroid; }    bool isLinux() const { return IsLinux; }    bool hasStandardEncoding() const { return !inMips16Mode(); } | 

