1*9880d681SAndroid Build Coastguard Worker //===-- HexagonTargetTransformInfo.cpp - Hexagon specific TTI pass --------===// 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 /// \file 9*9880d681SAndroid Build Coastguard Worker /// This file implements a TargetTransformInfo analysis pass specific to the 10*9880d681SAndroid Build Coastguard Worker /// Hexagon target machine. It uses the target's detailed information to provide 11*9880d681SAndroid Build Coastguard Worker /// more precise answers to certain TTI queries, while letting the target 12*9880d681SAndroid Build Coastguard Worker /// independent and default TTI implementations handle the rest. 13*9880d681SAndroid Build Coastguard Worker /// 14*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker #include "HexagonTargetTransformInfo.h" 17*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Debug.h" 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker using namespace llvm; 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker #define DEBUG_TYPE "hexagontti" 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker TargetTransformInfo::PopcntSupportKind getPopcntSupport(unsigned IntTyWidthInBit) const24*9880d681SAndroid Build Coastguard WorkerHexagonTTIImpl::getPopcntSupport(unsigned IntTyWidthInBit) const { 25*9880d681SAndroid Build Coastguard Worker // Return Fast Hardware support as every input < 64 bits will be promoted 26*9880d681SAndroid Build Coastguard Worker // to 64 bits. 27*9880d681SAndroid Build Coastguard Worker return TargetTransformInfo::PSK_FastHardware; 28*9880d681SAndroid Build Coastguard Worker } 29*9880d681SAndroid Build Coastguard Worker 30*9880d681SAndroid Build Coastguard Worker // The Hexagon target can unroll loops with run-time trip counts. getUnrollingPreferences(Loop * L,TTI::UnrollingPreferences & UP)31*9880d681SAndroid Build Coastguard Workervoid HexagonTTIImpl::getUnrollingPreferences(Loop *L, 32*9880d681SAndroid Build Coastguard Worker TTI::UnrollingPreferences &UP) { 33*9880d681SAndroid Build Coastguard Worker UP.Runtime = UP.Partial = true; 34*9880d681SAndroid Build Coastguard Worker } 35*9880d681SAndroid Build Coastguard Worker getNumberOfRegisters(bool vector) const36*9880d681SAndroid Build Coastguard Workerunsigned HexagonTTIImpl::getNumberOfRegisters(bool vector) const { 37*9880d681SAndroid Build Coastguard Worker return vector ? 0 : 32; 38*9880d681SAndroid Build Coastguard Worker } 39