diff options
author | Chris Lattner <sabre@nondot.org> | 2002-05-03 21:40:37 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-05-03 21:40:37 +0000 |
commit | bdd15ad565d5881251f84a9fd13bf89f81d340ec (patch) | |
tree | e948af8353cf49d57942ee550ef89b46fbad09dc /lib | |
parent | 8a2e64ce87302a80d3d4877f498dfb1df3ba87e1 (diff) | |
download | external_llvm-bdd15ad565d5881251f84a9fd13bf89f81d340ec.zip external_llvm-bdd15ad565d5881251f84a9fd13bf89f81d340ec.tar.gz external_llvm-bdd15ad565d5881251f84a9fd13bf89f81d340ec.tar.bz2 |
Implement remainder
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2463 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/VMCore/ConstantFold.h | 24 | ||||
-rw-r--r-- | lib/VMCore/ConstantFolding.h | 24 |
2 files changed, 26 insertions, 22 deletions
diff --git a/lib/VMCore/ConstantFold.h b/lib/VMCore/ConstantFold.h index 14231cb..ef0a810 100644 --- a/lib/VMCore/ConstantFold.h +++ b/lib/VMCore/ConstantFold.h @@ -67,14 +67,11 @@ public: virtual Constant *op_not(const Constant *V) const = 0; // Binary Operators... - virtual Constant *add(const Constant *V1, - const Constant *V2) const = 0; - virtual Constant *sub(const Constant *V1, - const Constant *V2) const = 0; - virtual Constant *mul(const Constant *V1, - const Constant *V2) const = 0; - virtual Constant *div(const Constant *V1, - const Constant *V2) const = 0; + virtual Constant *add(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *sub(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *mul(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *div(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *rem(const Constant *V1, const Constant *V2) const = 0; virtual ConstantBool *lessthan(const Constant *V1, const Constant *V2) const = 0; @@ -127,7 +124,7 @@ private : }; -inline Constant *operator!(const Constant &V) { +inline Constant *operator~(const Constant &V) { return ConstRules::get(V)->op_not(&V); } @@ -153,6 +150,11 @@ inline Constant *operator/(const Constant &V1, const Constant &V2) { return ConstRules::get(V1)->div(&V1, &V2); } +inline Constant *operator%(const Constant &V1, const Constant &V2) { + assert(V1.getType() == V2.getType() && "Constant types must be identical!"); + return ConstRules::get(V1)->rem(&V1, &V2); +} + inline ConstantBool *operator<(const Constant &V1, const Constant &V2) { assert(V1.getType() == V2.getType() && "Constant types must be identical!"); @@ -192,8 +194,7 @@ inline Constant *ConstantFoldCastInstruction(const Constant *V, inline Constant *ConstantFoldUnaryInstruction(unsigned Opcode, const Constant *V) { switch (Opcode) { - case Instruction::Not: return !*V; - // TODO: Handle get element ptr instruction here in the future? GEP null? + case Instruction::Not: return ~*V; } return 0; } @@ -206,6 +207,7 @@ inline Constant *ConstantFoldBinaryInstruction(unsigned Opcode, case Instruction::Sub: return *V1 - *V2; case Instruction::Mul: return *V1 * *V2; case Instruction::Div: return *V1 / *V2; + case Instruction::Rem: return *V1 % *V2; case Instruction::SetEQ: return *V1 == *V2; case Instruction::SetNE: return *V1 != *V2; diff --git a/lib/VMCore/ConstantFolding.h b/lib/VMCore/ConstantFolding.h index 14231cb..ef0a810 100644 --- a/lib/VMCore/ConstantFolding.h +++ b/lib/VMCore/ConstantFolding.h @@ -67,14 +67,11 @@ public: virtual Constant *op_not(const Constant *V) const = 0; // Binary Operators... - virtual Constant *add(const Constant *V1, - const Constant *V2) const = 0; - virtual Constant *sub(const Constant *V1, - const Constant *V2) const = 0; - virtual Constant *mul(const Constant *V1, - const Constant *V2) const = 0; - virtual Constant *div(const Constant *V1, - const Constant *V2) const = 0; + virtual Constant *add(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *sub(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *mul(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *div(const Constant *V1, const Constant *V2) const = 0; + virtual Constant *rem(const Constant *V1, const Constant *V2) const = 0; virtual ConstantBool *lessthan(const Constant *V1, const Constant *V2) const = 0; @@ -127,7 +124,7 @@ private : }; -inline Constant *operator!(const Constant &V) { +inline Constant *operator~(const Constant &V) { return ConstRules::get(V)->op_not(&V); } @@ -153,6 +150,11 @@ inline Constant *operator/(const Constant &V1, const Constant &V2) { return ConstRules::get(V1)->div(&V1, &V2); } +inline Constant *operator%(const Constant &V1, const Constant &V2) { + assert(V1.getType() == V2.getType() && "Constant types must be identical!"); + return ConstRules::get(V1)->rem(&V1, &V2); +} + inline ConstantBool *operator<(const Constant &V1, const Constant &V2) { assert(V1.getType() == V2.getType() && "Constant types must be identical!"); @@ -192,8 +194,7 @@ inline Constant *ConstantFoldCastInstruction(const Constant *V, inline Constant *ConstantFoldUnaryInstruction(unsigned Opcode, const Constant *V) { switch (Opcode) { - case Instruction::Not: return !*V; - // TODO: Handle get element ptr instruction here in the future? GEP null? + case Instruction::Not: return ~*V; } return 0; } @@ -206,6 +207,7 @@ inline Constant *ConstantFoldBinaryInstruction(unsigned Opcode, case Instruction::Sub: return *V1 - *V2; case Instruction::Mul: return *V1 * *V2; case Instruction::Div: return *V1 / *V2; + case Instruction::Rem: return *V1 % *V2; case Instruction::SetEQ: return *V1 == *V2; case Instruction::SetNE: return *V1 != *V2; |