qzdoom/tools/drawergen/ssa/ssa_int.cpp
2016-11-28 17:31:56 +01:00

208 lines
5 KiB
C++

/*
** SSA int32
** Copyright (c) 2016 Magnus Norddahl
**
** This software is provided 'as-is', without any express or implied
** warranty. In no event will the authors be held liable for any damages
** arising from the use of this software.
**
** Permission is granted to anyone to use this software for any purpose,
** including commercial applications, and to alter it and redistribute it
** freely, subject to the following restrictions:
**
** 1. The origin of this software must not be misrepresented; you must not
** claim that you wrote the original software. If you use this software
** in a product, an acknowledgment in the product documentation would be
** appreciated but is not required.
** 2. Altered source versions must be plainly marked as such, and must not be
** misrepresented as being the original software.
** 3. This notice may not be removed or altered from any source distribution.
**
*/
#include "precomp.h"
#include "ssa_int.h"
#include "ssa_float.h"
#include "ssa_ubyte.h"
#include "ssa_bool.h"
#include "ssa_scope.h"
SSAInt::SSAInt()
: v(0)
{
}
SSAInt::SSAInt(int constant)
: v(0)
{
v = llvm::ConstantInt::get(SSAScope::context(), llvm::APInt(32, constant, true));
}
SSAInt::SSAInt(SSAFloat f, bool uint)
: v(0)
{
if (uint)
v = SSAScope::builder().CreateFPToUI(f.v, llvm::Type::getInt32Ty(SSAScope::context()), SSAScope::hint());
else
v = SSAScope::builder().CreateFPToSI(f.v, llvm::Type::getInt32Ty(SSAScope::context()), SSAScope::hint());
}
SSAInt::SSAInt(llvm::Value *v)
: v(v)
{
}
llvm::Type *SSAInt::llvm_type()
{
return llvm::Type::getInt32Ty(SSAScope::context());
}
SSAInt SSAInt::MIN(SSAInt a, SSAInt b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateSelect((a < b).v, a.v, b.v, SSAScope::hint()));
}
SSAInt SSAInt::MAX(SSAInt a, SSAInt b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateSelect((a > b).v, a.v, b.v, SSAScope::hint()));
}
SSAInt SSAInt::clamp(SSAInt a, SSAInt b, SSAInt c)
{
return SSAInt::MAX(SSAInt::MIN(a, c), b);
}
SSAInt SSAInt::add(SSAInt b, bool no_unsigned_wrap, bool no_signed_wrap)
{
return SSAInt::from_llvm(SSAScope::builder().CreateAdd(v, b.v, SSAScope::hint(), no_unsigned_wrap, no_signed_wrap));
}
SSAInt SSAInt::ashr(int bits)
{
return SSAInt::from_llvm(SSAScope::builder().CreateAShr(v, bits, SSAScope::hint()));
}
SSAUByte SSAInt::trunc_ubyte()
{
return SSAUByte::from_llvm(SSAScope::builder().CreateTrunc(v, SSAUByte::llvm_type(), SSAScope::hint()));
}
SSAInt operator+(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateAdd(a.v, b.v, SSAScope::hint()));
}
SSAInt operator-(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateSub(a.v, b.v, SSAScope::hint()));
}
SSAInt operator*(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateMul(a.v, b.v, SSAScope::hint()));
}
SSAInt operator/(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateSDiv(a.v, b.v, SSAScope::hint()));
}
SSAInt operator%(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateSRem(a.v, b.v, SSAScope::hint()));
}
SSAInt operator+(int a, const SSAInt &b)
{
return SSAInt(a) + b;
}
SSAInt operator-(int a, const SSAInt &b)
{
return SSAInt(a) - b;
}
SSAInt operator*(int a, const SSAInt &b)
{
return SSAInt(a) * b;
}
SSAInt operator/(int a, const SSAInt &b)
{
return SSAInt(a) / b;
}
SSAInt operator%(int a, const SSAInt &b)
{
return SSAInt(a) % b;
}
SSAInt operator+(const SSAInt &a, int b)
{
return a + SSAInt(b);
}
SSAInt operator-(const SSAInt &a, int b)
{
return a - SSAInt(b);
}
SSAInt operator*(const SSAInt &a, int b)
{
return a * SSAInt(b);
}
SSAInt operator/(const SSAInt &a, int b)
{
return a / SSAInt(b);
}
SSAInt operator%(const SSAInt &a, int b)
{
return a % SSAInt(b);
}
SSAInt operator<<(const SSAInt &a, int bits)
{
return SSAInt::from_llvm(SSAScope::builder().CreateShl(a.v, bits, SSAScope::hint()));
}
SSAInt operator>>(const SSAInt &a, int bits)
{
return SSAInt::from_llvm(SSAScope::builder().CreateLShr(a.v, bits, SSAScope::hint()));
}
SSAInt operator<<(const SSAInt &a, const SSAInt &bits)
{
return SSAInt::from_llvm(SSAScope::builder().CreateShl(a.v, bits.v, SSAScope::hint()));
}
SSAInt operator>>(const SSAInt &a, const SSAInt &bits)
{
return SSAInt::from_llvm(SSAScope::builder().CreateLShr(a.v, bits.v, SSAScope::hint()));
}
SSAInt operator&(const SSAInt &a, int b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateAnd(a.v, b, SSAScope::hint()));
}
SSAInt operator&(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateAnd(a.v, b.v, SSAScope::hint()));
}
SSAInt operator|(const SSAInt &a, int b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateOr(a.v, b, SSAScope::hint()));
}
SSAInt operator|(const SSAInt &a, const SSAInt &b)
{
return SSAInt::from_llvm(SSAScope::builder().CreateOr(a.v, b.v, SSAScope::hint()));
}
SSAInt operator~(const SSAInt &a)
{
return SSAInt::from_llvm(SSAScope::builder().CreateNot(a.v, SSAScope::hint()));
}