2012-09-18 22:02:40 +00:00
|
|
|
//===- llvm/Transforms/Utils/IntegerDivision.h ------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file contains an implementation of 32bit integer division for targets
|
|
|
|
// that don't have native support. It's largely derived from compiler-rt's
|
|
|
|
// implementation of __udivsi3, but hand-tuned for targets that prefer less
|
|
|
|
// control flow.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2013-01-10 00:45:19 +00:00
|
|
|
#ifndef LLVM_TRANSFORMS_UTILS_INTEGERDIVISION_H
|
|
|
|
#define LLVM_TRANSFORMS_UTILS_INTEGERDIVISION_H
|
2012-09-18 22:02:40 +00:00
|
|
|
|
2012-09-19 15:55:03 +00:00
|
|
|
namespace llvm {
|
|
|
|
class BinaryOperator;
|
|
|
|
}
|
|
|
|
|
2012-09-18 22:02:40 +00:00
|
|
|
namespace llvm {
|
|
|
|
|
2012-09-26 01:55:01 +00:00
|
|
|
/// Generate code to calculate the remainder of two integers, replacing Rem
|
|
|
|
/// with the generated code. This currently generates code using the udiv
|
|
|
|
/// expansion, but future work includes generating more specialized code,
|
|
|
|
/// e.g. when more information about the operands are known. Currently only
|
|
|
|
/// implements 32bit scalar division (due to udiv's limitation), but future
|
|
|
|
/// work is removing this limitation.
|
|
|
|
///
|
|
|
|
/// @brief Replace Rem with generated code.
|
|
|
|
bool expandRemainder(BinaryOperator *Rem);
|
|
|
|
|
2012-09-19 16:03:57 +00:00
|
|
|
/// Generate code to divide two integers, replacing Div with the generated
|
|
|
|
/// code. This currently generates code similarly to compiler-rt's
|
|
|
|
/// implementations, but future work includes generating more specialized code
|
|
|
|
/// when more information about the operands are known. Currently only
|
|
|
|
/// implements 32bit scalar division, but future work is removing this
|
|
|
|
/// limitation.
|
|
|
|
///
|
|
|
|
/// @brief Replace Div with generated code.
|
2012-09-18 22:02:40 +00:00
|
|
|
bool expandDivision(BinaryOperator* Div);
|
|
|
|
|
2013-02-26 23:33:20 +00:00
|
|
|
/// Generate code to calculate the remainder of two integers, replacing Rem
|
|
|
|
/// with the generated code. Uses the above 32bit routine, therefore adequate
|
|
|
|
/// for targets with little or no support for less than 32 bit arithmetic.
|
|
|
|
///
|
|
|
|
/// @brief Replace Rem with generated code.
|
|
|
|
bool expandRemainderUpTo32Bits(BinaryOperator *Rem);
|
|
|
|
|
|
|
|
/// Generate code to divide two integers, replacing Div with the generated
|
|
|
|
/// code. Uses the above 32bit routine, therefore adequate for targets with
|
|
|
|
/// little or no support for less than 32 bit arithmetic.
|
|
|
|
///
|
|
|
|
/// @brief Replace Rem with generated code.
|
|
|
|
bool expandDivisionUpTo32Bits(BinaryOperator *Div);
|
|
|
|
|
2012-09-18 22:02:40 +00:00
|
|
|
} // End llvm namespace
|
|
|
|
|
|
|
|
#endif
|