1*9880d681SAndroid Build Coastguard Worker //===---- Mips16HardFloatInfo.h for Mips16 Hard Float --------===// 2*9880d681SAndroid Build Coastguard Worker // 3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure 4*9880d681SAndroid Build Coastguard Worker // 5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source 6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details. 7*9880d681SAndroid Build Coastguard Worker // 8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 9*9880d681SAndroid Build Coastguard Worker // 10*9880d681SAndroid Build Coastguard Worker // This file defines some data structures relevant to the implementation of 11*9880d681SAndroid Build Coastguard Worker // Mips16 hard float. 12*9880d681SAndroid Build Coastguard Worker // 13*9880d681SAndroid Build Coastguard Worker // 14*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_LIB_TARGET_MIPS_MIPS16HARDFLOATINFO_H 17*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_MIPS_MIPS16HARDFLOATINFO_H 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker namespace llvm { 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker namespace Mips16HardFloatInfo { 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker // Return types that matter for hard float are: 24*9880d681SAndroid Build Coastguard Worker // float, double, complex float, and complex double 25*9880d681SAndroid Build Coastguard Worker // 26*9880d681SAndroid Build Coastguard Worker enum FPReturnVariant { FRet, DRet, CFRet, CDRet, NoFPRet }; 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Worker // 29*9880d681SAndroid Build Coastguard Worker // Parameter type that matter are float, (float, float), (float, double), 30*9880d681SAndroid Build Coastguard Worker // double, (double, double), (double, float) 31*9880d681SAndroid Build Coastguard Worker // 32*9880d681SAndroid Build Coastguard Worker enum FPParamVariant { FSig, FFSig, FDSig, DSig, DDSig, DFSig, NoSig }; 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Worker struct FuncSignature { 35*9880d681SAndroid Build Coastguard Worker FPParamVariant ParamSig; 36*9880d681SAndroid Build Coastguard Worker FPReturnVariant RetSig; 37*9880d681SAndroid Build Coastguard Worker }; 38*9880d681SAndroid Build Coastguard Worker 39*9880d681SAndroid Build Coastguard Worker struct FuncNameSignature { 40*9880d681SAndroid Build Coastguard Worker const char *Name; 41*9880d681SAndroid Build Coastguard Worker FuncSignature Signature; 42*9880d681SAndroid Build Coastguard Worker }; 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker extern const FuncNameSignature PredefinedFuncs[]; 45*9880d681SAndroid Build Coastguard Worker 46*9880d681SAndroid Build Coastguard Worker extern FuncSignature const *findFuncSignature(const char *name); 47*9880d681SAndroid Build Coastguard Worker } 48*9880d681SAndroid Build Coastguard Worker } 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Worker #endif 51